summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
Diffstat (limited to 'sys')
-rw-r--r--sys/miscfs/fifofs/fifo.h99
-rw-r--r--sys/miscfs/fifofs/fifo_vnops.c133
2 files changed, 129 insertions, 103 deletions
diff --git a/sys/miscfs/fifofs/fifo.h b/sys/miscfs/fifofs/fifo.h
index 9b7ca197b39..cdfd83fdc3c 100644
--- a/sys/miscfs/fifofs/fifo.h
+++ b/sys/miscfs/fifofs/fifo.h
@@ -1,4 +1,5 @@
-/* $NetBSD: fifo.h,v 1.9 1994/12/13 20:14:38 mycroft Exp $ */
+/* $OpenBSD: fifo.h,v 1.2 1996/02/27 07:53:42 niklas Exp $ */
+/* $NetBSD: fifo.h,v 1.10 1996/02/09 22:40:15 christos Exp $ */
/*
* Copyright (c) 1991, 1993
@@ -34,55 +35,59 @@
*
* @(#)fifo.h 8.3 (Berkeley) 8/10/94
*/
-
#ifdef FIFO
+
/*
* Prototypes for fifo operations on vnodes.
*/
-int fifo_badop(),
- fifo_ebadf();
+int fifo_badop __P((void *));
+int fifo_ebadf __P((void *));
+
+int fifo_lookup __P((void *));
+#define fifo_create fifo_badop
+#define fifo_mknod fifo_badop
+int fifo_open __P((void *));
+int fifo_close __P((void *));
+#define fifo_access fifo_ebadf
+#define fifo_getattr fifo_ebadf
+#define fifo_setattr fifo_ebadf
+int fifo_read __P((void *));
+int fifo_write __P((void *));
+#define fifo_lease_check nullop
+int fifo_ioctl __P((void *));
+int fifo_select __P((void *));
+#define fifo_mmap fifo_badop
+#define fifo_fsync nullop
+#define fifo_seek fifo_badop
+#define fifo_remove fifo_badop
+#define fifo_link fifo_badop
+#define fifo_rename fifo_badop
+#define fifo_mkdir fifo_badop
+#define fifo_rmdir fifo_badop
+#define fifo_symlink fifo_badop
+#define fifo_readdir fifo_badop
+#define fifo_readlink fifo_badop
+#define fifo_abortop fifo_badop
+#define fifo_inactive nullop
+#define fifo_reclaim nullop
+int fifo_lock __P((void *));
+int fifo_unlock __P((void *));
+int fifo_bmap __P((void *));
+#define fifo_strategy fifo_badop
+int fifo_print __P((void *));
+#define fifo_islocked nullop
+int fifo_pathconf __P((void *));
+int fifo_advlock __P((void *));
+#define fifo_blkatoff fifo_badop
+#define fifo_valloc fifo_badop
+#define fifo_reallocblks fifo_badop
+#define fifo_vfree fifo_badop
+#define fifo_truncate nullop
+#define fifo_update nullop
+#define fifo_bwrite nullop
+
+void fifo_printinfo __P((struct vnode *));
+
+extern int (**fifo_vnodeop_p) __P((void *));
-int fifo_lookup __P((struct vop_lookup_args *));
-#define fifo_create ((int (*) __P((struct vop_create_args *)))fifo_badop)
-#define fifo_mknod ((int (*) __P((struct vop_mknod_args *)))fifo_badop)
-int fifo_open __P((struct vop_open_args *));
-int fifo_close __P((struct vop_close_args *));
-#define fifo_access ((int (*) __P((struct vop_access_args *)))fifo_ebadf)
-#define fifo_getattr ((int (*) __P((struct vop_getattr_args *)))fifo_ebadf)
-#define fifo_setattr ((int (*) __P((struct vop_setattr_args *)))fifo_ebadf)
-int fifo_read __P((struct vop_read_args *));
-int fifo_write __P((struct vop_write_args *));
-#define fifo_lease_check ((int (*) __P((struct vop_lease_args *)))nullop)
-int fifo_ioctl __P((struct vop_ioctl_args *));
-int fifo_select __P((struct vop_select_args *));
-#define fifo_mmap ((int (*) __P((struct vop_mmap_args *)))fifo_badop)
-#define fifo_fsync ((int (*) __P((struct vop_fsync_args *)))nullop)
-#define fifo_seek ((int (*) __P((struct vop_seek_args *)))fifo_badop)
-#define fifo_remove ((int (*) __P((struct vop_remove_args *)))fifo_badop)
-#define fifo_link ((int (*) __P((struct vop_link_args *)))fifo_badop)
-#define fifo_rename ((int (*) __P((struct vop_rename_args *)))fifo_badop)
-#define fifo_mkdir ((int (*) __P((struct vop_mkdir_args *)))fifo_badop)
-#define fifo_rmdir ((int (*) __P((struct vop_rmdir_args *)))fifo_badop)
-#define fifo_symlink ((int (*) __P((struct vop_symlink_args *)))fifo_badop)
-#define fifo_readdir ((int (*) __P((struct vop_readdir_args *)))fifo_badop)
-#define fifo_readlink ((int (*) __P((struct vop_readlink_args *)))fifo_badop)
-#define fifo_abortop ((int (*) __P((struct vop_abortop_args *)))fifo_badop)
-#define fifo_inactive ((int (*) __P((struct vop_inactive_args *)))nullop)
-#define fifo_reclaim ((int (*) __P((struct vop_reclaim_args *)))nullop)
-int fifo_lock __P((struct vop_lock_args *));
-int fifo_unlock __P((struct vop_unlock_args *));
-int fifo_bmap __P((struct vop_bmap_args *));
-#define fifo_strategy ((int (*) __P((struct vop_strategy_args *)))fifo_badop)
-int fifo_print __P((struct vop_print_args *));
-#define fifo_islocked ((int (*) __P((struct vop_islocked_args *)))nullop)
-int fifo_pathconf __P((struct vop_pathconf_args *));
-int fifo_advlock __P((struct vop_advlock_args *));
-#define fifo_blkatoff ((int (*) __P((struct vop_blkatoff_args *)))fifo_badop)
-#define fifo_valloc ((int (*) __P((struct vop_valloc_args *)))fifo_badop)
-#define fifo_reallocblks \
- ((int (*) __P((struct vop_reallocblks_args *)))fifo_badop)
-#define fifo_vfree ((int (*) __P((struct vop_vfree_args *)))fifo_badop)
-#define fifo_truncate ((int (*) __P((struct vop_truncate_args *)))nullop)
-#define fifo_update ((int (*) __P((struct vop_update_args *)))nullop)
-#define fifo_bwrite ((int (*) __P((struct vop_bwrite_args *)))nullop)
#endif /* FIFO */
diff --git a/sys/miscfs/fifofs/fifo_vnops.c b/sys/miscfs/fifofs/fifo_vnops.c
index 9d7193d92a9..751380c1f89 100644
--- a/sys/miscfs/fifofs/fifo_vnops.c
+++ b/sys/miscfs/fifofs/fifo_vnops.c
@@ -1,4 +1,5 @@
-/* $NetBSD: fifo_vnops.c,v 1.16 1995/04/14 23:30:14 mycroft Exp $ */
+/* $OpenBSD: fifo_vnops.c,v 1.2 1996/02/27 07:53:43 niklas Exp $ */
+/* $NetBSD: fifo_vnops.c,v 1.17 1996/02/09 22:40:16 christos Exp $ */
/*
* Copyright (c) 1990, 1993
@@ -48,6 +49,7 @@
#include <sys/file.h>
#include <sys/errno.h>
#include <sys/malloc.h>
+#include <sys/un.h>
#include <miscfs/fifofs/fifo.h>
/*
@@ -61,7 +63,7 @@ struct fifoinfo {
long fi_writers;
};
-int (**fifo_vnodeop_p)();
+int (**fifo_vnodeop_p) __P((void *));
struct vnodeopv_entry_desc fifo_vnodeop_entries[] = {
{ &vop_default_desc, vn_default_error },
{ &vop_lookup_desc, fifo_lookup }, /* lookup */
@@ -105,7 +107,7 @@ struct vnodeopv_entry_desc fifo_vnodeop_entries[] = {
{ &vop_truncate_desc, fifo_truncate }, /* truncate */
{ &vop_update_desc, fifo_update }, /* update */
{ &vop_bwrite_desc, fifo_bwrite }, /* bwrite */
- { (struct vnodeop_desc*)NULL, (int(*)())NULL }
+ { (struct vnodeop_desc*)NULL, (int(*) __P((void *)))NULL }
};
struct vnodeopv_desc fifo_vnodeop_opv_desc =
{ &fifo_vnodeop_p, fifo_vnodeop_entries };
@@ -114,13 +116,15 @@ struct vnodeopv_desc fifo_vnodeop_opv_desc =
* Trivial lookup routine that always fails.
*/
/* ARGSUSED */
-fifo_lookup(ap)
+int
+fifo_lookup(v)
+ void *v;
+{
struct vop_lookup_args /* {
struct vnode * a_dvp;
struct vnode ** a_vpp;
struct componentname * a_cnp;
- } */ *ap;
-{
+ } */ *ap = v;
*ap->a_vpp = NULL;
return (ENOTDIR);
@@ -131,14 +135,16 @@ fifo_lookup(ap)
* to find an active instance of a fifo.
*/
/* ARGSUSED */
-fifo_open(ap)
+int
+fifo_open(v)
+ void *v;
+{
struct vop_open_args /* {
struct vnode *a_vp;
int a_mode;
struct ucred *a_cred;
struct proc *a_p;
- } */ *ap;
-{
+ } */ *ap = v;
register struct vnode *vp = ap->a_vp;
register struct fifoinfo *fip;
struct socket *rso, *wso;
@@ -148,20 +154,20 @@ fifo_open(ap)
if ((fip = vp->v_fifoinfo) == NULL) {
MALLOC(fip, struct fifoinfo *, sizeof(*fip), M_VNODE, M_WAITOK);
vp->v_fifoinfo = fip;
- if (error = socreate(AF_LOCAL, &rso, SOCK_STREAM, 0)) {
+ if ((error = socreate(AF_LOCAL, &rso, SOCK_STREAM, 0)) != 0) {
free(fip, M_VNODE);
vp->v_fifoinfo = NULL;
return (error);
}
fip->fi_readsock = rso;
- if (error = socreate(AF_LOCAL, &wso, SOCK_STREAM, 0)) {
+ if ((error = socreate(AF_LOCAL, &wso, SOCK_STREAM, 0)) != 0) {
(void)soclose(rso);
free(fip, M_VNODE);
vp->v_fifoinfo = NULL;
return (error);
}
fip->fi_writesock = wso;
- if (error = unp_connect2(wso, rso)) {
+ if ((error = unp_connect2(wso, rso)) != 0) {
(void)soclose(wso);
(void)soclose(rso);
free(fip, M_VNODE);
@@ -226,14 +232,16 @@ bad:
* Vnode op for read
*/
/* ARGSUSED */
-fifo_read(ap)
+int
+fifo_read(v)
+ void *v;
+{
struct vop_read_args /* {
struct vnode *a_vp;
struct uio *a_uio;
int a_ioflag;
struct ucred *a_cred;
- } */ *ap;
-{
+ } */ *ap = v;
register struct uio *uio = ap->a_uio;
register struct socket *rso = ap->a_vp->v_fifoinfo->fi_readsock;
int error, startresid;
@@ -265,14 +273,16 @@ fifo_read(ap)
* Vnode op for write
*/
/* ARGSUSED */
-fifo_write(ap)
+int
+fifo_write(v)
+ void *v;
+{
struct vop_write_args /* {
struct vnode *a_vp;
struct uio *a_uio;
int a_ioflag;
struct ucred *a_cred;
- } */ *ap;
-{
+ } */ *ap = v;
struct socket *wso = ap->a_vp->v_fifoinfo->fi_writesock;
int error;
@@ -294,7 +304,10 @@ fifo_write(ap)
* Device ioctl operation.
*/
/* ARGSUSED */
-fifo_ioctl(ap)
+int
+fifo_ioctl(v)
+ void *v;
+{
struct vop_ioctl_args /* {
struct vnode *a_vp;
u_long a_command;
@@ -302,8 +315,7 @@ fifo_ioctl(ap)
int a_fflag;
struct ucred *a_cred;
struct proc *a_p;
- } */ *ap;
-{
+ } */ *ap = v;
struct file filetmp;
int error;
@@ -325,15 +337,17 @@ fifo_ioctl(ap)
}
/* ARGSUSED */
-fifo_select(ap)
+int
+fifo_select(v)
+ void *v;
+{
struct vop_select_args /* {
struct vnode *a_vp;
int a_which;
int a_fflags;
struct ucred *a_cred;
struct proc *a_p;
- } */ *ap;
-{
+ } */ *ap = v;
struct file filetmp;
int ready;
@@ -355,14 +369,16 @@ fifo_select(ap)
/*
* This is a noop, simply returning what one has been given.
*/
-fifo_bmap(ap)
+int
+fifo_bmap(v)
+ void *v;
+{
struct vop_bmap_args /* {
struct vnode *a_vp;
daddr_t a_bn;
struct vnode **a_vpp;
daddr_t *a_bnp;
- } */ *ap;
-{
+ } */ *ap = v;
if (ap->a_vpp != NULL)
*ap->a_vpp = ap->a_vp;
@@ -375,20 +391,17 @@ fifo_bmap(ap)
* At the moment we do not do any locking.
*/
/* ARGSUSED */
-fifo_lock(ap)
- struct vop_lock_args /* {
- struct vnode *a_vp;
- } */ *ap;
+int
+fifo_lock(v)
+ void *v;
{
-
return (0);
}
/* ARGSUSED */
-fifo_unlock(ap)
- struct vop_unlock_args /* {
- struct vnode *a_vp;
- } */ *ap;
+int
+fifo_unlock(v)
+ void *v;
{
return (0);
@@ -398,14 +411,16 @@ fifo_unlock(ap)
* Device close routine
*/
/* ARGSUSED */
-fifo_close(ap)
+int
+fifo_close(v)
+ void *v;
+{
struct vop_close_args /* {
struct vnode *a_vp;
int a_fflag;
struct ucred *a_cred;
struct proc *a_p;
- } */ *ap;
-{
+ } */ *ap = v;
register struct vnode *vp = ap->a_vp;
register struct fifoinfo *fip = vp->v_fifoinfo;
int error1, error2;
@@ -432,20 +447,24 @@ fifo_close(ap)
/*
* Print out the contents of a fifo vnode.
*/
-fifo_print(ap)
+int
+fifo_print(v)
+ void *v;
+{
struct vop_print_args /* {
struct vnode *a_vp;
- } */ *ap;
-{
+ } */ *ap = v;
printf("tag VT_NON");
fifo_printinfo(ap->a_vp);
printf("\n");
+ return 0;
}
/*
* Print out internal contents of a fifo vnode.
*/
+void
fifo_printinfo(vp)
struct vnode *vp;
{
@@ -458,13 +477,15 @@ fifo_printinfo(vp)
/*
* Return POSIX pathconf information applicable to fifo's.
*/
-fifo_pathconf(ap)
+int
+fifo_pathconf(v)
+ void *v;
+{
struct vop_pathconf_args /* {
struct vnode *a_vp;
int a_name;
register_t *a_retval;
- } */ *ap;
-{
+ } */ *ap = v;
switch (ap->a_name) {
case _PC_LINK_MAX:
@@ -485,7 +506,10 @@ fifo_pathconf(ap)
/*
* Fifo failed operation
*/
-fifo_ebadf()
+/*ARGSUSED*/
+int
+fifo_ebadf(v)
+ void *v;
{
return (EBADF);
@@ -495,23 +519,20 @@ fifo_ebadf()
* Fifo advisory byte-level locks.
*/
/* ARGSUSED */
-fifo_advlock(ap)
- struct vop_advlock_args /* {
- struct vnode *a_vp;
- caddr_t a_id;
- int a_op;
- struct flock *a_fl;
- int a_flags;
- } */ *ap;
+int
+fifo_advlock(v)
+ void *v;
{
-
return (EOPNOTSUPP);
}
/*
* Fifo bad operation
*/
-fifo_badop()
+/*ARGSUSED*/
+int
+fifo_badop(v)
+ void *v;
{
panic("fifo_badop called");