]> git.saurik.com Git - apple/xnu.git/blobdiff - bsd/vfs/vfs_support.c
xnu-6153.11.26.tar.gz
[apple/xnu.git] / bsd / vfs / vfs_support.c
index c74bde6fa27e2895f1cf569877b506aff820af64..ca360954192489c0bdf6e768d46ad8b3c4f89d98 100644 (file)
@@ -1,17 +1,20 @@
 /*
- * Copyright (c) 2000 Apple Computer, Inc. All rights reserved.
+ * Copyright (c) 2000-2004 Apple Computer, Inc. All rights reserved.
+ *
+ * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
  *
- * @APPLE_LICENSE_HEADER_START@
- * 
- * Copyright (c) 1999-2003 Apple Computer, Inc.  All Rights Reserved.
- * 
  * This file contains Original Code and/or Modifications of Original Code
  * as defined in and that are subject to the Apple Public Source License
  * Version 2.0 (the 'License'). You may not use this file except in
- * compliance with the License. Please obtain a copy of the License at
- * http://www.opensource.apple.com/apsl/ and read it before using this
- * file.
- * 
+ * compliance with the License. The rights granted to you under the License
+ * may not be used to create, or enable the creation or redistribution of,
+ * unlawful or unlicensed copies of an Apple operating system, or to
+ * circumvent, violate, or enable the circumvention or violation of, any
+ * terms of an Apple operating system software license agreement.
+ *
+ * Please obtain a copy of the License at
+ * http://www.opensource.apple.com/apsl/ and read it before using this file.
+ *
  * The Original Code and all software distributed under the License are
  * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
  * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
@@ -19,8 +22,8 @@
  * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
  * Please see the License for the specific language governing rights and
  * limitations under the License.
- * 
- * @APPLE_LICENSE_HEADER_END@
+ *
+ * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
  */
 /*
  * Copyright (c) 1998-1999 Apple Computer, Inc.  All rights reserved.
@@ -33,7 +36,7 @@
  *     supposed to.
  *
  *     nop_* routines always return 0 [success]
- *     err_* routines always return EOPNOTSUPP
+ *     err_* routines always return ENOTSUP
  *
  *     This file could be auto-generated from vnode_if.src. but that needs
  *     support for freeing cnp.
  */
 
 #include <vfs/vfs_support.h>
+#include <sys/kauth.h>
+#include <sys/ubc.h>    /* ubc_upl_abort_range() */
 
 
-struct vop_create_args /* {
-       struct vnode *a_dvp;
-       struct vnode **a_vpp;
-       struct componentname *a_cnp;
-       struct vattr *a_vap;
-} */;
+struct vnop_create_args /* {
+                         *  struct vnode *a_dvp;
+                         *  struct vnode **a_vpp;
+                         *  struct componentname *a_cnp;
+                         *  struct vnode_vattr *a_vap;
+                         *  vfs_context_t a_context;
+                         *  } */;
 
 int
-nop_create(struct vop_create_args *ap)
+nop_create(__unused struct vnop_create_args *ap)
 {
 #if DIAGNOSTIC
-       if ((ap->a_cnp->cn_flags & HASBUF) == 0)
+       if ((ap->a_cnp->cn_flags & HASBUF) == 0) {
                panic("nop_create: no name");
+       }
 #endif
-       VOP_ABORTOP(ap->a_dvp, ap->a_cnp);
-       vput(ap->a_dvp);
-       return (0);
+       return 0;
 }
 
 int
-err_create(struct vop_create_args *ap)
+err_create(struct vnop_create_args *ap)
 {
        (void)nop_create(ap);
-       return (EOPNOTSUPP);
+       return ENOTSUP;
 }
 
 
-struct vop_whiteout_args /* {
-       struct vnode *a_dvp;
-       struct componentname *a_cnp;
-       int a_flags;
-} */;
+struct vnop_whiteout_args /* {
+                           *  struct vnode *a_dvp;
+                           *  struct componentname *a_cnp;
+                           *  int a_flags;
+                           *  vfs_context_t a_context;
+                           *  } */;
 
 int
-nop_whiteout(struct vop_whiteout_args *ap)
+nop_whiteout(__unused struct vnop_whiteout_args *ap)
 {
-       return (0);
+       return 0;
 }
 
 int
-err_whiteout(struct vop_whiteout_args *ap)
+err_whiteout(__unused struct vnop_whiteout_args *ap)
 {
-       return (EOPNOTSUPP);
+       return ENOTSUP;
 }
 
 
-struct vop_mknod_args /* {
-       struct vnode *a_dvp;
-       struct vnode **a_vpp;
-       struct componentname *a_cnp;
-       struct vattr *a_vap;
-} */;
+struct vnop_mknod_args /* {
+                        *  struct vnode *a_dvp;
+                        *  struct vnode **a_vpp;
+                        *  struct componentname *a_cnp;
+                        *  struct vnode_vattr *a_vap;
+                        *  vfs_context_t a_context;
+                        *  } */;
 
 int
-nop_mknod(struct vop_mknod_args *ap)
+nop_mknod(__unused struct vnop_mknod_args *ap)
 {
 #if DIAGNOSTIC
-       if ((ap->a_cnp->cn_flags & HASBUF) == 0)
+       if ((ap->a_cnp->cn_flags & HASBUF) == 0) {
                panic("nop_mknod: no name");
+       }
 #endif
-       VOP_ABORTOP(ap->a_dvp, ap->a_cnp);
-       vput(ap->a_dvp);
-       return (0);
+       return 0;
 }
 
 int
-err_mknod(struct vop_mknod_args *ap)
+err_mknod(struct vnop_mknod_args *ap)
 {
        (void)nop_mknod(ap);
-       return (EOPNOTSUPP);
-}
-
-
-struct vop_mkcomplex_args /* {
-       struct vnode *a_dvp,
-       struct vnode **a_vpp,
-       struct componentname *a_cnp,
-       struct vattr *a_vap,
-       u_long a_type)
-} */;
-
-int
-nop_mkcomplex(struct vop_mkcomplex_args *ap)
-{
-#if DIAGNOSTIC
-       if ((ap->a_cnp->cn_flags & HASBUF) == 0)
-               panic("nop_mkcomplex: no name");
-#endif
-       VOP_ABORTOP(ap->a_dvp, ap->a_cnp);
-       vput(ap->a_dvp);
-       return (0);
-}
-
-int
-err_mkcomplex(struct vop_mkcomplex_args *ap)
-{
-       (void)nop_mkcomplex(ap);
-       return (EOPNOTSUPP);
-}
-
-
-struct vop_open_args /* {
-       struct vnode *a_vp;
-       int  a_mode;
-       struct ucred *a_cred;
-       struct proc *a_p;
-} */;
-
-int
-nop_open(struct vop_open_args *ap)
-{
-       return (0);
+       return ENOTSUP;
 }
 
