1af6d6403SAaron LI /*-
2af6d6403SAaron LI * SPDX-License-Identifier: MIT
382c705f0SAaron LI *
482c705f0SAaron LI * Copyright (C) 2015-2021 Jason A. Donenfeld <Jason@zx2c4.com>. All Rights Reserved.
582c705f0SAaron LI * Copyright (C) 2019-2021 Matt Dunwoodie <ncon@noconroy.net>
6af6d6403SAaron LI *
7af6d6403SAaron LI * Permission is hereby granted, free of charge, to any person obtaining
8af6d6403SAaron LI * a copy of this software and associated documentation files (the
9af6d6403SAaron LI * "Software"), to deal in the Software without restriction, including
10af6d6403SAaron LI * without limitation the rights to use, copy, modify, merge, publish,
11af6d6403SAaron LI * distribute, sublicense, and/or sell copies of the Software, and to
12af6d6403SAaron LI * permit persons to whom the Software is furnished to do so, subject
13af6d6403SAaron LI * to the following conditions:
14af6d6403SAaron LI *
15af6d6403SAaron LI * The above copyright notice and this permission notice shall be
16af6d6403SAaron LI * included in all copies or substantial portions of the Software.
17af6d6403SAaron LI *
18af6d6403SAaron LI * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
19af6d6403SAaron LI * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
20af6d6403SAaron LI * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
21af6d6403SAaron LI * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
22af6d6403SAaron LI * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
23af6d6403SAaron LI * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
24af6d6403SAaron LI * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
2582c705f0SAaron LI */
2682c705f0SAaron LI
2782c705f0SAaron LI #define T_LIM (COUNTER_WINDOW_SIZE + 1)
2882c705f0SAaron LI #define T_INIT do { \
2982c705f0SAaron LI bzero(&kp, sizeof(kp)); \
309de0ba69SAaron LI lockinit(&kp.kp_counter_lock, "noise_counter", 0, 0); \
3182c705f0SAaron LI } while (0)
3282c705f0SAaron LI #define T(num, v, e) do { \
339de0ba69SAaron LI if (noise_keypair_counter_check(&kp, v) != (e)) { \
349de0ba69SAaron LI kprintf("%s: self-test %u: FAIL\n", __func__, num); \
3582c705f0SAaron LI success = false; \
3682c705f0SAaron LI } \
3782c705f0SAaron LI } while (0)
3882c705f0SAaron LI
3982c705f0SAaron LI bool
noise_counter_selftest(void)4082c705f0SAaron LI noise_counter_selftest(void)
4182c705f0SAaron LI {
4282c705f0SAaron LI struct noise_keypair kp;
43af6d6403SAaron LI int i;
4482c705f0SAaron LI bool success = true;
4582c705f0SAaron LI
4682c705f0SAaron LI T_INIT;
47af6d6403SAaron LI /* T(test_number, counter, expected_response) */
48*79d60aa0SAaron LI T( 1, 0, 0);
49*79d60aa0SAaron LI T( 2, 1, 0);
50*79d60aa0SAaron LI T( 3, 1, EEXIST);
51*79d60aa0SAaron LI T( 4, 9, 0);
52*79d60aa0SAaron LI T( 5, 8, 0);
53*79d60aa0SAaron LI T( 6, 7, 0);
54*79d60aa0SAaron LI T( 7, 7, EEXIST);
55*79d60aa0SAaron LI T( 8, T_LIM, 0);
56*79d60aa0SAaron LI T( 9, T_LIM - 1, 0);
57*79d60aa0SAaron LI T(10, T_LIM - 1, EEXIST);
58*79d60aa0SAaron LI T(11, T_LIM - 2, 0);
59*79d60aa0SAaron LI T(12, 2, 0);
60*79d60aa0SAaron LI T(13, 2, EEXIST);
61*79d60aa0SAaron LI T(14, T_LIM + 16, 0);
62*79d60aa0SAaron LI T(15, 3, ESTALE);
63*79d60aa0SAaron LI T(16, T_LIM + 16, EEXIST);
64*79d60aa0SAaron LI T(17, T_LIM * 4, 0);
65*79d60aa0SAaron LI T(18, T_LIM * 4 - (T_LIM - 1), 0);
66*79d60aa0SAaron LI T(19, 10, ESTALE);
67*79d60aa0SAaron LI T(20, T_LIM * 4 - T_LIM, ESTALE);
68*79d60aa0SAaron LI T(21, T_LIM * 4 - (T_LIM + 1), ESTALE);
69*79d60aa0SAaron LI T(22, T_LIM * 4 - (T_LIM - 2), 0);
70*79d60aa0SAaron LI T(23, T_LIM * 4 - (T_LIM - 1), EEXIST);
71*79d60aa0SAaron LI T(24, 0, ESTALE);
72*79d60aa0SAaron LI T(25, REJECT_AFTER_MESSAGES, EINVAL);
73*79d60aa0SAaron LI T(26, REJECT_AFTER_MESSAGES - 1, 0);
74*79d60aa0SAaron LI T(27, REJECT_AFTER_MESSAGES, EINVAL);
75*79d60aa0SAaron LI T(28, REJECT_AFTER_MESSAGES - 1, EEXIST);
76*79d60aa0SAaron LI T(29, REJECT_AFTER_MESSAGES - 2, 0);
77*79d60aa0SAaron LI T(30, REJECT_AFTER_MESSAGES + 1, EINVAL);
78*79d60aa0SAaron LI T(31, REJECT_AFTER_MESSAGES + 2, EINVAL);
79*79d60aa0SAaron LI T(32, REJECT_AFTER_MESSAGES - 2, EEXIST);
80*79d60aa0SAaron LI T(33, REJECT_AFTER_MESSAGES - 3, 0);
81*79d60aa0SAaron LI T(34, 0, ESTALE);
8282c705f0SAaron LI
8382c705f0SAaron LI T_INIT;
8482c705f0SAaron LI for (i = 1; i <= COUNTER_WINDOW_SIZE; ++i)
85*79d60aa0SAaron LI T(35, i, 0);
86*79d60aa0SAaron LI T(36, 0, 0);
87*79d60aa0SAaron LI T(37, 0, EEXIST);
8882c705f0SAaron LI
8982c705f0SAaron LI T_INIT;
9082c705f0SAaron LI for (i = 2; i <= COUNTER_WINDOW_SIZE + 1; ++i)
91*79d60aa0SAaron LI T(38, i, 0);
92*79d60aa0SAaron LI T(39, 1, 0);
93*79d60aa0SAaron LI T(40, 0, ESTALE);
9482c705f0SAaron LI
9582c705f0SAaron LI T_INIT;
96af6d6403SAaron LI for (i = COUNTER_WINDOW_SIZE; i >= 0; --i)
97*79d60aa0SAaron LI T(41, i, 0);
9882c705f0SAaron LI
9982c705f0SAaron LI T_INIT;
100af6d6403SAaron LI for (i = COUNTER_WINDOW_SIZE + 1; i >= 1; --i)
101*79d60aa0SAaron LI T(42, i, 0);
102*79d60aa0SAaron LI T(43, 0, ESTALE);
10382c705f0SAaron LI
10482c705f0SAaron LI T_INIT;
105af6d6403SAaron LI for (i = COUNTER_WINDOW_SIZE; i >= 1; --i)
106*79d60aa0SAaron LI T(44, i, 0);
107*79d60aa0SAaron LI T(45, COUNTER_WINDOW_SIZE + 1, 0);
108*79d60aa0SAaron LI T(46, 0, ESTALE);
10982c705f0SAaron LI
11082c705f0SAaron LI T_INIT;
111af6d6403SAaron LI for (i = COUNTER_WINDOW_SIZE; i >= 1; --i)
112*79d60aa0SAaron LI T(47, i, 0);
113*79d60aa0SAaron LI T(48, 0, 0);
114*79d60aa0SAaron LI T(49, COUNTER_WINDOW_SIZE + 1, 0);
11582c705f0SAaron LI
116af6d6403SAaron LI kprintf("%s: %s\n", __func__, success ? "pass" : "FAIL");
1179de0ba69SAaron LI return (success);
11882c705f0SAaron LI }
119af6d6403SAaron LI
120af6d6403SAaron LI #undef T
121af6d6403SAaron LI #undef T_INIT
122af6d6403SAaron LI #undef T_LIM
123