b7c5748e5e
LQM and HDLC timer diagnostics come out with the correct name. o Don't send an LQR immediately upon reviving a datalink. Leave it 'till the next timeout. o Add the link name to some more LQR diagnostics. o Break out of the main loop when a descriptor exception is seen in select(). o Remove the evil nointr_[u]sleep() functions. Timers should be (and are) used instead. o Treat a read() of 0 bytes as an error that's fatal to the link on which the read() is done. We should never read() 0 after select() says there's something there - not unless the link has been closed by the other side. o Write the data seen before a HDLC header to the terminal in `term' mode, *not* back to the modem :-/ o Initialise our transmitted file descriptor before starting any timers. o Only send data links that have *no* pending output data. This means that our final ACK will be written rather than being nuked with the datalink transmission.
47 lines
1.6 KiB
C
47 lines
1.6 KiB
C
/*
|
|
* Written by Toshiharu OHNO (tony-o@iij.ad.jp)
|
|
*
|
|
* Copyright (C) 1993, Internet Initiative Japan, Inc. All rights reserverd.
|
|
*
|
|
* Redistribution and use in source and binary forms are permitted
|
|
* provided that the above copyright notice and this paragraph are
|
|
* duplicated in all such forms and that any documentation,
|
|
* advertising materials, and other materials related to such
|
|
* distribution and use acknowledge that the software was developed
|
|
* by the Internet Initiative Japan. The name of the
|
|
* IIJ may not be used to endorse or promote products derived
|
|
* from this software without specific prior written permission.
|
|
* THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
|
|
* IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
|
|
* WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.
|
|
*
|
|
* $Id: timer.h,v 1.5.4.4 1998/05/01 19:26:07 brian Exp $
|
|
*
|
|
* TODO:
|
|
*/
|
|
|
|
#define TICKUNIT 100000 /* usec's per Unit */
|
|
#define SECTICKS (1000000/TICKUNIT) /* Units per second */
|
|
|
|
struct pppTimer {
|
|
int state;
|
|
const char *name;
|
|
u_long rest; /* Ticks to expire */
|
|
u_long load; /* Initial load value */
|
|
void (*func)(void *); /* Function called when timer is expired */
|
|
void *arg; /* Argument passed to timeout function */
|
|
struct pppTimer *next; /* Link to next timer */
|
|
struct pppTimer *enext; /* Link to next expired timer */
|
|
};
|
|
|
|
#define TIMER_STOPPED 0
|
|
#define TIMER_RUNNING 1
|
|
#define TIMER_EXPIRED 2
|
|
|
|
struct prompt;
|
|
|
|
extern void timer_Start(struct pppTimer *);
|
|
extern void timer_Stop(struct pppTimer *);
|
|
extern void timer_TermService(void);
|
|
extern void timer_Show(int LogLevel, struct prompt *);
|