linux/fs/9p
Markus Armbruster b32a09db4f add match_strlcpy() us it to make v9fs make uname and remotename parsing more robust
match_strcpy() is a somewhat creepy function: the caller needs to make sure
that the destination buffer is big enough, and when he screws up or
forgets, match_strcpy() happily overruns the buffer.

There's exactly one customer: v9fs_parse_options().  I believe it currently
can't overflow its buffer, but that's not exactly obvious.

The source string is a substing of the mount options.  The kernel silently
truncates those to PAGE_SIZE bytes, including the terminating zero.  See
compat_sys_mount() and do_mount().

The destination buffer is obtained from __getname(), which allocates from
name_cachep, which is initialized by vfs_caches_init() for size PATH_MAX.

We're safe as long as PATH_MAX <= PAGE_SIZE.  PATH_MAX is 4096.  As far as
I know, the smallest PAGE_SIZE is also 4096.

Here's a patch that makes the code a bit more obviously correct.  It
doesn't depend on PATH_MAX <= PAGE_SIZE.

Signed-off-by: Markus Armbruster <armbru@redhat.com>
Cc: Latchesar Ionkov <lucho@ionkov.net>
Cc: Jim Meyering <meyering@redhat.com>
Cc: "Randy.Dunlap" <rdunlap@xenotime.net>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Eric Van Hensbergen <ericvh@gmail.com>
2008-05-14 19:23:25 -05:00
..
fid.c fs: Remove unnecessary inclusions of asm/semaphore.h 2008-04-18 22:16:44 -04:00
fid.h 9p: remove deprecated v9fs_fid_lookup_remove() 2007-08-23 10:13:45 -05:00
Makefile 9p: Reorganization of 9p file system code 2007-07-14 15:13:40 -05:00
v9fs_vfs.h 9p: Reorganization of 9p file system code 2007-07-14 15:13:40 -05:00
v9fs.c add match_strlcpy() us it to make v9fs make uname and remotename parsing more robust 2008-05-14 19:23:25 -05:00
v9fs.h 9p: transport API reorganization 2008-02-06 19:25:03 -06:00
vfs_addr.c 9p: Reorganization of 9p file system code 2007-07-14 15:13:40 -05:00
vfs_dentry.c 9p: Reorganization of 9p file system code 2007-07-14 15:13:40 -05:00
vfs_dir.c 9p: Reorganization of 9p file system code 2007-07-14 15:13:40 -05:00
vfs_file.c 9p: fix mmap to be read-only 2008-02-06 19:25:05 -06:00
vfs_inode.c Convert ERR_PTR(PTR_ERR(p)) instances to ERR_CAST(p) 2008-02-07 08:42:26 -08:00
vfs_super.c [PATCH] restore sane ->umount_begin() API 2008-04-25 09:23:25 -04:00