source: rtems/c/src/ada-tests/tmtests/tm05/tmtest.adb @ 110e1f1

4.104.115
Last change on this file since 110e1f1 was 110e1f1, checked in by Joel Sherrill <joel.sherrill@…>, on 12/14/09 at 21:17:59

2009-12-14 Joel Sherrill <joel.sherrill@…>

  • samples/base_sp/sptest.adb, samples/hello/sptest.adb, samples/nsecs/sptest.adb, samples/ticker/sptest.adb, sptests/sp01/sptest.adb, sptests/sp02/sptest.adb, sptests/sp03/sptest.adb, sptests/sp04/sptest.adb, sptests/sp05/sptest.adb, sptests/sp06/sptest.adb, sptests/sp07/sptest.adb, sptests/sp08/sptest.adb, sptests/sp09/sptest.adb, sptests/sp11/sptest.adb, sptests/sp12/sptest.adb, sptests/sp13/sptest.adb, sptests/sp14/sptest.adb, sptests/sp15/sptest.adb, sptests/sp16/sptest.adb, sptests/sp17/sptest.adb, sptests/sp19/sptest.adp, sptests/sp20/sptest.adb, sptests/sp22/sptest.adb, sptests/sp23/sptest.adb, sptests/sp24/sptest.adb, sptests/sp25/sptest.adb, sptests/spname01/spname01.adb, sptests/spname01/sptest.adb, sptests/spname01/sptest.ads, support/address_io.adb, support/init.c, support/test_support.adb, support/test_support.ads, support/time_test_support.adb, support/timer_driver.adb, tmtests/tm01/tmtest.adb, tmtests/tm01/tmtest.ads, tmtests/tm02/tmtest.adb, tmtests/tm02/tmtest.ads, tmtests/tm03/tmtest.adb, tmtests/tm03/tmtest.ads, tmtests/tm04/tmtest.adb, tmtests/tm04/tmtest.ads, tmtests/tm05/tmtest.adb, tmtests/tm05/tmtest.ads, tmtests/tm06/tmtest.adb, tmtests/tm06/tmtest.ads, tmtests/tm07/tmtest.adb, tmtests/tm07/tmtest.ads, tmtests/tm08/tmtest.adb, tmtests/tm08/tmtest.ads, tmtests/tm09/tmtest.adb, tmtests/tm09/tmtest.ads, tmtests/tm10/tmtest.adb, tmtests/tm10/tmtest.ads, tmtests/tm11/tmtest.adb, tmtests/tm11/tmtest.ads, tmtests/tm12/tmtest.adb, tmtests/tm12/tmtest.ads, tmtests/tm13/tmtest.adb, tmtests/tm13/tmtest.ads, tmtests/tm14/tmtest.adb, tmtests/tm14/tmtest.ads, tmtests/tm15/tmtest.adb, tmtests/tm15/tmtest.ads, tmtests/tm16/tmtest.adb, tmtests/tm16/tmtest.ads, tmtests/tm17/tmtest.adb, tmtests/tm17/tmtest.ads, tmtests/tm18/tmtest.adb, tmtests/tm18/tmtest.ads, tmtests/tm19/tmtest.adb, tmtests/tm19/tmtest.ads, tmtests/tm20/tmtest.adb, tmtests/tm20/tmtest.ads, tmtests/tm21/tmtest.adb, tmtests/tm21/tmtest.ads, tmtests/tm22/tmtest.adb, tmtests/tm22/tmtest.ads, tmtests/tm23/tmtest.adb, tmtests/tm23/tmtest.ads, tmtests/tm24/tmtest.adb, tmtests/tm24/tmtest.ads, tmtests/tm25/tmtest.adb, tmtests/tm25/tmtest.ads, tmtests/tm28/tmtest.adb, tmtests/tm28/tmtest.ads, tmtests/tm29/tmtest.adb, tmtests/tm29/tmtest.ads, tmtests/tmck/tmtest.adb, tmtests/tmck/tmtest.ads, tmtests/tmoverhd/dummy_rtems.adb, tmtests/tmoverhd/tmtest.adb, tmtests/tmoverhd/tmtest.ads: Remove many warnings.
  • Property mode set to 100644
