source: rtems/c/src/ada-tests/tmtests/tm06/tmtest.adb @ 820901ba

4.104.114.84.95
Last change on this file since 820901ba was 820901ba, checked in by Joel Sherrill <joel.sherrill@…>, on 05/03/05 at 21:41:45

2005-05-03 Joel Sherrill <joel@…>

  • samples/hello/sptest.adb, sptests/sp03/sptest.adb, sptests/sp04/sptest.adb, sptests/sp05/sptest.adb, sptests/sp07/sptest.adb, sptests/sp13/sptest.adb, sptests/sp14/sptest.adb, sptests/sp20/sptest.adb, sptests/sp24/sptest.adb, tmtests/tm01/tmtest.adb, tmtests/tm02/tmtest.adb, tmtests/tm03/tmtest.adb, tmtests/tm04/tmtest.adb, tmtests/tm05/tmtest.adb, tmtests/tm06/tmtest.adb, tmtests/tm07/tmtest.adb, tmtests/tm08/tmtest.adb, tmtests/tm09/tmtest.adb, tmtests/tm10/tmtest.adb, tmtests/tm11/tmtest.adb, tmtests/tm12/tmtest.adb, tmtests/tm13/tmtest.adb, tmtests/tm14/tmtest.adb, tmtests/tm15/tmtest.adb, tmtests/tm16/tmtest.adb, tmtests/tm17/tmtest.adb, tmtests/tm18/tmtest.adb, tmtests/tm19/tmtest.adb, tmtests/tm20/tmtest.adb, tmtests/tm21/tmtest.adb, tmtests/tm22/tmtest.adb, tmtests/tm23/tmtest.adb, tmtests/tm24/tmtest.adb, tmtests/tm25/tmtest.adb, tmtests/tm28/tmtest.adb, tmtests/tm29/tmtest.adb, tmtests/tmck/tmtest.adb, tmtests/tmoverhd/dummy_rtems.adb, tmtests/tmoverhd/tmtest.adb: Remove warnings.
  • 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 6 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--
