source: rtems/testsuites/ada/tmtests/tm06/tmtest.adb @ ee537ea

5
Last change on this file since ee537ea was ee537ea, checked in by Sebastian Huber <sebastian.huber@…>, on 10/12/17 at 08:00:10

ada-tests: Move to testsuites/ada

This solves a build dependency issue, e.g. building tests before
librtemsbsp.a exists.

Close #3079.

  • Property mode set to 100644
File size: 4.7 KB
Line 
1--
2--  TMTEST / BODY
3--
4--  DESCRIPTION:
5--
6--  This package is the implementation of Test 6 of the RTEMS
7--  Timing Test Suite.
8--
9--  DEPENDENCIES:
10--
11-- 
12--
13--  COPYRIGHT (c) 1989-2011.
14--  On-Line Applications Research Corporation (OAR).
15--
16--  The license and distribution terms for this file may in
17--  the file LICENSE in this distribution or at
18--  http://www.rtems.org/license/LICENSE.
19--
20
21with INTERFACES; use INTERFACES;
22with RTEMS_CALLING_OVERHEAD;
23with TEST_SUPPORT;
24with TEXT_IO;
25with TIMER_DRIVER;
26
27package body TMTEST is
28
29--
30--  INIT
31--
32
33   procedure INIT (
34      ARGUMENT : in     RTEMS.TASKS.ARGUMENT
35   ) is
36      pragma Unreferenced(ARGUMENT);
37      STATUS  : RTEMS.STATUS_CODES;
38   begin
39
40      TEXT_IO.NEW_LINE( 2 );
41      TEXT_IO.PUT_LINE( "*** TIME TEST 6 ***" );
42
43      TMTEST.TEST_INIT;
44
45      RTEMS.TASKS.DELETE( RTEMS.SELF, STATUS );
46      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_DELETE OF SELF" );
47
48   end INIT;
49
50--
51--  TEST_INIT
52--
53
54   procedure TEST_INIT
55   is
56      ID         : RTEMS.ID;
57      STATUS     : RTEMS.STATUS_CODES;
58   begin
59
60      TMTEST.TASK_RESTARTED := TIME_TEST_SUPPORT.OPERATION_COUNT;
61
62      RTEMS.TASKS.CREATE(
63         RTEMS.BUILD_NAME( 'T', 'I', 'M', 'E' ),
64         128,
65         1024,
66         RTEMS.DEFAULT_MODES,
67         RTEMS.DEFAULT_ATTRIBUTES,
68         ID,
69         STATUS
70      );
71      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE" );
72
73      RTEMS.TASKS.START( ID, TMTEST.TASK_1'ACCESS, 0, STATUS );
74      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START" );
75
76   end TEST_INIT;
77
78--
79--  TASK_1
80--
81
82   procedure TASK_1 (
83      ARGUMENT : in     RTEMS.TASKS.ARGUMENT
84   ) is
85      pragma Unreferenced(ARGUMENT);
86      OVERHEAD     : RTEMS.UNSIGNED32;
87      STATUS       : RTEMS.STATUS_CODES;
88   begin
89
90      if TMTEST.TASK_RESTARTED = TIME_TEST_SUPPORT.OPERATION_COUNT then
91         TIMER_DRIVER.INITIALIZE;
92      end if;
93
94      TMTEST.TASK_RESTARTED := TMTEST.TASK_RESTARTED - 1;
95
96      if TMTEST.TASK_RESTARTED /= 0 then
97         RTEMS.TASKS.RESTART( RTEMS.SELF, 0, STATUS );
98      end if;
99
100      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
101
102      TIMER_DRIVER.INITIALIZE;
103         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
104         loop
105            TIMER_DRIVER.EMPTY_FUNCTION;
106         end loop;
107      OVERHEAD := TIMER_DRIVER.READ_TIMER;
108
109      TIME_TEST_SUPPORT.PUT_TIME(
110         "TASK_RESTART self",
111         TMTEST.END_TIME,
112         TIME_TEST_SUPPORT.OPERATION_COUNT,
113         0,
114         RTEMS_CALLING_OVERHEAD.TASK_RESTART
115      );
116
117      for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
118      loop
119
120         RTEMS.TASKS.CREATE(
121            RTEMS.BUILD_NAME( 'T', 'I', 'M', 'E' ),
122            254,
123            1024,
124            RTEMS.DEFAULT_MODES,
125            RTEMS.DEFAULT_ATTRIBUTES,
126            TMTEST.TASK_ID( INDEX ),
127            STATUS
128         );
129         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE LOOP" );
130
131         RTEMS.TASKS.START(
132            TMTEST.TASK_ID( INDEX ),
133            TMTEST.NULL_TASK'ACCESS,
134            0,
135            STATUS
136         );
137         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START LOOP" );
138
139      end loop;
140
141      TIMER_DRIVER.INITIALIZE;
142         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
143         loop
144            RTEMS.TASKS.SUSPEND( TMTEST.TASK_ID( INDEX ), STATUS );
145         end loop;
146      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
147      TIME_TEST_SUPPORT.PUT_TIME(
148         "TASK_SUSPEND no preempt",
149         TMTEST.END_TIME,
150         TIME_TEST_SUPPORT.OPERATION_COUNT,
151         OVERHEAD,
152         RTEMS_CALLING_OVERHEAD.TASK_SUSPEND
153      );
154
155      TIMER_DRIVER.INITIALIZE;
156         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
157         loop
158            RTEMS.TASKS.RESUME( TMTEST.TASK_ID( INDEX ), STATUS );
159         end loop;
160      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
161      TIME_TEST_SUPPORT.PUT_TIME(
162         "TASK_RESUME no preempt",
163         TMTEST.END_TIME,
164         TIME_TEST_SUPPORT.OPERATION_COUNT,
165         OVERHEAD,
166         RTEMS_CALLING_OVERHEAD.TASK_RESUME
167      );
168
169      TIMER_DRIVER.INITIALIZE;
170         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
171         loop
172            RTEMS.TASKS.DELETE( TMTEST.TASK_ID( INDEX ), STATUS );
173         end loop;
174      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
175      TIME_TEST_SUPPORT.PUT_TIME(
176         "TASK_DELETE others",
177         TMTEST.END_TIME,
178         TIME_TEST_SUPPORT.OPERATION_COUNT,
179         OVERHEAD,
180         RTEMS_CALLING_OVERHEAD.TASK_DELETE
181      );
182
183      TEXT_IO.PUT_LINE( "*** END OF TIME TEST 6 ***" );
184      RTEMS.SHUTDOWN_EXECUTIVE( 0 );
185
186   end TASK_1;
187
188--
189--  NULL_TASK
190--
191
192   procedure NULL_TASK (
193      ARGUMENT : in     RTEMS.TASKS.ARGUMENT
194   ) is
195      pragma Unreferenced(ARGUMENT);
196   begin
197
198      NULL;
199
200   end NULL_TASK;
201
202end TMTEST;
Note: See TracBrowser for help on using the repository browser.