aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAnton Blanchard <anton@samba.org>2015-04-08 23:51:30 -0400
committerIngo Molnar <mingo@kernel.org>2015-04-09 03:40:23 -0400
commit55dd0df781e58ec23d218376ea4a676e7362a98c (patch)
tree2401cee7d708bb538a2ed0251f675a01cda71407
parent01ac33c1f907b366dcc50551316b372f1519cca9 (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.h5
-rw-r--r--arch/arm64/include/asm/jump_label.h8
-rw-r--r--arch/mips/include/asm/jump_label.h7
-rw-r--r--arch/s390/include/asm/jump_label.h3
-rw-r--r--arch/sparc/include/asm/jump_label.h5
-rw-r--r--arch/x86/include/asm/jump_label.h5
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
32typedef u32 jump_label_t; 30typedef u32 jump_label_t;
33 31
34struct jump_entry { 32struct 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
28static __always_inline bool arch_static_branch(struct static_key *key) 29static __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
44typedef u64 jump_label_t; 43typedef u64 jump_label_t;
45 44
46struct jump_entry { 45struct 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
45typedef u64 jump_label_t; 43typedef 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
27typedef u32 jump_label_t; 25typedef u32 jump_label_t;
28 26
29struct jump_entry { 27struct 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
36typedef u64 jump_label_t; 34typedef 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