diff options
author | Eric Biggers <ebiggers@google.com> | 2017-12-08 16:13:28 +0100 |
---|---|---|
committer | David Howells <dhowells@redhat.com> | 2017-12-08 16:13:28 +0100 |
commit | 7204eb8590c750e8c10b47f4acd4efe6e4138452 (patch) | |
tree | b6e67acf18994b248f57d71d03dc872e9557a93a /crypto | |
parent | pkcs7: return correct error code if pkcs7_check_authattrs() fails (diff) | |
download | linux-7204eb8590c750e8c10b47f4acd4efe6e4138452.tar.xz linux-7204eb8590c750e8c10b47f4acd4efe6e4138452.zip |
pkcs7: fix check for self-signed certificate
pkcs7_validate_trust_one() used 'x509->next == x509' to identify a
self-signed certificate. That's wrong; ->next is simply the link in the
linked list of certificates in the PKCS#7 message. It should be
checking ->signer instead. Fix it.
Fortunately this didn't actually matter because when we re-visited
'x509' on the next iteration via 'x509->signer', it was already seen and
not verified, so we returned -ENOKEY anyway.
Signed-off-by: Eric Biggers <ebiggers@google.com>
Signed-off-by: David Howells <dhowells@redhat.com>
Reviewed-by: James Morris <james.l.morris@oracle.com>
Diffstat (limited to 'crypto')
-rw-r--r-- | crypto/asymmetric_keys/pkcs7_trust.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/crypto/asymmetric_keys/pkcs7_trust.c b/crypto/asymmetric_keys/pkcs7_trust.c index f6a009d88a33..1f4e25f10049 100644 --- a/crypto/asymmetric_keys/pkcs7_trust.c +++ b/crypto/asymmetric_keys/pkcs7_trust.c @@ -69,7 +69,7 @@ static int pkcs7_validate_trust_one(struct pkcs7_message *pkcs7, /* Self-signed certificates form roots of their own, and if we * don't know them, then we can't accept them. */ - if (x509->next == x509) { + if (x509->signer == x509) { kleave(" = -ENOKEY [unknown self-signed]"); return -ENOKEY; } |