Commit 4df3d976 authored by Ronnie Sahlberg's avatar Ronnie Sahlberg Committed by Steve French
Browse files

cifs: move the check for nohandlecache into open_shroot



instead of doing it in the callsites for open_shroot.

Signed-off-by: default avatarRonnie Sahlberg <lsahlber@redhat.com>
Signed-off-by: default avatarSteve French <stfrench@microsoft.com>
parent 991e72eb
Loading
Loading
Loading
Loading
+11 −13
Original line number Diff line number Diff line
@@ -512,7 +512,6 @@ smb2_query_path_info(const unsigned int xid, struct cifs_tcon *tcon,
	int rc;
	struct smb2_file_all_info *smb2_data;
	__u32 create_options = 0;
	bool no_cached_open = tcon->nohandlecache;
	struct cifsFileInfo *cfile;
	struct cached_fid *cfid = NULL;

@@ -525,11 +524,9 @@ smb2_query_path_info(const unsigned int xid, struct cifs_tcon *tcon,
		return -ENOMEM;

	/* If it is a root and its handle is cached then use it */
	if (!strlen(full_path) && !no_cached_open) {
	if (!strlen(full_path)) {
		rc = open_shroot(xid, tcon, cifs_sb, &cfid);
		if (rc)
			goto out;

		if (!rc) {
			if (tcon->crfid.file_all_info_is_valid) {
				move_smb2_info_to_cifs(data,
					       &tcon->crfid.file_all_info);
@@ -543,6 +540,7 @@ smb2_query_path_info(const unsigned int xid, struct cifs_tcon *tcon,
			close_shroot(cfid);
			goto out;
		}
	}

	cifs_get_readable_path(tcon, full_path, &cfile);
	rc = smb2_compound_op(xid, tcon, cifs_sb, full_path,
+8 −8
Original line number Diff line number Diff line
@@ -746,6 +746,9 @@ int open_shroot(unsigned int xid, struct cifs_tcon *tcon,
	u8 oplock = SMB2_OPLOCK_LEVEL_II;
	struct cifs_fid *pfid;

	if (tcon->nohandlecache)
		return -ENOTSUPP;

	mutex_lock(&tcon->crfid.fid_mutex);
	if (tcon->crfid.is_valid) {
		cifs_dbg(FYI, "found a cached root file handle\n");
@@ -914,7 +917,6 @@ smb3_qfs_tcon(const unsigned int xid, struct cifs_tcon *tcon,
	u8 oplock = SMB2_OPLOCK_LEVEL_NONE;
	struct cifs_open_parms oparms;
	struct cifs_fid fid;
	bool no_cached_open = tcon->nohandlecache;
	struct cached_fid *cfid = NULL;

	oparms.tcon = tcon;
@@ -924,14 +926,12 @@ smb3_qfs_tcon(const unsigned int xid, struct cifs_tcon *tcon,
	oparms.fid = &fid;
	oparms.reconnect = false;

	if (no_cached_open) {
		rc = SMB2_open(xid, &oparms, &srch_path, &oplock, NULL, NULL,
			       NULL, NULL);
	} else {
	rc = open_shroot(xid, tcon, cifs_sb, &cfid);
	if (rc == 0)
		memcpy(&fid, cfid->fid, sizeof(struct cifs_fid));
	}
	else
		rc = SMB2_open(xid, &oparms, &srch_path, &oplock, NULL, NULL,
			       NULL, NULL);
	if (rc)
		return;

@@ -945,7 +945,7 @@ smb3_qfs_tcon(const unsigned int xid, struct cifs_tcon *tcon,
			FS_VOLUME_INFORMATION);
	SMB2_QFS_attr(xid, tcon, fid.persistent_fid, fid.volatile_fid,
			FS_SECTOR_SIZE_INFORMATION); /* SMB3 specific */
	if (no_cached_open)
	if (cfid == NULL)
		SMB2_close(xid, tcon, fid.persistent_fid, fid.volatile_fid);
	else
		close_shroot(cfid);