Commit f7025d86 authored by Enzo Matsumiya's avatar Enzo Matsumiya Committed by Steve French
Browse files

smb: client: allocate crypto only for primary server



For extra channels, point ->secmech.{enc,dec} to the primary
server ones.

Signed-off-by: default avatarEnzo Matsumiya <ematsumiya@suse.de>
Signed-off-by: default avatarSteve French <stfrench@microsoft.com>
parent b0abcd65
Loading
Loading
Loading
Loading
+11 −6
Original line number Diff line number Diff line
@@ -735,6 +735,7 @@ cifs_crypto_secmech_release(struct TCP_Server_Info *server)
	cifs_free_hash(&server->secmech.sha512);
	cifs_free_hash(&server->secmech.hmacmd5);

	if (!SERVER_IS_CHAN(server)) {
		if (server->secmech.enc) {
			crypto_free_aead(server->secmech.enc);
			server->secmech.enc = NULL;
@@ -744,4 +745,8 @@ cifs_crypto_secmech_release(struct TCP_Server_Info *server)
			crypto_free_aead(server->secmech.dec);
			server->secmech.dec = NULL;
		}
	} else {
		server->secmech.enc = NULL;
		server->secmech.dec = NULL;
	}
}
+7 −3
Original line number Diff line number Diff line
@@ -1268,9 +1268,13 @@ SMB2_negotiate(const unsigned int xid,
	}

	if (server->cipher_type && !rc) {
		if (!SERVER_IS_CHAN(server)) {
			rc = smb3_crypto_aead_allocate(server);
		if (rc)
			cifs_server_dbg(VFS, "%s: crypto alloc failed, rc=%d\n", __func__, rc);
		} else {
			/* For channels, just reuse the primary server crypto secmech. */
			server->secmech.enc = server->primary_server->secmech.enc;
			server->secmech.dec = server->primary_server->secmech.dec;
		}
	}
neg_exit:
	free_rsp_buf(resp_buftype, rsp);