source: rtems/testsuites/ada/tmtests/tm21/tmtest.adb @ f6c9334d

5
Last change on this file since f6c9334d was f6c9334d, checked in by Sebastian Huber <sebastian.huber@…>, on 12/01/17 at 07:51:17

ada: Add standard test begin/end message

  • Property mode set to 100644
File size: 7.7 KB
Line 
1--
2--  TMTEST / BODY
3--
4--  DESCRIPTION:
5--
6--  This package is the implementation of Test 21 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 RTEMS_CALLING_OVERHEAD;
22with TEST_SUPPORT;
23with TEXT_IO;
24with TIME_TEST_SUPPORT;
25with TIMER_DRIVER;
26with RTEMS.MESSAGE_QUEUE;
27with RTEMS.PARTITION;
28with RTEMS.PORT;
29with RTEMS.RATE_MONOTONIC;
30with RTEMS.REGION;
31with RTEMS.SEMAPHORE;
32with RTEMS.TIMER;
33
34package body TMTEST is
35
36--
37--  INIT
38--
39
40   procedure INIT (
41      ARGUMENT : in     RTEMS.TASKS.ARGUMENT
42   ) is
43      pragma Unreferenced(ARGUMENT);
44      ID     : RTEMS.ID;
45      STATUS : RTEMS.STATUS_CODES;
46   begin
47
48      TEXT_IO.NEW_LINE( 2 );
49      TEST_SUPPORT.ADA_TEST_BEGIN;
50
51      RTEMS.TASKS.CREATE(
52         RTEMS.BUILD_NAME( 'T', 'I', 'M', 'E' ),
53         250,
54         2048,
55         RTEMS.DEFAULT_MODES,
56         RTEMS.DEFAULT_ATTRIBUTES,
57         ID,
58         STATUS
59      );
60      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE TASK_1" );
61
62      RTEMS.TASKS.START( ID, TMTEST.TASK_1'ACCESS, 0, STATUS );
63      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START TASK1" );
64
65      RTEMS.TASKS.DELETE( RTEMS.SELF, STATUS );
66      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_DELETE OF SELF" );
67
68   end INIT;
69
70--
71--  TASK_1
72--
73
74   procedure TASK_1 (
75      ARGUMENT : in     RTEMS.TASKS.ARGUMENT
76   ) is
77      pragma Unreferenced(ARGUMENT);
78      ID       : RTEMS.ID;
79      OVERHEAD : RTEMS.UNSIGNED32;
80      STATUS   : RTEMS.STATUS_CODES;
81   begin
82
83      for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
84      loop
85
86         RTEMS.TASKS.CREATE(
87            INDEX,
88            254,
89            1024,
90            RTEMS.DEFAULT_MODES,
91            RTEMS.DEFAULT_ATTRIBUTES,
92            ID,
93            STATUS
94         );
95         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE" );
96
97         RTEMS.MESSAGE_QUEUE.CREATE(
98            INDEX,
99            TIME_TEST_SUPPORT.OPERATION_COUNT,
100            16,
101            RTEMS.DEFAULT_ATTRIBUTES,
102            ID,
103            STATUS
104         );
105         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "MESSAGE_QUEUE_CREATE" );
106
107         RTEMS.SEMAPHORE.CREATE(
108            INDEX,
109            TIME_TEST_SUPPORT.OPERATION_COUNT,
110            RTEMS.DEFAULT_ATTRIBUTES,
111            RTEMS.TASKS.NO_PRIORITY,
112            ID,
113            STATUS
114         );
115         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "SEMAPHORE_CREATE" );
116
117         RTEMS.REGION.CREATE(
118            INDEX,
119            TMTEST.REGION_AREA'ADDRESS,
120            2048,
121            16,
122            RTEMS.DEFAULT_ATTRIBUTES,
123            ID,
124            STATUS
125         );
126         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "REGION_CREATE" );
127
128         RTEMS.PARTITION.CREATE(
129            INDEX,
130            TMTEST.PARTITION_AREA'ADDRESS,
131            2048,
132            128,
133            RTEMS.DEFAULT_ATTRIBUTES,
134            ID,
135            STATUS
136         );
137         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "PARTITION_CREATE" );
138
139         RTEMS.PORT.CREATE(
140            INDEX,
141            TMTEST.INTERNAL_PORT_AREA'ADDRESS,
142            TMTEST.EXTERNAL_PORT_AREA'ADDRESS,
143            16#FF#,
144            ID,
145            STATUS
146         );
147         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "PORT_CREATE" );
148
149         RTEMS.TIMER.CREATE( INDEX, ID, STATUS );
150         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TIMER_CREATE" );
151
152         RTEMS.RATE_MONOTONIC.CREATE( INDEX, ID, STATUS );
153         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "RATE_MONOTONIC_CREATE" );
154
155      end loop;
156
157      TIMER_DRIVER.INITIALIZE;
158         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
159         loop
160            TIMER_DRIVER.EMPTY_FUNCTION;
161         end loop;
162      OVERHEAD := TIMER_DRIVER.READ_TIMER;
163
164      TIMER_DRIVER.INITIALIZE;
165         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
166         loop
167            RTEMS.TASKS.IDENT( INDEX, RTEMS.SEARCH_ALL_NODES, ID, STATUS );
168         end loop;
169      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
170
171      TIME_TEST_SUPPORT.PUT_TIME(
172         "TASK_IDENT",
173         TMTEST.END_TIME,
174         TIME_TEST_SUPPORT.OPERATION_COUNT,
175         OVERHEAD,
176         RTEMS_CALLING_OVERHEAD.TASK_IDENT
177      );
178
179      TIMER_DRIVER.INITIALIZE;
180         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
181         loop
182            RTEMS.MESSAGE_QUEUE.IDENT(
183               INDEX,
184               RTEMS.SEARCH_ALL_NODES,
185               ID,
186               STATUS
187            );
188         end loop;
189      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
190
191      TIME_TEST_SUPPORT.PUT_TIME(
192         "MESSAGE_QUEUE_IDENT",
193         TMTEST.END_TIME,
194         TIME_TEST_SUPPORT.OPERATION_COUNT,
195         OVERHEAD,
196         RTEMS_CALLING_OVERHEAD.MESSAGE_QUEUE_IDENT
197      );
198
199      TIMER_DRIVER.INITIALIZE;
200         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
201         loop
202            RTEMS.SEMAPHORE.IDENT(
203               INDEX,
204               RTEMS.SEARCH_ALL_NODES,
205               ID,
206               STATUS
207           );
208         end loop;
209      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
210
211      TIME_TEST_SUPPORT.PUT_TIME(
212         "SEMAPHORE_IDENT",
213         TMTEST.END_TIME,
214         TIME_TEST_SUPPORT.OPERATION_COUNT,
215         OVERHEAD,
216         RTEMS_CALLING_OVERHEAD.SEMAPHORE_IDENT
217      );
218
219      TIMER_DRIVER.INITIALIZE;
220         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
221         loop
222            RTEMS.PARTITION.IDENT(
223               INDEX,
224               RTEMS.SEARCH_ALL_NODES,
225               ID,
226               STATUS
227           );
228         end loop;
229      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
230
231      TIME_TEST_SUPPORT.PUT_TIME(
232         "PARTITION_IDENT",
233         TMTEST.END_TIME,
234         TIME_TEST_SUPPORT.OPERATION_COUNT,
235         OVERHEAD,
236         RTEMS_CALLING_OVERHEAD.PARTITION_IDENT
237      );
238
239      TIMER_DRIVER.INITIALIZE;
240         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
241         loop
242            RTEMS.REGION.IDENT( INDEX, ID, STATUS );
243         end loop;
244      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
245
246      TIME_TEST_SUPPORT.PUT_TIME(
247         "REGION_IDENT",
248         TMTEST.END_TIME,
249         TIME_TEST_SUPPORT.OPERATION_COUNT,
250         OVERHEAD,
251         RTEMS_CALLING_OVERHEAD.REGION_IDENT
252      );
253
254      TIMER_DRIVER.INITIALIZE;
255         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
256         loop
257            RTEMS.PORT.IDENT( INDEX, ID, STATUS );
258         end loop;
259      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
260
261      TIME_TEST_SUPPORT.PUT_TIME(
262         "PORT_IDENT",
263         TMTEST.END_TIME,
264         TIME_TEST_SUPPORT.OPERATION_COUNT,
265         OVERHEAD,
266         RTEMS_CALLING_OVERHEAD.PORT_IDENT
267      );
268
269      TIMER_DRIVER.INITIALIZE;
270         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
271         loop
272            RTEMS.TIMER.IDENT( INDEX, ID, STATUS );
273         end loop;
274      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
275
276      TIME_TEST_SUPPORT.PUT_TIME(
277         "TIMER_IDENT",
278         TMTEST.END_TIME,
279         TIME_TEST_SUPPORT.OPERATION_COUNT,
280         OVERHEAD,
281         RTEMS_CALLING_OVERHEAD.TIMER_IDENT
282      );
283
284      TIMER_DRIVER.INITIALIZE;
285         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
286         loop
287            RTEMS.RATE_MONOTONIC.IDENT( INDEX, ID, STATUS );
288         end loop;
289      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
290
291      TIME_TEST_SUPPORT.PUT_TIME(
292         "RATE_MONOTONIC_IDENT",
293         TMTEST.END_TIME,
294         TIME_TEST_SUPPORT.OPERATION_COUNT,
295         OVERHEAD,
296         RTEMS_CALLING_OVERHEAD.RATE_MONOTONIC_IDENT
297      );
298
299      TEST_SUPPORT.ADA_TEST_END;
300      RTEMS.SHUTDOWN_EXECUTIVE( 0 );
301
302   end TASK_1;
303
304end TMTEST;
Note: See TracBrowser for help on using the repository browser.