public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* fs/xfs/xfs_vnodeops.c:xfs_readdir(): NULL variable dereferenced
@ 2006-07-06 21:13 Adrian Bunk
  2006-07-06 23:32 ` David Chinner
  0 siblings, 1 reply; 5+ messages in thread
From: Adrian Bunk @ 2006-07-06 21:13 UTC (permalink / raw)
  To: xfs-masters; +Cc: xfs, linux-kernel

The Coverity checker spotted the following:

<--  snip  -->

...
STATIC int
xfs_readdir(
        bhv_desc_t      *dir_bdp,
        uio_t           *uiop,
        cred_t          *credp,
        int             *eofp)
{
        xfs_inode_t     *dp;
        xfs_trans_t     *tp = NULL;
        int             error = 0;
        uint            lock_mode;

        vn_trace_entry(BHV_TO_VNODE(dir_bdp), __FUNCTION__,
                                               (inst_t *)__return_address);
        dp = XFS_BHVTOI(dir_bdp);

        if (XFS_FORCED_SHUTDOWN(dp->i_mount))
                return XFS_ERROR(EIO);

        lock_mode = xfs_ilock_map_shared(dp);
        error = xfs_dir_getdents(tp, dp, uiop, eofp);
        xfs_iunlock_map_shared(dp, lock_mode);
        return error;
}
...

<--  snip  -->

Note that tp is never assigned any value other than NULL (and the 
Coverity checker found a way how tp might be dereferenced four function 
calls later).

cu
Adrian

-- 

       "Is there not promise of rain?" Ling Tan asked suddenly out
        of the darkness. There had been need of rain for many days.
       "Only a promise," Lao Er said.
                                       Pearl S. Buck - Dragon Seed


^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2006-07-09  1:05 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2006-07-06 21:13 fs/xfs/xfs_vnodeops.c:xfs_readdir(): NULL variable dereferenced Adrian Bunk
2006-07-06 23:32 ` David Chinner
2006-07-06 23:37   ` Hua Zhong
2006-07-08 19:46   ` Adrian Bunk
2006-07-09  1:04     ` [xfs-masters] " Nathan Scott

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox