blob: 34f7b6980d21dc81dbdd54b75e4568685f885d29 [file] [log] [blame]
Rabin Vincent09f05d82012-02-18 17:52:41 +01001#ifndef _ASM_ARM_JUMP_LABEL_H
2#define _ASM_ARM_JUMP_LABEL_H
3
Anton Blanchard55dd0df2015-04-09 13:51:30 +10004#ifndef __ASSEMBLY__
Rabin Vincent09f05d82012-02-18 17:52:41 +01005
6#include <linux/types.h>
Peter Zijlstra11276d52015-07-24 15:09:55 +02007#include <asm/unified.h>
Rabin Vincent09f05d82012-02-18 17:52:41 +01008
9#define JUMP_LABEL_NOP_SIZE 4
10
Peter Zijlstra11276d52015-07-24 15:09:55 +020011static __always_inline bool arch_static_branch(struct static_key *key, bool branch)
Rabin Vincent09f05d82012-02-18 17:52:41 +010012{
Ingo Molnar3f0116c2013-10-10 10:16:30 +020013 asm_volatile_goto("1:\n\t"
Peter Zijlstra11276d52015-07-24 15:09:55 +020014 WASM(nop) "\n\t"
Rabin Vincent09f05d82012-02-18 17:52:41 +010015 ".pushsection __jump_table, \"aw\"\n\t"
16 ".word 1b, %l[l_yes], %c0\n\t"
17 ".popsection\n\t"
Peter Zijlstra11276d52015-07-24 15:09:55 +020018 : : "i" (&((char *)key)[branch]) : : l_yes);
19
20 return false;
21l_yes:
22 return true;
23}
24
25static __always_inline bool arch_static_branch_jump(struct static_key *key, bool branch)
26{
27 asm_volatile_goto("1:\n\t"
28 WASM(b) " %l[l_yes]\n\t"
29 ".pushsection __jump_table, \"aw\"\n\t"
30 ".word 1b, %l[l_yes], %c0\n\t"
31 ".popsection\n\t"
32 : : "i" (&((char *)key)[branch]) : : l_yes);
Rabin Vincent09f05d82012-02-18 17:52:41 +010033
34 return false;
35l_yes:
36 return true;
37}
38
Rabin Vincent09f05d82012-02-18 17:52:41 +010039typedef u32 jump_label_t;
40
41struct jump_entry {
42 jump_label_t code;
43 jump_label_t target;
44 jump_label_t key;
45};
46
Anton Blanchard55dd0df2015-04-09 13:51:30 +100047#endif /* __ASSEMBLY__ */
Rabin Vincent09f05d82012-02-18 17:52:41 +010048#endif