source: rtems/c/src/ada-tests/tmtests/tm14/tmtest.adb @ d0d73ec

4.104.114.84.95
Last change on this file since d0d73ec was 688ecaa0, checked in by Joel Sherrill <joel.sherrill@…>, on 06/03/97 at 22:08:59

Fixed calls to Message_Queue_Create to include maximum message size
parameter.

  • Property mode set to 100644
File size: 4.6 KB
Line 
1--
2--  TMTEST / BODY
3--
4--  DESCRIPTION:
5--
6--  This package is the implementation of Test 14 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 14 ***" );
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;
83      PRIORITY       : RTEMS.TASK_PRIORITY;
84      TASK_ID        : RTEMS.ID;
85      BUFFER         : TMTEST.BUFFER;
86      BUFFER_POINTER : RTEMS.ADDRESS;
87      STATUS         : RTEMS.STATUS_CODES;
88   begin
89
90      BUFFER_POINTER := BUFFER'ADDRESS;
91
92      RTEMS.MESSAGE_QUEUE_CREATE(
93         RTEMS.BUILD_NAME( 'M', 'Q', '1', ' ' ),
94         TIME_TEST_SUPPORT.OPERATION_COUNT,
95         16,
96         RTEMS.DEFAULT_OPTIONS,
97         TMTEST.QUEUE_ID,
98         STATUS
99      );
100
101      PRIORITY := 250;
102
103      for INDEX in 0 .. TIME_TEST_SUPPORT.OPERATION_COUNT - 1
104      loop
105
106         RTEMS.TASK_CREATE(
107            RTEMS.BUILD_NAME( 'T', 'I', 'M', 'E' ),
108            PRIORITY,
109            1024,
110            RTEMS.DEFAULT_MODES,
111            RTEMS.DEFAULT_ATTRIBUTES,
112            TASK_ID,
113            STATUS
114         );
115         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE LOOP" );
116
117         PRIORITY := PRIORITY - 1;
118
119         if INDEX = TIME_TEST_SUPPORT.OPERATION_COUNT - 1 then
120            TASK_ENTRY := TMTEST.HIGH_TASK'ACCESS;
121         else
122            TASK_ENTRY := TMTEST.LOW_TASKS'ACCESS;
123         end if;
124
125         RTEMS.TASK_START( TASK_ID, TASK_ENTRY, 0, STATUS );
126         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START LOOP" );
127
128      end loop;
129
130      TIMER_DRIVER.INITIALIZE;
131      RTEMS.MESSAGE_QUEUE_URGENT(
132         TMTEST.QUEUE_ID,
133         BUFFER_POINTER,
134         16,
135         STATUS
136      );
137
138   end TEST_INIT;
139
140--PAGE
141--
142--  HIGH_TASK
143--
144
145   procedure HIGH_TASK (
146      ARGUMENT : in     RTEMS.TASK_ARGUMENT
147   ) is
148      BUFFER         : TMTEST.BUFFER;
149      BUFFER_POINTER : RTEMS.ADDRESS;
150      OVERHEAD       : RTEMS.UNSIGNED32;
151      STATUS         : RTEMS.STATUS_CODES;
152   begin
153
154      BUFFER_POINTER := BUFFER'ADDRESS;
155
156      TIMER_DRIVER.INITIALIZE;
157         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
158         loop
159            TIMER_DRIVER.EMPTY_FUNCTION;
160         end loop;
161      OVERHEAD := TIMER_DRIVER.READ_TIMER;
162
163      for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
164      loop
165     
166         RTEMS.MESSAGE_QUEUE_URGENT(
167            TMTEST.QUEUE_ID,
168            BUFFER_POINTER,
169            16,
170            STATUS
171         );
172
173      end loop;
174
175      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
176
177      TIME_TEST_SUPPORT.PUT_TIME(
178         "MESSAGE_QUEUE_URGENT (readying)",
179         TMTEST.END_TIME,
180         TIME_TEST_SUPPORT.OPERATION_COUNT,
181         OVERHEAD,
182         RTEMS_CALLING_OVERHEAD.MESSAGE_QUEUE_URGENT
183      );
184
185      RTEMS.SHUTDOWN_EXECUTIVE( 0 );
186
187   end HIGH_TASK;
188
189--PAGE
190--
191--  LOW_TASKS
192--
193
194   procedure LOW_TASKS (
195      ARGUMENT : in     RTEMS.TASK_ARGUMENT
196   ) is
197      BUFFER         : TMTEST.BUFFER;
198      BUFFER_POINTER : RTEMS.ADDRESS;
199      MESSAGE_SIZE   : RTEMS.UNSIGNED32;
200      STATUS         : RTEMS.STATUS_CODES;
201   begin
202 
203      BUFFER_POINTER := BUFFER'ADDRESS;
204
205      RTEMS.MESSAGE_QUEUE_RECEIVE(
206         TMTEST.QUEUE_ID,
207         BUFFER_POINTER,
208         RTEMS.DEFAULT_OPTIONS,
209         RTEMS.NO_TIMEOUT,
210         MESSAGE_SIZE,
211         STATUS
212      );
213 
214   end LOW_TASKS;
215
216end TMTEST;
Note: See TracBrowser for help on using the repository browser.