1 /* Linux ISDN subsystem, sync PPP, interface to ipppd
3 * Copyright 1994-1999 by Fritz Elfert (fritz@isdn4linux.de)
4 * Copyright 1995,96 Thinking Objects Software GmbH Wuerzburg
5 * Copyright 1995,96 by Michael Hipp (Michael.Hipp@student.uni-tuebingen.de)
6 * Copyright 2000-2002 by Kai Germaschewski (kai@germaschewski.name)
8 * This software may be used and distributed according to the terms
9 * of the GNU General Public License, incorporated herein by reference.
13 #ifndef _LINUX_ISDN_PPP_H
14 #define _LINUX_ISDN_PPP_H
16 #define CALLTYPE_INCOMING 0x1
17 #define CALLTYPE_OUTGOING 0x2
18 #define CALLTYPE_CALLBACK 0x4
20 #define IPPP_VERSION "2.2.0"
25 unsigned char local_num
[64];
26 unsigned char remote_num
[64];
30 #define PPPIOCGCALLINFO _IOWR('t',128,struct pppcallinfo)
31 #define PPPIOCBUNDLE _IOW('t',129,int)
32 #define PPPIOCGMPFLAGS _IOR('t',130,int)
33 #define PPPIOCSMPFLAGS _IOW('t',131,int)
34 #define PPPIOCSMPMTU _IOW('t',132,int)
35 #define PPPIOCSMPMRU _IOW('t',133,int)
36 #define PPPIOCGCOMPRESSORS _IOR('t',134,unsigned long [8])
37 #define PPPIOCSCOMPRESSOR _IOW('t',135,int)
38 #define PPPIOCGIFNAME _IOR('t',136, char [IFNAMSIZ] )
41 #define SC_MP_PROT 0x00000200
42 #define SC_REJ_MP_PROT 0x00000400
43 #define SC_OUT_SHORT_SEQ 0x00000800
44 #define SC_IN_SHORT_SEQ 0x00004000
46 #define SC_DECOMP_ON 0x01
47 #define SC_COMP_ON 0x02
48 #define SC_DECOMP_DISCARD 0x04
49 #define SC_COMP_DISCARD 0x08
50 #define SC_LINK_DECOMP_ON 0x10
51 #define SC_LINK_COMP_ON 0x20
52 #define SC_LINK_DECOMP_DISCARD 0x40
53 #define SC_LINK_COMP_DISCARD 0x80
55 #define ISDN_PPP_COMP_MAX_OPTIONS 16
57 #define IPPP_COMP_FLAG_XMIT 0x1
58 #define IPPP_COMP_FLAG_LINK 0x2
60 struct isdn_ppp_comp_data
{
62 unsigned char options
[ISDN_PPP_COMP_MAX_OPTIONS
];
70 #include <linux/config.h>
72 #ifdef CONFIG_IPPP_FILTER
73 #include <linux/filter.h>
76 #define DECOMP_ERR_NOMEM (-10)
78 #define MP_END_FRAG 0x40
79 #define MP_BEGIN_FRAG 0x80
81 #define MP_MAX_QUEUE_LEN 16
84 * We need a way for the decompressor to influence the generation of CCP
85 * Reset-Requests in a variety of ways. The decompressor is already returning
86 * a lot of information (generated skb length, error conditions) so we use
87 * another parameter. This parameter is a pointer to a structure which is
88 * to be marked valid by the decompressor and only in this case is ever used.
89 * Furthermore, the only case where this data is used is when the decom-
90 * pressor returns DECOMP_ERROR.
92 * We use this same struct for the reset entry of the compressor to commu-
93 * nicate to its caller how to deal with sending of a Reset Ack. In this
94 * case, expra is not used, but other options still apply (suppressing
95 * sending with rsend, appending arbitrary data, etc).
98 #define IPPP_RESET_MAXDATABYTES 32
100 struct isdn_ppp_resetparams
{
101 unsigned char valid
:1; /* rw Is this structure filled at all ? */
102 unsigned char rsend
:1; /* rw Should we send one at all ? */
103 unsigned char idval
:1; /* rw Is the id field valid ? */
104 unsigned char dtval
:1; /* rw Is the data field valid ? */
105 unsigned char expra
:1; /* rw Is an Ack expected for this Req ? */
106 unsigned char id
; /* wo Send CCP ResetReq with this id */
107 unsigned short maxdlen
; /* ro Max bytes to be stored in data field */
108 unsigned short dlen
; /* rw Bytes stored in data field */
109 unsigned char *data
; /* wo Data for ResetReq info field */
113 * this is an 'old friend' from ppp-comp.h under a new name
114 * check the original include for more information
116 struct isdn_ppp_compressor
{
117 struct isdn_ppp_compressor
*next
, *prev
;
118 struct module
*owner
;
119 int num
; /* CCP compression protocol number */
121 void *(*alloc
) (struct isdn_ppp_comp_data
*);
122 void (*free
) (void *state
);
123 int (*init
) (void *state
, struct isdn_ppp_comp_data
*,
126 /* The reset entry needs to get more exact information about the
127 ResetReq or ResetAck it was called with. The parameters are
128 obvious. If reset is called without a Req or Ack frame which
129 could be handed into it, code MUST be set to 0. Using rsparm,
130 the reset entry can control if and how a ResetAck is returned. */
132 void (*reset
) (void *state
, unsigned char code
, unsigned char id
,
133 unsigned char *data
, unsigned len
,
134 struct isdn_ppp_resetparams
*rsparm
);
136 int (*compress
) (void *state
, struct sk_buff
*in
,
137 struct sk_buff
*skb_out
, int proto
);
139 int (*decompress
) (void *state
,struct sk_buff
*in
,
140 struct sk_buff
*skb_out
,
141 struct isdn_ppp_resetparams
*rsparm
);
143 void (*incomp
) (void *state
, struct sk_buff
*in
,int proto
);
144 void (*stat
) (void *state
, struct compstat
*stats
);
147 extern int isdn_ppp_register_compressor(struct isdn_ppp_compressor
*);
148 extern int isdn_ppp_unregister_compressor(struct isdn_ppp_compressor
*);
149 extern int isdn_ppp_dial_slave(char *);
150 extern int isdn_ppp_hangup_slave(char *);
153 unsigned long seqerrs
;
154 unsigned long frame_drops
;
155 unsigned long overflows
;
156 unsigned long max_queue_len
;
160 int mp_mrru
; /* unused */
161 struct sk_buff
* frags
; /* fragments sl list -- use skb->next */
162 long frames
; /* number of frames in the frame list */
163 unsigned int seq
; /* last processed packet seq #: any packets
164 * with smaller seq # will be dropped
169 isdn_mppp_stats stats
;
172 #define NUM_RCV_BUFFS 64
174 struct ippp_buf_queue
{
175 struct ippp_buf_queue
*next
;
176 struct ippp_buf_queue
*last
;
177 char *buf
; /* NULL here indicates end of queue */
181 /* The data structure for one CCP reset transaction */
182 enum ippp_ccp_reset_states
{
190 struct ippp_ccp_reset_state
{
191 enum ippp_ccp_reset_states state
; /* State of this transaction */
192 struct ippp_struct
*is
; /* Backlink to device stuff */
193 unsigned char id
; /* Backlink id index */
194 unsigned char ta
:1; /* The timer is active (flag) */
195 unsigned char expra
:1; /* We expect a ResetAck at all */
196 int dlen
; /* Databytes stored in data */
197 struct timer_list timer
; /* For timeouts/retries */
198 /* This is a hack but seems sufficient for the moment. We do not want
199 to have this be yet another allocation for some bytes, it is more
200 memory management overhead than the whole mess is worth. */
201 unsigned char data
[IPPP_RESET_MAXDATABYTES
];
204 /* The data structure keeping track of the currently outstanding CCP Reset
206 struct ippp_ccp_reset
{
207 struct ippp_ccp_reset_state
*rs
[256]; /* One per possible id */
208 unsigned char lastid
; /* Last id allocated by the engine */
212 struct ippp_struct
*next_link
;
215 struct ippp_buf_queue rq
[NUM_RCV_BUFFS
]; /* packet queue for isdn_ppp_read() */
216 struct ippp_buf_queue
*first
; /* pointer to (current) first packet */
217 struct ippp_buf_queue
*last
; /* pointer to (current) last used packet in queue */
218 wait_queue_head_t wq
;
219 struct task_struct
*tk
;
220 unsigned int mpppcfg
;
226 struct isdn_net_local_s
*lp
;
229 unsigned int last_link_seqno
;
231 #ifdef CONFIG_ISDN_PPP_VJ
233 struct slcompress
*slcomp
;
235 #ifdef CONFIG_IPPP_FILTER
236 struct sock_filter
*pass_filter
; /* filter for packets to pass */
237 struct sock_filter
*active_filter
; /* filter for pkts to reset idle */
238 unsigned pass_len
, active_len
;
241 struct isdn_ppp_compressor
*compressor
,*decompressor
;
242 struct isdn_ppp_compressor
*link_compressor
,*link_decompressor
;
243 void *decomp_stat
,*comp_stat
,*link_decomp_stat
,*link_comp_stat
;
244 struct ippp_ccp_reset
*reset
; /* Allocated on demand, may never be needed */
245 unsigned long compflags
;
248 #endif /* __KERNEL__ */
249 #endif /* _LINUX_ISDN_PPP_H */