source: rtems/c/src/ada-tests/tmtests/tm15/tmtest.adb @ 3c0534a

4.104.114.84.95
Last change on this file since 3c0534a was 3c0534a, checked in by Joel Sherrill <joel.sherrill@…>, on 08/20/03 at 16:02:19

2003-08-20 Joel Sherrill <joel@…>

  • mptests/mp01/config.h, mptests/mp01/mp01.adb, mptests/mp01/mptest.adb, mptests/mp01/mptest.ads, mptests/mp02/mptest.adb, mptests/mp02/mptest.ads, mptests/mp03/mptest.adb, mptests/mp03/mptest.ads, mptests/mp04/mptest.adb, mptests/mp04/mptest.ads, mptests/mp05/mptest.adb, mptests/mp05/mptest.ads, mptests/mp06/mptest.adb, mptests/mp06/mptest.ads, mptests/mp07/mptest.adb, mptests/mp07/mptest.ads, mptests/mp08/mptest.adb, mptests/mp08/mptest.ads, mptests/mp09/mptest.adb, mptests/mp09/mptest.ads, mptests/mp10/mptest.adb, mptests/mp10/mptest.ads, mptests/mp11/mptest.adb, mptests/mp11/mptest.ads, mptests/mp12/mptest.adb, mptests/mp12/mptest.ads, mptests/mp13/mptest.adb, mptests/mp13/mptest.ads, mptests/mp14/mptest.adb, mptests/mp14/mptest.ads, samples/base_mp/mptest.adb, samples/base_mp/mptest.ads, samples/base_sp/base_sp.adb, samples/base_sp/config.h, samples/base_sp/sptest.adb, samples/base_sp/sptest.ads, samples/hello/config.h, samples/hello/hello.adb, samples/hello/sptest.adb, samples/hello/sptest.ads, samples/ticker/config.h, samples/ticker/sptest.adb, samples/ticker/sptest.ads, samples/ticker/ticker.adb, sptests/sp01/config.h, sptests/sp01/sp01.adb, sptests/sp01/sptest.adb, sptests/sp01/sptest.ads, sptests/sp02/config.h, sptests/sp02/sp02.adb, sptests/sp02/sptest.adb, sptests/sp02/sptest.ads, sptests/sp03/config.h, sptests/sp03/sp03.adb, sptests/sp03/sptest.adb, sptests/sp03/sptest.ads, sptests/sp04/config.h, sptests/sp04/sp04.adb, sptests/sp04/sptest.adb, sptests/sp04/sptest.ads, sptests/sp05/config.h, sptests/sp05/sp05.adb, sptests/sp05/sptest.adb, sptests/sp05/sptest.ads, sptests/sp06/config.h, sptests/sp06/sp06.adb, sptests/sp06/sptest.adb, sptests/sp06/sptest.ads, sptests/sp07/config.h, sptests/sp07/sp07.adb, sptests/sp07/sptest.adb, sptests/sp07/sptest.ads, sptests/sp08/config.h, sptests/sp08/sp08.adb, sptests/sp08/sptest.adb, sptests/sp08/sptest.ads, sptests/sp09/config.h, sptests/sp09/sp09.adb, sptests/sp09/sptest.adb, sptests/sp09/sptest.ads, sptests/sp11/config.h, sptests/sp11/sp11.adb, sptests/sp11/sptest.adb, sptests/sp11/sptest.ads, sptests/sp12/config.h, sptests/sp12/sp12.adb, sptests/sp12/sptest.adb, sptests/sp12/sptest.ads, sptests/sp13/config.h, sptests/sp13/sp13.adb, sptests/sp13/sptest.adb, sptests/sp13/sptest.ads, sptests/sp14/config.h, sptests/sp14/sp14.adb, sptests/sp14/sptest.adb, sptests/sp14/sptest.ads, sptests/sp15/config.h, sptests/sp15/sp15.adb, sptests/sp15/sptest.adb, sptests/sp15/sptest.ads, sptests/sp16/config.h, sptests/sp16/sp16.adb, sptests/sp16/sptest.adb, sptests/sp16/sptest.ads, sptests/sp17/config.h, sptests/sp17/sp17.adb, sptests/sp17/sptest.adb, sptests/sp17/sptest.ads, sptests/sp19/config.h, sptests/sp19/sp19.adb, sptests/sp19/sptest.ads, sptests/sp20/config.h, sptests/sp20/sp20.adb, sptests/sp20/sptest.adb, sptests/sp20/sptest.ads, sptests/sp21/config.h, sptests/sp21/sp21.adb, sptests/sp21/sptest.adb, sptests/sp21/sptest.ads, sptests/sp22/config.h, sptests/sp22/sp22.adb, sptests/sp22/sptest.adb, sptests/sp22/sptest.ads, sptests/sp23/config.h, sptests/sp23/sp23.adb, sptests/sp23/sptest.adb, sptests/sp23/sptest.ads, sptests/sp24/config.h, sptests/sp24/sp24.adb, sptests/sp24/sptest.adb, sptests/sp24/sptest.ads, sptests/sp25/config.h, sptests/sp25/sp25.adb, sptests/sp25/sptest.adb, sptests/sp25/sptest.ads, sptests/spsize/spsize.adb, sptests/spsize/sptest.adb, sptests/spsize/sptest.ads, support/address_io.adb, support/address_io.ads, support/float_io.ads, support/fp.inc, support/integer.inc, support/rtems_calling_overhead.ads, support/status_io.ads, support/test_support.adb, support/test_support.ads, support/time_test_support.adb, support/time_test_support.ads, support/timer_driver.adb, support/timer_driver.ads, support/unsigned32_io.ads, tmtests/tm01/config.h, tmtests/tm01/tm01.adb, tmtests/tm01/tmtest.adb, tmtests/tm01/tmtest.ads, tmtests/tm02/config.h, tmtests/tm02/tm02.adb, tmtests/tm02/tmtest.adb, tmtests/tm02/tmtest.ads, tmtests/tm03/config.h, tmtests/tm03/tm03.adb, tmtests/tm03/tmtest.adb, tmtests/tm03/tmtest.ads, tmtests/tm04/config.h, tmtests/tm04/tm04.adb, tmtests/tm04/tmtest.adb, tmtests/tm04/tmtest.ads, tmtests/tm05/config.h, tmtests/tm05/tm05.adb, tmtests/tm05/tmtest.adb, tmtests/tm05/tmtest.ads, tmtests/tm06/config.h, tmtests/tm06/tm06.adb, tmtests/tm06/tmtest.adb, tmtests/tm06/tmtest.ads, tmtests/tm07/config.h, tmtests/tm07/tm07.adb, tmtests/tm07/tmtest.adb, tmtests/tm07/tmtest.ads, tmtests/tm08/config.h, tmtests/tm08/tm08.adb, tmtests/tm08/tmtest.adb, tmtests/tm08/tmtest.ads, tmtests/tm09/config.h, tmtests/tm09/tm09.adb, tmtests/tm09/tmtest.adb, tmtests/tm09/tmtest.ads, tmtests/tm10/config.h, tmtests/tm10/tm10.adb, tmtests/tm10/tmtest.adb, tmtests/tm10/tmtest.ads, tmtests/tm11/config.h, tmtests/tm11/tm11.adb, tmtests/tm11/tmtest.adb, tmtests/tm11/tmtest.ads, tmtests/tm12/config.h, tmtests/tm12/tm12.adb, tmtests/tm12/tmtest.adb, tmtests/tm12/tmtest.ads, tmtests/tm13/config.h, tmtests/tm13/tm13.adb, tmtests/tm13/tmtest.adb, tmtests/tm13/tmtest.ads, tmtests/tm14/config.h, tmtests/tm14/tm14.adb, tmtests/tm14/tmtest.adb, tmtests/tm14/tmtest.ads, tmtests/tm15/config.h, tmtests/tm15/tm15.adb, tmtests/tm15/tmtest.adb, tmtests/tm15/tmtest.ads, tmtests/tm16/config.h, tmtests/tm16/tm16.adb, tmtests/tm16/tmtest.adb, tmtests/tm16/tmtest.ads, tmtests/tm17/config.h, tmtests/tm17/tm17.adb, tmtests/tm17/tmtest.adb, tmtests/tm17/tmtest.ads, tmtests/tm18/config.h, tmtests/tm18/tm18.adb, tmtests/tm18/tmtest.adb, tmtests/tm18/tmtest.ads, tmtests/tm19/config.h, tmtests/tm19/tm19.adb, tmtests/tm19/tmtest.adb, tmtests/tm19/tmtest.ads, tmtests/tm20/config.h, tmtests/tm20/tm20.adb, tmtests/tm20/tmtest.adb, tmtests/tm20/tmtest.ads, tmtests/tm21/config.h, tmtests/tm21/tm21.adb, tmtests/tm21/tmtest.adb, tmtests/tm21/tmtest.ads, tmtests/tm22/config.h, tmtests/tm22/tm22.adb, tmtests/tm22/tmtest.adb, tmtests/tm22/tmtest.ads, tmtests/tm23/config.h, tmtests/tm23/tm23.adb, tmtests/tm23/tmtest.adb, tmtests/tm23/tmtest.ads, tmtests/tm24/config.h, tmtests/tm24/tm24.adb, tmtests/tm24/tmtest.adb, tmtests/tm24/tmtest.ads, tmtests/tm25/config.h, tmtests/tm25/tm25.adb, tmtests/tm25/tmtest.adb, tmtests/tm25/tmtest.ads, tmtests/tm28/config.h, tmtests/tm28/tm28.adb, tmtests/tm28/tmtest.adb, tmtests/tm28/tmtest.ads, tmtests/tm29/config.h, tmtests/tm29/tm29.adb, tmtests/tm29/tmtest.adb, tmtests/tm29/tmtest.ads, tmtests/tmck/config.h, tmtests/tmck/tmck.adb, tmtests/tmck/tmtest.adb, tmtests/tmck/tmtest.ads, tmtests/tmoverhd/config.h, tmtests/tmoverhd/dummy_rtems.adb, tmtests/tmoverhd/dummy_rtems.ads, tmtests/tmoverhd/tmoverhd.adb, tmtests/tmoverhd/tmtest.adb, tmtests/tmoverhd/tmtest.ads: Correct copyright statements.
  • Property mode set to 100644
