mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 8befc9f23c
			
		
	
	
		8befc9f23c
		
	
	
	
	
		
			
			jump_label.c needs asm/cacheflush.h to get flushi(). kgdb_64.c needs asm/cacheflush.h to get flushw_all(). Signed-off-by: David S. Miller <davem@davemloft.net>
		
			
				
	
	
		
			42 lines
		
	
	
		
			794 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			42 lines
		
	
	
		
			794 B
		
	
	
	
		
			C
		
	
	
	
	
	
| #include <linux/kernel.h>
 | |
| #include <linux/types.h>
 | |
| #include <linux/mutex.h>
 | |
| #include <linux/cpu.h>
 | |
| 
 | |
| #include <linux/jump_label.h>
 | |
| #include <linux/memory.h>
 | |
| 
 | |
| #include <asm/cacheflush.h>
 | |
| 
 | |
| #ifdef HAVE_JUMP_LABEL
 | |
| 
 | |
| void arch_jump_label_transform(struct jump_entry *entry,
 | |
| 			       enum jump_label_type type)
 | |
| {
 | |
| 	u32 val;
 | |
| 	u32 *insn = (u32 *) (unsigned long) entry->code;
 | |
| 
 | |
| 	if (type == JUMP_LABEL_ENABLE) {
 | |
| 		s32 off = (s32)entry->target - (s32)entry->code;
 | |
| 
 | |
| #ifdef CONFIG_SPARC64
 | |
| 		/* ba,pt %xcc, . + (off << 2) */
 | |
| 		val = 0x10680000 | ((u32) off >> 2);
 | |
| #else
 | |
| 		/* ba . + (off << 2) */
 | |
| 		val = 0x10800000 | ((u32) off >> 2);
 | |
| #endif
 | |
| 	} else {
 | |
| 		val = 0x01000000;
 | |
| 	}
 | |
| 
 | |
| 	get_online_cpus();
 | |
| 	mutex_lock(&text_mutex);
 | |
| 	*insn = val;
 | |
| 	flushi(insn);
 | |
| 	mutex_unlock(&text_mutex);
 | |
| 	put_online_cpus();
 | |
| }
 | |
| 
 | |
| #endif
 |