[bug report] fs: Teach path_connected to handle nfs filesystems with multiple roots.

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hello Eric W. Biederman,

The patch 95dd77580ccd: "fs: Teach path_connected to handle nfs
filesystems with multiple roots." from Mar 14, 2018, leads to the
following static checker warning:

	fs/nfs/super.c:2634 nfs_fs_mount_common()
	error: potential NULL dereference 'server'.

fs/nfs/super.c
  2598          if (server->flags & NFS_MOUNT_UNSHARED)
  2599                  compare_super = NULL;
  2600  
  2601          /* -o noac implies -o sync */
  2602          if (server->flags & NFS_MOUNT_NOAC)
  2603                  sb_mntdata.mntflags |= SB_SYNCHRONOUS;
  2604  
  2605          if (mount_info->cloned != NULL && mount_info->cloned->sb != NULL)
  2606                  if (mount_info->cloned->sb->s_flags & SB_SYNCHRONOUS)
  2607                          sb_mntdata.mntflags |= SB_SYNCHRONOUS;
  2608  
  2609          /* Get a superblock - note that we may end up sharing one that already exists */
  2610          s = sget(nfs_mod->nfs_fs, compare_super, nfs_set_super, flags, &sb_mntdata);
  2611          if (IS_ERR(s)) {
  2612                  mntroot = ERR_CAST(s);
  2613                  goto out_err_nosb;
  2614          }
  2615  
  2616          if (s->s_fs_info != server) {
  2617                  nfs_free_server(server);
  2618                  server = NULL;
                        ^^^^^^^^^^^^^
We set server to NULL here.  Smatch and I don't know the value of
s->s_root at this point, but maybe it can't be NULL here?  If so, that's
fine then.

  2619          } else {
  2620                  error = super_setup_bdi_name(s, "%u:%u", MAJOR(server->s_dev),
  2621                                               MINOR(server->s_dev));
  2622                  if (error) {
  2623                          mntroot = ERR_PTR(error);
  2624                          goto error_splat_super;
  2625                  }
  2626                  s->s_bdi->ra_pages = server->rpages * NFS_MAX_READAHEAD;
  2627                  server->super = s;
  2628          }
  2629  
  2630          if (!s->s_root) {
  2631                  /* initial superblock/root creation */
  2632                  mount_info->fill_super(s, mount_info);
  2633                  nfs_get_cache_cookie(s, mount_info->parsed, mount_info->cloned);
  2634                  if (!(server->flags & NFS_MOUNT_UNSHARED))
                              ^^^^^^^^^^^^^
Potential NULL dereference.

  2635                          s->s_iflags |= SB_I_MULTIROOT;
  2636          }

regards,
dan carpenter
--
To unsubscribe from this list: send the line "unsubscribe linux-nfs" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html



[Index of Archives]     [Linux Filesystem Development]     [Linux USB Development]     [Linux Media Development]     [Video for Linux]     [Linux NILFS]     [Linux Audio Users]     [Yosemite Info]     [Linux SCSI]

  Powered by Linux