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

4.115
Last change on this file since c499856 was c499856, checked in by Chris Johns <chrisj@…>, on 03/20/14 at 21:10:47

Change all references of rtems.com to rtems.org.

  • Property mode set to 100644
File size: 3.9 KB
RevLine 
[6d4e604b]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--
[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;
[110e1f1]25with TIMER_DRIVER;
[6d4e604b]26
27package body TMTEST is
28
29--
30--  INIT
31--
32
33   procedure INIT (
[3c4d8cd1]34      ARGUMENT : in     RTEMS.TASKS.ARGUMENT
[6d4e604b]35   ) is
[110e1f1]36      pragma Unreferenced(ARGUMENT);
[6d4e604b]37      STATUS  : RTEMS.STATUS_CODES;
38   begin
39
40      TEXT_IO.NEW_LINE( 2 );
41      TEXT_IO.PUT_LINE( "*** TIME TEST 5 ***" );
42
43      TMTEST.TEST_INIT;
44
[3c4d8cd1]45      RTEMS.TASKS.DELETE( RTEMS.SELF, STATUS );
[6d4e604b]46      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_DELETE OF SELF" );
47
48   end INIT;
49
50--
51--  TEST_INIT
52--
53
54   procedure TEST_INIT
55   is
[3c4d8cd1]56      TASK_ENTRY : RTEMS.TASKS.ENTRY_POINT;
57      PRIORITY   : RTEMS.TASKS.PRIORITY;
[6d4e604b]58      STATUS     : RTEMS.STATUS_CODES;
59   begin
60
61      PRIORITY := 250;
62
63      for INDEX in 0 .. TIME_TEST_SUPPORT.OPERATION_COUNT
64      loop
65
[3c4d8cd1]66         RTEMS.TASKS.CREATE(
[6d4e604b]67            RTEMS.BUILD_NAME( 'T', 'I', 'M', 'E' ),
68            PRIORITY,
69            1024,
70            RTEMS.DEFAULT_MODES,
71            RTEMS.DEFAULT_ATTRIBUTES,
72            TMTEST.TASK_ID( INDEX ),
73            STATUS
74         );
75         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE LOOP" );
76
77         PRIORITY := PRIORITY - 1;
78
79         if INDEX = 0 then
80            TASK_ENTRY := TMTEST.LOW_TASK'ACCESS;
81         elsif INDEX = TIME_TEST_SUPPORT.OPERATION_COUNT then
82            TASK_ENTRY := TMTEST.HIGH_TASK'ACCESS;
83         else
84            TASK_ENTRY := TMTEST.MIDDLE_TASKS'ACCESS;
85         end if;
86
[3c4d8cd1]87         RTEMS.TASKS.START( TMTEST.TASK_ID( INDEX ), TASK_ENTRY, 0, STATUS );
[6d4e604b]88         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START LOOP" );
89
90      end loop;
91
92   end TEST_INIT;
93
94--
95--  HIGH_TASK
96--
97
98   procedure HIGH_TASK (
[3c4d8cd1]99      ARGUMENT : in     RTEMS.TASKS.ARGUMENT
[6d4e604b]100   ) is
[110e1f1]101      pragma Unreferenced(ARGUMENT);
[6d4e604b]102      STATUS       : RTEMS.STATUS_CODES;
103   begin
104
105      TIMER_DRIVER.INITIALIZE;
[3c4d8cd1]106         RTEMS.TASKS.SUSPEND( RTEMS.SELF, STATUS );
107         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_SUSPENT" );
[6d4e604b]108
109      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
110      TIME_TEST_SUPPORT.PUT_TIME(
111         "TASK_RESUME causing preempt",
112         TMTEST.END_TIME,
113         TIME_TEST_SUPPORT.OPERATION_COUNT,
114         0,
115         RTEMS_CALLING_OVERHEAD.TASK_RESUME
116      );
117
[a8e724d6]118      TEXT_IO.PUT_LINE( "*** END OF TIME TEST 5 ***" );
[6d4e604b]119      RTEMS.SHUTDOWN_EXECUTIVE( 0 );
120
121   end HIGH_TASK;
122
123--
124--  MIDDLE_TASKS
125--
126
127   procedure MIDDLE_TASKS (
[3c4d8cd1]128      ARGUMENT : in     RTEMS.TASKS.ARGUMENT
[6d4e604b]129   ) is
[110e1f1]130      pragma Unreferenced(ARGUMENT);
[6d4e604b]131      STATUS       : RTEMS.STATUS_CODES;
132   begin
133 
[3c4d8cd1]134      RTEMS.TASKS.SUSPEND( RTEMS.SELF, STATUS );
135      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_SUSPEND" );
[6d4e604b]136
137      TMTEST.TASK_INDEX := TMTEST.TASK_INDEX + 1;
[3c4d8cd1]138      RTEMS.TASKS.RESUME( TMTEST.TASK_ID( TMTEST.TASK_INDEX ), STATUS );
139      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_RESUME" );
[6d4e604b]140 
141   end MIDDLE_TASKS;
142
143--
144--  LOW_TASK
145--
146
147   procedure LOW_TASK (
[3c4d8cd1]148      ARGUMENT : in     RTEMS.TASKS.ARGUMENT
[6d4e604b]149   ) is
[110e1f1]150      pragma Unreferenced(ARGUMENT);
[6d4e604b]151      STATUS   : RTEMS.STATUS_CODES;
152   begin
153
154      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
155      TIME_TEST_SUPPORT.PUT_TIME(
156         "TASK_SUSPEND self",
157         TMTEST.END_TIME,
158         TIME_TEST_SUPPORT.OPERATION_COUNT,
159         0,
160         RTEMS_CALLING_OVERHEAD.TASK_SUSPEND
161      );
162   
163      TMTEST.TASK_INDEX := 1;
164      TIMER_DRIVER.INITIALIZE;
[3c4d8cd1]165      RTEMS.TASKS.RESUME( TMTEST.TASK_ID( TMTEST.TASK_INDEX ), STATUS );
166      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_RESUME" );
[6d4e604b]167
168   end LOW_TASK;
169
170end TMTEST;
Note: See TracBrowser for help on using the repository browser.