-int
-err_open(struct vop_open_args *ap)
-{
-       return (EOPNOTSUPP);
-}
-
-
-struct vop_close_args /* {
-       struct vnode *a_vp;
-       int  a_fflag;
-       struct ucred *a_cred;
-       struct proc *a_p;
-} */;
+struct vnop_open_args /* {
+                       *  struct vnode *a_vp;
+                       *  int  a_mode;
+                       *  vfs_context_t a_context;
+                       *  } */;
 
 int
-nop_close(struct vop_close_args *ap)
+nop_open(__unused struct vnop_open_args *ap)
 {
-       return (0);
+       return 0;
 }
 
 int
-err_close(struct vop_close_args *ap)
+err_open(__unused struct vnop_open_args *ap)
 {
-       return (EOPNOTSUPP);
+       return ENOTSUP;
 }
 
 
-struct vop_access_args /* {
-       struct vnode *a_vp;
-       int  a_mode;
-       struct ucred *a_cred;
-       struct proc *a_p;
-} */;
+struct vnop_close_args /* {
+                        *  struct vnode *a_vp;
+                        *  int  a_fflag;
+                        *  vfs_context_t a_context;
+                        *  } */;
 
 int
-nop_access(struct vop_access_args *ap)
+nop_close(__unused struct vnop_close_args *ap)
 {
-       return (0);
+       return 0;
 }
 
 int
-err_access(struct vop_access_args *ap)
+err_close(__unused struct vnop_close_args *ap)
 {
-       return (EOPNOTSUPP);
+       return ENOTSUP;
 }
 
 
-struct vop_getattr_args /* {
-       struct vnode *a_vp;
-       struct vattr *a_vap;
-       struct ucred *a_cred;
-       struct proc *a_p;
-} */;
+struct vnop_access_args /* {
+                         *  struct vnode *a_vp;
+                         *  int  a_mode;
+                         *  vfs_context_t a_context;
+                         *  } */;
 
 int
-nop_getattr(struct vop_getattr_args *ap)
+nop_access(__unused struct vnop_access_args *ap)
 {
-       return (0);
+       return 0;
 }
 
 int
-err_getattr(struct vop_getattr_args *ap)
+err_access(__unused struct vnop_access_args *ap)
 {
-       return (EOPNOTSUPP);
+       return ENOTSUP;
 }
 
 
-struct vop_setattr_args /* {
-       struct vnode *a_vp;
-       struct vattr *a_vap;
-       struct ucred *a_cred;
-       struct proc *a_p;
-} */;
+struct vnop_getattr_args /* {
+                          *  struct vnode *a_vp;
+                          *  struct vnode_vattr *a_vap;
+                          *  vfs_context_t a_context;
+                          *  } */;
 
 int
-nop_setattr(struct vop_setattr_args *ap)
+nop_getattr(__unused struct vnop_getattr_args *ap)
 {
-       return (0);
+       return 0;
 }
 
 int
-err_setattr(struct vop_setattr_args *ap)
+err_getattr(__unused struct vnop_getattr_args *ap)
 {
-       return (EOPNOTSUPP);
+       return ENOTSUP;
 }
 
 
-struct vop_getattrlist_args /* {
-       struct vnode *a_vp;
-       struct attrlist *a_alist;
-       struct uio *a_uio;
-       struct ucred *a_cred;
-       struct proc *a_p;
-} */;
+struct vnop_setattr_args /* {
+                          *  struct vnode *a_vp;
+                          *  struct vnode_vattr *a_vap;
+                          *  vfs_context_t a_context;
+                          *  } */;
 
 int
-nop_getattrlist(struct vop_getattrlist_args *ap)
+nop_setattr(__unused struct vnop_setattr_args *ap)
 {
-       return (0);
+       return 0;
 }
 
 int
-err_getattrlist(struct vop_getattrlist_args *ap)
+err_setattr(__unused struct vnop_setattr_args *ap)
 {
-       return (EOPNOTSUPP);
+       return ENOTSUP;
 }
 
-
-struct vop_setattrlist_args /* {
-       struct vnode *a_vp;
-       struct attrlist *a_alist;
-       struct uio *a_uio;
-       struct ucred *a_cred;
-       struct proc *a_p;
-} */;
+struct vnop_read_args /*  {
+                       *  struct vnode *a_vp;
+                       *  struct uio *a_uio;
+                       *  int a_ioflag;
+                       *  vfs_context_t a_context;
+                       *  } */;
 
 int
-nop_setattrlist(struct vop_setattrlist_args *ap)
+nop_read(__unused struct vnop_read_args *ap)
 {
-       return (0);
+       return 0;
 }
 
 int
-err_setattrlist(struct vop_setattrlist_args *ap)
+err_read(__unused struct vnop_read_args *ap)
 {
-       return (EOPNOTSUPP);
+       return ENOTSUP;
 }
 
 
-struct vop_read_args /*  {
-       struct vnode *a_vp;
-       struct uio *a_uio;
-       int a_ioflag;
-       struct ucred *a_cred;
-} */;
+struct vnop_write_args /*  {
+                        *  struct vnode *a_vp;
+                        *  struct uio *a_uio;
+                        *  int a_ioflag;
+                        *  vfs_context_t a_context;
+                        *  } */;
 
 int
-nop_read(struct vop_read_args *ap)
+nop_write(__unused struct vnop_write_args *ap)
 {
-       return (0);
+       return 0;
 }
 
 int
-err_read(struct vop_read_args *ap)
+err_write(__unused struct vnop_write_args *ap)
 {
-       return (EOPNOTSUPP);
+       return ENOTSUP;
 }
 
 
-struct vop_write_args /*  {
-       struct vnode *a_vp;
-       struct uio *a_uio;
-       int a_ioflag;
-       struct ucred *a_cred;
-} */;
+struct vnop_ioctl_args /* {
+                        *  struct vnode *a_vp;
+                        *  u_long a_command;
+                        *  caddr_t a_data;
+                        *  int a_fflag;
+                        *  kauth_cred_t a_cred;
+                        *  struct proc *a_p;
+                        *  } */;
 
 int
