[PATCH] readv/writev syscalls are not checked by lsm
authorKostik Belousov <kostikbel@gmail.com>
Wed, 28 Sep 2005 15:21:28 +0000 (18:21 +0300)
committerChris Wright <chrisw@osdl.org>
Thu, 29 Sep 2005 22:42:08 +0000 (15:42 -0700)
it seems that readv(2)/writev(2) syscalls do not call
file_permission callback. Looks like this is overlook.

I have filled the issue into redhat bugzilla as
https://bugzilla.redhat.com/bugzilla/show_bug.cgi?id=169433
and got the recommendation to post this on lsm mailing list.

The following trivial patch solves the problem.

Signed-off-by: Kostik Belousov <kostikbel@gmail.com>
Signed-off-by: Chris Wright <chrisw@osdl.org>
fs/read_write.c

index b60324a..a091ee4 100644 (file)
@@ -499,6 +499,9 @@ static ssize_t do_readv_writev(int type, struct file *file,
        ret = rw_verify_area(type, file, pos, tot_len);
        if (ret)
                goto out;
+       ret = security_file_permission(file, type == READ ? MAY_READ : MAY_WRITE);
+       if (ret)
+               goto out;
 
        fnv = NULL;
        if (type == READ) {