diff options
Diffstat (limited to 'fs/cifs/connect.c')
| -rw-r--r-- | fs/cifs/connect.c | 40 | 
1 files changed, 16 insertions, 24 deletions
| diff --git a/fs/cifs/connect.c b/fs/cifs/connect.c index e8830f076a7f..7a10a5d0731f 100644 --- a/fs/cifs/connect.c +++ b/fs/cifs/connect.c @@ -1977,14 +1977,6 @@ cifs_parse_mount_options(const char *mountdata, const char *devname,  		goto cifs_parse_mount_err;  	} -#ifdef CONFIG_CIFS_SMB_DIRECT -	if (vol->rdma && vol->sign) { -		cifs_dbg(VFS, "Currently SMB direct doesn't support signing." -			" This is being fixed\n"); -		goto cifs_parse_mount_err; -	} -#endif -  #ifndef CONFIG_KEYS  	/* Muliuser mounts require CONFIG_KEYS support */  	if (vol->multiuser) { @@ -2959,6 +2951,22 @@ cifs_get_tcon(struct cifs_ses *ses, struct smb_vol *volume_info)  		}  	} +	if (volume_info->seal) { +		if (ses->server->vals->protocol_id == 0) { +			cifs_dbg(VFS, +				 "SMB3 or later required for encryption\n"); +			rc = -EOPNOTSUPP; +			goto out_fail; +		} else if (tcon->ses->server->capabilities & +					SMB2_GLOBAL_CAP_ENCRYPTION) +			tcon->seal = true; +		else { +			cifs_dbg(VFS, "Encryption is not supported on share\n"); +			rc = -EOPNOTSUPP; +			goto out_fail; +		} +	} +  	/*  	 * BB Do we need to wrap session_mutex around this TCon call and Unix  	 * SetFS as we do on SessSetup and reconnect? @@ -3007,22 +3015,6 @@ cifs_get_tcon(struct cifs_ses *ses, struct smb_vol *volume_info)  		tcon->use_resilient = true;  	} -	if (volume_info->seal) { -		if (ses->server->vals->protocol_id == 0) { -			cifs_dbg(VFS, -				 "SMB3 or later required for encryption\n"); -			rc = -EOPNOTSUPP; -			goto out_fail; -		} else if (tcon->ses->server->capabilities & -					SMB2_GLOBAL_CAP_ENCRYPTION) -			tcon->seal = true; -		else { -			cifs_dbg(VFS, "Encryption is not supported on share\n"); -			rc = -EOPNOTSUPP; -			goto out_fail; -		} -	} -  	/*  	 * We can have only one retry value for a connection to a share so for  	 * resources mounted more than once to the same server share the last | 
