source: rtems/testsuites/ada/tmtests/tm12/tmtest.adb @ bc96f3b4

Last change on this file since bc96f3b4 was bc96f3b4, checked in by Sebastian Huber <sebastian.huber@…>, on Jan 23, 2018 at 8:53:06 AM

ada: Introduce RTEMS.Size type

Some time ago the Classic API object size related parameters were
changed to use size_t. Reflect this in the Ada bindings.

Update #3082.

  • Property mode set to 100644
File size: 4.6 KB
Line 
1--
2--  TMTEST / BODY
3--
4--  DESCRIPTION:
5--
6--  This package is the implementation of Test 12 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      STATUS         : RTEMS.STATUS_CODES;
82   begin
83
84      RTEMS.MESSAGE_QUEUE.CREATE(
85         RTEMS.BUILD_NAME( 'M', 'Q', '1', ' ' ),
86         TIME_TEST_SUPPORT.OPERATION_COUNT,
87         16,
88         RTEMS.DEFAULT_OPTIONS,
89         TMTEST.QUEUE_ID,
90         STATUS
91      );
92      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "MESSAGE_QUEUE_CREATE" );
93
94      PRIORITY := 250;
95
96      for INDEX in 0 .. TIME_TEST_SUPPORT.OPERATION_COUNT - 1
97      loop
98
99         RTEMS.TASKS.CREATE( 
100            RTEMS.BUILD_NAME( 'T', 'I', 'M', 'E' ),
101            PRIORITY, 
102            1024, 
103            RTEMS.DEFAULT_MODES,
104            RTEMS.DEFAULT_ATTRIBUTES,
105            TASK_ID,
106            STATUS
107         );
108         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE LOOP" );
109
110         PRIORITY := PRIORITY - 1;
111
112         if INDEX = TIME_TEST_SUPPORT.OPERATION_COUNT - 1 then
113            TASK_ENTRY := TMTEST.HIGH_TASK'ACCESS;
114         else
115            TASK_ENTRY := TMTEST.LOW_TASKS'ACCESS;
116         end if;
117
118         RTEMS.TASKS.START( TASK_ID, TASK_ENTRY, 0, STATUS );
119         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START LOOP" );
120
121      end loop;
122
123   end TEST_INIT;
124
125--
126--  HIGH_TASK
127--
128
129   procedure HIGH_TASK (
130      ARGUMENT : in     RTEMS.TASKS.ARGUMENT
131   ) is
132      pragma Unreferenced(ARGUMENT);
133      BUFFER         : TMTEST.BUFFER;
134      BUFFER_POINTER : RTEMS.ADDRESS;
135      OVERHEAD       : RTEMS.UNSIGNED32;
136      STATUS         : RTEMS.STATUS_CODES;
137   begin
138
139      BUFFER_POINTER := BUFFER'ADDRESS;
140
141      TIMER_DRIVER.INITIALIZE;
142         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
143         loop
144            TIMER_DRIVER.EMPTY_FUNCTION;
145         end loop;
146      OVERHEAD := TIMER_DRIVER.READ_TIMER;
147
148      for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
149      loop
150     
151         RTEMS.MESSAGE_QUEUE.SEND(
152            TMTEST.QUEUE_ID,
153            BUFFER_POINTER, 
154            16,
155            STATUS
156         );
157         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "MESSAGE_QUEUE_SEND" ); --XXX
158
159      end loop;
160
161      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
162
163      TIME_TEST_SUPPORT.PUT_TIME(
164         "MESSAGE_QUEUE_SEND (readying)",
165         TMTEST.END_TIME, 
166         TIME_TEST_SUPPORT.OPERATION_COUNT, 
167         OVERHEAD,
168         RTEMS_CALLING_OVERHEAD.MESSAGE_QUEUE_SEND
169      );
170
171      TEST_SUPPORT.ADA_TEST_END;
172      RTEMS.SHUTDOWN_EXECUTIVE( 0 );
173
174   end HIGH_TASK;
175
176--
177--  LOW_TASK
178--
179
180   procedure LOW_TASKS (
181      ARGUMENT : in     RTEMS.TASKS.ARGUMENT
182   ) is
183      pragma Unreferenced(ARGUMENT);
184      BUFFER         : TMTEST.BUFFER;
185      BUFFER_POINTER : RTEMS.ADDRESS;
186      MESSAGE_SIZE   : RTEMS.Size := 0;
187      STATUS         : RTEMS.STATUS_CODES;
188   begin
189 
190      BUFFER_POINTER := BUFFER'ADDRESS;
191
192      RTEMS.MESSAGE_QUEUE.RECEIVE( 
193         TMTEST.QUEUE_ID,
194         BUFFER_POINTER,
195         RTEMS.DEFAULT_OPTIONS,
196         RTEMS.NO_TIMEOUT,
197         MESSAGE_SIZE,
198         STATUS
199      );
200      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "MESSAGE_QUEUE_RECEIVE" ); --XXX
201 
202   end LOW_TASKS;
203
204end TMTEST;
Note: See TracBrowser for help on using the repository browser.