source: rtems/c/src/ada-tests/tmtests/tm14/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.7 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, 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:46 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      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_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      RTEMS.MESSAGE_QUEUE_CREATE(
93         RTEMS.BUILD_NAME( 'M', 'Q', '1', ' ' ),
94         TIME_TEST_SUPPORT.OPERATION_COUNT,
95         RTEMS.DEFAULT_OPTIONS,
96         TMTEST.QUEUE_ID,
97         STATUS
98      );
99
100      PRIORITY := 250;
101
102      for INDEX in 0 .. TIME_TEST_SUPPORT.OPERATION_COUNT - 1
103      loop
104
105         RTEMS.TASK_CREATE(
106            RTEMS.BUILD_NAME( 'T', 'I', 'M', 'E' ),
107            PRIORITY,
108            1024,
109            RTEMS.DEFAULT_MODES,
110            RTEMS.DEFAULT_ATTRIBUTES,
111            TASK_ID,
112            STATUS
113         );
114         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE LOOP" );
115
116         PRIORITY := PRIORITY - 1;
117
118         if INDEX = TIME_TEST_SUPPORT.OPERATION_COUNT - 1 then
119            TASK_ENTRY := TMTEST.HIGH_TASK'ACCESS;
120         else
121            TASK_ENTRY := TMTEST.LOW_TASKS'ACCESS;
122         end if;
123
124         RTEMS.TASK_START( TASK_ID, TASK_ENTRY, 0, STATUS );
125         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START LOOP" );
126
127      end loop;
128
129      TIMER_DRIVER.INITIALIZE;
130      RTEMS.MESSAGE_QUEUE_URGENT(
131         TMTEST.QUEUE_ID,
132         BUFFER_POINTER,
133         STATUS
134      );
135
136   end TEST_INIT;
137
138--PAGE
139--
140--  HIGH_TASK
141--
142
143   procedure HIGH_TASK (
144      ARGUMENT : in     RTEMS.TASK_ARGUMENT
145   ) is
146      BUFFER         : RTEMS.BUFFER;
147      BUFFER_POINTER : RTEMS.BUFFER_POINTER;
148      OVERHEAD       : RTEMS.UNSIGNED32;
149      STATUS         : RTEMS.STATUS_CODES;
150   begin
151
152      BUFFER_POINTER := RTEMS.TO_BUFFER_POINTER( BUFFER'ADDRESS );
153
154      TIMER_DRIVER.INITIALIZE;
155         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
156         loop
157            TIMER_DRIVER.EMPTY_FUNCTION;
158         end loop;
159      OVERHEAD := TIMER_DRIVER.READ_TIMER;
160
161      for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
162      loop
163     
164         RTEMS.MESSAGE_QUEUE_URGENT(
165            TMTEST.QUEUE_ID,
166            BUFFER_POINTER,
167            STATUS
168         );
169
170      end loop;
171
172      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
173
174      TIME_TEST_SUPPORT.PUT_TIME(
175         "MESSAGE_QUEUE_URGENT (readying)",
176         TMTEST.END_TIME,
177         TIME_TEST_SUPPORT.OPERATION_COUNT,
178         OVERHEAD,
179         RTEMS_CALLING_OVERHEAD.MESSAGE_QUEUE_URGENT
180      );
181
182      RTEMS.SHUTDOWN_EXECUTIVE( 0 );
183
184   end HIGH_TASK;
185
186--PAGE
187--
188--  LOW_TASKS
189--
190
191   procedure LOW_TASKS (
192      ARGUMENT : in     RTEMS.TASK_ARGUMENT
193   ) is
194      BUFFER         : RTEMS.BUFFER;
195      BUFFER_POINTER : RTEMS.BUFFER_POINTER;
196      STATUS         : RTEMS.STATUS_CODES;
197   begin
198 
199      BUFFER_POINTER := RTEMS.TO_BUFFER_POINTER( BUFFER'ADDRESS );
200
201      RTEMS.MESSAGE_QUEUE_RECEIVE(
202         TMTEST.QUEUE_ID,
203         BUFFER_POINTER,
204         RTEMS.DEFAULT_OPTIONS,
205         RTEMS.NO_TIMEOUT,
206         STATUS
207      );
208 
209   end LOW_TASKS;
210
211end TMTEST;
Note: See TracBrowser for help on using the repository browser.