summaryrefslogtreecommitdiffstats
path: root/sys
diff options
context:
space:
mode:
authorache <ache@FreeBSD.org>1994-12-01 23:48:09 +0000
committerache <ache@FreeBSD.org>1994-12-01 23:48:09 +0000
commit04188ac3ca16476d70e7822961cfafc87454fe7d (patch)
treeb6ba6a01062c4e146b0d2229b1e33886a70e55d1 /sys
parent098465c84501c5d5bdab230a2818cbfb7f798e46 (diff)
downloadFreeBSD-src-04188ac3ca16476d70e7822961cfafc87454fe7d.zip
FreeBSD-src-04188ac3ca16476d70e7822961cfafc87454fe7d.tar.gz
Change wakeup to endtsleep, because wakeup don't produce timeout
state, cause infinite wakeups loop in ttywait
Diffstat (limited to 'sys')
-rw-r--r--sys/dev/sio/sio.c7
-rw-r--r--sys/i386/isa/sio.c7
-rw-r--r--sys/isa/sio.c7
3 files changed, 12 insertions, 9 deletions
diff --git a/sys/dev/sio/sio.c b/sys/dev/sio/sio.c
index 13db874..e75085a 100644
--- a/sys/dev/sio/sio.c
+++ b/sys/dev/sio/sio.c
@@ -31,7 +31,7 @@
* SUCH DAMAGE.
*
* from: @(#)com.c 7.5 (Berkeley) 5/16/91
- * $Id: sio.c,v 1.59 1994/11/01 23:09:29 bde Exp $
+ * $Id: sio.c,v 1.60 1994/11/06 00:23:45 bde Exp $
*/
#include "sio.h"
@@ -899,6 +899,7 @@ sioclose(dev, flag, mode, p)
int mynor;
int s;
struct tty *tp;
+ void endtsleep __P((void *));
mynor = minor(dev);
if (mynor & CONTROL_MASK)
@@ -906,9 +907,9 @@ sioclose(dev, flag, mode, p)
com = com_addr(MINOR_TO_UNIT(mynor));
tp = com->tp;
s = spltty();
- timeout(wakeup, TSA_OCOMPLETE(tp), 60 * hz);
+ timeout(endtsleep, (void *)p, 60 * hz);
(*linesw[tp->t_line].l_close)(tp, flag);
- untimeout(wakeup, TSA_OCOMPLETE(tp));
+ untimeout(endtsleep, (void *)p);
siostop(tp, FREAD | FWRITE);
comhardclose(com);
ttyclose(tp);
diff --git a/sys/i386/isa/sio.c b/sys/i386/isa/sio.c
index 13db874..e75085a 100644
--- a/sys/i386/isa/sio.c
+++ b/sys/i386/isa/sio.c
@@ -31,7 +31,7 @@
* SUCH DAMAGE.
*
* from: @(#)com.c 7.5 (Berkeley) 5/16/91
- * $Id: sio.c,v 1.59 1994/11/01 23:09:29 bde Exp $
+ * $Id: sio.c,v 1.60 1994/11/06 00:23:45 bde Exp $
*/
#include "sio.h"
@@ -899,6 +899,7 @@ sioclose(dev, flag, mode, p)
int mynor;
int s;
struct tty *tp;
+ void endtsleep __P((void *));
mynor = minor(dev);
if (mynor & CONTROL_MASK)
@@ -906,9 +907,9 @@ sioclose(dev, flag, mode, p)
com = com_addr(MINOR_TO_UNIT(mynor));
tp = com->tp;
s = spltty();
- timeout(wakeup, TSA_OCOMPLETE(tp), 60 * hz);
+ timeout(endtsleep, (void *)p, 60 * hz);
(*linesw[tp->t_line].l_close)(tp, flag);
- untimeout(wakeup, TSA_OCOMPLETE(tp));
+ untimeout(endtsleep, (void *)p);
siostop(tp, FREAD | FWRITE);
comhardclose(com);
ttyclose(tp);
diff --git a/sys/isa/sio.c b/sys/isa/sio.c
index 13db874..e75085a 100644
--- a/sys/isa/sio.c
+++ b/sys/isa/sio.c
@@ -31,7 +31,7 @@
* SUCH DAMAGE.
*
* from: @(#)com.c 7.5 (Berkeley) 5/16/91
- * $Id: sio.c,v 1.59 1994/11/01 23:09:29 bde Exp $
+ * $Id: sio.c,v 1.60 1994/11/06 00:23:45 bde Exp $
*/
#include "sio.h"
@@ -899,6 +899,7 @@ sioclose(dev, flag, mode, p)
int mynor;
int s;
struct tty *tp;
+ void endtsleep __P((void *));
mynor = minor(dev);
if (mynor & CONTROL_MASK)
@@ -906,9 +907,9 @@ sioclose(dev, flag, mode, p)
com = com_addr(MINOR_TO_UNIT(mynor));
tp = com->tp;
s = spltty();
- timeout(wakeup, TSA_OCOMPLETE(tp), 60 * hz);
+ timeout(endtsleep, (void *)p, 60 * hz);
(*linesw[tp->t_line].l_close)(tp, flag);
- untimeout(wakeup, TSA_OCOMPLETE(tp));
+ untimeout(endtsleep, (void *)p);
siostop(tp, FREAD | FWRITE);
comhardclose(com);
ttyclose(tp);
OpenPOWER on IntegriCloud