blob: c63bd0cdf719137e7ab563af3aabee25ac8e1d7d [file] [log] [blame]
Gilles Peskine57948362021-02-13 00:14:28 +01001/** \file asn1_helpers.c
2 *
3 * \brief Helper functions for tests that manipulate ASN.1 data.
4 */
5
6/*
7 * Copyright The Mbed TLS Contributors
Dave Rodgman16799db2023-11-02 19:47:20 +00008 * SPDX-License-Identifier: Apache-2.0 OR GPL-2.0-or-later
Gilles Peskine57948362021-02-13 00:14:28 +01009 */
10
11#include <test/helpers.h>
12#include <test/macros.h>
13
Gilles Peskine8e94efe2021-02-13 00:25:53 +010014#if defined(MBEDTLS_ASN1_PARSE_C)
15
16#include <mbedtls/asn1.h>
17
Michael Schusterb4d55bb2024-05-29 19:51:36 +020018#include <test/asn1_helpers.h>
19
Gilles Peskine449bd832023-01-11 14:50:10 +010020int mbedtls_test_asn1_skip_integer(unsigned char **p, const unsigned char *end,
21 size_t min_bits, size_t max_bits,
22 int must_be_odd)
Gilles Peskine8e94efe2021-02-13 00:25:53 +010023{
24 size_t len;
25 size_t actual_bits;
26 unsigned char msb;
Gilles Peskine449bd832023-01-11 14:50:10 +010027 TEST_EQUAL(mbedtls_asn1_get_tag(p, end, &len,
28 MBEDTLS_ASN1_INTEGER),
29 0);
Gilles Peskine8e94efe2021-02-13 00:25:53 +010030
31 /* Check if the retrieved length doesn't extend the actual buffer's size.
32 * It is assumed here, that end >= p, which validates casting to size_t. */
Gilles Peskine449bd832023-01-11 14:50:10 +010033 TEST_ASSERT(len <= (size_t) (end - *p));
Gilles Peskine8e94efe2021-02-13 00:25:53 +010034
35 /* Tolerate a slight departure from DER encoding:
36 * - 0 may be represented by an empty string or a 1-byte string.
37 * - The sign bit may be used as a value bit. */
Gilles Peskine449bd832023-01-11 14:50:10 +010038 if ((len == 1 && (*p)[0] == 0) ||
39 (len > 1 && (*p)[0] == 0 && ((*p)[1] & 0x80) != 0)) {
40 ++(*p);
Gilles Peskine8e94efe2021-02-13 00:25:53 +010041 --len;
42 }
Gilles Peskine449bd832023-01-11 14:50:10 +010043 if (min_bits == 0 && len == 0) {
44 return 1;
45 }
46 msb = (*p)[0];
47 TEST_ASSERT(msb != 0);
48 actual_bits = 8 * (len - 1);
49 while (msb != 0) {
Gilles Peskine8e94efe2021-02-13 00:25:53 +010050 msb >>= 1;
51 ++actual_bits;
52 }
Gilles Peskine449bd832023-01-11 14:50:10 +010053 TEST_ASSERT(actual_bits >= min_bits);
54 TEST_ASSERT(actual_bits <= max_bits);
55 if (must_be_odd) {
56 TEST_ASSERT(((*p)[len-1] & 1) != 0);
57 }
Gilles Peskine8e94efe2021-02-13 00:25:53 +010058 *p += len;
Gilles Peskine449bd832023-01-11 14:50:10 +010059 return 1;
Gilles Peskine8e94efe2021-02-13 00:25:53 +010060exit:
Gilles Peskine449bd832023-01-11 14:50:10 +010061 return 0;
Gilles Peskine8e94efe2021-02-13 00:25:53 +010062}
63
64#endif /* MBEDTLS_ASN1_PARSE_C */