source: rtems/testsuites/ada/tmtests/tm10/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.9 KB
RevLine 
[6d4e604b]1--
2--  TMTEST / BODY
3--
4--  DESCRIPTION:
5--
6--  This package is the implementation of Test 10 of the RTEMS
7--  Timing Test Suite.
8--
9--  DEPENDENCIES:
10--
11-- 
12--
[3c4d8cd1]13--  COPYRIGHT (c) 1989-2011.
[6d4e604b]14--  On-Line Applications Research Corporation (OAR).
15--
[bf9ae83]16--  The license and distribution terms for this file may in
17--  the file LICENSE in this distribution or at
[c499856]18--  http://www.rtems.org/license/LICENSE.
[6d4e604b]19--
20
21with INTERFACES; use INTERFACES;
22with RTEMS_CALLING_OVERHEAD;
23with TEST_SUPPORT;
24with TEXT_IO;
25with TIME_TEST_SUPPORT;
[110e1f1]26with TIMER_DRIVER;
[3c4d8cd1]27with RTEMS.MESSAGE_QUEUE;
[6d4e604b]28
29package body TMTEST is
30
31--
32--  INIT
33--
34
35   procedure INIT (
[3c4d8cd1]36      ARGUMENT : in     RTEMS.TASKS.ARGUMENT
[6d4e604b]37   ) is
[110e1f1]38      pragma Unreferenced(ARGUMENT);
[6d4e604b]39      STATUS  : RTEMS.STATUS_CODES;
40   begin
41
42      TEXT_IO.NEW_LINE( 2 );
[f6c9334d]43      TEST_SUPPORT.ADA_TEST_BEGIN;
[6d4e604b]44
45      TMTEST.TEST_INIT;
46
[3c4d8cd1]47      RTEMS.TASKS.DELETE( RTEMS.SELF, STATUS );
[6d4e604b]48      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_DELETE OF SELF" );
49
50   end INIT;
51
52--
53--  TEST_INIT
54--
55
56   procedure TEST_INIT
57   is
[3c4d8cd1]58      TASK_ENTRY     : RTEMS.TASKS.ENTRY_POINT;
59      PRIORITY       : RTEMS.TASKS.PRIORITY;
[6d4e604b]60      OVERHEAD       : RTEMS.UNSIGNED32;
61      TASK_ID        : RTEMS.ID;
[e17ffea]62      BUFFER         : TMTEST.BUFFER;
63      BUFFER_POINTER : RTEMS.ADDRESS;
[110e1f1]64      MESSAGE_SIZE   : RTEMS.UNSIGNED32 := 0;
[6d4e604b]65      STATUS         : RTEMS.STATUS_CODES;
66   begin
67
[e17ffea]68      BUFFER_POINTER := BUFFER'ADDRESS;
[6d4e604b]69
70      PRIORITY := 5;
71
72      for INDEX in 0 .. TIME_TEST_SUPPORT.OPERATION_COUNT
73      loop
74
[3c4d8cd1]75         RTEMS.TASKS.CREATE(
[6d4e604b]76            RTEMS.BUILD_NAME( 'T', 'I', 'M', 'E' ),
77            PRIORITY,
78            1024,
79            RTEMS.DEFAULT_MODES,
80            RTEMS.DEFAULT_ATTRIBUTES,
81            TASK_ID,
82            STATUS
83         );
84         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE LOOP" );
85
86         PRIORITY := PRIORITY + 1;
87
88         if INDEX = 0 then
89            TASK_ENTRY := TMTEST.HIGH_TASK'ACCESS;
90         elsif INDEX = TIME_TEST_SUPPORT.OPERATION_COUNT then
91            TASK_ENTRY := TMTEST.LOW_TASK'ACCESS;
92         else
93            TASK_ENTRY := TMTEST.MIDDLE_TASKS'ACCESS;
94         end if;
95
[3c4d8cd1]96         RTEMS.TASKS.START( TASK_ID, TASK_ENTRY, 0, STATUS );
[6d4e604b]97         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START LOOP" );
98
99      end loop;
100
[3c4d8cd1]101      RTEMS.MESSAGE_QUEUE.CREATE(
[6d4e604b]102         1,
103         TIME_TEST_SUPPORT.OPERATION_COUNT,
[688ecaa0]104         16,
[6d4e604b]105         RTEMS.DEFAULT_OPTIONS,
106         TMTEST.QUEUE_ID,
107         STATUS
108      );
109
110      TIMER_DRIVER.INITIALIZE;
111         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
112         loop
113            TIMER_DRIVER.EMPTY_FUNCTION;
114         end loop;
115      OVERHEAD := TIMER_DRIVER.READ_TIMER;
116
117      TIMER_DRIVER.INITIALIZE;
118         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
119         loop
[3c4d8cd1]120            RTEMS.MESSAGE_QUEUE.RECEIVE(
[6d4e604b]121               TMTEST.QUEUE_ID,
122               BUFFER_POINTER,
123               RTEMS.NO_WAIT,
124               RTEMS.NO_TIMEOUT,
[e17ffea]125               MESSAGE_SIZE,
[6d4e604b]126               STATUS
127            );
128         end loop;
129      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
130      TIME_TEST_SUPPORT.PUT_TIME(
131         "MESSAGE_QUEUE_RECEIVE (NO_WAIT)",
132         TMTEST.END_TIME,
133         TIME_TEST_SUPPORT.OPERATION_COUNT,
134         OVERHEAD,
135         RTEMS_CALLING_OVERHEAD.MESSAGE_QUEUE_RECEIVE
136      );
137
138   end TEST_INIT;
139
140--
141--  HIGH_TASK
142--
143
144   procedure HIGH_TASK (
[3c4d8cd1]145      ARGUMENT : in     RTEMS.TASKS.ARGUMENT
[6d4e604b]146   ) is
[110e1f1]147      pragma Unreferenced(ARGUMENT);
[e17ffea]148      BUFFER         : TMTEST.BUFFER;
149      BUFFER_POINTER : RTEMS.ADDRESS;
[110e1f1]150      MESSAGE_SIZE   : RTEMS.UNSIGNED32 := 0;
[6d4e604b]151      STATUS         : RTEMS.STATUS_CODES;
152   begin
153
[e17ffea]154      BUFFER_POINTER := BUFFER'ADDRESS;
[6d4e604b]155
156      TIMER_DRIVER.INITIALIZE;
157
[3c4d8cd1]158      RTEMS.MESSAGE_QUEUE.RECEIVE(
[6d4e604b]159         TMTEST.QUEUE_ID,
160         BUFFER_POINTER,
161         RTEMS.DEFAULT_OPTIONS,
162         RTEMS.NO_TIMEOUT,
[e17ffea]163         MESSAGE_SIZE,
[6d4e604b]164         STATUS
165      );
166
167   end HIGH_TASK;
168
169--
170--  MIDDLE_TASKS
171--
172
173   procedure MIDDLE_TASKS (
[3c4d8cd1]174      ARGUMENT : in     RTEMS.TASKS.ARGUMENT
[6d4e604b]175   ) is
[110e1f1]176      pragma Unreferenced(ARGUMENT);
[e17ffea]177      BUFFER         : TMTEST.BUFFER;
178      BUFFER_POINTER : RTEMS.ADDRESS;
[110e1f1]179      MESSAGE_SIZE   : RTEMS.UNSIGNED32 := 0;
[6d4e604b]180      STATUS         : RTEMS.STATUS_CODES;
181   begin
182 
[e17ffea]183      BUFFER_POINTER := BUFFER'ADDRESS;
[6d4e604b]184
[3c4d8cd1]185      RTEMS.MESSAGE_QUEUE.RECEIVE(
[6d4e604b]186         TMTEST.QUEUE_ID,
187         BUFFER_POINTER,
188         RTEMS.DEFAULT_OPTIONS,
189         RTEMS.NO_TIMEOUT,
[e17ffea]190         MESSAGE_SIZE,
[6d4e604b]191         STATUS
192      );
193 
194   end MIDDLE_TASKS;
195
196--
197--  LOW_TASK
198--
199
200   procedure LOW_TASK (
[3c4d8cd1]201      ARGUMENT : in     RTEMS.TASKS.ARGUMENT
[6d4e604b]202   ) is
[110e1f1]203      pragma Unreferenced(ARGUMENT);
[6d4e604b]204   begin
205
206      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
207      TIME_TEST_SUPPORT.PUT_TIME(
208         "MESSAGE_QUEUE_RECEIVE (blocking)",
209         TMTEST.END_TIME,
210         TIME_TEST_SUPPORT.OPERATION_COUNT,
211         0,
212         RTEMS_CALLING_OVERHEAD.MESSAGE_QUEUE_RECEIVE
213      );
214
[f6c9334d]215      TEST_SUPPORT.ADA_TEST_END;
[6d4e604b]216      RTEMS.SHUTDOWN_EXECUTIVE( 0 );
217
218   end LOW_TASK;
219
220end TMTEST;
Note: See TracBrowser for help on using the repository browser.