-nop_write(struct vop_write_args *ap)
+nop_ioctl(__unused struct vnop_ioctl_args *ap)
 {
-       return (0);
+       return 0;
 }
 
 int
-err_write(struct vop_write_args *ap)
+err_ioctl(__unused struct vnop_ioctl_args *ap)
 {
-       return (EOPNOTSUPP);
+       return ENOTSUP;
 }
 
 
-struct vop_lease_args /* {
-       struct vnode *a_vp;
-       struct proc *a_p;
-       struct ucred *a_cred;
-       int a_flag;
-} */;
+struct vnop_select_args /* {
+                         *  struct vnode *a_vp;
+                         *  int a_which;
+                         *  int a_fflags;
+                         *  kauth_cred_t a_cred;
+                         *  void *a_wql;
+                         *  struct proc *a_p;
+                         *  } */;
 
 int
-nop_lease(struct vop_lease_args *ap)
+nop_select(__unused struct vnop_select_args *ap)
 {
-       return (0);
+       return 0;
 }
 
 int
-err_lease(struct vop_lease_args *ap)
+err_select(__unused struct vnop_select_args *ap)
 {
-       return (EOPNOTSUPP);
+       return ENOTSUP;
 }
 
 
-struct vop_ioctl_args /* {
-       struct vnode *a_vp;
-       u_long a_command;
-       caddr_t a_data;
-       int a_fflag;
-       struct ucred *a_cred;
-       struct proc *a_p;
-} */;
+struct vnop_exchange_args /* {
+                           *  struct vnode *a_fvp;
+                           *  struct vnode *a_tvp;
+                           *  int a_options;
+                           *  vfs_context_t a_context;
+                           *  } */;
 
 int
-nop_ioctl(struct vop_ioctl_args *ap)
+nop_exchange(__unused struct vnop_exchange_args *ap)
 {
-       return (0);
+       return 0;
 }
 
 int
-err_ioctl(struct vop_ioctl_args *ap)
+err_exchange(__unused struct vnop_exchange_args *ap)
 {
-       return (EOPNOTSUPP);
+       return ENOTSUP;
 }
 
 
-struct vop_select_args /* {
-       struct vnode *a_vp;
-       int a_which;
-       int a_fflags;
-       struct ucred *a_cred;
-       void *a_wql;
-       struct proc *a_p;
-} */;
+struct vnop_revoke_args /* {
+                         *  struct vnode *a_vp;
+                         *  int a_flags;
+                         *  vfs_context_t a_context;
+                         *  } */;
 
 int
-nop_select(struct vop_select_args *ap)
+nop_revoke(struct vnop_revoke_args *ap)
 {
-       return (0);
+       return vn_revoke(ap->a_vp, ap->a_flags, ap->a_context);
 }
 
 int
-err_select(struct vop_select_args *ap)
-{
-       return (EOPNOTSUPP);
-}
-
-
-struct vop_exchange_args /* {
-       struct vnode *a_fvp;
-       struct vnode *a_tvp;
-       struct ucred *a_cred;
-       struct proc *a_p;
-} */;
-
-int
-nop_exchange(struct vop_exchange_args *ap)
-{
-       return (0);
-}
-
-int
-err_exchange(struct vop_exchange_args *ap)
-{
-       return (EOPNOTSUPP);
-}
-
-
-struct vop_revoke_args /* {
-       struct vnode *a_vp;
-       int a_flags;
-} */;
-
-int
-nop_revoke(struct vop_revoke_args *ap)
-{
-       return (vop_revoke(ap));
-}
-
-int
-err_revoke(struct vop_revoke_args *ap)
+err_revoke(struct vnop_revoke_args *ap)
 {
        (void)nop_revoke(ap);
-       return (EOPNOTSUPP);
+       return ENOTSUP;
 }
 
 
-struct vop_mmap_args /* {
-       struct vnode *a_vp;
-       int a_fflags;
-       struct ucred *a_cred;
-       struct proc *a_p;
-} */;
+struct vnop_mmap_args /* {
+                       *  struct vnode *a_vp;
+                       *  int a_fflags;
+                       *  kauth_cred_t a_cred;
+                       *  struct proc *a_p;
+                       *  } */;
 
 int
-nop_mmap(struct vop_mmap_args *ap)
+nop_mmap(__unused struct vnop_mmap_args *ap)
 {
-       return (0);
+       return 0;
 }
 
 int
-err_mmap(struct vop_mmap_args *ap)
+err_mmap(__unused struct vnop_mmap_args *ap)
 {
-       return (EOPNOTSUPP);
+       return ENOTSUP;
 }
 
 
-struct vop_fsync_args /* {
-       struct vnode *a_vp;
-       struct ucred *a_cred;
-       int a_waitfor;
-       struct proc *a_p;
-} */;
+struct vnop_fsync_args /* {
+                        *  struct vnode *a_vp;
+                        *  int a_waitfor;
+                        *  vfs_context_t a_context;
+                        *  } */;
 
 int
-nop_fsync(struct vop_fsync_args *ap)
+nop_fsync(__unused struct vnop_fsync_args *ap)
 {
-       return (0);
+       return 0;
 }
 
 int
-err_fsync(struct vop_fsync_args *ap)
+err_fsync(__unused struct vnop_fsync_args *ap)
 {
-       return (EOPNOTSUPP);
+       return ENOTSUP;
 }
 
 
-struct vop_seek_args /* {
-       struct vnode *a_vp;
-       off_t a_oldoff;
-       off_t a_newoff;
-       struct ucred *a_cred;
-} */;
+struct vnop_remove_args /* {
+                         *  struct vnode *a_dvp;
+                         *  struct vnode *a_vp;
+                         *  struct componentname *a_cnp;
+                         *  int a_flags;
+                         *  vfs_context_t a_context;
+                         *  } */;
 
 int
-nop_seek(struct vop_seek_args *ap)
+nop_remove(__unused struct vnop_remove_args *ap)
 {
-       return (0);
+       return 0;
 }
 
 int
