[PATCH] files: files struct with RCU
authorDipankar Sarma <dipankar@in.ibm.com>
Fri, 9 Sep 2005 20:04:13 +0000 (13:04 -0700)
committerLinus Torvalds <torvalds@g5.osdl.org>
Fri, 9 Sep 2005 20:57:55 +0000 (13:57 -0700)
commitab2af1f5005069321c5d130f09cce577b03f43ef
tree73a70ba486f522cd9eeeef376ede2b5a1c1b473b
parent6e72ad2c581de121cc7e772469e2a8f6b1fd4379
[PATCH] files: files struct with RCU

Patch to eliminate struct files_struct.file_lock spinlock on the reader side
and use rcu refcounting rcuref_xxx api for the f_count refcounter.  The
updates to the fdtable are done by allocating a new fdtable structure and
setting files->fdt to point to the new structure.  The fdtable structure is
protected by RCU thereby allowing lock-free lookup.  For fd arrays/sets that
are vmalloced, we use keventd to free them since RCU callbacks can't sleep.  A
global list of fdtable to be freed is not scalable, so we use a per-cpu list.
If keventd is already handling the current cpu's work, we use a timer to defer
queueing of that work.

Since the last publication, this patch has been re-written to avoid using
explicit memory barriers and use rcu_assign_pointer(), rcu_dereference()
premitives instead.  This required that the fd information is kept in a
separate structure (fdtable) and updated atomically.

Signed-off-by: Dipankar Sarma <dipankar@in.ibm.com>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
fs/aio.c
fs/fcntl.c
fs/file.c
fs/file_table.c
fs/open.c
include/linux/file.h
include/linux/fs.h
include/linux/init_task.h
kernel/exit.c
kernel/fork.c