hc
2024-11-01 2f529f9b558ca1c1bd74be7437a84e4711743404
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
#include <stdio.h>
#include <stdlib.h>
#include <copperplate/traceobj.h>
#include <vxworks/errnoLib.h>
#include <vxworks/semLib.h>
#include <vxworks/tickLib.h>
 
static struct traceobj trobj;
 
#define WAIT_TIME  100
#define TOLERANCE  20
#define MIN_WAIT   (WAIT_TIME - TOLERANCE)
 
static SEM_ID sem_id;
 
static void rootTask(long arg, ...)
{
   ULONG start;
   int ret;
 
   traceobj_enter(&trobj);
 
   sem_id = semCCreate(SEM_Q_PRIORITY, 0);
   traceobj_assert(&trobj, sem_id != 0);
 
   start = tickGet();
   ret = semTake(sem_id, WAIT_TIME);
   traceobj_assert(&trobj, ret == ERROR && errno == S_objLib_OBJ_TIMEOUT);
   traceobj_assert(&trobj, tickGet() - start >= MIN_WAIT);
 
   start = tickGet();
   ret = semTake(sem_id, WAIT_TIME);
   traceobj_assert(&trobj, ret == ERROR && errno == S_objLib_OBJ_TIMEOUT);
   traceobj_assert(&trobj, tickGet() - start >= MIN_WAIT);
 
   start = tickGet();
   ret = semTake(sem_id, WAIT_TIME);
   traceobj_assert(&trobj, ret == ERROR && errno == S_objLib_OBJ_TIMEOUT);
   traceobj_assert(&trobj, tickGet() - start >= MIN_WAIT);
 
   ret = semGive(sem_id);
   traceobj_assert(&trobj, ret == OK);
   ret = semTake(sem_id, WAIT_TIME);
   traceobj_assert(&trobj, ret == OK);
   ret = semGive(sem_id);
   traceobj_assert(&trobj, ret == OK);
   ret = semGive(sem_id);
   traceobj_assert(&trobj, ret == OK);
   ret = semTake(sem_id, WAIT_FOREVER);
   traceobj_assert(&trobj, ret == OK);
   ret = semTake(sem_id, WAIT_FOREVER);
   traceobj_assert(&trobj, ret == OK);
 
   traceobj_exit(&trobj);
}
 
int main(int argc, char *const argv[])
{
   TASK_ID tid;
   int ret;
 
   traceobj_init(&trobj, argv[0], 0);
 
   tid = taskSpawn("rootTask", 50, 0, 0, rootTask,
           0, 0, 0, 0, 0, 0, 0, 0, 0, 0);
   traceobj_assert(&trobj, tid != ERROR);
 
   traceobj_join(&trobj);
 
   ret = semDelete(sem_id);
   traceobj_assert(&trobj, ret == OK);
 
   exit(0);
}