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

4.104.114.84.95
Last change on this file since 6d4e604b was 6d4e604b, checked in by Joel Sherrill <joel.sherrill@…>, on 06/02/97 at 20:19:03

Initial revision

  • Property mode set to 100644
File size: 4.9 KB
RevLine 
[6d4e604b]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, 1990, 1991, 1992, 1993, 1994.
14--  On-Line Applications Research Corporation (OAR).
15--  All rights assigned to U.S. Government, 1994.
16--
17--  This material may be reproduced by or for the U.S. Government pursuant
18--  to the copyright license under the clause at DFARS 252.227-7013.  This
19--  notice must appear in all copies of this file and its derivatives.
20--
21--  tmtest.adb,v 1.3 1995/07/12 19:43:32 joel Exp
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_POINT;
64      PRIORITY       : RTEMS.TASK_PRIORITY;
65      OVERHEAD       : RTEMS.UNSIGNED32;
66      TASK_ID        : RTEMS.ID;
67      BUFFER         : RTEMS.BUFFER;
68      BUFFER_POINTER : RTEMS.BUFFER_POINTER;
69      STATUS         : RTEMS.STATUS_CODES;
70   begin
71
72      BUFFER_POINTER := RTEMS.TO_BUFFER_POINTER( BUFFER'ADDRESS );
73
74      PRIORITY := 5;
75
76      for INDEX in 0 .. TIME_TEST_SUPPORT.OPERATION_COUNT
77      loop
78
79         RTEMS.TASK_CREATE(
80            RTEMS.BUILD_NAME( 'T', 'I', 'M', 'E' ),
81            PRIORITY,
82            1024,
83            RTEMS.DEFAULT_MODES,
84            RTEMS.DEFAULT_ATTRIBUTES,
85            TASK_ID,
86            STATUS
87         );
88         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE LOOP" );
89
90         PRIORITY := PRIORITY + 1;
91
92         if INDEX = 0 then
93            TASK_ENTRY := TMTEST.HIGH_TASK'ACCESS;
94         elsif INDEX = TIME_TEST_SUPPORT.OPERATION_COUNT then
95            TASK_ENTRY := TMTEST.LOW_TASK'ACCESS;
96         else
97            TASK_ENTRY := TMTEST.MIDDLE_TASKS'ACCESS;
98         end if;
99
100         RTEMS.TASK_START( TASK_ID, TASK_ENTRY, 0, STATUS );
101         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START LOOP" );
102
103      end loop;
104
105      RTEMS.MESSAGE_QUEUE_CREATE(
106         1,
107         TIME_TEST_SUPPORT.OPERATION_COUNT,
108         RTEMS.DEFAULT_OPTIONS,
109         TMTEST.QUEUE_ID,
110         STATUS
111      );
112
113      TIMER_DRIVER.INITIALIZE;
114         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
115         loop
116            TIMER_DRIVER.EMPTY_FUNCTION;
117         end loop;
118      OVERHEAD := TIMER_DRIVER.READ_TIMER;
119
120      TIMER_DRIVER.INITIALIZE;
121         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
122         loop
123            RTEMS.MESSAGE_QUEUE_RECEIVE(
124               TMTEST.QUEUE_ID,
125               BUFFER_POINTER,
126               RTEMS.NO_WAIT,
127               RTEMS.NO_TIMEOUT,
128               STATUS
129            );
130         end loop;
131      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
132      TIME_TEST_SUPPORT.PUT_TIME(
133         "MESSAGE_QUEUE_RECEIVE (NO_WAIT)",
134         TMTEST.END_TIME,
135         TIME_TEST_SUPPORT.OPERATION_COUNT,
136         OVERHEAD,
137         RTEMS_CALLING_OVERHEAD.MESSAGE_QUEUE_RECEIVE
138      );
139
140   end TEST_INIT;
141
142--PAGE
143--
144--  HIGH_TASK
145--
146
147   procedure HIGH_TASK (
148      ARGUMENT : in     RTEMS.TASK_ARGUMENT
149   ) is
150      BUFFER         : RTEMS.BUFFER;
151      BUFFER_POINTER : RTEMS.BUFFER_POINTER;
152      STATUS         : RTEMS.STATUS_CODES;
153   begin
154
155      BUFFER_POINTER := RTEMS.TO_BUFFER_POINTER( BUFFER'ADDRESS );
156
157      TIMER_DRIVER.INITIALIZE;
158
159      RTEMS.MESSAGE_QUEUE_RECEIVE(
160         TMTEST.QUEUE_ID,
161         BUFFER_POINTER,
162         RTEMS.DEFAULT_OPTIONS,
163         RTEMS.NO_TIMEOUT,
164         STATUS
165      );
166
167   end HIGH_TASK;
168
169--PAGE
170--
171--  MIDDLE_TASKS
172--
173
174   procedure MIDDLE_TASKS (
175      ARGUMENT : in     RTEMS.TASK_ARGUMENT
176   ) is
177      BUFFER         : RTEMS.BUFFER;
178      BUFFER_POINTER : RTEMS.BUFFER_POINTER;
179      STATUS         : RTEMS.STATUS_CODES;
180   begin
181 
182      BUFFER_POINTER := RTEMS.TO_BUFFER_POINTER( BUFFER'ADDRESS );
183
184      RTEMS.MESSAGE_QUEUE_RECEIVE(
185         TMTEST.QUEUE_ID,
186         BUFFER_POINTER,
187         RTEMS.DEFAULT_OPTIONS,
188         RTEMS.NO_TIMEOUT,
189         STATUS
190      );
191 
192   end MIDDLE_TASKS;
193
194--PAGE
195--
196--  LOW_TASK
197--
198
199   procedure LOW_TASK (
200      ARGUMENT : in     RTEMS.TASK_ARGUMENT
201   ) is
202      STATUS   : RTEMS.STATUS_CODES;
203   begin
204
205      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
206      TIME_TEST_SUPPORT.PUT_TIME(
207         "MESSAGE_QUEUE_RECEIVE (blocking)",
208         TMTEST.END_TIME,
209         TIME_TEST_SUPPORT.OPERATION_COUNT,
210         0,
211         RTEMS_CALLING_OVERHEAD.MESSAGE_QUEUE_RECEIVE
212      );
213
214      RTEMS.SHUTDOWN_EXECUTIVE( 0 );
215
216   end LOW_TASK;
217
218end TMTEST;
Note: See TracBrowser for help on using the repository browser.