-err_seek(struct vop_seek_args *ap)
-{
-       return (EOPNOTSUPP);
-}
-
-
-struct vop_remove_args /* {
-       struct vnode *a_dvp;
-       struct vnode *a_vp;
-       struct componentname *a_cnp;
-} */;
-
-int
-nop_remove(struct vop_remove_args *ap)
-{
-       if (ap->a_dvp == ap->a_vp)
-               vrele(ap->a_vp);
-       else
-               vput(ap->a_vp);
-       vput(ap->a_dvp);
-       return (0);
-}
-
-int
-err_remove(struct vop_remove_args *ap)
+err_remove(struct vnop_remove_args *ap)
 {
        (void)nop_remove(ap);
-       return (EOPNOTSUPP);
+       return ENOTSUP;
 }
 
 
-struct vop_link_args /* {
-       struct vnode *a_vp;
-       struct vnode *a_tdvp;
-       struct componentname *a_cnp;
-} */;
+struct vnop_link_args /* {
+                       *  struct vnode *a_vp;
+                       *  struct vnode *a_tdvp;
+                       *  struct componentname *a_cnp;
+                       *  vfs_context_t a_context;
+                       *  } */;
 
 int
-nop_link(struct vop_link_args *ap)
+nop_link(__unused struct vnop_link_args *ap)
 {
-#if DIAGNOSTIC
-       if ((ap->a_cnp->cn_flags & HASBUF) == 0)
-               panic("nop_link: no name");
-#endif
-       VOP_ABORTOP(ap->a_tdvp, ap->a_cnp);
-       vput(ap->a_tdvp);
-       return (0);
+       return 0;
 }
 
 int
-err_link(struct vop_link_args *ap)
+err_link(struct vnop_link_args *ap)
 {
        (void)nop_link(ap);
-       return (EOPNOTSUPP);
+       return ENOTSUP;
 }
 
 
-struct vop_rename_args /* {
-       struct vnode *a_fdvp;
-       struct vnode *a_fvp;
-       struct componentname *a_fcnp;
-       struct vnode *a_tdvp;
-       struct vnode *a_tvp;
-       struct componentname *a_tcnp;
-} */;
+struct vnop_rename_args /* {
+                         *  struct vnode *a_fdvp;
+                         *  struct vnode *a_fvp;
+                         *  struct componentname *a_fcnp;
+                         *  struct vnode *a_tdvp;
+                         *  struct vnode *a_tvp;
+                         *  struct componentname *a_tcnp;
+                         *  vfs_context_t a_context;
+                         *  } */;
 
 int
-nop_rename(struct vop_rename_args *ap)
+nop_rename(__unused struct vnop_rename_args *ap)
 {
-#if DIAGNOSTIC
-       if ((ap->a_tcnp->cn_flags & HASBUF) == 0 ||
-           (ap->a_fcnp->cn_flags & HASBUF) == 0)
-               panic("nop_rename: no name");
-#endif
-       VOP_ABORTOP(ap->a_tdvp, ap->a_tcnp);
-       if (ap->a_tdvp == ap->a_tvp)
-               vrele(ap->a_tdvp);
-       else
-               vput(ap->a_tdvp);
-       if (ap->a_tvp)
-               vput(ap->a_tvp);
-       VOP_ABORTOP(ap->a_fdvp, ap->a_fcnp);
-       vrele(ap->a_fdvp);
-       vrele(ap->a_fvp);
-       return (0);
+       return 0;
 }
 
 int
-err_rename(struct vop_rename_args *ap)
+err_rename(struct vnop_rename_args *ap)
 {
        (void)nop_rename(ap);
-       return (EOPNOTSUPP);
+       return ENOTSUP;
 }
 
 
-struct vop_mkdir_args /* {
-       struct vnode *a_dvp;
-       struct vnode **a_vpp;
-       struct componentname *a_cnp;
-       struct vattr *a_vap;
-} */;
+struct vnop_mkdir_args /* {
+                        *  struct vnode *a_dvp;
+                        *  struct vnode **a_vpp;
+                        *  struct componentname *a_cnp;
+                        *  struct vnode_vattr *a_vap;
+                        *  vfs_context_t a_context;
+                        *  } */;
 
 int
-nop_mkdir(struct vop_mkdir_args *ap)
+nop_mkdir(__unused struct vnop_mkdir_args *ap)
 {
-#if DIAGNOSTIC
-       if ((ap->a_cnp->cn_flags & HASBUF) == 0)
-               panic("nop_mkdir: no name");
-#endif
-       VOP_ABORTOP(ap->a_dvp, ap->a_cnp);
-       vput(ap->a_dvp);
-       return (0);
+       return 0;
 }
 
 int
-err_mkdir(struct vop_mkdir_args *ap)
+err_mkdir(__unused struct vnop_mkdir_args *ap)
 {
-       (void)nop_mkdir(ap);
-       return (EOPNOTSUPP);
+       return ENOTSUP;
 }
 
 
-struct vop_rmdir_args /* {
-       struct vnode *a_dvp;
-       struct vnode *a_vp;
-       struct componentname *a_cnp;
-} */;
+struct vnop_rmdir_args /* {
+                        *  struct vnode *a_dvp;
+                        *  struct vnode *a_vp;
+                        *  struct componentname *a_cnp;
+                        *  vfs_context_t a_context;
+                        *  } */;
 
 int
-nop_rmdir(struct vop_rmdir_args *ap)
+nop_rmdir(__unused struct vnop_rmdir_args *ap)
 {
-       vput(ap->a_dvp);
-       vput(ap->a_vp);
-       return (0);
+       return 0;
 }
 
 int
-err_rmdir(struct vop_rmdir_args *ap)
+err_rmdir(struct vnop_rmdir_args *ap)
 {
        (void)nop_rmdir(ap);
-       return (EOPNOTSUPP);
+       return ENOTSUP;
 }
 
 
-struct vop_symlink_args /* {
-       struct vnode *a_dvp;
-       struct vnode **a_vpp;
-       struct componentname *a_cnp;
-       struct vattr *a_vap;
-       char *a_target;
-} */;
+struct vnop_symlink_args /* {
+                          *  struct vnode *a_dvp;
+                          *  struct vnode **a_vpp;
+                          *  struct componentname *a_cnp;
+                          *  struct vnode_vattr *a_vap;
+                          *  char *a_target;
+                          *  vfs_context_t a_context;
+                          *  } */;
 
 int
