Linux-2.6.12-rc2
[linux-3.10.git] / arch / ia64 / kernel / ia64_ksyms.c
1 /*
2  * Architecture-specific kernel symbols
3  *
4  * Don't put any exports here unless it's defined in an assembler file.
5  * All other exports should be put directly after the definition.
6  */
7
8 #include <linux/config.h>
9 #include <linux/module.h>
10
11 #include <linux/string.h>
12 EXPORT_SYMBOL(memset);
13 EXPORT_SYMBOL(memchr);
14 EXPORT_SYMBOL(memcmp);
15 EXPORT_SYMBOL(memcpy);
16 EXPORT_SYMBOL(memmove);
17 EXPORT_SYMBOL(memscan);
18 EXPORT_SYMBOL(strcat);
19 EXPORT_SYMBOL(strchr);
20 EXPORT_SYMBOL(strcmp);
21 EXPORT_SYMBOL(strcpy);
22 EXPORT_SYMBOL(strlen);
23 EXPORT_SYMBOL(strncat);
24 EXPORT_SYMBOL(strncmp);
25 EXPORT_SYMBOL(strncpy);
26 EXPORT_SYMBOL(strnlen);
27 EXPORT_SYMBOL(strrchr);
28 EXPORT_SYMBOL(strstr);
29 EXPORT_SYMBOL(strpbrk);
30
31 #include <asm/checksum.h>
32 EXPORT_SYMBOL(ip_fast_csum);            /* hand-coded assembly */
33
34 #include <asm/semaphore.h>
35 EXPORT_SYMBOL(__down);
36 EXPORT_SYMBOL(__down_interruptible);
37 EXPORT_SYMBOL(__down_trylock);
38 EXPORT_SYMBOL(__up);
39
40 #include <asm/page.h>
41 EXPORT_SYMBOL(clear_page);
42
43 #ifdef CONFIG_VIRTUAL_MEM_MAP
44 #include <linux/bootmem.h>
45 EXPORT_SYMBOL(max_low_pfn);     /* defined by bootmem.c, but not exported by generic code */
46 #endif
47
48 #include <asm/processor.h>
49 EXPORT_SYMBOL(per_cpu__cpu_info);
50 #ifdef CONFIG_SMP
51 EXPORT_SYMBOL(per_cpu__local_per_cpu_offset);
52 #endif
53
54 #include <asm/uaccess.h>
55 EXPORT_SYMBOL(__copy_user);
56 EXPORT_SYMBOL(__do_clear_user);
57 EXPORT_SYMBOL(__strlen_user);
58 EXPORT_SYMBOL(__strncpy_from_user);
59 EXPORT_SYMBOL(__strnlen_user);
60
61 #include <asm/unistd.h>
62 EXPORT_SYMBOL(__ia64_syscall);
63
64 /* from arch/ia64/lib */
65 extern void __divsi3(void);
66 extern void __udivsi3(void);
67 extern void __modsi3(void);
68 extern void __umodsi3(void);
69 extern void __divdi3(void);
70 extern void __udivdi3(void);
71 extern void __moddi3(void);
72 extern void __umoddi3(void);
73
74 EXPORT_SYMBOL(__divsi3);
75 EXPORT_SYMBOL(__udivsi3);
76 EXPORT_SYMBOL(__modsi3);
77 EXPORT_SYMBOL(__umodsi3);
78 EXPORT_SYMBOL(__divdi3);
79 EXPORT_SYMBOL(__udivdi3);
80 EXPORT_SYMBOL(__moddi3);
81 EXPORT_SYMBOL(__umoddi3);
82
83 #if defined(CONFIG_MD_RAID5) || defined(CONFIG_MD_RAID5_MODULE)
84 extern void xor_ia64_2(void);
85 extern void xor_ia64_3(void);
86 extern void xor_ia64_4(void);
87 extern void xor_ia64_5(void);
88
89 EXPORT_SYMBOL(xor_ia64_2);
90 EXPORT_SYMBOL(xor_ia64_3);
91 EXPORT_SYMBOL(xor_ia64_4);
92 EXPORT_SYMBOL(xor_ia64_5);
93 #endif
94
95 #include <asm/pal.h>
96 EXPORT_SYMBOL(ia64_pal_call_phys_stacked);
97 EXPORT_SYMBOL(ia64_pal_call_phys_static);
98 EXPORT_SYMBOL(ia64_pal_call_stacked);
99 EXPORT_SYMBOL(ia64_pal_call_static);
100 EXPORT_SYMBOL(ia64_load_scratch_fpregs);
101 EXPORT_SYMBOL(ia64_save_scratch_fpregs);
102
103 #include <asm/unwind.h>
104 EXPORT_SYMBOL(unw_init_running);
105
106 #ifdef ASM_SUPPORTED
107 # ifdef CONFIG_SMP
108 #  if __GNUC__ < 3 || (__GNUC__ == 3 && __GNUC_MINOR__ < 3)
109 /*
110  * This is not a normal routine and we don't want a function descriptor for it, so we use
111  * a fake declaration here.
112  */
113 extern char ia64_spinlock_contention_pre3_4;
114 EXPORT_SYMBOL(ia64_spinlock_contention_pre3_4);
115 #  else
116 /*
117  * This is not a normal routine and we don't want a function descriptor for it, so we use
118  * a fake declaration here.
119  */
120 extern char ia64_spinlock_contention;
121 EXPORT_SYMBOL(ia64_spinlock_contention);
122 #  endif
123 # endif
124 #endif
125
126 extern char ia64_ivt[];
127 EXPORT_SYMBOL(ia64_ivt);