Merge remote-tracking branch 'selinux/next'
[deliverable/linux.git] / arch / arm / include / asm / module.h
CommitLineData
1da177e4
LT
1#ifndef _ASM_ARM_MODULE_H
2#define _ASM_ARM_MODULE_H
3
786d35d4 4#include <asm-generic/module.h>
1da177e4 5
2e1926e7
CM
6struct unwind_table;
7
2e1926e7 8#ifdef CONFIG_ARM_UNWIND
e5f7772e
PC
9enum {
10 ARM_SEC_INIT,
11 ARM_SEC_DEVINIT,
12 ARM_SEC_CORE,
09e56a2d
PC
13 ARM_SEC_EXIT,
14 ARM_SEC_DEVEXIT,
849b882b
DA
15 ARM_SEC_HOT,
16 ARM_SEC_UNLIKELY,
e5f7772e
PC
17 ARM_SEC_MAX,
18};
7d485f64 19#endif
8931360e 20
e5f7772e 21struct mod_arch_specific {
7d485f64 22#ifdef CONFIG_ARM_UNWIND
8931360e 23 struct unwind_table *unwind[ARM_SEC_MAX];
786d35d4 24#endif
7d485f64 25#ifdef CONFIG_ARM_MODULE_PLTS
35fa91ee
AB
26 struct elf32_shdr *plt;
27 int plt_count;
7d485f64
AB
28#endif
29};
30
31u32 get_module_plt(struct module *mod, unsigned long loc, Elf32_Addr val);
2e1926e7 32
1da177e4 33/*
dc21af99 34 * Add the ARM architecture version to the version magic string
1da177e4 35 */
dc21af99
RK
36#define MODULE_ARCH_VERMAGIC_ARMVSN "ARMv" __stringify(__LINUX_ARM_ARCH__) " "
37
38/* Add __virt_to_phys patching state as well */
39#ifdef CONFIG_ARM_PATCH_PHYS_VIRT
40#define MODULE_ARCH_VERMAGIC_P2V "p2v8 "
41#else
42#define MODULE_ARCH_VERMAGIC_P2V ""
43#endif
44
80f0aad7
DM
45/* Add instruction set architecture tag to distinguish ARM/Thumb kernels */
46#ifdef CONFIG_THUMB2_KERNEL
47#define MODULE_ARCH_VERMAGIC_ARMTHUMB "thumb2 "
48#else
49#define MODULE_ARCH_VERMAGIC_ARMTHUMB ""
50#endif
51
dc21af99
RK
52#define MODULE_ARCH_VERMAGIC \
53 MODULE_ARCH_VERMAGIC_ARMVSN \
80f0aad7 54 MODULE_ARCH_VERMAGIC_ARMTHUMB \
dc21af99 55 MODULE_ARCH_VERMAGIC_P2V
1da177e4
LT
56
57#endif /* _ASM_ARM_MODULE_H */
This page took 0.860421 seconds and 5 git commands to generate.