X-Git-Url: http://git.eversberg.eu/gitweb.cgi?p=lcr.git;a=blobdiff_plain;f=gsm.h;h=4959e00948855cf8533427e4b69ab8e39dcc7d82;hp=61676de8d9b5ed1c1a1cdc309982dc1ce6797c01;hb=a498faceb2af635bd8e8c60ef87fe1a1afbd4b1d;hpb=20a671d76854520ad9d5ea9d481e008240465e62 diff --git a/gsm.h b/gsm.h index 61676de..4959e00 100644 --- a/gsm.h +++ b/gsm.h @@ -1,26 +1,20 @@ - -struct bts_conf { - int type; /* type of BTS */ - int card; /* E1 card number of BS11 BTS */ - int numtrx; /* up to 8 TRXs */ - int frequency[8]; /* up to 8 frequencies for TRXs */ -}; +extern "C" { +#include +} struct gsm_conf { char debug[128]; /* debug info */ char interface_bsc[64]; /* loopback interface BSC side */ char interface_lcr[64]; /* loopback interface LCR side */ + char openbsc_cfg[128]; /* openbsc config file */ char short_name[64]; /* short network name */ char long_name[64]; /* long network name */ - int mcc; /* mobile country code */ - int mnc; /* mobile network code */ - int lac; /* location area code */ char hlr[64]; /* database name */ int allow_all; /* accept unknown subscribers */ int keep_l2; /* keep layer 2 after exit */ - int numbts; /* number of BTS' */ - struct bts_conf bts[8]; /* configure BTS' */ int noemergshut; /* don't shut down on emergency */ + char pcapfile[128]; /* open capture file for BS11 links */ + int reject_cause; /* reject cause for unsubcribed IMSIs */ }; struct lcr_gsm { @@ -39,9 +33,11 @@ class Pgsm : public PmISDN Pgsm(int type, struct mISDNport *mISDNport, char *portname, struct port_settings *settings, int channel, int exclusive, int mode); ~Pgsm(); + struct lcr_work p_m_g_delete; /* timer for audio transmission */ unsigned int p_m_g_callref; /* ref by OpenBSC */ unsigned int p_m_g_mode; /* data/transparent mode */ int p_m_g_gsm_b_sock; /* gsm bchannel socket */ + struct lcr_fd p_m_g_gsm_b_fd; /* event node */ int p_m_g_gsm_b_index; /* gsm bchannel socket index to use */ int p_m_g_gsm_b_active; /* gsm bchannel socket is activated */ struct lcr_msg *p_m_g_notify_pending; /* queue for NOTIFY if not connected */ @@ -55,8 +51,8 @@ class Pgsm : public PmISDN void bchannel_receive(struct mISDNhead *hh, unsigned char *data, int len); void bchannel_send(unsigned int prim, unsigned int id, unsigned char *data, int len); - void trau_send(void *_tf); - void trau_receive(void *_frame); + void frame_send(void *_frame); + void frame_receive(void *_frame); int hunt_bchannel(void); void setup_ind(unsigned int msg_type, unsigned int callref, struct gsm_mncc *mncc); @@ -78,11 +74,9 @@ class Pgsm : public PmISDN void message_disconnect(unsigned int epoint_id, int message_id, union parameter *param); void message_release(unsigned int epoint_id, int message_id, union parameter *param); int message_epoint(unsigned int epoint_id, int message_id, union parameter *param); - int handler(void); }; -extern char *gsm_conf_error; -int gsm_conf(struct gsm_conf *gsm_conf); +int gsm_conf(struct gsm_conf *gsm_conf, char *conf_error); int handle_gsm(void); int gsm_exit(int rc); int gsm_init(void);