-nop_symlink(struct vop_symlink_args *ap)
+nop_symlink(__unused struct vnop_symlink_args *ap)
 {
 #if DIAGNOSTIC
-       if ((ap->a_cnp->cn_flags & HASBUF) == 0)
+       if ((ap->a_cnp->cn_flags & HASBUF) == 0) {
                panic("nop_symlink: no name");
+       }
 #endif
-       VOP_ABORTOP(ap->a_dvp, ap->a_cnp);
-       vput(ap->a_dvp);
-       return (0);
+       return 0;
 }
 
 int
-err_symlink(struct vop_symlink_args *ap)
+err_symlink(struct vnop_symlink_args *ap)
 {
        (void)nop_symlink(ap);
-       return (EOPNOTSUPP);
+       return ENOTSUP;
 }
 
 
-struct vop_readdir_args /* {
-       struct vnode *a_vp;
-       struct uio *a_uio;
-       struct ucred *a_cred;
-       int *a_eofflag;
-       int *a_ncookies;
-       u_long **a_cookies;
-} */;
+struct vnop_readdir_args /* {
+                          *  vnode_t a_vp;
+                          *  struct uio *a_uio;
+                          *  int a_flags;
+                          *  int *a_eofflag;
+                          *  int *a_numdirent;
+                          *  vfs_context_t a_context;
+                          *  } */;
 
 int
-nop_readdir(struct vop_readdir_args *ap)
+nop_readdir(__unused struct vnop_readdir_args *ap)
 {
-       return (0);
+       return 0;
 }
 
 int
-err_readdir(struct vop_readdir_args *ap)
+err_readdir(__unused struct vnop_readdir_args *ap)
 {
-       return (EOPNOTSUPP);
+       return ENOTSUP;
 }
 
 
-struct vop_readdirattr_args /* {
-       struct vnode *a_vp;
-       struct attrlist *a_alist;
-       struct uio *a_uio;
-       u_long a_maxcount;
-        u_long a_options;
-        int *a_newstate;
-       int *a_eofflag;
-       u_long *a_actualcount;
-       u_long **a_cookies;
-       struct ucred *a_cred;
-} */;
+struct vnop_readdirattr_args /* {
+                              *  struct vnodeop_desc *a_desc;
+                              *  vnode_t a_vp;
+                              *  struct attrlist *a_alist;
+                              *  struct uio *a_uio;
+                              *  u_long a_maxcount;
+                              *  u_long a_options;
+                              *  u_long *a_newstate;
+                              *  int *a_eofflag;
+                              *  u_long *a_actualcount;
+                              *  vfs_context_t a_context;
+                              *  } */;
 
 int
-nop_readdirattr(struct vop_readdirattr_args *ap)
+nop_readdirattr(struct vnop_readdirattr_args *ap)
 {
-        *(ap->a_actualcount) = 0;
-        *(ap->a_eofflag) = 0;
-       return (0);
+       *(ap->a_actualcount) = 0;
+       *(ap->a_eofflag) = 0;
+       return 0;
 }
 
 int
-err_readdirattr(struct vop_readdirattr_args *ap)
+err_readdirattr(struct vnop_readdirattr_args *ap)
 {
-       (void)nop_readdirattr(ap);
-       return (EOPNOTSUPP);
+       (void)nop_readdirattr(ap);
+       return ENOTSUP;
 }
 
 
-struct vop_readlink_args /* {
-       struct vnode *vp;
-       struct uio *uio;
-       struct ucred *cred;
-} */;
+struct vnop_readlink_args /* {
+                           *  struct vnode *vp;
+                           *  struct uio *uio;
+                           *  vfs_context_t a_context;
+                           *  } */;
 
 int
-nop_readlink(struct vop_readlink_args *ap)
+nop_readlink(__unused struct vnop_readlink_args *ap)
 {
-       return (0);
+       return 0;
 }
 
 int
-err_readlink(struct vop_readlink_args *ap)
+err_readlink(__unused struct vnop_readlink_args *ap)
 {
-       return (EOPNOTSUPP);
+       return ENOTSUP;
 }
 
 
-struct vop_abortop_args /* {
-       struct vnode *a_dvp;
-       struct componentname *a_cnp;
-} */;
+struct vnop_inactive_args /* {
+                           *  struct vnode *a_vp;
+                           *  vfs_context_t a_context;
+                           *  } */;
 
 int
-nop_abortop(struct vop_abortop_args *ap)
+nop_inactive(__unused struct vnop_inactive_args *ap)
 {
-       if ((ap->a_cnp->cn_flags & (HASBUF | SAVESTART)) == HASBUF)
-               FREE_ZONE(ap->a_cnp->cn_pnbuf, ap->a_cnp->cn_pnlen, M_NAMEI);
-       return (0);
+       return 0;
 }
 
 int
-err_abortop(struct vop_abortop_args *ap)
-{
-       (void)nop_abortop(ap);
-       return (EOPNOTSUPP);
-}
-
-
-struct vop_inactive_args /* {
-       struct vnode *a_vp;
-       struct proc *a_p;
-} */;
-
-int
-nop_inactive(struct vop_inactive_args *ap)
-{
-       VOP_UNLOCK(ap->a_vp, 0, ap->a_p);
-       return (0);
-}
-
-int
-err_inactive(struct vop_inactive_args *ap)
+err_inactive(struct vnop_inactive_args *ap)
 {
        (void)nop_inactive(ap);
-       return (EOPNOTSUPP);
-}
-
-
-struct vop_reclaim_args /* {
-       struct vnode *a_vp;
-       struct proc *a_p;
-} */;
-
-int
-nop_reclaim(struct vop_reclaim_args *ap)
-{
-       return (0);
-}
-
-int
-err_reclaim(struct vop_reclaim_args *ap)
-{
-       return (EOPNOTSUPP);
+       return ENOTSUP;
 }
 
 
-struct vop_lock_args /* {
-       struct vnode *a_vp;
-       int a_flags;
-       struct proc *a_p;
-} */;
+struct vnop_reclaim_args /* {
+                          *  struct vnode *a_vp;
+                          *  vfs_context_t a_context;
+                          *  } */;
 
 int
-nop_lock(struct vop_lock_args *ap)
+nop_reclaim(__unused struct vnop_reclaim_args *ap)
 {
-       return (vop_nolock(ap));
+       return 0;
 }
 
 int
