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