summaryrefslogtreecommitdiffstats
path: root/sys/kern
diff options
context:
space:
mode:
authoralm <alm@FreeBSD.org>1993-08-20 05:46:09 +0000
committeralm <alm@FreeBSD.org>1993-08-20 05:46:09 +0000
commit86178533d78b1f333cbbf1228a2bf2494f4071cd (patch)
tree3295af2c9fe64692373f17f6f89e5ec480139351 /sys/kern
parentbde4b15b25dc8d0854fd364440cacf32677391ca (diff)
downloadFreeBSD-src-86178533d78b1f333cbbf1228a2bf2494f4071cd.zip
FreeBSD-src-86178533d78b1f333cbbf1228a2bf2494f4071cd.tar.gz
patch 1of2 to prevent kill -1 syslogd from hanging the console
blindly applied patch provided by Christoph Robitschko: *** cons.c.orig Sat Jun 12 07:57:53 1993 --- cons.c Thu Aug 19 22:34:53 1993 *************** *** 56,61 **** --- 56,62 ---- #include "sys/tty.h" #include "sys/file.h" #include "sys/conf.h" + #include "sys/vnode.h" #include "cons.h" *************** *** 105,118 **** --- 106,130 ---- (*cp->cn_init)(cp); } + static struct vnode *cnopenvp = NULLVP; + + cnopen(dev, flag, mode, p) dev_t dev; int flag, mode; struct proc *p; { + int error; + + if (cn_tab == NULL) return (0); dev = cn_tab->cn_dev; + if (cnopenvp == NULLVP) + if ((error = getdevvp(dev, &cnopenvp, VCHR))) { + printf("cnopen: getdevvp returned %d !\n", error); + return(error); + } return ((*cdevsw[major(dev)].d_open)(dev, flag, mode, p)); } *************** *** 121,130 **** int flag, mode; struct proc *p; { if (cn_tab == NULL) return (0); dev = cn_tab->cn_dev; ! return ((*cdevsw[major(dev)].d_close)(dev, flag, mode, p)); } cnread(dev, uio, flag) --- 133,153 ---- int flag, mode; struct proc *p; { + int error; + + if (cn_tab == NULL) return (0); dev = cn_tab->cn_dev; ! if (vcount(cnopenvp) <= 1) ! error = (*cdevsw[major(dev)].d_close)(dev, flag, mode, p); ! else ! error = 0; ! if (error == 0) { ! vrele(cnopenvp); ! cnopenvp = NULLVP; ! return(error); ! } } cnread(dev, uio, flag)
Diffstat (limited to 'sys/kern')
-rw-r--r--sys/kern/tty_cons.c25
1 files changed, 24 insertions, 1 deletions
diff --git a/sys/kern/tty_cons.c b/sys/kern/tty_cons.c
index 6189d72..a0e92f1 100644
--- a/sys/kern/tty_cons.c
+++ b/sys/kern/tty_cons.c
@@ -56,6 +56,7 @@
#include "sys/tty.h"
#include "sys/file.h"
#include "sys/conf.h"
+#include "sys/vnode.h"
#include "cons.h"
@@ -105,14 +106,25 @@ cninit()
(*cp->cn_init)(cp);
}
+static struct vnode *cnopenvp = NULLVP;
+
+
cnopen(dev, flag, mode, p)
dev_t dev;
int flag, mode;
struct proc *p;
{
+ int error;
+
+
if (cn_tab == NULL)
return (0);
dev = cn_tab->cn_dev;
+ if (cnopenvp == NULLVP)
+ if ((error = getdevvp(dev, &cnopenvp, VCHR))) {
+ printf("cnopen: getdevvp returned %d !\n", error);
+ return(error);
+ }
return ((*cdevsw[major(dev)].d_open)(dev, flag, mode, p));
}
@@ -121,10 +133,21 @@ cnclose(dev, flag, mode, p)
int flag, mode;
struct proc *p;
{
+ int error;
+
+
if (cn_tab == NULL)
return (0);
dev = cn_tab->cn_dev;
- return ((*cdevsw[major(dev)].d_close)(dev, flag, mode, p));
+ if (vcount(cnopenvp) <= 1)
+ error = (*cdevsw[major(dev)].d_close)(dev, flag, mode, p);
+ else
+ error = 0;
+ if (error == 0) {
+ vrele(cnopenvp);
+ cnopenvp = NULLVP;
+ return(error);
+ }
}
cnread(dev, uio, flag)
OpenPOWER on IntegriCloud