-err_lock(struct vop_lock_args *ap)
+err_reclaim(__unused struct vnop_reclaim_args *ap)
 {
-       (void)nop_lock(ap);
-       return (EOPNOTSUPP);
+       return ENOTSUP;
 }
 
 
-struct vop_unlock_args /* {
-       struct vnode *a_vp;
-       int a_flags;
-       struct proc *a_p;
-} */;
+struct vnop_strategy_args /* {
+                           *  struct buf *a_bp;
+                           *  } */;
 
 int
-nop_unlock(struct vop_unlock_args *ap)
+nop_strategy(__unused struct vnop_strategy_args *ap)
 {
-       return (vop_nounlock(ap));
+       return 0;
 }
 
 int
-err_unlock(struct vop_unlock_args *ap)
+err_strategy(__unused struct vnop_strategy_args *ap)
 {
-       (void)nop_unlock(ap);
-       return (EOPNOTSUPP);
+       return ENOTSUP;
 }
 
 
-struct vop_bmap_args /* {
-       struct vnode *vp;
-       daddr_t bn;
-       struct vnode **vpp;
-       daddr_t *bnp;
-       int *runp;
-} */;
+struct vnop_pathconf_args /* {
+                           *  struct vnode *a_vp;
+                           *  int a_name;
+                           *  int32_t *a_retval;
+                           *  vfs_context_t a_context;
+                           *  } */;
 
 int
-nop_bmap(struct vop_bmap_args *ap)
+nop_pathconf(__unused struct vnop_pathconf_args *ap)
 {
-       return (0);
+       return 0;
 }
 
 int
-err_bmap(struct vop_bmap_args *ap)
+err_pathconf(__unused struct vnop_pathconf_args *ap)
 {
-       return (EOPNOTSUPP);
+       return ENOTSUP;
 }
 
 
-struct vop_strategy_args /* {
-       struct buf *a_bp;
-} */;
+struct vnop_advlock_args /* {
+                          *  struct vnode *a_vp;
+                          *  caddr_t a_id;
+                          *  int a_op;
+                          *  struct flock *a_fl;
+                          *  int a_flags;
+                          *  vfs_context_t a_context;
+                          *  } */;
 
 int
-nop_strategy(struct vop_strategy_args *ap)
+nop_advlock(__unused struct vnop_advlock_args *ap)
 {
-       return (0);
+       return 0;
 }
 
 int
-err_strategy(struct vop_strategy_args *ap)
-{
-       return (EOPNOTSUPP);
-}
-
-
-struct vop_print_args /* {
-       struct vnode *a_vp;
-} */;
-
-int
-nop_print(struct vop_print_args *ap)
+err_advlock(__unused struct vnop_advlock_args *ap)
 {
-       return (0);
+       return ENOTSUP;
 }
 
-int
-err_print(struct vop_print_args *ap)
-{
-       return (EOPNOTSUPP);
-}
 
 
-struct vop_islocked_args /* {
-       struct vnode *a_vp;
-} */;
+struct vnop_allocate_args /* {
+                           *  struct vnode *a_vp;
+                           *  off_t a_length;
+                           *  u_int32_t a_flags;
+                           *  off_t *a_bytesallocated;
+                           *  off_t a_offset;
+                           *  vfs_context_t a_context;
+                           *  } */;
 
 int
-nop_islocked(struct vop_islocked_args *ap)
-{
-       return (vop_noislocked(ap));
-}
-
-int
-err_islocked(struct vop_islocked_args *ap)
-{
-       (void)nop_islocked(ap);
-       return (EOPNOTSUPP);
-}
-
-
-struct vop_pathconf_args /* {
-       struct vnode *a_vp;
-       int a_name;
-       register_t *a_retval;
-} */;
-
-int
-nop_pathconf(struct vop_pathconf_args *ap)
-{
-       return (0);
-}
-
-int
-err_pathconf(struct vop_pathconf_args *ap)
-{
-       return (EOPNOTSUPP);
-}
-
-
-struct vop_advlock_args /* {
-       struct vnode *a_vp;
-       caddr_t a_id;
-       int a_op;
-       struct flock *a_fl;
-       int a_flags;
-} */;
-
-int
-nop_advlock(struct vop_advlock_args *ap)
-{
-       return (0);
-}
-
-int
-err_advlock(struct vop_advlock_args *ap)
-{
-       return (EOPNOTSUPP);
-}
-
-
-struct vop_blkatoff_args /* {
-       struct vnode *a_vp;
-       off_t a_offset;
-       char **a_res;
-       struct buf **a_bpp;
-} */;
-
-int
-nop_blkatoff(struct vop_blkatoff_args *ap)
-{
-       *ap->a_bpp = NULL;
-       return (0);
-}
-
-int
-err_blkatoff(struct vop_blkatoff_args *ap)
-{
-       (void)nop_blkatoff(ap);
-       return (EOPNOTSUPP);
-}
-
-
-struct vop_valloc_args /* {
-       struct vnode *a_pvp;
-       int a_mode;
-       struct ucred *a_cred;
-       struct vnode **a_vpp;
-} */;
-
-int
-nop_valloc(struct vop_valloc_args *ap)
-{
-       *ap->a_vpp = NULL;
-       return (0);
-}
-
-int
-err_valloc(struct vop_valloc_args *ap)
-{
-       (void)nop_valloc(ap);
-       return (EOPNOTSUPP);
-}
-
-
-struct vop_reallocblks_args /* {
-       struct vnode *a_vp;
-       struct cluster_save *a_buflist;
-} */;
-
-int
-nop_reallocblks(struct vop_reallocblks_args *ap)
-{
-       return (0);
-}
-
-int
-err_reallocblks(struct vop_reallocblks_args *ap)
-{
-       return (EOPNOTSUPP);
-}
-
-
-struct vop_vfree_args /* {
-       struct vnode *a_pvp;
-       ino_t a_ino;
-       int a_mode;
-} */;
-
-int
-nop_vfree(struct vop_vfree_args *ap)
-{
-       return (0);
-}
-
-int
-err_vfree(struct vop_vfree_args *ap)
-{
-       return (EOPNOTSUPP);
-}
-
-
-struct vop_truncate_args /* {
-       struct vnode *a_vp;
-       off_t a_length;
-       int a_flags;
-       struct ucred *a_cred;
-       struct proc *a_p;
-} */;
-
-int
-nop_truncate(struct vop_truncate_args *ap)
-{
-       return (0);
-}
-
-int
-err_truncate(struct vop_truncate_args *ap)
-{
-       return (EOPNOTSUPP);
-}
-
-
-struct vop_allocate_args /* {
-       struct vnode *a_vp;
-       off_t a_length;
-       u_int32_t a_flags;
-       off_t *a_bytesallocated;
-       off_t a_offset;
-       struct ucred *a_cred;
-       struct proc *a_p;
-} */;
-
-int
-nop_allocate(struct vop_allocate_args *ap)
+nop_allocate(struct vnop_allocate_args *ap)
 {
        *(ap->a_bytesallocated) = 0;
-       return (0);
+       return 0;
 }
 
 int
