source: rtems/testsuites/ada/tmtests/tm11/tmtest.adb @ f6c9334d

Last change on this file since f6c9334d was f6c9334d, checked in by Sebastian Huber <sebastian.huber@…>, on Dec 1, 2017 at 7:51:17 AM

ada: Add standard test begin/end message

  • Property mode set to 100644
File size: 5.0 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-2011.
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.org/license/LICENSE.
19--
20
21with INTERFACES; use INTERFACES;
22with RTEMS_CALLING_OVERHEAD;
23with TEST_SUPPORT;
24with TEXT_IO;
25with TIME_TEST_SUPPORT;
26with TIMER_DRIVER;
27with RTEMS.MESSAGE_QUEUE;
28
29package body TMTEST is
30
31--
32--  INIT
33--
34
35   procedure INIT (
36      ARGUMENT : in     RTEMS.TASKS.ARGUMENT
37   ) is
38      pragma Unreferenced(ARGUMENT);
39      TASK_ID : RTEMS.ID;
40      STATUS  : RTEMS.STATUS_CODES;
41   begin
42
43      TEXT_IO.NEW_LINE( 2 );
44      TEST_SUPPORT.ADA_TEST_BEGIN;
45
46      RTEMS.TASKS.CREATE( 
47         1,
48         251, 
49         1024, 
50         RTEMS.DEFAULT_MODES,
51         RTEMS.DEFAULT_ATTRIBUTES,
52         TASK_ID,
53         STATUS
54      );
55      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE" );
56
57      RTEMS.TASKS.START( 
58         TASK_ID, 
59         TMTEST.TEST_INIT'ACCESS, 
60         0, 
61         STATUS
62      );
63      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START" );
64
65      RTEMS.TASKS.DELETE( RTEMS.SELF, STATUS );
66      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_DELETE OF SELF" );
67
68   end INIT;
69
70--
71--  TEST_INIT
72--
73
74   procedure TEST_INIT (
75      ARGUMENT : in     RTEMS.TASKS.ARGUMENT
76   ) is
77      pragma Unreferenced(ARGUMENT);
78      TASK_ENTRY     : RTEMS.TASKS.ENTRY_POINT;
79      PRIORITY       : RTEMS.TASKS.PRIORITY;
80      TASK_ID        : RTEMS.ID;
81      BUFFER         : TMTEST.BUFFER;
82      BUFFER_POINTER : RTEMS.ADDRESS;
83      STATUS         : RTEMS.STATUS_CODES;
84   begin
85
86      BUFFER_POINTER := BUFFER'ADDRESS;
87
88-- As each task is started, it preempts this task and performs a blocking
89-- MESSAGE_QUEUE_RECEIVE.  Upon completion of this loop all created tasks
90-- are blocked.
91
92      RTEMS.MESSAGE_QUEUE.CREATE(
93         RTEMS.BUILD_NAME( 'M', 'Q', '1', ' ' ),
94         TIME_TEST_SUPPORT.OPERATION_COUNT,
95         16,
96         RTEMS.DEFAULT_OPTIONS,
97         TMTEST.QUEUE_ID,
98         STATUS
99      );
100      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "MESSAGE_QUEUE_CREATE" );
101
102      PRIORITY := 250;
103
104      for INDEX in 0 .. TIME_TEST_SUPPORT.OPERATION_COUNT - 1
105      loop
106
107         RTEMS.TASKS.CREATE( 
108            RTEMS.BUILD_NAME( 'T', 'I', 'M', 'E' ),
109            PRIORITY, 
110            1024, 
111            RTEMS.DEFAULT_MODES,
112            RTEMS.DEFAULT_ATTRIBUTES,
113            TASK_ID,
114            STATUS
115         );
116         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE LOOP" );
117
118         PRIORITY := PRIORITY - 1;
119
120         if INDEX = TIME_TEST_SUPPORT.OPERATION_COUNT - 1 then
121            TASK_ENTRY := TMTEST.HIGH_TASK'ACCESS;
122         else
123            TASK_ENTRY := TMTEST.MIDDLE_TASKS'ACCESS;
124         end if;
125
126         RTEMS.TASKS.START( TASK_ID, TASK_ENTRY, 0, STATUS );
127         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START LOOP" );
128
129      end loop;
130
131      TIMER_DRIVER.INITIALIZE;
132         RTEMS.MESSAGE_QUEUE.SEND( 
133            TMTEST.QUEUE_ID,
134            BUFFER_POINTER,
135            16,
136            STATUS
137         );
138         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "MESSAGE_QUEUE_SEND" );
139
140   end TEST_INIT;
141
142--
143--  HIGH_TASK
144--
145
146   procedure HIGH_TASK (
147      ARGUMENT : in     RTEMS.TASKS.ARGUMENT
148   ) is
149      pragma Unreferenced(ARGUMENT);
150      BUFFER         : TMTEST.BUFFER;
151      BUFFER_POINTER : RTEMS.ADDRESS;
152      MESSAGE_SIZE   : RTEMS.UNSIGNED32 := 0;
153      STATUS         : RTEMS.STATUS_CODES;
154   begin
155
156      BUFFER_POINTER := BUFFER'ADDRESS;
157
158      RTEMS.MESSAGE_QUEUE.RECEIVE( 
159         TMTEST.QUEUE_ID,
160         BUFFER_POINTER,
161         RTEMS.DEFAULT_OPTIONS,
162         RTEMS.NO_TIMEOUT,
163         MESSAGE_SIZE,
164         STATUS
165      );
166
167      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
168
169      TIME_TEST_SUPPORT.PUT_TIME(
170         "MESSAGE_QUEUE_SEND (preemptive)",
171         TMTEST.END_TIME, 
172         TIME_TEST_SUPPORT.OPERATION_COUNT, 
173         0,
174         RTEMS_CALLING_OVERHEAD.MESSAGE_QUEUE_SEND
175      );
176
177      TEST_SUPPORT.ADA_TEST_END;
178      RTEMS.SHUTDOWN_EXECUTIVE( 0 );
179
180   end HIGH_TASK;
181
182--
183--  MIDDLE_TASKS
184--
185
186   procedure MIDDLE_TASKS (
187      ARGUMENT : in     RTEMS.TASKS.ARGUMENT
188   ) is
189      pragma Unreferenced(ARGUMENT);
190      BUFFER         : TMTEST.BUFFER;
191      BUFFER_POINTER : RTEMS.ADDRESS;
192      MESSAGE_SIZE   : RTEMS.UNSIGNED32 := 0;
193      STATUS         : RTEMS.STATUS_CODES;
194   begin
195 
196      BUFFER_POINTER := BUFFER'ADDRESS;
197
198      RTEMS.MESSAGE_QUEUE.RECEIVE( 
199         TMTEST.QUEUE_ID,
200         BUFFER_POINTER,
201         RTEMS.DEFAULT_OPTIONS,
202         RTEMS.NO_TIMEOUT,
203         MESSAGE_SIZE,
204         STATUS
205      );
206      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "MESSAGE_QUEUE_RECEIVE" );
207 
208      RTEMS.MESSAGE_QUEUE.SEND( 
209         TMTEST.QUEUE_ID,
210         BUFFER_POINTER,
211         16,
212         STATUS
213      );
214      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "MESSAGE_QUEUE_SEND" );
215
216   end MIDDLE_TASKS;
217
218end TMTEST;
Note: See TracBrowser for help on using the repository browser.