diff options
author | bde <bde@FreeBSD.org> | 1995-07-31 21:02:00 +0000 |
---|---|---|
committer | bde <bde@FreeBSD.org> | 1995-07-31 21:02:00 +0000 |
commit | 6161be8527d8436daf7da9ba9caf28dd75239974 (patch) | |
tree | 6db12c5f3b7deb883374e9daa21609a9e76eaa85 /sys/gnu | |
parent | fc2f9d98283b5feb3a2c1173667335cdc22e809b (diff) | |
download | FreeBSD-src-6161be8527d8436daf7da9ba9caf28dd75239974.zip FreeBSD-src-6161be8527d8436daf7da9ba9caf28dd75239974.tar.gz |
Obtained from: partly from ancient patches of mine via 1.1.5
Introduce TS_CONNECTED and TS_ZOMBIE states. TS_CONNECTED is set
while a connection is established. It is set while (TS_CARR_ON or
CLOCAL is set) and TS_ZOMBIE is clear. TS_ZOMBIE is set for on to
off transitions of TS_CARR_ON that occur when CLOCAL is clear and
is cleared for off to on transitions of CLOCAL. I/o can only occur
while TS_CONNECTED is set. TS_ZOMBIE prevents further i/o.
Split the input-event sleep address TSA_CARR_ON(tp) into TSA_CARR_ON(tp)
and TSA_HUP_OR_INPUT(tp). The former address is now used only for
off to on carrier transitions and equivalent CLOCAL transitions.
The latter is used for all input events, all carrier transitions
and certain CLOCAL transitions. There are some harmless extra
wakeups for rare connection- related events. Previously there were
too many extra wakeups for non-rare input events.
Drivers now call l_modem() instead of setting TS_CARR_ON directly
to handle even the initial off to on transition of carrier. They
should always have done this. l_modem() now handles TS_CONNECTED
and TS_ZOMBIE as well as TS_CARR_ON.
gnu/isdn/iitty.c:
Set TS_CONNECTED for first open ourself to go with bogusly setting
CLOCAL.
i386/isa/syscons.c, i386/isa/pcvt/pcvt_drv.c:
We fake carrier, so don't also fake CLOCAL.
kern/tty.c:
Testing TS_CONNECTED instead of TS_CARR_ON fixes TIOCCONS forgetting to
test CLOCAL. TS_ISOPEN was tested instead, but that broke when we disabled
the clearing of TS_ISOPEN for certain transitions of CLOCAL.
Testing TS_CONNECTED fixes ttyselect() returning false success for output
to devices in state !TS_CARR_ON && !CLOCAL.
Optimize the other selwakeup() call (this is not related to the other
changes).
kern/tty_pty.c:
ptcopen() can be declared in traditional C now that dev_t isn't short.
Diffstat (limited to 'sys/gnu')
-rw-r--r-- | sys/gnu/isdn/iitty.c | 20 |
1 files changed, 16 insertions, 4 deletions
diff --git a/sys/gnu/isdn/iitty.c b/sys/gnu/isdn/iitty.c index afd806d..1e2e6d4 100644 --- a/sys/gnu/isdn/iitty.c +++ b/sys/gnu/isdn/iitty.c @@ -1,6 +1,6 @@ -static char _ittyid[] = "@(#)$Id: iitty.c,v 1.8 1995/07/22 01:29:28 bde Exp $"; +static char _ittyid[] = "@(#)$Id: iitty.c,v 1.9 1995/07/22 16:44:26 bde Exp $"; /******************************************************************************* - * II - Version 0.1 $Revision: 1.8 $ $State: Exp $ + * II - Version 0.1 $Revision: 1.9 $ $State: Exp $ * * Copyright 1994 Dietmar Friede ******************************************************************************* @@ -10,6 +10,12 @@ static char _ittyid[] = "@(#)$Id: iitty.c,v 1.8 1995/07/22 01:29:28 bde Exp * ******************************************************************************* * $Log: iitty.c,v $ + * Revision 1.9 1995/07/22 16:44:26 bde + * Obtained from: partly from ancient patches of mine via 1.1.5 + * + * Give names to the magic tty i/o sleep addresses and use them. This makes + * it easier to remember what the addresses are for and to keep them unique. + * * Revision 1.8 1995/07/22 01:29:28 bde * Move the inline code for waking up writers to a new function * ttwwakeup(). The conditions for doing the wakeup will soon become @@ -159,7 +165,14 @@ ityopen(dev_t dev, int flag, int mode, struct proc * p) return (EBUSY); (void) spltty(); - if(OUTBOUND(dev)) tp->t_cflag |= CLOCAL; + if (OUTBOUND(dev)) { + /* + * XXX should call l_modem() here and not meddle with CLOCAL, + * but itystart() wants TS_CARR_ON to give the true carrier. + */ + tp->t_cflag |= CLOCAL; + tp->t_state |= TS_CONNECTED; + } while ((flag & O_NONBLOCK) == 0 && (tp->t_cflag & CLOCAL) == 0 && (tp->t_state & TS_CARR_ON) == 0) @@ -286,7 +299,6 @@ ity_connect(int no) return; if(OUTBOUND(tp->t_dev)) tp->t_cflag &= ~CLOCAL; (*linesw[tp->t_line].l_modem) (tp, 1); - tp->t_state |= TS_CARR_ON; tp->t_state &=~ (TS_BUSY|TS_FLUSH); if (tp->t_line) (*linesw[tp->t_line].l_start)(tp); |