2 * Herein lies all the functions/variables that are "exported" for linkage
3 * with dynamically loaded kernel modules.
6 * - Stacked module support and unified symbol table added (June 1994)
7 * - External symbol table support added (December 1994)
8 * - Versions on symbols added (December 1994)
9 * by Bjorn Ekwall <bj0rn@blox.se>
12 #include <linux/config.h>
13 #include <linux/malloc.h>
14 #include <linux/module.h>
15 #include <linux/blkdev.h>
16 #include <linux/cdrom.h>
17 #include <linux/kernel_stat.h>
18 #include <linux/vmalloc.h>
19 #include <linux/sys.h>
20 #include <linux/utsname.h>
21 #include <linux/interrupt.h>
22 #include <linux/ioport.h>
23 #include <linux/serial.h>
24 #include <linux/locks.h>
25 #include <linux/delay.h>
26 #include <linux/minix_fs.h>
27 #include <linux/ext2_fs.h>
28 #include <linux/random.h>
29 #include <linux/reboot.h>
30 #include <linux/pagemap.h>
31 #include <linux/sysctl.h>
32 #include <linux/hdreg.h>
33 #include <linux/skbuff.h>
34 #include <linux/genhd.h>
35 #include <linux/blkpg.h>
36 #include <linux/swap.h>
37 #include <linux/ctype.h>
38 #include <linux/file.h>
39 #include <linux/iobuf.h>
40 #include <linux/console.h>
41 #include <linux/poll.h>
42 #include <linux/mmzone.h>
44 #include <linux/capability.h>
45 #include <linux/highuid.h>
46 #include <linux/brlock.h>
48 #if defined(CONFIG_PROC_FS)
49 #include <linux/proc_fs.h>
52 #include <linux/kmod.h>
55 extern int console_loglevel
;
56 extern void set_device_ro(kdev_t dev
,int flag
);
57 #if !defined(CONFIG_NFSD) && defined(CONFIG_NFSD_MODULE)
58 extern int (*do_nfsservctl
)(int, void *, void *);
61 extern void *sys_call_table
;
64 extern int request_dma(unsigned int dmanr
, char * deviceID
);
65 extern void free_dma(unsigned int dmanr
);
66 extern spinlock_t dma_spin_lock
;
68 #ifdef CONFIG_MODVERSIONS
69 const struct module_symbol __export_Using_Versions
70 __attribute__((section("__ksymtab"))) = {
71 1 /* Version version */, "Using_Versions"
77 EXPORT_SYMBOL(request_module
);
78 EXPORT_SYMBOL(exec_usermodehelper
);
82 EXPORT_SYMBOL(get_module_symbol
);
84 EXPORT_SYMBOL(get_option
);
85 EXPORT_SYMBOL(get_options
);
87 /* process memory management */
88 EXPORT_SYMBOL(do_mmap_pgoff
);
89 EXPORT_SYMBOL(do_munmap
);
90 EXPORT_SYMBOL(do_brk
);
91 EXPORT_SYMBOL(exit_mm
);
92 EXPORT_SYMBOL(exit_files
);
93 EXPORT_SYMBOL(exit_fs
);
94 EXPORT_SYMBOL(exit_sighand
);
96 /* internal kernel memory management */
97 EXPORT_SYMBOL(__alloc_pages
);
98 EXPORT_SYMBOL(alloc_pages_node
);
99 EXPORT_SYMBOL(__free_pages_ok
);
100 #ifndef CONFIG_DISCONTIGMEM
101 EXPORT_SYMBOL(contig_page_data
);
103 EXPORT_SYMBOL(num_physpages
);
104 EXPORT_SYMBOL(kmem_find_general_cachep
);
105 EXPORT_SYMBOL(kmem_cache_create
);
106 EXPORT_SYMBOL(kmem_cache_destroy
);
107 EXPORT_SYMBOL(kmem_cache_shrink
);
108 EXPORT_SYMBOL(kmem_cache_alloc
);
109 EXPORT_SYMBOL(kmem_cache_free
);
110 EXPORT_SYMBOL(kmalloc
);
111 EXPORT_SYMBOL(kfree
);
112 EXPORT_SYMBOL(kfree_s
);
113 EXPORT_SYMBOL(vmalloc
);
114 EXPORT_SYMBOL(vfree
);
115 EXPORT_SYMBOL(mem_map
);
116 EXPORT_SYMBOL(remap_page_range
);
117 EXPORT_SYMBOL(max_mapnr
);
118 EXPORT_SYMBOL(high_memory
);
119 EXPORT_SYMBOL(vmtruncate
);
120 EXPORT_SYMBOL(find_vma
);
121 EXPORT_SYMBOL(get_unmapped_area
);
122 EXPORT_SYMBOL(init_mm
);
123 #ifdef CONFIG_HIGHMEM
124 EXPORT_SYMBOL(kmap_high
);
125 EXPORT_SYMBOL(kunmap_high
);
126 EXPORT_SYMBOL(highmem_start_page
);
129 /* filesystem internal functions */
130 EXPORT_SYMBOL(def_blk_fops
);
131 EXPORT_SYMBOL(in_group_p
);
132 EXPORT_SYMBOL(update_atime
);
133 EXPORT_SYMBOL(get_super
);
134 EXPORT_SYMBOL(get_fs_type
);
135 EXPORT_SYMBOL(get_empty_super
);
136 EXPORT_SYMBOL(remove_vfsmnt
);
137 EXPORT_SYMBOL(getname
);
138 EXPORT_SYMBOL(_fput
);
139 EXPORT_SYMBOL(igrab
);
140 EXPORT_SYMBOL(iunique
);
141 EXPORT_SYMBOL(iget4
);
143 EXPORT_SYMBOL(__namei
);
144 EXPORT_SYMBOL(lookup_dentry
);
145 EXPORT_SYMBOL(open_namei
);
146 EXPORT_SYMBOL(sys_close
);
147 EXPORT_SYMBOL(d_alloc_root
);
148 EXPORT_SYMBOL(d_delete
);
149 EXPORT_SYMBOL(d_validate
);
150 EXPORT_SYMBOL(d_rehash
);
151 EXPORT_SYMBOL(d_invalidate
); /* May be it will be better in dcache.h? */
152 EXPORT_SYMBOL(d_move
);
153 EXPORT_SYMBOL(d_instantiate
);
154 EXPORT_SYMBOL(d_alloc
);
155 EXPORT_SYMBOL(d_lookup
);
156 EXPORT_SYMBOL(d_path
);
157 EXPORT_SYMBOL(mark_buffer_dirty
);
158 EXPORT_SYMBOL(__mark_buffer_dirty
);
159 EXPORT_SYMBOL(__mark_inode_dirty
);
160 EXPORT_SYMBOL(free_kiovec
);
161 EXPORT_SYMBOL(brw_kiovec
);
162 EXPORT_SYMBOL(alloc_kiovec
);
163 EXPORT_SYMBOL(expand_kiobuf
);
164 EXPORT_SYMBOL(unmap_kiobuf
);
165 EXPORT_SYMBOL(get_empty_filp
);
166 EXPORT_SYMBOL(init_private_file
);
167 EXPORT_SYMBOL(filp_open
);
168 EXPORT_SYMBOL(filp_close
);
169 EXPORT_SYMBOL(put_filp
);
170 EXPORT_SYMBOL(files_lock
);
171 EXPORT_SYMBOL(check_disk_change
);
172 EXPORT_SYMBOL(__invalidate_buffers
);
173 EXPORT_SYMBOL(invalidate_inodes
);
174 EXPORT_SYMBOL(invalidate_inode_pages
);
175 EXPORT_SYMBOL(truncate_inode_pages
);
176 EXPORT_SYMBOL(fsync_dev
);
177 EXPORT_SYMBOL(permission
);
178 EXPORT_SYMBOL(inode_setattr
);
179 EXPORT_SYMBOL(inode_change_ok
);
180 EXPORT_SYMBOL(write_inode_now
);
181 EXPORT_SYMBOL(notify_change
);
182 EXPORT_SYMBOL(get_hardblocksize
);
183 EXPORT_SYMBOL(set_blocksize
);
184 EXPORT_SYMBOL(getblk
);
185 EXPORT_SYMBOL(bdget
);
186 EXPORT_SYMBOL(bread
);
187 EXPORT_SYMBOL(breada
);
188 EXPORT_SYMBOL(__brelse
);
189 EXPORT_SYMBOL(__bforget
);
190 EXPORT_SYMBOL(ll_rw_block
);
191 EXPORT_SYMBOL(__wait_on_buffer
);
192 EXPORT_SYMBOL(___wait_on_page
);
193 EXPORT_SYMBOL(block_write_full_page
);
194 EXPORT_SYMBOL(block_read_full_page
);
195 EXPORT_SYMBOL(block_prepare_write
);
196 EXPORT_SYMBOL(cont_prepare_write
);
197 EXPORT_SYMBOL(generic_commit_write
);
198 EXPORT_SYMBOL(generic_block_bmap
);
199 EXPORT_SYMBOL(generic_file_read
);
200 EXPORT_SYMBOL(do_generic_file_read
);
201 EXPORT_SYMBOL(generic_file_write
);
202 EXPORT_SYMBOL(generic_file_mmap
);
203 EXPORT_SYMBOL(generic_ro_fops
);
204 EXPORT_SYMBOL(generic_buffer_fdatasync
);
205 EXPORT_SYMBOL(page_hash_bits
);
206 EXPORT_SYMBOL(page_hash_table
);
207 EXPORT_SYMBOL(file_lock_table
);
208 EXPORT_SYMBOL(posix_lock_file
);
209 EXPORT_SYMBOL(posix_test_lock
);
210 EXPORT_SYMBOL(posix_block_lock
);
211 EXPORT_SYMBOL(posix_unblock_lock
);
212 EXPORT_SYMBOL(locks_mandatory_area
);
214 EXPORT_SYMBOL(is_root_busy
);
215 EXPORT_SYMBOL(prune_dcache
);
216 EXPORT_SYMBOL(shrink_dcache_sb
);
217 EXPORT_SYMBOL(shrink_dcache_parent
);
218 EXPORT_SYMBOL(find_inode_number
);
219 EXPORT_SYMBOL(is_subdir
);
220 EXPORT_SYMBOL(get_unused_fd
);
221 EXPORT_SYMBOL(vfs_create
);
222 EXPORT_SYMBOL(vfs_mkdir
);
223 EXPORT_SYMBOL(vfs_mknod
);
224 EXPORT_SYMBOL(vfs_symlink
);
225 EXPORT_SYMBOL(vfs_link
);
226 EXPORT_SYMBOL(vfs_rmdir
);
227 EXPORT_SYMBOL(vfs_unlink
);
228 EXPORT_SYMBOL(vfs_rename
);
229 EXPORT_SYMBOL(generic_read_dir
);
230 EXPORT_SYMBOL(__pollwait
);
231 EXPORT_SYMBOL(ROOT_DEV
);
232 EXPORT_SYMBOL(__find_get_page
);
233 EXPORT_SYMBOL(__find_lock_page
);
234 EXPORT_SYMBOL(grab_cache_page
);
235 EXPORT_SYMBOL(read_cache_page
);
236 EXPORT_SYMBOL(vfs_readlink
);
237 EXPORT_SYMBOL(vfs_follow_link
);
238 EXPORT_SYMBOL(page_readlink
);
239 EXPORT_SYMBOL(page_follow_link
);
240 EXPORT_SYMBOL(page_symlink_inode_operations
);
241 EXPORT_SYMBOL(block_symlink
);
242 EXPORT_SYMBOL(vfs_readdir
);
244 /* for stackable file systems (lofs, wrapfs, etc.) */
245 EXPORT_SYMBOL(add_to_page_cache
);
246 EXPORT_SYMBOL(filemap_nopage
);
247 EXPORT_SYMBOL(filemap_swapout
);
248 EXPORT_SYMBOL(filemap_sync
);
249 EXPORT_SYMBOL(remove_inode_page
);
251 #if !defined(CONFIG_NFSD) && defined(CONFIG_NFSD_MODULE)
252 EXPORT_SYMBOL(do_nfsservctl
);
255 /* device registration */
256 EXPORT_SYMBOL(register_chrdev
);
257 EXPORT_SYMBOL(unregister_chrdev
);
258 EXPORT_SYMBOL(register_blkdev
);
259 EXPORT_SYMBOL(unregister_blkdev
);
260 EXPORT_SYMBOL(tty_register_driver
);
261 EXPORT_SYMBOL(tty_unregister_driver
);
262 EXPORT_SYMBOL(tty_std_termios
);
264 /* block device driver support */
265 EXPORT_SYMBOL(block_read
);
266 EXPORT_SYMBOL(block_write
);
267 EXPORT_SYMBOL(wait_for_request
);
268 EXPORT_SYMBOL(blksize_size
);
269 EXPORT_SYMBOL(hardsect_size
);
270 EXPORT_SYMBOL(blk_size
);
271 EXPORT_SYMBOL(blk_dev
);
272 EXPORT_SYMBOL(is_read_only
);
273 EXPORT_SYMBOL(set_device_ro
);
275 EXPORT_SYMBOL(sync_dev
);
276 EXPORT_SYMBOL(devfs_register_partitions
);
277 EXPORT_SYMBOL(blkdev_open
);
278 EXPORT_SYMBOL(blkdev_get
);
279 EXPORT_SYMBOL(blkdev_put
);
280 EXPORT_SYMBOL(ioctl_by_bdev
);
281 EXPORT_SYMBOL(gendisk_head
);
282 EXPORT_SYMBOL(grok_partitions
);
283 EXPORT_SYMBOL(register_disk
);
284 EXPORT_SYMBOL(tq_disk
);
285 EXPORT_SYMBOL(init_buffer
);
286 EXPORT_SYMBOL(refile_buffer
);
287 EXPORT_SYMBOL(max_sectors
);
288 EXPORT_SYMBOL(max_readahead
);
289 EXPORT_SYMBOL(file_moveto
);
292 EXPORT_SYMBOL(tty_hangup
);
293 EXPORT_SYMBOL(tty_wait_until_sent
);
294 EXPORT_SYMBOL(tty_check_change
);
295 EXPORT_SYMBOL(tty_hung_up_p
);
296 EXPORT_SYMBOL(tty_flip_buffer_push
);
297 EXPORT_SYMBOL(tty_get_baud_rate
);
298 EXPORT_SYMBOL(do_SAK
);
299 EXPORT_SYMBOL(console_print
);
300 EXPORT_SYMBOL(console_loglevel
);
302 /* filesystem registration */
303 EXPORT_SYMBOL(register_filesystem
);
304 EXPORT_SYMBOL(unregister_filesystem
);
306 /* executable format registration */
307 EXPORT_SYMBOL(register_binfmt
);
308 EXPORT_SYMBOL(unregister_binfmt
);
309 EXPORT_SYMBOL(search_binary_handler
);
310 EXPORT_SYMBOL(prepare_binprm
);
311 EXPORT_SYMBOL(compute_creds
);
312 EXPORT_SYMBOL(remove_arg_zero
);
314 /* execution environment registration */
315 EXPORT_SYMBOL(lookup_exec_domain
);
316 EXPORT_SYMBOL(register_exec_domain
);
317 EXPORT_SYMBOL(unregister_exec_domain
);
319 /* sysctl table registration */
320 EXPORT_SYMBOL(register_sysctl_table
);
321 EXPORT_SYMBOL(unregister_sysctl_table
);
322 EXPORT_SYMBOL(sysctl_string
);
323 EXPORT_SYMBOL(sysctl_intvec
);
324 EXPORT_SYMBOL(proc_dostring
);
325 EXPORT_SYMBOL(proc_dointvec
);
326 EXPORT_SYMBOL(proc_dointvec_jiffies
);
327 EXPORT_SYMBOL(proc_dointvec_minmax
);
328 EXPORT_SYMBOL(proc_doulongvec_ms_jiffies_minmax
);
329 EXPORT_SYMBOL(proc_doulongvec_minmax
);
331 /* interrupt handling */
332 EXPORT_SYMBOL(request_irq
);
333 EXPORT_SYMBOL(free_irq
);
334 EXPORT_SYMBOL(probe_irq_on
);
335 EXPORT_SYMBOL(probe_irq_off
);
336 EXPORT_SYMBOL(add_timer
);
337 EXPORT_SYMBOL(del_timer
);
339 EXPORT_SYMBOL(del_timer_sync
);
341 EXPORT_SYMBOL(mod_timer
);
342 EXPORT_SYMBOL(tq_timer
);
343 EXPORT_SYMBOL(tq_immediate
);
344 EXPORT_SYMBOL(tq_scheduler
);
345 EXPORT_SYMBOL(timer_active
);
346 EXPORT_SYMBOL(timer_table
);
349 /* Various random spinlocks we want to export */
350 EXPORT_SYMBOL(tqueue_lock
);
352 /* Big-Reader lock implementation */
353 EXPORT_SYMBOL(__brlock_array
);
354 #ifndef __BRLOCK_USE_ATOMICS
355 EXPORT_SYMBOL(__br_write_locks
);
357 EXPORT_SYMBOL(__br_write_lock
);
358 EXPORT_SYMBOL(__br_write_unlock
);
361 /* autoirq from drivers/net/auto_irq.c */
362 EXPORT_SYMBOL(autoirq_setup
);
363 EXPORT_SYMBOL(autoirq_report
);
366 EXPORT_SYMBOL(request_dma
);
367 EXPORT_SYMBOL(free_dma
);
368 EXPORT_SYMBOL(dma_spin_lock
);
369 #ifdef HAVE_DISABLE_HLT
370 EXPORT_SYMBOL(disable_hlt
);
371 EXPORT_SYMBOL(enable_hlt
);
374 /* resource handling */
375 EXPORT_SYMBOL(request_resource
);
376 EXPORT_SYMBOL(release_resource
);
377 EXPORT_SYMBOL(allocate_resource
);
378 EXPORT_SYMBOL(check_resource
);
379 EXPORT_SYMBOL(__request_region
);
380 EXPORT_SYMBOL(__check_region
);
381 EXPORT_SYMBOL(__release_region
);
382 EXPORT_SYMBOL(ioport_resource
);
383 EXPORT_SYMBOL(iomem_resource
);
385 /* process management */
386 EXPORT_SYMBOL(__wake_up
);
387 EXPORT_SYMBOL(sleep_on
);
388 EXPORT_SYMBOL(sleep_on_timeout
);
389 EXPORT_SYMBOL(interruptible_sleep_on
);
390 EXPORT_SYMBOL(interruptible_sleep_on_timeout
);
391 EXPORT_SYMBOL(schedule
);
392 EXPORT_SYMBOL(schedule_timeout
);
393 EXPORT_SYMBOL(jiffies
);
394 EXPORT_SYMBOL(xtime
);
395 EXPORT_SYMBOL(do_gettimeofday
);
397 EXPORT_SYMBOL(loops_per_sec
);
399 EXPORT_SYMBOL(kstat
);
400 EXPORT_SYMBOL(nr_running
);
403 EXPORT_SYMBOL(panic
);
404 EXPORT_SYMBOL(printk
);
405 EXPORT_SYMBOL(sprintf
);
406 EXPORT_SYMBOL(vsprintf
);
407 EXPORT_SYMBOL(kdevname
);
408 EXPORT_SYMBOL(bdevname
);
409 EXPORT_SYMBOL(cdevname
);
410 EXPORT_SYMBOL(simple_strtoul
);
411 EXPORT_SYMBOL(system_utsname
); /* UTS data */
412 EXPORT_SYMBOL(uts_sem
); /* UTS semaphore */
413 EXPORT_SYMBOL(sys_call_table
);
414 EXPORT_SYMBOL(machine_restart
);
415 EXPORT_SYMBOL(machine_halt
);
416 EXPORT_SYMBOL(machine_power_off
);
417 EXPORT_SYMBOL(register_reboot_notifier
);
418 EXPORT_SYMBOL(unregister_reboot_notifier
);
419 EXPORT_SYMBOL(_ctype
);
420 EXPORT_SYMBOL(secure_tcp_sequence_number
);
421 EXPORT_SYMBOL(get_random_bytes
);
422 EXPORT_SYMBOL(securebits
);
423 EXPORT_SYMBOL(cap_bset
);
424 EXPORT_SYMBOL(daemonize
);
426 /* Program loader interfaces */
427 EXPORT_SYMBOL(setup_arg_pages
);
428 EXPORT_SYMBOL(copy_strings_kernel
);
429 EXPORT_SYMBOL(do_execve
);
430 EXPORT_SYMBOL(flush_old_exec
);
431 EXPORT_SYMBOL(open_dentry
);
432 EXPORT_SYMBOL(read_exec
);
434 /* Miscellaneous access points */
435 EXPORT_SYMBOL(si_meminfo
);
437 /* Added to make file system as module */
438 EXPORT_SYMBOL(sys_tz
);
439 EXPORT_SYMBOL(__wait_on_super
);
440 EXPORT_SYMBOL(file_fsync
);
441 EXPORT_SYMBOL(clear_inode
);
442 EXPORT_SYMBOL(nr_async_pages
);
443 EXPORT_SYMBOL(___strtok
);
444 EXPORT_SYMBOL(init_special_inode
);
445 EXPORT_SYMBOL(read_ahead
);
446 EXPORT_SYMBOL(get_hash_table
);
447 EXPORT_SYMBOL(get_empty_inode
);
448 EXPORT_SYMBOL(insert_inode_hash
);
449 EXPORT_SYMBOL(remove_inode_hash
);
450 EXPORT_SYMBOL(make_bad_inode
);
451 EXPORT_SYMBOL(is_bad_inode
);
452 EXPORT_SYMBOL(event
);
453 EXPORT_SYMBOL(__down
);
454 EXPORT_SYMBOL(__down_interruptible
);
455 EXPORT_SYMBOL(__down_trylock
);
457 EXPORT_SYMBOL(brw_page
);
460 EXPORT_SYMBOL(overflowuid
);
461 EXPORT_SYMBOL(overflowgid
);
463 EXPORT_SYMBOL(fs_overflowuid
);
464 EXPORT_SYMBOL(fs_overflowgid
);
467 EXPORT_SYMBOL(fasync_helper
);
469 #ifdef CONFIG_BLK_DEV_MD
470 EXPORT_SYMBOL(disk_name
); /* for md.c */
474 EXPORT_SYMBOL(get_write_access
);
475 EXPORT_SYMBOL(put_write_access
);
477 /* dynamic registering of consoles */
478 EXPORT_SYMBOL(register_console
);
479 EXPORT_SYMBOL(unregister_console
);
482 EXPORT_SYMBOL(get_fast_time
);
484 /* library functions */
485 EXPORT_SYMBOL(strnicmp
);
486 EXPORT_SYMBOL(strspn
);
488 /* software interrupts */
489 EXPORT_SYMBOL(tasklet_hi_vec
);
490 EXPORT_SYMBOL(tasklet_vec
);
491 EXPORT_SYMBOL(bh_task_vec
);
492 EXPORT_SYMBOL(init_bh
);
493 EXPORT_SYMBOL(remove_bh
);
494 EXPORT_SYMBOL(tasklet_init
);
495 EXPORT_SYMBOL(tasklet_kill
);
497 /* init task, for moving kthread roots - ought to export a function ?? */
499 EXPORT_SYMBOL(init_task_union
);