| #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> | 
 |  | 
 | #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(); | 
 | } | 
 |  | 
 | void arch_jump_label_text_poke_early(jump_label_t addr) | 
 | { | 
 | 	u32 *insn_p = (u32 *) (unsigned long) addr; | 
 |  | 
 | 	*insn_p = 0x01000000; | 
 | 	flushi(insn_p); | 
 | } | 
 |  | 
 | #endif |