blob: 294d6ae785d4e9fed609ceb51d69975c0b51ed85 [file] [log] [blame]
Al Viro22823ab2016-01-11 10:54:54 -05001#ifndef __ASM_GENERIC_EXPORT_H
2#define __ASM_GENERIC_EXPORT_H
3
4#ifndef KSYM_FUNC
5#define KSYM_FUNC(x) x
6#endif
7#ifdef CONFIG_64BIT
Al Viro22823ab2016-01-11 10:54:54 -05008#ifndef KSYM_ALIGN
9#define KSYM_ALIGN 8
10#endif
Al Viro22823ab2016-01-11 10:54:54 -050011#else
Al Viro22823ab2016-01-11 10:54:54 -050012#ifndef KSYM_ALIGN
13#define KSYM_ALIGN 4
14#endif
Ard Biesheuvel71810db2017-02-03 09:54:06 +000015#endif
Al Viro22823ab2016-01-11 10:54:54 -050016#ifndef KCRC_ALIGN
17#define KCRC_ALIGN 4
18#endif
Al Viro22823ab2016-01-11 10:54:54 -050019
Ard Biesheuvel7290d582018-08-21 21:56:09 -070020.macro __put, val, name
21#ifdef CONFIG_HAVE_ARCH_PREL32_RELOCATIONS
22 .long \val - ., \name - .
23#elif defined(CONFIG_64BIT)
24 .quad \val, \name
25#else
26 .long \val, \name
27#endif
28.endm
29
Al Viro22823ab2016-01-11 10:54:54 -050030/*
31 * note on .section use: @progbits vs %progbits nastiness doesn't matter,
32 * since we immediately emit into those sections anyway.
33 */
34.macro ___EXPORT_SYMBOL name,val,sec
35#ifdef CONFIG_MODULES
Masahiro Yamada94e58e02018-05-09 16:23:49 +090036 .globl __ksymtab_\name
Al Viro22823ab2016-01-11 10:54:54 -050037 .section ___ksymtab\sec+\name,"a"
38 .balign KSYM_ALIGN
Masahiro Yamada94e58e02018-05-09 16:23:49 +090039__ksymtab_\name:
40 __put \val, __kstrtab_\name
Al Viro22823ab2016-01-11 10:54:54 -050041 .previous
42 .section __ksymtab_strings,"a"
Masahiro Yamada94e58e02018-05-09 16:23:49 +090043__kstrtab_\name:
Al Viro22823ab2016-01-11 10:54:54 -050044 .asciz "\name"
Al Viro22823ab2016-01-11 10:54:54 -050045 .previous
46#ifdef CONFIG_MODVERSIONS
47 .section ___kcrctab\sec+\name,"a"
48 .balign KCRC_ALIGN
Masahiro Yamada94e58e02018-05-09 16:23:49 +090049__kcrctab_\name:
Ard Biesheuvel71810db2017-02-03 09:54:06 +000050#if defined(CONFIG_MODULE_REL_CRCS)
Masahiro Yamada94e58e02018-05-09 16:23:49 +090051 .long __crc_\name - .
Ard Biesheuvel71810db2017-02-03 09:54:06 +000052#else
Masahiro Yamada94e58e02018-05-09 16:23:49 +090053 .long __crc_\name
Ard Biesheuvel71810db2017-02-03 09:54:06 +000054#endif
Masahiro Yamada94e58e02018-05-09 16:23:49 +090055 .weak __crc_\name
Al Viro22823ab2016-01-11 10:54:54 -050056 .previous
57#endif
58#endif
59.endm
60#undef __put
61
Masahiro Yamadabbda5ec2018-11-30 10:05:26 +090062#if defined(CONFIG_TRIM_UNUSED_KSYMS)
Al Viro22823ab2016-01-11 10:54:54 -050063
64#include <linux/kconfig.h>
65#include <generated/autoksyms.h>
66
Masahiro Yamadabbda5ec2018-11-30 10:05:26 +090067.macro __ksym_marker sym
68 .section ".discard.ksym","a"
69__ksym_marker_\sym:
70 .previous
71.endm
72
Al Viro22823ab2016-01-11 10:54:54 -050073#define __EXPORT_SYMBOL(sym, val, sec) \
Masahiro Yamadabbda5ec2018-11-30 10:05:26 +090074 __ksym_marker sym; \
Masahiro Yamadac0a0aba2016-10-27 17:46:38 -070075 __cond_export_sym(sym, val, sec, __is_defined(__KSYM_##sym))
Al Viro22823ab2016-01-11 10:54:54 -050076#define __cond_export_sym(sym, val, sec, conf) \
77 ___cond_export_sym(sym, val, sec, conf)
78#define ___cond_export_sym(sym, val, sec, enabled) \
79 __cond_export_sym_##enabled(sym, val, sec)
80#define __cond_export_sym_1(sym, val, sec) ___EXPORT_SYMBOL sym, val, sec
81#define __cond_export_sym_0(sym, val, sec) /* nothing */
82
83#else
84#define __EXPORT_SYMBOL(sym, val, sec) ___EXPORT_SYMBOL sym, val, sec
85#endif
86
87#define EXPORT_SYMBOL(name) \
Masahiro Yamada94e58e02018-05-09 16:23:49 +090088 __EXPORT_SYMBOL(name, KSYM_FUNC(name),)
Al Viro22823ab2016-01-11 10:54:54 -050089#define EXPORT_SYMBOL_GPL(name) \
Masahiro Yamada94e58e02018-05-09 16:23:49 +090090 __EXPORT_SYMBOL(name, KSYM_FUNC(name), _gpl)
Al Viro22823ab2016-01-11 10:54:54 -050091#define EXPORT_DATA_SYMBOL(name) \
Masahiro Yamada94e58e02018-05-09 16:23:49 +090092 __EXPORT_SYMBOL(name, name,)
Al Viro22823ab2016-01-11 10:54:54 -050093#define EXPORT_DATA_SYMBOL_GPL(name) \
Masahiro Yamada94e58e02018-05-09 16:23:49 +090094 __EXPORT_SYMBOL(name, name,_gpl)
Al Viro22823ab2016-01-11 10:54:54 -050095
96#endif