source: rtems/c/src/ada-tests/tmtests/tm02/tmtest.adb @ b4be04e

4.104.114.84.95
Last change on this file since b4be04e was bf9ae83, checked in by Joel Sherrill <joel.sherrill@…>, on 06/02/97 at 20:32:11

modified copyright notice to be the same as RTEMS 4.0.0.

changed the CVS ID string to be a "development" version.

  • Property mode set to 100644
File size: 4.3 KB
Line 
1--
2--  TMTEST / BODY
3--
4--  DESCRIPTION:
5--
6--  This package is the implementation of Test 2 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--  Copyright assigned to U.S. Government, 1994.
16--
17--  The license and distribution terms for this file may in
18--  the file LICENSE in this distribution or at
19--  http://www.OARcorp.com/rtems/license.html.
20--
21--  $Id$
22--
23
24with INTERFACES; use INTERFACES;
25with RTEMS;
26with RTEMS_CALLING_OVERHEAD;
27with TEST_SUPPORT;
28with TEXT_IO;
29with TIME_TEST_SUPPORT;
30with UNSIGNED32_IO;
31
32package body TMTEST is
33
34--PAGE
35--
36--  INIT
37--
38
39   procedure INIT (
40      ARGUMENT : in     RTEMS.TASK_ARGUMENT
41   ) is
42      STATUS : RTEMS.STATUS_CODES;
43   begin
44
45      TEXT_IO.NEW_LINE( 2 );
46      TEXT_IO.PUT_LINE( "*** TIME TEST 2 ***" );
47
48      TMTEST.TEST_INIT;
49
50      RTEMS.TASK_DELETE( RTEMS.SELF, STATUS );
51      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_DELETE OF SELF" );
52
53   end INIT;
54
55--PAGE
56--
57--  TEST_INIT
58--
59
60   procedure TEST_INIT is
61      PRIORITY : RTEMS.TASK_PRIORITY;
62      INDEX    : RTEMS.UNSIGNED32;
63      HIGH_ID  : RTEMS.ID;
64      LOW_ID   : RTEMS.ID;
65      TASK_ID  : RTEMS.ID;
66      STATUS   : RTEMS.STATUS_CODES;
67   begin
68
69      PRIORITY := 5;
70
71      RTEMS.TASK_CREATE(
72         RTEMS.BUILD_NAME( 'H', 'I', 'G', 'H' ),
73         PRIORITY,
74         1024,
75         RTEMS.DEFAULT_MODES,
76         RTEMS.DEFAULT_ATTRIBUTES,
77         HIGH_ID,
78         STATUS
79      );
80      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE OF HIGH TASK" );
81
82      PRIORITY := PRIORITY + 1;
83
84      RTEMS.TASK_START(
85         HIGH_ID,
86         TMTEST.HIGH_TASK'ACCESS,
87         0,
88         STATUS
89      );
90      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START OF HIGH TASK" );
91
92      for INDEX in 2 .. TIME_TEST_SUPPORT.OPERATION_COUNT
93      loop
94
95         RTEMS.TASK_CREATE(
96            RTEMS.BUILD_NAME( 'M', 'I', 'D', ' ' ),
97            PRIORITY,
98            1024,
99            RTEMS.DEFAULT_MODES,
100            RTEMS.DEFAULT_ATTRIBUTES,
101            TASK_ID,
102            STATUS
103         );
104         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE MIDDLE" );
105
106         PRIORITY := PRIORITY + 1;
107
108         RTEMS.TASK_START(
109            TASK_ID,
110            TMTEST.MIDDLE_TASKS'ACCESS,
111            0,
112            STATUS
113         );
114         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START MIDDLE" );
115
116      end loop;
117
118      RTEMS.TASK_CREATE(
119         RTEMS.BUILD_NAME( 'L', 'O', 'W', ' ' ),
120         PRIORITY,
121         2048,
122         RTEMS.DEFAULT_MODES,
123         RTEMS.DEFAULT_ATTRIBUTES,
124         LOW_ID,
125         STATUS
126      );
127      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE OF LOW TASK" );
128
129      RTEMS.TASK_START( LOW_ID, TMTEST.LOW_TASK'ACCESS, 0, STATUS );
130      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START OF LOW TASK" );
131
132      RTEMS.SEMAPHORE_CREATE(
133         RTEMS.BUILD_NAME( 'S', 'M', '1', ' ' ),
134         0,
135         RTEMS.DEFAULT_ATTRIBUTES,
136         TMTEST.SEMAPHORE_ID,
137         STATUS
138      );
139      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "SEMAPHORE_CREATE OF SM1" );
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      STATUS                   : RTEMS.STATUS_CODES;
152   begin
153
154      TIMER_DRIVER.INITIALIZE;
155      RTEMS.SEMAPHORE_OBTAIN(
156         TMTEST.SEMAPHORE_ID,
157         RTEMS.DEFAULT_OPTIONS,
158         RTEMS.NO_TIMEOUT,
159         STATUS
160      );
161
162   end HIGH_TASK;
163
164--PAGE
165--
166--  MIDDLE_TASKS
167--
168
169   procedure MIDDLE_TASKS (
170      ARGUMENT : in     RTEMS.TASK_ARGUMENT
171   ) is
172      STATUS                   : RTEMS.STATUS_CODES;
173   begin
174
175      RTEMS.SEMAPHORE_OBTAIN(
176         TMTEST.SEMAPHORE_ID,
177         RTEMS.DEFAULT_OPTIONS,
178         RTEMS.NO_TIMEOUT,
179         STATUS
180      );
181
182   end MIDDLE_TASKS;
183
184--PAGE
185--
186--  LOW_TASK
187--
188
189   procedure LOW_TASK (
190      ARGUMENT : in     RTEMS.TASK_ARGUMENT
191   ) is
192      STATUS                   : RTEMS.STATUS_CODES;
193   begin
194
195      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
196      TIME_TEST_SUPPORT.PUT_TIME(
197         "SEMAPHORE_OBTAIN (blocking)",
198         TMTEST.END_TIME,
199         TIME_TEST_SUPPORT.OPERATION_COUNT,
200         0,
201         RTEMS_CALLING_OVERHEAD.SEMAPHORE_OBTAIN
202      );
203
204      RTEMS.SHUTDOWN_EXECUTIVE( 0 );
205
206   end LOW_TASK;
207
208end TMTEST;
Note: See TracBrowser for help on using the repository browser.