source: rtems/testsuites/tmtests/tm11/task1.c @ 8f71a36

4.104.114.84.95
Last change on this file since 8f71a36 was 8f71a36, checked in by Ralf Corsepius <ralf.corsepius@…>, on 04/20/04 at 07:09:31

Remove stray white spaces.

  • Property mode set to 100644
File size: 3.2 KB
RevLine 
[ac7d5ef0]1/*
2 *
[08311cc3]3 *  COPYRIGHT (c) 1989-1999.
[ac7d5ef0]4 *  On-Line Applications Research Corporation (OAR).
5 *
[98e4ebf5]6 *  The license and distribution terms for this file may be
7 *  found in the file LICENSE in this distribution or at
[95a81ab]8 *  http://www.rtems.com/license/LICENSE.
[ac7d5ef0]9 *
[3235ad9]10 *  $Id$
[ac7d5ef0]11 */
12
[3a4ae6c]13#define TEST_INIT
[ac7d5ef0]14#include "system.h"
15
16rtems_id Queue_id;
17
18long Buffer[4];
19
20rtems_task test_init(
21  rtems_task_argument argument
22);
23
24rtems_task Middle_tasks(
25  rtems_task_argument argument
26);
27
28rtems_task High_task(
29  rtems_task_argument argument
30);
31
32
33void Init(
34  rtems_task_argument argument
35)
36{
37  rtems_status_code status;
38  rtems_id id;
39
[3a4ae6c]40  Print_Warning();
41
[ac7d5ef0]42  puts( "\n\n*** TIME TEST 11 ***" );
43
44  status = rtems_task_create(
45    1,
46    251,
[3652ad35]47    RTEMS_MINIMUM_STACK_SIZE,
[ac7d5ef0]48    RTEMS_DEFAULT_MODES,
49    RTEMS_DEFAULT_ATTRIBUTES,
50    &id
51  );
52  directive_failed( status, "rtems_task_create" );
53
54  status = rtems_task_start( id, test_init, 0 );
55  directive_failed( status, "rtems_task_start" );
56
57  status = rtems_task_delete( RTEMS_SELF );
58  directive_failed( status, "rtems_task_delete of RTEMS_SELF" );
59}
60
[df49c60]61#define MESSAGE_SIZE (sizeof(long) * 4)
62
[ac7d5ef0]63rtems_task test_init(
64  rtems_task_argument argument
65)
66{
[0720ff4]67  uint32_t      index;
[ac7d5ef0]68  rtems_task_entry    task_entry;
69  rtems_task_priority priority;
70  rtems_id            task_id;
71  rtems_status_code   status;
72
73/*  As each task is started, it preempts this task and
74 *  performs a blocking rtems_message_queue_receive.  Upon completion of
75 *  this loop all created tasks are blocked.
76 */
77
78  status = rtems_message_queue_create(
79    rtems_build_name( 'M', 'Q', '1', ' '  ),
80    OPERATION_COUNT,
[df49c60]81    MESSAGE_SIZE,
[ac7d5ef0]82    RTEMS_DEFAULT_ATTRIBUTES,
83    &Queue_id
84  );
85  directive_failed( status, "rtems_message_queue_create" );
86
87  priority = 250;
88
89  for( index = 0; index < OPERATION_COUNT ; index++ ) {
90    status = rtems_task_create(
91      rtems_build_name( 'T', 'I', 'M', 'E'  ),
92      priority,
[3652ad35]93      RTEMS_MINIMUM_STACK_SIZE,
[ac7d5ef0]94      RTEMS_DEFAULT_MODES,
95      RTEMS_DEFAULT_ATTRIBUTES,
96      &task_id
97    );
98    directive_failed( status, "rtems_task_create LOOP" );
99
100    priority--;
101
102    if ( index==OPERATION_COUNT-1 ) task_entry = High_task;
103    else                            task_entry = Middle_tasks;
104
105    status = rtems_task_start( task_id, task_entry, 0 );
106    directive_failed( status, "rtems_task_start LOOP" );
107  }
108
109  Timer_initialize();
[df49c60]110    (void) rtems_message_queue_send( Queue_id, Buffer, MESSAGE_SIZE );
[ac7d5ef0]111}
112
113rtems_task Middle_tasks(
114  rtems_task_argument argument
115)
116{
[0720ff4]117  uint32_t   size;
[4b374f36]118
[ac7d5ef0]119  (void) rtems_message_queue_receive(
120           Queue_id,
121           (long (*)[4]) Buffer,
[4b374f36]122           &size,
[ac7d5ef0]123           RTEMS_DEFAULT_OPTIONS,
124           RTEMS_NO_TIMEOUT
125         );
126
[4b374f36]127  (void) rtems_message_queue_send( Queue_id, (long (*)[4]) Buffer, size );
[ac7d5ef0]128}
129
130rtems_task High_task(
131  rtems_task_argument argument
132)
133{
[0720ff4]134  uint32_t   size;
[8f71a36]135
[ac7d5ef0]136  (void) rtems_message_queue_receive(
137           Queue_id,
138           (long (*)[4]) Buffer,
[4b374f36]139           &size,
[ac7d5ef0]140           RTEMS_DEFAULT_OPTIONS,
141           RTEMS_NO_TIMEOUT
142         );
143
144  end_time = Read_timer();
145
146  put_time(
[5c491aef]147    "rtems_message_queue_send: task readied -- preempts caller",
[ac7d5ef0]148    end_time,
149    OPERATION_COUNT,
150    0,
151    CALLING_OVERHEAD_MESSAGE_QUEUE_SEND
152  );
153
[3a4ae6c]154  puts( "*** END OF TEST 11 ***" );
[b454bc9]155  rtems_test_exit( 0 );
[ac7d5ef0]156}
Note: See TracBrowser for help on using the repository browser.