source: rtems/c/src/ada-tests/tmtests/tm08/tmtest.adb @ a8e724d6

4.104.115
Last change on this file since a8e724d6 was a8e724d6, checked in by Joel Sherrill <joel.sherrill@…>, on 09/29/08 at 20:44:58

2008-09-29 Joel Sherrill <joel.sherrill@…>

  • support/timer_driver.adb, support/timer_driver.ads, tmtests/tm01/tmtest.adb, tmtests/tm02/tmtest.adb, tmtests/tm03/tmtest.adb, tmtests/tm04/tmtest.adb, tmtests/tm05/tmtest.adb, tmtests/tm06/tmtest.adb, tmtests/tm07/tmtest.adb, tmtests/tm08/tmtest.adb, tmtests/tm09/tmtest.adb, tmtests/tm10/tmtest.adb, tmtests/tm11/tmtest.adb, tmtests/tm12/tmtest.adb, tmtests/tm13/tmtest.adb, tmtests/tm14/tmtest.adb, tmtests/tm15/tmtest.adb, tmtests/tm16/tmtest.adb, tmtests/tm17/tmtest.adb, tmtests/tm18/tmtest.adb, tmtests/tm19/tmtest.adb, tmtests/tm20/config.h, tmtests/tm20/tmtest.adb, tmtests/tm21/tmtest.adb, tmtests/tm22/tmtest.adb, tmtests/tm23/tmtest.adb, tmtests/tm24/tmtest.adb, tmtests/tm25/tmtest.adb, tmtests/tm28/tmtest.adb, tmtests/tm29/tmtest.adb, tmtests/tmck/tmtest.adb, tmtests/tmoverhd/tmtest.adb: Clean up. Verified to run on psim with gcc 4.3.2.
  • Property mode set to 100644
