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
128
129
|
/* ==== machdep.h ============================================================
* Copyright (c) 1994 Chris Provenzano, proven@athena.mit.edu
*
* $Id: engine-sparc-sunos-5.3.h,v 1.1 1998/07/21 13:19:15 peter Exp $
*
*/
#include <unistd.h>
#include <setjmp.h>
#include <sys/time.h>
#include <sys/cdefs.h>
/*
* The first machine dependent functions are the SEMAPHORES
* needing the test and set instruction.
*/
#define SEMAPHORE_CLEAR 0
#define SEMAPHORE_SET 0xff
#define SEMAPHORE_TEST_AND_SET(lock) \
({ \
char *p = lock; \
long temp; \
\
__asm__ volatile("ldstub %1,%0" \
:"=r" (temp) \
:"m" (*p) \
:"memory"); \
temp; \
})
#define SEMAPHORE_RESET(lock) \
{ \
__asm__ volatile("stb %1, %0" \
:"=m" (*lock) \
:"r" (SEMAPHORE_CLEAR) \
:"memory"); \
}
/*
* More machine dependent macros
*/
#ifdef PTHREAD_KERNEL
#define machdep_save_float_state(x)
#define machdep_restore_float_state()
#endif
/*
* New types
*/
typedef char semaphore;
/*
* sigset_t macros
*/
#define SIGMAX 31
#define SIG_ANY(sig) \
({ \
sigset_t *sig_addr = (sigset_t *)&sig; \
int ret = 0; \
int i; \
\
for (i = 1; i <= SIGMAX; i++) { \
if (sigismember(sig_addr, i)) { \
ret = 1; \
break; \
} \
} \
ret; \
})
/*
* New Strutures
*/
struct machdep_pthread {
void *(*start_routine)(void *);
void *start_argument;
void *machdep_stack;
struct itimerval machdep_timer;
jmp_buf machdep_state;
};
/*
* Static machdep_pthread initialization values.
* For initial thread only.
*/
#define MACHDEP_PTHREAD_INIT \
{ NULL, NULL, NULL, { { 0, 0 }, { 0, 100000 } }, 0 }
/*
* Minimum stack size
*/
#undef PTHREAD_STACK_MIN /* Defined in limits.h */
#define PTHREAD_STACK_MIN 1024
/*
* Some fd flag defines that are necessary to distinguish between posix
* behavior and bsd4.3 behavior.
*/
#define __FD_NONBLOCK (O_NONBLOCK | O_NDELAY)
/*
* New functions
*/
__BEGIN_DECLS
#if defined(PTHREAD_KERNEL)
#define __machdep_stack_get(x) (x)->machdep_stack
#define __machdep_stack_set(x, y) (x)->machdep_stack = y
#define __machdep_stack_repl(x, y) \
{ \
if (stack = __machdep_stack_get(x)) { \
__machdep_stack_free(stack); \
} \
__machdep_stack_set(x, y); \
}
void * __machdep_stack_alloc __P_((size_t));
void __machdep_stack_free __P_((void *));
int machdep_save_state __P_((void));
#endif
__END_DECLS
|