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

5
Last change on this file since f6c9334d was f6c9334d, checked in by Sebastian Huber <sebastian.huber@…>, on 12/01/17 at 07:51:17

ada: Add standard test begin/end message

  • 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-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      RTEMS.MESSAGE_QUEUE.CREATE(
89         RTEMS.BUILD_NAME( 'M', 'Q', '1', ' ' ),
90         TIME_TEST_SUPPORT.OPERATION_COUNT,
91         16,
92         RTEMS.DEFAULT_OPTIONS,
93         TMTEST.QUEUE_ID,
94         STATUS
95      );
96
97      PRIORITY := 250;
98
99      for INDEX in 0 .. TIME_TEST_SUPPORT.OPERATION_COUNT - 1
100      loop
101
102         RTEMS.TASKS.CREATE(
103            RTEMS.BUILD_NAME( 'T', 'I', 'M', 'E' ),
104            PRIORITY,
105            1024,
106            RTEMS.DEFAULT_MODES,
107            RTEMS.DEFAULT_ATTRIBUTES,
108            TASK_ID,
109            STATUS
110         );
111         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE LOOP" );
112
113         PRIORITY := PRIORITY - 1;
114
115         if INDEX = TIME_TEST_SUPPORT.OPERATION_COUNT - 1 then
116            TASK_ENTRY := TMTEST.HIGH_TASK'ACCESS;
117         else
118            TASK_ENTRY := TMTEST.LOW_TASKS'ACCESS;
119         end if;
120
121         RTEMS.TASKS.START( TASK_ID, TASK_ENTRY, 0, STATUS );
122         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START LOOP" );
123
124      end loop;
125
126      TIMER_DRIVER.INITIALIZE;
127      RTEMS.MESSAGE_QUEUE.URGENT(
128         TMTEST.QUEUE_ID,
129         BUFFER_POINTER,
130         16,
131         STATUS
132      );
133      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "MESSSAGE_QUEUE_URGENT" );
134
135   end TEST_INIT;
136
137--
138--  HIGH_TASK
139--
140
141   procedure HIGH_TASK (
142      ARGUMENT : in     RTEMS.TASKS.ARGUMENT
143   ) is
144      pragma Unreferenced(ARGUMENT);
145      BUFFER         : TMTEST.BUFFER;
146      BUFFER_POINTER : RTEMS.ADDRESS;
147      OVERHEAD       : RTEMS.UNSIGNED32;
148      STATUS         : RTEMS.STATUS_CODES;
149   begin
150
151      BUFFER_POINTER := BUFFER'ADDRESS;
152
153      TIMER_DRIVER.INITIALIZE;
154         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
155         loop
156            TIMER_DRIVER.EMPTY_FUNCTION;
157         end loop;
158      OVERHEAD := TIMER_DRIVER.READ_TIMER;
159
160      for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
161      loop
162     
163         RTEMS.MESSAGE_QUEUE.URGENT(
164            TMTEST.QUEUE_ID,
165            BUFFER_POINTER,
166            16,
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      TEST_SUPPORT.ADA_TEST_END;
183      RTEMS.SHUTDOWN_EXECUTIVE( 0 );
184
185   end HIGH_TASK;
186
187--
188--  LOW_TASKS
189--
190
191   procedure LOW_TASKS (
192      ARGUMENT : in     RTEMS.TASKS.ARGUMENT
193   ) is
194      pragma Unreferenced(ARGUMENT);
195      BUFFER         : TMTEST.BUFFER;
196      BUFFER_POINTER : RTEMS.ADDRESS;
197      MESSAGE_SIZE   : RTEMS.UNSIGNED32 := 0;
198      STATUS         : RTEMS.STATUS_CODES;
199   begin
200 
201      BUFFER_POINTER := BUFFER'ADDRESS;
202
203      RTEMS.MESSAGE_QUEUE.RECEIVE(
204         TMTEST.QUEUE_ID,
205         BUFFER_POINTER,
206         RTEMS.DEFAULT_OPTIONS,
207         RTEMS.NO_TIMEOUT,
208         MESSAGE_SIZE,
209         STATUS
210      );
211 
212   end LOW_TASKS;
213
214end TMTEST;
Note: See TracBrowser for help on using the repository browser.