source: rtems/c/src/ada-tests/mptests/mp13/mptest.adb @ 23848bbd

4.104.114.95
Last change on this file since 23848bbd was 23848bbd, checked in by Joel Sherrill <joel.sherrill@…>, on Oct 1, 2007 at 10:58:09 PM

2007-10-01 Joel Sherrill <joel.sherrill@…>

  • mptests/mp01/mptest.adb, mptests/mp01/mptest.ads, mptests/mp01/node1/Makefile.am, mptests/mp02/mptest.adb, mptests/mp02/mptest.ads, mptests/mp03/mptest.adb, mptests/mp03/mptest.ads, mptests/mp04/mptest.adb, mptests/mp04/mptest.ads, mptests/mp05/mptest.adb, mptests/mp05/mptest.ads, mptests/mp06/mptest.adb, mptests/mp06/mptest.ads, mptests/mp07/mptest.adb, mptests/mp07/mptest.ads, mptests/mp08/mptest.adb, mptests/mp08/mptest.ads, mptests/mp09/mptest.adb, mptests/mp09/mptest.ads, mptests/mp10/mptest.adb, mptests/mp10/mptest.ads, mptests/mp11/mptest.adb, mptests/mp11/mptest.ads, mptests/mp12/mptest.adb, mptests/mp12/mptest.ads, mptests/mp13/mptest.adb, mptests/mp13/mptest.ads, mptests/mp14/mptest.adb, mptests/mp14/mptest.ads, support/init.c, support/test_support.adb, support/test_support.ads: Most of single processor Ada tests now build. Some run.
  • Property mode set to 100644
