mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-10 07:00:48 +00:00
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>
This commit is contained in:
parent
01ac33c1f9
commit
55dd0df781
@ -1,7 +1,7 @@
|
|||||||
#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 @@ l_yes:
|
|||||||
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 {
|
|||||||
jump_label_t key;
|
jump_label_t key;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#endif /* __ASSEMBLY__ */
|
||||||
#endif
|
#endif
|
||||||
|
@ -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 @@ l_yes:
|
|||||||
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 {
|
|||||||
jump_label_t key;
|
jump_label_t key;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#endif /* __ASSEMBLY__ */
|
||||||
#endif /* __ASM_JUMP_LABEL_H */
|
#endif /* __ASM_JUMP_LABEL_H */
|
||||||
|
@ -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 @@ l_yes:
|
|||||||
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 {
|
|||||||
jump_label_t key;
|
jump_label_t key;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#endif /* __ASSEMBLY__ */
|
||||||
#endif /* _ASM_MIPS_JUMP_LABEL_H */
|
#endif /* _ASM_MIPS_JUMP_LABEL_H */
|
||||||
|
@ -1,6 +1,8 @@
|
|||||||
#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 {
|
|||||||
jump_label_t key;
|
jump_label_t key;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#endif /* __ASSEMBLY__ */
|
||||||
#endif
|
#endif
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
#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 @@ l_yes:
|
|||||||
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 {
|
|||||||
jump_label_t key;
|
jump_label_t key;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#endif /* __ASSEMBLY__ */
|
||||||
#endif
|
#endif
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
#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 @@ l_yes:
|
|||||||
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 {
|
|||||||
jump_label_t key;
|
jump_label_t key;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#endif /* __ASSEMBLY__ */
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
x
Reference in New Issue
Block a user