1 #ifndef _LINUX_LINKAGE_H
2 #define _LINUX_LINKAGE_H
4 #include <linux/compiler.h>
5 #include <asm/linkage.h>
7 #define notrace __attribute__((no_instrument_function))
10 #define CPP_ASMLINKAGE extern "C"
12 #define CPP_ASMLINKAGE
16 #define asmlinkage CPP_ASMLINKAGE
23 #define __page_aligned_data __section(.data.page_aligned) __aligned(PAGE_SIZE)
24 #define __page_aligned_bss __section(.bss.page_aligned) __aligned(PAGE_SIZE)
27 * This is used by architectures to keep arguments on the stack
28 * untouched by the compiler by keeping them live until the end.
29 * The argument stack may be owned by the assembly-language
30 * caller, not the callee, and gcc doesn't always understand
33 * We have the return value, and a maximum of six arguments.
35 * This should always be followed by a "return ret" for the
36 * protection to work (ie no more work that the compiler might
37 * end up needing stack temporaries for).
39 /* Assembly files may be compiled with -traditional .. */
41 #ifndef asmlinkage_protect
42 # define asmlinkage_protect(n, ret, args...) do { } while (0)
47 #define __ALIGN .align 4,0x90
48 #define __ALIGN_STR ".align 4,0x90"
54 #define ALIGN_STR __ALIGN_STR
69 #define KPROBE_ENTRY(name) \
70 .pushsection .kprobes.text, "ax"; \
73 #define KPROBE_END(name) \
82 /* If symbol 'name' is treated as a subroutine (gets called, and returns)
83 * then please use ENDPROC to mark 'name' as STT_FUNC for the benefit of
84 * static analysis tools such as stack depth analyzer.
87 #define ENDPROC(name) \
88 .type name, @function; \
94 #define NORET_TYPE /**/
95 #define ATTRIB_NORET __attribute__((noreturn))
96 #define NORET_AND noreturn,