source: rtems/c/src/ada-tests/tmtests/tm11/tmtest.adb @ 9db72b4

4.104.114.84.95
Last change on this file since 9db72b4 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: 4.7 KB
Line 
1--
2--  TMTEST / BODY
3--
4--  DESCRIPTION:
5--
6--  This package is the implementation of Test 11 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--  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 RTEMS_CALLING_OVERHEAD;
27with TEST_SUPPORT;
28with TEXT_IO;
29with TIME_TEST_SUPPORT;
30with UNSIGNED32_IO;
31
32package body TMTEST is
33
34--PAGE
35--
36--  INIT
37--
38
39   procedure INIT (
40      ARGUMENT : in     RTEMS.TASK_ARGUMENT
41   ) is
42      TASK_ID : RTEMS.ID;
43      STATUS  : RTEMS.STATUS_CODES;
44   begin
45
46      TEXT_IO.NEW_LINE( 2 );
47      TEXT_IO.PUT_LINE( "*** TIME TEST 11 ***" );
48
49      RTEMS.TASK_CREATE(
50         1,
51         251,
52         1024,
53         RTEMS.DEFAULT_MODES,
54         RTEMS.DEFAULT_ATTRIBUTES,
55         TASK_ID,
56         STATUS
57      );
58      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE" );
59
60      RTEMS.TASK_START(
61         TASK_ID,
62         TMTEST.TEST_INIT'ACCESS,
63         0,
64         STATUS
65      );
66      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START" );
67
68      RTEMS.TASK_DELETE( RTEMS.SELF, STATUS );
69      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_DELETE OF SELF" );
70
71   end INIT;
72
73--PAGE
74--
75--  TEST_INIT
76--
77
78   procedure TEST_INIT (
79      ARGUMENT : in     RTEMS.TASK_ARGUMENT
80   ) is
81      INDEX          : RTEMS.UNSIGNED32;
82      TASK_ENTRY     : RTEMS.TASK_ENTRY_POINT;
83      PRIORITY       : RTEMS.TASK_PRIORITY;
84      TASK_ID        : RTEMS.ID;
85      BUFFER         : RTEMS.BUFFER;
86      BUFFER_POINTER : RTEMS.BUFFER_POINTER;
87      STATUS         : RTEMS.STATUS_CODES;
88   begin
89
90      BUFFER_POINTER := RTEMS.TO_BUFFER_POINTER( BUFFER'ADDRESS );
91
92-- As each task is started, it preempts this task and performs a blocking
93-- MESSAGE_QUEUE_RECEIVE.  Upon completion of this loop all created tasks
94-- are blocked.
95
96      RTEMS.MESSAGE_QUEUE_CREATE(
97         RTEMS.BUILD_NAME( 'M', 'Q', '1', ' ' ),
98         TIME_TEST_SUPPORT.OPERATION_COUNT,
99         RTEMS.DEFAULT_OPTIONS,
100         TMTEST.QUEUE_ID,
101         STATUS
102      );
103      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "MESSAGE_QUEUE_CREATE" );
104
105      PRIORITY := 250;
106
107      for INDEX in 0 .. TIME_TEST_SUPPORT.OPERATION_COUNT - 1
108      loop
109
110         RTEMS.TASK_CREATE(
111            RTEMS.BUILD_NAME( 'T', 'I', 'M', 'E' ),
112            PRIORITY,
113            1024,
114            RTEMS.DEFAULT_MODES,
115            RTEMS.DEFAULT_ATTRIBUTES,
116            TASK_ID,
117            STATUS
118         );
119         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE LOOP" );
120
121         PRIORITY := PRIORITY - 1;
122
123         if INDEX = TIME_TEST_SUPPORT.OPERATION_COUNT - 1 then
124            TASK_ENTRY := TMTEST.HIGH_TASK'ACCESS;
125         else
126            TASK_ENTRY := TMTEST.MIDDLE_TASKS'ACCESS;
127         end if;
128
129         RTEMS.TASK_START( TASK_ID, TASK_ENTRY, 0, STATUS );
130         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START LOOP" );
131
132      end loop;
133
134      TIMER_DRIVER.INITIALIZE;
135         RTEMS.MESSAGE_QUEUE_SEND(
136            TMTEST.QUEUE_ID,
137            BUFFER_POINTER,
138            STATUS
139         );
140
141   end TEST_INIT;
142
143--PAGE
144--
145--  HIGH_TASK
146--
147
148   procedure HIGH_TASK (
149      ARGUMENT : in     RTEMS.TASK_ARGUMENT
150   ) is
151      BUFFER         : RTEMS.BUFFER;
152      BUFFER_POINTER : RTEMS.BUFFER_POINTER;
153      STATUS         : RTEMS.STATUS_CODES;
154   begin
155
156      BUFFER_POINTER := RTEMS.TO_BUFFER_POINTER( BUFFER'ADDRESS );
157
158      RTEMS.MESSAGE_QUEUE_RECEIVE(
159         TMTEST.QUEUE_ID,
160         BUFFER_POINTER,
161         RTEMS.DEFAULT_OPTIONS,
162         RTEMS.NO_TIMEOUT,
163         STATUS
164      );
165
166      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
167
168      TIME_TEST_SUPPORT.PUT_TIME(
169         "MESSAGE_QUEUE_SEND (preemptive)",
170         TMTEST.END_TIME,
171         TIME_TEST_SUPPORT.OPERATION_COUNT,
172         0,
173         RTEMS_CALLING_OVERHEAD.MESSAGE_QUEUE_SEND
174      );
175
176      RTEMS.SHUTDOWN_EXECUTIVE( 0 );
177
178   end HIGH_TASK;
179
180--PAGE
181--
182--  MIDDLE_TASKS
183--
184
185   procedure MIDDLE_TASKS (
186      ARGUMENT : in     RTEMS.TASK_ARGUMENT
187   ) is
188      BUFFER         : RTEMS.BUFFER;
189      BUFFER_POINTER : RTEMS.BUFFER_POINTER;
190      STATUS         : RTEMS.STATUS_CODES;
191   begin
192 
193      BUFFER_POINTER := RTEMS.TO_BUFFER_POINTER( BUFFER'ADDRESS );
194
195      RTEMS.MESSAGE_QUEUE_RECEIVE(
196         TMTEST.QUEUE_ID,
197         BUFFER_POINTER,
198         RTEMS.DEFAULT_OPTIONS,
199         RTEMS.NO_TIMEOUT,
200         STATUS
201      );
202 
203      RTEMS.MESSAGE_QUEUE_SEND(
204         TMTEST.QUEUE_ID,
205         BUFFER_POINTER,
206         STATUS
207      );
208
209   end MIDDLE_TASKS;
210
211end TMTEST;
Note: See TracBrowser for help on using the repository browser.