1 #include <linux/config.h>
2 #include <linux/module.h>
3 #include <linux/threads.h>
5 #include <linux/sched.h>
6 #include <linux/elfcore.h>
7 #include <linux/string.h>
8 #include <linux/interrupt.h>
10 #include <linux/vt_kern.h>
11 #include <linux/nvram.h>
12 #include <linux/console.h>
13 #include <linux/irq.h>
14 #include <linux/pci.h>
15 #include <linux/delay.h>
16 #include <linux/ide.h>
17 #include <linux/bitops.h>
20 #include <asm/semaphore.h>
21 #include <asm/processor.h>
22 #include <asm/uaccess.h>
25 #include <asm/atomic.h>
26 #include <asm/checksum.h>
27 #include <asm/pgtable.h>
28 #include <asm/tlbflush.h>
29 #include <linux/adb.h>
30 #include <linux/cuda.h>
31 #include <linux/pmu.h>
33 #include <asm/system.h>
34 #include <asm/pci-bridge.h>
36 #include <asm/pmac_feature.h>
38 #include <asm/machdep.h>
39 #include <asm/hw_irq.h>
40 #include <asm/nvram.h>
41 #include <asm/mmu_context.h>
42 #include <asm/backlight.h>
44 #include <asm/cputable.h>
45 #include <asm/btext.h>
46 #include <asm/div64.h>
47 #include <asm/signal.h>
50 #include <asm/commproc.h>
54 extern void transfer_to_handler(void);
55 extern void do_IRQ(struct pt_regs
*regs
);
56 extern void machine_check_exception(struct pt_regs
*regs
);
57 extern void alignment_exception(struct pt_regs
*regs
);
58 extern void program_check_exception(struct pt_regs
*regs
);
59 extern void single_step_exception(struct pt_regs
*regs
);
60 extern int pmac_newworld
;
61 extern int sys_sigreturn(struct pt_regs
*regs
);
63 EXPORT_SYMBOL(clear_pages
);
64 EXPORT_SYMBOL(ISA_DMA_THRESHOLD
);
65 EXPORT_SYMBOL(DMA_MODE_READ
);
66 EXPORT_SYMBOL(DMA_MODE_WRITE
);
67 EXPORT_SYMBOL(__div64_32
);
69 EXPORT_SYMBOL(do_signal
);
70 EXPORT_SYMBOL(transfer_to_handler
);
71 EXPORT_SYMBOL(do_IRQ
);
72 EXPORT_SYMBOL(machine_check_exception
);
73 EXPORT_SYMBOL(alignment_exception
);
74 EXPORT_SYMBOL(program_check_exception
);
75 EXPORT_SYMBOL(single_step_exception
);
76 EXPORT_SYMBOL(sys_sigreturn
);
79 EXPORT_SYMBOL(strcpy
);
80 EXPORT_SYMBOL(strncpy
);
81 EXPORT_SYMBOL(strcat
);
82 EXPORT_SYMBOL(strncat
);
83 EXPORT_SYMBOL(strchr
);
84 EXPORT_SYMBOL(strrchr
);
85 EXPORT_SYMBOL(strpbrk
);
86 EXPORT_SYMBOL(strstr
);
87 EXPORT_SYMBOL(strlen
);
88 EXPORT_SYMBOL(strnlen
);
89 EXPORT_SYMBOL(strcmp
);
90 EXPORT_SYMBOL(strncmp
);
91 EXPORT_SYMBOL(strcasecmp
);
93 EXPORT_SYMBOL(csum_partial
);
94 EXPORT_SYMBOL(csum_partial_copy_generic
);
95 EXPORT_SYMBOL(ip_fast_csum
);
96 EXPORT_SYMBOL(csum_tcpudp_magic
);
98 EXPORT_SYMBOL(__copy_tofrom_user
);
99 EXPORT_SYMBOL(__clear_user
);
100 EXPORT_SYMBOL(__strncpy_from_user
);
101 EXPORT_SYMBOL(__strnlen_user
);
103 #ifndef __powerpc64__
104 EXPORT_SYMBOL(__ide_mm_insl
);
105 EXPORT_SYMBOL(__ide_mm_outsw
);
106 EXPORT_SYMBOL(__ide_mm_insw
);
107 EXPORT_SYMBOL(__ide_mm_outsl
);
110 EXPORT_SYMBOL(_insb
);
111 EXPORT_SYMBOL(_outsb
);
112 EXPORT_SYMBOL(_insw
);
113 EXPORT_SYMBOL(_outsw
);
114 EXPORT_SYMBOL(_insl
);
115 EXPORT_SYMBOL(_outsl
);
116 EXPORT_SYMBOL(_insw_ns
);
117 EXPORT_SYMBOL(_outsw_ns
);
118 EXPORT_SYMBOL(_insl_ns
);
119 EXPORT_SYMBOL(_outsl_ns
);
120 EXPORT_SYMBOL(ioremap
);
122 EXPORT_SYMBOL(ioremap64
);
124 EXPORT_SYMBOL(__ioremap
);
125 EXPORT_SYMBOL(iounmap
);
127 EXPORT_SYMBOL(ioremap_bot
); /* aka VMALLOC_END */
130 #if defined(CONFIG_PPC32) && (defined(CONFIG_BLK_DEV_IDE) || defined(CONFIG_BLK_DEV_IDE_MODULE))
131 EXPORT_SYMBOL(ppc_ide_md
);
134 #if defined(CONFIG_PCI) && defined(CONFIG_PPC32)
135 EXPORT_SYMBOL(isa_io_base
);
136 EXPORT_SYMBOL(isa_mem_base
);
137 EXPORT_SYMBOL(pci_dram_offset
);
138 EXPORT_SYMBOL(pci_alloc_consistent
);
139 EXPORT_SYMBOL(pci_free_consistent
);
140 EXPORT_SYMBOL(pci_bus_io_base
);
141 EXPORT_SYMBOL(pci_bus_io_base_phys
);
142 EXPORT_SYMBOL(pci_bus_mem_base_phys
);
143 EXPORT_SYMBOL(pci_bus_to_hose
);
144 #endif /* CONFIG_PCI */
146 #ifdef CONFIG_NOT_COHERENT_CACHE
147 EXPORT_SYMBOL(flush_dcache_all
);
150 EXPORT_SYMBOL(start_thread
);
151 EXPORT_SYMBOL(kernel_thread
);
153 EXPORT_SYMBOL(giveup_fpu
);
154 #ifdef CONFIG_ALTIVEC
155 EXPORT_SYMBOL(giveup_altivec
);
156 #endif /* CONFIG_ALTIVEC */
158 EXPORT_SYMBOL(giveup_spe
);
159 #endif /* CONFIG_SPE */
162 EXPORT_SYMBOL(flush_instruction_cache
);
163 EXPORT_SYMBOL(flush_tlb_kernel_range
);
164 EXPORT_SYMBOL(flush_tlb_page
);
165 EXPORT_SYMBOL(_tlbie
);
167 EXPORT_SYMBOL(__flush_icache_range
);
168 EXPORT_SYMBOL(flush_dcache_range
);
171 EXPORT_SYMBOL(smp_call_function
);
173 EXPORT_SYMBOL(smp_hw_index
);
178 EXPORT_SYMBOL(adb_request
);
179 EXPORT_SYMBOL(adb_register
);
180 EXPORT_SYMBOL(adb_unregister
);
181 EXPORT_SYMBOL(adb_poll
);
182 EXPORT_SYMBOL(adb_try_handler_change
);
183 #endif /* CONFIG_ADB */
184 #ifdef CONFIG_ADB_CUDA
185 EXPORT_SYMBOL(cuda_request
);
186 EXPORT_SYMBOL(cuda_poll
);
187 #endif /* CONFIG_ADB_CUDA */
188 #ifdef CONFIG_PPC_PMAC
189 EXPORT_SYMBOL(sys_ctrler
);
192 EXPORT_SYMBOL(kd_mksound
);
194 EXPORT_SYMBOL(to_tm
);
197 long long __ashrdi3(long long, int);
198 long long __ashldi3(long long, int);
199 long long __lshrdi3(long long, int);
200 EXPORT_SYMBOL(__ashrdi3
);
201 EXPORT_SYMBOL(__ashldi3
);
202 EXPORT_SYMBOL(__lshrdi3
);
205 EXPORT_SYMBOL(memcpy
);
206 EXPORT_SYMBOL(memset
);
207 EXPORT_SYMBOL(memmove
);
208 EXPORT_SYMBOL(memscan
);
209 EXPORT_SYMBOL(memcmp
);
210 EXPORT_SYMBOL(memchr
);
212 #if defined(CONFIG_FB_VGA16_MODULE)
213 EXPORT_SYMBOL(screen_info
);
217 EXPORT_SYMBOL(__delay
);
218 EXPORT_SYMBOL(timer_interrupt
);
219 EXPORT_SYMBOL(irq_desc
);
220 EXPORT_SYMBOL(tb_ticks_per_jiffy
);
221 EXPORT_SYMBOL(console_drivers
);
222 EXPORT_SYMBOL(cacheable_memcpy
);
226 EXPORT_SYMBOL(__down
);
227 EXPORT_SYMBOL(__down_interruptible
);
230 EXPORT_SYMBOL(cpm_install_handler
);
231 EXPORT_SYMBOL(cpm_free_handler
);
232 #endif /* CONFIG_8xx */
233 #if defined(CONFIG_8xx) || defined(CONFIG_40x) || defined(CONFIG_85xx) ||\
235 EXPORT_SYMBOL(__res
);
239 EXPORT_SYMBOL(next_mmu_context
);
240 EXPORT_SYMBOL(set_context
);
243 #ifdef CONFIG_PPC_STD_MMU_32
244 extern long mol_trampoline
;
245 EXPORT_SYMBOL(mol_trampoline
); /* For MOL */
246 EXPORT_SYMBOL(flush_hash_pages
); /* For MOL */
247 EXPORT_SYMBOL_GPL(__handle_mm_fault
); /* For MOL */
249 extern int mmu_hash_lock
;
250 EXPORT_SYMBOL(mmu_hash_lock
); /* For MOL */
251 #endif /* CONFIG_SMP */
252 extern long *intercept_table
;
253 EXPORT_SYMBOL(intercept_table
);
254 #endif /* CONFIG_PPC_STD_MMU_32 */
255 #if defined(CONFIG_40x) || defined(CONFIG_BOOKE)
256 EXPORT_SYMBOL(__mtdcr
);
257 EXPORT_SYMBOL(__mfdcr
);