1 // SPDX-License-Identifier: GPL-2.0
2 #include <linux/kernel.h>
3 #include <linux/types.h>
4 #include <linux/mutex.h>
7 #include <linux/jump_label.h>
8 #include <linux/memory.h>
10 #include <asm/cacheflush.h>
12 #ifdef HAVE_JUMP_LABEL
14 void arch_jump_label_transform(struct jump_entry
*entry
,
15 enum jump_label_type type
)
17 u32
*insn
= (u32
*) (unsigned long) entry
->code
;
20 if (type
== JUMP_LABEL_JMP
) {
21 s32 off
= (s32
)entry
->target
- (s32
)entry
->code
;
22 bool use_v9_branch
= false;
27 if (off
<= 0xfffff && off
>= -0x100000)
31 /* WDISP19 - target is . + immed << 2 */
32 /* ba,pt %xcc, . + off */
33 val
= 0x10680000 | (((u32
) off
>> 2) & 0x7ffff);
35 /* WDISP22 - target is . + immed << 2 */
36 BUG_ON(off
> 0x7fffff);
37 BUG_ON(off
< -0x800000);
39 val
= 0x10800000 | (((u32
) off
>> 2) & 0x3fffff);
45 mutex_lock(&text_mutex
);
48 mutex_unlock(&text_mutex
);