2005-04-16 15:20:36 -07:00
/*
* Defines for synchronous PPP / Cisco link level subroutines .
*
* Copyright ( C ) 1994 Cronyx Ltd .
* Author : Serge Vakulenko , < vak @ zebub . msk . su >
*
* This software is distributed with NO WARRANTIES , not even the implied
* warranties for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE .
*
* Authors grant any other persons or organizations permission to use
* or modify this software as long as this message is kept with the software ,
* all derivative works or modified versions .
*
* Version 1.7 , Wed Jun 7 22 : 12 : 02 MSD 1995
*
*
*
*/
# ifndef _SYNCPPP_H_
# define _SYNCPPP_H_ 1
# ifdef __KERNEL__
struct slcp {
u16 state ; /* state machine */
u32 magic ; /* local magic number */
u_char echoid ; /* id of last keepalive echo request */
u_char confid ; /* id of last configuration request */
} ;
struct sipcp {
u16 state ; /* state machine */
u_char confid ; /* id of last configuration request */
} ;
struct sppp
{
struct sppp * pp_next ; /* next interface in keepalive list */
u32 pp_flags ; /* use Cisco protocol instead of PPP */
u16 pp_alivecnt ; /* keepalive packets counter */
u16 pp_loopcnt ; /* loopback detection counter */
u32 pp_seq ; /* local sequence number */
u32 pp_rseq ; /* remote sequence number */
struct slcp lcp ; /* LCP params */
struct sipcp ipcp ; /* IPCP params */
u32 ibytes , obytes ; /* Bytes in/out */
u32 ipkts , opkts ; /* Packets in/out */
struct timer_list pp_timer ;
struct net_device * pp_if ;
char pp_link_state ; /* Link status */
spinlock_t lock ;
} ;
struct ppp_device
{
struct net_device * dev ; /* Network device pointer */
struct sppp sppp ; /* Synchronous PPP */
} ;
static inline struct sppp * sppp_of ( struct net_device * dev )
{
2008-05-12 03:29:11 -07:00
struct ppp_device * * ppp = dev - > ml_priv ;
2005-04-16 15:20:36 -07:00
BUG_ON ( ( * ppp ) - > dev ! = dev ) ;
return & ( * ppp ) - > sppp ;
}
# define PP_KEEPALIVE 0x01 /* use keepalive protocol */
# define PP_CISCO 0x02 /* use Cisco protocol instead of PPP */
# define PP_TIMO 0x04 /* cp_timeout routine active */
# define PP_DEBUG 0x08
# define PPP_MTU 1500 /* max. transmit unit */
# define LCP_STATE_CLOSED 0 /* LCP state: closed (conf-req sent) */
# define LCP_STATE_ACK_RCVD 1 /* LCP state: conf-ack received */
# define LCP_STATE_ACK_SENT 2 /* LCP state: conf-ack sent */
# define LCP_STATE_OPENED 3 /* LCP state: opened */
# define IPCP_STATE_CLOSED 0 /* IPCP state: closed (conf-req sent) */
# define IPCP_STATE_ACK_RCVD 1 /* IPCP state: conf-ack received */
# define IPCP_STATE_ACK_SENT 2 /* IPCP state: conf-ack sent */
# define IPCP_STATE_OPENED 3 /* IPCP state: opened */
# define SPPP_LINK_DOWN 0 /* link down - no keepalive */
# define SPPP_LINK_UP 1 /* link is up - keepalive ok */
void sppp_attach ( struct ppp_device * pd ) ;
void sppp_detach ( struct net_device * dev ) ;
int sppp_do_ioctl ( struct net_device * dev , struct ifreq * ifr , int cmd ) ;
struct sk_buff * sppp_dequeue ( struct net_device * dev ) ;
int sppp_isempty ( struct net_device * dev ) ;
void sppp_flush ( struct net_device * dev ) ;
int sppp_open ( struct net_device * dev ) ;
int sppp_reopen ( struct net_device * dev ) ;
int sppp_close ( struct net_device * dev ) ;
# endif
# define SPPPIOCCISCO (SIOCDEVPRIVATE)
# define SPPPIOCPPP (SIOCDEVPRIVATE+1)
# define SPPPIOCDEBUG (SIOCDEVPRIVATE+2)
# define SPPPIOCSFLAGS (SIOCDEVPRIVATE+3)
# define SPPPIOCGFLAGS (SIOCDEVPRIVATE+4)
# endif /* _SYNCPPP_H_ */