aboutsummaryrefslogtreecommitdiff
path: root/tests/suites/test_suite_timing.function
blob: 4143a1c5112e4218d27ca3377f3440c41e68269d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
/* BEGIN_HEADER */

/* This test module exercises the timing module. Since, depending on the
 * underlying operating system, the timing routines are not always reliable,
 * this suite only performs very basic sanity checks of the timing API.
 */

#include <limits.h>

#include "mbedtls/timing.h"

/* END_HEADER */

/* BEGIN_DEPENDENCIES
 * depends_on:MBEDTLS_TIMING_C
 * END_DEPENDENCIES
 */

/* BEGIN_CASE */
void timing_get_timer()
{
    struct mbedtls_timing_hr_time time;

    memset(&time, 0, sizeof(time));

    (void) mbedtls_timing_get_timer(&time, 1);

    /* Check that a non-zero time was written back */
    int all_zero = 1;
    for (size_t i = 0; i < sizeof(time); i++) {
        all_zero &= ((unsigned char *) &time)[i] == 0;
    }
    TEST_ASSERT(!all_zero);

    (void) mbedtls_timing_get_timer(&time, 0);

    /* This goto is added to avoid warnings from the generated code. */
    goto exit;
}
/* END_CASE */

/* BEGIN_CASE */
void timing_delay(int fin_ms)
{
    mbedtls_timing_delay_context ctx;
    int result;
    if (fin_ms == 0) {
        mbedtls_timing_set_delay(&ctx, 0, 0);
        result = mbedtls_timing_get_delay(&ctx);
        TEST_ASSERT(result == -1);
    } else {
        mbedtls_timing_set_delay(&ctx, fin_ms / 2, fin_ms);
        result = mbedtls_timing_get_delay(&ctx);
        TEST_ASSERT(result >= 0 && result <= 2);
    }
}
/* END_CASE */