puffs_priv.h revision 1.44 1 1.44 mrg /* $NetBSD: puffs_priv.h,v 1.44 2011/06/20 09:11:17 mrg Exp $ */
2 1.1 pooka
3 1.1 pooka /*
4 1.38 pooka * Copyright (c) 2006, 2007, 2008 Antti Kantee. All Rights Reserved.
5 1.1 pooka *
6 1.1 pooka * Redistribution and use in source and binary forms, with or without
7 1.1 pooka * modification, are permitted provided that the following conditions
8 1.1 pooka * are met:
9 1.1 pooka * 1. Redistributions of source code must retain the above copyright
10 1.1 pooka * notice, this list of conditions and the following disclaimer.
11 1.1 pooka * 2. Redistributions in binary form must reproduce the above copyright
12 1.1 pooka * notice, this list of conditions and the following disclaimer in the
13 1.1 pooka * documentation and/or other materials provided with the distribution.
14 1.1 pooka *
15 1.1 pooka * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS
16 1.1 pooka * OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
17 1.1 pooka * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
18 1.1 pooka * DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
19 1.1 pooka * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
20 1.1 pooka * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
21 1.1 pooka * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
22 1.1 pooka * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
23 1.1 pooka * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
24 1.1 pooka * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
25 1.1 pooka * SUCH DAMAGE.
26 1.1 pooka */
27 1.1 pooka
28 1.1 pooka #ifndef _PUFFS_PRIVATE_H_
29 1.1 pooka #define _PUFFS_PRIVATE_H_
30 1.1 pooka
31 1.1 pooka #include <sys/types.h>
32 1.1 pooka #include <fs/puffs/puffs_msgif.h>
33 1.1 pooka
34 1.43 pooka #include <pthread.h>
35 1.1 pooka #include <puffs.h>
36 1.2 pooka #include <ucontext.h>
37 1.2 pooka
38 1.30 pooka extern pthread_mutex_t pu_lock;
39 1.31 pooka #define PU_LOCK() pthread_mutex_lock(&pu_lock)
40 1.31 pooka #define PU_UNLOCK() pthread_mutex_unlock(&pu_lock)
41 1.30 pooka
42 1.37 pooka #define PU_CMAP(pu, c) (pu->pu_cmap ? pu->pu_cmap(pu,c) : (struct puffs_node*)c)
43 1.4 pooka
44 1.9 pooka struct puffs_framectrl {
45 1.10 pooka puffs_framev_readframe_fn rfb;
46 1.10 pooka puffs_framev_writeframe_fn wfb;
47 1.11 pooka puffs_framev_cmpframe_fn cmpfb;
48 1.21 pooka puffs_framev_gotframe_fn gotfb;
49 1.10 pooka puffs_framev_fdnotify_fn fdnotfn;
50 1.9 pooka };
51 1.9 pooka
52 1.9 pooka struct puffs_fctrl_io {
53 1.33 pooka struct puffs_framectrl *fctrl;
54 1.33 pooka
55 1.9 pooka int io_fd;
56 1.10 pooka int stat;
57 1.9 pooka
58 1.19 pooka int rwait;
59 1.19 pooka int wwait;
60 1.19 pooka
61 1.9 pooka struct puffs_framebuf *cur_in;
62 1.9 pooka
63 1.9 pooka TAILQ_HEAD(, puffs_framebuf) snd_qing; /* queueing to be sent */
64 1.9 pooka TAILQ_HEAD(, puffs_framebuf) res_qing; /* q'ing for rescue */
65 1.19 pooka LIST_HEAD(, puffs_fbevent) ev_qing; /* q'ing for events */
66 1.9 pooka
67 1.9 pooka LIST_ENTRY(puffs_fctrl_io) fio_entries;
68 1.9 pooka };
69 1.10 pooka #define FIO_WR 0x01
70 1.10 pooka #define FIO_WRGONE 0x02
71 1.10 pooka #define FIO_RDGONE 0x04
72 1.10 pooka #define FIO_DEAD 0x08
73 1.17 pooka #define FIO_ENABLE_R 0x10
74 1.17 pooka #define FIO_ENABLE_W 0x20
75 1.10 pooka
76 1.19 pooka #define FIO_EN_WRITE(fio) \
77 1.19 pooka (!(fio->stat & FIO_WR) \
78 1.19 pooka && ((!TAILQ_EMPTY(&fio->snd_qing) \
79 1.19 pooka && (fio->stat & FIO_ENABLE_W)) \
80 1.19 pooka || fio->wwait))
81 1.17 pooka
82 1.17 pooka #define FIO_RM_WRITE(fio) \
83 1.17 pooka ((fio->stat & FIO_WR) \
84 1.19 pooka && (((TAILQ_EMPTY(&fio->snd_qing) \
85 1.19 pooka || (fio->stat & FIO_ENABLE_W) == 0)) \
86 1.19 pooka && (fio->wwait == 0)))
87 1.7 pooka
88 1.28 pooka
89 1.5 pooka /*
90 1.5 pooka * usermount: describes one file system instance
91 1.5 pooka */
92 1.5 pooka struct puffs_usermount {
93 1.5 pooka struct puffs_ops pu_ops;
94 1.18 pooka
95 1.18 pooka int pu_fd;
96 1.18 pooka size_t pu_maxreqlen;
97 1.5 pooka
98 1.5 pooka uint32_t pu_flags;
99 1.27 pooka int pu_cc_stackshift;
100 1.5 pooka
101 1.40 pooka ucontext_t pu_mainctx;
102 1.38 pooka #define PUFFS_CCMAXSTORE 32
103 1.38 pooka int pu_cc_nstored;
104 1.38 pooka
105 1.9 pooka int pu_kq;
106 1.5 pooka int pu_state;
107 1.40 pooka #define PU_STATEMASK 0x00ff
108 1.40 pooka #define PU_INLOOP 0x0100
109 1.40 pooka #define PU_ASYNCFD 0x0200
110 1.40 pooka #define PU_HASKQ 0x0400
111 1.40 pooka #define PU_PUFFSDAEMON 0x0800
112 1.40 pooka #define PU_MAINRESTORE 0x1000
113 1.42 pooka #define PU_DONEXIT 0x2000
114 1.9 pooka #define PU_SETSTATE(pu, s) (pu->pu_state = (s) | (pu->pu_state & ~PU_STATEMASK))
115 1.40 pooka #define PU_SETSFLAG(pu, s) (pu->pu_state |= (s))
116 1.40 pooka #define PU_CLRSFLAG(pu, s) \
117 1.44 mrg (pu->pu_state = ((pu->pu_state & ~(s)) | (pu->pu_state & PU_STATEMASK)))
118 1.32 pooka int pu_dpipe[2];
119 1.5 pooka
120 1.5 pooka struct puffs_node *pu_pn_root;
121 1.5 pooka
122 1.5 pooka LIST_HEAD(, puffs_node) pu_pnodelst;
123 1.38 pooka
124 1.38 pooka LIST_HEAD(, puffs_cc) pu_ccmagazin;
125 1.39 pooka TAILQ_HEAD(, puffs_cc) pu_lazyctx;
126 1.25 pooka TAILQ_HEAD(, puffs_cc) pu_sched;
127 1.5 pooka
128 1.37 pooka pu_cmap_fn pu_cmap;
129 1.5 pooka
130 1.5 pooka pu_pathbuild_fn pu_pathbuild;
131 1.5 pooka pu_pathtransform_fn pu_pathtransform;
132 1.5 pooka pu_pathcmp_fn pu_pathcmp;
133 1.5 pooka pu_pathfree_fn pu_pathfree;
134 1.5 pooka pu_namemod_fn pu_namemod;
135 1.5 pooka
136 1.22 pooka pu_errnotify_fn pu_errnotify;
137 1.22 pooka
138 1.29 pooka pu_prepost_fn pu_oppre;
139 1.29 pooka pu_prepost_fn pu_oppost;
140 1.29 pooka
141 1.33 pooka struct puffs_framectrl pu_framectrl[2];
142 1.33 pooka #define PU_FRAMECTRL_FS 0
143 1.33 pooka #define PU_FRAMECTRL_USER 1
144 1.33 pooka LIST_HEAD(, puffs_fctrl_io) pu_ios;
145 1.33 pooka LIST_HEAD(, puffs_fctrl_io) pu_ios_rmlist;
146 1.33 pooka struct kevent *pu_evs;
147 1.42 pooka size_t pu_nevs;
148 1.7 pooka
149 1.10 pooka puffs_ml_loop_fn pu_ml_lfn;
150 1.10 pooka struct timespec pu_ml_timeout;
151 1.10 pooka struct timespec *pu_ml_timep;
152 1.10 pooka
153 1.18 pooka struct puffs_kargs *pu_kargp;
154 1.18 pooka
155 1.34 pooka uint64_t pu_nextreq;
156 1.10 pooka void *pu_privdata;
157 1.5 pooka };
158 1.5 pooka
159 1.2 pooka /* call context */
160 1.2 pooka
161 1.39 pooka struct puffs_cc;
162 1.39 pooka typedef void (*puffs_ccfunc)(struct puffs_cc *);
163 1.39 pooka
164 1.2 pooka struct puffs_cc {
165 1.2 pooka struct puffs_usermount *pcc_pu;
166 1.33 pooka struct puffs_framebuf *pcc_pb;
167 1.2 pooka
168 1.39 pooka /* real cc */
169 1.39 pooka union {
170 1.39 pooka struct {
171 1.39 pooka ucontext_t uc; /* "continue" */
172 1.39 pooka ucontext_t uc_ret; /* "yield" */
173 1.39 pooka } real;
174 1.39 pooka struct {
175 1.39 pooka puffs_ccfunc func;
176 1.39 pooka void *farg;
177 1.39 pooka } fake;
178 1.39 pooka } pcc_u;
179 1.2 pooka
180 1.24 pooka pid_t pcc_pid;
181 1.24 pooka lwpid_t pcc_lid;
182 1.24 pooka
183 1.2 pooka int pcc_flags;
184 1.2 pooka
185 1.38 pooka TAILQ_ENTRY(puffs_cc) pcc_schedent;
186 1.38 pooka LIST_ENTRY(puffs_cc) pcc_rope;
187 1.2 pooka };
188 1.39 pooka #define pcc_uc pcc_u.real.uc
189 1.39 pooka #define pcc_uc_ret pcc_u.real.uc_ret
190 1.39 pooka #define pcc_func pcc_u.fake.func
191 1.39 pooka #define pcc_farg pcc_u.fake.farg
192 1.39 pooka #define PCC_DONE 0x01
193 1.39 pooka #define PCC_BORROWED 0x02
194 1.39 pooka #define PCC_HASCALLER 0x04
195 1.39 pooka #define PCC_MLCONT 0x08
196 1.2 pooka
197 1.16 pooka struct puffs_newinfo {
198 1.16 pooka void **pni_cookie;
199 1.16 pooka enum vtype *pni_vtype;
200 1.16 pooka voff_t *pni_size;
201 1.16 pooka dev_t *pni_rdev;
202 1.16 pooka };
203 1.16 pooka
204 1.13 pooka #define PUFFS_MAKEKCRED(to, from) \
205 1.13 pooka /*LINTED: tnilxnaht, the cast is ok */ \
206 1.15 pooka const struct puffs_kcred *to = (const void *)from
207 1.13 pooka #define PUFFS_MAKECRED(to, from) \
208 1.13 pooka /*LINTED: tnilxnaht, the cast is ok */ \
209 1.15 pooka const struct puffs_cred *to = (const void *)from
210 1.13 pooka #define PUFFS_KCREDTOCRED(to, from) \
211 1.13 pooka /*LINTED: tnilxnaht, the cast is ok */ \
212 1.15 pooka to = (void *)from
213 1.9 pooka
214 1.2 pooka __BEGIN_DECLS
215 1.2 pooka
216 1.39 pooka void puffs__framev_input(struct puffs_usermount *, struct puffs_framectrl *,
217 1.33 pooka struct puffs_fctrl_io *);
218 1.39 pooka int puffs__framev_output(struct puffs_usermount *, struct puffs_framectrl*,
219 1.33 pooka struct puffs_fctrl_io *);
220 1.39 pooka void puffs__framev_exit(struct puffs_usermount *);
221 1.39 pooka void puffs__framev_readclose(struct puffs_usermount *,
222 1.10 pooka struct puffs_fctrl_io *, int);
223 1.39 pooka void puffs__framev_writeclose(struct puffs_usermount *,
224 1.10 pooka struct puffs_fctrl_io *, int);
225 1.39 pooka void puffs__framev_notify(struct puffs_fctrl_io *, int);
226 1.33 pooka void *puffs__framebuf_getdataptr(struct puffs_framebuf *);
227 1.33 pooka int puffs__framev_addfd_ctrl(struct puffs_usermount *, int, int,
228 1.33 pooka struct puffs_framectrl *);
229 1.33 pooka void puffs__framebuf_moveinfo(struct puffs_framebuf *,
230 1.33 pooka struct puffs_framebuf *);
231 1.10 pooka
232 1.39 pooka void puffs__theloop(struct puffs_cc *);
233 1.39 pooka void puffs__ml_dispatch(struct puffs_usermount *, struct puffs_framebuf *);
234 1.39 pooka
235 1.39 pooka int puffs__cc_create(struct puffs_usermount *, puffs_ccfunc,
236 1.39 pooka struct puffs_cc **);
237 1.39 pooka void puffs__cc_cont(struct puffs_cc *);
238 1.39 pooka void puffs__cc_destroy(struct puffs_cc *, int);
239 1.39 pooka void puffs__cc_setcaller(struct puffs_cc *, pid_t, lwpid_t);
240 1.39 pooka void puffs__goto(struct puffs_cc *);
241 1.40 pooka int puffs__cc_savemain(struct puffs_usermount *);
242 1.40 pooka int puffs__cc_restoremain(struct puffs_usermount *);
243 1.41 pooka void puffs__cc_exit(struct puffs_usermount *);
244 1.39 pooka
245 1.39 pooka int puffs__fsframe_read(struct puffs_usermount *, struct puffs_framebuf *,
246 1.39 pooka int, int *);
247 1.39 pooka int puffs__fsframe_write(struct puffs_usermount *, struct puffs_framebuf *,
248 1.39 pooka int, int *);
249 1.39 pooka int puffs__fsframe_cmp(struct puffs_usermount *, struct puffs_framebuf *,
250 1.39 pooka struct puffs_framebuf *, int *);
251 1.39 pooka void puffs__fsframe_gotframe(struct puffs_usermount *,
252 1.39 pooka struct puffs_framebuf *);
253 1.33 pooka
254 1.34 pooka uint64_t puffs__nextreq(struct puffs_usermount *pu);
255 1.34 pooka
256 1.2 pooka __END_DECLS
257 1.2 pooka
258 1.1 pooka #endif /* _PUFFS_PRIVATE_H_ */
259