1 #include <linux/config.h>
2 #include <linux/module.h>
3 #include <linux/user.h>
4 #include <linux/string.h>
7 #include <linux/mman.h>
9 #include <linux/delay.h>
10 #include <linux/in6.h>
12 #include <asm/byteorder.h>
17 #include <asm/pgalloc.h>
18 #include <asm/proc-fns.h>
19 #include <asm/processor.h>
20 #include <asm/semaphore.h>
21 #include <asm/system.h>
22 #include <asm/uaccess.h>
23 #include <asm/checksum.h>
25 extern void dump_thread(struct pt_regs
*, struct user
*);
26 extern int dump_fpu(struct pt_regs
*, struct user_fp_struct
*);
27 extern void inswb(unsigned int port
, void *to
, int len
);
28 extern void outswb(unsigned int port
, const void *to
, int len
);
30 extern unsigned int local_bh_count
[NR_CPUS
];
31 extern unsigned int local_irq_count
[NR_CPUS
];
36 extern int sys_write(int, const char *, int);
37 extern int sys_read(int, char *, int);
38 extern int sys_lseek(int, off_t
, int);
39 extern int sys_exit(int);
40 extern int sys_wait4(int, int *, int, struct rusage
*);
43 * libgcc functions - functions that are used internally by the
44 * compiler... (prototypes are not correct though, but that
45 * doesn't really matter since they're not versioned).
47 extern void __gcc_bcmp(void);
48 extern void __ashldi3(void);
49 extern void __ashrdi3(void);
50 extern void __cmpdi2(void);
51 extern void __divdi3(void);
52 extern void __divsi3(void);
53 extern void __lshrdi3(void);
54 extern void __moddi3(void);
55 extern void __modsi3(void);
56 extern void __muldi3(void);
57 extern void __negdi2(void);
58 extern void __ucmpdi2(void);
59 extern void __udivdi3(void);
60 extern void __udivmoddi4(void);
61 extern void __udivsi3(void);
62 extern void __umoddi3(void);
63 extern void __umodsi3(void);
65 extern void ret_from_exception(void);
66 extern void fpundefinstr(void);
67 extern void fp_enter(void);
68 #define EXPORT_SYMBOL_ALIAS(sym,orig) \
69 const char __kstrtab_##sym##[] __attribute__((section(".kstrtab"))) = \
70 __MODULE_STRING(##sym##); \
71 const struct module_symbol __ksymtab_##sym __attribute__((section("__ksymtab"))) = \
72 { (unsigned long)&##orig, __kstrtab_##sym };
74 * floating point math emulator support.
75 * These symbols will never change their calling convention...
77 EXPORT_SYMBOL_ALIAS(kern_fp_enter
,fp_enter
);
78 EXPORT_SYMBOL_ALIAS(fp_printk
,printk
);
79 EXPORT_SYMBOL_ALIAS(fp_send_sig
,send_sig
);
82 EXPORT_SYMBOL(fpundefinstr
);
83 EXPORT_SYMBOL(ret_from_exception
);
86 /* platform dependent support */
87 EXPORT_SYMBOL(dump_thread
);
88 EXPORT_SYMBOL(dump_fpu
);
89 EXPORT_SYMBOL(udelay
);
90 EXPORT_SYMBOL(xchg_str
);
91 EXPORT_SYMBOL(local_bh_count
);
92 EXPORT_SYMBOL(local_irq_count
);
94 EXPORT_SYMBOL(__ioremap
);
95 EXPORT_SYMBOL(__iounmap
);
97 EXPORT_SYMBOL(kernel_thread
);
98 EXPORT_SYMBOL(system_rev
);
99 EXPORT_SYMBOL(system_serial_low
);
100 EXPORT_SYMBOL(system_serial_high
);
101 EXPORT_SYMBOL(__bug
);
102 EXPORT_SYMBOL(__readwrite_bug
);
103 EXPORT_SYMBOL(enable_irq
);
104 EXPORT_SYMBOL(disable_irq
);
106 /* processor dependencies */
108 EXPORT_SYMBOL(processor
);
110 EXPORT_SYMBOL(cpu_flush_cache_all
);
111 EXPORT_SYMBOL(cpu_flush_cache_area
);
112 EXPORT_SYMBOL(cpu_flush_cache_entry
);
113 EXPORT_SYMBOL(cpu_clean_cache_area
);
114 EXPORT_SYMBOL(cpu_flush_ram_page
);
115 EXPORT_SYMBOL(cpu_flush_tlb_all
);
116 EXPORT_SYMBOL(cpu_flush_tlb_area
);
117 EXPORT_SYMBOL(cpu_set_pgd
);
118 EXPORT_SYMBOL(cpu_set_pmd
);
119 EXPORT_SYMBOL(cpu_set_pte
);
120 EXPORT_SYMBOL(cpu_flush_icache_area
);
121 EXPORT_SYMBOL(cpu_cache_wback_area
);
122 EXPORT_SYMBOL(cpu_cache_purge_area
);
124 EXPORT_SYMBOL(__machine_arch_type
);
127 EXPORT_SYMBOL(csum_partial_copy_nocheck
);
128 EXPORT_SYMBOL(__csum_ipv6_magic
);
131 EXPORT_SYMBOL(outsb
);
132 EXPORT_SYMBOL(outsw
);
133 EXPORT_SYMBOL(outsl
);
138 /* address translation */
139 #ifndef __virt_to_phys__is_a_macro
140 EXPORT_SYMBOL(__virt_to_phys
);
142 #ifndef __phys_to_virt__is_a_macro
143 EXPORT_SYMBOL(__phys_to_virt
);
145 #ifndef __virt_to_bus__is_a_macro
146 EXPORT_SYMBOL(__virt_to_bus
);
148 #ifndef __bus_to_virt__is_a_macro
149 EXPORT_SYMBOL(__bus_to_virt
);
152 #ifndef CONFIG_NO_PGT_CACHE
153 EXPORT_SYMBOL(quicklists
);
155 EXPORT_SYMBOL(__handle_bad_pmd
);
156 EXPORT_SYMBOL(__handle_bad_pmd_kernel
);
158 /* string / mem functions */
159 EXPORT_SYMBOL_NOVERS(strcpy
);
160 EXPORT_SYMBOL_NOVERS(strncpy
);
161 EXPORT_SYMBOL_NOVERS(strcat
);
162 EXPORT_SYMBOL_NOVERS(strncat
);
163 EXPORT_SYMBOL_NOVERS(strcmp
);
164 EXPORT_SYMBOL_NOVERS(strncmp
);
165 EXPORT_SYMBOL_NOVERS(strchr
);
166 EXPORT_SYMBOL_NOVERS(strlen
);
167 EXPORT_SYMBOL_NOVERS(strnlen
);
168 EXPORT_SYMBOL_NOVERS(strpbrk
);
169 EXPORT_SYMBOL_NOVERS(strtok
);
170 EXPORT_SYMBOL_NOVERS(strrchr
);
171 EXPORT_SYMBOL_NOVERS(strstr
);
172 EXPORT_SYMBOL_NOVERS(memset
);
173 EXPORT_SYMBOL_NOVERS(memcpy
);
174 EXPORT_SYMBOL_NOVERS(memmove
);
175 EXPORT_SYMBOL_NOVERS(memcmp
);
176 EXPORT_SYMBOL_NOVERS(memscan
);
177 EXPORT_SYMBOL_NOVERS(__memzero
);
179 /* user mem (segment) */
180 #if defined(CONFIG_CPU_32)
181 EXPORT_SYMBOL(__arch_copy_from_user
);
182 EXPORT_SYMBOL(__arch_copy_to_user
);
183 EXPORT_SYMBOL(__arch_clear_user
);
184 EXPORT_SYMBOL(__arch_strnlen_user
);
185 #elif defined(CONFIG_CPU_26)
186 EXPORT_SYMBOL(uaccess_kernel
);
187 EXPORT_SYMBOL(uaccess_user
);
190 EXPORT_SYMBOL(consistent_alloc
);
191 EXPORT_SYMBOL(consistent_free
);
192 EXPORT_SYMBOL(consistent_sync
);
194 /* gcc lib functions */
195 EXPORT_SYMBOL_NOVERS(__gcc_bcmp
);
196 EXPORT_SYMBOL_NOVERS(__ashldi3
);
197 EXPORT_SYMBOL_NOVERS(__ashrdi3
);
198 EXPORT_SYMBOL_NOVERS(__cmpdi2
);
199 EXPORT_SYMBOL_NOVERS(__divdi3
);
200 EXPORT_SYMBOL_NOVERS(__divsi3
);
201 EXPORT_SYMBOL_NOVERS(__lshrdi3
);
202 EXPORT_SYMBOL_NOVERS(__moddi3
);
203 EXPORT_SYMBOL_NOVERS(__modsi3
);
204 EXPORT_SYMBOL_NOVERS(__muldi3
);
205 EXPORT_SYMBOL_NOVERS(__negdi2
);
206 EXPORT_SYMBOL_NOVERS(__ucmpdi2
);
207 EXPORT_SYMBOL_NOVERS(__udivdi3
);
208 EXPORT_SYMBOL_NOVERS(__udivmoddi4
);
209 EXPORT_SYMBOL_NOVERS(__udivsi3
);
210 EXPORT_SYMBOL_NOVERS(__umoddi3
);
211 EXPORT_SYMBOL_NOVERS(__umodsi3
);
214 EXPORT_SYMBOL(set_bit
);
215 EXPORT_SYMBOL(test_and_set_bit
);
216 EXPORT_SYMBOL(clear_bit
);
217 EXPORT_SYMBOL(test_and_clear_bit
);
218 EXPORT_SYMBOL(change_bit
);
219 EXPORT_SYMBOL(test_and_change_bit
);
220 EXPORT_SYMBOL(find_first_zero_bit
);
221 EXPORT_SYMBOL(find_next_zero_bit
);
224 EXPORT_SYMBOL(elf_platform
);
225 EXPORT_SYMBOL(elf_hwcap
);
228 EXPORT_SYMBOL(sys_write
);
229 EXPORT_SYMBOL(sys_read
);
230 EXPORT_SYMBOL(sys_lseek
);
231 EXPORT_SYMBOL(sys_open
);
232 EXPORT_SYMBOL(sys_exit
);
233 EXPORT_SYMBOL(sys_wait4
);
236 EXPORT_SYMBOL_NOVERS(__down_failed
);
237 EXPORT_SYMBOL_NOVERS(__down_interruptible_failed
);
238 EXPORT_SYMBOL_NOVERS(__down_trylock_failed
);
239 EXPORT_SYMBOL_NOVERS(__up_wakeup
);
240 EXPORT_SYMBOL_NOVERS(__down_read_failed
);
241 EXPORT_SYMBOL_NOVERS(__down_write_failed
);
242 EXPORT_SYMBOL_NOVERS(__rwsem_wake
);
244 EXPORT_SYMBOL(get_wchan
);