1*4f1223e8SApple OSS Distributions /*
2*4f1223e8SApple OSS Distributions * Copyright (c) 2000-2004 Apple Computer, Inc. All rights reserved.
3*4f1223e8SApple OSS Distributions *
4*4f1223e8SApple OSS Distributions * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
5*4f1223e8SApple OSS Distributions *
6*4f1223e8SApple OSS Distributions * This file contains Original Code and/or Modifications of Original Code
7*4f1223e8SApple OSS Distributions * as defined in and that are subject to the Apple Public Source License
8*4f1223e8SApple OSS Distributions * Version 2.0 (the 'License'). You may not use this file except in
9*4f1223e8SApple OSS Distributions * compliance with the License. The rights granted to you under the License
10*4f1223e8SApple OSS Distributions * may not be used to create, or enable the creation or redistribution of,
11*4f1223e8SApple OSS Distributions * unlawful or unlicensed copies of an Apple operating system, or to
12*4f1223e8SApple OSS Distributions * circumvent, violate, or enable the circumvention or violation of, any
13*4f1223e8SApple OSS Distributions * terms of an Apple operating system software license agreement.
14*4f1223e8SApple OSS Distributions *
15*4f1223e8SApple OSS Distributions * Please obtain a copy of the License at
16*4f1223e8SApple OSS Distributions * http://www.opensource.apple.com/apsl/ and read it before using this file.
17*4f1223e8SApple OSS Distributions *
18*4f1223e8SApple OSS Distributions * The Original Code and all software distributed under the License are
19*4f1223e8SApple OSS Distributions * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
20*4f1223e8SApple OSS Distributions * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
21*4f1223e8SApple OSS Distributions * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
22*4f1223e8SApple OSS Distributions * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
23*4f1223e8SApple OSS Distributions * Please see the License for the specific language governing rights and
24*4f1223e8SApple OSS Distributions * limitations under the License.
25*4f1223e8SApple OSS Distributions *
26*4f1223e8SApple OSS Distributions * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
27*4f1223e8SApple OSS Distributions */
28*4f1223e8SApple OSS Distributions /*
29*4f1223e8SApple OSS Distributions * Copyright (c) 1998-1999 Apple Computer, Inc. All rights reserved.
30*4f1223e8SApple OSS Distributions *
31*4f1223e8SApple OSS Distributions * File: vfs/vfs_support.c
32*4f1223e8SApple OSS Distributions *
33*4f1223e8SApple OSS Distributions * The default VFS routines. A VFS plugin can use these
34*4f1223e8SApple OSS Distributions * functions in case it does not want to implement all. These functions
35*4f1223e8SApple OSS Distributions * take care of releasing locks and free up memory that they are
36*4f1223e8SApple OSS Distributions * supposed to.
37*4f1223e8SApple OSS Distributions *
38*4f1223e8SApple OSS Distributions * nop_* routines always return 0 [success]
39*4f1223e8SApple OSS Distributions * err_* routines always return ENOTSUP
40*4f1223e8SApple OSS Distributions *
41*4f1223e8SApple OSS Distributions * This file could be auto-generated from vnode_if.src. but that needs
42*4f1223e8SApple OSS Distributions * support for freeing cnp.
43*4f1223e8SApple OSS Distributions *
44*4f1223e8SApple OSS Distributions * HISTORY
45*4f1223e8SApple OSS Distributions * 15-Jul-1998 Earsh Nandkeshwar ([email protected])
46*4f1223e8SApple OSS Distributions * Fixed up readdirattr for its existance now.
47*4f1223e8SApple OSS Distributions * 18-Aug-1998 Umesh Vaishampayan ([email protected])
48*4f1223e8SApple OSS Distributions * Created.
49*4f1223e8SApple OSS Distributions */
50*4f1223e8SApple OSS Distributions
51*4f1223e8SApple OSS Distributions #include <vfs/vfs_support.h>
52*4f1223e8SApple OSS Distributions #include <sys/kauth.h>
53*4f1223e8SApple OSS Distributions #include <sys/ubc.h> /* ubc_upl_abort_range() */
54*4f1223e8SApple OSS Distributions
55*4f1223e8SApple OSS Distributions
56*4f1223e8SApple OSS Distributions struct vnop_create_args /* {
57*4f1223e8SApple OSS Distributions * struct vnode *a_dvp;
58*4f1223e8SApple OSS Distributions * struct vnode **a_vpp;
59*4f1223e8SApple OSS Distributions * struct componentname *a_cnp;
60*4f1223e8SApple OSS Distributions * struct vnode_vattr *a_vap;
61*4f1223e8SApple OSS Distributions * vfs_context_t a_context;
62*4f1223e8SApple OSS Distributions * } */;
63*4f1223e8SApple OSS Distributions
64*4f1223e8SApple OSS Distributions int
nop_create(__unused struct vnop_create_args * ap)65*4f1223e8SApple OSS Distributions nop_create(__unused struct vnop_create_args *ap)
66*4f1223e8SApple OSS Distributions {
67*4f1223e8SApple OSS Distributions #if DIAGNOSTIC
68*4f1223e8SApple OSS Distributions if ((ap->a_cnp->cn_flags & HASBUF) == 0) {
69*4f1223e8SApple OSS Distributions panic("nop_create: no name");
70*4f1223e8SApple OSS Distributions }
71*4f1223e8SApple OSS Distributions #endif
72*4f1223e8SApple OSS Distributions return 0;
73*4f1223e8SApple OSS Distributions }
74*4f1223e8SApple OSS Distributions
75*4f1223e8SApple OSS Distributions int
err_create(struct vnop_create_args * ap)76*4f1223e8SApple OSS Distributions err_create(struct vnop_create_args *ap)
77*4f1223e8SApple OSS Distributions {
78*4f1223e8SApple OSS Distributions (void)nop_create(ap);
79*4f1223e8SApple OSS Distributions return ENOTSUP;
80*4f1223e8SApple OSS Distributions }
81*4f1223e8SApple OSS Distributions
82*4f1223e8SApple OSS Distributions
83*4f1223e8SApple OSS Distributions struct vnop_whiteout_args /* {
84*4f1223e8SApple OSS Distributions * struct vnode *a_dvp;
85*4f1223e8SApple OSS Distributions * struct componentname *a_cnp;
86*4f1223e8SApple OSS Distributions * int a_flags;
87*4f1223e8SApple OSS Distributions * vfs_context_t a_context;
88*4f1223e8SApple OSS Distributions * } */;
89*4f1223e8SApple OSS Distributions
90*4f1223e8SApple OSS Distributions int
nop_whiteout(__unused struct vnop_whiteout_args * ap)91*4f1223e8SApple OSS Distributions nop_whiteout(__unused struct vnop_whiteout_args *ap)
92*4f1223e8SApple OSS Distributions {
93*4f1223e8SApple OSS Distributions return 0;
94*4f1223e8SApple OSS Distributions }
95*4f1223e8SApple OSS Distributions
96*4f1223e8SApple OSS Distributions int
err_whiteout(__unused struct vnop_whiteout_args * ap)97*4f1223e8SApple OSS Distributions err_whiteout(__unused struct vnop_whiteout_args *ap)
98*4f1223e8SApple OSS Distributions {
99*4f1223e8SApple OSS Distributions return ENOTSUP;
100*4f1223e8SApple OSS Distributions }
101*4f1223e8SApple OSS Distributions
102*4f1223e8SApple OSS Distributions
103*4f1223e8SApple OSS Distributions struct vnop_mknod_args /* {
104*4f1223e8SApple OSS Distributions * struct vnode *a_dvp;
105*4f1223e8SApple OSS Distributions * struct vnode **a_vpp;
106*4f1223e8SApple OSS Distributions * struct componentname *a_cnp;
107*4f1223e8SApple OSS Distributions * struct vnode_vattr *a_vap;
108*4f1223e8SApple OSS Distributions * vfs_context_t a_context;
109*4f1223e8SApple OSS Distributions * } */;
110*4f1223e8SApple OSS Distributions
111*4f1223e8SApple OSS Distributions int
nop_mknod(__unused struct vnop_mknod_args * ap)112*4f1223e8SApple OSS Distributions nop_mknod(__unused struct vnop_mknod_args *ap)
113*4f1223e8SApple OSS Distributions {
114*4f1223e8SApple OSS Distributions #if DIAGNOSTIC
115*4f1223e8SApple OSS Distributions if ((ap->a_cnp->cn_flags & HASBUF) == 0) {
116*4f1223e8SApple OSS Distributions panic("nop_mknod: no name");
117*4f1223e8SApple OSS Distributions }
118*4f1223e8SApple OSS Distributions #endif
119*4f1223e8SApple OSS Distributions return 0;
120*4f1223e8SApple OSS Distributions }
121*4f1223e8SApple OSS Distributions
122*4f1223e8SApple OSS Distributions int
err_mknod(struct vnop_mknod_args * ap)123*4f1223e8SApple OSS Distributions err_mknod(struct vnop_mknod_args *ap)
124*4f1223e8SApple OSS Distributions {
125*4f1223e8SApple OSS Distributions (void)nop_mknod(ap);
126*4f1223e8SApple OSS Distributions return ENOTSUP;
127*4f1223e8SApple OSS Distributions }
128*4f1223e8SApple OSS Distributions
129*4f1223e8SApple OSS Distributions struct vnop_open_args /* {
130*4f1223e8SApple OSS Distributions * struct vnode *a_vp;
131*4f1223e8SApple OSS Distributions * int a_mode;
132*4f1223e8SApple OSS Distributions * vfs_context_t a_context;
133*4f1223e8SApple OSS Distributions * } */;
134*4f1223e8SApple OSS Distributions
135*4f1223e8SApple OSS Distributions int
nop_open(__unused struct vnop_open_args * ap)136*4f1223e8SApple OSS Distributions nop_open(__unused struct vnop_open_args *ap)
137*4f1223e8SApple OSS Distributions {
138*4f1223e8SApple OSS Distributions return 0;
139*4f1223e8SApple OSS Distributions }
140*4f1223e8SApple OSS Distributions
141*4f1223e8SApple OSS Distributions int
err_open(__unused struct vnop_open_args * ap)142*4f1223e8SApple OSS Distributions err_open(__unused struct vnop_open_args *ap)
143*4f1223e8SApple OSS Distributions {
144*4f1223e8SApple OSS Distributions return ENOTSUP;
145*4f1223e8SApple OSS Distributions }
146*4f1223e8SApple OSS Distributions
147*4f1223e8SApple OSS Distributions
148*4f1223e8SApple OSS Distributions struct vnop_close_args /* {
149*4f1223e8SApple OSS Distributions * struct vnode *a_vp;
150*4f1223e8SApple OSS Distributions * int a_fflag;
151*4f1223e8SApple OSS Distributions * vfs_context_t a_context;
152*4f1223e8SApple OSS Distributions * } */;
153*4f1223e8SApple OSS Distributions
154*4f1223e8SApple OSS Distributions int
nop_close(__unused struct vnop_close_args * ap)155*4f1223e8SApple OSS Distributions nop_close(__unused struct vnop_close_args *ap)
156*4f1223e8SApple OSS Distributions {
157*4f1223e8SApple OSS Distributions return 0;
158*4f1223e8SApple OSS Distributions }
159*4f1223e8SApple OSS Distributions
160*4f1223e8SApple OSS Distributions int
err_close(__unused struct vnop_close_args * ap)161*4f1223e8SApple OSS Distributions err_close(__unused struct vnop_close_args *ap)
162*4f1223e8SApple OSS Distributions {
163*4f1223e8SApple OSS Distributions return ENOTSUP;
164*4f1223e8SApple OSS Distributions }
165*4f1223e8SApple OSS Distributions
166*4f1223e8SApple OSS Distributions
167*4f1223e8SApple OSS Distributions struct vnop_access_args /* {
168*4f1223e8SApple OSS Distributions * struct vnode *a_vp;
169*4f1223e8SApple OSS Distributions * int a_mode;
170*4f1223e8SApple OSS Distributions * vfs_context_t a_context;
171*4f1223e8SApple OSS Distributions * } */;
172*4f1223e8SApple OSS Distributions
173*4f1223e8SApple OSS Distributions int
nop_access(__unused struct vnop_access_args * ap)174*4f1223e8SApple OSS Distributions nop_access(__unused struct vnop_access_args *ap)
175*4f1223e8SApple OSS Distributions {
176*4f1223e8SApple OSS Distributions return 0;
177*4f1223e8SApple OSS Distributions }
178*4f1223e8SApple OSS Distributions
179*4f1223e8SApple OSS Distributions int
err_access(__unused struct vnop_access_args * ap)180*4f1223e8SApple OSS Distributions err_access(__unused struct vnop_access_args *ap)
181*4f1223e8SApple OSS Distributions {
182*4f1223e8SApple OSS Distributions return ENOTSUP;
183*4f1223e8SApple OSS Distributions }
184*4f1223e8SApple OSS Distributions
185*4f1223e8SApple OSS Distributions
186*4f1223e8SApple OSS Distributions struct vnop_getattr_args /* {
187*4f1223e8SApple OSS Distributions * struct vnode *a_vp;
188*4f1223e8SApple OSS Distributions * struct vnode_vattr *a_vap;
189*4f1223e8SApple OSS Distributions * vfs_context_t a_context;
190*4f1223e8SApple OSS Distributions * } */;
191*4f1223e8SApple OSS Distributions
192*4f1223e8SApple OSS Distributions int
nop_getattr(__unused struct vnop_getattr_args * ap)193*4f1223e8SApple OSS Distributions nop_getattr(__unused struct vnop_getattr_args *ap)
194*4f1223e8SApple OSS Distributions {
195*4f1223e8SApple OSS Distributions return 0;
196*4f1223e8SApple OSS Distributions }
197*4f1223e8SApple OSS Distributions
198*4f1223e8SApple OSS Distributions int
err_getattr(__unused struct vnop_getattr_args * ap)199*4f1223e8SApple OSS Distributions err_getattr(__unused struct vnop_getattr_args *ap)
200*4f1223e8SApple OSS Distributions {
201*4f1223e8SApple OSS Distributions return ENOTSUP;
202*4f1223e8SApple OSS Distributions }
203*4f1223e8SApple OSS Distributions
204*4f1223e8SApple OSS Distributions
205*4f1223e8SApple OSS Distributions struct vnop_setattr_args /* {
206*4f1223e8SApple OSS Distributions * struct vnode *a_vp;
207*4f1223e8SApple OSS Distributions * struct vnode_vattr *a_vap;
208*4f1223e8SApple OSS Distributions * vfs_context_t a_context;
209*4f1223e8SApple OSS Distributions * } */;
210*4f1223e8SApple OSS Distributions
211*4f1223e8SApple OSS Distributions int
nop_setattr(__unused struct vnop_setattr_args * ap)212*4f1223e8SApple OSS Distributions nop_setattr(__unused struct vnop_setattr_args *ap)
213*4f1223e8SApple OSS Distributions {
214*4f1223e8SApple OSS Distributions return 0;
215*4f1223e8SApple OSS Distributions }
216*4f1223e8SApple OSS Distributions
217*4f1223e8SApple OSS Distributions int
err_setattr(__unused struct vnop_setattr_args * ap)218*4f1223e8SApple OSS Distributions err_setattr(__unused struct vnop_setattr_args *ap)
219*4f1223e8SApple OSS Distributions {
220*4f1223e8SApple OSS Distributions return ENOTSUP;
221*4f1223e8SApple OSS Distributions }
222*4f1223e8SApple OSS Distributions
223*4f1223e8SApple OSS Distributions struct vnop_read_args /* {
224*4f1223e8SApple OSS Distributions * struct vnode *a_vp;
225*4f1223e8SApple OSS Distributions * struct uio *a_uio;
226*4f1223e8SApple OSS Distributions * int a_ioflag;
227*4f1223e8SApple OSS Distributions * vfs_context_t a_context;
228*4f1223e8SApple OSS Distributions * } */;
229*4f1223e8SApple OSS Distributions
230*4f1223e8SApple OSS Distributions int
nop_read(__unused struct vnop_read_args * ap)231*4f1223e8SApple OSS Distributions nop_read(__unused struct vnop_read_args *ap)
232*4f1223e8SApple OSS Distributions {
233*4f1223e8SApple OSS Distributions return 0;
234*4f1223e8SApple OSS Distributions }
235*4f1223e8SApple OSS Distributions
236*4f1223e8SApple OSS Distributions int
err_read(__unused struct vnop_read_args * ap)237*4f1223e8SApple OSS Distributions err_read(__unused struct vnop_read_args *ap)
238*4f1223e8SApple OSS Distributions {
239*4f1223e8SApple OSS Distributions return ENOTSUP;
240*4f1223e8SApple OSS Distributions }
241*4f1223e8SApple OSS Distributions
242*4f1223e8SApple OSS Distributions
243*4f1223e8SApple OSS Distributions struct vnop_write_args /* {
244*4f1223e8SApple OSS Distributions * struct vnode *a_vp;
245*4f1223e8SApple OSS Distributions * struct uio *a_uio;
246*4f1223e8SApple OSS Distributions * int a_ioflag;
247*4f1223e8SApple OSS Distributions * vfs_context_t a_context;
248*4f1223e8SApple OSS Distributions * } */;
249*4f1223e8SApple OSS Distributions
250*4f1223e8SApple OSS Distributions int
nop_write(__unused struct vnop_write_args * ap)251*4f1223e8SApple OSS Distributions nop_write(__unused struct vnop_write_args *ap)
252*4f1223e8SApple OSS Distributions {
253*4f1223e8SApple OSS Distributions return 0;
254*4f1223e8SApple OSS Distributions }
255*4f1223e8SApple OSS Distributions
256*4f1223e8SApple OSS Distributions int
err_write(__unused struct vnop_write_args * ap)257*4f1223e8SApple OSS Distributions err_write(__unused struct vnop_write_args *ap)
258*4f1223e8SApple OSS Distributions {
259*4f1223e8SApple OSS Distributions return ENOTSUP;
260*4f1223e8SApple OSS Distributions }
261*4f1223e8SApple OSS Distributions
262*4f1223e8SApple OSS Distributions
263*4f1223e8SApple OSS Distributions struct vnop_ioctl_args /* {
264*4f1223e8SApple OSS Distributions * struct vnode *a_vp;
265*4f1223e8SApple OSS Distributions * u_long a_command;
266*4f1223e8SApple OSS Distributions * caddr_t a_data;
267*4f1223e8SApple OSS Distributions * int a_fflag;
268*4f1223e8SApple OSS Distributions * kauth_cred_t a_cred;
269*4f1223e8SApple OSS Distributions * struct proc *a_p;
270*4f1223e8SApple OSS Distributions * } */;
271*4f1223e8SApple OSS Distributions
272*4f1223e8SApple OSS Distributions int
nop_ioctl(__unused struct vnop_ioctl_args * ap)273*4f1223e8SApple OSS Distributions nop_ioctl(__unused struct vnop_ioctl_args *ap)
274*4f1223e8SApple OSS Distributions {
275*4f1223e8SApple OSS Distributions return 0;
276*4f1223e8SApple OSS Distributions }
277*4f1223e8SApple OSS Distributions
278*4f1223e8SApple OSS Distributions int
err_ioctl(__unused struct vnop_ioctl_args * ap)279*4f1223e8SApple OSS Distributions err_ioctl(__unused struct vnop_ioctl_args *ap)
280*4f1223e8SApple OSS Distributions {
281*4f1223e8SApple OSS Distributions return ENOTSUP;
282*4f1223e8SApple OSS Distributions }
283*4f1223e8SApple OSS Distributions
284*4f1223e8SApple OSS Distributions
285*4f1223e8SApple OSS Distributions struct vnop_select_args /* {
286*4f1223e8SApple OSS Distributions * struct vnode *a_vp;
287*4f1223e8SApple OSS Distributions * int a_which;
288*4f1223e8SApple OSS Distributions * int a_fflags;
289*4f1223e8SApple OSS Distributions * kauth_cred_t a_cred;
290*4f1223e8SApple OSS Distributions * void *a_wql;
291*4f1223e8SApple OSS Distributions * struct proc *a_p;
292*4f1223e8SApple OSS Distributions * } */;
293*4f1223e8SApple OSS Distributions
294*4f1223e8SApple OSS Distributions int
nop_select(__unused struct vnop_select_args * ap)295*4f1223e8SApple OSS Distributions nop_select(__unused struct vnop_select_args *ap)
296*4f1223e8SApple OSS Distributions {
297*4f1223e8SApple OSS Distributions return 0;
298*4f1223e8SApple OSS Distributions }
299*4f1223e8SApple OSS Distributions
300*4f1223e8SApple OSS Distributions int
err_select(__unused struct vnop_select_args * ap)301*4f1223e8SApple OSS Distributions err_select(__unused struct vnop_select_args *ap)
302*4f1223e8SApple OSS Distributions {
303*4f1223e8SApple OSS Distributions return ENOTSUP;
304*4f1223e8SApple OSS Distributions }
305*4f1223e8SApple OSS Distributions
306*4f1223e8SApple OSS Distributions
307*4f1223e8SApple OSS Distributions struct vnop_exchange_args /* {
308*4f1223e8SApple OSS Distributions * struct vnode *a_fvp;
309*4f1223e8SApple OSS Distributions * struct vnode *a_tvp;
310*4f1223e8SApple OSS Distributions * int a_options;
311*4f1223e8SApple OSS Distributions * vfs_context_t a_context;
312*4f1223e8SApple OSS Distributions * } */;
313*4f1223e8SApple OSS Distributions
314*4f1223e8SApple OSS Distributions int
nop_exchange(__unused struct vnop_exchange_args * ap)315*4f1223e8SApple OSS Distributions nop_exchange(__unused struct vnop_exchange_args *ap)
316*4f1223e8SApple OSS Distributions {
317*4f1223e8SApple OSS Distributions return 0;
318*4f1223e8SApple OSS Distributions }
319*4f1223e8SApple OSS Distributions
320*4f1223e8SApple OSS Distributions int
err_exchange(__unused struct vnop_exchange_args * ap)321*4f1223e8SApple OSS Distributions err_exchange(__unused struct vnop_exchange_args *ap)
322*4f1223e8SApple OSS Distributions {
323*4f1223e8SApple OSS Distributions return ENOTSUP;
324*4f1223e8SApple OSS Distributions }
325*4f1223e8SApple OSS Distributions
326*4f1223e8SApple OSS Distributions
327*4f1223e8SApple OSS Distributions struct vnop_revoke_args /* {
328*4f1223e8SApple OSS Distributions * struct vnode *a_vp;
329*4f1223e8SApple OSS Distributions * int a_flags;
330*4f1223e8SApple OSS Distributions * vfs_context_t a_context;
331*4f1223e8SApple OSS Distributions * } */;
332*4f1223e8SApple OSS Distributions
333*4f1223e8SApple OSS Distributions int
nop_revoke(struct vnop_revoke_args * ap)334*4f1223e8SApple OSS Distributions nop_revoke(struct vnop_revoke_args *ap)
335*4f1223e8SApple OSS Distributions {
336*4f1223e8SApple OSS Distributions return vn_revoke(ap->a_vp, ap->a_flags, ap->a_context);
337*4f1223e8SApple OSS Distributions }
338*4f1223e8SApple OSS Distributions
339*4f1223e8SApple OSS Distributions int
err_revoke(struct vnop_revoke_args * ap)340*4f1223e8SApple OSS Distributions err_revoke(struct vnop_revoke_args *ap)
341*4f1223e8SApple OSS Distributions {
342*4f1223e8SApple OSS Distributions (void)nop_revoke(ap);
343*4f1223e8SApple OSS Distributions return ENOTSUP;
344*4f1223e8SApple OSS Distributions }
345*4f1223e8SApple OSS Distributions
346*4f1223e8SApple OSS Distributions
347*4f1223e8SApple OSS Distributions struct vnop_mmap_args /* {
348*4f1223e8SApple OSS Distributions * struct vnode *a_vp;
349*4f1223e8SApple OSS Distributions * int a_fflags;
350*4f1223e8SApple OSS Distributions * kauth_cred_t a_cred;
351*4f1223e8SApple OSS Distributions * struct proc *a_p;
352*4f1223e8SApple OSS Distributions * } */;
353*4f1223e8SApple OSS Distributions
354*4f1223e8SApple OSS Distributions int
nop_mmap(__unused struct vnop_mmap_args * ap)355*4f1223e8SApple OSS Distributions nop_mmap(__unused struct vnop_mmap_args *ap)
356*4f1223e8SApple OSS Distributions {
357*4f1223e8SApple OSS Distributions return 0;
358*4f1223e8SApple OSS Distributions }
359*4f1223e8SApple OSS Distributions
360*4f1223e8SApple OSS Distributions int
err_mmap(__unused struct vnop_mmap_args * ap)361*4f1223e8SApple OSS Distributions err_mmap(__unused struct vnop_mmap_args *ap)
362*4f1223e8SApple OSS Distributions {
363*4f1223e8SApple OSS Distributions return ENOTSUP;
364*4f1223e8SApple OSS Distributions }
365*4f1223e8SApple OSS Distributions
366*4f1223e8SApple OSS Distributions
367*4f1223e8SApple OSS Distributions struct vnop_fsync_args /* {
368*4f1223e8SApple OSS Distributions * struct vnode *a_vp;
369*4f1223e8SApple OSS Distributions * int a_waitfor;
370*4f1223e8SApple OSS Distributions * vfs_context_t a_context;
371*4f1223e8SApple OSS Distributions * } */;
372*4f1223e8SApple OSS Distributions
373*4f1223e8SApple OSS Distributions int
nop_fsync(__unused struct vnop_fsync_args * ap)374*4f1223e8SApple OSS Distributions nop_fsync(__unused struct vnop_fsync_args *ap)
375*4f1223e8SApple OSS Distributions {
376*4f1223e8SApple OSS Distributions return 0;
377*4f1223e8SApple OSS Distributions }
378*4f1223e8SApple OSS Distributions
379*4f1223e8SApple OSS Distributions int
err_fsync(__unused struct vnop_fsync_args * ap)380*4f1223e8SApple OSS Distributions err_fsync(__unused struct vnop_fsync_args *ap)
381*4f1223e8SApple OSS Distributions {
382*4f1223e8SApple OSS Distributions return ENOTSUP;
383*4f1223e8SApple OSS Distributions }
384*4f1223e8SApple OSS Distributions
385*4f1223e8SApple OSS Distributions
386*4f1223e8SApple OSS Distributions struct vnop_remove_args /* {
387*4f1223e8SApple OSS Distributions * struct vnode *a_dvp;
388*4f1223e8SApple OSS Distributions * struct vnode *a_vp;
389*4f1223e8SApple OSS Distributions * struct componentname *a_cnp;
390*4f1223e8SApple OSS Distributions * int a_flags;
391*4f1223e8SApple OSS Distributions * vfs_context_t a_context;
392*4f1223e8SApple OSS Distributions * } */;
393*4f1223e8SApple OSS Distributions
394*4f1223e8SApple OSS Distributions int
nop_remove(__unused struct vnop_remove_args * ap)395*4f1223e8SApple OSS Distributions nop_remove(__unused struct vnop_remove_args *ap)
396*4f1223e8SApple OSS Distributions {
397*4f1223e8SApple OSS Distributions return 0;
398*4f1223e8SApple OSS Distributions }
399*4f1223e8SApple OSS Distributions
400*4f1223e8SApple OSS Distributions int
err_remove(struct vnop_remove_args * ap)401*4f1223e8SApple OSS Distributions err_remove(struct vnop_remove_args *ap)
402*4f1223e8SApple OSS Distributions {
403*4f1223e8SApple OSS Distributions (void)nop_remove(ap);
404*4f1223e8SApple OSS Distributions return ENOTSUP;
405*4f1223e8SApple OSS Distributions }
406*4f1223e8SApple OSS Distributions
407*4f1223e8SApple OSS Distributions
408*4f1223e8SApple OSS Distributions struct vnop_link_args /* {
409*4f1223e8SApple OSS Distributions * struct vnode *a_vp;
410*4f1223e8SApple OSS Distributions * struct vnode *a_tdvp;
411*4f1223e8SApple OSS Distributions * struct componentname *a_cnp;
412*4f1223e8SApple OSS Distributions * vfs_context_t a_context;
413*4f1223e8SApple OSS Distributions * } */;
414*4f1223e8SApple OSS Distributions
415*4f1223e8SApple OSS Distributions int
nop_link(__unused struct vnop_link_args * ap)416*4f1223e8SApple OSS Distributions nop_link(__unused struct vnop_link_args *ap)
417*4f1223e8SApple OSS Distributions {
418*4f1223e8SApple OSS Distributions return 0;
419*4f1223e8SApple OSS Distributions }
420*4f1223e8SApple OSS Distributions
421*4f1223e8SApple OSS Distributions int
err_link(struct vnop_link_args * ap)422*4f1223e8SApple OSS Distributions err_link(struct vnop_link_args *ap)
423*4f1223e8SApple OSS Distributions {
424*4f1223e8SApple OSS Distributions (void)nop_link(ap);
425*4f1223e8SApple OSS Distributions return ENOTSUP;
426*4f1223e8SApple OSS Distributions }
427*4f1223e8SApple OSS Distributions
428*4f1223e8SApple OSS Distributions
429*4f1223e8SApple OSS Distributions struct vnop_rename_args /* {
430*4f1223e8SApple OSS Distributions * struct vnode *a_fdvp;
431*4f1223e8SApple OSS Distributions * struct vnode *a_fvp;
432*4f1223e8SApple OSS Distributions * struct componentname *a_fcnp;
433*4f1223e8SApple OSS Distributions * struct vnode *a_tdvp;
434*4f1223e8SApple OSS Distributions * struct vnode *a_tvp;
435*4f1223e8SApple OSS Distributions * struct componentname *a_tcnp;
436*4f1223e8SApple OSS Distributions * vfs_context_t a_context;
437*4f1223e8SApple OSS Distributions * } */;
438*4f1223e8SApple OSS Distributions
439*4f1223e8SApple OSS Distributions int
nop_rename(__unused struct vnop_rename_args * ap)440*4f1223e8SApple OSS Distributions nop_rename(__unused struct vnop_rename_args *ap)
441*4f1223e8SApple OSS Distributions {
442*4f1223e8SApple OSS Distributions return 0;
443*4f1223e8SApple OSS Distributions }
444*4f1223e8SApple OSS Distributions
445*4f1223e8SApple OSS Distributions int
err_rename(struct vnop_rename_args * ap)446*4f1223e8SApple OSS Distributions err_rename(struct vnop_rename_args *ap)
447*4f1223e8SApple OSS Distributions {
448*4f1223e8SApple OSS Distributions (void)nop_rename(ap);
449*4f1223e8SApple OSS Distributions return ENOTSUP;
450*4f1223e8SApple OSS Distributions }
451*4f1223e8SApple OSS Distributions
452*4f1223e8SApple OSS Distributions
453*4f1223e8SApple OSS Distributions struct vnop_mkdir_args /* {
454*4f1223e8SApple OSS Distributions * struct vnode *a_dvp;
455*4f1223e8SApple OSS Distributions * struct vnode **a_vpp;
456*4f1223e8SApple OSS Distributions * struct componentname *a_cnp;
457*4f1223e8SApple OSS Distributions * struct vnode_vattr *a_vap;
458*4f1223e8SApple OSS Distributions * vfs_context_t a_context;
459*4f1223e8SApple OSS Distributions * } */;
460*4f1223e8SApple OSS Distributions
461*4f1223e8SApple OSS Distributions int
nop_mkdir(__unused struct vnop_mkdir_args * ap)462*4f1223e8SApple OSS Distributions nop_mkdir(__unused struct vnop_mkdir_args *ap)
463*4f1223e8SApple OSS Distributions {
464*4f1223e8SApple OSS Distributions return 0;
465*4f1223e8SApple OSS Distributions }
466*4f1223e8SApple OSS Distributions
467*4f1223e8SApple OSS Distributions int
err_mkdir(__unused struct vnop_mkdir_args * ap)468*4f1223e8SApple OSS Distributions err_mkdir(__unused struct vnop_mkdir_args *ap)
469*4f1223e8SApple OSS Distributions {
470*4f1223e8SApple OSS Distributions return ENOTSUP;
471*4f1223e8SApple OSS Distributions }
472*4f1223e8SApple OSS Distributions
473*4f1223e8SApple OSS Distributions
474*4f1223e8SApple OSS Distributions struct vnop_rmdir_args /* {
475*4f1223e8SApple OSS Distributions * struct vnode *a_dvp;
476*4f1223e8SApple OSS Distributions * struct vnode *a_vp;
477*4f1223e8SApple OSS Distributions * struct componentname *a_cnp;
478*4f1223e8SApple OSS Distributions * vfs_context_t a_context;
479*4f1223e8SApple OSS Distributions * } */;
480*4f1223e8SApple OSS Distributions
481*4f1223e8SApple OSS Distributions int
nop_rmdir(__unused struct vnop_rmdir_args * ap)482*4f1223e8SApple OSS Distributions nop_rmdir(__unused struct vnop_rmdir_args *ap)
483*4f1223e8SApple OSS Distributions {
484*4f1223e8SApple OSS Distributions return 0;
485*4f1223e8SApple OSS Distributions }
486*4f1223e8SApple OSS Distributions
487*4f1223e8SApple OSS Distributions int
err_rmdir(struct vnop_rmdir_args * ap)488*4f1223e8SApple OSS Distributions err_rmdir(struct vnop_rmdir_args *ap)
489*4f1223e8SApple OSS Distributions {
490*4f1223e8SApple OSS Distributions (void)nop_rmdir(ap);
491*4f1223e8SApple OSS Distributions return ENOTSUP;
492*4f1223e8SApple OSS Distributions }
493*4f1223e8SApple OSS Distributions
494*4f1223e8SApple OSS Distributions
495*4f1223e8SApple OSS Distributions struct vnop_symlink_args /* {
496*4f1223e8SApple OSS Distributions * struct vnode *a_dvp;
497*4f1223e8SApple OSS Distributions * struct vnode **a_vpp;
498*4f1223e8SApple OSS Distributions * struct componentname *a_cnp;
499*4f1223e8SApple OSS Distributions * struct vnode_vattr *a_vap;
500*4f1223e8SApple OSS Distributions * char *a_target;
501*4f1223e8SApple OSS Distributions * vfs_context_t a_context;
502*4f1223e8SApple OSS Distributions * } */;
503*4f1223e8SApple OSS Distributions
504*4f1223e8SApple OSS Distributions int
nop_symlink(__unused struct vnop_symlink_args * ap)505*4f1223e8SApple OSS Distributions nop_symlink(__unused struct vnop_symlink_args *ap)
506*4f1223e8SApple OSS Distributions {
507*4f1223e8SApple OSS Distributions #if DIAGNOSTIC
508*4f1223e8SApple OSS Distributions if ((ap->a_cnp->cn_flags & HASBUF) == 0) {
509*4f1223e8SApple OSS Distributions panic("nop_symlink: no name");
510*4f1223e8SApple OSS Distributions }
511*4f1223e8SApple OSS Distributions #endif
512*4f1223e8SApple OSS Distributions return 0;
513*4f1223e8SApple OSS Distributions }
514*4f1223e8SApple OSS Distributions
515*4f1223e8SApple OSS Distributions int
err_symlink(struct vnop_symlink_args * ap)516*4f1223e8SApple OSS Distributions err_symlink(struct vnop_symlink_args *ap)
517*4f1223e8SApple OSS Distributions {
518*4f1223e8SApple OSS Distributions (void)nop_symlink(ap);
519*4f1223e8SApple OSS Distributions return ENOTSUP;
520*4f1223e8SApple OSS Distributions }
521*4f1223e8SApple OSS Distributions
522*4f1223e8SApple OSS Distributions
523*4f1223e8SApple OSS Distributions struct vnop_readdir_args /* {
524*4f1223e8SApple OSS Distributions * vnode_t a_vp;
525*4f1223e8SApple OSS Distributions * struct uio *a_uio;
526*4f1223e8SApple OSS Distributions * int a_flags;
527*4f1223e8SApple OSS Distributions * int *a_eofflag;
528*4f1223e8SApple OSS Distributions * int *a_numdirent;
529*4f1223e8SApple OSS Distributions * vfs_context_t a_context;
530*4f1223e8SApple OSS Distributions * } */;
531*4f1223e8SApple OSS Distributions
532*4f1223e8SApple OSS Distributions int
nop_readdir(__unused struct vnop_readdir_args * ap)533*4f1223e8SApple OSS Distributions nop_readdir(__unused struct vnop_readdir_args *ap)
534*4f1223e8SApple OSS Distributions {
535*4f1223e8SApple OSS Distributions return 0;
536*4f1223e8SApple OSS Distributions }
537*4f1223e8SApple OSS Distributions
538*4f1223e8SApple OSS Distributions int
err_readdir(__unused struct vnop_readdir_args * ap)539*4f1223e8SApple OSS Distributions err_readdir(__unused struct vnop_readdir_args *ap)
540*4f1223e8SApple OSS Distributions {
541*4f1223e8SApple OSS Distributions return ENOTSUP;
542*4f1223e8SApple OSS Distributions }
543*4f1223e8SApple OSS Distributions
544*4f1223e8SApple OSS Distributions
545*4f1223e8SApple OSS Distributions struct vnop_readdirattr_args /* {
546*4f1223e8SApple OSS Distributions * struct vnodeop_desc *a_desc;
547*4f1223e8SApple OSS Distributions * vnode_t a_vp;
548*4f1223e8SApple OSS Distributions * struct attrlist *a_alist;
549*4f1223e8SApple OSS Distributions * struct uio *a_uio;
550*4f1223e8SApple OSS Distributions * u_long a_maxcount;
551*4f1223e8SApple OSS Distributions * u_long a_options;
552*4f1223e8SApple OSS Distributions * u_long *a_newstate;
553*4f1223e8SApple OSS Distributions * int *a_eofflag;
554*4f1223e8SApple OSS Distributions * u_long *a_actualcount;
555*4f1223e8SApple OSS Distributions * vfs_context_t a_context;
556*4f1223e8SApple OSS Distributions * } */;
557*4f1223e8SApple OSS Distributions
558*4f1223e8SApple OSS Distributions int
nop_readdirattr(struct vnop_readdirattr_args * ap)559*4f1223e8SApple OSS Distributions nop_readdirattr(struct vnop_readdirattr_args *ap)
560*4f1223e8SApple OSS Distributions {
561*4f1223e8SApple OSS Distributions *(ap->a_actualcount) = 0;
562*4f1223e8SApple OSS Distributions *(ap->a_eofflag) = 0;
563*4f1223e8SApple OSS Distributions return 0;
564*4f1223e8SApple OSS Distributions }
565*4f1223e8SApple OSS Distributions
566*4f1223e8SApple OSS Distributions int
err_readdirattr(struct vnop_readdirattr_args * ap)567*4f1223e8SApple OSS Distributions err_readdirattr(struct vnop_readdirattr_args *ap)
568*4f1223e8SApple OSS Distributions {
569*4f1223e8SApple OSS Distributions (void)nop_readdirattr(ap);
570*4f1223e8SApple OSS Distributions return ENOTSUP;
571*4f1223e8SApple OSS Distributions }
572*4f1223e8SApple OSS Distributions
573*4f1223e8SApple OSS Distributions
574*4f1223e8SApple OSS Distributions struct vnop_readlink_args /* {
575*4f1223e8SApple OSS Distributions * struct vnode *vp;
576*4f1223e8SApple OSS Distributions * struct uio *uio;
577*4f1223e8SApple OSS Distributions * vfs_context_t a_context;
578*4f1223e8SApple OSS Distributions * } */;
579*4f1223e8SApple OSS Distributions
580*4f1223e8SApple OSS Distributions int
nop_readlink(__unused struct vnop_readlink_args * ap)581*4f1223e8SApple OSS Distributions nop_readlink(__unused struct vnop_readlink_args *ap)
582*4f1223e8SApple OSS Distributions {
583*4f1223e8SApple OSS Distributions return 0;
584*4f1223e8SApple OSS Distributions }
585*4f1223e8SApple OSS Distributions
586*4f1223e8SApple OSS Distributions int
err_readlink(__unused struct vnop_readlink_args * ap)587*4f1223e8SApple OSS Distributions err_readlink(__unused struct vnop_readlink_args *ap)
588*4f1223e8SApple OSS Distributions {
589*4f1223e8SApple OSS Distributions return ENOTSUP;
590*4f1223e8SApple OSS Distributions }
591*4f1223e8SApple OSS Distributions
592*4f1223e8SApple OSS Distributions
593*4f1223e8SApple OSS Distributions struct vnop_inactive_args /* {
594*4f1223e8SApple OSS Distributions * struct vnode *a_vp;
595*4f1223e8SApple OSS Distributions * vfs_context_t a_context;
596*4f1223e8SApple OSS Distributions * } */;
597*4f1223e8SApple OSS Distributions
598*4f1223e8SApple OSS Distributions int
nop_inactive(__unused struct vnop_inactive_args * ap)599*4f1223e8SApple OSS Distributions nop_inactive(__unused struct vnop_inactive_args *ap)
600*4f1223e8SApple OSS Distributions {
601*4f1223e8SApple OSS Distributions return 0;
602*4f1223e8SApple OSS Distributions }
603*4f1223e8SApple OSS Distributions
604*4f1223e8SApple OSS Distributions int
err_inactive(struct vnop_inactive_args * ap)605*4f1223e8SApple OSS Distributions err_inactive(struct vnop_inactive_args *ap)
606*4f1223e8SApple OSS Distributions {
607*4f1223e8SApple OSS Distributions (void)nop_inactive(ap);
608*4f1223e8SApple OSS Distributions return ENOTSUP;
609*4f1223e8SApple OSS Distributions }
610*4f1223e8SApple OSS Distributions
611*4f1223e8SApple OSS Distributions
612*4f1223e8SApple OSS Distributions struct vnop_reclaim_args /* {
613*4f1223e8SApple OSS Distributions * struct vnode *a_vp;
614*4f1223e8SApple OSS Distributions * vfs_context_t a_context;
615*4f1223e8SApple OSS Distributions * } */;
616*4f1223e8SApple OSS Distributions
617*4f1223e8SApple OSS Distributions int
nop_reclaim(__unused struct vnop_reclaim_args * ap)618*4f1223e8SApple OSS Distributions nop_reclaim(__unused struct vnop_reclaim_args *ap)
619*4f1223e8SApple OSS Distributions {
620*4f1223e8SApple OSS Distributions return 0;
621*4f1223e8SApple OSS Distributions }
622*4f1223e8SApple OSS Distributions
623*4f1223e8SApple OSS Distributions int
err_reclaim(__unused struct vnop_reclaim_args * ap)624*4f1223e8SApple OSS Distributions err_reclaim(__unused struct vnop_reclaim_args *ap)
625*4f1223e8SApple OSS Distributions {
626*4f1223e8SApple OSS Distributions return ENOTSUP;
627*4f1223e8SApple OSS Distributions }
628*4f1223e8SApple OSS Distributions
629*4f1223e8SApple OSS Distributions
630*4f1223e8SApple OSS Distributions struct vnop_strategy_args /* {
631*4f1223e8SApple OSS Distributions * struct buf *a_bp;
632*4f1223e8SApple OSS Distributions * } */;
633*4f1223e8SApple OSS Distributions
634*4f1223e8SApple OSS Distributions int
nop_strategy(__unused struct vnop_strategy_args * ap)635*4f1223e8SApple OSS Distributions nop_strategy(__unused struct vnop_strategy_args *ap)
636*4f1223e8SApple OSS Distributions {
637*4f1223e8SApple OSS Distributions return 0;
638*4f1223e8SApple OSS Distributions }
639*4f1223e8SApple OSS Distributions
640*4f1223e8SApple OSS Distributions int
err_strategy(__unused struct vnop_strategy_args * ap)641*4f1223e8SApple OSS Distributions err_strategy(__unused struct vnop_strategy_args *ap)
642*4f1223e8SApple OSS Distributions {
643*4f1223e8SApple OSS Distributions return ENOTSUP;
644*4f1223e8SApple OSS Distributions }
645*4f1223e8SApple OSS Distributions
646*4f1223e8SApple OSS Distributions
647*4f1223e8SApple OSS Distributions struct vnop_pathconf_args /* {
648*4f1223e8SApple OSS Distributions * struct vnode *a_vp;
649*4f1223e8SApple OSS Distributions * int a_name;
650*4f1223e8SApple OSS Distributions * int32_t *a_retval;
651*4f1223e8SApple OSS Distributions * vfs_context_t a_context;
652*4f1223e8SApple OSS Distributions * } */;
653*4f1223e8SApple OSS Distributions
654*4f1223e8SApple OSS Distributions int
nop_pathconf(__unused struct vnop_pathconf_args * ap)655*4f1223e8SApple OSS Distributions nop_pathconf(__unused struct vnop_pathconf_args *ap)
656*4f1223e8SApple OSS Distributions {
657*4f1223e8SApple OSS Distributions return 0;
658*4f1223e8SApple OSS Distributions }
659*4f1223e8SApple OSS Distributions
660*4f1223e8SApple OSS Distributions int
err_pathconf(__unused struct vnop_pathconf_args * ap)661*4f1223e8SApple OSS Distributions err_pathconf(__unused struct vnop_pathconf_args *ap)
662*4f1223e8SApple OSS Distributions {
663*4f1223e8SApple OSS Distributions return ENOTSUP;
664*4f1223e8SApple OSS Distributions }
665*4f1223e8SApple OSS Distributions
666*4f1223e8SApple OSS Distributions
667*4f1223e8SApple OSS Distributions struct vnop_advlock_args /* {
668*4f1223e8SApple OSS Distributions * struct vnode *a_vp;
669*4f1223e8SApple OSS Distributions * caddr_t a_id;
670*4f1223e8SApple OSS Distributions * int a_op;
671*4f1223e8SApple OSS Distributions * struct flock *a_fl;
672*4f1223e8SApple OSS Distributions * int a_flags;
673*4f1223e8SApple OSS Distributions * vfs_context_t a_context;
674*4f1223e8SApple OSS Distributions * } */;
675*4f1223e8SApple OSS Distributions
676*4f1223e8SApple OSS Distributions int
nop_advlock(__unused struct vnop_advlock_args * ap)677*4f1223e8SApple OSS Distributions nop_advlock(__unused struct vnop_advlock_args *ap)
678*4f1223e8SApple OSS Distributions {
679*4f1223e8SApple OSS Distributions return 0;
680*4f1223e8SApple OSS Distributions }
681*4f1223e8SApple OSS Distributions
682*4f1223e8SApple OSS Distributions int
err_advlock(__unused struct vnop_advlock_args * ap)683*4f1223e8SApple OSS Distributions err_advlock(__unused struct vnop_advlock_args *ap)
684*4f1223e8SApple OSS Distributions {
685*4f1223e8SApple OSS Distributions return ENOTSUP;
686*4f1223e8SApple OSS Distributions }
687*4f1223e8SApple OSS Distributions
688*4f1223e8SApple OSS Distributions
689*4f1223e8SApple OSS Distributions
690*4f1223e8SApple OSS Distributions struct vnop_allocate_args /* {
691*4f1223e8SApple OSS Distributions * struct vnode *a_vp;
692*4f1223e8SApple OSS Distributions * off_t a_length;
693*4f1223e8SApple OSS Distributions * u_int32_t a_flags;
694*4f1223e8SApple OSS Distributions * off_t *a_bytesallocated;
695*4f1223e8SApple OSS Distributions * off_t a_offset;
696*4f1223e8SApple OSS Distributions * vfs_context_t a_context;
697*4f1223e8SApple OSS Distributions * } */;
698*4f1223e8SApple OSS Distributions
699*4f1223e8SApple OSS Distributions int
nop_allocate(struct vnop_allocate_args * ap)700*4f1223e8SApple OSS Distributions nop_allocate(struct vnop_allocate_args *ap)
701*4f1223e8SApple OSS Distributions {
702*4f1223e8SApple OSS Distributions *(ap->a_bytesallocated) = 0;
703*4f1223e8SApple OSS Distributions return 0;
704*4f1223e8SApple OSS Distributions }
705*4f1223e8SApple OSS Distributions
706*4f1223e8SApple OSS Distributions int
err_allocate(struct vnop_allocate_args * ap)707*4f1223e8SApple OSS Distributions err_allocate(struct vnop_allocate_args *ap)
708*4f1223e8SApple OSS Distributions {
709*4f1223e8SApple OSS Distributions (void)nop_allocate(ap);
710*4f1223e8SApple OSS Distributions return ENOTSUP;
711*4f1223e8SApple OSS Distributions }
712*4f1223e8SApple OSS Distributions
713*4f1223e8SApple OSS Distributions struct vnop_bwrite_args /* {
714*4f1223e8SApple OSS Distributions * struct buf *a_bp;
715*4f1223e8SApple OSS Distributions * } */;
716*4f1223e8SApple OSS Distributions
717*4f1223e8SApple OSS Distributions int
nop_bwrite(struct vnop_bwrite_args * ap)718*4f1223e8SApple OSS Distributions nop_bwrite(struct vnop_bwrite_args *ap)
719*4f1223e8SApple OSS Distributions {
720*4f1223e8SApple OSS Distributions return (int)buf_bwrite(ap->a_bp);
721*4f1223e8SApple OSS Distributions }
722*4f1223e8SApple OSS Distributions
723*4f1223e8SApple OSS Distributions int
err_bwrite(__unused struct vnop_bwrite_args * ap)724*4f1223e8SApple OSS Distributions err_bwrite(__unused struct vnop_bwrite_args *ap)
725*4f1223e8SApple OSS Distributions {
726*4f1223e8SApple OSS Distributions return ENOTSUP;
727*4f1223e8SApple OSS Distributions }
728*4f1223e8SApple OSS Distributions
729*4f1223e8SApple OSS Distributions
730*4f1223e8SApple OSS Distributions struct vnop_pagein_args /* {
731*4f1223e8SApple OSS Distributions * struct vnode *a_vp,
732*4f1223e8SApple OSS Distributions * upl_t a_pl,
733*4f1223e8SApple OSS Distributions * vm_offset_t a_pl_offset,
734*4f1223e8SApple OSS Distributions * off_t a_foffset,
735*4f1223e8SApple OSS Distributions * size_t a_size,
736*4f1223e8SApple OSS Distributions * int a_flags
737*4f1223e8SApple OSS Distributions * vfs_context_t a_context;
738*4f1223e8SApple OSS Distributions * } */;
739*4f1223e8SApple OSS Distributions
740*4f1223e8SApple OSS Distributions int
nop_pagein(struct vnop_pagein_args * ap)741*4f1223e8SApple OSS Distributions nop_pagein(struct vnop_pagein_args *ap)
742*4f1223e8SApple OSS Distributions {
743*4f1223e8SApple OSS Distributions if (!(ap->a_flags & UPL_NOCOMMIT)) {
744*4f1223e8SApple OSS Distributions assert(ap->a_size <= UINT32_MAX);
745*4f1223e8SApple OSS Distributions ubc_upl_abort_range(ap->a_pl, ap->a_pl_offset, (upl_size_t)ap->a_size, UPL_ABORT_FREE_ON_EMPTY | UPL_ABORT_ERROR);
746*4f1223e8SApple OSS Distributions }
747*4f1223e8SApple OSS Distributions return EINVAL;
748*4f1223e8SApple OSS Distributions }
749*4f1223e8SApple OSS Distributions
750*4f1223e8SApple OSS Distributions int
err_pagein(struct vnop_pagein_args * ap)751*4f1223e8SApple OSS Distributions err_pagein(struct vnop_pagein_args *ap)
752*4f1223e8SApple OSS Distributions {
753*4f1223e8SApple OSS Distributions if (!(ap->a_flags & UPL_NOCOMMIT)) {
754*4f1223e8SApple OSS Distributions assert(ap->a_size <= UINT32_MAX);
755*4f1223e8SApple OSS Distributions ubc_upl_abort_range(ap->a_pl, ap->a_pl_offset, (upl_size_t)ap->a_size, UPL_ABORT_FREE_ON_EMPTY | UPL_ABORT_ERROR);
756*4f1223e8SApple OSS Distributions }
757*4f1223e8SApple OSS Distributions return ENOTSUP;
758*4f1223e8SApple OSS Distributions }
759*4f1223e8SApple OSS Distributions
760*4f1223e8SApple OSS Distributions
761*4f1223e8SApple OSS Distributions struct vnop_pageout_args /* {
762*4f1223e8SApple OSS Distributions * struct vnode *a_vp,
763*4f1223e8SApple OSS Distributions * upl_t a_pl,
764*4f1223e8SApple OSS Distributions * vm_offset_t a_pl_offset,
765*4f1223e8SApple OSS Distributions * off_t a_foffset,
766*4f1223e8SApple OSS Distributions * size_t a_size,
767*4f1223e8SApple OSS Distributions * int a_flags
768*4f1223e8SApple OSS Distributions * vfs_context_t a_context;
769*4f1223e8SApple OSS Distributions * } */;
770*4f1223e8SApple OSS Distributions
771*4f1223e8SApple OSS Distributions int
nop_pageout(struct vnop_pageout_args * ap)772*4f1223e8SApple OSS Distributions nop_pageout(struct vnop_pageout_args *ap)
773*4f1223e8SApple OSS Distributions {
774*4f1223e8SApple OSS Distributions if (!(ap->a_flags & UPL_NOCOMMIT)) {
775*4f1223e8SApple OSS Distributions assert(ap->a_size <= UINT32_MAX);
776*4f1223e8SApple OSS Distributions ubc_upl_abort_range(ap->a_pl, ap->a_pl_offset, (upl_size_t)ap->a_size, UPL_ABORT_FREE_ON_EMPTY | UPL_ABORT_ERROR);
777*4f1223e8SApple OSS Distributions }
778*4f1223e8SApple OSS Distributions return EINVAL;
779*4f1223e8SApple OSS Distributions }
780*4f1223e8SApple OSS Distributions
781*4f1223e8SApple OSS Distributions int
err_pageout(struct vnop_pageout_args * ap)782*4f1223e8SApple OSS Distributions err_pageout(struct vnop_pageout_args *ap)
783*4f1223e8SApple OSS Distributions {
784*4f1223e8SApple OSS Distributions if (!(ap->a_flags & UPL_NOCOMMIT)) {
785*4f1223e8SApple OSS Distributions assert(ap->a_size <= UINT32_MAX);
786*4f1223e8SApple OSS Distributions ubc_upl_abort_range(ap->a_pl, ap->a_pl_offset, (upl_size_t)ap->a_size, UPL_ABORT_FREE_ON_EMPTY | UPL_ABORT_ERROR);
787*4f1223e8SApple OSS Distributions }
788*4f1223e8SApple OSS Distributions return ENOTSUP;
789*4f1223e8SApple OSS Distributions }
790*4f1223e8SApple OSS Distributions
791*4f1223e8SApple OSS Distributions
792*4f1223e8SApple OSS Distributions struct vnop_searchfs /* {
793*4f1223e8SApple OSS Distributions * struct vnode *a_vp;
794*4f1223e8SApple OSS Distributions * void *a_searchparams1;
795*4f1223e8SApple OSS Distributions * void *a_searchparams2;
796*4f1223e8SApple OSS Distributions * struct attrlist *a_searchattrs;
797*4f1223e8SApple OSS Distributions * u_long a_maxmatches;
798*4f1223e8SApple OSS Distributions * struct timeval *a_timelimit;
799*4f1223e8SApple OSS Distributions * struct attrlist *a_returnattrs;
800*4f1223e8SApple OSS Distributions * u_long *a_nummatches;
801*4f1223e8SApple OSS Distributions * u_long a_scriptcode;
802*4f1223e8SApple OSS Distributions * u_long a_options;
803*4f1223e8SApple OSS Distributions * struct uio *a_uio;
804*4f1223e8SApple OSS Distributions * struct searchstate *a_searchstate;
805*4f1223e8SApple OSS Distributions * vfs_context_t a_context;
806*4f1223e8SApple OSS Distributions * } */;
807*4f1223e8SApple OSS Distributions
808*4f1223e8SApple OSS Distributions int
nop_searchfs(struct vnop_searchfs_args * ap)809*4f1223e8SApple OSS Distributions nop_searchfs(struct vnop_searchfs_args *ap)
810*4f1223e8SApple OSS Distributions {
811*4f1223e8SApple OSS Distributions *(ap->a_nummatches) = 0;
812*4f1223e8SApple OSS Distributions return 0;
813*4f1223e8SApple OSS Distributions }
814*4f1223e8SApple OSS Distributions
815*4f1223e8SApple OSS Distributions int
err_searchfs(struct vnop_searchfs_args * ap)816*4f1223e8SApple OSS Distributions err_searchfs(struct vnop_searchfs_args *ap)
817*4f1223e8SApple OSS Distributions {
818*4f1223e8SApple OSS Distributions (void)nop_searchfs(ap);
819*4f1223e8SApple OSS Distributions return ENOTSUP;
820*4f1223e8SApple OSS Distributions }
821*4f1223e8SApple OSS Distributions
822*4f1223e8SApple OSS Distributions struct vnop_copyfile_args /*{
823*4f1223e8SApple OSS Distributions * struct vnodeop_desc *a_desc;
824*4f1223e8SApple OSS Distributions * struct vnode *a_fvp;
825*4f1223e8SApple OSS Distributions * struct vnode *a_tdvp;
826*4f1223e8SApple OSS Distributions * struct vnode *a_tvp;
827*4f1223e8SApple OSS Distributions * struct componentname *a_tcnp;
828*4f1223e8SApple OSS Distributions * int a_flags;
829*4f1223e8SApple OSS Distributions * }*/;
830*4f1223e8SApple OSS Distributions
831*4f1223e8SApple OSS Distributions int
nop_copyfile(__unused struct vnop_copyfile_args * ap)832*4f1223e8SApple OSS Distributions nop_copyfile(__unused struct vnop_copyfile_args *ap)
833*4f1223e8SApple OSS Distributions {
834*4f1223e8SApple OSS Distributions return 0;
835*4f1223e8SApple OSS Distributions }
836*4f1223e8SApple OSS Distributions
837*4f1223e8SApple OSS Distributions
838*4f1223e8SApple OSS Distributions int
err_copyfile(struct vnop_copyfile_args * ap)839*4f1223e8SApple OSS Distributions err_copyfile(struct vnop_copyfile_args *ap)
840*4f1223e8SApple OSS Distributions {
841*4f1223e8SApple OSS Distributions (void)nop_copyfile(ap);
842*4f1223e8SApple OSS Distributions return ENOTSUP;
843*4f1223e8SApple OSS Distributions }
844*4f1223e8SApple OSS Distributions
845*4f1223e8SApple OSS Distributions
846*4f1223e8SApple OSS Distributions struct vnop_blktooff_args /* {
847*4f1223e8SApple OSS Distributions * struct vnode *a_vp;
848*4f1223e8SApple OSS Distributions * daddr64_t a_lblkno;
849*4f1223e8SApple OSS Distributions * off_t *a_offset;
850*4f1223e8SApple OSS Distributions * } */;
851*4f1223e8SApple OSS Distributions
852*4f1223e8SApple OSS Distributions int
nop_blktooff(struct vnop_blktooff_args * ap)853*4f1223e8SApple OSS Distributions nop_blktooff(struct vnop_blktooff_args *ap)
854*4f1223e8SApple OSS Distributions {
855*4f1223e8SApple OSS Distributions *ap->a_offset = (off_t)-1; /* failure */
856*4f1223e8SApple OSS Distributions return 0;
857*4f1223e8SApple OSS Distributions }
858*4f1223e8SApple OSS Distributions
859*4f1223e8SApple OSS Distributions int
err_blktooff(struct vnop_blktooff_args * ap)860*4f1223e8SApple OSS Distributions err_blktooff(struct vnop_blktooff_args *ap)
861*4f1223e8SApple OSS Distributions {
862*4f1223e8SApple OSS Distributions (void)nop_blktooff(ap);
863*4f1223e8SApple OSS Distributions return ENOTSUP;
864*4f1223e8SApple OSS Distributions }
865*4f1223e8SApple OSS Distributions
866*4f1223e8SApple OSS Distributions struct vnop_offtoblk_args /* {
867*4f1223e8SApple OSS Distributions * struct vnode *a_vp;
868*4f1223e8SApple OSS Distributions * off_t a_offset;
869*4f1223e8SApple OSS Distributions * daddr64_t *a_lblkno;
870*4f1223e8SApple OSS Distributions * } */;
871*4f1223e8SApple OSS Distributions
872*4f1223e8SApple OSS Distributions int
nop_offtoblk(struct vnop_offtoblk_args * ap)873*4f1223e8SApple OSS Distributions nop_offtoblk(struct vnop_offtoblk_args *ap)
874*4f1223e8SApple OSS Distributions {
875*4f1223e8SApple OSS Distributions *ap->a_lblkno = (daddr64_t)-1; /* failure */
876*4f1223e8SApple OSS Distributions return 0;
877*4f1223e8SApple OSS Distributions }
878*4f1223e8SApple OSS Distributions
879*4f1223e8SApple OSS Distributions int
err_offtoblk(struct vnop_offtoblk_args * ap)880*4f1223e8SApple OSS Distributions err_offtoblk(struct vnop_offtoblk_args *ap)
881*4f1223e8SApple OSS Distributions {
882*4f1223e8SApple OSS Distributions (void)nop_offtoblk(ap);
883*4f1223e8SApple OSS Distributions return ENOTSUP;
884*4f1223e8SApple OSS Distributions }
885*4f1223e8SApple OSS Distributions
886*4f1223e8SApple OSS Distributions struct vnop_blockmap_args /* {
887*4f1223e8SApple OSS Distributions * struct vnode *a_vp;
888*4f1223e8SApple OSS Distributions * off_t a_foffset;
889*4f1223e8SApple OSS Distributions * size_t a_size;
890*4f1223e8SApple OSS Distributions * daddr64_t *a_bpn;
891*4f1223e8SApple OSS Distributions * size_t *a_run;
892*4f1223e8SApple OSS Distributions * void *a_poff;
893*4f1223e8SApple OSS Distributions * int a_flags;
894*4f1223e8SApple OSS Distributions * } */;
895*4f1223e8SApple OSS Distributions
896*4f1223e8SApple OSS Distributions int
nop_blockmap(__unused struct vnop_blockmap_args * ap)897*4f1223e8SApple OSS Distributions nop_blockmap(__unused struct vnop_blockmap_args *ap)
898*4f1223e8SApple OSS Distributions {
899*4f1223e8SApple OSS Distributions return 0;
900*4f1223e8SApple OSS Distributions }
901*4f1223e8SApple OSS Distributions
902*4f1223e8SApple OSS Distributions int
err_blockmap(__unused struct vnop_blockmap_args * ap)903*4f1223e8SApple OSS Distributions err_blockmap(__unused struct vnop_blockmap_args *ap)
904*4f1223e8SApple OSS Distributions {
905*4f1223e8SApple OSS Distributions return ENOTSUP;
906*4f1223e8SApple OSS Distributions }
907