-err_allocate(struct vop_allocate_args *ap)
+err_allocate(struct vnop_allocate_args *ap)
 {
        (void)nop_allocate(ap);
-       return (EOPNOTSUPP);
-}
-
-
-struct vop_update_args /* {
-       struct vnode *a_vp;
-       struct timeval *a_access;
-       struct timeval *a_modify;
-       int a_waitfor;
-} */;
-
-int
-nop_update(struct vop_update_args *ap)
-{
-       return (0);
-}
-
-int
-err_update(struct vop_update_args *ap)
-{
-       return (EOPNOTSUPP);
-}
-
-
-struct vop_pgrd_args /* {
-       struct vnode *a_vp;
-       struct uio *a_uio;
-       struct ucred *a_cred;
-} */;
-
-int
-nop_pgrd(struct vop_pgrd_args *ap)
-{
-       return (0);
-}
-
-int
-err_pgrd(struct vop_pgrd_args *ap)
-{
-       return (EOPNOTSUPP);
-}
-
-
-struct vop_pgwr_args /* {
-       struct vnode *a_vp;
-       struct uio *a_uio;
-       struct ucred *a_cred;
-       vm_offset_t     a_offset;
-} */;
-
-int
-nop_pgwr(struct vop_pgwr_args *ap)
-{
-       return (0);
+       return ENOTSUP;
 }
 
-int
-err_pgwr(struct vop_pgwr_args *ap)
-{
-       return (EOPNOTSUPP);
-}
-
-
-struct vop_bwrite_args /* {
-       struct buf *a_bp;
-} */;
+struct vnop_bwrite_args /* {
+                         *  struct buf *a_bp;
+                         *  } */;
 
 int
-nop_bwrite(struct vop_bwrite_args *ap)
+nop_bwrite(struct vnop_bwrite_args *ap)
 {
-       return (bwrite(ap->a_bp));
+       return (int)buf_bwrite(ap->a_bp);
 }
 
 int
-err_bwrite(struct vop_bwrite_args *ap)
+err_bwrite(__unused struct vnop_bwrite_args *ap)
 {
-       return (EOPNOTSUPP);
+       return ENOTSUP;
 }
 
 
-struct vop_pagein_args /* {
-               struct vnode    *a_vp,
-               upl_t           a_pl,
-               vm_offset_t     a_pl_offset,
-               off_t           a_foffset,
-               size_t          a_size,
-               struct ucred    *a_cred,
-               int             a_flags
-} */;
+struct vnop_pagein_args /* {
+                         *  struct vnode        *a_vp,
+                         *  upl_t              a_pl,
+                         *  vm_offset_t        a_pl_offset,
+                         *  off_t              a_foffset,
+                         *  size_t             a_size,
+                         *  int                a_flags
+                         *  vfs_context_t a_context;
+                         *  } */;
 
 int
-nop_pagein(struct vop_pagein_args *ap)
+nop_pagein(struct vnop_pagein_args *ap)
 {
-       ubc_upl_abort(ap->a_pl, UPL_ABORT_ERROR);
-       return (0);
+       if (!(ap->a_flags & UPL_NOCOMMIT)) {
+               ubc_upl_abort_range(ap->a_pl, ap->a_pl_offset, ap->a_size, UPL_ABORT_FREE_ON_EMPTY | UPL_ABORT_ERROR);
+       }
+       return EINVAL;
 }
 
 int
-err_pagein(struct vop_pagein_args *ap)
+err_pagein(struct vnop_pagein_args *ap)
 {
-       ubc_upl_abort(ap->a_pl, UPL_ABORT_ERROR);
-       return (EOPNOTSUPP);
+       if (!(ap->a_flags & UPL_NOCOMMIT)) {
+               ubc_upl_abort_range(ap->a_pl, ap->a_pl_offset, ap->a_size, UPL_ABORT_FREE_ON_EMPTY | UPL_ABORT_ERROR);
+       }
+       return ENOTSUP;
 }
 
 
-struct vop_pageout_args /* {
-               struct vnode    *a_vp,
-               upl_t           a_pl,
-               vm_offset_t     a_pl_offset,
-               off_t           a_foffset,
-               size_t          a_size,
-               struct ucred    *a_cred,
-               int             a_flags
-} */;
+struct vnop_pageout_args /* {
+                          *  struct vnode       *a_vp,
+                          *  upl_t             a_pl,
+                          *  vm_offset_t       a_pl_offset,
+                          *  off_t             a_foffset,
+                          *  size_t            a_size,
+                          *  int               a_flags
+                          *  vfs_context_t a_context;
+                          *  } */;
 
 int
-nop_pageout(struct vop_pageout_args *ap)
+nop_pageout(struct vnop_pageout_args *ap)
 {
-       ubc_upl_abort(ap->a_pl, UPL_ABORT_ERROR);
-       return (0);
+       if (!(ap->a_flags & UPL_NOCOMMIT)) {
+               ubc_upl_abort_range(ap->a_pl, ap->a_pl_offset, ap->a_size, UPL_ABORT_FREE_ON_EMPTY | UPL_ABORT_ERROR);
+       }
+       return EINVAL;
 }
 
 int
-err_pageout(struct vop_pageout_args *ap)
+err_pageout(struct vnop_pageout_args *ap)
 {
-       ubc_upl_abort(ap->a_pl, UPL_ABORT_ERROR);
-       return (EOPNOTSUPP);
+       if (!(ap->a_flags & UPL_NOCOMMIT)) {
+               ubc_upl_abort_range(ap->a_pl, ap->a_pl_offset, ap->a_size, UPL_ABORT_FREE_ON_EMPTY | UPL_ABORT_ERROR);
+       }
+       return ENOTSUP;
 }
 
 