File size: 8.5 KB
Line 
1--
2--  MPTEST / BODY
3--
4--  DESCRIPTION:
5--
6--  This package is the implementation for Test 13 of the RTEMS
7--  Multiprocessor 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 TEST_SUPPORT;
26with TEXT_IO;
27with UNSIGNED32_IO;
28
29package body MPTEST is
30
31--PAGE
32--
33--  INIT
34--
35
36   procedure INIT (
37      ARGUMENT : in     RTEMS.TASK_ARGUMENT
38   ) is
39      STATUS : RTEMS.STATUS_CODES;
40   begin
41
42      TEXT_IO.NEW_LINE( 2 );
43      TEXT_IO.PUT( "*** TEST 13 -- NODE " );
44      UNSIGNED32_IO.PUT(
45         TEST_SUPPORT.NODE,
46         WIDTH => 1
47      );
48      TEXT_IO.PUT_LINE( " ***" );
49
50      MPTEST.TASK_NAME( 1 ) := RTEMS.BUILD_NAME(  '1', '1', '1', ' ' );
51      MPTEST.TASK_NAME( 2 ) := RTEMS.BUILD_NAME(  '2', '2', '2', ' ' );
52
53      MPTEST.QUEUE_NAME( 1 ) := RTEMS.BUILD_NAME(  'M', 'S', 'G', ' ' );
54
55      MPTEST.SEMAPHORE_NAME( 1 ) := RTEMS.BUILD_NAME(  'S', 'E', 'M', ' ' );
56
57      if TEST_SUPPORT.NODE = 1 then
58
59         TEXT_IO.PUT_LINE( "Creating Message Queue (Global)" );
60         RTEMS.MESSAGE_QUEUE_CREATE(
61            MPTEST.QUEUE_NAME( 1 ),
62            3,
63            RTEMS.GLOBAL + RTEMS.LIMIT,
64            MPTEST.QUEUE_ID( 1 ),
65            STATUS
66         );
67         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "MESSAGE_QUEUE_CREATE" );
68
69         TEXT_IO.PUT_LINE( "Creating Semaphore (Global)" );
70         RTEMS.SEMAPHORE_CREATE(
71            MPTEST.SEMAPHORE_NAME( 1 ),
72            1,
73            RTEMS.GLOBAL + RTEMS.PRIORITY,
74            MPTEST.SEMAPHORE_ID( 1 ),
75            STATUS
76         );
77         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "SEMAPHORE_CREATE" );
78
79         RTEMS.SEMAPHORE_OBTAIN(
80            MPTEST.SEMAPHORE_ID( 1 ),
81            RTEMS.DEFAULT_OPTIONS,
82            RTEMS.NO_TIMEOUT,
83            STATUS
84         );
85         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "SEMAPHORE_OBTAIN" );
86
87      end if;
88
89      TEXT_IO.PUT_LINE( "Creating Test_task 1 (local)" );
90         RTEMS.TASK_CREATE(
91         MPTEST.TASK_NAME( 1 ),
92         1,
93         2048,
94         RTEMS.TIMESLICE,
95         RTEMS.DEFAULT_ATTRIBUTES,
96         MPTEST.TASK_ID( 1 ),
97         STATUS
98      );
99      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE" );
100
101      TEXT_IO.PUT_LINE( "Starting Test_task 1 (local)" );
102      RTEMS.TASK_START(
103         MPTEST.TASK_ID( 1 ),
104         MPTEST.TEST_TASK_1'ACCESS,
105         0,
106         STATUS
107      );
108      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START" );
109
110      TEXT_IO.PUT_LINE( "Creating Test_task 2 (local)" );
111      RTEMS.TASK_CREATE(
112         MPTEST.TASK_NAME( 2 ),
113         1,
114         2048,
115         RTEMS.TIMESLICE,
116         RTEMS.DEFAULT_ATTRIBUTES,
117         MPTEST.TASK_ID( 2 ),
118         STATUS
119      );
120      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE" );
121
122      TEXT_IO.PUT_LINE( "Starting Test_task 2 (local)" );
123      RTEMS.TASK_START(
124         MPTEST.TASK_ID( 2 ),
125         MPTEST.TEST_TASK_2'ACCESS,
126         0,
127         STATUS
128      );
129      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START" );
130
131      if TEST_SUPPORT.NODE = 1 then
132
133         RTEMS.TASK_WAKE_AFTER( 5 * TEST_SUPPORT.TICKS_PER_SECOND, STATUS );
134         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_WAKE_AFTER" );
135
136         TEXT_IO.PUT_LINE( "*** END OF TEST 13 ***" );
137
138         RTEMS.SHUTDOWN_EXECUTIVE( 0 );
139
140      end if;
141
142      TEXT_IO.PUT_LINE( "Deleting initialization task" );
143      RTEMS.TASK_DELETE( RTEMS.SELF, STATUS );
144      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_DELETE OF SELF" );
145
146   end INIT;
147
148--PAGE
149--
150--  TEST_TASK_1
151--
152
153   procedure TEST_TASK_1 (
154      ARGUMENT : in     RTEMS.TASK_ARGUMENT
155   ) is
156      COUNT               : RTEMS.UNSIGNED32;
157      RECEIVE_BUFFER_AREA : RTEMS.BUFFER;
158      RECEIVE_BUFFER      : RTEMS.BUFFER_POINTER;
159      STATUS              : RTEMS.STATUS_CODES;
160   begin
161
162      RECEIVE_BUFFER :=
163         RTEMS.TO_BUFFER_POINTER( RECEIVE_BUFFER_AREA'ADDRESS );
164
165      TEXT_IO.PUT_LINE( "Getting QID of message queue" );
166
167      loop
168
169         RTEMS.MESSAGE_QUEUE_IDENT(
170            MPTEST.QUEUE_NAME( 1 ),
171            RTEMS.SEARCH_ALL_NODES,
172            MPTEST.QUEUE_ID( 1 ),
173            STATUS
174         );
175
176         exit when RTEMS.IS_STATUS_SUCCESSFUL( STATUS );
177
178      end loop;
179
180      if TEST_SUPPORT.NODE = 1 then
181
182         TEXT_IO.PUT_LINE( "Receiving message ..." );
183         RTEMS.MESSAGE_QUEUE_RECEIVE(
184            MPTEST.QUEUE_ID( 1 ),
185            RECEIVE_BUFFER,
186            RTEMS.DEFAULT_OPTIONS,
187            RTEMS.NO_TIMEOUT,
188            STATUS
189         );
190         TEXT_IO.PUT_LINE( "How did I get back from here???" );
191         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "MESSAGE_QUEUE_RECEIVE" );
192
193      end if;
194
195      RTEMS.TASK_WAKE_AFTER( TEST_SUPPORT.TICKS_PER_SECOND, STATUS );
196      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_WAKE_AFTER" );
197
198      TEXT_IO.PUT_LINE( "Receiving message ..." );
199      RTEMS.MESSAGE_QUEUE_RECEIVE(
200         MPTEST.QUEUE_ID( 1 ),
201         RECEIVE_BUFFER,
202         RTEMS.DEFAULT_OPTIONS,
203         2 * TEST_SUPPORT.TICKS_PER_SECOND,
204         STATUS
205      );
206      TEST_SUPPORT.FATAL_DIRECTIVE_STATUS(
207         STATUS,
208         RTEMS.TIMEOUT,
209         "MESSAGE_QUEUE_RECEIVE"
210      );
211      TEST_SUPPORT.FATAL_DIRECTIVE_STATUS(
212         STATUS,
213         RTEMS.TIMEOUT,
214         "MESSAGE_QUEUE_OBTAIN"
215      );
216
217      TEXT_IO.PUT_LINE(
218         "message_queue_receive correctly returned TIMEOUT"
219      );
220
221      TEXT_IO.PUT_LINE( "Deleting self" );
222      RTEMS.TASK_DELETE( RTEMS.SELF, STATUS );
223      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_DELETE OF SELF" );
224
225   end TEST_TASK_1;
226
227--PAGE
228--
229--  TEST_TASK_2
230--
231
232   procedure TEST_TASK_2 (
233      ARGUMENT : in     RTEMS.TASK_ARGUMENT
234   ) is
235      STATUS : RTEMS.STATUS_CODES;
236   begin
237
238      TEXT_IO.PUT_LINE( "Getting SMID of semaphore" );
239
240      loop
241
242         RTEMS.SEMAPHORE_IDENT(
243            MPTEST.SEMAPHORE_NAME( 1 ),
244            RTEMS.SEARCH_ALL_NODES,
245            MPTEST.SEMAPHORE_ID( 1 ),
246            STATUS
247         );
248
249         exit when RTEMS.IS_STATUS_SUCCESSFUL( STATUS );
250
251      end loop;
252
253      if TEST_SUPPORT.NODE = 1 then
254
255         RTEMS.TASK_WAKE_AFTER( TEST_SUPPORT.TICKS_PER_SECOND, STATUS );
256         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_WAKE_AFTER" );
257
258         TEXT_IO.PUT_LINE( "Releasing semaphore ..." );
259         RTEMS.SEMAPHORE_RELEASE( MPTEST.SEMAPHORE_ID( 1 ), STATUS );
260         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "SEMAPHORE_RELEASE" );
261
262         RTEMS.TASK_WAKE_AFTER( TEST_SUPPORT.TICKS_PER_SECOND / 2, STATUS );
263         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_WAKE_AFTER" );
264
265         TEXT_IO.PUT_LINE( "Getting semaphore ..." );
266         RTEMS.SEMAPHORE_OBTAIN(
267            MPTEST.SEMAPHORE_ID( 1 ),
268            RTEMS.DEFAULT_OPTIONS,
269            RTEMS.NO_TIMEOUT,
270            STATUS
271         );
272         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "SEMAPHORE_OBTAIN" );
273
274         TEXT_IO.PUT_LINE( "Getting semaphore ..." );
275         RTEMS.SEMAPHORE_OBTAIN(
276            MPTEST.SEMAPHORE_ID( 1 ),
277            RTEMS.DEFAULT_OPTIONS,
278            RTEMS.NO_TIMEOUT,
279            STATUS
280         );
281         TEXT_IO.PUT_LINE( "How did I get back from here???" );
282         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "SEMAPHORE_OBTAIN" );
283
284      end if;
285
286      RTEMS.TASK_WAKE_AFTER( TEST_SUPPORT.TICKS_PER_SECOND / 2, STATUS );
287      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_WAKE_AFTER" );
288
289      TEXT_IO.PUT_LINE( "Getting semaphore ..." );
290      RTEMS.SEMAPHORE_OBTAIN(
291         MPTEST.SEMAPHORE_ID( 1 ),
292         RTEMS.DEFAULT_OPTIONS,
293         RTEMS.NO_TIMEOUT,
294         STATUS
295      );
296      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "SEMAPHORE_OBTAIN" );
297
298      TEXT_IO.PUT_LINE( "Releasing semaphore ..." );
299      RTEMS.SEMAPHORE_RELEASE( MPTEST.SEMAPHORE_ID( 1 ), STATUS );
300      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "SEMAPHORE_RELEASE" );
301
302      RTEMS.TASK_WAKE_AFTER( TEST_SUPPORT.TICKS_PER_SECOND, STATUS );
303      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_WAKE_AFTER" );
304
305      TEXT_IO.PUT_LINE( "Getting semaphore ..." );
306      RTEMS.SEMAPHORE_OBTAIN(
307         MPTEST.SEMAPHORE_ID( 1 ),
308         RTEMS.DEFAULT_OPTIONS,
309         2 * TEST_SUPPORT.TICKS_PER_SECOND,
310         STATUS
311      );
312      TEST_SUPPORT.FATAL_DIRECTIVE_STATUS(
313         STATUS,
314         RTEMS.TIMEOUT,
315         "SEMAPHORE_OBTAIN"
316      );
317      TEXT_IO.PUT_LINE( "semaphore_obtain correctly returned TIMEOUT" );
318
319      TEXT_IO.PUT_LINE( "*** END OF TEST 13 ***" );
320
321      RTEMS.SHUTDOWN_EXECUTIVE( 0 );
322
323   end TEST_TASK_2;
324
325end MPTEST;
Note: See TracBrowser for help on using the repository browser.