File size: 6.3 KB
Line 
1--
2--  TMTEST / BODY
3--
4--  DESCRIPTION:
5--
6--  This package is the implementation of Test 15 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--
16--  The license and distribution terms for this file may in
17--  the file LICENSE in this distribution or at
18--  http://www.OARcorp.com/rtems/license.html.
19--
20--  $Id$
21--
22
23with INTERFACES; use INTERFACES;
24with RTEMS;
25with RTEMS_CALLING_OVERHEAD;
26with TEST_SUPPORT;
27with TEXT_IO;
28with TIME_TEST_SUPPORT;
29with UNSIGNED32_IO;
30
31package body TMTEST is
32
33--PAGE
34--
35--  INIT
36--
37
38   procedure INIT (
39      ARGUMENT : in     RTEMS.TASK_ARGUMENT
40   ) is
41      TASK_ID : RTEMS.ID;
42      STATUS  : RTEMS.STATUS_CODES;
43   begin
44
45      TEXT_IO.NEW_LINE( 2 );
46      TEXT_IO.PUT_LINE( "*** TIME TEST 15 ***" );
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      ID        : RTEMS.ID;
63      INDEX     : RTEMS.UNSIGNED32;
64      OVERHEAD  : RTEMS.UNSIGNED32;
65      EVENT_OUT : RTEMS.EVENT_SET;
66      STATUS    : RTEMS.STATUS_CODES;
67   begin
68
69      TMTEST.TIME_SET := FALSE;
70
71      RTEMS.TASK_CREATE(
72         RTEMS.BUILD_NAME( 'L', 'O', 'W', ' ' ),
73         10,
74         1024,
75         RTEMS.NO_PREEMPT,
76         RTEMS.DEFAULT_ATTRIBUTES,
77         ID,
78         STATUS
79      );
80      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE LOW" );
81
82      RTEMS.TASK_START( ID, TMTEST.LOW_TASK'ACCESS, 0, STATUS );
83      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START LOW" );
84
85      for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
86      loop
87
88         RTEMS.TASK_CREATE(
89            RTEMS.BUILD_NAME( 'H', 'I', 'G', 'H' ),
90            5,
91            1024,
92            RTEMS.DEFAULT_MODES,
93            RTEMS.DEFAULT_ATTRIBUTES,
94            TMTEST.TASK_ID( INDEX ),
95            STATUS
96         );
97         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE LOOP" );
98
99         RTEMS.TASK_START(
100            TMTEST.TASK_ID( INDEX ),
101            TMTEST.HIGH_TASKS'ACCESS,
102            0,
103            STATUS
104         );
105         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START LOOP" );
106
107      end loop;
108
109      TIMER_DRIVER.INITIALIZE;
110         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
111         loop
112            TIMER_DRIVER.EMPTY_FUNCTION;
113         end loop;
114      OVERHEAD := TIMER_DRIVER.READ_TIMER;
115
116      TIMER_DRIVER.INITIALIZE;
117         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
118         loop
119            RTEMS.EVENT_RECEIVE(
120               RTEMS.PENDING_EVENTS,
121               RTEMS.DEFAULT_OPTIONS,
122               RTEMS.NO_TIMEOUT,
123               EVENT_OUT,
124               STATUS
125            );
126         end loop;
127      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
128
129      TIME_TEST_SUPPORT.PUT_TIME(
130         "EVENT_RECEIVE (current)",
131         TMTEST.END_TIME,
132         TIME_TEST_SUPPORT.OPERATION_COUNT,
133         OVERHEAD,
134         RTEMS_CALLING_OVERHEAD.EVENT_RECEIVE
135      );
136
137      TIMER_DRIVER.INITIALIZE;
138         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
139         loop
140            RTEMS.EVENT_RECEIVE(
141               RTEMS.ALL_EVENTS,
142               RTEMS.NO_WAIT,
143               RTEMS.NO_TIMEOUT,
144               EVENT_OUT,
145               STATUS
146            );
147         end loop;
148      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
149
150      TIME_TEST_SUPPORT.PUT_TIME(
151         "EVENT_RECEIVE (NO_WAIT)",
152         TMTEST.END_TIME,
153         TIME_TEST_SUPPORT.OPERATION_COUNT,
154         OVERHEAD,
155         RTEMS_CALLING_OVERHEAD.EVENT_RECEIVE
156      );
157
158   end TEST_INIT;
159
160--PAGE
161--
162--  LOW_TASK
163--
164
165   procedure LOW_TASK (
166      ARGUMENT : in     RTEMS.TASK_ARGUMENT
167   ) is
168      ID        : RTEMS.ID;
169      INDEX     : RTEMS.UNSIGNED32;
170      EVENT_OUT : RTEMS.EVENT_SET;
171      OVERHEAD  : RTEMS.UNSIGNED32;
172      STATUS    : RTEMS.STATUS_CODES;
173   begin
174   
175      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
176
177      TIME_TEST_SUPPORT.PUT_TIME(
178         "EVENT_RECEIVE (blocking)",
179         TMTEST.END_TIME,
180         TIME_TEST_SUPPORT.OPERATION_COUNT,
181         0,
182         RTEMS_CALLING_OVERHEAD.EVENT_RECEIVE
183      );
184
185      TIMER_DRIVER.INITIALIZE;
186         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
187         loop
188            TIMER_DRIVER.EMPTY_FUNCTION;
189         end loop;
190      OVERHEAD := TIMER_DRIVER.READ_TIMER;
191
192      TIMER_DRIVER.INITIALIZE;
193         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
194         loop
195            RTEMS.EVENT_SEND( RTEMS.SELF, RTEMS.EVENT_16, STATUS );
196         end loop;
197      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
198
199      TIME_TEST_SUPPORT.PUT_TIME(
200         "EVENT_SEND (returns to caller)",
201         TMTEST.END_TIME,
202         TIME_TEST_SUPPORT.OPERATION_COUNT,
203         OVERHEAD,
204         RTEMS_CALLING_OVERHEAD.EVENT_SEND
205      );
206
207      TIMER_DRIVER.INITIALIZE;
208         RTEMS.EVENT_RECEIVE(
209            RTEMS.EVENT_16,
210            RTEMS.DEFAULT_OPTIONS,
211            RTEMS.NO_TIMEOUT,
212            EVENT_OUT,
213            STATUS
214         );
215      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
216
217      TIME_TEST_SUPPORT.PUT_TIME(
218         "EVENT_RECEIVE (available)",
219         TMTEST.END_TIME,
220         1,
221         0,
222         RTEMS_CALLING_OVERHEAD.EVENT_RECEIVE
223      );
224
225      TIMER_DRIVER.INITIALIZE;
226         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
227         loop
228            RTEMS.EVENT_SEND(
229               TMTEST.TASK_ID( INDEX ),
230               RTEMS.EVENT_16,
231               STATUS
232            );
233         end loop;
234      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
235
236      TIME_TEST_SUPPORT.PUT_TIME(
237         "EVENT_SEND (readying)",
238         TMTEST.END_TIME,
239         TIME_TEST_SUPPORT.OPERATION_COUNT,
240         OVERHEAD,
241         RTEMS_CALLING_OVERHEAD.EVENT_SEND
242      );
243
244      RTEMS.SHUTDOWN_EXECUTIVE( 0 );
245
246   end LOW_TASK;
247
248--PAGE
249--
250--  HIGH_TASKS
251--
252
253   procedure HIGH_TASKS (
254      ARGUMENT : in     RTEMS.TASK_ARGUMENT
255   ) is
256      EVENT_OUT : RTEMS.EVENT_SET;
257      STATUS    : RTEMS.STATUS_CODES;
258   begin
259
260      if TMTEST.TIME_SET = FALSE then
261         TMTEST.TIME_SET := TRUE;
262         TIMER_DRIVER.INITIALIZE;
263      end if;
264
265      RTEMS.EVENT_RECEIVE(
266         16#7FFFFFFF#,
267         RTEMS.DEFAULT_OPTIONS,
268         RTEMS.NO_TIMEOUT,
269         EVENT_OUT,
270         STATUS
271      );
272   
273   end HIGH_TASKS;
274
275end TMTEST;
Note: See TracBrowser for help on using the repository browser.