diff options
author | bde <bde@FreeBSD.org> | 1995-11-09 08:17:23 +0000 |
---|---|---|
committer | bde <bde@FreeBSD.org> | 1995-11-09 08:17:23 +0000 |
commit | 449a11eb8852c894681575cf4226b1c639a2f9bc (patch) | |
tree | d1df2f42cd1cf04bc5757d3dff0d353c3e6a3a58 /sys/fs/portalfs | |
parent | 7b39ff1acd679291e1eaa968c4a256d7c6e3b22f (diff) | |
download | FreeBSD-src-449a11eb8852c894681575cf4226b1c639a2f9bc.zip FreeBSD-src-449a11eb8852c894681575cf4226b1c639a2f9bc.tar.gz |
Introduced a type `vop_t' for vnode operation functions and used
it 1138 times (:-() in casts and a few more times in declarations.
This change is null for the i386.
The type has to be `typedef int vop_t(void *)' and not `typedef
int vop_t()' because `gcc -Wstrict-prototypes' warns about the
latter. Since vnode op functions are called with args of different
(struct pointer) types, neither of these function types is any use
for type checking of the arg, so it would be preferable not to use
the complete function type, especially since using the complete
type requires adding 1138 casts to avoid compiler warnings and
another 40+ casts to reverse the function pointer conversions before
calling the functions.
Diffstat (limited to 'sys/fs/portalfs')
-rw-r--r-- | sys/fs/portalfs/portal.h | 4 | ||||
-rw-r--r-- | sys/fs/portalfs/portal_vnops.c | 88 |
2 files changed, 46 insertions, 46 deletions
diff --git a/sys/fs/portalfs/portal.h b/sys/fs/portalfs/portal.h index 38d7ee0..f2f1e7b 100644 --- a/sys/fs/portalfs/portal.h +++ b/sys/fs/portalfs/portal.h @@ -35,7 +35,7 @@ * * @(#)portal.h 8.4 (Berkeley) 1/21/94 * - * $Id: portal.h,v 1.3 1992/05/30 10:05:24 jsp Exp jsp $ + * $Id: portal.h,v 1.1.1.1 1994/05/24 10:05:06 rgrimes Exp $ */ struct portal_args { @@ -67,6 +67,6 @@ struct portalnode { #define PORTAL_ROOTFILEID 2 -extern int (**portal_vnodeop_p)(); +extern vop_t **portal_vnodeop_p; extern struct vfsops portal_vfsops; #endif /* KERNEL */ diff --git a/sys/fs/portalfs/portal_vnops.c b/sys/fs/portalfs/portal_vnops.c index 4ee5824..7bea6da 100644 --- a/sys/fs/portalfs/portal_vnops.c +++ b/sys/fs/portalfs/portal_vnops.c @@ -35,7 +35,7 @@ * * @(#)portal_vnops.c 8.8 (Berkeley) 1/21/94 * - * $Id: portal_vnops.c,v 1.6 1995/05/30 08:07:06 rgrimes Exp $ + * $Id: portal_vnops.c,v 1.7 1995/10/08 00:09:00 swallace Exp $ */ /* @@ -659,50 +659,50 @@ portal_nullop() #define portal_update ((int (*) __P((struct vop_update_args *)))portal_enotsupp) #define portal_bwrite ((int (*) __P((struct vop_bwrite_args *)))portal_enotsupp) -int (**portal_vnodeop_p)(); +vop_t **portal_vnodeop_p; struct vnodeopv_entry_desc portal_vnodeop_entries[] = { - { &vop_default_desc, vn_default_error }, - { &vop_lookup_desc, portal_lookup }, /* lookup */ - { &vop_create_desc, portal_create }, /* create */ - { &vop_mknod_desc, portal_mknod }, /* mknod */ - { &vop_open_desc, portal_open }, /* open */ - { &vop_close_desc, portal_close }, /* close */ - { &vop_access_desc, portal_access }, /* access */ - { &vop_getattr_desc, portal_getattr }, /* getattr */ - { &vop_setattr_desc, portal_setattr }, /* setattr */ - { &vop_read_desc, portal_read }, /* read */ - { &vop_write_desc, portal_write }, /* write */ - { &vop_ioctl_desc, portal_ioctl }, /* ioctl */ - { &vop_select_desc, portal_select }, /* select */ - { &vop_mmap_desc, portal_mmap }, /* mmap */ - { &vop_fsync_desc, portal_fsync }, /* fsync */ - { &vop_seek_desc, portal_seek }, /* seek */ - { &vop_remove_desc, portal_remove }, /* remove */ - { &vop_link_desc, portal_link }, /* link */ - { &vop_rename_desc, portal_rename }, /* rename */ - { &vop_mkdir_desc, portal_mkdir }, /* mkdir */ - { &vop_rmdir_desc, portal_rmdir }, /* rmdir */ - { &vop_symlink_desc, portal_symlink }, /* symlink */ - { &vop_readdir_desc, portal_readdir }, /* readdir */ - { &vop_readlink_desc, portal_readlink }, /* readlink */ - { &vop_abortop_desc, portal_abortop }, /* abortop */ - { &vop_inactive_desc, portal_inactive }, /* inactive */ - { &vop_reclaim_desc, portal_reclaim }, /* reclaim */ - { &vop_lock_desc, portal_lock }, /* lock */ - { &vop_unlock_desc, portal_unlock }, /* unlock */ - { &vop_bmap_desc, portal_bmap }, /* bmap */ - { &vop_strategy_desc, portal_strategy }, /* strategy */ - { &vop_print_desc, portal_print }, /* print */ - { &vop_islocked_desc, portal_islocked }, /* islocked */ - { &vop_pathconf_desc, portal_pathconf }, /* pathconf */ - { &vop_advlock_desc, portal_advlock }, /* advlock */ - { &vop_blkatoff_desc, portal_blkatoff }, /* blkatoff */ - { &vop_valloc_desc, portal_valloc }, /* valloc */ - { &vop_vfree_desc, portal_vfree }, /* vfree */ - { &vop_truncate_desc, portal_truncate }, /* truncate */ - { &vop_update_desc, portal_update }, /* update */ - { &vop_bwrite_desc, portal_bwrite }, /* bwrite */ - { (struct vnodeop_desc*)NULL, (int(*)())NULL } + { &vop_default_desc, (vop_t *)vn_default_error }, + { &vop_lookup_desc, (vop_t *)portal_lookup }, /* lookup */ + { &vop_create_desc, (vop_t *)portal_create }, /* create */ + { &vop_mknod_desc, (vop_t *)portal_mknod }, /* mknod */ + { &vop_open_desc, (vop_t *)portal_open }, /* open */ + { &vop_close_desc, (vop_t *)portal_close }, /* close */ + { &vop_access_desc, (vop_t *)portal_access }, /* access */ + { &vop_getattr_desc, (vop_t *)portal_getattr }, /* getattr */ + { &vop_setattr_desc, (vop_t *)portal_setattr }, /* setattr */ + { &vop_read_desc, (vop_t *)portal_read }, /* read */ + { &vop_write_desc, (vop_t *)portal_write }, /* write */ + { &vop_ioctl_desc, (vop_t *)portal_ioctl }, /* ioctl */ + { &vop_select_desc, (vop_t *)portal_select }, /* select */ + { &vop_mmap_desc, (vop_t *)portal_mmap }, /* mmap */ + { &vop_fsync_desc, (vop_t *)portal_fsync }, /* fsync */ + { &vop_seek_desc, (vop_t *)portal_seek }, /* seek */ + { &vop_remove_desc, (vop_t *)portal_remove }, /* remove */ + { &vop_link_desc, (vop_t *)portal_link }, /* link */ + { &vop_rename_desc, (vop_t *)portal_rename }, /* rename */ + { &vop_mkdir_desc, (vop_t *)portal_mkdir }, /* mkdir */ + { &vop_rmdir_desc, (vop_t *)portal_rmdir }, /* rmdir */ + { &vop_symlink_desc, (vop_t *)portal_symlink }, /* symlink */ + { &vop_readdir_desc, (vop_t *)portal_readdir }, /* readdir */ + { &vop_readlink_desc, (vop_t *)portal_readlink }, /* readlink */ + { &vop_abortop_desc, (vop_t *)portal_abortop }, /* abortop */ + { &vop_inactive_desc, (vop_t *)portal_inactive }, /* inactive */ + { &vop_reclaim_desc, (vop_t *)portal_reclaim }, /* reclaim */ + { &vop_lock_desc, (vop_t *)portal_lock }, /* lock */ + { &vop_unlock_desc, (vop_t *)portal_unlock }, /* unlock */ + { &vop_bmap_desc, (vop_t *)portal_bmap }, /* bmap */ + { &vop_strategy_desc, (vop_t *)portal_strategy }, /* strategy */ + { &vop_print_desc, (vop_t *)portal_print }, /* print */ + { &vop_islocked_desc, (vop_t *)portal_islocked }, /* islocked */ + { &vop_pathconf_desc, (vop_t *)portal_pathconf }, /* pathconf */ + { &vop_advlock_desc, (vop_t *)portal_advlock }, /* advlock */ + { &vop_blkatoff_desc, (vop_t *)portal_blkatoff }, /* blkatoff */ + { &vop_valloc_desc, (vop_t *)portal_valloc }, /* valloc */ + { &vop_vfree_desc, (vop_t *)portal_vfree }, /* vfree */ + { &vop_truncate_desc, (vop_t *)portal_truncate }, /* truncate */ + { &vop_update_desc, (vop_t *)portal_update }, /* update */ + { &vop_bwrite_desc, (vop_t *)portal_bwrite }, /* bwrite */ + { NULL, NULL } }; struct vnodeopv_desc portal_vnodeop_opv_desc = { &portal_vnodeop_p, portal_vnodeop_entries }; |