source: rtems/c/src/ada-tests/tmtests/tm10/tmtest.adb @ e17ffea

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

Changed to variable length messages.

  • 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         RTEMS.DEFAULT_OPTIONS,
110         TMTEST.QUEUE_ID,
111         STATUS
112      );
113
114      TIMER_DRIVER.INITIALIZE;
115         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
116         loop
117            TIMER_DRIVER.EMPTY_FUNCTION;
118         end loop;
119      OVERHEAD := TIMER_DRIVER.READ_TIMER;
120
121      TIMER_DRIVER.INITIALIZE;
122         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
123         loop
124            RTEMS.MESSAGE_QUEUE_RECEIVE(
125               TMTEST.QUEUE_ID,
126               BUFFER_POINTER,
127               RTEMS.NO_WAIT,
128               RTEMS.NO_TIMEOUT,
129               MESSAGE_SIZE,
130               STATUS
131            );
132         end loop;
133      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
134      TIME_TEST_SUPPORT.PUT_TIME(
135         "MESSAGE_QUEUE_RECEIVE (NO_WAIT)",
136         TMTEST.END_TIME,
137         TIME_TEST_SUPPORT.OPERATION_COUNT,
138         OVERHEAD,
139         RTEMS_CALLING_OVERHEAD.MESSAGE_QUEUE_RECEIVE
140      );
141
142   end TEST_INIT;
143
144--PAGE
145--
146--  HIGH_TASK
147--
148
149   procedure HIGH_TASK (
150      ARGUMENT : in     RTEMS.TASK_ARGUMENT
151   ) is
152      BUFFER         : TMTEST.BUFFER;
153      BUFFER_POINTER : RTEMS.ADDRESS;
154      MESSAGE_SIZE   : RTEMS.UNSIGNED32;
155      STATUS         : RTEMS.STATUS_CODES;
156   begin
157
158      BUFFER_POINTER := BUFFER'ADDRESS;
159
160      TIMER_DRIVER.INITIALIZE;
161
162      RTEMS.MESSAGE_QUEUE_RECEIVE(
163         TMTEST.QUEUE_ID,
164         BUFFER_POINTER,
165         RTEMS.DEFAULT_OPTIONS,
166         RTEMS.NO_TIMEOUT,
167         MESSAGE_SIZE,
168         STATUS
169      );
170
171   end HIGH_TASK;
172
173--PAGE
174--
175--  MIDDLE_TASKS
176--
177
178   procedure MIDDLE_TASKS (
179      ARGUMENT : in     RTEMS.TASK_ARGUMENT
180   ) is
181      BUFFER         : TMTEST.BUFFER;
182      BUFFER_POINTER : RTEMS.ADDRESS;
183      MESSAGE_SIZE   : RTEMS.UNSIGNED32;
184      STATUS         : RTEMS.STATUS_CODES;
185   begin
186 
187      BUFFER_POINTER := BUFFER'ADDRESS;
188
189      RTEMS.MESSAGE_QUEUE_RECEIVE(
190         TMTEST.QUEUE_ID,
191         BUFFER_POINTER,
192         RTEMS.DEFAULT_OPTIONS,
193         RTEMS.NO_TIMEOUT,
194         MESSAGE_SIZE,
195         STATUS
196      );
197 
198   end MIDDLE_TASKS;
199
200--PAGE
201--
202--  LOW_TASK
203--
204
205   procedure LOW_TASK (
206      ARGUMENT : in     RTEMS.TASK_ARGUMENT
207   ) is
208      STATUS   : RTEMS.STATUS_CODES;
209   begin
210
211      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
212      TIME_TEST_SUPPORT.PUT_TIME(
213         "MESSAGE_QUEUE_RECEIVE (blocking)",
214         TMTEST.END_TIME,
215         TIME_TEST_SUPPORT.OPERATION_COUNT,
216         0,
217         RTEMS_CALLING_OVERHEAD.MESSAGE_QUEUE_RECEIVE
218      );
219
220      RTEMS.SHUTDOWN_EXECUTIVE( 0 );
221
222   end LOW_TASK;
223
224end TMTEST;
Note: See TracBrowser for help on using the repository browser.