source: rtems/c/src/ada-tests/sptests/sp02/sptest.adb @ 7f79b673

4.104.114.84.95
Last change on this file since 7f79b673 was bf9ae83, checked in by Joel Sherrill <joel.sherrill@…>, on 06/02/97 at 20:32:11

modified copyright notice to be the same as RTEMS 4.0.0.

changed the CVS ID string to be a "development" version.

  • Property mode set to 100644
File size: 8.6 KB
Line 
1--
2--  SPTEST / BODY
3--
4--  DESCRIPTION:
5--
6--  This package is the implementation of Test 2 of the RTEMS
7--  Single Processor Test Suite.
8--
9--  DEPENDENCIES:
10--
11-- 
12--
13--  COPYRIGHT (c) 1989-1997.
14--  On-Line Applications Research Corporation (OAR).
15--  Copyright assigned to U.S. Government, 1994.
16--
17--  The license and distribution terms for this file may in
18--  the file LICENSE in this distribution or at
19--  http://www.OARcorp.com/rtems/license.html.
20--
21--  $Id$
22--
23
24with INTERFACES; use INTERFACES;
25with RTEMS;
26with TEST_SUPPORT;
27with TEXT_IO;
28with UNSIGNED32_IO;
29
30package body SPTEST is
31
32--PAGE
33--
34--  INIT
35--
36
37   procedure INIT (
38      ARGUMENT : in     RTEMS.TASK_ARGUMENT
39   ) is
40      STATUS : RTEMS.STATUS_CODES;
41   begin
42
43      TEXT_IO.NEW_LINE( 2 );
44      TEXT_IO.PUT_LINE( "*** TEST 2 ***" );
45
46      SPTEST.PREEMPT_TASK_NAME := RTEMS.BUILD_NAME(  'P', 'R', 'M', 'T' );
47
48      RTEMS.TASK_CREATE(
49         SPTEST.PREEMPT_TASK_NAME,
50         1,
51         2048,
52         RTEMS.DEFAULT_MODES,
53         RTEMS.DEFAULT_ATTRIBUTES,
54         SPTEST.PREEMPT_TASK_ID,
55         STATUS
56      );
57      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE OF PREEMPT" );
58
59      RTEMS.TASK_START(
60         SPTEST.PREEMPT_TASK_ID,
61         SPTEST.PREEMPT_TASK'ACCESS,
62         0,
63         STATUS
64      );
65      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START OF PREEMPT" );
66
67      TEXT_IO.PUT_LINE( "INIT - task_wake_after - yielding processor" );
68      RTEMS.TASK_WAKE_AFTER( RTEMS.YIELD_PROCESSOR, STATUS );
69      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_WAKE_AFTER" );
70
71      SPTEST.TASK_NAME( 1 ) := RTEMS.BUILD_NAME(  'T', 'A', '1', ' ' );
72      SPTEST.TASK_NAME( 2 ) := RTEMS.BUILD_NAME(  'T', 'A', '2', ' ' );
73      SPTEST.TASK_NAME( 3 ) := RTEMS.BUILD_NAME(  'T', 'A', '3', ' ' );
74
75      RTEMS.TASK_CREATE(
76         SPTEST.TASK_NAME( 1 ),
77         3,
78         2048,
79         RTEMS.DEFAULT_MODES,
80         RTEMS.DEFAULT_ATTRIBUTES,
81         SPTEST.TASK_ID( 1 ),
82         STATUS
83      );
84      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE OF TA1" );
85
86      RTEMS.TASK_CREATE(
87         SPTEST.TASK_NAME( 2 ),
88         3,
89         2048,
90         RTEMS.DEFAULT_MODES,
91         RTEMS.DEFAULT_ATTRIBUTES,
92         SPTEST.TASK_ID( 2 ),
93         STATUS
94      );
95      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE OF TA2" );
96
97      RTEMS.TASK_CREATE(
98         SPTEST.TASK_NAME( 3 ),
99         3,
100         2048,
101         RTEMS.DEFAULT_MODES,
102         RTEMS.DEFAULT_ATTRIBUTES,
103         SPTEST.TASK_ID( 3 ),
104         STATUS
105      );
106      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE OF TA3" );
107
108      RTEMS.TASK_START(
109         SPTEST.TASK_ID( 1 ),
110         SPTEST.TASK_1'ACCESS,
111         0,
112         STATUS
113      );
114      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START OF TA1" );
115
116      RTEMS.TASK_START(
117         SPTEST.TASK_ID( 2 ),
118         SPTEST.TASK_2'ACCESS,
119         0,
120         STATUS
121      );
122      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START OF TA2" );
123
124      RTEMS.TASK_START(
125         SPTEST.TASK_ID( 3 ),
126         SPTEST.TASK_3'ACCESS,
127         0,
128         STATUS
129      );
130      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START OF TA3" );
131
132      TEXT_IO.PUT_LINE(
133         "INIT - suspending TA2 while middle task on a ready chain"
134      );
135 
136      RTEMS.TASK_SUSPEND( SPTEST.TASK_ID( 2 ), STATUS );
137      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_SUSPEND OF TA2" );
138
139      RTEMS.TASK_DELETE( SPTEST.TASK_ID( 1 ), STATUS );
140      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_DELETE OF TA1" );
141
142      RTEMS.TASK_DELETE( SPTEST.TASK_ID( 2 ), STATUS );
143      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_DELETE OF TA2" );
144
145      RTEMS.TASK_DELETE( SPTEST.TASK_ID( 3 ), STATUS );
146      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_DELETE OF TA3" );
147
148      RTEMS.TASK_CREATE(
149         SPTEST.TASK_NAME( 1 ),
150         1,
151         2048,
152         RTEMS.DEFAULT_MODES,
153         RTEMS.DEFAULT_ATTRIBUTES,
154         SPTEST.TASK_ID( 1 ),
155         STATUS
156      );
157      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE OF TA1" );
158
159      RTEMS.TASK_CREATE(
160         SPTEST.TASK_NAME( 2 ),
161         3,
162         2048,
163         RTEMS.DEFAULT_MODES,
164         RTEMS.DEFAULT_ATTRIBUTES,
165         SPTEST.TASK_ID( 2 ),
166         STATUS
167      );
168      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE OF TA2" );
169
170      RTEMS.TASK_CREATE(
171         SPTEST.TASK_NAME( 3 ),
172         3,
173         2048,
174         RTEMS.DEFAULT_MODES,
175         RTEMS.DEFAULT_ATTRIBUTES,
176         SPTEST.TASK_ID( 3 ),
177         STATUS
178      );
179      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE OF TA3" );
180
181      RTEMS.TASK_START(
182         SPTEST.TASK_ID( 1 ),
183         SPTEST.TASK_1'ACCESS,
184         0,
185         STATUS
186      );
187      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START OF TA1" );
188
189      RTEMS.TASK_START(
190         SPTEST.TASK_ID( 2 ),
191         SPTEST.TASK_2'ACCESS,
192         0,
193         STATUS
194      );
195      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START OF TA2" );
196
197      RTEMS.TASK_START(
198         SPTEST.TASK_ID( 3 ),
199         SPTEST.TASK_3'ACCESS,
200         0,
201         STATUS
202      );
203      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START OF TA3" );
204
205      RTEMS.TASK_DELETE( RTEMS.SELF, STATUS );
206      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_DELETE OF SELF" );
207
208   end INIT;
209
210--PAGE
211--
212--  PREEMPT_TASK
213--
214
215   procedure PREEMPT_TASK (
216      ARGUMENT : in     RTEMS.TASK_ARGUMENT
217   ) is
218      STATUS            : RTEMS.STATUS_CODES;
219   begin
220
221      TEXT_IO.PUT_LINE( "PREEMPT - task_delete - deleting self" );
222      RTEMS.TASK_DELETE( RTEMS.SELF, STATUS );
223      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_DELETE OF PREEMPT" );
224
225   end PREEMPT_TASK;
226
227--PAGE
228--
229--  TASK_1
230--
231
232   procedure TASK_1 (
233      ARGUMENT : in     RTEMS.TASK_ARGUMENT
234   ) is
235      TID2              : RTEMS.ID;
236      TID3              : RTEMS.ID;
237      STATUS            : RTEMS.STATUS_CODES;
238      PREVIOUS_PRIORITY : RTEMS.TASK_PRIORITY;
239   begin
240
241      TEXT_IO.PUT_LINE( "TA1 - task_wake_after - sleep 1 second" );
242      RTEMS.TASK_WAKE_AFTER( TEST_SUPPORT.TICKS_PER_SECOND, STATUS );
243      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_WAKE_AFTER" );
244         
245      RTEMS.TASK_IDENT(
246         SPTEST.TASK_NAME( 2 ),
247         RTEMS.SEARCH_ALL_NODES,
248         TID2,
249         STATUS
250      );
251      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_IDENT OF TA2" );
252   
253      TEXT_IO.PUT( "TA1 - task_ident - tid of TA2 (" );
254      UNSIGNED32_IO.PUT( TID2, WIDTH => 8, BASE => 10#16# );
255      TEXT_IO.PUT_LINE( ")" );
256
257      RTEMS.TASK_IDENT(
258         SPTEST.TASK_NAME( 3 ),
259         RTEMS.SEARCH_ALL_NODES,
260         TID3,
261         STATUS
262      );
263      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_IDENT OF TA3" );
264   
265      TEXT_IO.PUT( "TA1 - task_ident - tid of TA3 (" );
266      UNSIGNED32_IO.PUT( TID3, WIDTH => 8, BASE => 10#16# );
267      TEXT_IO.PUT_LINE( ")" );
268
269      RTEMS.TASK_SET_PRIORITY( TID3, 2, PREVIOUS_PRIORITY, STATUS );
270      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_SET_PRIORITY" );
271
272      TEXT_IO.PUT_LINE(
273         "TA1 - task_set_priority - set TA3's priority to 2"
274      );
275
276      TEXT_IO.PUT_LINE( "TA1 - task_suspend - suspend TA2" );
277      RTEMS.TASK_SUSPEND( TID2, STATUS );
278      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_SUSPEND OF TA2" );
279
280      TEXT_IO.PUT_LINE( "TA1 - task_delete - delete TA2" );
281      RTEMS.TASK_DELETE( TID2, STATUS );
282      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_DELETE OF TA2" );
283
284      TEXT_IO.PUT_LINE( "TA1 - task_wake_after - sleep for 5 seconds" );
285      RTEMS.TASK_WAKE_AFTER( 5 * TEST_SUPPORT.TICKS_PER_SECOND, STATUS );
286      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_WAKE_AFTER" );
287
288      TEXT_IO.PUT_LINE( "*** END OF TEST 2 ***" );
289      RTEMS.SHUTDOWN_EXECUTIVE( 0 );
290   
291   end TASK_1;
292
293--PAGE
294--
295--  TASK_2
296--
297
298   procedure TASK_2 (
299      ARGUMENT : in     RTEMS.TASK_ARGUMENT
300   ) is
301      STATUS : RTEMS.STATUS_CODES;
302   begin
303
304      TEXT_IO.PUT_LINE( "TA2 - task_wake_after - sleep 1 minute" );
305      RTEMS.TASK_WAKE_AFTER( 60 * TEST_SUPPORT.TICKS_PER_SECOND, STATUS );
306      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_WAKE_AFTER IN TA2" );
307         
308   end TASK_2;
309
310--PAGE
311--
312--  TASK_3
313--
314
315   procedure TASK_3 (
316      ARGUMENT : in     RTEMS.TASK_ARGUMENT
317   ) is
318      STATUS : RTEMS.STATUS_CODES;
319   begin
320
321      TEXT_IO.PUT_LINE( "TA3 - task_wake_after - sleep 5 seconds" );
322      RTEMS.TASK_WAKE_AFTER( 5 * TEST_SUPPORT.TICKS_PER_SECOND, STATUS );
323      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_WAKE_AFTER IN TA3" );
324
325      TEXT_IO.PUT_LINE( "TA3 - task_delete - delete self" );
326      RTEMS.TASK_DELETE( RTEMS.SELF, STATUS );
327      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_DELETE OF TA3" );
328         
329   end TASK_3;
330
331end SPTEST;
Note: See TracBrowser for help on using the repository browser.