diff options
author | alm <alm@FreeBSD.org> | 1993-08-20 05:46:09 +0000 |
---|---|---|
committer | alm <alm@FreeBSD.org> | 1993-08-20 05:46:09 +0000 |
commit | 86178533d78b1f333cbbf1228a2bf2494f4071cd (patch) | |
tree | 3295af2c9fe64692373f17f6f89e5ec480139351 /sys/kern | |
parent | bde4b15b25dc8d0854fd364440cacf32677391ca (diff) | |
download | FreeBSD-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.c | 25 |
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) |