summaryrefslogtreecommitdiffstats
path: root/spec/rtems/clock/val/clock.yml
blob: b2689b4d6428b1525fbda155932bcff7b25e5800 (plain) (blame)
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
58
59
60
61
62
63
64
65
66
67
SPDX-License-Identifier: CC-BY-SA-4.0 OR BSD-2-Clause
copyrights:
- Copyright (C) 2021 embedded brains GmbH (http://www.embedded-brains.de)
enabled-by: true
links: []
test-actions:
- action-brief: |
    Use the ${../if/get-ticks-since-boot:/name} function.
  action-code: |
    rtems_interval result_0;
    rtems_interval result_1;
    int32_t difference; /* Note: rtems_interval = uint32_t (unsigned!) */

    result_0 = rtems_clock_get_ticks_since_boot();
    do {
      result_1 = rtems_clock_get_ticks_since_boot();
    } while( result_0 == result_1 );
    /*
     * Because of the ones-complement, the overflow
     * is handled correctly. result_0 = 0xFFFFFFFF will become -1
     * and result_1 = 0x0 will become 0.
     */
    difference = (int32_t) result_1 - (int32_t) result_0;
  checks:
  - brief: |
      Check that ${/glossary/clock-tick:/term} gets incremented.
    code: |
      T_step_eq_i32( ${step}, difference, 1 );
    links:
    - role: validation
      uid: ../req/get-ticks-since-boot
  links: []
- action-brief: |
    Use the ${../if/get-ticks-per-second:/name} function.
  action-code: |
    rtems_interval result;
    result = rtems_clock_get_ticks_per_second();
  checks:
  - brief: |
      Check that ${../if/get-ticks-per-second:/name} actually returns
      1us / CONFIGURE_MICROSECONDS_PER_TICK.
    code: |
      T_step_eq_u32( ${step}, result, 1000000UL / TEST_MICROSECONDS_PER_TICK );
    links:
    - role: validation
      uid: ../req/get-ticks-per-second
  links: []
test-brief: |
  Tests the Clock Manager from ${/glossary/rtems:/term} the Classic
  ${/glossary/api:/term}.
test-context: []
test-context-support: null
test-description: |
  These tests cover only the elements of
  the Clock Manager ${/glossary/api:/term} which are listed in the
  Space Profile.
test-header: null
test-includes:
- rtems.h
test-local-includes:
- ts-config.h
test-setup: null
test-stop: null
test-support: null
test-target: testsuites/validation/tc-clock.c
test-teardown: null
type: test-case