]> git.karo-electronics.de Git - karo-tx-linux.git/blob - include/linux/linkage.h
Merge tag 'scsi-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi
[karo-tx-linux.git] / include / linux / linkage.h
1 #ifndef _LINUX_LINKAGE_H
2 #define _LINUX_LINKAGE_H
3
4 #include <linux/compiler.h>
5 #include <linux/stringify.h>
6 #include <linux/export.h>
7 #include <asm/linkage.h>
8
9 /* Some toolchains use other characters (e.g. '`') to mark new line in macro */
10 #ifndef ASM_NL
11 #define ASM_NL           ;
12 #endif
13
14 #ifdef __cplusplus
15 #define CPP_ASMLINKAGE extern "C"
16 #else
17 #define CPP_ASMLINKAGE
18 #endif
19
20 #ifndef asmlinkage
21 #define asmlinkage CPP_ASMLINKAGE
22 #endif
23
24 #ifndef cond_syscall
25 #define cond_syscall(x) asm(                            \
26         ".weak " VMLINUX_SYMBOL_STR(x) "\n\t"           \
27         ".set  " VMLINUX_SYMBOL_STR(x) ","              \
28                  VMLINUX_SYMBOL_STR(sys_ni_syscall))
29 #endif
30
31 #ifndef SYSCALL_ALIAS
32 #define SYSCALL_ALIAS(alias, name) asm(                 \
33         ".globl " VMLINUX_SYMBOL_STR(alias) "\n\t"      \
34         ".set   " VMLINUX_SYMBOL_STR(alias) ","         \
35                   VMLINUX_SYMBOL_STR(name))
36 #endif
37
38 #define __page_aligned_data     __section(.data..page_aligned) __aligned(PAGE_SIZE)
39 #define __page_aligned_bss      __section(.bss..page_aligned) __aligned(PAGE_SIZE)
40
41 /*
42  * For assembly routines.
43  *
44  * Note when using these that you must specify the appropriate
45  * alignment directives yourself
46  */
47 #define __PAGE_ALIGNED_DATA     .section ".data..page_aligned", "aw"
48 #define __PAGE_ALIGNED_BSS      .section ".bss..page_aligned", "aw"
49
50 /*
51  * This is used by architectures to keep arguments on the stack
52  * untouched by the compiler by keeping them live until the end.
53  * The argument stack may be owned by the assembly-language
54  * caller, not the callee, and gcc doesn't always understand
55  * that.
56  *
57  * We have the return value, and a maximum of six arguments.
58  *
59  * This should always be followed by a "return ret" for the
60  * protection to work (ie no more work that the compiler might
61  * end up needing stack temporaries for).
62  */
63 /* Assembly files may be compiled with -traditional .. */
64 #ifndef __ASSEMBLY__
65 #ifndef asmlinkage_protect
66 # define asmlinkage_protect(n, ret, args...)    do { } while (0)
67 #endif
68 #endif
69
70 #ifndef __ALIGN
71 #define __ALIGN         .align 4,0x90
72 #define __ALIGN_STR     ".align 4,0x90"
73 #endif
74
75 #ifdef __ASSEMBLY__
76
77 #ifndef LINKER_SCRIPT
78 #define ALIGN __ALIGN
79 #define ALIGN_STR __ALIGN_STR
80
81 #ifndef ENTRY
82 #define ENTRY(name) \
83         .globl name ASM_NL \
84         ALIGN ASM_NL \
85         name:
86 #endif
87 #endif /* LINKER_SCRIPT */
88
89 #ifndef WEAK
90 #define WEAK(name)         \
91         .weak name ASM_NL   \
92         name:
93 #endif
94
95 #ifndef END
96 #define END(name) \
97         .size name, .-name
98 #endif
99
100 /* If symbol 'name' is treated as a subroutine (gets called, and returns)
101  * then please use ENDPROC to mark 'name' as STT_FUNC for the benefit of
102  * static analysis tools such as stack depth analyzer.
103  */
104 #ifndef ENDPROC
105 #define ENDPROC(name) \
106         .type name, @function ASM_NL \
107         END(name)
108 #endif
109
110 #endif
111
112 #endif