Fix undefined behaviour when printing the X509 and CRL version
Found by oss-fuzz Reviewed-by: Andy Polyakov <appro@openssl.org> GH: #2231
This commit is contained in:
parent
68d4bcfd06
commit
c2ce477f1f
2 changed files with 11 additions and 3 deletions
|
@ -44,7 +44,10 @@ int X509_CRL_print(BIO *out, X509_CRL *x)
|
||||||
|
|
||||||
BIO_printf(out, "Certificate Revocation List (CRL):\n");
|
BIO_printf(out, "Certificate Revocation List (CRL):\n");
|
||||||
l = X509_CRL_get_version(x);
|
l = X509_CRL_get_version(x);
|
||||||
BIO_printf(out, "%8sVersion %lu (0x%lx)\n", "", l + 1, l);
|
if (l >= 0 && l <= 1)
|
||||||
|
BIO_printf(out, "%8sVersion %ld (0x%lx)\n", "", l + 1, (unsigned long)l);
|
||||||
|
else
|
||||||
|
BIO_printf(out, "%8sVersion unknown (%ld)\n", "", l);
|
||||||
X509_CRL_get0_signature(x, &sig, &sig_alg);
|
X509_CRL_get0_signature(x, &sig, &sig_alg);
|
||||||
X509_signature_print(out, sig_alg, NULL);
|
X509_signature_print(out, sig_alg, NULL);
|
||||||
p = X509_NAME_oneline(X509_CRL_get_issuer(x), NULL, 0);
|
p = X509_NAME_oneline(X509_CRL_get_issuer(x), NULL, 0);
|
||||||
|
|
|
@ -60,8 +60,13 @@ int X509_REQ_print_ex(BIO *bp, X509_REQ *x, unsigned long nmflags,
|
||||||
}
|
}
|
||||||
if (!(cflag & X509_FLAG_NO_VERSION)) {
|
if (!(cflag & X509_FLAG_NO_VERSION)) {
|
||||||
l = X509_REQ_get_version(x);
|
l = X509_REQ_get_version(x);
|
||||||
if (BIO_printf(bp, "%8sVersion: %ld (0x%lx)\n", "", l + 1, l) <= 0)
|
if (l >= 0 && l <= 2) {
|
||||||
goto err;
|
if (BIO_printf(bp, "%8sVersion: %ld (0x%lx)\n", "", l + 1, (unsigned long)l) <= 0)
|
||||||
|
goto err;
|
||||||
|
} else {
|
||||||
|
if (BIO_printf(bp, "%8sVersion: Unknown (%ld)\n", "", l) <= 0)
|
||||||
|
goto err;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if (!(cflag & X509_FLAG_NO_SUBJECT)) {
|
if (!(cflag & X509_FLAG_NO_SUBJECT)) {
|
||||||
if (BIO_printf(bp, " Subject:%c", mlch) <= 0)
|
if (BIO_printf(bp, " Subject:%c", mlch) <= 0)
|
||||||
|
|
Loading…
Reference in a new issue