| Daniel King | adc32c0 | 2016-05-16 18:25:45 -0300 | [diff] [blame] | 1 | /* BEGIN_HEADER */ | 
|  | 2 | #include "mbedtls/poly1305.h" | 
|  | 3 | #include <stddef.h> | 
|  | 4 | /* END_HEADER */ | 
|  | 5 |  | 
| Manuel Pégourié-Gonnard | a8fa8b8 | 2018-05-10 10:12:36 +0200 | [diff] [blame] | 6 | /* BEGIN_DEPENDENCIES | 
|  | 7 | * depends_on:MBEDTLS_POLY1305_C | 
|  | 8 | * END_DEPENDENCIES | 
|  | 9 | */ | 
|  | 10 |  | 
|  | 11 | /* BEGIN_CASE */ | 
| Gilles Peskine | 1b6c09a | 2023-01-11 14:52:35 +0100 | [diff] [blame] | 12 | void mbedtls_poly1305(data_t *key, data_t *expected_mac, data_t *src_str) | 
| Daniel King | adc32c0 | 2016-05-16 18:25:45 -0300 | [diff] [blame] | 13 | { | 
| Manuel Pégourié-Gonnard | 528524b | 2018-05-09 11:21:21 +0200 | [diff] [blame] | 14 | unsigned char mac[16]; /* size set by the standard */ | 
| Manuel Pégourié-Gonnard | 1465602 | 2018-05-09 12:51:54 +0200 | [diff] [blame] | 15 | mbedtls_poly1305_context ctx; | 
| Daniel King | adc32c0 | 2016-05-16 18:25:45 -0300 | [diff] [blame] | 16 |  | 
| Gilles Peskine | 1b6c09a | 2023-01-11 14:52:35 +0100 | [diff] [blame] | 17 | memset(mac, 0x00, sizeof(mac)); | 
| Daniel King | adc32c0 | 2016-05-16 18:25:45 -0300 | [diff] [blame] | 18 |  | 
| Manuel Pégourié-Gonnard | 1465602 | 2018-05-09 12:51:54 +0200 | [diff] [blame] | 19 | /* | 
|  | 20 | * Test the integrated API | 
|  | 21 | */ | 
| Gilles Peskine | 1b6c09a | 2023-01-11 14:52:35 +0100 | [diff] [blame] | 22 | TEST_ASSERT(mbedtls_poly1305_mac(key->x, src_str->x, | 
|  | 23 | src_str->len, mac) == 0); | 
| Daniel King | adc32c0 | 2016-05-16 18:25:45 -0300 | [diff] [blame] | 24 |  | 
| Tom Cosgrove | ba3b14d | 2023-09-04 11:23:02 +0100 | [diff] [blame] | 25 | TEST_MEMORY_COMPARE(mac, expected_mac->len, | 
| Tom Cosgrove | a240fe3 | 2023-09-04 11:29:39 +0100 | [diff] [blame^] | 26 | expected_mac->x, expected_mac->len); | 
| Manuel Pégourié-Gonnard | 1465602 | 2018-05-09 12:51:54 +0200 | [diff] [blame] | 27 |  | 
|  | 28 | /* | 
|  | 29 | * Test the streaming API | 
|  | 30 | */ | 
| Gilles Peskine | 1b6c09a | 2023-01-11 14:52:35 +0100 | [diff] [blame] | 31 | mbedtls_poly1305_init(&ctx); | 
| Manuel Pégourié-Gonnard | 1465602 | 2018-05-09 12:51:54 +0200 | [diff] [blame] | 32 |  | 
| Gilles Peskine | 1b6c09a | 2023-01-11 14:52:35 +0100 | [diff] [blame] | 33 | TEST_ASSERT(mbedtls_poly1305_starts(&ctx, key->x) == 0); | 
| Manuel Pégourié-Gonnard | 1465602 | 2018-05-09 12:51:54 +0200 | [diff] [blame] | 34 |  | 
| Gilles Peskine | 1b6c09a | 2023-01-11 14:52:35 +0100 | [diff] [blame] | 35 | TEST_ASSERT(mbedtls_poly1305_update(&ctx, src_str->x, src_str->len) == 0); | 
| Manuel Pégourié-Gonnard | 1465602 | 2018-05-09 12:51:54 +0200 | [diff] [blame] | 36 |  | 
| Gilles Peskine | 1b6c09a | 2023-01-11 14:52:35 +0100 | [diff] [blame] | 37 | TEST_ASSERT(mbedtls_poly1305_finish(&ctx, mac) == 0); | 
| Manuel Pégourié-Gonnard | 1465602 | 2018-05-09 12:51:54 +0200 | [diff] [blame] | 38 |  | 
| Tom Cosgrove | ba3b14d | 2023-09-04 11:23:02 +0100 | [diff] [blame] | 39 | TEST_MEMORY_COMPARE(mac, expected_mac->len, | 
| Tom Cosgrove | a240fe3 | 2023-09-04 11:29:39 +0100 | [diff] [blame^] | 40 | expected_mac->x, expected_mac->len); | 
| Manuel Pégourié-Gonnard | 1465602 | 2018-05-09 12:51:54 +0200 | [diff] [blame] | 41 |  | 
|  | 42 | /* | 
|  | 43 | * Test the streaming API again, piecewise | 
|  | 44 | */ | 
|  | 45 |  | 
|  | 46 | /* Don't free/init the context, in order to test that starts() does the | 
|  | 47 | * right thing. */ | 
| Gilles Peskine | 1b6c09a | 2023-01-11 14:52:35 +0100 | [diff] [blame] | 48 | if (src_str->len >= 1) { | 
|  | 49 | TEST_ASSERT(mbedtls_poly1305_starts(&ctx, key->x) == 0); | 
| Manuel Pégourié-Gonnard | 1465602 | 2018-05-09 12:51:54 +0200 | [diff] [blame] | 50 |  | 
| Gilles Peskine | 1b6c09a | 2023-01-11 14:52:35 +0100 | [diff] [blame] | 51 | TEST_ASSERT(mbedtls_poly1305_update(&ctx, src_str->x, 1) == 0); | 
|  | 52 | TEST_ASSERT(mbedtls_poly1305_update(&ctx, src_str->x + 1, src_str->len - 1) == 0); | 
| Manuel Pégourié-Gonnard | 1465602 | 2018-05-09 12:51:54 +0200 | [diff] [blame] | 53 |  | 
| Gilles Peskine | 1b6c09a | 2023-01-11 14:52:35 +0100 | [diff] [blame] | 54 | TEST_ASSERT(mbedtls_poly1305_finish(&ctx, mac) == 0); | 
| Manuel Pégourié-Gonnard | 1465602 | 2018-05-09 12:51:54 +0200 | [diff] [blame] | 55 |  | 
| Tom Cosgrove | ba3b14d | 2023-09-04 11:23:02 +0100 | [diff] [blame] | 56 | TEST_MEMORY_COMPARE(mac, expected_mac->len, | 
| Tom Cosgrove | a240fe3 | 2023-09-04 11:29:39 +0100 | [diff] [blame^] | 57 | expected_mac->x, expected_mac->len); | 
| Manuel Pégourié-Gonnard | 444f711 | 2018-05-10 11:06:46 +0200 | [diff] [blame] | 58 | } | 
|  | 59 |  | 
|  | 60 | /* | 
|  | 61 | * Again with more pieces | 
|  | 62 | */ | 
| Gilles Peskine | 1b6c09a | 2023-01-11 14:52:35 +0100 | [diff] [blame] | 63 | if (src_str->len >= 2) { | 
|  | 64 | TEST_ASSERT(mbedtls_poly1305_starts(&ctx, key->x) == 0); | 
| Manuel Pégourié-Gonnard | 444f711 | 2018-05-10 11:06:46 +0200 | [diff] [blame] | 65 |  | 
| Gilles Peskine | 1b6c09a | 2023-01-11 14:52:35 +0100 | [diff] [blame] | 66 | TEST_ASSERT(mbedtls_poly1305_update(&ctx, src_str->x, 1) == 0); | 
|  | 67 | TEST_ASSERT(mbedtls_poly1305_update(&ctx, src_str->x + 1, 1) == 0); | 
|  | 68 | TEST_ASSERT(mbedtls_poly1305_update(&ctx, src_str->x + 2, src_str->len - 2) == 0); | 
| Manuel Pégourié-Gonnard | 444f711 | 2018-05-10 11:06:46 +0200 | [diff] [blame] | 69 |  | 
| Gilles Peskine | 1b6c09a | 2023-01-11 14:52:35 +0100 | [diff] [blame] | 70 | TEST_ASSERT(mbedtls_poly1305_finish(&ctx, mac) == 0); | 
| Manuel Pégourié-Gonnard | 444f711 | 2018-05-10 11:06:46 +0200 | [diff] [blame] | 71 |  | 
| Tom Cosgrove | ba3b14d | 2023-09-04 11:23:02 +0100 | [diff] [blame] | 72 | TEST_MEMORY_COMPARE(mac, expected_mac->len, | 
| Tom Cosgrove | a240fe3 | 2023-09-04 11:29:39 +0100 | [diff] [blame^] | 73 | expected_mac->x, expected_mac->len); | 
| Manuel Pégourié-Gonnard | 444f711 | 2018-05-10 11:06:46 +0200 | [diff] [blame] | 74 | } | 
| Manuel Pégourié-Gonnard | 1465602 | 2018-05-09 12:51:54 +0200 | [diff] [blame] | 75 |  | 
| Gilles Peskine | 1b6c09a | 2023-01-11 14:52:35 +0100 | [diff] [blame] | 76 | mbedtls_poly1305_free(&ctx); | 
| Daniel King | adc32c0 | 2016-05-16 18:25:45 -0300 | [diff] [blame] | 77 | } | 
|  | 78 | /* END_CASE */ | 
|  | 79 |  | 
| Andrzej Kurek | c470b6b | 2019-01-31 08:20:20 -0500 | [diff] [blame] | 80 | /* BEGIN_CASE depends_on:MBEDTLS_CHECK_PARAMS:!MBEDTLS_PARAM_FAILED_ALT */ | 
| Manuel Pégourié-Gonnard | a8fa8b8 | 2018-05-10 10:12:36 +0200 | [diff] [blame] | 81 | void poly1305_bad_params() | 
|  | 82 | { | 
|  | 83 | unsigned char src[1]; | 
|  | 84 | unsigned char key[32]; | 
|  | 85 | unsigned char mac[16]; | 
| Gilles Peskine | 1b6c09a | 2023-01-11 14:52:35 +0100 | [diff] [blame] | 86 | size_t src_len = sizeof(src); | 
| Manuel Pégourié-Gonnard | a8fa8b8 | 2018-05-10 10:12:36 +0200 | [diff] [blame] | 87 | mbedtls_poly1305_context ctx; | 
|  | 88 |  | 
| Gilles Peskine | 1b6c09a | 2023-01-11 14:52:35 +0100 | [diff] [blame] | 89 | TEST_INVALID_PARAM(mbedtls_poly1305_init(NULL)); | 
|  | 90 | TEST_VALID_PARAM(mbedtls_poly1305_free(NULL)); | 
| Manuel Pégourié-Gonnard | a8fa8b8 | 2018-05-10 10:12:36 +0200 | [diff] [blame] | 91 |  | 
| Gilles Peskine | 1b6c09a | 2023-01-11 14:52:35 +0100 | [diff] [blame] | 92 | TEST_INVALID_PARAM_RET(MBEDTLS_ERR_POLY1305_BAD_INPUT_DATA, | 
|  | 93 | mbedtls_poly1305_starts(NULL, key)); | 
|  | 94 | TEST_INVALID_PARAM_RET(MBEDTLS_ERR_POLY1305_BAD_INPUT_DATA, | 
|  | 95 | mbedtls_poly1305_starts(&ctx, NULL)); | 
| Manuel Pégourié-Gonnard | a8fa8b8 | 2018-05-10 10:12:36 +0200 | [diff] [blame] | 96 |  | 
| Gilles Peskine | 1b6c09a | 2023-01-11 14:52:35 +0100 | [diff] [blame] | 97 | TEST_INVALID_PARAM_RET(MBEDTLS_ERR_POLY1305_BAD_INPUT_DATA, | 
|  | 98 | mbedtls_poly1305_update(NULL, src, 0)); | 
|  | 99 | TEST_INVALID_PARAM_RET(MBEDTLS_ERR_POLY1305_BAD_INPUT_DATA, | 
|  | 100 | mbedtls_poly1305_update(&ctx, NULL, src_len)); | 
| Manuel Pégourié-Gonnard | a8fa8b8 | 2018-05-10 10:12:36 +0200 | [diff] [blame] | 101 |  | 
| Gilles Peskine | 1b6c09a | 2023-01-11 14:52:35 +0100 | [diff] [blame] | 102 | TEST_INVALID_PARAM_RET(MBEDTLS_ERR_POLY1305_BAD_INPUT_DATA, | 
|  | 103 | mbedtls_poly1305_finish(NULL, mac)); | 
|  | 104 | TEST_INVALID_PARAM_RET(MBEDTLS_ERR_POLY1305_BAD_INPUT_DATA, | 
|  | 105 | mbedtls_poly1305_finish(&ctx, NULL)); | 
| Manuel Pégourié-Gonnard | a8fa8b8 | 2018-05-10 10:12:36 +0200 | [diff] [blame] | 106 |  | 
| Gilles Peskine | 1b6c09a | 2023-01-11 14:52:35 +0100 | [diff] [blame] | 107 | TEST_INVALID_PARAM_RET(MBEDTLS_ERR_POLY1305_BAD_INPUT_DATA, | 
|  | 108 | mbedtls_poly1305_mac(NULL, src, 0, mac)); | 
|  | 109 | TEST_INVALID_PARAM_RET(MBEDTLS_ERR_POLY1305_BAD_INPUT_DATA, | 
|  | 110 | mbedtls_poly1305_mac(key, NULL, src_len, mac)); | 
|  | 111 | TEST_INVALID_PARAM_RET(MBEDTLS_ERR_POLY1305_BAD_INPUT_DATA, | 
|  | 112 | mbedtls_poly1305_mac(key, src, 0, NULL)); | 
| Manuel Pégourié-Gonnard | a8fa8b8 | 2018-05-10 10:12:36 +0200 | [diff] [blame] | 113 |  | 
| Andrzej Kurek | c470b6b | 2019-01-31 08:20:20 -0500 | [diff] [blame] | 114 | exit: | 
|  | 115 | return; | 
| Manuel Pégourié-Gonnard | a8fa8b8 | 2018-05-10 10:12:36 +0200 | [diff] [blame] | 116 | } | 
|  | 117 | /* END_CASE */ | 
|  | 118 |  | 
|  | 119 | /* BEGIN_CASE depends_on:MBEDTLS_SELF_TEST */ | 
| Daniel King | adc32c0 | 2016-05-16 18:25:45 -0300 | [diff] [blame] | 120 | void poly1305_selftest() | 
|  | 121 | { | 
| Gilles Peskine | 1b6c09a | 2023-01-11 14:52:35 +0100 | [diff] [blame] | 122 | TEST_ASSERT(mbedtls_poly1305_self_test(1) == 0); | 
| Daniel King | adc32c0 | 2016-05-16 18:25:45 -0300 | [diff] [blame] | 123 | } | 
|  | 124 | /* END_CASE */ |