[PATCH][RFC] autofs4: Do not potentially dereference null pointerreturned by fget() in autofs_dev_ioctl_setpipefd()

From: Jesper Juhl
Date: Sun Dec 12 2010 - 18:09:28 EST


Hi,

In fs/autofs4/dev-ioctl.c::autofs_dev_ioctl_setpipefd() we call fget(),
which may return NULL, but we do not explicitly test for that NULL return
so we may end up dereferencing a NULL pointer - bad.

A comment in fget() says "File object ref couldn't be taken" when that
function returns NULL, so I guess EBUSY is the proper error to return from
autofs_dev_ioctl_setpipefd() when this happens, but I'm far from sure
about this, so I'd like some feedback before this patch is merged.


Signed-off-by: Jesper Juhl <jj@xxxxxxxxxxxxx>
---
dev-ioctl.c | 4 ++++
1 file changed, 4 insertions(+)

compile tested only.

diff --git a/fs/autofs4/dev-ioctl.c b/fs/autofs4/dev-ioctl.c
index eff9a41..ab551ee 100644
--- a/fs/autofs4/dev-ioctl.c
+++ b/fs/autofs4/dev-ioctl.c
@@ -372,6 +372,10 @@ static int autofs_dev_ioctl_setpipefd(struct file *fp,
return -EBUSY;
} else {
struct file *pipe = fget(pipefd);
+ if (!pipe) {
+ err = -EBUSY;
+ goto out;
+ }
if (!pipe->f_op || !pipe->f_op->write) {
err = -EPIPE;
fput(pipe);



--
Jesper Juhl <jj@xxxxxxxxxxxxx> http://www.chaosbits.net/
Don't top-post http://www.catb.org/~esr/jargon/html/T/top-post.html
Plain text mails only, please.

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/