[POWERPC] Emulate power5 popcntb instruction
[linux-2.6] / arch / powerpc / kernel / ppc_ksyms.c
1 #include <linux/module.h>
2 #include <linux/threads.h>
3 #include <linux/smp.h>
4 #include <linux/sched.h>
5 #include <linux/elfcore.h>
6 #include <linux/string.h>
7 #include <linux/interrupt.h>
8 #include <linux/screen_info.h>
9 #include <linux/vt_kern.h>
10 #include <linux/nvram.h>
11 #include <linux/console.h>
12 #include <linux/irq.h>
13 #include <linux/pci.h>
14 #include <linux/delay.h>
15 #include <linux/ide.h>
16 #include <linux/bitops.h>
17
18 #include <asm/page.h>
19 #include <asm/semaphore.h>
20 #include <asm/processor.h>
21 #include <asm/uaccess.h>
22 #include <asm/io.h>
23 #include <asm/ide.h>
24 #include <asm/atomic.h>
25 #include <asm/checksum.h>
26 #include <asm/pgtable.h>
27 #include <asm/tlbflush.h>
28 #include <linux/adb.h>
29 #include <linux/cuda.h>
30 #include <linux/pmu.h>
31 #include <asm/prom.h>
32 #include <asm/system.h>
33 #include <asm/pci-bridge.h>
34 #include <asm/irq.h>
35 #include <asm/pmac_feature.h>
36 #include <asm/dma.h>
37 #include <asm/machdep.h>
38 #include <asm/hw_irq.h>
39 #include <asm/nvram.h>
40 #include <asm/mmu_context.h>
41 #include <asm/backlight.h>
42 #include <asm/time.h>
43 #include <asm/cputable.h>
44 #include <asm/btext.h>
45 #include <asm/div64.h>
46 #include <asm/signal.h>
47
48 #ifdef  CONFIG_8xx
49 #include <asm/commproc.h>
50 #endif
51
52 #ifdef CONFIG_PPC32
53 extern void transfer_to_handler(void);
54 extern void do_IRQ(struct pt_regs *regs);
55 extern void machine_check_exception(struct pt_regs *regs);
56 extern void alignment_exception(struct pt_regs *regs);
57 extern void program_check_exception(struct pt_regs *regs);
58 extern void single_step_exception(struct pt_regs *regs);
59 extern int sys_sigreturn(struct pt_regs *regs);
60
61 EXPORT_SYMBOL(clear_pages);
62 EXPORT_SYMBOL(ISA_DMA_THRESHOLD);
63 EXPORT_SYMBOL(DMA_MODE_READ);
64 EXPORT_SYMBOL(DMA_MODE_WRITE);
65 EXPORT_SYMBOL(__div64_32);
66
67 EXPORT_SYMBOL(do_signal);
68 EXPORT_SYMBOL(transfer_to_handler);
69 EXPORT_SYMBOL(do_IRQ);
70 EXPORT_SYMBOL(machine_check_exception);
71 EXPORT_SYMBOL(alignment_exception);
72 EXPORT_SYMBOL(program_check_exception);
73 EXPORT_SYMBOL(single_step_exception);
74 EXPORT_SYMBOL(sys_sigreturn);
75 #endif
76
77 EXPORT_SYMBOL(strcpy);
78 EXPORT_SYMBOL(strncpy);
79 EXPORT_SYMBOL(strcat);
80 EXPORT_SYMBOL(strlen);
81 EXPORT_SYMBOL(strcmp);
82 EXPORT_SYMBOL(strcasecmp);
83 EXPORT_SYMBOL(strncasecmp);
84
85 EXPORT_SYMBOL(csum_partial);
86 EXPORT_SYMBOL(csum_partial_copy_generic);
87 EXPORT_SYMBOL(ip_fast_csum);
88 EXPORT_SYMBOL(csum_tcpudp_magic);
89
90 EXPORT_SYMBOL(__copy_tofrom_user);
91 EXPORT_SYMBOL(__clear_user);
92 EXPORT_SYMBOL(__strncpy_from_user);
93 EXPORT_SYMBOL(__strnlen_user);
94
95 #ifndef  __powerpc64__
96 EXPORT_SYMBOL(__ide_mm_insl);
97 EXPORT_SYMBOL(__ide_mm_outsw);
98 EXPORT_SYMBOL(__ide_mm_insw);
99 EXPORT_SYMBOL(__ide_mm_outsl);
100 #endif
101
102 EXPORT_SYMBOL(_insb);
103 EXPORT_SYMBOL(_outsb);
104 EXPORT_SYMBOL(_insw);
105 EXPORT_SYMBOL(_outsw);
106 EXPORT_SYMBOL(_insl);
107 EXPORT_SYMBOL(_outsl);
108 EXPORT_SYMBOL(_insw_ns);
109 EXPORT_SYMBOL(_outsw_ns);
110 EXPORT_SYMBOL(_insl_ns);
111 EXPORT_SYMBOL(_outsl_ns);
112
113 #if defined(CONFIG_PPC32) && (defined(CONFIG_BLK_DEV_IDE) || defined(CONFIG_BLK_DEV_IDE_MODULE))
114 EXPORT_SYMBOL(ppc_ide_md);
115 #endif
116
117 #if defined(CONFIG_PCI) && defined(CONFIG_PPC32)
118 EXPORT_SYMBOL(isa_io_base);
119 EXPORT_SYMBOL(isa_mem_base);
120 EXPORT_SYMBOL(pci_dram_offset);
121 EXPORT_SYMBOL(pci_alloc_consistent);
122 EXPORT_SYMBOL(pci_free_consistent);
123 EXPORT_SYMBOL(pci_bus_io_base);
124 EXPORT_SYMBOL(pci_bus_io_base_phys);
125 EXPORT_SYMBOL(pci_bus_mem_base_phys);
126 EXPORT_SYMBOL(pci_bus_to_hose);
127 #endif /* CONFIG_PCI */
128
129 EXPORT_SYMBOL(start_thread);
130 EXPORT_SYMBOL(kernel_thread);
131
132 EXPORT_SYMBOL(giveup_fpu);
133 #ifdef CONFIG_ALTIVEC
134 EXPORT_SYMBOL(giveup_altivec);
135 #endif /* CONFIG_ALTIVEC */
136 #ifdef CONFIG_SPE
137 EXPORT_SYMBOL(giveup_spe);
138 #endif /* CONFIG_SPE */
139
140 #ifndef CONFIG_PPC64
141 EXPORT_SYMBOL(flush_instruction_cache);
142 EXPORT_SYMBOL(flush_tlb_kernel_range);
143 EXPORT_SYMBOL(flush_tlb_page);
144 EXPORT_SYMBOL(_tlbie);
145 #endif
146 EXPORT_SYMBOL(__flush_icache_range);
147 EXPORT_SYMBOL(flush_dcache_range);
148
149 #ifdef CONFIG_SMP
150 #ifdef CONFIG_PPC32
151 EXPORT_SYMBOL(smp_hw_index);
152 #endif
153 #endif
154
155 #ifdef CONFIG_ADB
156 EXPORT_SYMBOL(adb_request);
157 EXPORT_SYMBOL(adb_register);
158 EXPORT_SYMBOL(adb_unregister);
159 EXPORT_SYMBOL(adb_poll);
160 EXPORT_SYMBOL(adb_try_handler_change);
161 #endif /* CONFIG_ADB */
162 #ifdef CONFIG_ADB_CUDA
163 EXPORT_SYMBOL(cuda_request);
164 EXPORT_SYMBOL(cuda_poll);
165 #endif /* CONFIG_ADB_CUDA */
166 #ifdef CONFIG_VT
167 EXPORT_SYMBOL(kd_mksound);
168 #endif
169 EXPORT_SYMBOL(to_tm);
170
171 #ifdef CONFIG_PPC32
172 long long __ashrdi3(long long, int);
173 long long __ashldi3(long long, int);
174 long long __lshrdi3(long long, int);
175 EXPORT_SYMBOL(__ashrdi3);
176 EXPORT_SYMBOL(__ashldi3);
177 EXPORT_SYMBOL(__lshrdi3);
178 #endif
179
180 EXPORT_SYMBOL(memcpy);
181 EXPORT_SYMBOL(memset);
182 EXPORT_SYMBOL(memmove);
183 EXPORT_SYMBOL(memcmp);
184 EXPORT_SYMBOL(memchr);
185
186 #if defined(CONFIG_FB_VGA16_MODULE)
187 EXPORT_SYMBOL(screen_info);
188 #endif
189
190 #ifdef CONFIG_PPC32
191 EXPORT_SYMBOL(timer_interrupt);
192 EXPORT_SYMBOL(irq_desc);
193 EXPORT_SYMBOL(tb_ticks_per_jiffy);
194 EXPORT_SYMBOL(console_drivers);
195 EXPORT_SYMBOL(cacheable_memcpy);
196 #endif
197
198 #ifdef  CONFIG_8xx
199 EXPORT_SYMBOL(cpm_install_handler);
200 EXPORT_SYMBOL(cpm_free_handler);
201 #endif /* CONFIG_8xx */
202 #if defined(CONFIG_8xx) || defined(CONFIG_40x)
203 EXPORT_SYMBOL(__res);
204 #endif
205
206 #ifdef CONFIG_PPC32
207 EXPORT_SYMBOL(next_mmu_context);
208 EXPORT_SYMBOL(set_context);
209 #endif
210
211 #ifdef CONFIG_PPC_STD_MMU_32
212 extern long mol_trampoline;
213 EXPORT_SYMBOL(mol_trampoline); /* For MOL */
214 EXPORT_SYMBOL(flush_hash_pages); /* For MOL */
215 #ifdef CONFIG_SMP
216 extern int mmu_hash_lock;
217 EXPORT_SYMBOL(mmu_hash_lock); /* For MOL */
218 #endif /* CONFIG_SMP */
219 extern long *intercept_table;
220 EXPORT_SYMBOL(intercept_table);
221 #endif /* CONFIG_PPC_STD_MMU_32 */
222 #if defined(CONFIG_40x) || defined(CONFIG_BOOKE)
223 EXPORT_SYMBOL(__mtdcr);
224 EXPORT_SYMBOL(__mfdcr);
225 #endif