Commit 55dd0df7 authored by Anton Blanchard's avatar Anton Blanchard Committed by Ingo Molnar

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: default avatarAnton Blanchard <anton@samba.org>
Acked-by: default avatarPeter 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.orgSigned-off-by: default avatarIngo Molnar <mingo@kernel.org>
parent 01ac33c1
#ifndef _ASM_ARM_JUMP_LABEL_H #ifndef _ASM_ARM_JUMP_LABEL_H
#define _ASM_ARM_JUMP_LABEL_H #define _ASM_ARM_JUMP_LABEL_H
#ifdef __KERNEL__ #ifndef __ASSEMBLY__
#include <linux/types.h> #include <linux/types.h>
...@@ -27,8 +27,6 @@ static __always_inline bool arch_static_branch(struct static_key *key) ...@@ -27,8 +27,6 @@ static __always_inline bool arch_static_branch(struct static_key *key)
return true; return true;
} }
#endif /* __KERNEL__ */
typedef u32 jump_label_t; typedef u32 jump_label_t;
struct jump_entry { struct jump_entry {
...@@ -37,4 +35,5 @@ struct jump_entry { ...@@ -37,4 +35,5 @@ struct jump_entry {
jump_label_t key; jump_label_t key;
}; };
#endif /* __ASSEMBLY__ */
#endif #endif
...@@ -18,11 +18,12 @@ ...@@ -18,11 +18,12 @@
*/ */
#ifndef __ASM_JUMP_LABEL_H #ifndef __ASM_JUMP_LABEL_H
#define __ASM_JUMP_LABEL_H #define __ASM_JUMP_LABEL_H
#ifndef __ASSEMBLY__
#include <linux/types.h> #include <linux/types.h>
#include <asm/insn.h> #include <asm/insn.h>
#ifdef __KERNEL__
#define JUMP_LABEL_NOP_SIZE AARCH64_INSN_SIZE #define JUMP_LABEL_NOP_SIZE AARCH64_INSN_SIZE
static __always_inline bool arch_static_branch(struct static_key *key) static __always_inline bool arch_static_branch(struct static_key *key)
...@@ -39,8 +40,6 @@ static __always_inline bool arch_static_branch(struct static_key *key) ...@@ -39,8 +40,6 @@ static __always_inline bool arch_static_branch(struct static_key *key)
return true; return true;
} }
#endif /* __KERNEL__ */
typedef u64 jump_label_t; typedef u64 jump_label_t;
struct jump_entry { struct jump_entry {
...@@ -49,4 +48,5 @@ struct jump_entry { ...@@ -49,4 +48,5 @@ struct jump_entry {
jump_label_t key; jump_label_t key;
}; };
#endif /* __ASSEMBLY__ */
#endif /* __ASM_JUMP_LABEL_H */ #endif /* __ASM_JUMP_LABEL_H */
...@@ -8,9 +8,9 @@ ...@@ -8,9 +8,9 @@
#ifndef _ASM_MIPS_JUMP_LABEL_H #ifndef _ASM_MIPS_JUMP_LABEL_H
#define _ASM_MIPS_JUMP_LABEL_H #define _ASM_MIPS_JUMP_LABEL_H
#include <linux/types.h> #ifndef __ASSEMBLY__
#ifdef __KERNEL__ #include <linux/types.h>
#define JUMP_LABEL_NOP_SIZE 4 #define JUMP_LABEL_NOP_SIZE 4
...@@ -39,8 +39,6 @@ static __always_inline bool arch_static_branch(struct static_key *key) ...@@ -39,8 +39,6 @@ static __always_inline bool arch_static_branch(struct static_key *key)
return true; return true;
} }
#endif /* __KERNEL__ */
#ifdef CONFIG_64BIT #ifdef CONFIG_64BIT
typedef u64 jump_label_t; typedef u64 jump_label_t;
#else #else
...@@ -53,4 +51,5 @@ struct jump_entry { ...@@ -53,4 +51,5 @@ struct jump_entry {
jump_label_t key; jump_label_t key;
}; };
#endif /* __ASSEMBLY__ */
#endif /* _ASM_MIPS_JUMP_LABEL_H */ #endif /* _ASM_MIPS_JUMP_LABEL_H */
#ifndef _ASM_S390_JUMP_LABEL_H #ifndef _ASM_S390_JUMP_LABEL_H
#define _ASM_S390_JUMP_LABEL_H #define _ASM_S390_JUMP_LABEL_H
#ifndef __ASSEMBLY__
#include <linux/types.h> #include <linux/types.h>
#define JUMP_LABEL_NOP_SIZE 6 #define JUMP_LABEL_NOP_SIZE 6
...@@ -39,4 +41,5 @@ struct jump_entry { ...@@ -39,4 +41,5 @@ struct jump_entry {
jump_label_t key; jump_label_t key;
}; };
#endif /* __ASSEMBLY__ */
#endif #endif
#ifndef _ASM_SPARC_JUMP_LABEL_H #ifndef _ASM_SPARC_JUMP_LABEL_H
#define _ASM_SPARC_JUMP_LABEL_H #define _ASM_SPARC_JUMP_LABEL_H
#ifdef __KERNEL__ #ifndef __ASSEMBLY__
#include <linux/types.h> #include <linux/types.h>
...@@ -22,8 +22,6 @@ static __always_inline bool arch_static_branch(struct static_key *key) ...@@ -22,8 +22,6 @@ static __always_inline bool arch_static_branch(struct static_key *key)
return true; return true;
} }
#endif /* __KERNEL__ */
typedef u32 jump_label_t; typedef u32 jump_label_t;
struct jump_entry { struct jump_entry {
...@@ -32,4 +30,5 @@ struct jump_entry { ...@@ -32,4 +30,5 @@ struct jump_entry {
jump_label_t key; jump_label_t key;
}; };
#endif /* __ASSEMBLY__ */
#endif #endif
#ifndef _ASM_X86_JUMP_LABEL_H #ifndef _ASM_X86_JUMP_LABEL_H
#define _ASM_X86_JUMP_LABEL_H #define _ASM_X86_JUMP_LABEL_H
#ifdef __KERNEL__ #ifndef __ASSEMBLY__
#include <linux/stringify.h> #include <linux/stringify.h>
#include <linux/types.h> #include <linux/types.h>
...@@ -30,8 +30,6 @@ static __always_inline bool arch_static_branch(struct static_key *key) ...@@ -30,8 +30,6 @@ static __always_inline bool arch_static_branch(struct static_key *key)
return true; return true;
} }
#endif /* __KERNEL__ */
#ifdef CONFIG_X86_64 #ifdef CONFIG_X86_64
typedef u64 jump_label_t; typedef u64 jump_label_t;
#else #else
...@@ -44,4 +42,5 @@ struct jump_entry { ...@@ -44,4 +42,5 @@ struct jump_entry {
jump_label_t key; jump_label_t key;
}; };
#endif /* __ASSEMBLY__ */
#endif #endif
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment