2007-05-06 13:54:52 +00:00
|
|
|
/*****************************************************************************\
|
|
|
|
** **
|
2007-07-17 17:28:09 +00:00
|
|
|
** Linux Call Router **
|
2007-05-06 13:54:52 +00:00
|
|
|
** **
|
|
|
|
**---------------------------------------------------------------------------**
|
|
|
|
** Copyright: Andreas Eversberg **
|
|
|
|
** **
|
|
|
|
** mISDN-port header file **
|
|
|
|
** **
|
|
|
|
\*****************************************************************************/
|
|
|
|
|
2007-06-27 06:23:50 +00:00
|
|
|
#define FROMUP_BUFFER_SIZE 1024
|
|
|
|
#define FROMUP_BUFFER_MASK 1023
|
2007-05-06 13:54:52 +00:00
|
|
|
|
|
|
|
extern int entity;
|
|
|
|
extern int mISDNdevice;
|
|
|
|
|
2009-05-11 09:07:58 +00:00
|
|
|
extern int mISDNsocket;
|
|
|
|
|
2008-06-01 16:52:10 +00:00
|
|
|
enum {
|
2012-07-27 15:20:43 +00:00
|
|
|
B_EVENT_USE, /* activate bchannel */
|
2008-06-01 16:52:10 +00:00
|
|
|
B_EVENT_ACTIVATED, /* DL_ESTABLISH received */
|
2012-07-27 15:20:43 +00:00
|
|
|
B_EVENT_DROP, /* deactivate bchannel */
|
2008-06-01 16:52:10 +00:00
|
|
|
B_EVENT_DEACTIVATED, /* DL_RELEASE received */
|
2012-07-27 15:20:43 +00:00
|
|
|
B_EVENT_TIMEOUT, /* timeout happed during (de)activation */
|
2008-06-01 16:52:10 +00:00
|
|
|
};
|
|
|
|
|
2007-05-06 13:54:52 +00:00
|
|
|
/* mISDN port structure list */
|
|
|
|
struct mISDNport {
|
2007-08-26 13:23:58 +00:00
|
|
|
struct mlayer3 *ml3;
|
2007-05-06 13:54:52 +00:00
|
|
|
struct mISDNport *next;
|
2007-08-26 13:23:58 +00:00
|
|
|
char name[64]; /* name of port, if available */
|
2007-05-06 13:54:52 +00:00
|
|
|
struct interface_port *ifport; /* link to interface_port */
|
|
|
|
// int iftype; /* IF_* */
|
|
|
|
// int multilink; /* if set, this port will not support callwaiting */
|
2007-08-26 13:23:58 +00:00
|
|
|
int portnum; /* port number 1..n */
|
2007-05-06 13:54:52 +00:00
|
|
|
int ptp; /* if ptp is set, we keep track of l2link */
|
|
|
|
int l1link; /* if l1 is available (only works with nt-mode) */
|
|
|
|
int l2link; /* if l2 is available (at PTP we take this serious) */
|
2009-04-05 10:52:24 +00:00
|
|
|
unsigned char l2mask[16]; /* 128 bits for each tei */
|
2009-03-20 19:46:25 +00:00
|
|
|
int l1hold; /* set, if layer 1 should be holt */
|
2008-04-24 07:24:04 +00:00
|
|
|
int l2hold; /* set, if layer 2 must be hold/checked */
|
2010-01-16 10:20:23 +00:00
|
|
|
struct lcr_timer l2establish; /* time until establishing after link failure */
|
2007-05-06 13:54:52 +00:00
|
|
|
int use; /* counts the number of port that uses this port */
|
2008-09-21 06:57:51 +00:00
|
|
|
int ntmode; /* is TRUE if port is NT mode */
|
|
|
|
int tespecial; /* is TRUE if port uses special TE mode */
|
2007-05-06 13:54:52 +00:00
|
|
|
int pri; /* is TRUE if port is a primary rate interface */
|
2007-07-07 15:13:20 +00:00
|
|
|
int tones; /* TRUE if tones are sent outside connect state */
|
|
|
|
int earlyb; /* TRUE if tones are received outside connect state */
|
2007-05-06 13:54:52 +00:00
|
|
|
int b_num; /* number of bchannels */
|
|
|
|
int b_reserved; /* number of bchannels reserved or in use */
|
2007-08-11 13:57:58 +00:00
|
|
|
class PmISDN *b_port[128]; /* bchannel assigned to port object */
|
2008-04-24 07:24:04 +00:00
|
|
|
struct mqueue upqueue;
|
2010-01-16 10:20:23 +00:00
|
|
|
struct lcr_fd b_sock[128]; /* socket list elements */
|
2008-07-26 15:42:16 +00:00
|
|
|
int b_mode[128]; /* B_MODE_* */
|
2007-08-11 13:57:58 +00:00
|
|
|
int b_state[128]; /* statemachine, 0 = IDLE */
|
2010-01-16 10:20:23 +00:00
|
|
|
struct lcr_timer b_timer[128]; /* timer for bchannel state machine */
|
2007-07-15 10:01:27 +00:00
|
|
|
int locally; /* local causes are sent as local causes not remote */
|
2008-05-02 19:19:06 +00:00
|
|
|
int los, ais, rdi, slip_rx, slip_tx;
|
2009-05-11 09:07:58 +00:00
|
|
|
|
2009-09-26 11:20:29 +00:00
|
|
|
/* ss5 */
|
|
|
|
unsigned int ss5; /* set, if SS5 signalling enabled, also holds feature bits */
|
2007-05-06 13:54:52 +00:00
|
|
|
};
|
|
|
|
extern mISDNport *mISDNport_first;
|
|
|
|
|
|
|
|
/*
|
|
|
|
|
|
|
|
notes on bchannels:
|
|
|
|
|
|
|
|
if a b-channel is in use, the b_port[channel] is linked to the port using it.
|
|
|
|
also each used b-channel counts b_inuse.
|
|
|
|
to assign a bchannel, that is not jet defined due to remote channel assignment,
|
|
|
|
the b_inuse is also increased to reserve channel
|
|
|
|
|
|
|
|
'use' is the number of port instances using this mISDNport. this counts also
|
|
|
|
calls with no bchannel (call waiting, call on hold).
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
/* mISDN none-object functions */
|
2007-07-31 05:34:18 +00:00
|
|
|
int mISDN_initialize(void);
|
|
|
|
void mISDN_deinitialize(void);
|
2009-05-11 09:07:58 +00:00
|
|
|
int mISDN_getportbyname(int sock, int cnt, char *portname);
|
2010-01-15 20:55:25 +00:00
|
|
|
struct mISDNport *mISDNport_open(struct interface_port *ifport);
|
2009-09-26 11:20:29 +00:00
|
|
|
void mISDNport_static(struct mISDNport *mISDNport);
|
2007-05-06 13:54:52 +00:00
|
|
|
void mISDNport_close_all(void);
|
|
|
|
void mISDNport_close(struct mISDNport *mISDNport);
|
|
|
|
void mISDN_port_reorder(void);
|
2008-03-24 10:13:44 +00:00
|
|
|
void enc_ie_cause_standalone(struct l3_msg *l3m, int location, int cause);
|
2008-04-12 16:24:31 +00:00
|
|
|
int stack2manager(struct mISDNport *mISDNport, unsigned int cmd, unsigned int pid, struct l3_msg *l3m);
|
2008-09-02 00:02:11 +00:00
|
|
|
void ph_control(struct mISDNport *mISDNport, class PmISDN *isdnport, unsigned int handle, unsigned int c1, unsigned int c2, const char *trace_name, int trace_value);
|
|
|
|
void ph_control_block(struct mISDNport *mISDNport, unsigned int handle, unsigned int c1, void *c2, int c2_len, const char *trace_name, int trace_value);
|
|
|
|
void chan_trace_header(struct mISDNport *mISDNport, class PmISDN *port, const char *msgtext, int direction);
|
2008-06-14 06:34:50 +00:00
|
|
|
void l1l2l3_trace_header(struct mISDNport *mISDNport, class PmISDN *port, unsigned int prim, int direction);
|
2007-08-12 08:16:19 +00:00
|
|
|
void bchannel_event(struct mISDNport *mISDNport, int i, int event);
|
2007-05-06 13:54:52 +00:00
|
|
|
|
|
|
|
|
|
|
|
/* mISDN port classes */
|
|
|
|
class PmISDN : public Port
|
|
|
|
{
|
|
|
|
public:
|
2008-07-26 15:42:16 +00:00
|
|
|
PmISDN(int type, struct mISDNport *mISDNport, char *portname, struct port_settings *settings, int channel, int exclusive, int mode);
|
2007-05-06 13:54:52 +00:00
|
|
|
~PmISDN();
|
2008-04-13 17:52:42 +00:00
|
|
|
void bchannel_receive(struct mISDNhead *hh, unsigned char *data, int len);
|
2007-05-19 17:45:42 +00:00
|
|
|
void transmit(unsigned char *buffer, int length);
|
2008-06-14 06:34:50 +00:00
|
|
|
int message_epoint(unsigned int epoint_id, int message, union parameter *param);
|
|
|
|
void message_mISDNsignal(unsigned int epoint_id, int message_id, union parameter *param);
|
|
|
|
void message_crypt(unsigned int epoint_id, int message_id, union parameter *param);
|
2007-05-06 13:54:52 +00:00
|
|
|
struct mISDNport *p_m_mISDNport; /* pointer to port */
|
|
|
|
int p_m_delay; /* use delay instead of dejitter */
|
2012-01-20 07:58:27 +00:00
|
|
|
int p_m_tx_dejitter; /* use dejitter on transmit data to DSP */
|
2012-07-29 12:33:15 +00:00
|
|
|
int p_m_disable_dejitter; /* usefull to send fax via bridge */
|
|
|
|
int p_m_preload; /* set to ISDN_LOAD, but may be changed later */
|
2008-01-19 17:10:46 +00:00
|
|
|
int p_m_tx_gain, p_m_rx_gain; /* volume shift (0 = no change) */
|
2008-01-06 14:49:29 +00:00
|
|
|
char p_m_pipeline[256]; /* filter pipeline */
|
2007-05-06 13:54:52 +00:00
|
|
|
int p_m_echo, p_m_conf; /* remote echo, conference number */
|
2009-09-26 11:20:29 +00:00
|
|
|
int p_m_mute; /* if set, conf is disconnected */
|
2007-05-06 13:54:52 +00:00
|
|
|
int p_m_tone; /* current kernel space tone */
|
|
|
|
int p_m_rxoff; /* rx from driver is disabled */
|
2007-06-27 06:23:50 +00:00
|
|
|
int p_m_txdata; /* get what we transmit */
|
2007-05-06 13:54:52 +00:00
|
|
|
int p_m_dtmf; /* dtmf decoding is enabled */
|
2012-01-14 17:36:26 +00:00
|
|
|
|
|
|
|
int bridge_rx(unsigned char *data, int len);
|
2007-06-27 06:23:50 +00:00
|
|
|
|
2010-01-16 10:20:23 +00:00
|
|
|
struct lcr_timer p_m_loadtimer; /* timer for audio transmission */
|
|
|
|
virtual void update_load(void);
|
|
|
|
void load_tx(void);
|
2007-07-15 10:01:27 +00:00
|
|
|
int p_m_load; /* current data in dsp tx buffer */
|
2010-01-16 10:20:23 +00:00
|
|
|
unsigned int p_m_last_tv_sec; /* time stamp of last tx_load call, (to sync audio data */
|
2008-06-14 06:34:50 +00:00
|
|
|
unsigned int p_m_last_tv_msec;
|
2007-05-06 13:54:52 +00:00
|
|
|
|
|
|
|
int p_m_crypt; /* encryption is enabled */
|
|
|
|
int p_m_crypt_msg_loops; /* sending a message */
|
|
|
|
int p_m_crypt_msg_len;
|
|
|
|
unsigned char p_m_crypt_msg[1100];
|
|
|
|
int p_m_crypt_msg_current;
|
|
|
|
unsigned char p_m_crypt_key[128];
|
|
|
|
int p_m_crypt_key_len;
|
|
|
|
int p_m_crypt_listen;
|
|
|
|
int p_m_crypt_listen_state;
|
|
|
|
int p_m_crypt_listen_len;
|
|
|
|
unsigned char p_m_crypt_listen_msg[1100];
|
2008-06-14 06:34:50 +00:00
|
|
|
unsigned int p_m_crypt_listen_crc;
|
2007-05-06 13:54:52 +00:00
|
|
|
void cryptman_listen_bch(unsigned char *p, int l);
|
|
|
|
|
2008-09-02 00:02:11 +00:00
|
|
|
void set_tone(const char *dir, const char *name);
|
2007-05-06 13:54:52 +00:00
|
|
|
void set_echotest(int echotest);
|
2009-09-26 11:20:29 +00:00
|
|
|
void set_conf(int oldconf, int newconf);
|
2007-05-06 13:54:52 +00:00
|
|
|
|
|
|
|
int p_m_portnum; /* used port number (1...n) */
|
|
|
|
int p_m_b_index; /* index 0,1 0..29 */
|
|
|
|
int p_m_b_channel; /* number 1,2 1..15,17... */
|
|
|
|
int p_m_b_exclusive; /* if bchannel is exclusive */
|
2007-06-27 06:23:50 +00:00
|
|
|
int p_m_b_reserve; /* set if channel is reserved */
|
2008-07-26 15:42:16 +00:00
|
|
|
int p_m_b_mode; /* bchannel mode */
|
2007-05-06 13:54:52 +00:00
|
|
|
int p_m_hold; /* if port is on hold */
|
2010-01-16 10:20:23 +00:00
|
|
|
struct lcr_timer p_m_timeout; /* timeout of timers */
|
2007-05-06 13:54:52 +00:00
|
|
|
|
2009-09-26 11:20:29 +00:00
|
|
|
int p_m_inband_send_on; /* triggers optional send function */
|
|
|
|
int p_m_inband_receive_on; /* triggers optional receive function */
|
|
|
|
int p_m_mute_on; /* if mute is on, bridge is removed */
|
|
|
|
virtual int inband_send(unsigned char *buffer, int len);
|
|
|
|
void inband_send_on(void);
|
|
|
|
void inband_send_off(void);
|
|
|
|
virtual void inband_receive(unsigned char *buffer, int len);
|
|
|
|
void inband_receive_on(void);
|
|
|
|
void inband_receive_off(void);
|
|
|
|
void mute_on(void);
|
|
|
|
void mute_off(void);
|
2010-01-16 10:20:23 +00:00
|
|
|
void update_rxoff(void);
|
2009-09-26 11:20:29 +00:00
|
|
|
|
2007-06-27 06:23:50 +00:00
|
|
|
int seize_bchannel(int channel, int exclusive); /* requests / reserves / links bchannels, but does not open it! */
|
|
|
|
void drop_bchannel(void);
|
2007-05-06 13:54:52 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
extern unsigned char mISDN_rand[256]; /* noisy randomizer */
|
|
|
|
|