source: rtems/c/src/ada-tests/tmtests/tm18/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.1 KB
Line 
1--
2--  TMTEST / BODY
3--
4--  DESCRIPTION:
5--
6--  This package is the implementation of Test 18 of the RTEMS
7--  Timing Test Suite.
8--
9--  DEPENDENCIES:
10--
11-- 
12--
13--  COPYRIGHT (c) 1989-2011.
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.org/license/LICENSE.
19--
20
21with INTERFACES; use INTERFACES;
22with RTEMS_CALLING_OVERHEAD;
23with TEST_SUPPORT;
24with TEXT_IO;
25with TIME_TEST_SUPPORT;
26with TIMER_DRIVER;
27
28package body TMTEST is
29
30--
31--  INIT
32--
33
34   procedure INIT (
35      ARGUMENT : in     RTEMS.TASKS.ARGUMENT
36   ) is
37      pragma Unreferenced(ARGUMENT);
38      STATUS     : RTEMS.STATUS_CODES;
39   begin
40
41      TEXT_IO.NEW_LINE( 2 );
42      TEXT_IO.PUT_LINE( "*** TIME TEST 18 ***" );
43
44      TMTEST.TEST_INIT;
45
46      RTEMS.TASKS.DELETE( RTEMS.SELF, STATUS );
47      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_DELETE OF SELF" );
48
49   end INIT;
50
51--
52--  TEST_INIT
53--
54
55   procedure TEST_INIT
56   is
57      ID         : RTEMS.ID;
58      TASK_ENTRY : RTEMS.TASKS.ENTRY_POINT;
59      STATUS     : RTEMS.STATUS_CODES;
60   begin
61
62      for INDEX in 0 .. TIME_TEST_SUPPORT.OPERATION_COUNT
63      loop
64
65         RTEMS.TASKS.CREATE(
66            RTEMS.BUILD_NAME( 'T', 'I', 'M', 'E' ),
67            128,
68            1024,
69            RTEMS.DEFAULT_MODES,
70            RTEMS.DEFAULT_ATTRIBUTES,
71            ID,
72            STATUS
73         );
74         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_CREATE LOOP" );
75
76
77         if INDEX = TIME_TEST_SUPPORT.OPERATION_COUNT then
78            TASK_ENTRY := TMTEST.LAST_TASK'ACCESS;
79         elsif INDEX = 0 then
80            TASK_ENTRY := TMTEST.FIRST_TASK'ACCESS;
81         else
82            TASK_ENTRY := TMTEST.MIDDLE_TASKS'ACCESS;
83         end if;
84
85         RTEMS.TASKS.START( ID, TASK_ENTRY, 0, STATUS );
86         TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_START LOOP" );
87
88      end loop;
89
90   end TEST_INIT;
91
92--
93--  FIRST_TASK
94--
95
96   procedure FIRST_TASK (
97      ARGUMENT : in     RTEMS.TASKS.ARGUMENT
98   ) is
99      pragma Unreferenced(ARGUMENT);
100      STATUS : RTEMS.STATUS_CODES;
101   begin
102
103      TIMER_DRIVER.INITIALIZE;
104
105      RTEMS.TASKS.DELETE( RTEMS.SELF, STATUS );
106      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_DELETE" );
107
108   end FIRST_TASK;
109
110--
111--  MIDDLE_TASKS
112--
113
114   procedure MIDDLE_TASKS (
115      ARGUMENT : in     RTEMS.TASKS.ARGUMENT
116   ) is
117      pragma Unreferenced(ARGUMENT);
118      STATUS : RTEMS.STATUS_CODES;
119   begin
120
121      RTEMS.TASKS.DELETE( RTEMS.SELF, STATUS );
122      TEST_SUPPORT.DIRECTIVE_FAILED( STATUS, "TASK_DELETE" );
123
124   end MIDDLE_TASKS;
125
126--
127--  LAST_TASK
128--
129
130   procedure LAST_TASK (
131      ARGUMENT : in     RTEMS.TASKS.ARGUMENT
132   ) is
133      pragma Unreferenced(ARGUMENT);
134   begin
135
136      TMTEST.END_TIME := TIMER_DRIVER.READ_TIMER;
137
138      TIME_TEST_SUPPORT.PUT_TIME(
139         "TASK_DELETE (self)",
140         TMTEST.END_TIME,
141         TIME_TEST_SUPPORT.OPERATION_COUNT,
142         0,
143         RTEMS_CALLING_OVERHEAD.TASK_DELETE
144      );
145
146      TEXT_IO.PUT_LINE( "*** END OF TIME TEST 18 ***" );
147      RTEMS.SHUTDOWN_EXECUTIVE( 0 );
148
149   end LAST_TASK;
150
151end TMTEST;
Note: See TracBrowser for help on using the repository browser.