File size: 8.2 KB
Line 
1--
2--  TMTEST / BODY
3--
4--  DESCRIPTION:
5--
6--  This package is the implementation of Test 8 of the RTEMS
7--  Timing Test Suite.
8--
9--  DEPENDENCIES:
10--
11-- 
12--
13--  COPYRIGHT (c) 1989-1997.
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.com/license/LICENSE.
19--
20--  $Id$
21--
22
23with INTERFACES; use INTERFACES;
24with RTEMS;
25with RTEMS_CALLING_OVERHEAD;
26with TEST_SUPPORT;
27with TEXT_IO;
28with TIME_TEST_SUPPORT;
29with UNSIGNED32_IO;
30
31package body TMTEST is
32
33--PAGE
34--
35--  INIT
36--
37
38   procedure INIT (
39      ARGUMENT : in     RTEMS.TASK_ARGUMENT
40   ) is
41      STATUS  : RTEMS.STATUS_CODES;
42   begin
43
44      TEXT_IO.NEW_LINE( 2 );
45      TEXT_IO.PUT_LINE( "*** TIME TEST 8 ***" );
46
47      TMTEST.TEST_INIT;
48
49      RTEMS.TASK_DELETE( RTEMS.SELF, STATUS );
50      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_DELETE OF SELF" );
51
52   end INIT;
53
54--PAGE
55--
56--  TEST_INIT
57--
58
59   procedure TEST_INIT
60   is
61      STATUS     : RTEMS.STATUS_CODES;
62   begin
63
64      RTEMS.TASK_CREATE(
65         1,
66         128,
67         1024,
68         RTEMS.DEFAULT_OPTIONS,
69         RTEMS.DEFAULT_ATTRIBUTES,
70         TASK_ID,
71         STATUS
72      );
73      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE" );
74
75      RTEMS.TASK_START( TASK_ID, TMTEST.TEST_TASK'ACCESS, 0, STATUS );
76      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START" );
77
78      RTEMS.TASK_CREATE(
79         1,
80         254,
81         1024,
82         RTEMS.DEFAULT_OPTIONS,
83         RTEMS.DEFAULT_ATTRIBUTES,
84         TASK_ID,
85         STATUS
86      );
87      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE" );
88
89      RTEMS.TASK_START( TASK_ID, TMTEST.TEST_TASK1'ACCESS, 0, STATUS );
90      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START" );
91
92   end TEST_INIT;
93
94--PAGE
95--
96--  TEST_TASK
97--
98
99   procedure TEST_TASK (
100      ARGUMENT : in     RTEMS.TASK_ARGUMENT
101   ) is
102      OVERHEAD     : RTEMS.UNSIGNED32;
103      OLD_PRIORITY : RTEMS.TASK_PRIORITY;
104      OLD_MODE     : RTEMS.MODE;
105      OLD_NOTE     : RTEMS.NOTEPAD_INDEX;
106      TIME         : RTEMS.TIME_OF_DAY;
107      STATUS       : RTEMS.STATUS_CODES;
108   begin
109
110      TIMER_DRIVER.INITIALIZE;
111         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
112         loop
113            TIMER_DRIVER.EMPTY_FUNCTION;
114         end loop;
115      OVERHEAD := TIMER_DRIVER.READ_TIMER;
116
117      TIMER_DRIVER.INITIALIZE;
118         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
119         loop
120            RTEMS.TASK_SET_PRIORITY(
121               TMTEST.TASK_ID,
122               RTEMS.CURRENT_PRIORITY,
123               OLD_PRIORITY,
124               STATUS
125            );
126         end loop;
127      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
128      TIME_TEST_SUPPORT.PUT_TIME(
129         "TASK_SET_PRIORITY current priority",
130         TMTEST.END_TIME,
131         TIME_TEST_SUPPORT.OPERATION_COUNT,
132         OVERHEAD,
133         RTEMS_CALLING_OVERHEAD.TASK_SET_PRIORITY
134      );
135
136      TIMER_DRIVER.INITIALIZE;
137         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
138         loop
139            RTEMS.TASK_SET_PRIORITY(
140               TMTEST.TASK_ID,
141               253,
142               OLD_PRIORITY,
143               STATUS
144            );
145         end loop;
146      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
147      TIME_TEST_SUPPORT.PUT_TIME(
148         "TASK_SET_PRIORITY no preempt",
149         TMTEST.END_TIME,
150         TIME_TEST_SUPPORT.OPERATION_COUNT,
151         OVERHEAD,
152         RTEMS_CALLING_OVERHEAD.TASK_SET_PRIORITY
153      );
154
155      TIMER_DRIVER.INITIALIZE;
156         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
157         loop
158            RTEMS.TASK_MODE(
159               RTEMS.CURRENT_MODE,
160               RTEMS.CURRENT_MODE,
161               OLD_MODE,
162               STATUS
163            );
164         end loop;
165      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
166      TIME_TEST_SUPPORT.PUT_TIME(
167         "TASK_MODE (current)",
168         TMTEST.END_TIME,
169         TIME_TEST_SUPPORT.OPERATION_COUNT,
170         OVERHEAD,
171         RTEMS_CALLING_OVERHEAD.TASK_MODE
172      );
173
174      TIMER_DRIVER.INITIALIZE;
175         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
176         loop
177            RTEMS.TASK_MODE(
178               RTEMS.INTERRUPT_LEVEL( 1 ),
179               RTEMS.INTERRUPT_MASK,
180               OLD_MODE,
181               STATUS
182            );
183            RTEMS.TASK_MODE(
184               RTEMS.INTERRUPT_LEVEL( 0 ),
185               RTEMS.INTERRUPT_MASK,
186               OLD_MODE,
187               STATUS
188            );
189         end loop;
190      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
191      TIME_TEST_SUPPORT.PUT_TIME(
192         "TASK_MODE (no reschedule)",
193         TMTEST.END_TIME,
194         TIME_TEST_SUPPORT.OPERATION_COUNT * 2,
195         OVERHEAD,
196         RTEMS_CALLING_OVERHEAD.TASK_MODE
197      );
198
199      TIMER_DRIVER.INITIALIZE;
200         RTEMS.TASK_MODE(
201            RTEMS.NO_ASR,
202            RTEMS.ASR_MASK,
203            OLD_MODE,
204            STATUS
205         );
206      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
207      TIME_TEST_SUPPORT.PUT_TIME(
208         "TASK_MODE (reschedule)",
209         TMTEST.END_TIME,
210         1,
211         0,
212         RTEMS_CALLING_OVERHEAD.TASK_MODE
213      );
214
215      RTEMS.TASK_MODE(
216         RTEMS.NO_PREEMPT,
217         RTEMS.PREEMPT_MASK,
218         OLD_MODE,
219         STATUS
220      );
221      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_MODE" );
222
223      RTEMS.TASK_SET_PRIORITY(
224         TMTEST.TASK_ID,
225         1,
226         OLD_PRIORITY,
227         STATUS
228      );
229      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_SET_PRIORITY" );
230
231      TIMER_DRIVER.INITIALIZE;
232      RTEMS.TASK_MODE(          -- preempted by TEST_TASK1
233         RTEMS.PREEMPT,
234         RTEMS.PREEMPT_MASK,
235         OLD_MODE,
236         STATUS
237      );
238
239      TIMER_DRIVER.INITIALIZE;
240         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
241         loop
242            RTEMS.TASK_SET_NOTE(
243               TMTEST.TASK_ID,
244               8,
245               10,
246               STATUS
247            );
248         end loop;
249      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
250      TIME_TEST_SUPPORT.PUT_TIME(
251         "TASK_SET_NOTE ",
252         TMTEST.END_TIME,
253         TIME_TEST_SUPPORT.OPERATION_COUNT,
254         OVERHEAD,
255         RTEMS_CALLING_OVERHEAD.TASK_SET_NOTE
256      );
257
258      TIMER_DRIVER.INITIALIZE;
259         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
260         loop
261            RTEMS.TASK_GET_NOTE(
262               TMTEST.TASK_ID,
263               8,
264               OLD_NOTE,
265               STATUS
266            );
267         end loop;
268      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
269      TIME_TEST_SUPPORT.PUT_TIME(
270         "TASK_GET_NOTE ",
271         TMTEST.END_TIME,
272         TIME_TEST_SUPPORT.OPERATION_COUNT,
273         OVERHEAD,
274         RTEMS_CALLING_OVERHEAD.TASK_GET_NOTE
275      );
276
277      TIME := (1988, 1, 1, 0, 0, 0, 0 );
278
279      TIMER_DRIVER.INITIALIZE;
280         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
281         loop
282            RTEMS.CLOCK_SET(
283               TIME,
284               STATUS
285            );
286         end loop;
287      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
288      TIME_TEST_SUPPORT.PUT_TIME(
289         "CLOCK_SET",
290         TMTEST.END_TIME,
291         TIME_TEST_SUPPORT.OPERATION_COUNT,
292         OVERHEAD,
293         RTEMS_CALLING_OVERHEAD.CLOCK_SET
294      );
295
296      TIMER_DRIVER.INITIALIZE;
297         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
298         loop
299            RTEMS.CLOCK_GET( RTEMS.CLOCK_GET_TOD, TIME'ADDRESS, STATUS );
300         end loop;
301      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
302      TIME_TEST_SUPPORT.PUT_TIME(
303         "CLOCK_GET",
304         TMTEST.END_TIME,
305         TIME_TEST_SUPPORT.OPERATION_COUNT,
306         OVERHEAD,
307         RTEMS_CALLING_OVERHEAD.CLOCK_GET
308      );
309
310      TEXT_IO.PUT_LINE( "*** END OF TIME TEST 8 ***" );
311      RTEMS.SHUTDOWN_EXECUTIVE( 0 );
312
313   end TEST_TASK;
314
315--PAGE
316--
317--  TEST_TASK1
318--
319
320   procedure TEST_TASK1 (
321      ARGUMENT : in     RTEMS.TASK_ARGUMENT
322   ) is
323      STATUS       : RTEMS.STATUS_CODES;
324   begin
325
326      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
327      TIME_TEST_SUPPORT.PUT_TIME(
328         "TASK_MODE (preemptive) ",
329         TMTEST.END_TIME,
330         1,
331         0,
332         RTEMS_CALLING_OVERHEAD.TASK_MODE
333      );
334
335      RTEMS.TASK_SUSPEND( RTEMS.SELF, STATUS );
336
337   end TEST_TASK1;
338
339end TMTEST;
Note: See TracBrowser for help on using the repository browser.