vnode_if.c revision 1.7 1 /*
2 * $NetBSD: vnode_if.c,v 1.7 1998/01/05 19:14:39 perry Exp $
3 *
4 * Warning: This file is generated automatically.
5 * (Modifications made here may easily be lost!)
6 *
7 * Created from the file:
8 * NetBSD: vnode_if.src,v 1.12 1997/10/10 02:07:00 fvdl Exp
9 * by the script:
10 * NetBSD: vnode_if.sh,v 1.13 1998/01/05 19:13:04 perry Exp
11 */
12
13 /*
14 * Copyright (c) 1992, 1993
15 * The Regents of the University of California. All rights reserved.
16 *
17 * Redistribution and use in source and binary forms, with or without
18 * modification, are permitted provided that the following conditions
19 * are met:
20 * 1. Redistributions of source code must retain the above copyright
21 * notice, this list of conditions and the following disclaimer.
22 * 2. Redistributions in binary form must reproduce the above copyright
23 * notice, this list of conditions and the following disclaimer in the
24 * documentation and/or other materials provided with the distribution.
25 * 3. All advertising materials mentioning features or use of this software
26 * must display the following acknowledgement:
27 * This product includes software developed by the University of
28 * California, Berkeley and its contributors.
29 * 4. Neither the name of the University nor the names of its contributors
30 * may be used to endorse or promote products derived from this software
31 * without specific prior written permission.
32 *
33 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS AS IS'' AND
34 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
35 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
36 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
37 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
38 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
39 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
40 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
41 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
42 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
43 * SUCH DAMAGE.
44 */
45
46 #include <sys/param.h>
47 #include <sys/mount.h>
48 #include <sys/vnode.h>
49
50 struct vnodeop_desc vop_default_desc = {
51 0,
52 "default",
53 0,
54 NULL,
55 VDESC_NO_OFFSET,
56 VDESC_NO_OFFSET,
57 VDESC_NO_OFFSET,
58 VDESC_NO_OFFSET,
59 NULL,
60 };
61
62
63 int vop_lookup_vp_offsets[] = {
64 VOPARG_OFFSETOF(struct vop_lookup_args,a_dvp),
65 VDESC_NO_OFFSET
66 };
67 struct vnodeop_desc vop_lookup_desc = {
68 0,
69 "vop_lookup",
70 0,
71 vop_lookup_vp_offsets,
72 VOPARG_OFFSETOF(struct vop_lookup_args, a_vpp),
73 VDESC_NO_OFFSET,
74 VDESC_NO_OFFSET,
75 VOPARG_OFFSETOF(struct vop_lookup_args, a_cnp),
76 NULL,
77 };
78
79 int vop_create_vp_offsets[] = {
80 VOPARG_OFFSETOF(struct vop_create_args,a_dvp),
81 VDESC_NO_OFFSET
82 };
83 struct vnodeop_desc vop_create_desc = {
84 0,
85 "vop_create",
86 0 | VDESC_VP0_WILLRELE,
87 vop_create_vp_offsets,
88 VOPARG_OFFSETOF(struct vop_create_args, a_vpp),
89 VDESC_NO_OFFSET,
90 VDESC_NO_OFFSET,
91 VOPARG_OFFSETOF(struct vop_create_args, a_cnp),
92 NULL,
93 };
94
95 int vop_mknod_vp_offsets[] = {
96 VOPARG_OFFSETOF(struct vop_mknod_args,a_dvp),
97 VDESC_NO_OFFSET
98 };
99 struct vnodeop_desc vop_mknod_desc = {
100 0,
101 "vop_mknod",
102 0 | VDESC_VP0_WILLRELE | VDESC_VPP_WILLRELE,
103 vop_mknod_vp_offsets,
104 VOPARG_OFFSETOF(struct vop_mknod_args, a_vpp),
105 VDESC_NO_OFFSET,
106 VDESC_NO_OFFSET,
107 VOPARG_OFFSETOF(struct vop_mknod_args, a_cnp),
108 NULL,
109 };
110
111 int vop_open_vp_offsets[] = {
112 VOPARG_OFFSETOF(struct vop_open_args,a_vp),
113 VDESC_NO_OFFSET
114 };
115 struct vnodeop_desc vop_open_desc = {
116 0,
117 "vop_open",
118 0,
119 vop_open_vp_offsets,
120 VDESC_NO_OFFSET,
121 VOPARG_OFFSETOF(struct vop_open_args, a_cred),
122 VOPARG_OFFSETOF(struct vop_open_args, a_p),
123 VDESC_NO_OFFSET,
124 NULL,
125 };
126
127 int vop_close_vp_offsets[] = {
128 VOPARG_OFFSETOF(struct vop_close_args,a_vp),
129 VDESC_NO_OFFSET
130 };
131 struct vnodeop_desc vop_close_desc = {
132 0,
133 "vop_close",
134 0,
135 vop_close_vp_offsets,
136 VDESC_NO_OFFSET,
137 VOPARG_OFFSETOF(struct vop_close_args, a_cred),
138 VOPARG_OFFSETOF(struct vop_close_args, a_p),
139 VDESC_NO_OFFSET,
140 NULL,
141 };
142
143 int vop_access_vp_offsets[] = {
144 VOPARG_OFFSETOF(struct vop_access_args,a_vp),
145 VDESC_NO_OFFSET
146 };
147 struct vnodeop_desc vop_access_desc = {
148 0,
149 "vop_access",
150 0,
151 vop_access_vp_offsets,
152 VDESC_NO_OFFSET,
153 VOPARG_OFFSETOF(struct vop_access_args, a_cred),
154 VOPARG_OFFSETOF(struct vop_access_args, a_p),
155 VDESC_NO_OFFSET,
156 NULL,
157 };
158
159 int vop_getattr_vp_offsets[] = {
160 VOPARG_OFFSETOF(struct vop_getattr_args,a_vp),
161 VDESC_NO_OFFSET
162 };
163 struct vnodeop_desc vop_getattr_desc = {
164 0,
165 "vop_getattr",
166 0,
167 vop_getattr_vp_offsets,
168 VDESC_NO_OFFSET,
169 VOPARG_OFFSETOF(struct vop_getattr_args, a_cred),
170 VOPARG_OFFSETOF(struct vop_getattr_args, a_p),
171 VDESC_NO_OFFSET,
172 NULL,
173 };
174
175 int vop_setattr_vp_offsets[] = {
176 VOPARG_OFFSETOF(struct vop_setattr_args,a_vp),
177 VDESC_NO_OFFSET
178 };
179 struct vnodeop_desc vop_setattr_desc = {
180 0,
181 "vop_setattr",
182 0,
183 vop_setattr_vp_offsets,
184 VDESC_NO_OFFSET,
185 VOPARG_OFFSETOF(struct vop_setattr_args, a_cred),
186 VOPARG_OFFSETOF(struct vop_setattr_args, a_p),
187 VDESC_NO_OFFSET,
188 NULL,
189 };
190
191 int vop_read_vp_offsets[] = {
192 VOPARG_OFFSETOF(struct vop_read_args,a_vp),
193 VDESC_NO_OFFSET
194 };
195 struct vnodeop_desc vop_read_desc = {
196 0,
197 "vop_read",
198 0,
199 vop_read_vp_offsets,
200 VDESC_NO_OFFSET,
201 VOPARG_OFFSETOF(struct vop_read_args, a_cred),
202 VDESC_NO_OFFSET,
203 VDESC_NO_OFFSET,
204 NULL,
205 };
206
207 int vop_write_vp_offsets[] = {
208 VOPARG_OFFSETOF(struct vop_write_args,a_vp),
209 VDESC_NO_OFFSET
210 };
211 struct vnodeop_desc vop_write_desc = {
212 0,
213 "vop_write",
214 0,
215 vop_write_vp_offsets,
216 VDESC_NO_OFFSET,
217 VOPARG_OFFSETOF(struct vop_write_args, a_cred),
218 VDESC_NO_OFFSET,
219 VDESC_NO_OFFSET,
220 NULL,
221 };
222
223 int vop_ioctl_vp_offsets[] = {
224 VOPARG_OFFSETOF(struct vop_ioctl_args,a_vp),
225 VDESC_NO_OFFSET
226 };
227 struct vnodeop_desc vop_ioctl_desc = {
228 0,
229 "vop_ioctl",
230 0,
231 vop_ioctl_vp_offsets,
232 VDESC_NO_OFFSET,
233 VOPARG_OFFSETOF(struct vop_ioctl_args, a_cred),
234 VOPARG_OFFSETOF(struct vop_ioctl_args, a_p),
235 VDESC_NO_OFFSET,
236 NULL,
237 };
238
239 int vop_poll_vp_offsets[] = {
240 VOPARG_OFFSETOF(struct vop_poll_args,a_vp),
241 VDESC_NO_OFFSET
242 };
243 struct vnodeop_desc vop_poll_desc = {
244 0,
245 "vop_poll",
246 0,
247 vop_poll_vp_offsets,
248 VDESC_NO_OFFSET,
249 VDESC_NO_OFFSET,
250 VOPARG_OFFSETOF(struct vop_poll_args, a_p),
251 VDESC_NO_OFFSET,
252 NULL,
253 };
254
255 int vop_mmap_vp_offsets[] = {
256 VOPARG_OFFSETOF(struct vop_mmap_args,a_vp),
257 VDESC_NO_OFFSET
258 };
259 struct vnodeop_desc vop_mmap_desc = {
260 0,
261 "vop_mmap",
262 0,
263 vop_mmap_vp_offsets,
264 VDESC_NO_OFFSET,
265 VOPARG_OFFSETOF(struct vop_mmap_args, a_cred),
266 VOPARG_OFFSETOF(struct vop_mmap_args, a_p),
267 VDESC_NO_OFFSET,
268 NULL,
269 };
270
271 int vop_fsync_vp_offsets[] = {
272 VOPARG_OFFSETOF(struct vop_fsync_args,a_vp),
273 VDESC_NO_OFFSET
274 };
275 struct vnodeop_desc vop_fsync_desc = {
276 0,
277 "vop_fsync",
278 0,
279 vop_fsync_vp_offsets,
280 VDESC_NO_OFFSET,
281 VOPARG_OFFSETOF(struct vop_fsync_args, a_cred),
282 VOPARG_OFFSETOF(struct vop_fsync_args, a_p),
283 VDESC_NO_OFFSET,
284 NULL,
285 };
286
287 int vop_seek_vp_offsets[] = {
288 VOPARG_OFFSETOF(struct vop_seek_args,a_vp),
289 VDESC_NO_OFFSET
290 };
291 struct vnodeop_desc vop_seek_desc = {
292 0,
293 "vop_seek",
294 0,
295 vop_seek_vp_offsets,
296 VDESC_NO_OFFSET,
297 VOPARG_OFFSETOF(struct vop_seek_args, a_cred),
298 VDESC_NO_OFFSET,
299 VDESC_NO_OFFSET,
300 NULL,
301 };
302
303 int vop_remove_vp_offsets[] = {
304 VOPARG_OFFSETOF(struct vop_remove_args,a_dvp),
305 VOPARG_OFFSETOF(struct vop_remove_args,a_vp),
306 VDESC_NO_OFFSET
307 };
308 struct vnodeop_desc vop_remove_desc = {
309 0,
310 "vop_remove",
311 0 | VDESC_VP0_WILLRELE | VDESC_VP1_WILLRELE,
312 vop_remove_vp_offsets,
313 VDESC_NO_OFFSET,
314 VDESC_NO_OFFSET,
315 VDESC_NO_OFFSET,
316 VOPARG_OFFSETOF(struct vop_remove_args, a_cnp),
317 NULL,
318 };
319
320 int vop_link_vp_offsets[] = {
321 VOPARG_OFFSETOF(struct vop_link_args,a_dvp),
322 VOPARG_OFFSETOF(struct vop_link_args,a_vp),
323 VDESC_NO_OFFSET
324 };
325 struct vnodeop_desc vop_link_desc = {
326 0,
327 "vop_link",
328 0 | VDESC_VP0_WILLRELE,
329 vop_link_vp_offsets,
330 VDESC_NO_OFFSET,
331 VDESC_NO_OFFSET,
332 VDESC_NO_OFFSET,
333 VOPARG_OFFSETOF(struct vop_link_args, a_cnp),
334 NULL,
335 };
336
337 int vop_rename_vp_offsets[] = {
338 VOPARG_OFFSETOF(struct vop_rename_args,a_fdvp),
339 VOPARG_OFFSETOF(struct vop_rename_args,a_fvp),
340 VOPARG_OFFSETOF(struct vop_rename_args,a_tdvp),
341 VOPARG_OFFSETOF(struct vop_rename_args,a_tvp),
342 VDESC_NO_OFFSET
343 };
344 struct vnodeop_desc vop_rename_desc = {
345 0,
346 "vop_rename",
347 0 | VDESC_VP0_WILLRELE | VDESC_VP1_WILLRELE | VDESC_VP2_WILLRELE | VDESC_VP3_WILLRELE,
348 vop_rename_vp_offsets,
349 VDESC_NO_OFFSET,
350 VDESC_NO_OFFSET,
351 VDESC_NO_OFFSET,
352 VOPARG_OFFSETOF(struct vop_rename_args, a_fcnp),
353 NULL,
354 };
355
356 int vop_mkdir_vp_offsets[] = {
357 VOPARG_OFFSETOF(struct vop_mkdir_args,a_dvp),
358 VDESC_NO_OFFSET
359 };
360 struct vnodeop_desc vop_mkdir_desc = {
361 0,
362 "vop_mkdir",
363 0 | VDESC_VP0_WILLRELE,
364 vop_mkdir_vp_offsets,
365 VOPARG_OFFSETOF(struct vop_mkdir_args, a_vpp),
366 VDESC_NO_OFFSET,
367 VDESC_NO_OFFSET,
368 VOPARG_OFFSETOF(struct vop_mkdir_args, a_cnp),
369 NULL,
370 };
371
372 int vop_rmdir_vp_offsets[] = {
373 VOPARG_OFFSETOF(struct vop_rmdir_args,a_dvp),
374 VOPARG_OFFSETOF(struct vop_rmdir_args,a_vp),
375 VDESC_NO_OFFSET
376 };
377 struct vnodeop_desc vop_rmdir_desc = {
378 0,
379 "vop_rmdir",
380 0 | VDESC_VP0_WILLRELE | VDESC_VP1_WILLRELE,
381 vop_rmdir_vp_offsets,
382 VDESC_NO_OFFSET,
383 VDESC_NO_OFFSET,
384 VDESC_NO_OFFSET,
385 VOPARG_OFFSETOF(struct vop_rmdir_args, a_cnp),
386 NULL,
387 };
388
389 int vop_symlink_vp_offsets[] = {
390 VOPARG_OFFSETOF(struct vop_symlink_args,a_dvp),
391 VDESC_NO_OFFSET
392 };
393 struct vnodeop_desc vop_symlink_desc = {
394 0,
395 "vop_symlink",
396 0 | VDESC_VP0_WILLRELE | VDESC_VPP_WILLRELE,
397 vop_symlink_vp_offsets,
398 VOPARG_OFFSETOF(struct vop_symlink_args, a_vpp),
399 VDESC_NO_OFFSET,
400 VDESC_NO_OFFSET,
401 VOPARG_OFFSETOF(struct vop_symlink_args, a_cnp),
402 NULL,
403 };
404
405 int vop_readdir_vp_offsets[] = {
406 VOPARG_OFFSETOF(struct vop_readdir_args,a_vp),
407 VDESC_NO_OFFSET
408 };
409 struct vnodeop_desc vop_readdir_desc = {
410 0,
411 "vop_readdir",
412 0,
413 vop_readdir_vp_offsets,
414 VDESC_NO_OFFSET,
415 VOPARG_OFFSETOF(struct vop_readdir_args, a_cred),
416 VDESC_NO_OFFSET,
417 VDESC_NO_OFFSET,
418 NULL,
419 };
420
421 int vop_readlink_vp_offsets[] = {
422 VOPARG_OFFSETOF(struct vop_readlink_args,a_vp),
423 VDESC_NO_OFFSET
424 };
425 struct vnodeop_desc vop_readlink_desc = {
426 0,
427 "vop_readlink",
428 0,
429 vop_readlink_vp_offsets,
430 VDESC_NO_OFFSET,
431 VOPARG_OFFSETOF(struct vop_readlink_args, a_cred),
432 VDESC_NO_OFFSET,
433 VDESC_NO_OFFSET,
434 NULL,
435 };
436
437 int vop_abortop_vp_offsets[] = {
438 VOPARG_OFFSETOF(struct vop_abortop_args,a_dvp),
439 VDESC_NO_OFFSET
440 };
441 struct vnodeop_desc vop_abortop_desc = {
442 0,
443 "vop_abortop",
444 0,
445 vop_abortop_vp_offsets,
446 VDESC_NO_OFFSET,
447 VDESC_NO_OFFSET,
448 VDESC_NO_OFFSET,
449 VOPARG_OFFSETOF(struct vop_abortop_args, a_cnp),
450 NULL,
451 };
452
453 int vop_inactive_vp_offsets[] = {
454 VOPARG_OFFSETOF(struct vop_inactive_args,a_vp),
455 VDESC_NO_OFFSET
456 };
457 struct vnodeop_desc vop_inactive_desc = {
458 0,
459 "vop_inactive",
460 0,
461 vop_inactive_vp_offsets,
462 VDESC_NO_OFFSET,
463 VDESC_NO_OFFSET,
464 VDESC_NO_OFFSET,
465 VDESC_NO_OFFSET,
466 NULL,
467 };
468
469 int vop_reclaim_vp_offsets[] = {
470 VOPARG_OFFSETOF(struct vop_reclaim_args,a_vp),
471 VDESC_NO_OFFSET
472 };
473 struct vnodeop_desc vop_reclaim_desc = {
474 0,
475 "vop_reclaim",
476 0,
477 vop_reclaim_vp_offsets,
478 VDESC_NO_OFFSET,
479 VDESC_NO_OFFSET,
480 VDESC_NO_OFFSET,
481 VDESC_NO_OFFSET,
482 NULL,
483 };
484
485 int vop_lock_vp_offsets[] = {
486 VOPARG_OFFSETOF(struct vop_lock_args,a_vp),
487 VDESC_NO_OFFSET
488 };
489 struct vnodeop_desc vop_lock_desc = {
490 0,
491 "vop_lock",
492 0,
493 vop_lock_vp_offsets,
494 VDESC_NO_OFFSET,
495 VDESC_NO_OFFSET,
496 VDESC_NO_OFFSET,
497 VDESC_NO_OFFSET,
498 NULL,
499 };
500
501 int vop_unlock_vp_offsets[] = {
502 VOPARG_OFFSETOF(struct vop_unlock_args,a_vp),
503 VDESC_NO_OFFSET
504 };
505 struct vnodeop_desc vop_unlock_desc = {
506 0,
507 "vop_unlock",
508 0,
509 vop_unlock_vp_offsets,
510 VDESC_NO_OFFSET,
511 VDESC_NO_OFFSET,
512 VDESC_NO_OFFSET,
513 VDESC_NO_OFFSET,
514 NULL,
515 };
516
517 int vop_bmap_vp_offsets[] = {
518 VOPARG_OFFSETOF(struct vop_bmap_args,a_vp),
519 VDESC_NO_OFFSET
520 };
521 struct vnodeop_desc vop_bmap_desc = {
522 0,
523 "vop_bmap",
524 0,
525 vop_bmap_vp_offsets,
526 VOPARG_OFFSETOF(struct vop_bmap_args, a_vpp),
527 VDESC_NO_OFFSET,
528 VDESC_NO_OFFSET,
529 VDESC_NO_OFFSET,
530 NULL,
531 };
532
533 int vop_print_vp_offsets[] = {
534 VOPARG_OFFSETOF(struct vop_print_args,a_vp),
535 VDESC_NO_OFFSET
536 };
537 struct vnodeop_desc vop_print_desc = {
538 0,
539 "vop_print",
540 0,
541 vop_print_vp_offsets,
542 VDESC_NO_OFFSET,
543 VDESC_NO_OFFSET,
544 VDESC_NO_OFFSET,
545 VDESC_NO_OFFSET,
546 NULL,
547 };
548
549 int vop_islocked_vp_offsets[] = {
550 VOPARG_OFFSETOF(struct vop_islocked_args,a_vp),
551 VDESC_NO_OFFSET
552 };
553 struct vnodeop_desc vop_islocked_desc = {
554 0,
555 "vop_islocked",
556 0,
557 vop_islocked_vp_offsets,
558 VDESC_NO_OFFSET,
559 VDESC_NO_OFFSET,
560 VDESC_NO_OFFSET,
561 VDESC_NO_OFFSET,
562 NULL,
563 };
564
565 int vop_pathconf_vp_offsets[] = {
566 VOPARG_OFFSETOF(struct vop_pathconf_args,a_vp),
567 VDESC_NO_OFFSET
568 };
569 struct vnodeop_desc vop_pathconf_desc = {
570 0,
571 "vop_pathconf",
572 0,
573 vop_pathconf_vp_offsets,
574 VDESC_NO_OFFSET,
575 VDESC_NO_OFFSET,
576 VDESC_NO_OFFSET,
577 VDESC_NO_OFFSET,
578 NULL,
579 };
580
581 int vop_advlock_vp_offsets[] = {
582 VOPARG_OFFSETOF(struct vop_advlock_args,a_vp),
583 VDESC_NO_OFFSET
584 };
585 struct vnodeop_desc vop_advlock_desc = {
586 0,
587 "vop_advlock",
588 0,
589 vop_advlock_vp_offsets,
590 VDESC_NO_OFFSET,
591 VDESC_NO_OFFSET,
592 VDESC_NO_OFFSET,
593 VDESC_NO_OFFSET,
594 NULL,
595 };
596
597 int vop_blkatoff_vp_offsets[] = {
598 VOPARG_OFFSETOF(struct vop_blkatoff_args,a_vp),
599 VDESC_NO_OFFSET
600 };
601 struct vnodeop_desc vop_blkatoff_desc = {
602 0,
603 "vop_blkatoff",
604 0,
605 vop_blkatoff_vp_offsets,
606 VDESC_NO_OFFSET,
607 VDESC_NO_OFFSET,
608 VDESC_NO_OFFSET,
609 VDESC_NO_OFFSET,
610 NULL,
611 };
612
613 int vop_valloc_vp_offsets[] = {
614 VOPARG_OFFSETOF(struct vop_valloc_args,a_pvp),
615 VDESC_NO_OFFSET
616 };
617 struct vnodeop_desc vop_valloc_desc = {
618 0,
619 "vop_valloc",
620 0,
621 vop_valloc_vp_offsets,
622 VOPARG_OFFSETOF(struct vop_valloc_args, a_vpp),
623 VOPARG_OFFSETOF(struct vop_valloc_args, a_cred),
624 VDESC_NO_OFFSET,
625 VDESC_NO_OFFSET,
626 NULL,
627 };
628
629 int vop_reallocblks_vp_offsets[] = {
630 VOPARG_OFFSETOF(struct vop_reallocblks_args,a_vp),
631 VDESC_NO_OFFSET
632 };
633 struct vnodeop_desc vop_reallocblks_desc = {
634 0,
635 "vop_reallocblks",
636 0,
637 vop_reallocblks_vp_offsets,
638 VDESC_NO_OFFSET,
639 VDESC_NO_OFFSET,
640 VDESC_NO_OFFSET,
641 VDESC_NO_OFFSET,
642 NULL,
643 };
644
645 int vop_vfree_vp_offsets[] = {
646 VOPARG_OFFSETOF(struct vop_vfree_args,a_pvp),
647 VDESC_NO_OFFSET
648 };
649 struct vnodeop_desc vop_vfree_desc = {
650 0,
651 "vop_vfree",
652 0,
653 vop_vfree_vp_offsets,
654 VDESC_NO_OFFSET,
655 VDESC_NO_OFFSET,
656 VDESC_NO_OFFSET,
657 VDESC_NO_OFFSET,
658 NULL,
659 };
660
661 int vop_truncate_vp_offsets[] = {
662 VOPARG_OFFSETOF(struct vop_truncate_args,a_vp),
663 VDESC_NO_OFFSET
664 };
665 struct vnodeop_desc vop_truncate_desc = {
666 0,
667 "vop_truncate",
668 0,
669 vop_truncate_vp_offsets,
670 VDESC_NO_OFFSET,
671 VOPARG_OFFSETOF(struct vop_truncate_args, a_cred),
672 VOPARG_OFFSETOF(struct vop_truncate_args, a_p),
673 VDESC_NO_OFFSET,
674 NULL,
675 };
676
677 int vop_update_vp_offsets[] = {
678 VOPARG_OFFSETOF(struct vop_update_args,a_vp),
679 VDESC_NO_OFFSET
680 };
681 struct vnodeop_desc vop_update_desc = {
682 0,
683 "vop_update",
684 0,
685 vop_update_vp_offsets,
686 VDESC_NO_OFFSET,
687 VDESC_NO_OFFSET,
688 VDESC_NO_OFFSET,
689 VDESC_NO_OFFSET,
690 NULL,
691 };
692
693 int vop_lease_vp_offsets[] = {
694 VOPARG_OFFSETOF(struct vop_lease_args,a_vp),
695 VDESC_NO_OFFSET
696 };
697 struct vnodeop_desc vop_lease_desc = {
698 0,
699 "vop_lease",
700 0,
701 vop_lease_vp_offsets,
702 VDESC_NO_OFFSET,
703 VOPARG_OFFSETOF(struct vop_lease_args, a_cred),
704 VOPARG_OFFSETOF(struct vop_lease_args, a_p),
705 VDESC_NO_OFFSET,
706 NULL,
707 };
708
709 int vop_whiteout_vp_offsets[] = {
710 VOPARG_OFFSETOF(struct vop_whiteout_args,a_dvp),
711 VDESC_NO_OFFSET
712 };
713 struct vnodeop_desc vop_whiteout_desc = {
714 0,
715 "vop_whiteout",
716 0,
717 vop_whiteout_vp_offsets,
718 VDESC_NO_OFFSET,
719 VDESC_NO_OFFSET,
720 VDESC_NO_OFFSET,
721 VOPARG_OFFSETOF(struct vop_whiteout_args, a_cnp),
722 NULL,
723 };
724
725 /* Special cases: */
726
727 int vop_strategy_vp_offsets[] = {
728 VDESC_NO_OFFSET
729 };
730 struct vnodeop_desc vop_strategy_desc = {
731 0,
732 "vop_strategy",
733 0,
734 vop_strategy_vp_offsets,
735 VDESC_NO_OFFSET,
736 VDESC_NO_OFFSET,
737 VDESC_NO_OFFSET,
738 VDESC_NO_OFFSET,
739 NULL,
740 };
741
742 int vop_bwrite_vp_offsets[] = {
743 VDESC_NO_OFFSET
744 };
745 struct vnodeop_desc vop_bwrite_desc = {
746 0,
747 "vop_bwrite",
748 0,
749 vop_bwrite_vp_offsets,
750 VDESC_NO_OFFSET,
751 VDESC_NO_OFFSET,
752 VDESC_NO_OFFSET,
753 VDESC_NO_OFFSET,
754 NULL,
755 };
756
757 /* End of special cases. */
758
759 struct vnodeop_desc *vfs_op_descs[] = {
760 &vop_default_desc, /* MUST BE FIRST */
761 &vop_strategy_desc, /* XXX: SPECIAL CASE */
762 &vop_bwrite_desc, /* XXX: SPECIAL CASE */
763
764 &vop_lookup_desc,
765 &vop_create_desc,
766 &vop_mknod_desc,
767 &vop_open_desc,
768 &vop_close_desc,
769 &vop_access_desc,
770 &vop_getattr_desc,
771 &vop_setattr_desc,
772 &vop_read_desc,
773 &vop_write_desc,
774 &vop_ioctl_desc,
775 &vop_poll_desc,
776 &vop_mmap_desc,
777 &vop_fsync_desc,
778 &vop_seek_desc,
779 &vop_remove_desc,
780 &vop_link_desc,
781 &vop_rename_desc,
782 &vop_mkdir_desc,
783 &vop_rmdir_desc,
784 &vop_symlink_desc,
785 &vop_readdir_desc,
786 &vop_readlink_desc,
787 &vop_abortop_desc,
788 &vop_inactive_desc,
789 &vop_reclaim_desc,
790 &vop_lock_desc,
791 &vop_unlock_desc,
792 &vop_bmap_desc,
793 &vop_print_desc,
794 &vop_islocked_desc,
795 &vop_pathconf_desc,
796 &vop_advlock_desc,
797 &vop_blkatoff_desc,
798 &vop_valloc_desc,
799 &vop_reallocblks_desc,
800 &vop_vfree_desc,
801 &vop_truncate_desc,
802 &vop_update_desc,
803 &vop_lease_desc,
804 &vop_whiteout_desc,
805 NULL
806 };
807
808