Skip to content

Commit

Permalink
rsa_pss_compute_saltlen(): Avoid integer overflows and check MD and R…
Browse files Browse the repository at this point in the history
…SA sizes

Fixes Coverity 1604651

Reviewed-by: Dmitry Belyavskiy <[email protected]>
Reviewed-by: Tom Cosgrove <[email protected]>
(Merged from openssl#25085)

(cherry picked from commit 217e215)
  • Loading branch information
t8m committed Aug 7, 2024
1 parent 638e8a6 commit 819afba
Showing 1 changed file with 19 additions and 3 deletions.
22 changes: 19 additions & 3 deletions providers/implementations/signature/rsa_sig.c
Original file line number Diff line number Diff line change
Expand Up @@ -208,13 +208,29 @@ static int rsa_pss_compute_saltlen(PROV_RSA_CTX *ctx)
* Provide a way to use at most the digest length, so that the default does
* not violate FIPS 186-4. */
if (saltlen == RSA_PSS_SALTLEN_DIGEST) {
saltlen = EVP_MD_get_size(ctx->md);
if ((saltlen = EVP_MD_get_size(ctx->md)) <= 0) {
ERR_raise(ERR_LIB_PROV, PROV_R_INVALID_DIGEST);
return -1;
}
} else if (saltlen == RSA_PSS_SALTLEN_AUTO_DIGEST_MAX) {
saltlen = RSA_PSS_SALTLEN_MAX;
saltlenMax = EVP_MD_get_size(ctx->md);
if ((saltlenMax = EVP_MD_get_size(ctx->md)) <= 0) {
ERR_raise(ERR_LIB_PROV, PROV_R_INVALID_DIGEST);
return -1;
}
}
if (saltlen == RSA_PSS_SALTLEN_MAX || saltlen == RSA_PSS_SALTLEN_AUTO) {
saltlen = RSA_size(ctx->rsa) - EVP_MD_get_size(ctx->md) - 2;
int mdsize, rsasize;

if ((mdsize = EVP_MD_get_size(ctx->md)) <= 0) {
ERR_raise(ERR_LIB_PROV, PROV_R_INVALID_DIGEST);
return -1;
}
if ((rsasize = RSA_size(ctx->rsa)) <= 2 || rsasize - 2 < mdsize) {
ERR_raise(ERR_LIB_PROV, PROV_R_INVALID_KEY);
return -1;
}
saltlen = rsasize - mdsize - 2;
if ((RSA_bits(ctx->rsa) & 0x7) == 1)
saltlen--;
if (saltlenMax >= 0 && saltlen > saltlenMax)
Expand Down

0 comments on commit 819afba

Please sign in to comment.