1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
|
/*
* COPYRIGHT (c) 1989-2011.
* On-Line Applications Research Corporation (OAR).
*
* The license and distribution terms for this file may be
* found in the file LICENSE in this distribution or at
* http://www.rtems.org/license/LICENSE.
*/
#ifdef HAVE_CONFIG_H
#include "config.h"
#endif
#include <stdio.h>
#include <rtems.h>
#include <rtems/error.h>
static rtems_id taskId1;
static rtems_id taskId2;
rtems_interval ticksPerSecond;
#include "system.h"
static int
isSuspended (rtems_id tid)
{
rtems_status_code sc;
sc = rtems_task_is_suspended (tid);
if (sc == RTEMS_ALREADY_SUSPENDED)
return 1;
if (sc != RTEMS_SUCCESSFUL)
printf ("rtems_task_is_suspended: %s\n", rtems_status_text (sc));
return 0;
}
static void
subTask1 (rtems_task_argument arg)
{
rtems_status_code sc;
rtems_task_wake_after (ticksPerSecond * 3);
sc = rtems_event_send (taskId2, 1);
if (sc != RTEMS_SUCCESSFUL) {
printf ("subTask1 - Can't send event (%d)\n", sc);
rtems_task_suspend (RTEMS_SELF);
}
rtems_task_wake_after (ticksPerSecond * 3);
printf ("subTask1 - Event sent\n");
rtems_task_suspend (RTEMS_SELF);
printf ("subTask1 - Back to task 1\n");
rtems_task_wake_after (ticksPerSecond * 3);
rtems_task_suspend (RTEMS_SELF);
}
static void
subTask2 (rtems_task_argument arg)
{
rtems_status_code sc;
rtems_event_set ev;
rtems_task_wake_after (ticksPerSecond * 1);
sc = rtems_event_receive(
1,
RTEMS_WAIT|RTEMS_EVENT_ANY,
RTEMS_NO_TIMEOUT,
&ev
);
if (sc != RTEMS_SUCCESSFUL) {
printf ("subTask2 - Can't receive event (%d)\n", sc);
rtems_task_suspend (RTEMS_SELF);
}
printf ("subTask2 - Task 1 suspended? - should be 0: %d\n",
isSuspended (taskId1));
rtems_task_wake_after (ticksPerSecond * 4);
printf ("subTask2 - Task 1 suspended? - should be 1: %d\n",
isSuspended (taskId1));
rtems_task_resume (taskId1);
printf ("subTask2 - Task 1 suspended? - should be 0: %d\n",
isSuspended (taskId1));
rtems_task_wake_after (ticksPerSecond * 4);
printf ("subTask2 - Task 1 suspended? - should be 1: %d\n",
isSuspended (taskId1));
TEST_END();
rtems_test_exit( 0 );
}
static void
createTask (char c, rtems_id *tid)
{
rtems_status_code sc;
sc = rtems_task_create (rtems_build_name('S','u','b',c),
RTEMS_MAXIMUM_PRIORITY - 1u,
RTEMS_MINIMUM_STACK_SIZE * 4,
RTEMS_PREEMPT|RTEMS_NO_TIMESLICE|RTEMS_NO_ASR|RTEMS_INTERRUPT_LEVEL(0),
RTEMS_NO_FLOATING_POINT|RTEMS_LOCAL,
tid);
if (sc != RTEMS_SUCCESSFUL) {
printf ("Can't create task (%d)\n", sc);
rtems_task_suspend (RTEMS_SELF);
}
}
static void
startTask (rtems_id tid, rtems_task_entry entry_point)
{
rtems_status_code sc;
sc = rtems_task_start (tid, entry_point, 0);
if (sc != RTEMS_SUCCESSFUL) {
printf ("Can't start task (%d)\n", sc);
rtems_task_suspend (RTEMS_SELF);
}
}
void
task1 (void)
{
ticksPerSecond = rtems_clock_get_ticks_per_second();
createTask ('1', &taskId1);
createTask ('2', &taskId2);
startTask (taskId1, subTask1);
startTask (taskId2, subTask2);
rtems_task_suspend (RTEMS_SELF);
}
|