summaryrefslogtreecommitdiff
path: root/databases/mysql-server/patches/patch-ai
blob: 258fd1d378177d08cb50aaf85e4000e447fd067e (plain)
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
$NetBSD: patch-ai,v 1.3 2001/01/10 06:03:15 briggs Exp $

*** /dev/null	Wed Dec 31 19:00:00 1969
--- mit-pthreads/machdep/engine-powerpc-netbsd.h	Tue Jan  9 22:35:36 2001
***************
*** 0 ****
--- 1,109 ----
+ /* ==== machdep.h ============================================================
+  * Copyright (c) 1994 Chris Provenzano (proven@athena.mit.edu) and
+  * Ken Raeburn (raeburn@mit.edu).
+  *
+  * engine-alpha-osf1.h,v 1.4.4.1 1995/12/13 05:41:42 proven Exp
+  *
+  */
+ 
+ #include <unistd.h>
+ #include <setjmp.h>
+ #include <sys/time.h>
+ #include <sys/cdefs.h>
+ #include <sys/signal.h>  /* for _NSIG */
+ 
+ /*
+  * The first machine dependent functions are the SEMAPHORES
+  * needing the test and set instruction.
+  */
+ #define SEMAPHORE_CLEAR 0
+ #define SEMAPHORE_SET   0xffff
+ 
+ #define SEMAPHORE_TEST_AND_SET(lock)            \
+ ({                                              \
+         volatile long t1, temp = SEMAPHORE_SET; \
+         __asm__ volatile(                       \
+ 	  "1: lwarx  %0,0,%1;			\
+ 	      cmpwi  %0, 0;                     \
+ 	      bne    2f;                        \
+ 	      stwcx. %2,0,%1;                   \
+ 	      bne-   1b;                        \
+ 	   2: "                                 \
+           :"=r" (t1)                            \
+           :"m" (lock), "r" (temp));             \
+         t1;                                     \
+ })
+ 
+ #define SEMAPHORE_RESET(lock)           *lock = SEMAPHORE_CLEAR
+ 
+ /*
+  * New types
+  */
+ typedef int semaphore;
+ 
+ /*
+  * sigset_t macros
+  */
+ #define        SIG_ANY(sig)            (sig)
+ #define        SIGMAX                  (_NSIG-1)
+ 
+ /*
+  * New Strutures
+  */
+ struct machdep_pthread {
+     void                       *(*start_routine)(void *);
+     void                       *start_argument;
+     void                       *machdep_stack;
+     struct itimerval           machdep_timer;
+     jmp_buf	               machdep_istate;
+     unsigned long              machdep_fstate[66];
+ 				/* 64-bit fp regs 0-31 + fpscr */
+ 				/* We pretend the fpscr is 64 bits */
+ };
+ 
+ /*
+  * Static machdep_pthread initialization values.
+  * For initial thread only.
+  */
+ #define MACHDEP_PTHREAD_INIT    \
+        { NULL, NULL, NULL, { { 0, 0 }, { 0, 100000 } }, { 0 }, { 0 } }
+ 
+ /*
+  * Minimum stack size
+  */
+ #define PTHREAD_STACK_MIN      2048
+ 
+ /*
+  * Some fd flag defines that are necessary to distinguish between posix
+  * behavior and bsd4.3 behavior.
+  */
+ #define __FD_NONBLOCK          O_NONBLOCK
+ 
+ /*
+  * 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);                              \
+ }
+ 
+ int machdep_save_state(void);
+ 
+ void __machdep_save_fp_state(unsigned long *);
+ void __machdep_restore_fp_state(unsigned long *);
+ void *__machdep_stack_alloc(size_t);
+ void __machdep_stack_free(void *);
+ 
+ #endif
+ 
+ __END_DECLS