Source to bsd/vfs/vfs_support.c
/*
* Copyright (c) 2000 Apple Computer, Inc. All rights reserved.
*
* @APPLE_LICENSE_HEADER_START@
*
* The contents of this file constitute Original Code as defined in and
* are subject to the Apple Public Source License Version 1.1 (the
* "License"). You may not use this file except in compliance with the
* License. Please obtain a copy of the License at
* http://www.apple.com/publicsource and read it before using this file.
*
* This 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,
* INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT. Please see the
* License for the specific language governing rights and limitations
* under the License.
*
* @APPLE_LICENSE_HEADER_END@
*/
/*
* Copyright (c) 1998-1999 Apple Computer, Inc. All rights reserved.
*
* File: vfs/vfs_support.c
*
* The default VFS routines. A VFS plugin can use these
* functions in case it does not want to implement all. These functions
* take care of releasing locks and free up memory that they are
* supposed to.
*
* nop_* routines always return 0 [success]
* err_* routines always return EOPNOTSUPP
*
* This file could be auto-generated from vnode_if.src. but that needs
* support for freeing cnp.
*
* HISTORY
* 15-Jul-1998 Earsh Nandkeshwar ([email protected])
* Fixed up readdirattr for its existance now.
* 18-Aug-1998 Umesh Vaishampayan ([email protected])
* Created.
*/
#include <vfs/vfs_support.h>
struct vop_create_args /* {
struct vnode *a_dvp;
struct vnode **a_vpp;
struct componentname *a_cnp;
struct vattr *a_vap;
} */;
int
nop_create(struct vop_create_args *ap)
{
#if DIAGNOSTIC
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);
}
int
err_create(struct vop_create_args *ap)
{
(void)nop_create(ap);
return (EOPNOTSUPP);
}
struct vop_whiteout_args /* {
struct vnode *a_dvp;
struct componentname *a_cnp;
int a_flags;
} */;
int
nop_whiteout(struct vop_whiteout_args *ap)
{
return (0);
}
int
err_whiteout(struct vop_whiteout_args *ap)
{
return (EOPNOTSUPP);
}
struct vop_mknod_args /* {
struct vnode *a_dvp;
struct vnode **a_vpp;
struct componentname *a_cnp;
struct vattr *a_vap;
} */;
int
nop_mknod(struct vop_mknod_args *ap)
{
#if DIAGNOSTIC
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);
}
int
err_mknod(struct vop_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);
}
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;
} */;
int
nop_close(struct vop_close_args *ap)
{
return (0);
}
int
err_close(struct vop_close_args *ap)
{
return (EOPNOTSUPP);
}
struct vop_access_args /* {
struct vnode *a_vp;
int a_mode;
struct ucred *a_cred;
struct proc *a_p;
} */;
int
nop_access(struct vop_access_args *ap)
{
return (0);
}
int
err_access(struct vop_access_args *ap)
{
return (EOPNOTSUPP);
}
struct vop_getattr_args /* {
struct vnode *a_vp;
struct vattr *a_vap;
struct ucred *a_cred;
struct proc *a_p;
} */;
int
nop_getattr(struct vop_getattr_args *ap)
{
return (0);
}
int
err_getattr(struct vop_getattr_args *ap)
{
return (EOPNOTSUPP);
}
struct vop_setattr_args /* {
struct vnode *a_vp;
struct vattr *a_vap;
struct ucred *a_cred;
struct proc *a_p;
} */;
int
nop_setattr(struct vop_setattr_args *ap)
{
return (0);
}
int
err_setattr(struct vop_setattr_args *ap)
{
return (EOPNOTSUPP);
}
struct vop_getattrlist_args /* {
struct vnode *a_vp;
struct attrlist *a_alist;
struct uio *a_uio;
struct ucred *a_cred;
struct proc *a_p;
} */;
int
nop_getattrlist(struct vop_getattrlist_args *ap)
{
return (0);
}
int
err_getattrlist(struct vop_getattrlist_args *ap)
{
return (EOPNOTSUPP);
}
struct vop_setattrlist_args /* {
struct vnode *a_vp;
struct attrlist *a_alist;
struct uio *a_uio;
struct ucred *a_cred;
struct proc *a_p;
} */;
int
nop_setattrlist(struct vop_setattrlist_args *ap)
{
return (0);
}
int
err_setattrlist(struct vop_setattrlist_args *ap)
{
return (EOPNOTSUPP);
}
struct vop_read_args /* {
struct vnode *a_vp;
struct uio *a_uio;
int a_ioflag;
struct ucred *a_cred;
} */;
int
nop_read(struct vop_read_args *ap)
{
return (0);
}
int
err_read(struct vop_read_args *ap)
{
return (EOPNOTSUPP);
}
struct vop_write_args /* {
struct vnode *a_vp;
struct uio *a_uio;
int a_ioflag;
struct ucred *a_cred;
} */;
int
nop_write(struct vop_write_args *ap)
{
return (0);
}
int
err_write(struct vop_write_args *ap)
{
return (EOPNOTSUPP);
}
struct vop_lease_args /* {
struct vnode *a_vp;
struct proc *a_p;
struct ucred *a_cred;
int a_flag;
} */;
int
nop_lease(struct vop_lease_args *ap)
{
return (0);
}
int
err_lease(struct vop_lease_args *ap)
{
return (EOPNOTSUPP);
}
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;
} */;
int
nop_ioctl(struct vop_ioctl_args *ap)
{
return (0);
}
int
err_ioctl(struct vop_ioctl_args *ap)
{
return (EOPNOTSUPP);
}
struct vop_select_args /* {
struct vnode *a_vp;
int a_which;
int a_fflags;
struct ucred *a_cred;
struct proc *a_p;
} */;
int
nop_select(struct vop_select_args *ap)
{
return (0);
}
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)
{
(void)nop_revoke(ap);
return (EOPNOTSUPP);
}
struct vop_mmap_args /* {
struct vnode *a_vp;
int a_fflags;
struct ucred *a_cred;
struct proc *a_p;
} */;
int
nop_mmap(struct vop_mmap_args *ap)
{
return (0);
}
int
err_mmap(struct vop_mmap_args *ap)
{
return (EOPNOTSUPP);
}
struct vop_fsync_args /* {
struct vnode *a_vp;
struct ucred *a_cred;
int a_waitfor;
struct proc *a_p;
} */;
int
nop_fsync(struct vop_fsync_args *ap)
{
return (0);
}
int
err_fsync(struct vop_fsync_args *ap)
{
return (EOPNOTSUPP);
}
struct vop_seek_args /* {
struct vnode *a_vp;
off_t a_oldoff;
off_t a_newoff;
struct ucred *a_cred;
} */;
int
nop_seek(struct vop_seek_args *ap)
{
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)
{
(void)nop_remove(ap);
return (EOPNOTSUPP);
}
struct vop_link_args /* {
struct vnode *a_vp;
struct vnode *a_tdvp;
struct componentname *a_cnp;
} */;
int
nop_link(struct vop_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);
}
int
err_link(struct vop_link_args *ap)
{
(void)nop_link(ap);
return (EOPNOTSUPP);
}
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;
} */;
int
nop_rename(struct vop_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);
}
int
err_rename(struct vop_rename_args *ap)
{
(void)nop_rename(ap);
return (EOPNOTSUPP);
}
struct vop_mkdir_args /* {
struct vnode *a_dvp;
struct vnode **a_vpp;
struct componentname *a_cnp;
struct vattr *a_vap;
} */;
int
nop_mkdir(struct vop_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);
}
int
err_mkdir(struct vop_mkdir_args *ap)
{
(void)nop_mkdir(ap);
return (EOPNOTSUPP);
}
struct vop_rmdir_args /* {
struct vnode *a_dvp;
struct vnode *a_vp;
struct componentname *a_cnp;
} */;
int
nop_rmdir(struct vop_rmdir_args *ap)
{
vput(ap->a_dvp);
vput(ap->a_vp);
return (0);
}
int
err_rmdir(struct vop_rmdir_args *ap)
{
(void)nop_rmdir(ap);
return (EOPNOTSUPP);
}
struct vop_symlink_args /* {
struct vnode *a_dvp;
struct vnode **a_vpp;
struct componentname *a_cnp;
struct vattr *a_vap;
char *a_target;
} */;
int
nop_symlink(struct vop_symlink_args *ap)
{
#if DIAGNOSTIC
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);
}
int
err_symlink(struct vop_symlink_args *ap)
{
(void)nop_symlink(ap);
return (EOPNOTSUPP);
}
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;
} */;
int
nop_readdir(struct vop_readdir_args *ap)
{
return (0);
}
int
err_readdir(struct vop_readdir_args *ap)
{
return (EOPNOTSUPP);
}
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;
} */;
int
nop_readdirattr(struct vop_readdirattr_args *ap)
{
*(ap->a_actualcount) = 0;
*(ap->a_eofflag) = 0;
return (0);
}
int
err_readdirattr(struct vop_readdirattr_args *ap)
{
(void)nop_readdirattr(ap);
return (EOPNOTSUPP);
}
struct vop_readlink_args /* {
struct vnode *vp;
struct uio *uio;
struct ucred *cred;
} */;
int
nop_readlink(struct vop_readlink_args *ap)
{
return (0);
}
int
err_readlink(struct vop_readlink_args *ap)
{
return (EOPNOTSUPP);
}
struct vop_abortop_args /* {
struct vnode *a_dvp;
struct componentname *a_cnp;
} */;
int
nop_abortop(struct vop_abortop_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);
}
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)
{
(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);
}
struct vop_lock_args /* {
struct vnode *a_vp;
int a_flags;
struct proc *a_p;
} */;
int
nop_lock(struct vop_lock_args *ap)
{
return (vop_nolock(ap));
}
int
err_lock(struct vop_lock_args *ap)
{
(void)nop_lock(ap);
return (EOPNOTSUPP);
}
struct vop_unlock_args /* {
struct vnode *a_vp;
int a_flags;
struct proc *a_p;
} */;
int
nop_unlock(struct vop_unlock_args *ap)
{
return (vop_nounlock(ap));
}
int
err_unlock(struct vop_unlock_args *ap)
{
(void)nop_unlock(ap);
return (EOPNOTSUPP);
}
struct vop_bmap_args /* {
struct vnode *vp;
daddr_t bn;
struct vnode **vpp;
daddr_t *bnp;
int *runp;
} */;
int
nop_bmap(struct vop_bmap_args *ap)
{
return (0);
}
int
err_bmap(struct vop_bmap_args *ap)
{
return (EOPNOTSUPP);
}
struct vop_strategy_args /* {
struct buf *a_bp;
} */;
int
nop_strategy(struct vop_strategy_args *ap)
{
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)
{
return (0);
}
int
err_print(struct vop_print_args *ap)
{
return (EOPNOTSUPP);
}
struct vop_islocked_args /* {
struct vnode *a_vp;
} */;
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;
struct ucred *a_cred;
struct proc *a_p;
} */;
int
nop_allocate(struct vop_allocate_args *ap)
{
*(ap->a_bytesallocated) = 0;
return (0);
}
int
err_allocate(struct vop_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);
}
int
err_pgwr(struct vop_pgwr_args *ap)
{
return (EOPNOTSUPP);
}
struct vop_bwrite_args /* {
struct buf *a_bp;
} */;
int
nop_bwrite(struct vop_bwrite_args *ap)
{
return (bwrite(ap->a_bp));
}
int
err_bwrite(struct vop_bwrite_args *ap)
{
return (EOPNOTSUPP);
}
struct vop_pagein_args /* {
struct vnode *a_vp;
struct uio *a_uio;
int a_ioflag;
struct ucred *a_cred;
} */;
int
nop_pagein(struct vop_pagein_args *ap)
{
/* pass thru to read */
return (VOP_READ(ap->a_vp, ap->a_uio, ap->a_ioflag, ap->a_cred));
}
int
err_pagein(struct vop_pagein_args *ap)
{
/* pass thru to read */
return (VOP_READ(ap->a_vp, ap->a_uio, ap->a_ioflag, ap->a_cred));
}
struct vop_pageout_args /* {
struct vnode *a_vp;
struct uio *a_uio;
int a_ioflag;
struct ucred *a_cred;
} */;
int
nop_pageout(struct vop_pageout_args *ap)
{
/* pass thru to write */
return (VOP_WRITE(ap->a_vp, ap->a_uio, ap->a_ioflag, ap->a_cred));
}
int
err_pageout(struct vop_pageout_args *ap)
{
/* pass thru to write */
return (VOP_WRITE(ap->a_vp, ap->a_uio, ap->a_ioflag, ap->a_cred));
}
struct vop_devblocksize_args /* {
struct vnode *a_vp;
register_t *a_retval;
} */;
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)
{
*(ap->a_nummatches) = 0;
return (0);
}
int
err_searchfs(struct vop_searchfs_args *ap)
{
(void)nop_searchfs(ap);
return (EOPNOTSUPP);
}
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;
}*/;
int
nop_copyfile(struct vop_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);
}
int
err_copyfile(struct vop_copyfile_args *ap)
{
(void)nop_copyfile(ap);
return (EOPNOTSUPP);
}