Merge git://git.infradead.org/iommu-2.6
[linux-2.6] / arch / blackfin / kernel / bfin_ksyms.c
1 /*
2  * arch/blackfin/kernel/bfin_ksyms.c - exports for random symbols
3  *
4  * Copyright 2004-2008 Analog Devices Inc.
5  *
6  * Licensed under the GPL-2 or later.
7  */
8
9 #include <linux/module.h>
10 #include <linux/uaccess.h>
11
12 #include <asm/cacheflush.h>
13 #include <asm/io.h>
14
15 /* Allow people to have their own Blackfin exception handler in a module */
16 EXPORT_SYMBOL(bfin_return_from_exception);
17
18 /* All the Blackfin cache functions: mach-common/cache.S */
19 EXPORT_SYMBOL(blackfin_dcache_invalidate_range);
20 EXPORT_SYMBOL(blackfin_icache_flush_range);
21 EXPORT_SYMBOL(blackfin_dcache_flush_range);
22 EXPORT_SYMBOL(blackfin_dflush_page);
23
24 /* The following are special because they're not called
25  * explicitly (the C compiler generates them).  Fortunately,
26  * their interface isn't gonna change any time soon now, so
27  * it's OK to leave it out of version control.
28  */
29 EXPORT_SYMBOL(memcpy);
30 EXPORT_SYMBOL(memset);
31 EXPORT_SYMBOL(memcmp);
32 EXPORT_SYMBOL(memmove);
33 EXPORT_SYMBOL(memchr);
34
35 /*
36  * libgcc functions - functions that are used internally by the
37  * compiler...  (prototypes are not correct though, but that
38  * doesn't really matter since they're not versioned).
39  */
40 extern void __ashldi3(void);
41 extern void __ashrdi3(void);
42 extern void __smulsi3_highpart(void);
43 extern void __umulsi3_highpart(void);
44 extern void __divsi3(void);
45 extern void __lshrdi3(void);
46 extern void __modsi3(void);
47 extern void __muldi3(void);
48 extern void __udivsi3(void);
49 extern void __umodsi3(void);
50 EXPORT_SYMBOL(__ashldi3);
51 EXPORT_SYMBOL(__ashrdi3);
52 EXPORT_SYMBOL(__umulsi3_highpart);
53 EXPORT_SYMBOL(__smulsi3_highpart);
54 EXPORT_SYMBOL(__divsi3);
55 EXPORT_SYMBOL(__lshrdi3);
56 EXPORT_SYMBOL(__modsi3);
57 EXPORT_SYMBOL(__muldi3);
58 EXPORT_SYMBOL(__udivsi3);
59 EXPORT_SYMBOL(__umodsi3);
60
61 /* Input/output symbols: lib/{in,out}s.S */
62 EXPORT_SYMBOL(outsb);
63 EXPORT_SYMBOL(insb);
64 EXPORT_SYMBOL(outsw);
65 EXPORT_SYMBOL(outsw_8);
66 EXPORT_SYMBOL(insw);
67 EXPORT_SYMBOL(insw_8);
68 EXPORT_SYMBOL(outsl);
69 EXPORT_SYMBOL(insl);
70 EXPORT_SYMBOL(insl_16);
71
72 #ifdef CONFIG_SMP
73 EXPORT_SYMBOL(__raw_atomic_update_asm);
74 EXPORT_SYMBOL(__raw_atomic_clear_asm);
75 EXPORT_SYMBOL(__raw_atomic_set_asm);
76 EXPORT_SYMBOL(__raw_atomic_xor_asm);
77 EXPORT_SYMBOL(__raw_atomic_test_asm);
78 EXPORT_SYMBOL(__raw_xchg_1_asm);
79 EXPORT_SYMBOL(__raw_xchg_2_asm);
80 EXPORT_SYMBOL(__raw_xchg_4_asm);
81 EXPORT_SYMBOL(__raw_cmpxchg_1_asm);
82 EXPORT_SYMBOL(__raw_cmpxchg_2_asm);
83 EXPORT_SYMBOL(__raw_cmpxchg_4_asm);
84 EXPORT_SYMBOL(__raw_spin_is_locked_asm);
85 EXPORT_SYMBOL(__raw_spin_lock_asm);
86 EXPORT_SYMBOL(__raw_spin_trylock_asm);
87 EXPORT_SYMBOL(__raw_spin_unlock_asm);
88 EXPORT_SYMBOL(__raw_read_lock_asm);
89 EXPORT_SYMBOL(__raw_read_trylock_asm);
90 EXPORT_SYMBOL(__raw_read_unlock_asm);
91 EXPORT_SYMBOL(__raw_write_lock_asm);
92 EXPORT_SYMBOL(__raw_write_trylock_asm);
93 EXPORT_SYMBOL(__raw_write_unlock_asm);
94 EXPORT_SYMBOL(__raw_bit_set_asm);
95 EXPORT_SYMBOL(__raw_bit_clear_asm);
96 EXPORT_SYMBOL(__raw_bit_toggle_asm);
97 EXPORT_SYMBOL(__raw_bit_test_asm);
98 EXPORT_SYMBOL(__raw_bit_test_set_asm);
99 EXPORT_SYMBOL(__raw_bit_test_clear_asm);
100 EXPORT_SYMBOL(__raw_bit_test_toggle_asm);
101 EXPORT_SYMBOL(__raw_uncached_fetch_asm);
102 #ifdef __ARCH_SYNC_CORE_DCACHE
103 EXPORT_SYMBOL(__raw_smp_mark_barrier_asm);
104 EXPORT_SYMBOL(__raw_smp_check_barrier_asm);
105 #endif
106 #endif
107
108 #ifdef CONFIG_FUNCTION_TRACER
109 extern void _mcount(void);
110 EXPORT_SYMBOL(_mcount);
111 #endif