2021-05-19 15:54:54 +00:00
|
|
|
#define MBEDTLS_ALLOW_PRIVATE_ACCESS
|
|
|
|
|
2018-05-03 14:40:24 +00:00
|
|
|
#include <stdint.h>
|
|
|
|
#include "mbedtls/x509_csr.h"
|
|
|
|
|
2023-01-11 13:50:10 +00:00
|
|
|
int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size)
|
|
|
|
{
|
2018-05-03 14:40:24 +00:00
|
|
|
#ifdef MBEDTLS_X509_CSR_PARSE_C
|
|
|
|
int ret;
|
|
|
|
mbedtls_x509_csr csr;
|
|
|
|
unsigned char buf[4096];
|
|
|
|
|
2023-01-11 13:50:10 +00:00
|
|
|
mbedtls_x509_csr_init(&csr);
|
2023-04-19 09:47:01 +00:00
|
|
|
#if defined(MBEDTLS_USE_PSA_CRYPTO)
|
|
|
|
psa_status_t status = psa_crypto_init();
|
|
|
|
if (status != PSA_SUCCESS) {
|
|
|
|
goto exit;
|
|
|
|
}
|
|
|
|
#endif /* MBEDTLS_USE_PSA_CRYPTO */
|
2023-01-11 13:50:10 +00:00
|
|
|
ret = mbedtls_x509_csr_parse(&csr, Data, Size);
|
2020-10-09 08:45:29 +00:00
|
|
|
#if !defined(MBEDTLS_X509_REMOVE_INFO)
|
2018-05-03 14:40:24 +00:00
|
|
|
if (ret == 0) {
|
2023-01-11 13:50:10 +00:00
|
|
|
ret = mbedtls_x509_csr_info((char *) buf, sizeof(buf) - 1, " ", &csr);
|
2018-05-03 14:40:24 +00:00
|
|
|
}
|
2020-10-09 08:45:29 +00:00
|
|
|
#else
|
|
|
|
((void) ret);
|
2020-10-16 05:54:39 +00:00
|
|
|
((void) buf);
|
2020-10-09 08:45:29 +00:00
|
|
|
#endif /* !MBEDTLS_X509_REMOVE_INFO */
|
2023-04-19 09:47:01 +00:00
|
|
|
exit:
|
2023-01-11 13:50:10 +00:00
|
|
|
mbedtls_x509_csr_free(&csr);
|
2023-04-19 09:47:01 +00:00
|
|
|
mbedtls_psa_crypto_free();
|
2018-05-03 14:40:24 +00:00
|
|
|
#else
|
|
|
|
(void) Data;
|
|
|
|
(void) Size;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|