obsd44-pass1-20090123
[openafs.git] / src / afs / OBSD / osi_machdep.h
1 /*
2  * Copyright 2000, International Business Machines Corporation and others.
3  * All Rights Reserved.
4  * 
5  * This software has been released under the terms of the IBM Public
6  * License.  For details, see the LICENSE file in the top-level source
7  * directory or online at http://www.openafs.org/dl/license10.html
8  */
9
10 /*
11  *
12  * OpenBSD OSI header file. Extends afs_osi.h.
13  *
14  * afs_osi.h includes this file, which is the only way this file should
15  * be included in a source file. This file can redefine macros declared in
16  * afs_osi.h.
17  */
18
19 /* $Id$ */
20
21 #ifndef _OSI_MACHDEP_H_
22 #define _OSI_MACHDEP_H_
23
24 #include <sys/lock.h>
25
26 #define M_AFSFID        (M_TEMP-1)
27 #define M_AFSBUFHDR     (M_TEMP-2)
28 #define M_AFSBUFFER     (M_TEMP-3)
29 #define M_AFSGENERIC    (M_TEMP-4)
30
31 /* vfs */
32 #define osi_vfs         mount
33 #define osi_vfs_bsize   mnt_stat.f_bsize
34 #define osi_vfs_fsid    mnt_stat.f_fsid
35 #define vfs_bsize       mnt_stat.f_bsize
36 #define vfs_fsid        mnt_stat.f_fsid
37 #define vfs_vnodecovered mnt_vnodecovered
38 #define v_vfsp          v_mount
39
40 /* vnode */
41 #define VN_HOLD(vp)     afs_vget((vp), 0)
42 #define VN_RELE(vp)     vrele(vp)
43 #define osi_vnhold(avc, r) afs_vget(AFSTOV(avc), 0)
44 #define va_nodeid       va_fileid
45 #define vnode_t         struct vnode
46
47 /* uio */
48 #define afsio_iov       uio_iov
49 #define afsio_iovcnt    uio_iovcnt
50 #define afsio_offset    uio_offset
51 #define afsio_resid     uio_resid
52 #define afsio_seg       uio_segflg
53 #define AFS_UIOSYS      UIO_SYSSPACE
54 #define AFS_UIOUSER     UIO_USERSPACE
55
56 /* malloc */
57 inline void afs_osi_Free(void *buf, size_t asize);
58 inline void afs_osi_FreeStr(char *x);
59 extern void *osi_obsd_Alloc(size_t asize, int cansleep);
60 extern void osi_obsd_Free(void *p, size_t asize);
61
62 #define afs_osi_Alloc_NoSleep(asize) osi_obsd_Alloc((asize), 0)
63 #define afs_osi_Alloc(asize) osi_obsd_Alloc((asize), 1)
64 #define afs_osi_FreeStr(s) afs_osi_Free((s), strlen((s)) + 1)
65 #define afs_osi_Free(buf, asize) osi_obsd_Free((buf), (asize))
66
67 #ifdef AFS_KALLOC
68 #undef AFS_KALLOC
69 #define AFS_KALLOC(s) osi_obsd_Alloc((s), 1 /* cansleep */)
70 #endif
71
72 #ifdef AFS_KFREE
73 #undef AFS_KFREE
74 #define AFS_KFREE(p, s) (osi_obsd_Free((p), (s)))
75 #endif
76
77 #ifdef AFS_OBSD42_ENV
78 /* removed, live with it */
79 #define BSD_KMALLOC(p, ptype, msize, mtype, mflags)     \
80   (p) = malloc((msize), (mtype), (mflags))
81
82 #define BSD_KFREE(p, mflags) \
83   free((p), (mflags))
84 #else
85 #define BSD_KMALLOC MALLOC
86 #define BSD_KFREE KFREE
87 #endif /* AFS_OBSD42_ENV */
88
89 /* proc, cred */
90 #define AFS_PROC        struct proc
91 #define AFS_UCRED       ucred
92 #define afs_suser(x)    afs_osi_suser(osi_curcred())
93 #define getpid()        curproc
94 #define osi_curcred()   (curproc->p_cred->pc_ucred)
95 #define osi_curproc()   curproc
96 #define p_rcred         p_ucred
97
98 /* time */
99 #define afs_hz          hz
100 #define osi_GetTime(x)  microtime(x)
101 extern time_t osi_Time();
102
103 /* str */
104 #define afs_strcasecmp(s1, s2)  strncasecmp((s1), (s2), 65535)
105 #ifdef AFS_OBSD34_ENV
106 #define strcpy(s1, s2)          afs_strcpy((s1), (s2))
107 #define strcat(s1, s2)          afs_strcat((s1), (s2))
108 #else
109 #define afs_strcat(s1, s2)      strcat((s1), (s2))
110 #endif
111
112 /* other */
113 #define afs_bufferpages bufpages
114 #ifndef iodone
115 #define iodone biodone
116 #endif
117 #define printk          printf  /* for RX version of xdr_* */
118 #define setgroups       sys_setgroups
119 #define UVM
120
121 /* This is not always in scope yet */
122 struct vcache;
123
124 extern int afs_obsd_lookupname(char *fnamep, enum uio_seg segflg,
125                                int followlink, struct vnode **compvpp);
126 extern void afs_obsd_getnewvnode(struct vcache *tvc);
127 extern void *afs_obsd_Alloc(size_t asize);
128 extern void afs_obsd_Free(void *p, size_t asize);
129 extern int afs_vget();
130
131 #undef gop_lookupname
132 #define gop_lookupname(fnamep, segflg, followlink, compvpp) \
133         afs_nbsd_lookupname((fnamep), (segflg), (followlink), (compvpp))
134
135 #ifdef AFS_OBSD39_ENV
136 #define afs_osi_lockmgr(l, f, i, p) lockmgr((l), (f), (i))
137 #else
138 #define afs_osi_lockmgr(l, f, i, p) lockmgr((l), (f), (i), (p))
139 #endif
140
141 #ifdef KERNEL
142
143 #ifdef AFS_OBSD44_ENV
144 /* Revert to classical, BSD locks */
145
146 extern struct lock afs_global_lock;
147 extern struct proc *afs_global_owner;
148
149 #ifdef AFS_GLOBAL_SUNLOCK
150
151 #if defined(LOCKDEBUG)
152
153 #define AFS_GLOCK() \
154   do { \
155   _lockmgr(&afs_global_lock, LK_EXCLUSIVE, NULL, __FILE__, __LINE__); \
156   } while(0);
157 #define AFS_GUNLOCK() \
158   do { \
159   _lockmgr(&afs_global_lock, LK_RELEASE, NULL, __FILE__, __LINE__); \
160   } while(0);
161
162 #else
163
164 #define AFS_GLOCK() \
165   do { \
166   lockmgr(&afs_global_lock, LK_EXCLUSIVE, NULL); \
167   } while(0);
168 #define AFS_GUNLOCK() \
169   do { \
170   lockmgr(&afs_global_lock, LK_RELEASE, NULL); \
171   } while(0);
172 #endif /* LOCKDEBUG */
173 #define ISAFS_GLOCK() (lockstatus(&afs_global_lock) == LK_EXCLUSIVE)
174 #else
175 extern struct lock afs_global_lock;
176 #define AFS_GLOCKP(p)
177 #define AFS_GUNLOCKP(p)
178 #define AFS_ASSERT_GLOCK()
179 #define ISAFS_GLOCK() 1
180 #endif
181
182 #else
183 /* I don't see doing locks this way for older kernels, either,
184  * but, smart folks wrote this
185  */
186 #define AFS_GLOCK() AFS_GLOCKP(curproc)
187 #define AFS_GUNLOCK() AFS_GUNLOCKP(curproc)
188 #ifdef AFS_GLOBAL_SUNLOCK
189 extern struct proc *afs_global_owner;
190 extern struct lock afs_global_lock;
191 #define AFS_GLOCKP(p) \
192     do { \
193         osi_Assert(p); \
194         afs_osi_lockmgr(&afs_global_lock, LK_EXCLUSIVE, 0, (p)); \
195         osi_Assert(afs_global_owner == NULL); \
196         afs_global_owner = (p); \
197     } while (0)
198 #define AFS_GUNLOCKP(p) \
199     do { \
200         osi_Assert(p); \
201         osi_Assert(afs_global_owner == (p)); \
202         afs_global_owner = NULL; \
203         afs_osi_lockmgr(&afs_global_lock, LK_RELEASE, 0, (p)); \
204     } while(0)
205 #define ISAFS_GLOCK() (afs_global_owner == curproc && curproc)
206 #else
207 extern struct lock afs_global_lock;
208 #define AFS_GLOCKP(p)
209 #define AFS_GUNLOCKP(p)
210 #define AFS_ASSERT_GLOCK()
211 #define ISAFS_GLOCK() 1
212 #endif
213
214 #endif /* AFS_OBSD44_ENV */
215
216 #undef SPLVAR
217 #define SPLVAR int splvar
218 #undef NETPRI
219 #define NETPRI splvar=splnet()
220 #undef USERPRI
221 #define USERPRI splx(splvar)
222 #endif /* KERNEL */
223
224 #endif /* _OSI_MACHDEP_H_ */