summaryrefslogtreecommitdiffstats
path: root/sys/fs/portalfs
diff options
context:
space:
mode:
authorbde <bde@FreeBSD.org>1995-11-09 08:17:23 +0000
committerbde <bde@FreeBSD.org>1995-11-09 08:17:23 +0000
commit449a11eb8852c894681575cf4226b1c639a2f9bc (patch)
treed1df2f42cd1cf04bc5757d3dff0d353c3e6a3a58 /sys/fs/portalfs
parent7b39ff1acd679291e1eaa968c4a256d7c6e3b22f (diff)
downloadFreeBSD-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.h4
-rw-r--r--sys/fs/portalfs/portal_vnops.c88
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 };
OpenPOWER on IntegriCloud