source: rtems/c/src/ada-tests/tmtests/tm11/tmtest.adb @ a8e724d6

4.104.115
Last change on this file since a8e724d6 was a8e724d6, checked in by Joel Sherrill <joel.sherrill@…>, on 09/29/08 at 20:44:58

2008-09-29 Joel Sherrill <joel.sherrill@…>

  • support/timer_driver.adb, support/timer_driver.ads, tmtests/tm01/tmtest.adb, tmtests/tm02/tmtest.adb, tmtests/tm03/tmtest.adb, tmtests/tm04/tmtest.adb, tmtests/tm05/tmtest.adb, tmtests/tm06/tmtest.adb, tmtests/tm07/tmtest.adb, tmtests/tm08/tmtest.adb, tmtests/tm09/tmtest.adb, tmtests/tm10/tmtest.adb, tmtests/tm11/tmtest.adb, tmtests/tm12/tmtest.adb, tmtests/tm13/tmtest.adb, tmtests/tm14/tmtest.adb, tmtests/tm15/tmtest.adb, tmtests/tm16/tmtest.adb, tmtests/tm17/tmtest.adb, tmtests/tm18/tmtest.adb, tmtests/tm19/tmtest.adb, tmtests/tm20/config.h, tmtests/tm20/tmtest.adb, tmtests/tm21/tmtest.adb, tmtests/tm22/tmtest.adb, tmtests/tm23/tmtest.adb, tmtests/tm24/tmtest.adb, tmtests/tm25/tmtest.adb, tmtests/tm28/tmtest.adb, tmtests/tm29/tmtest.adb, tmtests/tmck/tmtest.adb, tmtests/tmoverhd/tmtest.adb: Clean up. Verified to run on psim with gcc 4.3.2.
  • 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 11 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.rtems.com/license/LICENSE.
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 11 ***" );
47
48      RTEMS.TASK_CREATE(
49         1,
50         251,
51         1024,
52         RTEMS.DEFAULT_MODES,
53         RTEMS.DEFAULT_ATTRIBUTES,
54         TASK_ID,
55         STATUS
56      );
57      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE" );
58
59      RTEMS.TASK_START(
60         TASK_ID,
61         TMTEST.TEST_INIT'ACCESS,
62         0,
63         STATUS
64      );
65      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START" );
66
67      RTEMS.TASK_DELETE( RTEMS.SELF, STATUS );
68      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_DELETE OF SELF" );
69
70   end INIT;
71
72--PAGE
73--
74--  TEST_INIT
75--
76
77   procedure TEST_INIT (
78      ARGUMENT : in     RTEMS.TASK_ARGUMENT
79   ) is
80      TASK_ENTRY     : RTEMS.TASK_ENTRY;
81      PRIORITY       : RTEMS.TASK_PRIORITY;
82      TASK_ID        : RTEMS.ID;
83      BUFFER         : TMTEST.BUFFER;
84      BUFFER_POINTER : RTEMS.ADDRESS;
85      STATUS         : RTEMS.STATUS_CODES;
86   begin
87
88      BUFFER_POINTER := BUFFER'ADDRESS;
89
90-- As each task is started, it preempts this task and performs a blocking
91-- MESSAGE_QUEUE_RECEIVE.  Upon completion of this loop all created tasks
92-- are blocked.
93
94      RTEMS.MESSAGE_QUEUE_CREATE(
95         RTEMS.BUILD_NAME( 'M', 'Q', '1', ' ' ),
96         TIME_TEST_SUPPORT.OPERATION_COUNT,
97         16,
98         RTEMS.DEFAULT_OPTIONS,
99         TMTEST.QUEUE_ID,
100         STATUS
101      );
102      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "MESSAGE_QUEUE_CREATE" );
103
104      PRIORITY := 250;
105
106      for INDEX in 0 .. TIME_TEST_SUPPORT.OPERATION_COUNT - 1
107      loop
108
109         RTEMS.TASK_CREATE(
110            RTEMS.BUILD_NAME( 'T', 'I', 'M', 'E' ),
111            PRIORITY,
112            1024,
113            RTEMS.DEFAULT_MODES,
114            RTEMS.DEFAULT_ATTRIBUTES,
115            TASK_ID,
116            STATUS
117         );
118         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE LOOP" );
119
120         PRIORITY := PRIORITY - 1;
121
122         if INDEX = TIME_TEST_SUPPORT.OPERATION_COUNT - 1 then
123            TASK_ENTRY := TMTEST.HIGH_TASK'ACCESS;
124         else
125            TASK_ENTRY := TMTEST.MIDDLE_TASKS'ACCESS;
126         end if;
127
128         RTEMS.TASK_START( TASK_ID, TASK_ENTRY, 0, STATUS );
129         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START LOOP" );
130
131      end loop;
132
133      TIMER_DRIVER.INITIALIZE;
134         RTEMS.MESSAGE_QUEUE_SEND(
135            TMTEST.QUEUE_ID,
136            BUFFER_POINTER,
137            16,
138            STATUS
139         );
140
141   end TEST_INIT;
142
143--PAGE
144--
145--  HIGH_TASK
146--
147
148   procedure HIGH_TASK (
149      ARGUMENT : in     RTEMS.TASK_ARGUMENT
150   ) is
151      BUFFER         : TMTEST.BUFFER;
152      BUFFER_POINTER : RTEMS.ADDRESS;
153      MESSAGE_SIZE   : RTEMS.UNSIGNED32;
154      STATUS         : RTEMS.STATUS_CODES;
155   begin
156
157      BUFFER_POINTER := BUFFER'ADDRESS;
158
159      RTEMS.MESSAGE_QUEUE_RECEIVE(
160         TMTEST.QUEUE_ID,
161         BUFFER_POINTER,
162         RTEMS.DEFAULT_OPTIONS,
163         RTEMS.NO_TIMEOUT,
164         MESSAGE_SIZE,
165         STATUS
166      );
167
168      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
169
170      TIME_TEST_SUPPORT.PUT_TIME(
171         "MESSAGE_QUEUE_SEND (preemptive)",
172         TMTEST.END_TIME,
173         TIME_TEST_SUPPORT.OPERATION_COUNT,
174         0,
175         RTEMS_CALLING_OVERHEAD.MESSAGE_QUEUE_SEND
176      );
177
178      TEXT_IO.PUT_LINE( "*** END OF TIME TEST 11 ***" );
179      RTEMS.SHUTDOWN_EXECUTIVE( 0 );
180
181   end HIGH_TASK;
182
183--PAGE
184--
185--  MIDDLE_TASKS
186--
187
188   procedure MIDDLE_TASKS (
189      ARGUMENT : in     RTEMS.TASK_ARGUMENT
190   ) is
191      BUFFER         : TMTEST.BUFFER;
192      BUFFER_POINTER : RTEMS.ADDRESS;
193      MESSAGE_SIZE   : RTEMS.UNSIGNED32;
194      STATUS         : RTEMS.STATUS_CODES;
195   begin
196 
197      BUFFER_POINTER := BUFFER'ADDRESS;
198
199      RTEMS.MESSAGE_QUEUE_RECEIVE(
200         TMTEST.QUEUE_ID,
201         BUFFER_POINTER,
202         RTEMS.DEFAULT_OPTIONS,
203         RTEMS.NO_TIMEOUT,
204         MESSAGE_SIZE,
205         STATUS
206      );
207 
208      RTEMS.MESSAGE_QUEUE_SEND(
209         TMTEST.QUEUE_ID,
210         BUFFER_POINTER,
211         16,
212         STATUS
213      );
214
215   end MIDDLE_TASKS;
216
217end TMTEST;
Note: See TracBrowser for help on using the repository browser.