File size: 3.6 KB
Line 
1--
2--  TMTEST / BODY
3--
4--  DESCRIPTION:
5--
6--  This package is the implementation of Test 5 of the RTEMS
7--  Timing Test Suite.
8--
9--  DEPENDENCIES:
10--
11-- 
12--
13--  COPYRIGHT (c) 1989-2009.
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_CALLING_OVERHEAD;
25with TEST_SUPPORT;
26with TEXT_IO;
27with TIMER_DRIVER;
28
29package body TMTEST is
30
31--PAGE
32--
33--  INIT
34--
35
36   procedure INIT (
37      ARGUMENT : in     RTEMS.TASK_ARGUMENT
38   ) is
39      pragma Unreferenced(ARGUMENT);
40      STATUS  : RTEMS.STATUS_CODES;
41   begin
42
43      TEXT_IO.NEW_LINE( 2 );
44      TEXT_IO.PUT_LINE( "*** TIME TEST 5 ***" );
45
46      TMTEST.TEST_INIT;
47
48      RTEMS.TASK_DELETE( RTEMS.SELF, STATUS );
49      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_DELETE OF SELF" );
50
51   end INIT;
52
53--PAGE
54--
55--  TEST_INIT
56--
57
58   procedure TEST_INIT
59   is
60      TASK_ENTRY : RTEMS.TASK_ENTRY;
61      PRIORITY   : RTEMS.TASK_PRIORITY;
62      STATUS     : RTEMS.STATUS_CODES;
63   begin
64
65      PRIORITY := 250;
66
67      for INDEX in 0 .. TIME_TEST_SUPPORT.OPERATION_COUNT
68      loop
69
70         RTEMS.TASK_CREATE(
71            RTEMS.BUILD_NAME( 'T', 'I', 'M', 'E' ),
72            PRIORITY,
73            1024,
74            RTEMS.DEFAULT_MODES,
75            RTEMS.DEFAULT_ATTRIBUTES,
76            TMTEST.TASK_ID( INDEX ),
77            STATUS
78         );
79         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE LOOP" );
80
81         PRIORITY := PRIORITY - 1;
82
83         if INDEX = 0 then
84            TASK_ENTRY := TMTEST.LOW_TASK'ACCESS;
85         elsif INDEX = TIME_TEST_SUPPORT.OPERATION_COUNT then
86            TASK_ENTRY := TMTEST.HIGH_TASK'ACCESS;
87         else
88            TASK_ENTRY := TMTEST.MIDDLE_TASKS'ACCESS;
89         end if;
90
91         RTEMS.TASK_START( TMTEST.TASK_ID( INDEX ), TASK_ENTRY, 0, STATUS );
92         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START LOOP" );
93
94      end loop;
95
96   end TEST_INIT;
97
98--PAGE
99--
100--  HIGH_TASK
101--
102
103   procedure HIGH_TASK (
104      ARGUMENT : in     RTEMS.TASK_ARGUMENT
105   ) is
106      pragma Unreferenced(ARGUMENT);
107      STATUS       : RTEMS.STATUS_CODES;
108   begin
109
110      TIMER_DRIVER.INITIALIZE;
111         RTEMS.TASK_SUSPEND( RTEMS.SELF, STATUS );
112
113      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
114      TIME_TEST_SUPPORT.PUT_TIME(
115         "TASK_RESUME causing preempt",
116         TMTEST.END_TIME,
117         TIME_TEST_SUPPORT.OPERATION_COUNT,
118         0,
119         RTEMS_CALLING_OVERHEAD.TASK_RESUME
120      );
121
122      TEXT_IO.PUT_LINE( "*** END OF TIME TEST 5 ***" );
123      RTEMS.SHUTDOWN_EXECUTIVE( 0 );
124
125   end HIGH_TASK;
126
127--PAGE
128--
129--  MIDDLE_TASKS
130--
131
132   procedure MIDDLE_TASKS (
133      ARGUMENT : in     RTEMS.TASK_ARGUMENT
134   ) is
135      pragma Unreferenced(ARGUMENT);
136      STATUS       : RTEMS.STATUS_CODES;
137   begin
138 
139      RTEMS.TASK_SUSPEND( RTEMS.SELF, STATUS );
140
141      TMTEST.TASK_INDEX := TMTEST.TASK_INDEX + 1;
142      RTEMS.TASK_RESUME( TMTEST.TASK_ID( TMTEST.TASK_INDEX ), STATUS );
143 
144   end MIDDLE_TASKS;
145
146--PAGE
147--
148--  LOW_TASK
149--
150
151   procedure LOW_TASK (
152      ARGUMENT : in     RTEMS.TASK_ARGUMENT
153   ) is
154      pragma Unreferenced(ARGUMENT);
155      STATUS   : RTEMS.STATUS_CODES;
156   begin
157
158      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
159      TIME_TEST_SUPPORT.PUT_TIME(
160         "TASK_SUSPEND self",
161         TMTEST.END_TIME,
162         TIME_TEST_SUPPORT.OPERATION_COUNT,
163         0,
164         RTEMS_CALLING_OVERHEAD.TASK_SUSPEND
165      );
166   
167      TMTEST.TASK_INDEX := 1;
168      TIMER_DRIVER.INITIALIZE;
169      RTEMS.TASK_RESUME( TMTEST.TASK_ID( TMTEST.TASK_INDEX ), STATUS );
170
171   end LOW_TASK;
172
173end TMTEST;
Note: See TracBrowser for help on using the repository browser.