source: rtems/c/src/ada-tests/tmtests/tm10/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 Jun 3, 1997 at 10:08:59 PM

Fixed calls to Message_Queue_Create to include maximum message size
parameter.

  • Property mode set to 100644
File size: 4.9 KB
Line 
1--
2--  TMTEST / BODY
3--
4--  DESCRIPTION:
5--
6--  This package is the implementation of Test 10 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      STATUS  : RTEMS.STATUS_CODES;
43   begin
44
45      TEXT_IO.NEW_LINE( 2 );
46      TEXT_IO.PUT_LINE( "*** TIME TEST 10 ***" );
47
48      TMTEST.TEST_INIT;
49
50      RTEMS.TASK_DELETE( RTEMS.SELF, STATUS );
51      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_DELETE OF SELF" );
52
53   end INIT;
54
55--PAGE
56--
57--  TEST_INIT
58--
59
60   procedure TEST_INIT
61   is
62      INDEX          : RTEMS.UNSIGNED32;
63      TASK_ENTRY     : RTEMS.TASK_ENTRY;
64      PRIORITY       : RTEMS.TASK_PRIORITY;
65      OVERHEAD       : RTEMS.UNSIGNED32;
66      TASK_ID        : RTEMS.ID;
67      BUFFER         : TMTEST.BUFFER;
68      BUFFER_POINTER : RTEMS.ADDRESS;
69      MESSAGE_SIZE   : RTEMS.UNSIGNED32;
70      STATUS         : RTEMS.STATUS_CODES;
71   begin
72
73      BUFFER_POINTER := BUFFER'ADDRESS;
74
75      PRIORITY := 5;
76
77      for INDEX in 0 .. TIME_TEST_SUPPORT.OPERATION_COUNT
78      loop
79
80         RTEMS.TASK_CREATE( 
81            RTEMS.BUILD_NAME( 'T', 'I', 'M', 'E' ),
82            PRIORITY, 
83            1024, 
84            RTEMS.DEFAULT_MODES,
85            RTEMS.DEFAULT_ATTRIBUTES,
86            TASK_ID,
87            STATUS
88         );
89         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE LOOP" );
90
91         PRIORITY := PRIORITY + 1;
92
93         if INDEX = 0 then
94            TASK_ENTRY := TMTEST.HIGH_TASK'ACCESS;
95         elsif INDEX = TIME_TEST_SUPPORT.OPERATION_COUNT then
96            TASK_ENTRY := TMTEST.LOW_TASK'ACCESS;
97         else
98            TASK_ENTRY := TMTEST.MIDDLE_TASKS'ACCESS;
99         end if;
100
101         RTEMS.TASK_START( TASK_ID, TASK_ENTRY, 0, STATUS );
102         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START LOOP" );
103
104      end loop;
105
106      RTEMS.MESSAGE_QUEUE_CREATE(
107         1,
108         TIME_TEST_SUPPORT.OPERATION_COUNT,
109         16,
110         RTEMS.DEFAULT_OPTIONS,
111         TMTEST.QUEUE_ID,
112         STATUS
113      );
114
115      TIMER_DRIVER.INITIALIZE;
116         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
117         loop
118            TIMER_DRIVER.EMPTY_FUNCTION;
119         end loop;
120      OVERHEAD := TIMER_DRIVER.READ_TIMER;
121
122      TIMER_DRIVER.INITIALIZE;
123         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
124         loop
125            RTEMS.MESSAGE_QUEUE_RECEIVE( 
126               TMTEST.QUEUE_ID,
127               BUFFER_POINTER,
128               RTEMS.NO_WAIT,
129               RTEMS.NO_TIMEOUT,
130               MESSAGE_SIZE,
131               STATUS
132            );
133         end loop;
134      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
135      TIME_TEST_SUPPORT.PUT_TIME(
136         "MESSAGE_QUEUE_RECEIVE (NO_WAIT)",
137         TMTEST.END_TIME, 
138         TIME_TEST_SUPPORT.OPERATION_COUNT, 
139         OVERHEAD,
140         RTEMS_CALLING_OVERHEAD.MESSAGE_QUEUE_RECEIVE
141      );
142
143   end TEST_INIT;
144
145--PAGE
146--
147--  HIGH_TASK
148--
149
150   procedure HIGH_TASK (
151      ARGUMENT : in     RTEMS.TASK_ARGUMENT
152   ) is
153      BUFFER         : TMTEST.BUFFER;
154      BUFFER_POINTER : RTEMS.ADDRESS;
155      MESSAGE_SIZE   : RTEMS.UNSIGNED32;
156      STATUS         : RTEMS.STATUS_CODES;
157   begin
158
159      BUFFER_POINTER := BUFFER'ADDRESS;
160
161      TIMER_DRIVER.INITIALIZE;
162
163      RTEMS.MESSAGE_QUEUE_RECEIVE( 
164         TMTEST.QUEUE_ID,
165         BUFFER_POINTER,
166         RTEMS.DEFAULT_OPTIONS,
167         RTEMS.NO_TIMEOUT,
168         MESSAGE_SIZE,
169         STATUS
170      );
171
172   end HIGH_TASK;
173
174--PAGE
175--
176--  MIDDLE_TASKS
177--
178
179   procedure MIDDLE_TASKS (
180      ARGUMENT : in     RTEMS.TASK_ARGUMENT
181   ) is
182      BUFFER         : TMTEST.BUFFER;
183      BUFFER_POINTER : RTEMS.ADDRESS;
184      MESSAGE_SIZE   : RTEMS.UNSIGNED32;
185      STATUS         : RTEMS.STATUS_CODES;
186   begin
187 
188      BUFFER_POINTER := BUFFER'ADDRESS;
189
190      RTEMS.MESSAGE_QUEUE_RECEIVE( 
191         TMTEST.QUEUE_ID,
192         BUFFER_POINTER,
193         RTEMS.DEFAULT_OPTIONS,
194         RTEMS.NO_TIMEOUT,
195         MESSAGE_SIZE,
196         STATUS
197      );
198 
199   end MIDDLE_TASKS;
200
201--PAGE
202--
203--  LOW_TASK
204--
205
206   procedure LOW_TASK (
207      ARGUMENT : in     RTEMS.TASK_ARGUMENT
208   ) is
209      STATUS   : RTEMS.STATUS_CODES;
210   begin
211
212      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
213      TIME_TEST_SUPPORT.PUT_TIME(
214         "MESSAGE_QUEUE_RECEIVE (blocking)",
215         TMTEST.END_TIME, 
216         TIME_TEST_SUPPORT.OPERATION_COUNT, 
217         0,
218         RTEMS_CALLING_OVERHEAD.MESSAGE_QUEUE_RECEIVE
219      );
220
221      RTEMS.SHUTDOWN_EXECUTIVE( 0 );
222
223   end LOW_TASK;
224
225end TMTEST;
Note: See TracBrowser for help on using the repository browser.