make sure that the tty layer restarts the ppp layer when there is an error
such as out of buffer space.
This commit is contained in:
parent
1b1e6276ce
commit
d465daac1e
@ -1,4 +1,4 @@
|
|||||||
/* $NetBSD: ppp_tty.c,v 1.12 1997/03/24 21:23:10 christos Exp $ */
|
/* $NetBSD: ppp_tty.c,v 1.13 1997/03/25 22:33:25 christos Exp $ */
|
||||||
/* Id: ppp_tty.c,v 1.3 1996/07/01 01:04:11 paulus Exp */
|
/* Id: ppp_tty.c,v 1.3 1996/07/01 01:04:11 paulus Exp */
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -119,7 +119,7 @@ int pppwrite __P((struct tty *tp, struct uio *uio, int flag));
|
|||||||
int ppptioctl __P((struct tty *tp, u_long cmd, caddr_t data, int flag,
|
int ppptioctl __P((struct tty *tp, u_long cmd, caddr_t data, int flag,
|
||||||
struct proc *));
|
struct proc *));
|
||||||
int pppinput __P((int c, struct tty *tp));
|
int pppinput __P((int c, struct tty *tp));
|
||||||
int pppstart __P((struct tty *tp));
|
int pppstart __P((struct tty *tp, int));
|
||||||
|
|
||||||
static u_int16_t pppfcs __P((u_int16_t fcs, u_char *cp, int len));
|
static u_int16_t pppfcs __P((u_int16_t fcs, u_char *cp, int len));
|
||||||
static void pppasyncstart __P((struct ppp_softc *));
|
static void pppasyncstart __P((struct ppp_softc *));
|
||||||
@ -664,7 +664,7 @@ pppasyncstart(sc)
|
|||||||
|
|
||||||
/* Call pppstart to start output again if necessary. */
|
/* Call pppstart to start output again if necessary. */
|
||||||
s = spltty();
|
s = spltty();
|
||||||
pppstart(tp);
|
pppstart(tp, 0);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This timeout is needed for operation on a pseudo-tty,
|
* This timeout is needed for operation on a pseudo-tty,
|
||||||
@ -705,8 +705,9 @@ pppasyncctlp(sc)
|
|||||||
* Called at spltty or higher.
|
* Called at spltty or higher.
|
||||||
*/
|
*/
|
||||||
int
|
int
|
||||||
pppstart(tp)
|
pppstart(tp, force)
|
||||||
register struct tty *tp;
|
register struct tty *tp;
|
||||||
|
int force;
|
||||||
{
|
{
|
||||||
register struct ppp_softc *sc = (struct ppp_softc *) tp->t_sc;
|
register struct ppp_softc *sc = (struct ppp_softc *) tp->t_sc;
|
||||||
|
|
||||||
@ -722,8 +723,9 @@ pppstart(tp)
|
|||||||
* or been disconnected from the ppp unit, then tell if_ppp.c that
|
* or been disconnected from the ppp unit, then tell if_ppp.c that
|
||||||
* we need more output.
|
* we need more output.
|
||||||
*/
|
*/
|
||||||
if (CCOUNT(&tp->t_outq) < PPP_LOWAT
|
if (CCOUNT(&tp->t_outq) >= PPP_LOWAT && !force)
|
||||||
&& !((tp->t_state & TS_CARR_ON) == 0 && (tp->t_cflag & CLOCAL) == 0)
|
return 0;
|
||||||
|
if (!((tp->t_state & TS_CARR_ON) == 0 && (tp->t_cflag & CLOCAL) == 0)
|
||||||
&& sc != NULL && tp == (struct tty *) sc->sc_devp) {
|
&& sc != NULL && tp == (struct tty *) sc->sc_devp) {
|
||||||
ppp_restart(sc);
|
ppp_restart(sc);
|
||||||
}
|
}
|
||||||
@ -744,7 +746,7 @@ ppp_timeout(x)
|
|||||||
|
|
||||||
s = spltty();
|
s = spltty();
|
||||||
sc->sc_flags &= ~SC_TIMEOUT;
|
sc->sc_flags &= ~SC_TIMEOUT;
|
||||||
pppstart(tp);
|
pppstart(tp, 1);
|
||||||
splx(s);
|
splx(s);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user