fixed very bad memory overwrite which leaded to segfaults on some systems. removed...
[asterisk/asterisk.git] / channels / misdn / isdn_lib.h
1 /*
2  * Chan_Misdn -- Channel Driver for Asterisk
3  *
4  * Interface to mISDN
5  *
6  * Copyright (C) 2004, Christian Richter
7  *
8  * Christian Richter <crich@beronet.com>
9  *
10  * This program is free software, distributed under the terms of
11  * the GNU General Public License
12  */
13
14 #ifndef TE_LIB
15 #define TE_LIB
16
17
18 /** For initialization usage **/
19 /* typedef int ie_nothing_t ;*/
20 /** end of init usage **/
21
22
23
24 #define MAX_BCHANS 30
25
26 enum bchannel_state {
27         BCHAN_CLEANED=0,
28         BCHAN_EMPTY,
29         BCHAN_SETUP,
30         BCHAN_SETUPED,
31         BCHAN_ACTIVE,
32         BCHAN_ACTIVATED,
33         BCHAN_BRIDGE,
34         BCHAN_BRIDGED,
35         BCHAN_RELEASE,
36         BCHAN_RELEASED,
37         BCHAN_CLEAN,
38         BCHAN_ERROR
39 };
40
41
42 enum misdn_err_e {
43         ENOCHAN=1
44 };
45
46
47 enum mISDN_NUMBER_PLAN {
48         NUMPLAN_UNINITIALIZED=-1,
49         NUMPLAN_INTERNATIONAL=0x1,
50         NUMPLAN_NATIONAL=0x2,
51         NUMPLAN_SUBSCRIBER=0x4,
52         NUMPLAN_UNKNOWN=0x0
53 }; 
54
55
56 enum event_response_e {
57         RESPONSE_IGNORE_SETUP_WITHOUT_CLOSE,
58         RESPONSE_IGNORE_SETUP,
59         RESPONSE_ERR,
60         RESPONSE_OK
61 };
62
63
64 enum event_e {
65         EVENT_NOTHING,
66         EVENT_TONE_GENERATE,
67         EVENT_BCHAN_DATA,
68         EVENT_BCHAN_ACTIVATED,
69         EVENT_CLEANUP,
70         EVENT_PROCEEDING,
71         EVENT_PROGRESS,
72         EVENT_SETUP,
73         EVENT_ALERTING,
74         EVENT_CONNECT,
75         EVENT_SETUP_ACKNOWLEDGE,
76         EVENT_CONNECT_ACKNOWLEDGE ,
77         EVENT_USER_INFORMATION,
78         EVENT_SUSPEND_REJECT,
79         EVENT_RESUME_REJECT,
80         EVENT_HOLD,
81         EVENT_SUSPEND,
82         EVENT_RESUME,
83         EVENT_HOLD_ACKNOWLEDGE,
84         EVENT_SUSPEND_ACKNOWLEDGE,
85         EVENT_RESUME_ACKNOWLEDGE,
86         EVENT_HOLD_REJECT,
87         EVENT_RETRIEVE,
88         EVENT_RETRIEVE_ACKNOWLEDGE,
89         EVENT_RETRIEVE_REJECT,
90         EVENT_DISCONNECT,
91         EVENT_RESTART,
92         EVENT_RELEASE,
93         EVENT_RELEASE_COMPLETE,
94         EVENT_FACILITY,
95         EVENT_NOTIFY,
96         EVENT_STATUS_ENQUIRY,
97         EVENT_INFORMATION,
98         EVENT_STATUS,
99         EVENT_TIMEOUT,
100         EVENT_DTMF_TONE,
101         EVENT_NEW_L3ID,
102         EVENT_NEW_BC,
103         EVENT_UNKNOWN
104 }; 
105
106
107 enum ie_name_e {
108         IE_DUMMY,
109         IE_LAST
110 };
111
112 enum { /* bearer capability */
113         INFO_CAPABILITY_SPEECH=0,
114         INFO_CAPABILITY_AUDIO_3_1K=0x10 ,
115         INFO_CAPABILITY_AUDIO_7K=0x11 ,
116         INFO_CAPABILITY_VIDEO =0x18,
117         INFO_CAPABILITY_DIGITAL_UNRESTRICTED =0x8,
118         INFO_CAPABILITY_DIGITAL_RESTRICTED =0x09,
119         INFO_CAPABILITY_DIGITAL_UNRESTRICTED_TONES
120 };
121
122 enum { /* progress indicators */
123         INFO_PI_CALL_NOT_E2E_ISDN =0x01,
124         INFO_PI_CALLED_NOT_ISDN =0x02,
125         INFO_PI_CALLER_NOT_ISDN =0x03,
126         INFO_PI_CALLER_RETURNED_TO_ISDN =0x04,
127         INFO_PI_INBAND_AVAILABLE =0x08,
128         INFO_PI_DELAY_AT_INTERF =0x0a,
129         INFO_PI_INTERWORKING_WITH_PUBLIC =0x10,
130         INFO_PI_INTERWORKING_NO_RELEASE =0x11,
131         INFO_PI_INTERWORKING_NO_RELEASE_PRE_ANSWER =0x12,
132         INFO_PI_INTERWORKING_NO_RELEASE_POST_ANSWER =0x13
133 };
134
135 enum { /*CODECS*/
136         INFO_CODEC_ULAW=2,
137         INFO_CODEC_ALAW=3
138 }; 
139
140
141 enum layer_e {
142         L3,
143         L2,
144         L1,
145         UNKNOWN
146 }; 
147
148
149
150 /** FACILITY STUFF **/
151
152 enum facility_type {
153         FACILITY_NONE,
154         FACILITY_CALLDEFLECT=0x91,
155         FACILITY_CENTREX=0x88
156 };
157
158 union facility {
159         char calldeflect_nr[15];
160         char cnip[256];
161 };
162
163
164
165
166 struct misdn_bchannel {
167
168         int nt;
169         int port;
170         /** init stuff **/
171         int b_stid;
172         /* int b_addr; */
173         int layer_id;
174
175         void *ack_hdlc;
176         
177         int layer;
178         
179         
180         /** var stuff**/
181         int l3_id;
182         int pid;
183         int ces;
184   
185         int channel;
186         int channel_preselected;
187         
188         int in_use;
189         int addr;
190
191         unsigned char * bframe;
192         int bframe_len;
193         int time_usec;
194         
195         
196         void *astbuf;
197
198         void *misdnbuf;
199
200         int te_choose_channel;
201         int early_bconnect;
202         
203         /* dtmf digit */
204         int dtmf;
205         int send_dtmf;
206
207         /* get setup ack */
208         int need_more_infos;
209
210         /* wether we should use jollys dsp or not */
211         int nodsp;
212         
213         /* wether we should use our jitter buf system or not */
214         int nojitter;
215         
216         enum mISDN_NUMBER_PLAN dnumplan;
217         enum mISDN_NUMBER_PLAN rnumplan;
218         enum mISDN_NUMBER_PLAN onumplan;
219         enum mISDN_NUMBER_PLAN cpnnumplan;
220
221         int progress_coding;
222         int progress_location;
223         int progress_indicator;
224         
225         enum facility_type fac_type;
226         union facility fac;
227         
228         enum facility_type out_fac_type;
229         union facility out_fac;
230         
231         enum event_e evq;
232         
233         /*** CRYPTING STUFF ***/
234         
235         int crypt;
236         int curprx;
237         int curptx; 
238         char crypt_key[255];
239   
240         int crypt_state;
241     
242         /*char ast_dtmf_buf[255];
243           char misdn_dtmf_buf[255]; */
244   
245         /*** CRYPTING STUFF END***/
246   
247         int active;
248         int upset;
249
250         int generate_tone;
251         int tone_cnt;
252  
253         enum bchannel_state bc_state;
254         enum bchannel_state next_bc_state;
255
256         int conf_id;
257         
258         int holded;
259         int stack_holder;
260
261         struct misdn_bchannel *holded_bc;
262         
263         int pres;
264         int screen;
265         
266         int capability;
267         int law;
268         /** V110 Stuff **/
269         int rate;
270         int mode;
271
272         int user1;
273         int urate;
274         int hdlc;
275         /* V110 */
276   
277         unsigned char display[84];
278         unsigned char msn[32];
279         unsigned char oad[32];
280         unsigned char rad[32];
281         unsigned char dad[32];
282         unsigned char cad[32];
283         unsigned char orig_dad[32];
284         unsigned char keypad[32];
285
286         unsigned char info_dad[64];
287         unsigned char infos_pending[64];
288
289 /*      unsigned char info_keypad[32]; */
290 /*      unsigned char clisub[24]; */
291 /*      unsigned char cldsub[24]; */
292 /*      unsigned char uu[256]; */
293   
294         int cause;
295         int out_cause;
296   
297         /* struct misdn_bchannel hold_bc; */
298   
299         /** list stuf **/
300
301         int ec_enable;
302         int ec_deftaps;
303         int ec_whenbridged;
304         int ec_training;
305         
306         int orig;
307
308         int txgain;
309         int rxgain;
310   
311         struct misdn_bchannel *next;
312 };
313
314
315 enum event_response_e (*cb_event) (enum event_e event, struct misdn_bchannel *bc, void *user_data);
316 void (*cb_log) (int level, int port, char *tmpl, ...);
317 int (*cb_jb_empty)(struct misdn_bchannel *bc, char *buffer, int len);
318
319 struct misdn_lib_iface {
320         
321         enum event_response_e (*cb_event)(enum event_e event, struct misdn_bchannel *bc, void *user_data);
322         void (*cb_log)(int level, int port, char *tmpl, ...);
323         int (*cb_jb_empty)(struct misdn_bchannel *bc, char *buffer, int len);
324 };
325
326 /***** USER IFACE **********/
327
328 int misdn_lib_init(char *portlist, struct misdn_lib_iface* iface, void *user_data);
329 int misdn_lib_send_event(struct misdn_bchannel *bc, enum event_e event );
330 void misdn_lib_destroy(void);
331
332 void misdn_lib_log_ies(struct misdn_bchannel *bc);
333
334 char *manager_isdn_get_info(enum event_e event);
335
336 void misdn_lib_transfer(struct misdn_bchannel* holded_bc);
337
338 struct misdn_bchannel* misdn_lib_get_free_bc(int port, int channel);
339
340 void manager_bchannel_activate(struct misdn_bchannel *bc);
341 void manager_bchannel_deactivate(struct misdn_bchannel * bc);
342
343 int misdn_lib_tx2misdn_frm(struct misdn_bchannel *bc, void *data, int len);
344
345 void manager_ph_control(struct misdn_bchannel *bc, long c1, long c2);
346
347
348 int misdn_lib_port_restart(int port);
349 int misdn_lib_get_port_info(int port);
350
351 int misdn_lib_port_up(int port, int notcheck);
352
353 int misdn_lib_get_port_down(int port);
354
355 int misdn_lib_get_port_up (int port) ;
356      
357 int misdn_lib_maxports_get(void) ;
358
359 void misdn_lib_release(struct misdn_bchannel *bc);
360
361 int misdn_cap_is_speech(int cap);
362 int misdn_inband_avail(struct misdn_bchannel *bc);
363
364 int misdn_lib_send_facility(struct misdn_bchannel *bc, enum facility_type fac, void *data);
365
366
367 void manager_ec_enable(struct misdn_bchannel *bc);
368 void manager_ec_disable(struct misdn_bchannel *bc);
369
370
371 void get_show_stack_details(int port, char *buf);
372
373
374 void misdn_lib_tone_generator_start(struct misdn_bchannel *bc);
375 void misdn_lib_tone_generator_stop(struct misdn_bchannel *bc);
376
377
378 void misdn_lib_setup_bc(struct misdn_bchannel *bc);
379
380 void misdn_lib_bridge( struct misdn_bchannel * bc1, struct misdn_bchannel *bc2);
381 void misdn_lib_split_bridge( struct misdn_bchannel * bc1, struct misdn_bchannel *bc2);
382
383 void misdn_lib_echo(struct misdn_bchannel *bc, int onoff);
384
385 int misdn_lib_is_ptp(int port);
386
387 #define PRI_TRANS_CAP_SPEECH                                    0x0
388 #define PRI_TRANS_CAP_DIGITAL                                   0x08
389 #define PRI_TRANS_CAP_RESTRICTED_DIGITAL                        0x09
390 #define PRI_TRANS_CAP_3_1K_AUDIO                                0x10
391 #define PRI_TRANS_CAP_7K_AUDIO                                  0x11
392
393
394
395 char *bc_state2str(enum bchannel_state state);
396 void bc_state_change(struct misdn_bchannel *bc, enum bchannel_state state);
397
398
399
400 #endif