source: rtems/c/src/ada-tests/tmtests/tm03/tmtest.adb @ 6d4e604b

4.104.114.84.95
Last change on this file since 6d4e604b was 6d4e604b, checked in by Joel Sherrill <joel.sherrill@…>, on 06/02/97 at 20:19:03

Initial revision

  • Property mode set to 100644
File size: 4.4 KB
Line 
1--
2--  TMTEST / BODY
3--
4--  DESCRIPTION:
5--
6--  This package is the implementation of Test 3 of the RTEMS
7--  Timing Test Suite.
8--
9--  DEPENDENCIES:
10--
11-- 
12--
13--  COPYRIGHT (c) 1989, 1990, 1991, 1992, 1993, 1994.
14--  On-Line Applications Research Corporation (OAR).
15--  All rights assigned to U.S. Government, 1994.
16--
17--  This material may be reproduced by or for the U.S. Government pursuant
18--  to the copyright license under the clause at DFARS 252.227-7013.  This
19--  notice must appear in all copies of this file and its derivatives.
20--
21--  tmtest.adb,v 1.3 1995/07/12 19:43:10 joel Exp
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      TASK_ID : RTEMS.ID;
43      STATUS  : RTEMS.STATUS_CODES;
44   begin
45
46      TEXT_IO.NEW_LINE( 2 );
47      TEXT_IO.PUT_LINE( "*** TIME TEST 3 ***" );
48
49      RTEMS.TASK_CREATE(
50         RTEMS.BUILD_NAME( 'T', 'A', '1', ' ' ),
51         252,
52         2048,
53         RTEMS.DEFAULT_MODES,
54         RTEMS.DEFAULT_ATTRIBUTES,
55         TASK_ID,
56         STATUS
57      );
58      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE OF TEST_INIT" );
59
60      RTEMS.TASK_START( TASK_ID, TMTEST.TEST_INIT'ACCESS, 0, STATUS );
61      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START OF TEST_INIT" );
62
63      RTEMS.TASK_DELETE( RTEMS.SELF, STATUS );
64      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_DELETE OF SELF" );
65
66   end INIT;
67
68--PAGE
69--
70--  TEST_INIT
71--
72
73   procedure TEST_INIT (
74      ARGUMENT : in     RTEMS.TASK_ARGUMENT
75   ) is
76      INDEX    : RTEMS.UNSIGNED32;
77      PRIORITY : RTEMS.TASK_PRIORITY;
78      TASK_ID  : RTEMS.ID;
79      STATUS   : RTEMS.STATUS_CODES;
80   begin
81
82      PRIORITY := 250;
83 
84      RTEMS.SEMAPHORE_CREATE(
85         RTEMS.BUILD_NAME( 'S', 'M', '1', ' ' ),
86         0,
87         RTEMS.DEFAULT_ATTRIBUTES,
88         TMTEST.SEMAPHORE_ID,
89         STATUS
90      );
91      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "SEMAPHORE_CREATE OF SM1" );
92
93      for INDEX in 2 .. TIME_TEST_SUPPORT.OPERATION_COUNT
94      loop
95
96         RTEMS.TASK_CREATE(
97            RTEMS.BUILD_NAME( 'M', 'I', 'D', ' ' ),
98            PRIORITY,
99            1024,
100            RTEMS.DEFAULT_MODES,
101            RTEMS.DEFAULT_ATTRIBUTES,
102            TASK_ID,
103            STATUS
104         );
105         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE MIDDLE" );
106
107         PRIORITY := PRIORITY - 1;
108
109         RTEMS.TASK_START( TASK_ID, TMTEST.MIDDLE_TASKS'ACCESS, 0, STATUS );
110         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START MIDDLE" );
111
112      end loop;
113
114      RTEMS.TASK_CREATE(
115         RTEMS.BUILD_NAME( 'H', 'I', 'G', 'H' ),
116         PRIORITY,
117         1024,
118         RTEMS.DEFAULT_MODES,
119         RTEMS.DEFAULT_ATTRIBUTES,
120         TASK_ID,
121         STATUS
122      );
123      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE OF HIGH TASK" );
124
125      RTEMS.TASK_START( TASK_ID, TMTEST.HIGH_TASK'ACCESS, 0, STATUS );
126      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START OF HIGH TASK" );
127
128      TIMER_DRIVER.INITIALIZE;
129      RTEMS.SEMAPHORE_RELEASE( TMTEST.SEMAPHORE_ID, STATUS );
130
131   end TEST_INIT;
132
133--PAGE
134--
135--  MIDDLE_TASKS
136--
137
138   procedure MIDDLE_TASKS (
139      ARGUMENT : in     RTEMS.TASK_ARGUMENT
140   ) is
141      INDEX    : RTEMS.UNSIGNED32;
142      PRIORITY : RTEMS.TASK_PRIORITY;
143      ID       : RTEMS.ID;
144      STATUS   : RTEMS.STATUS_CODES;
145   begin
146   
147      RTEMS.SEMAPHORE_OBTAIN(
148         TMTEST.SEMAPHORE_ID,
149         RTEMS.DEFAULT_OPTIONS,
150         RTEMS.NO_TIMEOUT,
151         STATUS
152      );
153
154      RTEMS.SEMAPHORE_RELEASE( TMTEST.SEMAPHORE_ID, STATUS );
155
156   end MIDDLE_TASKS;
157
158--PAGE
159--
160--  HIGH_TASK
161--
162
163   procedure HIGH_TASK (
164      ARGUMENT : in     RTEMS.TASK_ARGUMENT
165   ) is
166      INDEX    : RTEMS.UNSIGNED32;
167      PRIORITY : RTEMS.TASK_PRIORITY;
168      ID       : RTEMS.ID;
169      STATUS   : RTEMS.STATUS_CODES;
170   begin
171   
172      RTEMS.SEMAPHORE_OBTAIN(
173         TMTEST.SEMAPHORE_ID,
174         RTEMS.DEFAULT_OPTIONS,
175         RTEMS.NO_TIMEOUT,
176         STATUS
177      );
178
179      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
180
181      TIME_TEST_SUPPORT.PUT_TIME(
182         "SEMAPHORE_RELEASE (preemptive)",
183         TMTEST.END_TIME,
184         TIME_TEST_SUPPORT.OPERATION_COUNT,
185         0,
186         RTEMS_CALLING_OVERHEAD.SEMAPHORE_RELEASE
187      );
188
189      RTEMS.SHUTDOWN_EXECUTIVE( 0 );
190
191   end HIGH_TASK;
192
193end TMTEST;
Note: See TracBrowser for help on using the repository browser.