Linux 5.6.13
[linux/fpc-iii.git] / include / asm-generic / export.h
blob365345f9a9e32fa1802afcfa9da66eef54b2cbad
1 /* SPDX-License-Identifier: GPL-2.0-only */
2 #ifndef __ASM_GENERIC_EXPORT_H
3 #define __ASM_GENERIC_EXPORT_H
5 #ifndef KSYM_FUNC
6 #define KSYM_FUNC(x) x
7 #endif
8 #ifdef CONFIG_HAVE_ARCH_PREL32_RELOCATIONS
9 #define KSYM_ALIGN 4
10 #elif defined(CONFIG_64BIT)
11 #define KSYM_ALIGN 8
12 #else
13 #define KSYM_ALIGN 4
14 #endif
15 #ifndef KCRC_ALIGN
16 #define KCRC_ALIGN 4
17 #endif
19 .macro __put, val, name
20 #ifdef CONFIG_HAVE_ARCH_PREL32_RELOCATIONS
21 .long \val - ., \name - ., 0
22 #elif defined(CONFIG_64BIT)
23 .quad \val, \name, 0
24 #else
25 .long \val, \name, 0
26 #endif
27 .endm
30 * note on .section use: we specify progbits since usage of the "M" (SHF_MERGE)
31 * section flag requires it. Use '%progbits' instead of '@progbits' since the
32 * former apparently works on all arches according to the binutils source.
35 .macro ___EXPORT_SYMBOL name,val,sec
36 #ifdef CONFIG_MODULES
37 .section ___ksymtab\sec+\name,"a"
38 .balign KSYM_ALIGN
39 __ksymtab_\name:
40 __put \val, __kstrtab_\name
41 .previous
42 .section __ksymtab_strings,"aMS",%progbits,1
43 __kstrtab_\name:
44 .asciz "\name"
45 .previous
46 #ifdef CONFIG_MODVERSIONS
47 .section ___kcrctab\sec+\name,"a"
48 .balign KCRC_ALIGN
49 #if defined(CONFIG_MODULE_REL_CRCS)
50 .long __crc_\name - .
51 #else
52 .long __crc_\name
53 #endif
54 .weak __crc_\name
55 .previous
56 #endif
57 #endif
58 .endm
60 #if defined(CONFIG_TRIM_UNUSED_KSYMS)
62 #include <linux/kconfig.h>
63 #include <generated/autoksyms.h>
65 .macro __ksym_marker sym
66 .section ".discard.ksym","a"
67 __ksym_marker_\sym:
68 .previous
69 .endm
71 #define __EXPORT_SYMBOL(sym, val, sec) \
72 __ksym_marker sym; \
73 __cond_export_sym(sym, val, sec, __is_defined(__KSYM_##sym))
74 #define __cond_export_sym(sym, val, sec, conf) \
75 ___cond_export_sym(sym, val, sec, conf)
76 #define ___cond_export_sym(sym, val, sec, enabled) \
77 __cond_export_sym_##enabled(sym, val, sec)
78 #define __cond_export_sym_1(sym, val, sec) ___EXPORT_SYMBOL sym, val, sec
79 #define __cond_export_sym_0(sym, val, sec) /* nothing */
81 #else
82 #define __EXPORT_SYMBOL(sym, val, sec) ___EXPORT_SYMBOL sym, val, sec
83 #endif
85 #define EXPORT_SYMBOL(name) \
86 __EXPORT_SYMBOL(name, KSYM_FUNC(name),)
87 #define EXPORT_SYMBOL_GPL(name) \
88 __EXPORT_SYMBOL(name, KSYM_FUNC(name), _gpl)
89 #define EXPORT_DATA_SYMBOL(name) \
90 __EXPORT_SYMBOL(name, name,)
91 #define EXPORT_DATA_SYMBOL_GPL(name) \
92 __EXPORT_SYMBOL(name, name,_gpl)
94 #endif