Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
linux
Commits
d3ed1c8f
Commit
d3ed1c8f
authored
Oct 01, 2003
by
Linus Torvalds
Browse files
Options
Browse Files
Download
Plain Diff
Merge
bk://kernel.bkbits.net/acme/ksyms-2.6
into home.osdl.org:/home/torvalds/v2.5/linux
parents
8b36cbab
982d93ca
Changes
7
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
162 additions
and
100 deletions
+162
-100
fs/block_dev.c
fs/block_dev.c
+32
-0
fs/exec.c
fs/exec.c
+26
-0
fs/inode.c
fs/inode.c
+34
-9
fs/seq_file.c
fs/seq_file.c
+24
-3
fs/super.c
fs/super.c
+29
-0
kernel/ksyms.c
kernel/ksyms.c
+0
-88
kernel/sysctl.c
kernel/sysctl.c
+17
-0
No files found.
fs/block_dev.c
View file @
d3ed1c8f
...
@@ -70,6 +70,8 @@ int set_blocksize(struct block_device *bdev, int size)
...
@@ -70,6 +70,8 @@ int set_blocksize(struct block_device *bdev, int size)
return
0
;
return
0
;
}
}
EXPORT_SYMBOL
(
set_blocksize
);
int
sb_set_blocksize
(
struct
super_block
*
sb
,
int
size
)
int
sb_set_blocksize
(
struct
super_block
*
sb
,
int
size
)
{
{
int
bits
;
int
bits
;
...
@@ -82,6 +84,8 @@ int sb_set_blocksize(struct super_block *sb, int size)
...
@@ -82,6 +84,8 @@ int sb_set_blocksize(struct super_block *sb, int size)
return
sb
->
s_blocksize
;
return
sb
->
s_blocksize
;
}
}
EXPORT_SYMBOL
(
sb_set_blocksize
);
int
sb_min_blocksize
(
struct
super_block
*
sb
,
int
size
)
int
sb_min_blocksize
(
struct
super_block
*
sb
,
int
size
)
{
{
int
minsize
=
bdev_hardsect_size
(
sb
->
s_bdev
);
int
minsize
=
bdev_hardsect_size
(
sb
->
s_bdev
);
...
@@ -90,6 +94,8 @@ int sb_min_blocksize(struct super_block *sb, int size)
...
@@ -90,6 +94,8 @@ int sb_min_blocksize(struct super_block *sb, int size)
return
sb_set_blocksize
(
sb
,
size
);
return
sb_set_blocksize
(
sb
,
size
);
}
}
EXPORT_SYMBOL
(
sb_min_blocksize
);
static
int
static
int
blkdev_get_block
(
struct
inode
*
inode
,
sector_t
iblock
,
blkdev_get_block
(
struct
inode
*
inode
,
sector_t
iblock
,
struct
buffer_head
*
bh
,
int
create
)
struct
buffer_head
*
bh
,
int
create
)
...
@@ -358,6 +364,8 @@ struct block_device *bdget(dev_t dev)
...
@@ -358,6 +364,8 @@ struct block_device *bdget(dev_t dev)
return
bdev
;
return
bdev
;
}
}
EXPORT_SYMBOL
(
bdget
);
long
nr_blockdev_pages
(
void
)
long
nr_blockdev_pages
(
void
)
{
{
struct
list_head
*
p
;
struct
list_head
*
p
;
...
@@ -376,6 +384,8 @@ void bdput(struct block_device *bdev)
...
@@ -376,6 +384,8 @@ void bdput(struct block_device *bdev)
{
{
iput
(
bdev
->
bd_inode
);
iput
(
bdev
->
bd_inode
);
}
}
EXPORT_SYMBOL
(
bdput
);
int
bd_acquire
(
struct
inode
*
inode
)
int
bd_acquire
(
struct
inode
*
inode
)
{
{
...
@@ -444,6 +454,8 @@ int bd_claim(struct block_device *bdev, void *holder)
...
@@ -444,6 +454,8 @@ int bd_claim(struct block_device *bdev, void *holder)
return
res
;
return
res
;
}
}
EXPORT_SYMBOL
(
bd_claim
);
void
bd_release
(
struct
block_device
*
bdev
)
void
bd_release
(
struct
block_device
*
bdev
)
{
{
spin_lock
(
&
bdev_lock
);
spin_lock
(
&
bdev_lock
);
...
@@ -454,6 +466,8 @@ void bd_release(struct block_device *bdev)
...
@@ -454,6 +466,8 @@ void bd_release(struct block_device *bdev)
spin_unlock
(
&
bdev_lock
);
spin_unlock
(
&
bdev_lock
);
}
}
EXPORT_SYMBOL
(
bd_release
);
/*
/*
* Tries to open block device by device number. Use it ONLY if you
* Tries to open block device by device number. Use it ONLY if you
* really do not have anything better - i.e. when you are behind a
* really do not have anything better - i.e. when you are behind a
...
@@ -471,6 +485,8 @@ struct block_device *open_by_devnum(dev_t dev, unsigned mode, int kind)
...
@@ -471,6 +485,8 @@ struct block_device *open_by_devnum(dev_t dev, unsigned mode, int kind)
return
err
?
ERR_PTR
(
err
)
:
bdev
;
return
err
?
ERR_PTR
(
err
)
:
bdev
;
}
}
EXPORT_SYMBOL
(
open_by_devnum
);
/*
/*
* This routine checks whether a removable media has been changed,
* This routine checks whether a removable media has been changed,
* and invalidates all buffer-cache-entries in that case. This
* and invalidates all buffer-cache-entries in that case. This
...
@@ -500,6 +516,8 @@ int check_disk_change(struct block_device *bdev)
...
@@ -500,6 +516,8 @@ int check_disk_change(struct block_device *bdev)
return
1
;
return
1
;
}
}
EXPORT_SYMBOL
(
check_disk_change
);
static
void
bd_set_size
(
struct
block_device
*
bdev
,
loff_t
size
)
static
void
bd_set_size
(
struct
block_device
*
bdev
,
loff_t
size
)
{
{
unsigned
bsize
=
bdev_hardsect_size
(
bdev
);
unsigned
bsize
=
bdev_hardsect_size
(
bdev
);
...
@@ -632,6 +650,8 @@ int blkdev_get(struct block_device *bdev, mode_t mode, unsigned flags, int kind)
...
@@ -632,6 +650,8 @@ int blkdev_get(struct block_device *bdev, mode_t mode, unsigned flags, int kind)
return
do_open
(
bdev
,
bdev
->
bd_inode
,
&
fake_file
);
return
do_open
(
bdev
,
bdev
->
bd_inode
,
&
fake_file
);
}
}
EXPORT_SYMBOL
(
blkdev_get
);
int
blkdev_open
(
struct
inode
*
inode
,
struct
file
*
filp
)
int
blkdev_open
(
struct
inode
*
inode
,
struct
file
*
filp
)
{
{
struct
block_device
*
bdev
;
struct
block_device
*
bdev
;
...
@@ -662,6 +682,8 @@ int blkdev_open(struct inode * inode, struct file * filp)
...
@@ -662,6 +682,8 @@ int blkdev_open(struct inode * inode, struct file * filp)
return
res
;
return
res
;
}
}
EXPORT_SYMBOL
(
blkdev_open
);
int
blkdev_put
(
struct
block_device
*
bdev
,
int
kind
)
int
blkdev_put
(
struct
block_device
*
bdev
,
int
kind
)
{
{
int
ret
=
0
;
int
ret
=
0
;
...
@@ -710,6 +732,8 @@ int blkdev_put(struct block_device *bdev, int kind)
...
@@ -710,6 +732,8 @@ int blkdev_put(struct block_device *bdev, int kind)
return
ret
;
return
ret
;
}
}
EXPORT_SYMBOL
(
blkdev_put
);
int
blkdev_close
(
struct
inode
*
inode
,
struct
file
*
filp
)
int
blkdev_close
(
struct
inode
*
inode
,
struct
file
*
filp
)
{
{
if
(
inode
->
i_bdev
->
bd_holder
==
filp
)
if
(
inode
->
i_bdev
->
bd_holder
==
filp
)
...
@@ -760,6 +784,8 @@ struct file_operations def_blk_fops = {
...
@@ -760,6 +784,8 @@ struct file_operations def_blk_fops = {
.
sendfile
=
generic_file_sendfile
,
.
sendfile
=
generic_file_sendfile
,
};
};
EXPORT_SYMBOL
(
def_blk_fops
);
int
ioctl_by_bdev
(
struct
block_device
*
bdev
,
unsigned
cmd
,
unsigned
long
arg
)
int
ioctl_by_bdev
(
struct
block_device
*
bdev
,
unsigned
cmd
,
unsigned
long
arg
)
{
{
int
res
;
int
res
;
...
@@ -770,6 +796,8 @@ int ioctl_by_bdev(struct block_device *bdev, unsigned cmd, unsigned long arg)
...
@@ -770,6 +796,8 @@ int ioctl_by_bdev(struct block_device *bdev, unsigned cmd, unsigned long arg)
return
res
;
return
res
;
}
}
EXPORT_SYMBOL
(
ioctl_by_bdev
);
/**
/**
* lookup_bdev - lookup a struct block_device by name
* lookup_bdev - lookup a struct block_device by name
*
*
...
@@ -854,6 +882,8 @@ struct block_device *open_bdev_excl(const char *path, int flags,
...
@@ -854,6 +882,8 @@ struct block_device *open_bdev_excl(const char *path, int flags,
return
ERR_PTR
(
error
);
return
ERR_PTR
(
error
);
}
}
EXPORT_SYMBOL
(
open_bdev_excl
);
/**
/**
* close_bdev_excl - release a blockdevice openen by open_bdev_excl()
* close_bdev_excl - release a blockdevice openen by open_bdev_excl()
*
*
...
@@ -867,3 +897,5 @@ void close_bdev_excl(struct block_device *bdev, int kind)
...
@@ -867,3 +897,5 @@ void close_bdev_excl(struct block_device *bdev, int kind)
bd_release
(
bdev
);
bd_release
(
bdev
);
blkdev_put
(
bdev
,
kind
);
blkdev_put
(
bdev
,
kind
);
}
}
EXPORT_SYMBOL
(
close_bdev_excl
);
fs/exec.c
View file @
d3ed1c8f
...
@@ -83,6 +83,8 @@ int register_binfmt(struct linux_binfmt * fmt)
...
@@ -83,6 +83,8 @@ int register_binfmt(struct linux_binfmt * fmt)
return
0
;
return
0
;
}
}
EXPORT_SYMBOL
(
register_binfmt
);
int
unregister_binfmt
(
struct
linux_binfmt
*
fmt
)
int
unregister_binfmt
(
struct
linux_binfmt
*
fmt
)
{
{
struct
linux_binfmt
**
tmp
=
&
formats
;
struct
linux_binfmt
**
tmp
=
&
formats
;
...
@@ -100,6 +102,8 @@ int unregister_binfmt(struct linux_binfmt * fmt)
...
@@ -100,6 +102,8 @@ int unregister_binfmt(struct linux_binfmt * fmt)
return
-
EINVAL
;
return
-
EINVAL
;
}
}
EXPORT_SYMBOL
(
unregister_binfmt
);
static
inline
void
put_binfmt
(
struct
linux_binfmt
*
fmt
)
static
inline
void
put_binfmt
(
struct
linux_binfmt
*
fmt
)
{
{
module_put
(
fmt
->
module
);
module_put
(
fmt
->
module
);
...
@@ -281,6 +285,8 @@ int copy_strings_kernel(int argc,char ** argv, struct linux_binprm *bprm)
...
@@ -281,6 +285,8 @@ int copy_strings_kernel(int argc,char ** argv, struct linux_binprm *bprm)
return
r
;
return
r
;
}
}
EXPORT_SYMBOL
(
copy_strings_kernel
);
#ifdef CONFIG_MMU
#ifdef CONFIG_MMU
/*
/*
* This routine is used to map in a page into an address space: needed by
* This routine is used to map in a page into an address space: needed by
...
@@ -443,6 +449,8 @@ int setup_arg_pages(struct linux_binprm *bprm)
...
@@ -443,6 +449,8 @@ int setup_arg_pages(struct linux_binprm *bprm)
return
0
;
return
0
;
}
}
EXPORT_SYMBOL
(
setup_arg_pages
);
#define free_arg_pages(bprm) do { } while (0)
#define free_arg_pages(bprm) do { } while (0)
#else
#else
...
@@ -493,6 +501,8 @@ struct file *open_exec(const char *name)
...
@@ -493,6 +501,8 @@ struct file *open_exec(const char *name)
goto
out
;
goto
out
;
}
}
EXPORT_SYMBOL
(
open_exec
);
int
kernel_read
(
struct
file
*
file
,
unsigned
long
offset
,
int
kernel_read
(
struct
file
*
file
,
unsigned
long
offset
,
char
*
addr
,
unsigned
long
count
)
char
*
addr
,
unsigned
long
count
)
{
{
...
@@ -508,6 +518,8 @@ int kernel_read(struct file *file, unsigned long offset,
...
@@ -508,6 +518,8 @@ int kernel_read(struct file *file, unsigned long offset,
return
result
;
return
result
;
}
}
EXPORT_SYMBOL
(
kernel_read
);
static
int
exec_mmap
(
struct
mm_struct
*
mm
)
static
int
exec_mmap
(
struct
mm_struct
*
mm
)
{
{
struct
task_struct
*
tsk
;
struct
task_struct
*
tsk
;
...
@@ -822,6 +834,8 @@ int flush_old_exec(struct linux_binprm * bprm)
...
@@ -822,6 +834,8 @@ int flush_old_exec(struct linux_binprm * bprm)
return
retval
;
return
retval
;
}
}
EXPORT_SYMBOL
(
flush_old_exec
);
/*
/*
* We mustn't allow tracing of suid binaries, unless
* We mustn't allow tracing of suid binaries, unless
* the tracer has the capability to trace anything..
* the tracer has the capability to trace anything..
...
@@ -878,6 +892,8 @@ int prepare_binprm(struct linux_binprm *bprm)
...
@@ -878,6 +892,8 @@ int prepare_binprm(struct linux_binprm *bprm)
return
kernel_read
(
bprm
->
file
,
0
,
bprm
->
buf
,
BINPRM_BUF_SIZE
);
return
kernel_read
(
bprm
->
file
,
0
,
bprm
->
buf
,
BINPRM_BUF_SIZE
);
}
}
EXPORT_SYMBOL
(
prepare_binprm
);
/*
/*
* This function is used to produce the new IDs and capabilities
* This function is used to produce the new IDs and capabilities
* from the old ones and the file's capabilities.
* from the old ones and the file's capabilities.
...
@@ -918,6 +934,8 @@ void compute_creds(struct linux_binprm *bprm)
...
@@ -918,6 +934,8 @@ void compute_creds(struct linux_binprm *bprm)
security_bprm_compute_creds
(
bprm
);
security_bprm_compute_creds
(
bprm
);
}
}
EXPORT_SYMBOL
(
compute_creds
);
void
remove_arg_zero
(
struct
linux_binprm
*
bprm
)
void
remove_arg_zero
(
struct
linux_binprm
*
bprm
)
{
{
if
(
bprm
->
argc
)
{
if
(
bprm
->
argc
)
{
...
@@ -942,6 +960,8 @@ void remove_arg_zero(struct linux_binprm *bprm)
...
@@ -942,6 +960,8 @@ void remove_arg_zero(struct linux_binprm *bprm)
}
}
}
}
EXPORT_SYMBOL
(
remove_arg_zero
);
/*
/*
* cycle the list of binary formats handler, until one recognizes the image
* cycle the list of binary formats handler, until one recognizes the image
*/
*/
...
@@ -1037,6 +1057,8 @@ int search_binary_handler(struct linux_binprm *bprm,struct pt_regs *regs)
...
@@ -1037,6 +1057,8 @@ int search_binary_handler(struct linux_binprm *bprm,struct pt_regs *regs)
return
retval
;
return
retval
;
}
}
EXPORT_SYMBOL
(
search_binary_handler
);
/*
/*
* sys_execve() executes a new program.
* sys_execve() executes a new program.
*/
*/
...
@@ -1133,6 +1155,8 @@ int do_execve(char * filename,
...
@@ -1133,6 +1155,8 @@ int do_execve(char * filename,
return
retval
;
return
retval
;
}
}
EXPORT_SYMBOL
(
do_execve
);
int
set_binfmt
(
struct
linux_binfmt
*
new
)
int
set_binfmt
(
struct
linux_binfmt
*
new
)
{
{
struct
linux_binfmt
*
old
=
current
->
binfmt
;
struct
linux_binfmt
*
old
=
current
->
binfmt
;
...
@@ -1147,6 +1171,8 @@ int set_binfmt(struct linux_binfmt *new)
...
@@ -1147,6 +1171,8 @@ int set_binfmt(struct linux_binfmt *new)
return
0
;
return
0
;
}
}
EXPORT_SYMBOL
(
set_binfmt
);
#define CORENAME_MAX_SIZE 64
#define CORENAME_MAX_SIZE 64
/* format_corename will inspect the pattern parameter, and output a
/* format_corename will inspect the pattern parameter, and output a
...
...
fs/inode.c
View file @
d3ed1c8f
...
@@ -195,6 +195,8 @@ void inode_init_once(struct inode *inode)
...
@@ -195,6 +195,8 @@ void inode_init_once(struct inode *inode)
i_size_ordered_init
(
inode
);
i_size_ordered_init
(
inode
);
}
}
EXPORT_SYMBOL
(
inode_init_once
);
static
void
init_once
(
void
*
foo
,
kmem_cache_t
*
cachep
,
unsigned
long
flags
)
static
void
init_once
(
void
*
foo
,
kmem_cache_t
*
cachep
,
unsigned
long
flags
)
{
{
struct
inode
*
inode
=
(
struct
inode
*
)
foo
;
struct
inode
*
inode
=
(
struct
inode
*
)
foo
;
...
@@ -229,7 +231,6 @@ void __iget(struct inode * inode)
...
@@ -229,7 +231,6 @@ void __iget(struct inode * inode)
* that the inode is no longer useful. We just
* that the inode is no longer useful. We just
* terminate it with extreme prejudice.
* terminate it with extreme prejudice.
*/
*/
void
clear_inode
(
struct
inode
*
inode
)
void
clear_inode
(
struct
inode
*
inode
)
{
{
invalidate_inode_buffers
(
inode
);
invalidate_inode_buffers
(
inode
);
...
@@ -251,6 +252,8 @@ void clear_inode(struct inode *inode)
...
@@ -251,6 +252,8 @@ void clear_inode(struct inode *inode)
inode
->
i_state
=
I_CLEAR
;
inode
->
i_state
=
I_CLEAR
;
}
}
EXPORT_SYMBOL
(
clear_inode
);
/*
/*
* Dispose-list gets a local list with local inodes in it, so it doesn't
* Dispose-list gets a local list with local inodes in it, so it doesn't
* need to worry about list corruption and SMP locks.
* need to worry about list corruption and SMP locks.
...
@@ -327,7 +330,6 @@ static int invalidate_list(struct list_head *head, struct super_block * sb, stru
...
@@ -327,7 +330,6 @@ static int invalidate_list(struct list_head *head, struct super_block * sb, stru
* fails because there are busy inodes then a non zero value is returned.
* fails because there are busy inodes then a non zero value is returned.
* If the discard is successful all the inodes have been discarded.
* If the discard is successful all the inodes have been discarded.
*/
*/
int
invalidate_inodes
(
struct
super_block
*
sb
)
int
invalidate_inodes
(
struct
super_block
*
sb
)
{
{
int
busy
;
int
busy
;
...
@@ -346,6 +348,8 @@ int invalidate_inodes(struct super_block * sb)
...
@@ -346,6 +348,8 @@ int invalidate_inodes(struct super_block * sb)
return
busy
;
return
busy
;
}
}
EXPORT_SYMBOL
(
invalidate_inodes
);
int
__invalidate_device
(
struct
block_device
*
bdev
,
int
do_sync
)
int
__invalidate_device
(
struct
block_device
*
bdev
,
int
do_sync
)
{
{
...
@@ -372,6 +376,8 @@ int __invalidate_device(struct block_device *bdev, int do_sync)
...
@@ -372,6 +376,8 @@ int __invalidate_device(struct block_device *bdev, int do_sync)
return
res
;
return
res
;
}
}
EXPORT_SYMBOL
(
__invalidate_device
);
static
int
can_unuse
(
struct
inode
*
inode
)
static
int
can_unuse
(
struct
inode
*
inode
)
{
{
if
(
inode
->
i_state
)
if
(
inode
->
i_state
)
...
@@ -532,7 +538,6 @@ static struct inode * find_inode_fast(struct super_block * sb, struct hlist_head
...
@@ -532,7 +538,6 @@ static struct inode * find_inode_fast(struct super_block * sb, struct hlist_head
*
*
* Allocates a new inode for given superblock.
* Allocates a new inode for given superblock.
*/
*/
struct
inode
*
new_inode
(
struct
super_block
*
sb
)
struct
inode
*
new_inode
(
struct
super_block
*
sb
)
{
{
static
unsigned
long
last_ino
;
static
unsigned
long
last_ino
;
...
@@ -552,6 +557,8 @@ struct inode *new_inode(struct super_block *sb)
...
@@ -552,6 +557,8 @@ struct inode *new_inode(struct super_block *sb)
return
inode
;
return
inode
;
}
}
EXPORT_SYMBOL
(
new_inode
);
void
unlock_new_inode
(
struct
inode
*
inode
)
void
unlock_new_inode
(
struct
inode
*
inode
)
{
{
/*
/*
...
@@ -565,6 +572,7 @@ void unlock_new_inode(struct inode *inode)
...
@@ -565,6 +572,7 @@ void unlock_new_inode(struct inode *inode)
inode
->
i_state
&=
~
(
I_LOCK
|
I_NEW
);
inode
->
i_state
&=
~
(
I_LOCK
|
I_NEW
);
wake_up_inode
(
inode
);
wake_up_inode
(
inode
);
}
}
EXPORT_SYMBOL
(
unlock_new_inode
);
EXPORT_SYMBOL
(
unlock_new_inode
);
/*
/*
...
@@ -685,7 +693,6 @@ static inline unsigned long hash(struct super_block *sb, unsigned long hashval)
...
@@ -685,7 +693,6 @@ static inline unsigned long hash(struct super_block *sb, unsigned long hashval)
* With a large number of inodes live on the file system this function
* With a large number of inodes live on the file system this function
* currently becomes quite slow.
* currently becomes quite slow.
*/
*/
ino_t
iunique
(
struct
super_block
*
sb
,
ino_t
max_reserved
)
ino_t
iunique
(
struct
super_block
*
sb
,
ino_t
max_reserved
)
{
{
static
ino_t
counter
;
static
ino_t
counter
;
...
@@ -709,6 +716,8 @@ ino_t iunique(struct super_block *sb, ino_t max_reserved)
...
@@ -709,6 +716,8 @@ ino_t iunique(struct super_block *sb, ino_t max_reserved)
}
}
EXPORT_SYMBOL
(
iunique
);
struct
inode
*
igrab
(
struct
inode
*
inode
)
struct
inode
*
igrab
(
struct
inode
*
inode
)
{
{
spin_lock
(
&
inode_lock
);
spin_lock
(
&
inode_lock
);
...
@@ -725,6 +734,8 @@ struct inode *igrab(struct inode *inode)
...
@@ -725,6 +734,8 @@ struct inode *igrab(struct inode *inode)
return
inode
;
return
inode
;
}
}
EXPORT_SYMBOL
(
igrab
);
/**
/**
* ifind - internal function, you want ilookup5() or iget5().
* ifind - internal function, you want ilookup5() or iget5().
* @sb: super block of file system to search
* @sb: super block of file system to search
...
@@ -818,6 +829,7 @@ struct inode *ilookup5(struct super_block *sb, unsigned long hashval,
...
@@ -818,6 +829,7 @@ struct inode *ilookup5(struct super_block *sb, unsigned long hashval,
return
ifind
(
sb
,
head
,
test
,
data
);
return
ifind
(
sb
,
head
,
test
,
data
);
}
}
EXPORT_SYMBOL
(
ilookup5
);
EXPORT_SYMBOL
(
ilookup5
);
/**
/**
...
@@ -840,6 +852,7 @@ struct inode *ilookup(struct super_block *sb, unsigned long ino)
...
@@ -840,6 +852,7 @@ struct inode *ilookup(struct super_block *sb, unsigned long ino)
return
ifind_fast
(
sb
,
head
,
ino
);
return
ifind_fast
(
sb
,
head
,
ino
);
}
}
EXPORT_SYMBOL
(
ilookup
);
EXPORT_SYMBOL
(
ilookup
);
/**
/**
...
@@ -880,6 +893,7 @@ struct inode *iget5_locked(struct super_block *sb, unsigned long hashval,
...
@@ -880,6 +893,7 @@ struct inode *iget5_locked(struct super_block *sb, unsigned long hashval,
*/
*/
return
get_new_inode
(
sb
,
head
,
test
,
set
,
data
);
return
get_new_inode
(
sb
,
head
,
test
,
set
,
data
);
}
}
EXPORT_SYMBOL
(
iget5_locked
);
EXPORT_SYMBOL
(
iget5_locked
);
/**
/**
...
@@ -913,6 +927,7 @@ struct inode *iget_locked(struct super_block *sb, unsigned long ino)
...
@@ -913,6 +927,7 @@ struct inode *iget_locked(struct super_block *sb, unsigned long ino)
*/
*/
return
get_new_inode_fast
(
sb
,
head
,
ino
);
return
get_new_inode_fast
(
sb
,
head
,
ino
);
}
}
EXPORT_SYMBOL
(
iget_locked
);
EXPORT_SYMBOL
(
iget_locked
);
/**
/**
...
@@ -923,7 +938,6 @@ EXPORT_SYMBOL(iget_locked);
...
@@ -923,7 +938,6 @@ EXPORT_SYMBOL(iget_locked);
*
*
* Add an inode to the inode hash for this superblock.
* Add an inode to the inode hash for this superblock.
*/
*/
void
__insert_inode_hash
(
struct
inode
*
inode
,
unsigned
long
hashval
)
void
__insert_inode_hash
(
struct
inode
*
inode
,
unsigned
long
hashval
)
{
{
struct
hlist_head
*
head
=
inode_hashtable
+
hash
(
inode
->
i_sb
,
hashval
);
struct
hlist_head
*
head
=
inode_hashtable
+
hash
(
inode
->
i_sb
,
hashval
);
...
@@ -932,13 +946,14 @@ void __insert_inode_hash(struct inode *inode, unsigned long hashval)
...
@@ -932,13 +946,14 @@ void __insert_inode_hash(struct inode *inode, unsigned long hashval)
spin_unlock
(
&
inode_lock
);
spin_unlock
(
&
inode_lock
);
}
}
EXPORT_SYMBOL
(
__insert_inode_hash
);
/**
/**
* remove_inode_hash - remove an inode from the hash
* remove_inode_hash - remove an inode from the hash
* @inode: inode to unhash
* @inode: inode to unhash
*
*
* Remove an inode from the superblock.
* Remove an inode from the superblock.
*/
*/
void
remove_inode_hash
(
struct
inode
*
inode
)
void
remove_inode_hash
(
struct
inode
*
inode
)
{
{
spin_lock
(
&
inode_lock
);
spin_lock
(
&
inode_lock
);
...
@@ -946,6 +961,8 @@ void remove_inode_hash(struct inode *inode)
...
@@ -946,6 +961,8 @@ void remove_inode_hash(struct inode *inode)
spin_unlock
(
&
inode_lock
);
spin_unlock
(
&
inode_lock
);
}
}
EXPORT_SYMBOL
(
remove_inode_hash
);
/*
/*
* Tell the filesystem that this inode is no longer of any interest and should
* Tell the filesystem that this inode is no longer of any interest and should
* be completely destroyed.
* be completely destroyed.
...
@@ -988,6 +1005,7 @@ void generic_delete_inode(struct inode *inode)
...
@@ -988,6 +1005,7 @@ void generic_delete_inode(struct inode *inode)
BUG
();
BUG
();
destroy_inode
(
inode
);
destroy_inode
(
inode
);
}
}
EXPORT_SYMBOL
(
generic_delete_inode
);
EXPORT_SYMBOL
(
generic_delete_inode
);
static
void
generic_forget_inode
(
struct
inode
*
inode
)
static
void
generic_forget_inode
(
struct
inode
*
inode
)
...
@@ -1059,7 +1077,6 @@ static inline void iput_final(struct inode *inode)
...
@@ -1059,7 +1077,6 @@ static inline void iput_final(struct inode *inode)
* Puts an inode, dropping its usage count. If the inode use count hits
* Puts an inode, dropping its usage count. If the inode use count hits
* zero the inode is also then freed and may be destroyed.
* zero the inode is also then freed and may be destroyed.
*/
*/
void
iput
(
struct
inode
*
inode
)
void
iput
(
struct
inode
*
inode
)
{
{
if
(
inode
)
{
if
(
inode
)
{
...
@@ -1076,6 +1093,8 @@ void iput(struct inode *inode)
...
@@ -1076,6 +1093,8 @@ void iput(struct inode *inode)
}
}
}
}
EXPORT_SYMBOL
(
iput
);
/**
/**
* bmap - find a block number in a file
* bmap - find a block number in a file
* @inode: inode of file
* @inode: inode of file
...
@@ -1087,7 +1106,6 @@ void iput(struct inode *inode)
...
@@ -1087,7 +1106,6 @@ void iput(struct inode *inode)
* disk block relative to the disk start that holds that block of the
* disk block relative to the disk start that holds that block of the
* file.
* file.
*/
*/
sector_t
bmap
(
struct
inode
*
inode
,
sector_t
block
)
sector_t
bmap
(
struct
inode
*
inode
,
sector_t
block
)
{
{
sector_t
res
=
0
;
sector_t
res
=
0
;
...
@@ -1096,6 +1114,8 @@ sector_t bmap(struct inode * inode, sector_t block)
...
@@ -1096,6 +1114,8 @@ sector_t bmap(struct inode * inode, sector_t block)
return
res
;
return
res
;
}
}
EXPORT_SYMBOL
(
bmap
);
/*
/*
* Return true if the filesystem which backs this inode considers the two
* Return true if the filesystem which backs this inode considers the two
* passed timespecs to be sufficiently different to warrant flushing the
* passed timespecs to be sufficiently different to warrant flushing the
...
@@ -1117,7 +1137,6 @@ static int inode_times_differ(struct inode *inode,
...
@@ -1117,7 +1137,6 @@ static int inode_times_differ(struct inode *inode,
* This function automatically handles read only file systems and media,
* This function automatically handles read only file systems and media,
* as well as the "noatime" flag and inode specific "noatime" markers.
* as well as the "noatime" flag and inode specific "noatime" markers.
*/
*/
void
update_atime
(
struct
inode
*
inode
)
void
update_atime
(
struct
inode
*
inode
)
{
{
struct
timespec
now
;
struct
timespec
now
;
...
@@ -1139,6 +1158,8 @@ void update_atime(struct inode *inode)
...
@@ -1139,6 +1158,8 @@ void update_atime(struct inode *inode)
}
}
}
}
EXPORT_SYMBOL
(
update_atime
);
/**
/**
* inode_update_time - update mtime and ctime time
* inode_update_time - update mtime and ctime time
* @inode: inode accessed
* @inode: inode accessed
...
@@ -1170,6 +1191,7 @@ void inode_update_time(struct inode *inode, int ctime_too)
...
@@ -1170,6 +1191,7 @@ void inode_update_time(struct inode *inode, int ctime_too)
if
(
sync_it
)
if
(
sync_it
)
mark_inode_dirty_sync
(
inode
);
mark_inode_dirty_sync
(
inode
);
}
}
EXPORT_SYMBOL
(
inode_update_time
);
EXPORT_SYMBOL
(
inode_update_time
);
int
inode_needs_sync
(
struct
inode
*
inode
)
int
inode_needs_sync
(
struct
inode
*
inode
)
...
@@ -1180,6 +1202,7 @@ int inode_needs_sync(struct inode *inode)
...
@@ -1180,6 +1202,7 @@ int inode_needs_sync(struct inode *inode)
return
1
;
return
1
;
return
0
;
return
0
;
}
}
EXPORT_SYMBOL
(
inode_needs_sync
);
EXPORT_SYMBOL
(
inode_needs_sync
);
/*
/*
...
@@ -1375,3 +1398,5 @@ void init_special_inode(struct inode *inode, umode_t mode, dev_t rdev)
...
@@ -1375,3 +1398,5 @@ void init_special_inode(struct inode *inode, umode_t mode, dev_t rdev)
printk
(
KERN_DEBUG
"init_special_inode: bogus i_mode (%o)
\n
"
,
printk
(
KERN_DEBUG
"init_special_inode: bogus i_mode (%o)
\n
"
,
mode
);
mode
);
}
}
EXPORT_SYMBOL
(
init_special_inode
);
fs/seq_file.c
View file @
d3ed1c8f
...
@@ -6,6 +6,7 @@
...
@@ -6,6 +6,7 @@
*/
*/
#include <linux/fs.h>
#include <linux/fs.h>
#include <linux/module.h>
#include <linux/seq_file.h>
#include <linux/seq_file.h>
#include <linux/slab.h>
#include <linux/slab.h>
...
@@ -37,6 +38,8 @@ int seq_open(struct file *file, struct seq_operations *op)
...
@@ -37,6 +38,8 @@ int seq_open(struct file *file, struct seq_operations *op)
return
0
;
return
0
;
}
}
EXPORT_SYMBOL
(
seq_open
);
/**
/**
* seq_read - ->read() method for sequential files.
* seq_read - ->read() method for sequential files.
* @file, @buf, @size, @ppos: see file_operations method
* @file, @buf, @size, @ppos: see file_operations method
...
@@ -144,6 +147,8 @@ ssize_t seq_read(struct file *file, char __user *buf, size_t size, loff_t *ppos)
...
@@ -144,6 +147,8 @@ ssize_t seq_read(struct file *file, char __user *buf, size_t size, loff_t *ppos)
goto
Done
;
goto
Done
;
}
}
EXPORT_SYMBOL
(
seq_read
);
static
int
traverse
(
struct
seq_file
*
m
,
loff_t
offset
)
static
int
traverse
(
struct
seq_file
*
m
,
loff_t
offset
)
{
{
loff_t
pos
=
0
;
loff_t
pos
=
0
;
...
@@ -228,6 +233,8 @@ loff_t seq_lseek(struct file *file, loff_t offset, int origin)
...
@@ -228,6 +233,8 @@ loff_t seq_lseek(struct file *file, loff_t offset, int origin)
return
retval
;
return
retval
;
}
}
EXPORT_SYMBOL
(
seq_lseek
);
/**
/**
* seq_release - free the structures associated with sequential file.
* seq_release - free the structures associated with sequential file.
* @file: file in question
* @file: file in question
...
@@ -244,6 +251,8 @@ int seq_release(struct inode *inode, struct file *file)
...
@@ -244,6 +251,8 @@ int seq_release(struct inode *inode, struct file *file)
return
0
;
return
0
;
}
}
EXPORT_SYMBOL
(
seq_release
);
/**
/**
* seq_escape - print string into buffer, escaping some characters
* seq_escape - print string into buffer, escaping some characters
* @m: target buffer
* @m: target buffer
...
@@ -279,6 +288,8 @@ int seq_escape(struct seq_file *m, const char *s, const char *esc)
...
@@ -279,6 +288,8 @@ int seq_escape(struct seq_file *m, const char *s, const char *esc)
return
0
;
return
0
;
}
}
EXPORT_SYMBOL
(
seq_escape
);
int
seq_printf
(
struct
seq_file
*
m
,
const
char
*
f
,
...)
int
seq_printf
(
struct
seq_file
*
m
,
const
char
*
f
,
...)
{
{
va_list
args
;
va_list
args
;
...
@@ -297,9 +308,11 @@ int seq_printf(struct seq_file *m, const char *f, ...)
...
@@ -297,9 +308,11 @@ int seq_printf(struct seq_file *m, const char *f, ...)
return
-
1
;
return
-
1
;
}
}
EXPORT_SYMBOL
(
seq_printf
);
int
seq_path
(
struct
seq_file
*
m
,
int
seq_path
(
struct
seq_file
*
m
,
struct
vfsmount
*
mnt
,
struct
dentry
*
dentry
,
struct
vfsmount
*
mnt
,
struct
dentry
*
dentry
,
char
*
esc
)
char
*
esc
)
{
{
if
(
m
->
count
<
m
->
size
)
{
if
(
m
->
count
<
m
->
size
)
{
char
*
s
=
m
->
buf
+
m
->
count
;
char
*
s
=
m
->
buf
+
m
->
count
;
...
@@ -328,6 +341,8 @@ int seq_path(struct seq_file *m,
...
@@ -328,6 +341,8 @@ int seq_path(struct seq_file *m,
return
-
1
;
return
-
1
;
}
}
EXPORT_SYMBOL
(
seq_path
);
static
void
*
single_start
(
struct
seq_file
*
p
,
loff_t
*
pos
)
static
void
*
single_start
(
struct
seq_file
*
p
,
loff_t
*
pos
)
{
{
return
NULL
+
(
*
pos
==
0
);
return
NULL
+
(
*
pos
==
0
);
...
@@ -343,7 +358,8 @@ static void single_stop(struct seq_file *p, void *v)
...
@@ -343,7 +358,8 @@ static void single_stop(struct seq_file *p, void *v)
{
{
}
}
int
single_open
(
struct
file
*
file
,
int
(
*
show
)(
struct
seq_file
*
,
void
*
),
void
*
data
)
int
single_open
(
struct
file
*
file
,
int
(
*
show
)(
struct
seq_file
*
,
void
*
),
void
*
data
)
{
{
struct
seq_operations
*
op
=
kmalloc
(
sizeof
(
*
op
),
GFP_KERNEL
);
struct
seq_operations
*
op
=
kmalloc
(
sizeof
(
*
op
),
GFP_KERNEL
);
int
res
=
-
ENOMEM
;
int
res
=
-
ENOMEM
;
...
@@ -362,6 +378,8 @@ int single_open(struct file *file, int (*show)(struct seq_file *, void*), void *
...
@@ -362,6 +378,8 @@ int single_open(struct file *file, int (*show)(struct seq_file *, void*), void *
return
res
;
return
res
;
}
}
EXPORT_SYMBOL
(
single_open
);
int
single_release
(
struct
inode
*
inode
,
struct
file
*
file
)
int
single_release
(
struct
inode
*
inode
,
struct
file
*
file
)
{
{
struct
seq_operations
*
op
=
((
struct
seq_file
*
)
file
->
private_data
)
->
op
;
struct
seq_operations
*
op
=
((
struct
seq_file
*
)
file
->
private_data
)
->
op
;
...
@@ -370,6 +388,8 @@ int single_release(struct inode *inode, struct file *file)
...
@@ -370,6 +388,8 @@ int single_release(struct inode *inode, struct file *file)
return
res
;
return
res
;
}
}
EXPORT_SYMBOL
(
single_release
);
int
seq_release_private
(
struct
inode
*
inode
,
struct
file
*
file
)
int
seq_release_private
(
struct
inode
*
inode
,
struct
file
*
file
)
{
{
struct
seq_file
*
seq
=
file
->
private_data
;
struct
seq_file
*
seq
=
file
->
private_data
;
...
@@ -379,3 +399,4 @@ int seq_release_private(struct inode *inode, struct file *file)
...
@@ -379,3 +399,4 @@ int seq_release_private(struct inode *inode, struct file *file)
return
seq_release
(
inode
,
file
);
return
seq_release
(
inode
,
file
);
}
}
EXPORT_SYMBOL
(
seq_release_private
);
fs/super.c
View file @
d3ed1c8f
...
@@ -21,6 +21,7 @@
...
@@ -21,6 +21,7 @@
*/
*/
#include <linux/config.h>
#include <linux/config.h>
#include <linux/module.h>
#include <linux/slab.h>
#include <linux/slab.h>
#include <linux/smp_lock.h>
#include <linux/smp_lock.h>
#include <linux/acct.h>
#include <linux/acct.h>
...
@@ -134,6 +135,8 @@ void deactivate_super(struct super_block *s)
...
@@ -134,6 +135,8 @@ void deactivate_super(struct super_block *s)
}
}
}
}
EXPORT_SYMBOL
(
deactivate_super
);
/**
/**
* grab_super - acquire an active reference
* grab_super - acquire an active reference
* @s - reference we are trying to make active
* @s - reference we are trying to make active
...
@@ -214,6 +217,8 @@ void generic_shutdown_super(struct super_block *sb)
...
@@ -214,6 +217,8 @@ void generic_shutdown_super(struct super_block *sb)
up_write
(
&
sb
->
s_umount
);
up_write
(
&
sb
->
s_umount
);
}
}
EXPORT_SYMBOL
(
generic_shutdown_super
);
/**
/**
* sget - find or create a superblock
* sget - find or create a superblock
* @type: filesystem type superblock should belong to
* @type: filesystem type superblock should belong to
...
@@ -259,12 +264,16 @@ struct super_block *sget(struct file_system_type *type,
...
@@ -259,12 +264,16 @@ struct super_block *sget(struct file_system_type *type,
return
s
;
return
s
;
}
}
EXPORT_SYMBOL
(
sget
);
void
drop_super
(
struct
super_block
*
sb
)
void
drop_super
(
struct
super_block
*
sb
)
{
{
up_read
(
&
sb
->
s_umount
);
up_read
(
&
sb
->
s_umount
);
put_super
(
sb
);
put_super
(
sb
);
}
}
EXPORT_SYMBOL
(
drop_super
);
static
inline
void
write_super
(
struct
super_block
*
sb
)
static
inline
void
write_super
(
struct
super_block
*
sb
)
{
{
lock_super
(
sb
);
lock_super
(
sb
);
...
@@ -382,6 +391,8 @@ struct super_block * get_super(struct block_device *bdev)
...
@@ -382,6 +391,8 @@ struct super_block * get_super(struct block_device *bdev)
spin_unlock
(
&
sb_lock
);
spin_unlock
(
&
sb_lock
);
return
NULL
;
return
NULL
;
}
}
EXPORT_SYMBOL
(
get_super
);
struct
super_block
*
user_get_super
(
dev_t
dev
)
struct
super_block
*
user_get_super
(
dev_t
dev
)
{
{
...
@@ -405,6 +416,8 @@ struct super_block * user_get_super(dev_t dev)
...
@@ -405,6 +416,8 @@ struct super_block * user_get_super(dev_t dev)
return
NULL
;
return
NULL
;
}
}
EXPORT_SYMBOL
(
user_get_super
);
asmlinkage
long
sys_ustat
(
unsigned
dev
,
struct
ustat
__user
*
ubuf
)
asmlinkage
long
sys_ustat
(
unsigned
dev
,
struct
ustat
__user
*
ubuf
)
{
{
struct
super_block
*
s
;
struct
super_block
*
s
;
...
@@ -534,6 +547,8 @@ int set_anon_super(struct super_block *s, void *data)
...
@@ -534,6 +547,8 @@ int set_anon_super(struct super_block *s, void *data)
return
0
;
return
0
;
}
}
EXPORT_SYMBOL
(
set_anon_super
);
void
kill_anon_super
(
struct
super_block
*
sb
)
void
kill_anon_super
(
struct
super_block
*
sb
)
{
{
int
slot
=
MINOR
(
sb
->
s_dev
);
int
slot
=
MINOR
(
sb
->
s_dev
);
...
@@ -543,6 +558,8 @@ void kill_anon_super(struct super_block *sb)
...
@@ -543,6 +558,8 @@ void kill_anon_super(struct super_block *sb)
spin_unlock
(
&
unnamed_dev_lock
);
spin_unlock
(
&
unnamed_dev_lock
);
}
}
EXPORT_SYMBOL
(
kill_anon_super
);
void
kill_litter_super
(
struct
super_block
*
sb
)
void
kill_litter_super
(
struct
super_block
*
sb
)
{
{
if
(
sb
->
s_root
)
if
(
sb
->
s_root
)
...
@@ -550,6 +567,8 @@ void kill_litter_super(struct super_block *sb)
...
@@ -550,6 +567,8 @@ void kill_litter_super(struct super_block *sb)
kill_anon_super
(
sb
);
kill_anon_super
(
sb
);
}
}
EXPORT_SYMBOL
(
kill_litter_super
);
static
int
set_bdev_super
(
struct
super_block
*
s
,
void
*
data
)
static
int
set_bdev_super
(
struct
super_block
*
s
,
void
*
data
)
{
{
s
->
s_bdev
=
data
;
s
->
s_bdev
=
data
;
...
@@ -608,6 +627,8 @@ struct super_block *get_sb_bdev(struct file_system_type *fs_type,
...
@@ -608,6 +627,8 @@ struct super_block *get_sb_bdev(struct file_system_type *fs_type,
return
s
;
return
s
;
}
}
EXPORT_SYMBOL
(
get_sb_bdev
);
void
kill_block_super
(
struct
super_block
*
sb
)
void
kill_block_super
(
struct
super_block
*
sb
)
{
{
struct
block_device
*
bdev
=
sb
->
s_bdev
;
struct
block_device
*
bdev
=
sb
->
s_bdev
;
...
@@ -616,6 +637,8 @@ void kill_block_super(struct super_block *sb)
...
@@ -616,6 +637,8 @@ void kill_block_super(struct super_block *sb)
close_bdev_excl
(
bdev
,
BDEV_FS
);
close_bdev_excl
(
bdev
,
BDEV_FS
);
}
}
EXPORT_SYMBOL
(
kill_block_super
);
struct
super_block
*
get_sb_nodev
(
struct
file_system_type
*
fs_type
,
struct
super_block
*
get_sb_nodev
(
struct
file_system_type
*
fs_type
,
int
flags
,
void
*
data
,
int
flags
,
void
*
data
,
int
(
*
fill_super
)(
struct
super_block
*
,
void
*
,
int
))
int
(
*
fill_super
)(
struct
super_block
*
,
void
*
,
int
))
...
@@ -638,6 +661,8 @@ struct super_block *get_sb_nodev(struct file_system_type *fs_type,
...
@@ -638,6 +661,8 @@ struct super_block *get_sb_nodev(struct file_system_type *fs_type,
return
s
;
return
s
;
}
}
EXPORT_SYMBOL
(
get_sb_nodev
);
static
int
compare_single
(
struct
super_block
*
s
,
void
*
p
)
static
int
compare_single
(
struct
super_block
*
s
,
void
*
p
)
{
{
return
1
;
return
1
;
...
@@ -667,6 +692,8 @@ struct super_block *get_sb_single(struct file_system_type *fs_type,
...
@@ -667,6 +692,8 @@ struct super_block *get_sb_single(struct file_system_type *fs_type,
return
s
;
return
s
;
}
}
EXPORT_SYMBOL
(
get_sb_single
);
struct
vfsmount
*
struct
vfsmount
*
do_kern_mount
(
const
char
*
fstype
,
int
flags
,
const
char
*
name
,
void
*
data
)
do_kern_mount
(
const
char
*
fstype
,
int
flags
,
const
char
*
name
,
void
*
data
)
{
{
...
@@ -709,3 +736,5 @@ struct vfsmount *kern_mount(struct file_system_type *type)
...
@@ -709,3 +736,5 @@ struct vfsmount *kern_mount(struct file_system_type *type)
{
{
return
do_kern_mount
(
type
->
name
,
0
,
type
->
name
,
NULL
);
return
do_kern_mount
(
type
->
name
,
0
,
type
->
name
,
NULL
);
}
}
EXPORT_SYMBOL
(
kern_mount
);
kernel/ksyms.c
View file @
d3ed1c8f
...
@@ -45,7 +45,6 @@
...
@@ -45,7 +45,6 @@
#include <linux/uio.h>
#include <linux/uio.h>
#include <linux/tty.h>
#include <linux/tty.h>
#include <linux/in6.h>
#include <linux/in6.h>
#include <linux/seq_file.h>
#include <linux/binfmts.h>
#include <linux/binfmts.h>
#include <linux/namei.h>
#include <linux/namei.h>
#include <linux/buffer_head.h>
#include <linux/buffer_head.h>
...
@@ -138,18 +137,9 @@ EXPORT_SYMBOL(page_address);
...
@@ -138,18 +137,9 @@ EXPORT_SYMBOL(page_address);
EXPORT_SYMBOL
(
get_user_pages
);
EXPORT_SYMBOL
(
get_user_pages
);
/* filesystem internal functions */
/* filesystem internal functions */
EXPORT_SYMBOL
(
def_blk_fops
);
EXPORT_SYMBOL
(
update_atime
);
EXPORT_SYMBOL
(
get_fs_type
);
EXPORT_SYMBOL
(
get_fs_type
);
EXPORT_SYMBOL
(
user_get_super
);
EXPORT_SYMBOL
(
get_super
);
EXPORT_SYMBOL
(
drop_super
);
EXPORT_SYMBOL
(
fput
);
EXPORT_SYMBOL
(
fput
);
EXPORT_SYMBOL
(
fget
);
EXPORT_SYMBOL
(
fget
);
EXPORT_SYMBOL
(
igrab
);
EXPORT_SYMBOL
(
iunique
);
EXPORT_SYMBOL
(
iput
);
EXPORT_SYMBOL
(
inode_init_once
);
EXPORT_SYMBOL
(
lookup_mnt
);
EXPORT_SYMBOL
(
lookup_mnt
);
EXPORT_SYMBOL
(
sys_close
);
EXPORT_SYMBOL
(
sys_close
);
EXPORT_SYMBOL
(
dcache_lock
);
EXPORT_SYMBOL
(
dcache_lock
);
...
@@ -161,9 +151,6 @@ EXPORT_SYMBOL(filp_open);
...
@@ -161,9 +151,6 @@ EXPORT_SYMBOL(filp_open);
EXPORT_SYMBOL
(
filp_close
);
EXPORT_SYMBOL
(
filp_close
);
EXPORT_SYMBOL
(
put_filp
);
EXPORT_SYMBOL
(
put_filp
);
EXPORT_SYMBOL
(
files_lock
);
EXPORT_SYMBOL
(
files_lock
);
EXPORT_SYMBOL
(
check_disk_change
);
EXPORT_SYMBOL
(
invalidate_inodes
);
EXPORT_SYMBOL
(
__invalidate_device
);
EXPORT_SYMBOL
(
invalidate_inode_pages
);
EXPORT_SYMBOL
(
invalidate_inode_pages
);
EXPORT_SYMBOL_GPL
(
invalidate_inode_pages2
);
EXPORT_SYMBOL_GPL
(
invalidate_inode_pages2
);
EXPORT_SYMBOL
(
truncate_inode_pages
);
EXPORT_SYMBOL
(
truncate_inode_pages
);
...
@@ -171,16 +158,6 @@ EXPORT_SYMBOL(inode_setattr);
...
@@ -171,16 +158,6 @@ EXPORT_SYMBOL(inode_setattr);
EXPORT_SYMBOL
(
inode_change_ok
);
EXPORT_SYMBOL
(
inode_change_ok
);
EXPORT_SYMBOL
(
write_inode_now
);
EXPORT_SYMBOL
(
write_inode_now
);
EXPORT_SYMBOL
(
notify_change
);
EXPORT_SYMBOL
(
notify_change
);
EXPORT_SYMBOL
(
set_blocksize
);
EXPORT_SYMBOL
(
sb_set_blocksize
);
EXPORT_SYMBOL
(
sb_min_blocksize
);
EXPORT_SYMBOL
(
bdget
);
EXPORT_SYMBOL
(
bdput
);
EXPORT_SYMBOL
(
bd_claim
);
EXPORT_SYMBOL
(
bd_release
);
EXPORT_SYMBOL
(
open_bdev_excl
);
EXPORT_SYMBOL
(
close_bdev_excl
);
EXPORT_SYMBOL
(
open_by_devnum
);
EXPORT_SYMBOL
(
blockdev_direct_IO
);
EXPORT_SYMBOL
(
blockdev_direct_IO
);
EXPORT_SYMBOL
(
file_ra_state_init
);
EXPORT_SYMBOL
(
file_ra_state_init
);
EXPORT_SYMBOL
(
generic_ro_fops
);
EXPORT_SYMBOL
(
generic_ro_fops
);
...
@@ -214,16 +191,6 @@ EXPORT_SYMBOL(lock_may_read);
...
@@ -214,16 +191,6 @@ EXPORT_SYMBOL(lock_may_read);
EXPORT_SYMBOL
(
lock_may_write
);
EXPORT_SYMBOL
(
lock_may_write
);
EXPORT_SYMBOL
(
fd_install
);
EXPORT_SYMBOL
(
fd_install
);
EXPORT_SYMBOL
(
put_unused_fd
);
EXPORT_SYMBOL
(
put_unused_fd
);
EXPORT_SYMBOL
(
get_sb_bdev
);
EXPORT_SYMBOL
(
kill_block_super
);
EXPORT_SYMBOL
(
get_sb_nodev
);
EXPORT_SYMBOL
(
get_sb_single
);
EXPORT_SYMBOL
(
kill_anon_super
);
EXPORT_SYMBOL
(
kill_litter_super
);
EXPORT_SYMBOL
(
generic_shutdown_super
);
EXPORT_SYMBOL
(
deactivate_super
);
EXPORT_SYMBOL
(
sget
);
EXPORT_SYMBOL
(
set_anon_super
);
EXPORT_SYMBOL
(
do_select
);
EXPORT_SYMBOL
(
do_select
);
/* for stackable file systems (lofs, wrapfs, cryptfs, etc.) */
/* for stackable file systems (lofs, wrapfs, cryptfs, etc.) */
...
@@ -239,11 +206,6 @@ EXPORT_SYMBOL(tty_unregister_driver);
...
@@ -239,11 +206,6 @@ EXPORT_SYMBOL(tty_unregister_driver);
EXPORT_SYMBOL
(
tty_std_termios
);
EXPORT_SYMBOL
(
tty_std_termios
);
/* block device driver support */
/* block device driver support */
EXPORT_SYMBOL
(
bmap
);
EXPORT_SYMBOL
(
blkdev_open
);
EXPORT_SYMBOL
(
blkdev_get
);
EXPORT_SYMBOL
(
blkdev_put
);
EXPORT_SYMBOL
(
ioctl_by_bdev
);
EXPORT_SYMBOL
(
read_dev_sector
);
EXPORT_SYMBOL
(
read_dev_sector
);
EXPORT_SYMBOL
(
iov_shorten
);
EXPORT_SYMBOL
(
iov_shorten
);
EXPORT_SYMBOL_GPL
(
default_backing_dev_info
);
EXPORT_SYMBOL_GPL
(
default_backing_dev_info
);
...
@@ -255,32 +217,9 @@ EXPORT_SYMBOL(tty_flip_buffer_push);
...
@@ -255,32 +217,9 @@ EXPORT_SYMBOL(tty_flip_buffer_push);
/* filesystem registration */
/* filesystem registration */
EXPORT_SYMBOL
(
register_filesystem
);
EXPORT_SYMBOL
(
register_filesystem
);
EXPORT_SYMBOL
(
unregister_filesystem
);
EXPORT_SYMBOL
(
unregister_filesystem
);
EXPORT_SYMBOL
(
kern_mount
);
EXPORT_SYMBOL
(
__mntput
);
EXPORT_SYMBOL
(
__mntput
);
EXPORT_SYMBOL
(
may_umount
);
EXPORT_SYMBOL
(
may_umount
);
/* executable format registration */
EXPORT_SYMBOL
(
register_binfmt
);
EXPORT_SYMBOL
(
unregister_binfmt
);
EXPORT_SYMBOL
(
search_binary_handler
);
EXPORT_SYMBOL
(
prepare_binprm
);
EXPORT_SYMBOL
(
compute_creds
);
EXPORT_SYMBOL
(
remove_arg_zero
);
EXPORT_SYMBOL
(
set_binfmt
);
/* sysctl table registration */
EXPORT_SYMBOL
(
register_sysctl_table
);
EXPORT_SYMBOL
(
unregister_sysctl_table
);
EXPORT_SYMBOL
(
sysctl_string
);
EXPORT_SYMBOL
(
sysctl_intvec
);
EXPORT_SYMBOL
(
sysctl_jiffies
);
EXPORT_SYMBOL
(
proc_dostring
);
EXPORT_SYMBOL
(
proc_dointvec
);
EXPORT_SYMBOL
(
proc_dointvec_jiffies
);
EXPORT_SYMBOL
(
proc_dointvec_minmax
);
EXPORT_SYMBOL
(
proc_doulongvec_ms_jiffies_minmax
);
EXPORT_SYMBOL
(
proc_doulongvec_minmax
);
/* interrupt handling */
/* interrupt handling */
EXPORT_SYMBOL
(
request_irq
);
EXPORT_SYMBOL
(
request_irq
);
EXPORT_SYMBOL
(
free_irq
);
EXPORT_SYMBOL
(
free_irq
);
...
@@ -373,37 +312,12 @@ EXPORT_SYMBOL(securebits);
...
@@ -373,37 +312,12 @@ EXPORT_SYMBOL(securebits);
EXPORT_SYMBOL
(
cap_bset
);
EXPORT_SYMBOL
(
cap_bset
);
EXPORT_SYMBOL
(
daemonize
);
EXPORT_SYMBOL
(
daemonize
);
EXPORT_SYMBOL
(
csum_partial
);
/* for networking and md */
EXPORT_SYMBOL
(
csum_partial
);
/* for networking and md */
EXPORT_SYMBOL
(
seq_escape
);
EXPORT_SYMBOL
(
seq_printf
);
EXPORT_SYMBOL
(
seq_path
);
EXPORT_SYMBOL
(
seq_open
);
EXPORT_SYMBOL
(
seq_release
);
EXPORT_SYMBOL
(
seq_read
);
EXPORT_SYMBOL
(
seq_lseek
);
EXPORT_SYMBOL
(
single_open
);
EXPORT_SYMBOL
(
single_release
);
EXPORT_SYMBOL
(
seq_release_private
);
/* Program loader interfaces */
#ifdef CONFIG_MMU
EXPORT_SYMBOL
(
setup_arg_pages
);
#endif
EXPORT_SYMBOL
(
copy_strings_kernel
);
EXPORT_SYMBOL
(
do_execve
);
EXPORT_SYMBOL
(
flush_old_exec
);
EXPORT_SYMBOL
(
kernel_read
);
EXPORT_SYMBOL
(
open_exec
);
/* Miscellaneous access points */
/* Miscellaneous access points */
EXPORT_SYMBOL
(
si_meminfo
);
EXPORT_SYMBOL
(
si_meminfo
);
/* Added to make file system as module */
/* Added to make file system as module */
EXPORT_SYMBOL
(
sys_tz
);
EXPORT_SYMBOL
(
sys_tz
);
EXPORT_SYMBOL
(
clear_inode
);
EXPORT_SYMBOL
(
init_special_inode
);
EXPORT_SYMBOL
(
new_inode
);
EXPORT_SYMBOL
(
__insert_inode_hash
);
EXPORT_SYMBOL
(
remove_inode_hash
);
EXPORT_SYMBOL
(
make_bad_inode
);
EXPORT_SYMBOL
(
make_bad_inode
);
EXPORT_SYMBOL
(
is_bad_inode
);
EXPORT_SYMBOL
(
is_bad_inode
);
EXPORT_SYMBOL
(
__inode_dir_notify
);
EXPORT_SYMBOL
(
__inode_dir_notify
);
...
@@ -420,8 +334,6 @@ EXPORT_SYMBOL(fs_overflowgid);
...
@@ -420,8 +334,6 @@ EXPORT_SYMBOL(fs_overflowgid);
EXPORT_SYMBOL
(
fasync_helper
);
EXPORT_SYMBOL
(
fasync_helper
);
EXPORT_SYMBOL
(
kill_fasync
);
EXPORT_SYMBOL
(
kill_fasync
);
/* binfmt_aout */
/* library functions */
/* library functions */
EXPORT_SYMBOL
(
strnicmp
);
EXPORT_SYMBOL
(
strnicmp
);
EXPORT_SYMBOL
(
strspn
);
EXPORT_SYMBOL
(
strspn
);
...
...
kernel/sysctl.c
View file @
d3ed1c8f
...
@@ -19,6 +19,7 @@
...
@@ -19,6 +19,7 @@
*/
*/
#include <linux/config.h>
#include <linux/config.h>
#include <linux/module.h>
#include <linux/mm.h>
#include <linux/mm.h>
#include <linux/swap.h>
#include <linux/swap.h>
#include <linux/slab.h>
#include <linux/slab.h>
...
@@ -1994,3 +1995,19 @@ void unregister_sysctl_table(struct ctl_table_header * table)
...
@@ -1994,3 +1995,19 @@ void unregister_sysctl_table(struct ctl_table_header * table)
}
}
#endif
/* CONFIG_SYSCTL */
#endif
/* CONFIG_SYSCTL */
/*
* No sense putting this after each symbol definition, twice,
* exception granted :-)
*/
EXPORT_SYMBOL
(
proc_dointvec
);
EXPORT_SYMBOL
(
proc_dointvec_jiffies
);
EXPORT_SYMBOL
(
proc_dointvec_minmax
);
EXPORT_SYMBOL
(
proc_dostring
);
EXPORT_SYMBOL
(
proc_doulongvec_minmax
);
EXPORT_SYMBOL
(
proc_doulongvec_ms_jiffies_minmax
);
EXPORT_SYMBOL
(
register_sysctl_table
);
EXPORT_SYMBOL
(
sysctl_intvec
);
EXPORT_SYMBOL
(
sysctl_jiffies
);
EXPORT_SYMBOL
(
sysctl_string
);
EXPORT_SYMBOL
(
unregister_sysctl_table
);
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment