Skip to content

Commit f728074

Browse files
committed
pkcs7, x509: Rename ->digest to ->m
Rename ->digest and ->digest_len to ->m and ->m_size to represent the input to the signature verification algorithm, reflecting that ->digest may no longer actually *be* a digest. Signed-off-by: David Howells <dhowells@redhat.com> Reviewed-by: Jarkko Sakkinen <jarkko@kernel.org> cc: Lukas Wunner <lukas@wunner.de> cc: Ignat Korchagin <ignat@cloudflare.com> cc: Stephan Mueller <smueller@chronox.de> cc: Eric Biggers <ebiggers@kernel.org> cc: Herbert Xu <herbert@gondor.apana.org.au> cc: keyrings@vger.kernel.org cc: linux-crypto@vger.kernel.org
1 parent 2c62068 commit f728074

7 files changed

Lines changed: 26 additions & 29 deletions

File tree

crypto/asymmetric_keys/asymmetric_type.c

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -593,10 +593,10 @@ static int asymmetric_key_verify_signature(struct kernel_pkey_params *params,
593593
{
594594
struct public_key_signature sig = {
595595
.s_size = params->in2_len,
596-
.digest_size = params->in_len,
596+
.m_size = params->in_len,
597597
.encoding = params->encoding,
598598
.hash_algo = params->hash_algo,
599-
.digest = (void *)in,
599+
.m = (void *)in,
600600
.s = (void *)in2,
601601
};
602602

crypto/asymmetric_keys/pkcs7_verify.c

Lines changed: 14 additions & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -31,7 +31,7 @@ static int pkcs7_digest(struct pkcs7_message *pkcs7,
3131
kenter(",%u,%s", sinfo->index, sinfo->sig->hash_algo);
3232

3333
/* The digest was calculated already. */
34-
if (sig->digest)
34+
if (sig->m)
3535
return 0;
3636

3737
if (!sinfo->sig->hash_algo)
@@ -45,11 +45,11 @@ static int pkcs7_digest(struct pkcs7_message *pkcs7,
4545
return (PTR_ERR(tfm) == -ENOENT) ? -ENOPKG : PTR_ERR(tfm);
4646

4747
desc_size = crypto_shash_descsize(tfm) + sizeof(*desc);
48-
sig->digest_size = crypto_shash_digestsize(tfm);
48+
sig->m_size = crypto_shash_digestsize(tfm);
4949

5050
ret = -ENOMEM;
51-
sig->digest = kmalloc(sig->digest_size, GFP_KERNEL);
52-
if (!sig->digest)
51+
sig->m = kmalloc(sig->m_size, GFP_KERNEL);
52+
if (!sig->m)
5353
goto error_no_desc;
5454

5555
desc = kzalloc(desc_size, GFP_KERNEL);
@@ -59,11 +59,10 @@ static int pkcs7_digest(struct pkcs7_message *pkcs7,
5959
desc->tfm = tfm;
6060

6161
/* Digest the message [RFC2315 9.3] */
62-
ret = crypto_shash_digest(desc, pkcs7->data, pkcs7->data_len,
63-
sig->digest);
62+
ret = crypto_shash_digest(desc, pkcs7->data, pkcs7->data_len, sig->m);
6463
if (ret < 0)
6564
goto error;
66-
pr_devel("MsgDigest = [%*ph]\n", 8, sig->digest);
65+
pr_devel("MsgDigest = [%*ph]\n", 8, sig->m);
6766

6867
/* However, if there are authenticated attributes, there must be a
6968
* message digest attribute amongst them which corresponds to the
@@ -78,14 +77,14 @@ static int pkcs7_digest(struct pkcs7_message *pkcs7,
7877
goto error;
7978
}
8079

81-
if (sinfo->msgdigest_len != sig->digest_size) {
80+
if (sinfo->msgdigest_len != sig->m_size) {
8281
pr_warn("Sig %u: Invalid digest size (%u)\n",
8382
sinfo->index, sinfo->msgdigest_len);
8483
ret = -EBADMSG;
8584
goto error;
8685
}
8786

88-
if (memcmp(sig->digest, sinfo->msgdigest,
87+
if (memcmp(sig->m, sinfo->msgdigest,
8988
sinfo->msgdigest_len) != 0) {
9089
pr_warn("Sig %u: Message digest doesn't match\n",
9190
sinfo->index);
@@ -98,7 +97,8 @@ static int pkcs7_digest(struct pkcs7_message *pkcs7,
9897
* convert the attributes from a CONT.0 into a SET before we
9998
* hash it.
10099
*/
101-
memset(sig->digest, 0, sig->digest_size);
100+
memset(sig->m, 0, sig->m_size);
101+
102102

103103
ret = crypto_shash_init(desc);
104104
if (ret < 0)
@@ -108,10 +108,10 @@ static int pkcs7_digest(struct pkcs7_message *pkcs7,
108108
if (ret < 0)
109109
goto error;
110110
ret = crypto_shash_finup(desc, sinfo->authattrs,
111-
sinfo->authattrs_len, sig->digest);
111+
sinfo->authattrs_len, sig->m);
112112
if (ret < 0)
113113
goto error;
114-
pr_devel("AADigest = [%*ph]\n", 8, sig->digest);
114+
pr_devel("AADigest = [%*ph]\n", 8, sig->m);
115115
}
116116

117117
error:
@@ -138,8 +138,8 @@ int pkcs7_get_digest(struct pkcs7_message *pkcs7, const u8 **buf, u32 *len,
138138
if (ret)
139139
return ret;
140140

141-
*buf = sinfo->sig->digest;
142-
*len = sinfo->sig->digest_size;
141+
*buf = sinfo->sig->m;
142+
*len = sinfo->sig->m_size;
143143

144144
i = match_string(hash_algo_name, HASH_ALGO__LAST,
145145
sinfo->sig->hash_algo);

crypto/asymmetric_keys/public_key.c

Lines changed: 1 addition & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -425,8 +425,7 @@ int public_key_verify_signature(const struct public_key *pkey,
425425
if (ret)
426426
goto error_free_key;
427427

428-
ret = crypto_sig_verify(tfm, sig->s, sig->s_size,
429-
sig->digest, sig->digest_size);
428+
ret = crypto_sig_verify(tfm, sig->s, sig->s_size, sig->m, sig->m_size);
430429

431430
error_free_key:
432431
kfree_sensitive(key);

crypto/asymmetric_keys/signature.c

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -28,7 +28,7 @@ void public_key_signature_free(struct public_key_signature *sig)
2828
for (i = 0; i < ARRAY_SIZE(sig->auth_ids); i++)
2929
kfree(sig->auth_ids[i]);
3030
kfree(sig->s);
31-
kfree(sig->digest);
31+
kfree(sig->m);
3232
kfree(sig);
3333
}
3434
}

crypto/asymmetric_keys/x509_public_key.c

Lines changed: 4 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -63,11 +63,11 @@ int x509_get_sig_params(struct x509_certificate *cert)
6363
}
6464

6565
desc_size = crypto_shash_descsize(tfm) + sizeof(*desc);
66-
sig->digest_size = crypto_shash_digestsize(tfm);
66+
sig->m_size = crypto_shash_digestsize(tfm);
6767

6868
ret = -ENOMEM;
69-
sig->digest = kmalloc(sig->digest_size, GFP_KERNEL);
70-
if (!sig->digest)
69+
sig->m = kmalloc(sig->m_size, GFP_KERNEL);
70+
if (!sig->m)
7171
goto error;
7272

7373
desc = kzalloc(desc_size, GFP_KERNEL);
@@ -76,9 +76,7 @@ int x509_get_sig_params(struct x509_certificate *cert)
7676

7777
desc->tfm = tfm;
7878

79-
ret = crypto_shash_digest(desc, cert->tbs, cert->tbs_size,
80-
sig->digest);
81-
79+
ret = crypto_shash_digest(desc, cert->tbs, cert->tbs_size, sig->m);
8280
if (ret < 0)
8381
goto error_2;
8482

include/crypto/public_key.h

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -43,9 +43,9 @@ extern void public_key_free(struct public_key *key);
4343
struct public_key_signature {
4444
struct asymmetric_key_id *auth_ids[3];
4545
u8 *s; /* Signature */
46-
u8 *digest;
46+
u8 *m; /* Message data to pass to verifier */
4747
u32 s_size; /* Number of bytes in signature */
48-
u32 digest_size; /* Number of bytes in digest */
48+
u32 m_size; /* Number of bytes in ->m */
4949
const char *pkey_algo;
5050
const char *hash_algo;
5151
const char *encoding;

security/integrity/digsig_asymmetric.c

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -121,8 +121,8 @@ int asymmetric_verify(struct key *keyring, const char *sig,
121121
goto out;
122122
}
123123

124-
pks.digest = (u8 *)data;
125-
pks.digest_size = datalen;
124+
pks.m = (u8 *)data;
125+
pks.m_size = datalen;
126126
pks.s = hdr->sig;
127127
pks.s_size = siglen;
128128
ret = verify_signature(key, &pks);

0 commit comments

Comments
 (0)