-struct vop_devblocksize_args /* {
-       struct vnode *a_vp;
-       register_t *a_retval;
-} */;
+struct vnop_searchfs /* {
+                      *  struct vnode *a_vp;
+                      *  void *a_searchparams1;
+                      *  void *a_searchparams2;
+                      *  struct attrlist *a_searchattrs;
+                      *  u_long a_maxmatches;
+                      *  struct timeval *a_timelimit;
+                      *  struct attrlist *a_returnattrs;
+                      *  u_long *a_nummatches;
+                      *  u_long a_scriptcode;
+                      *  u_long a_options;
+                      *  struct uio    *a_uio;
+                      *  struct searchstate    *a_searchstate;
+                      *  vfs_context_t a_context;
+                      *  } */;
 
 int
-nop_devblocksize(struct vop_devblocksize_args *ap)
-{
-       /* XXX default value because the call sites do not check error */
-       *ap->a_retval = 512;
-       return (0);
-}
-
-int
-err_devblocksize(struct vop_devblocksize_args *ap)
-{
-       (void)nop_devblocksize(ap);
-       return (EOPNOTSUPP);
-}
-
-
-struct vop_searchfs /* {
-       struct vnode *a_vp;
-       void *a_searchparams1;
-       void *a_searchparams2;
-       struct attrlist *a_searchattrs;
-       u_long a_maxmatches;
-       struct timeval *a_timelimit;
-       struct attrlist *a_returnattrs;
-       u_long *a_nummatches;
-       u_long a_scriptcode;
-       u_long a_options;
-       struct uio      *a_uio;
-       struct searchstate      *a_searchstate;
-} */;
-
-int
-nop_searchfs(struct vop_searchfs_args *ap)
+nop_searchfs(struct vnop_searchfs_args *ap)
 {
        *(ap->a_nummatches) = 0;
-       return (0);
+       return 0;
 }
 
 int
-err_searchfs(struct vop_searchfs_args *ap)
+err_searchfs(struct vnop_searchfs_args *ap)
 {
        (void)nop_searchfs(ap);
-       return (EOPNOTSUPP);
+       return ENOTSUP;
 }
 
-struct vop_copyfile_args /*{
-        struct vnodeop_desc *a_desc;
-        struct vnode *a_fvp;
-        struct vnode *a_tdvp;
-        struct vnode *a_tvp;
-        struct componentname *a_tcnp;
-        int a_flags;
-}*/; 
+struct vnop_copyfile_args /*{
+                           *  struct vnodeop_desc *a_desc;
+                           *  struct vnode *a_fvp;
+                           *  struct vnode *a_tdvp;
+                           *  struct vnode *a_tvp;
+                           *  struct componentname *a_tcnp;
+                           *  int a_flags;
+                           *  }*/;
 
 int
-nop_copyfile(struct vop_copyfile_args *ap)
+nop_copyfile(__unused struct vnop_copyfile_args *ap)
 {
-       if (ap->a_tdvp == ap->a_tvp)
-               vrele(ap->a_tdvp);
-       else
-               vput(ap->a_tdvp);
-       if (ap->a_tvp)
-               vput(ap->a_tvp);
-       vrele(ap->a_fvp);
-       return (0);
+       return 0;
 }
 
 
 int
-err_copyfile(struct vop_copyfile_args *ap)
+err_copyfile(struct vnop_copyfile_args *ap)
 {
        (void)nop_copyfile(ap);
-       return (EOPNOTSUPP);
+       return ENOTSUP;
 }
 
 
-struct vop_blktooff_args /* {
-       struct vnode *a_vp;
-       daddr_t a_lblkno;
-       off_t *a_offset;    
-} */;
+struct vnop_blktooff_args /* {
+                           *  struct vnode *a_vp;
+                           *  daddr64_t a_lblkno;
+                           *  off_t *a_offset;
+                           *  } */;
 
 int
-nop_blktooff(struct vop_blktooff_args *ap)
+nop_blktooff(struct vnop_blktooff_args *ap)
 {
-       *ap->a_offset = (off_t)-1;      /* failure */
-       return (0);
+       *ap->a_offset = (off_t)-1;      /* failure */
+       return 0;
 }
 
 int
-err_blktooff(struct vop_blktooff_args *ap)
+err_blktooff(struct vnop_blktooff_args *ap)
 {
        (void)nop_blktooff(ap);
-       return (EOPNOTSUPP);
+       return ENOTSUP;
 }
 
-struct vop_offtoblk_args /* {
-       struct vnode *a_vp;
-       off_t a_offset;    
-       daddr_t *a_lblkno;
-} */;
+struct vnop_offtoblk_args /* {
+                           *  struct vnode *a_vp;
+                           *  off_t a_offset;
+                           *  daddr64_t *a_lblkno;
+                           *  } */;
 
 int
-nop_offtoblk(struct vop_offtoblk_args *ap)
+nop_offtoblk(struct vnop_offtoblk_args *ap)
 {
-       *ap->a_lblkno = (daddr_t)-1;    /* failure */
-       return (0);
+       *ap->a_lblkno = (daddr64_t)-1;  /* failure */
+       return 0;
 }
 
 int
-err_offtoblk(struct vop_offtoblk_args *ap)
+err_offtoblk(struct vnop_offtoblk_args *ap)
 {
        (void)nop_offtoblk(ap);
-       return (EOPNOTSUPP);
+       return ENOTSUP;
 }
 
-struct vop_cmap_args /* {
-       struct vnode *a_vp;
-       off_t a_foffset;
-       size_t a_size;
-       daddr_t *a_bpn;
-       size_t *a_run;
-       void *a_poff;
-} */;
+struct vnop_blockmap_args /* {
+                           *  struct vnode *a_vp;
+                           *  off_t a_foffset;
+                           *  size_t a_size;
+                           *  daddr64_t *a_bpn;
+                           *  size_t *a_run;
+                           *  void *a_poff;
+                           *  int a_flags;
+                           *  } */;
 
-int nop_cmap(struct vop_cmap_args *ap)
+int
+nop_blockmap(__unused struct vnop_blockmap_args *ap)
 {
-       return (0);
+       return 0;
 }
 
-int err_cmap(struct vop_cmap_args *ap)
+int
+err_blockmap(__unused struct vnop_blockmap_args *ap)
 {
-       return (EOPNOTSUPP);
+       return ENOTSUP;
 }
-