diff options
author | Anton Blanchard <anton@samba.org> | 2015-04-08 23:51:30 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@kernel.org> | 2015-04-09 03:40:23 -0400 |
commit | 55dd0df781e58ec23d218376ea4a676e7362a98c (patch) | |
tree | 2401cee7d708bb538a2ed0251f675a01cda71407 | |
parent | 01ac33c1f907b366dcc50551316b372f1519cca9 (diff) |
jump_label: Allow asm/jump_label.h to be included in assembly
Wrap asm/jump_label.h for all archs with #ifndef __ASSEMBLY__.
Since these are kernel only headers, we don't need #ifdef
__KERNEL__ so can simplify things a bit.
If an architecture wants to use jump labels in assembly, it
will still need to define a macro to create the __jump_table
entries (see ARCH_STATIC_BRANCH in the powerpc asm/jump_label.h
for an example).
Signed-off-by: Anton Blanchard <anton@samba.org>
Acked-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Cc: Andrew Morton <akpm@linux-foundation.org>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: Paul E. McKenney <paulmck@linux.vnet.ibm.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Thomas Gleixner <tglx@linutronix.de>
Cc: benh@kernel.crashing.org
Cc: catalin.marinas@arm.com
Cc: davem@davemloft.net
Cc: heiko.carstens@de.ibm.com
Cc: jbaron@akamai.com
Cc: linux@arm.linux.org.uk
Cc: linuxppc-dev@lists.ozlabs.org
Cc: liuj97@gmail.com
Cc: mgorman@suse.de
Cc: mmarek@suse.cz
Cc: mpe@ellerman.id.au
Cc: paulus@samba.org
Cc: ralf@linux-mips.org
Cc: rostedt@goodmis.org
Cc: schwidefsky@de.ibm.com
Cc: will.deacon@arm.com
Link: http://lkml.kernel.org/r/1428551492-21977-1-git-send-email-anton@samba.org
Signed-off-by: Ingo Molnar <mingo@kernel.org>
-rw-r--r-- | arch/arm/include/asm/jump_label.h | 5 | ||||
-rw-r--r-- | arch/arm64/include/asm/jump_label.h | 8 | ||||
-rw-r--r-- | arch/mips/include/asm/jump_label.h | 7 | ||||
-rw-r--r-- | arch/s390/include/asm/jump_label.h | 3 | ||||
-rw-r--r-- | arch/sparc/include/asm/jump_label.h | 5 | ||||
-rw-r--r-- | arch/x86/include/asm/jump_label.h | 5 |
6 files changed, 16 insertions, 17 deletions
diff --git a/arch/arm/include/asm/jump_label.h b/arch/arm/include/asm/jump_label.h index 70f9b9bfb1f9..5f337dc5c108 100644 --- a/arch/arm/include/asm/jump_label.h +++ b/arch/arm/include/asm/jump_label.h | |||
@@ -1,7 +1,7 @@ | |||
1 | #ifndef _ASM_ARM_JUMP_LABEL_H | 1 | #ifndef _ASM_ARM_JUMP_LABEL_H |
2 | #define _ASM_ARM_JUMP_LABEL_H | 2 | #define _ASM_ARM_JUMP_LABEL_H |
3 | 3 | ||
4 | #ifdef __KERNEL__ | 4 | #ifndef __ASSEMBLY__ |
5 | 5 | ||
6 | #include <linux/types.h> | 6 | #include <linux/types.h> |
7 | 7 | ||
@@ -27,8 +27,6 @@ l_yes: | |||
27 | return true; | 27 | return true; |
28 | } | 28 | } |
29 | 29 | ||
30 | #endif /* __KERNEL__ */ | ||
31 | |||
32 | typedef u32 jump_label_t; | 30 | typedef u32 jump_label_t; |
33 | 31 | ||
34 | struct jump_entry { | 32 | struct jump_entry { |
@@ -37,4 +35,5 @@ struct jump_entry { | |||
37 | jump_label_t key; | 35 | jump_label_t key; |
38 | }; | 36 | }; |
39 | 37 | ||
38 | #endif /* __ASSEMBLY__ */ | ||
40 | #endif | 39 | #endif |
diff --git a/arch/arm64/include/asm/jump_label.h b/arch/arm64/include/asm/jump_label.h index 076a1c714049..c0e5165c2f76 100644 --- a/arch/arm64/include/asm/jump_label.h +++ b/arch/arm64/include/asm/jump_label.h | |||
@@ -18,11 +18,12 @@ | |||
18 | */ | 18 | */ |
19 | #ifndef __ASM_JUMP_LABEL_H | 19 | #ifndef __ASM_JUMP_LABEL_H |
20 | #define __ASM_JUMP_LABEL_H | 20 | #define __ASM_JUMP_LABEL_H |
21 | |||
22 | #ifndef __ASSEMBLY__ | ||
23 | |||
21 | #include <linux/types.h> | 24 | #include <linux/types.h> |
22 | #include <asm/insn.h> | 25 | #include <asm/insn.h> |
23 | 26 | ||
24 | #ifdef __KERNEL__ | ||
25 | |||
26 | #define JUMP_LABEL_NOP_SIZE AARCH64_INSN_SIZE | 27 | #define JUMP_LABEL_NOP_SIZE AARCH64_INSN_SIZE |
27 | 28 | ||
28 | static __always_inline bool arch_static_branch(struct static_key *key) | 29 | static __always_inline bool arch_static_branch(struct static_key *key) |
@@ -39,8 +40,6 @@ l_yes: | |||
39 | return true; | 40 | return true; |
40 | } | 41 | } |
41 | 42 | ||
42 | #endif /* __KERNEL__ */ | ||
43 | |||
44 | typedef u64 jump_label_t; | 43 | typedef u64 jump_label_t; |
45 | 44 | ||
46 | struct jump_entry { | 45 | struct jump_entry { |
@@ -49,4 +48,5 @@ struct jump_entry { | |||
49 | jump_label_t key; | 48 | jump_label_t key; |
50 | }; | 49 | }; |
51 | 50 | ||
51 | #endif /* __ASSEMBLY__ */ | ||
52 | #endif /* __ASM_JUMP_LABEL_H */ | 52 | #endif /* __ASM_JUMP_LABEL_H */ |
diff --git a/arch/mips/include/asm/jump_label.h b/arch/mips/include/asm/jump_label.h index fdbff44e5482..608aa57799c8 100644 --- a/arch/mips/include/asm/jump_label.h +++ b/arch/mips/include/asm/jump_label.h | |||
@@ -8,9 +8,9 @@ | |||
8 | #ifndef _ASM_MIPS_JUMP_LABEL_H | 8 | #ifndef _ASM_MIPS_JUMP_LABEL_H |
9 | #define _ASM_MIPS_JUMP_LABEL_H | 9 | #define _ASM_MIPS_JUMP_LABEL_H |
10 | 10 | ||
11 | #include <linux/types.h> | 11 | #ifndef __ASSEMBLY__ |
12 | 12 | ||
13 | #ifdef __KERNEL__ | 13 | #include <linux/types.h> |
14 | 14 | ||
15 | #define JUMP_LABEL_NOP_SIZE 4 | 15 | #define JUMP_LABEL_NOP_SIZE 4 |
16 | 16 | ||
@@ -39,8 +39,6 @@ l_yes: | |||
39 | return true; | 39 | return true; |
40 | } | 40 | } |
41 | 41 | ||
42 | #endif /* __KERNEL__ */ | ||
43 | |||
44 | #ifdef CONFIG_64BIT | 42 | #ifdef CONFIG_64BIT |
45 | typedef u64 jump_label_t; | 43 | typedef u64 jump_label_t; |
46 | #else | 44 | #else |
@@ -53,4 +51,5 @@ struct jump_entry { | |||
53 | jump_label_t key; | 51 | jump_label_t key; |
54 | }; | 52 | }; |
55 | 53 | ||
54 | #endif /* __ASSEMBLY__ */ | ||
56 | #endif /* _ASM_MIPS_JUMP_LABEL_H */ | 55 | #endif /* _ASM_MIPS_JUMP_LABEL_H */ |
diff --git a/arch/s390/include/asm/jump_label.h b/arch/s390/include/asm/jump_label.h index 58642fd29c87..2b77e235b5fb 100644 --- a/arch/s390/include/asm/jump_label.h +++ b/arch/s390/include/asm/jump_label.h | |||
@@ -1,6 +1,8 @@ | |||
1 | #ifndef _ASM_S390_JUMP_LABEL_H | 1 | #ifndef _ASM_S390_JUMP_LABEL_H |
2 | #define _ASM_S390_JUMP_LABEL_H | 2 | #define _ASM_S390_JUMP_LABEL_H |
3 | 3 | ||
4 | #ifndef __ASSEMBLY__ | ||
5 | |||
4 | #include <linux/types.h> | 6 | #include <linux/types.h> |
5 | 7 | ||
6 | #define JUMP_LABEL_NOP_SIZE 6 | 8 | #define JUMP_LABEL_NOP_SIZE 6 |
@@ -39,4 +41,5 @@ struct jump_entry { | |||
39 | jump_label_t key; | 41 | jump_label_t key; |
40 | }; | 42 | }; |
41 | 43 | ||
44 | #endif /* __ASSEMBLY__ */ | ||
42 | #endif | 45 | #endif |
diff --git a/arch/sparc/include/asm/jump_label.h b/arch/sparc/include/asm/jump_label.h index ec2e2e2aba7d..cc9b04a2b11b 100644 --- a/arch/sparc/include/asm/jump_label.h +++ b/arch/sparc/include/asm/jump_label.h | |||
@@ -1,7 +1,7 @@ | |||
1 | #ifndef _ASM_SPARC_JUMP_LABEL_H | 1 | #ifndef _ASM_SPARC_JUMP_LABEL_H |
2 | #define _ASM_SPARC_JUMP_LABEL_H | 2 | #define _ASM_SPARC_JUMP_LABEL_H |
3 | 3 | ||
4 | #ifdef __KERNEL__ | 4 | #ifndef __ASSEMBLY__ |
5 | 5 | ||
6 | #include <linux/types.h> | 6 | #include <linux/types.h> |
7 | 7 | ||
@@ -22,8 +22,6 @@ l_yes: | |||
22 | return true; | 22 | return true; |
23 | } | 23 | } |
24 | 24 | ||
25 | #endif /* __KERNEL__ */ | ||
26 | |||
27 | typedef u32 jump_label_t; | 25 | typedef u32 jump_label_t; |
28 | 26 | ||
29 | struct jump_entry { | 27 | struct jump_entry { |
@@ -32,4 +30,5 @@ struct jump_entry { | |||
32 | jump_label_t key; | 30 | jump_label_t key; |
33 | }; | 31 | }; |
34 | 32 | ||
33 | #endif /* __ASSEMBLY__ */ | ||
35 | #endif | 34 | #endif |
diff --git a/arch/x86/include/asm/jump_label.h b/arch/x86/include/asm/jump_label.h index 6a2cefb4395a..a4c1cf7e93f8 100644 --- a/arch/x86/include/asm/jump_label.h +++ b/arch/x86/include/asm/jump_label.h | |||
@@ -1,7 +1,7 @@ | |||
1 | #ifndef _ASM_X86_JUMP_LABEL_H | 1 | #ifndef _ASM_X86_JUMP_LABEL_H |
2 | #define _ASM_X86_JUMP_LABEL_H | 2 | #define _ASM_X86_JUMP_LABEL_H |
3 | 3 | ||
4 | #ifdef __KERNEL__ | 4 | #ifndef __ASSEMBLY__ |
5 | 5 | ||
6 | #include <linux/stringify.h> | 6 | #include <linux/stringify.h> |
7 | #include <linux/types.h> | 7 | #include <linux/types.h> |
@@ -30,8 +30,6 @@ l_yes: | |||
30 | return true; | 30 | return true; |
31 | } | 31 | } |
32 | 32 | ||
33 | #endif /* __KERNEL__ */ | ||
34 | |||
35 | #ifdef CONFIG_X86_64 | 33 | #ifdef CONFIG_X86_64 |
36 | typedef u64 jump_label_t; | 34 | typedef u64 jump_label_t; |
37 | #else | 35 | #else |
@@ -44,4 +42,5 @@ struct jump_entry { | |||
44 | jump_label_t key; | 42 | jump_label_t key; |
45 | }; | 43 | }; |
46 | 44 | ||
45 | #endif /* __ASSEMBLY__ */ | ||
47 | #endif | 46 | #endif |