16--  The license and distribution terms for this file may in
17--  the file LICENSE in this distribution or at
18--  http://www.rtems.com/license/LICENSE.
19--
20--  $Id$
21--
22
23with INTERFACES; use INTERFACES;
24with RTEMS;
25with RTEMS_CALLING_OVERHEAD;
26with TEST_SUPPORT;
27with TEXT_IO;
28with TIME_TEST_SUPPORT;
29with UNSIGNED32_IO;
30
31package body TMTEST is
32
33--PAGE
34--
35--  INIT
36--
37
38   procedure INIT (
39      ARGUMENT : in     RTEMS.TASK_ARGUMENT
40   ) is
41      STATUS  : RTEMS.STATUS_CODES;
42   begin
43
44      TEXT_IO.NEW_LINE( 2 );
45      TEXT_IO.PUT_LINE( "*** TIME TEST 6 ***" );
46
47      TMTEST.TEST_INIT;
48
49      RTEMS.TASK_DELETE( RTEMS.SELF, STATUS );
50      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_DELETE OF SELF" );
51
52   end INIT;
53
54--PAGE
55--
56--  TEST_INIT
57--
58
59   procedure TEST_INIT
60   is
61      ID         : RTEMS.ID;
62      STATUS     : RTEMS.STATUS_CODES;
63   begin
64
65      TMTEST.TASK_RESTARTED := TIME_TEST_SUPPORT.OPERATION_COUNT;
66
67      RTEMS.TASK_CREATE(
68         RTEMS.BUILD_NAME( 'T', 'I', 'M', 'E' ),
69         128,
70         1024,
71         RTEMS.DEFAULT_MODES,
72         RTEMS.DEFAULT_ATTRIBUTES,
73         ID,
74         STATUS
75      );
76      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE" );
77
78      RTEMS.TASK_START( ID, TMTEST.TASK_1'ACCESS, 0, STATUS );
79      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START" );
80
81   end TEST_INIT;
82
83--PAGE
84--
85--  TASK_1
86--
87
88   procedure TASK_1 (
89      ARGUMENT : in     RTEMS.TASK_ARGUMENT
90   ) is
91      OVERHEAD     : RTEMS.UNSIGNED32;
92      STATUS       : RTEMS.STATUS_CODES;
93   begin
94
95      if TMTEST.TASK_RESTARTED = TIME_TEST_SUPPORT.OPERATION_COUNT then
96         TIMER_DRIVER.INITIALIZE;
97      end if;
98
99      TMTEST.TASK_RESTARTED := TMTEST.TASK_RESTARTED - 1;
100
101      if TMTEST.TASK_RESTARTED /= 0 then
102         RTEMS.TASK_RESTART( RTEMS.SELF, 0, STATUS );
103      end if;
104
105      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
106
107      TIMER_DRIVER.INITIALIZE;
108         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
109         loop
110            TIMER_DRIVER.EMPTY_FUNCTION;
111         end loop;
112      OVERHEAD := TIMER_DRIVER.READ_TIMER;
113
114      TIME_TEST_SUPPORT.PUT_TIME(
115         "TASK_RESTART self",
116         TMTEST.END_TIME,
117         TIME_TEST_SUPPORT.OPERATION_COUNT,
118         0,
119         RTEMS_CALLING_OVERHEAD.TASK_RESTART
120      );
121
122      for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
123      loop
124
125         RTEMS.TASK_CREATE(
126            RTEMS.BUILD_NAME( 'T', 'I', 'M', 'E' ),
127            254,
128            1024,
129            RTEMS.DEFAULT_MODES,
130            RTEMS.DEFAULT_ATTRIBUTES,
131            TMTEST.TASK_ID( INDEX ),
132            STATUS
133         );
134         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE LOOP" );
135
136         RTEMS.TASK_START(
137            TMTEST.TASK_ID( INDEX ),
138            TMTEST.NULL_TASK'ACCESS,
139            0,
140            STATUS
141         );
142         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START LOOP" );
143
144      end loop;
145
146      TIMER_DRIVER.INITIALIZE;
147         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
148         loop
149            RTEMS.TASK_SUSPEND( TMTEST.TASK_ID( INDEX ), STATUS );
150         end loop;
151      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
152      TIME_TEST_SUPPORT.PUT_TIME(
153         "TASK_SUSPEND no preempt",
154         TMTEST.END_TIME,
155         TIME_TEST_SUPPORT.OPERATION_COUNT,
156         OVERHEAD,
157         RTEMS_CALLING_OVERHEAD.TASK_SUSPEND
158      );
159
160      TIMER_DRIVER.INITIALIZE;
161         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
162         loop
163            RTEMS.TASK_RESUME( TMTEST.TASK_ID( INDEX ), STATUS );
164         end loop;
165      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
166      TIME_TEST_SUPPORT.PUT_TIME(
167         "TASK_RESUME no preempt",
168         TMTEST.END_TIME,
169         TIME_TEST_SUPPORT.OPERATION_COUNT,
170         OVERHEAD,
171         RTEMS_CALLING_OVERHEAD.TASK_RESUME
172      );
173
174      TIMER_DRIVER.INITIALIZE;
175         for INDEX in 1 .. TIME_TEST_SUPPORT.OPERATION_COUNT
176         loop
177            RTEMS.TASK_DELETE( TMTEST.TASK_ID( INDEX ), STATUS );
178         end loop;
179      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
180      TIME_TEST_SUPPORT.PUT_TIME(
181         "TASK_DELETE others",
182         TMTEST.END_TIME,
183         TIME_TEST_SUPPORT.OPERATION_COUNT,
184         OVERHEAD,
185         RTEMS_CALLING_OVERHEAD.TASK_DELETE
186      );
187
188      RTEMS.SHUTDOWN_EXECUTIVE( 0 );
189
190   end TASK_1;
191
192--PAGE
193--
194--  NULL_TASK
195--
196
197   procedure NULL_TASK (
198      ARGUMENT : in     RTEMS.TASK_ARGUMENT
199   ) is
200   begin
201
202      NULL;
203
204   end NULL_TASK;
205
206end TMTEST;
Note: See TracBrowser for help on using the repository browser.