From: Anna Schumaker Date: Mon, 5 Oct 2015 20:43:26 +0000 (-0400) Subject: NFS: Fix a tracepoint NULL-pointer dereference X-Git-Tag: firefly_0821_release~176^2~958^2 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=39d0d3bdf7bab3021a31e501172ac0f18947f9b3;p=firefly-linux-kernel-4.4.55.git NFS: Fix a tracepoint NULL-pointer dereference Running xfstest generic/013 with the tracepoint nfs:nfs4_open_file enabled produces a NULL-pointer dereference when calculating fileid and filehandle of the opened file. Fix this by checking if state is NULL before trying to use the inode pointer. Reported-by: Olga Kornievskaia Signed-off-by: Anna Schumaker Signed-off-by: Trond Myklebust --- diff --git a/fs/nfs/nfs4trace.h b/fs/nfs/nfs4trace.h index 28df12e525ba..671cf68fe56b 100644 --- a/fs/nfs/nfs4trace.h +++ b/fs/nfs/nfs4trace.h @@ -409,7 +409,7 @@ DECLARE_EVENT_CLASS(nfs4_open_event, __entry->flags = flags; __entry->fmode = (__force unsigned int)ctx->mode; __entry->dev = ctx->dentry->d_sb->s_dev; - if (!IS_ERR(state)) + if (!IS_ERR_OR_NULL(state)) inode = state->inode; if (inode != NULL) { __entry->fileid = NFS_FILEID(inode);