Sat Aug 6 00:39:58 2011

Asterisk developer's documentation


isdn_msg_parser.c File Reference

#include "isdn_lib_intern.h"
#include "isdn_lib.h"
#include "ie.c"

Go to the source code of this file.

Defines

#define ANY_CHANNEL   0xff
#define msgs_max   (sizeof(msgs_g)/sizeof(struct isdn_msg))

Functions

static msg_t * build_alerting (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)
static msg_t * build_connect (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)
static msg_t * build_connect_acknowledge (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)
static msg_t * build_disconnect (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)
static msg_t * build_facility (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)
static msg_t * build_hold (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)
static msg_t * build_hold_acknowledge (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)
static msg_t * build_hold_reject (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)
static msg_t * build_information (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)
static msg_t * build_notify (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)
static msg_t * build_proceeding (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)
static msg_t * build_progress (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)
static msg_t * build_release (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)
static msg_t * build_release_complete (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)
static msg_t * build_restart (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)
static msg_t * build_resume (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)
static msg_t * build_resume_acknowledge (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)
static msg_t * build_resume_reject (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)
static msg_t * build_retrieve (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)
static msg_t * build_retrieve_acknowledge (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)
static msg_t * build_retrieve_reject (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)
static msg_t * build_setup (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)
static msg_t * build_setup_acknowledge (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)
static msg_t * build_status (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)
static msg_t * build_status_enquiry (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)
static msg_t * build_suspend (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)
static msg_t * build_suspend_acknowledge (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)
static msg_t * build_suspend_reject (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)
static msg_t * build_timeout (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)
static msg_t * build_user_information (struct isdn_msg msgs[], struct misdn_bchannel *bc, int nt)
char * isdn_get_info (struct isdn_msg msgs[], enum event_e event, int nt)
msg_t * isdn_msg_build_event (struct isdn_msg msgs[], struct misdn_bchannel *bc, enum event_e event, int nt)
enum event_e isdn_msg_get_event (struct isdn_msg msgs[], msg_t *msg, int nt)
int isdn_msg_get_index (struct isdn_msg msgs[], msg_t *msg, int nt)
int isdn_msg_get_index_by_event (struct isdn_msg msgs[], enum event_e event, int nt)
char * isdn_msg_get_info (struct isdn_msg msgs[], msg_t *msg, int nt)
int isdn_msg_parse_event (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)
static void parse_alerting (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)
static void parse_connect (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)
static void parse_connect_acknowledge (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)
static void parse_disconnect (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)
static void parse_facility (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)
static void parse_hold (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)
static void parse_hold_acknowledge (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)
static void parse_hold_reject (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)
static void parse_information (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)
static void parse_notify (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)
static void parse_proceeding (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)
static void parse_progress (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)
static void parse_release (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)
static void parse_release_complete (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)
static void parse_restart (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)
static void parse_resume (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)
static void parse_resume_acknowledge (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)
static void parse_resume_reject (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)
static void parse_retrieve (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)
static void parse_retrieve_acknowledge (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)
static void parse_retrieve_reject (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)
static void parse_setup (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)
static void parse_setup_acknowledge (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)
static void parse_status (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)
static void parse_status_enquiry (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)
static void parse_suspend (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)
static void parse_suspend_acknowledge (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)
static void parse_suspend_reject (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)
static void parse_timeout (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)
static void parse_user_information (struct isdn_msg msgs[], msg_t *msg, struct misdn_bchannel *bc, int nt)
static void set_channel (struct misdn_bchannel *bc, int channel)

Variables

char EVENT_BCHAN_ACTIVATED_INFO [] = "BCHAN_ACTIVATED"
char EVENT_BCHAN_DATA_INFO [] = "BCHAN_DATA"
char EVENT_BCHAN_ERROR_INFO [] = "BCHAN_ERROR"
char EVENT_CLEAN_INFO [] = "CLEAN_UP"
char EVENT_DTMF_TONE_INFO [] = "DTMF_TONE"
char EVENT_NEW_BC_INFO [] = "NEW_BC"
char EVENT_NEW_CHANNEL_INFO [] = "NEW_CHANNEL"
char EVENT_NEW_L3ID_INFO [] = "NEW_L3ID"
char EVENT_PORT_ALARM_INFO [] = "ALARM"
char EVENT_TONE_GENERATE_INFO [] = "TONE_GENERATE"
isdn_msg msgs_g []


Define Documentation

#define ANY_CHANNEL   0xff

Definition at line 268 of file isdn_msg_parser.c.

Referenced by build_setup().

#define msgs_max   (sizeof(msgs_g)/sizeof(struct isdn_msg))

Definition at line 1252 of file isdn_msg_parser.c.

Referenced by isdn_msg_get_index(), and isdn_msg_get_index_by_event().


Function Documentation

static msg_t* build_alerting ( struct isdn_msg  msgs[],
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 107 of file isdn_msg_parser.c.

References misdn_stack::bc, misdn_bchannel::channel, create_l3msg(), enc_ie_channel_id(), enc_ie_progress(), HEADER_LEN, misdn_bchannel::l3_id, and mISDNUSER_HEAD_SIZE.

00108 {
00109    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
00110    ALERTING_t *alerting;
00111    msg_t *msg =(msg_t*)create_l3msg(CC_ALERTING | REQUEST, MT_ALERTING,  bc?bc->l3_id:-1, sizeof(ALERTING_t) ,nt); 
00112   
00113    alerting=(ALERTING_t*)((msg->data+HEADER_LEN)); 
00114   
00115    enc_ie_channel_id(&alerting->CHANNEL_ID, msg, 1,bc->channel, nt,bc);
00116    
00117    if (nt) 
00118       enc_ie_progress(&alerting->PROGRESS, msg, 0, nt?1:5, 8, nt,bc);
00119 #if DEBUG 
00120    printf("Building ALERTING Msg\n"); 
00121 #endif
00122    return msg; 
00123 }

static msg_t* build_connect ( struct isdn_msg  msgs[],
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 381 of file isdn_msg_parser.c.

References misdn_stack::bc, misdn_bchannel::cad, cb_log, misdn_bchannel::cpnnumplan, create_l3msg(), enc_ie_connected_pn(), enc_ie_date(), HEADER_LEN, misdn_bchannel::l3_id, mISDNUSER_HEAD_SIZE, misdn_bchannel::port, and type.

00382 {
00383    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
00384    CONNECT_t *connect;
00385    msg_t *msg =(msg_t*)create_l3msg(CC_CONNECT | REQUEST, MT_CONNECT,  bc?bc->l3_id:-1, sizeof(CONNECT_t) ,nt); 
00386    
00387    cb_log(6,bc->port,"BUILD_CONNECT: bc:%p bc->l3id:%d, nt:%d\n",bc,bc->l3_id,nt);
00388 
00389    connect=(CONNECT_t*)((msg->data+HEADER_LEN)); 
00390 
00391    if (nt) {
00392       time_t now;
00393       time(&now);
00394       enc_ie_date(&connect->DATE, msg, now, nt,bc);
00395    }
00396   
00397    {
00398       int type=bc->cpnnumplan, plan=1, present=2, screen=0;
00399       enc_ie_connected_pn(&connect->CONNECT_PN, msg, type,plan, present, screen, bc->cad, nt , bc);
00400    }
00401 
00402 #if DEBUG 
00403    printf("Building CONNECT Msg\n"); 
00404 #endif
00405    return msg; 
00406 }

static msg_t* build_connect_acknowledge ( struct isdn_msg  msgs[],
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 457 of file isdn_msg_parser.c.

References misdn_stack::bc, misdn_bchannel::channel, create_l3msg(), enc_ie_channel_id(), HEADER_LEN, misdn_bchannel::l3_id, and mISDNUSER_HEAD_SIZE.

00458 {
00459    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
00460    CONNECT_ACKNOWLEDGE_t *connect_acknowledge;
00461    msg_t *msg =(msg_t*)create_l3msg(CC_CONNECT | RESPONSE, MT_CONNECT,  bc?bc->l3_id:-1, sizeof(CONNECT_ACKNOWLEDGE_t) ,nt); 
00462  
00463    connect_acknowledge=(CONNECT_ACKNOWLEDGE_t*)((msg->data+HEADER_LEN)); 
00464   
00465    enc_ie_channel_id(&connect_acknowledge->CHANNEL_ID, msg, 1, bc->channel, nt,bc);
00466   
00467 #if DEBUG 
00468    printf("Building CONNECT_ACKNOWLEDGE Msg\n"); 
00469 #endif
00470    return msg; 
00471 }

static msg_t* build_disconnect ( struct isdn_msg  msgs[],
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 790 of file isdn_msg_parser.c.

References misdn_stack::bc, cb_log, create_l3msg(), enc_ie_cause(), enc_ie_progress(), enc_ie_useruser(), HEADER_LEN, misdn_bchannel::l3_id, mISDNUSER_HEAD_SIZE, misdn_bchannel::out_cause, misdn_bchannel::port, misdn_bchannel::uu, and misdn_bchannel::uulen.

00791 {
00792    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
00793    DISCONNECT_t *disconnect;
00794    msg_t *msg =(msg_t*)create_l3msg(CC_DISCONNECT | REQUEST, MT_DISCONNECT,  bc?bc->l3_id:-1, sizeof(DISCONNECT_t) ,nt); 
00795    
00796    disconnect=(DISCONNECT_t*)((msg->data+HEADER_LEN)); 
00797    
00798    enc_ie_cause(&disconnect->CAUSE, msg, (nt)?1:0, bc->out_cause,nt,bc);
00799    if (nt) enc_ie_progress(&disconnect->PROGRESS, msg, 0, nt?1:5, 8 ,nt,bc);
00800 
00801    if (bc->uulen) {
00802       int  protocol=4;
00803       enc_ie_useruser(&disconnect->USER_USER, msg, protocol, bc->uu, bc->uulen, nt,bc);
00804       cb_log(1,bc->port,"ENCODING USERUESRINFO:%s\n",bc->uu);
00805    }
00806   
00807 #if DEBUG 
00808    printf("Building DISCONNECT Msg\n"); 
00809 #endif
00810    return msg; 
00811 }

static msg_t* build_facility ( struct isdn_msg  msgs[],
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 978 of file isdn_msg_parser.c.

References misdn_stack::bc, create_l3msg(), misdn_bchannel::display, enc_ie_display(), misdn_bchannel::fac_out, HEADER_LEN, misdn_bchannel::l3_id, len(), mISDNUSER_HEAD_SIZE, and misdn_bchannel::nt.

00979 {
00980    int len,
00981       HEADER_LEN = nt ? mISDNUSER_HEAD_SIZE : mISDN_HEADER_LEN;
00982    unsigned char *ie_fac,
00983               fac_tmp[256];
00984    msg_t *msg =(msg_t*)create_l3msg(CC_FACILITY | REQUEST, MT_FACILITY,  bc?bc->l3_id:-1, sizeof(FACILITY_t) ,nt);
00985    FACILITY_t *facility = (FACILITY_t*)(msg->data+HEADER_LEN); 
00986    Q931_info_t *qi;
00987 
00988 #if DEBUG 
00989    printf("Building FACILITY Msg\n"); 
00990 #endif
00991    
00992    len = encodeFac(fac_tmp, &(bc->fac_out));
00993    if (len <= 0)
00994       return NULL;
00995 
00996    ie_fac = msg_put(msg, len);
00997    if (bc->nt) {
00998       facility->FACILITY = ie_fac + 1;
00999    } else {
01000       qi = (Q931_info_t *)(msg->data + mISDN_HEADER_LEN);
01001       qi->QI_ELEMENT(facility) = ie_fac - (unsigned char *)qi - sizeof(Q931_info_t);
01002    }
01003 
01004    memcpy(ie_fac, fac_tmp, len);
01005 
01006    if (*bc->display) {
01007       printf("Sending %s as Display\n", bc->display);
01008       enc_ie_display(&facility->DISPLAY, msg, bc->display, nt,bc);
01009    }
01010 
01011    return msg; 
01012 }

static msg_t* build_hold ( struct isdn_msg  msgs[],
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 551 of file isdn_msg_parser.c.

References misdn_stack::bc, create_l3msg(), HEADER_LEN, misdn_bchannel::l3_id, and mISDNUSER_HEAD_SIZE.

00552 {
00553    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
00554    HOLD_t *hold;
00555    msg_t *msg =(msg_t*)create_l3msg(CC_HOLD | REQUEST, MT_HOLD,  bc?bc->l3_id:-1, sizeof(HOLD_t) ,nt); 
00556  
00557    hold=(HOLD_t*)((msg->data+HEADER_LEN)); 
00558 
00559 #if DEBUG 
00560    printf("Building HOLD Msg\n"); 
00561 #endif
00562    return msg; 
00563 }

static msg_t* build_hold_acknowledge ( struct isdn_msg  msgs[],
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 620 of file isdn_msg_parser.c.

References misdn_stack::bc, create_l3msg(), HEADER_LEN, misdn_bchannel::l3_id, and mISDNUSER_HEAD_SIZE.

00621 {
00622    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
00623    HOLD_ACKNOWLEDGE_t *hold_acknowledge;
00624    msg_t *msg =(msg_t*)create_l3msg(CC_HOLD_ACKNOWLEDGE | REQUEST, MT_HOLD_ACKNOWLEDGE,  bc?bc->l3_id:-1, sizeof(HOLD_ACKNOWLEDGE_t) ,nt); 
00625  
00626    hold_acknowledge=(HOLD_ACKNOWLEDGE_t*)((msg->data+HEADER_LEN)); 
00627 
00628 #if DEBUG 
00629    printf("Building HOLD_ACKNOWLEDGE Msg\n"); 
00630 #endif
00631    return msg; 
00632 }

static msg_t* build_hold_reject ( struct isdn_msg  msgs[],
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 689 of file isdn_msg_parser.c.

References misdn_stack::bc, create_l3msg(), HEADER_LEN, misdn_bchannel::l3_id, and mISDNUSER_HEAD_SIZE.

00690 {
00691    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
00692    HOLD_REJECT_t *hold_reject;
00693    msg_t *msg =(msg_t*)create_l3msg(CC_HOLD_REJECT | REQUEST, MT_HOLD_REJECT,  bc?bc->l3_id:-1, sizeof(HOLD_REJECT_t) ,nt); 
00694  
00695    hold_reject=(HOLD_REJECT_t*)((msg->data+HEADER_LEN)); 
00696 
00697 #if DEBUG 
00698    printf("Building HOLD_REJECT Msg\n"); 
00699 #endif
00700    return msg; 
00701 }

static msg_t* build_information ( struct isdn_msg  msgs[],
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 1074 of file isdn_msg_parser.c.

References misdn_stack::bc, create_l3msg(), misdn_bchannel::display, enc_ie_called_pn(), enc_ie_display(), HEADER_LEN, misdn_bchannel::info_dad, misdn_bchannel::l3_id, and mISDNUSER_HEAD_SIZE.

01075 {
01076    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
01077    INFORMATION_t *information;
01078    msg_t *msg =(msg_t*)create_l3msg(CC_INFORMATION | REQUEST, MT_INFORMATION,  bc?bc->l3_id:-1, sizeof(INFORMATION_t) ,nt); 
01079  
01080    information=(INFORMATION_t*)((msg->data+HEADER_LEN)); 
01081   
01082    {
01083       enc_ie_called_pn(&information->CALLED_PN, msg, 0, 1, bc->info_dad, nt,bc);
01084    }
01085 
01086    {
01087       if (*bc->display) {
01088          printf("Sending %s as Display\n", bc->display);
01089          enc_ie_display(&information->DISPLAY, msg, bc->display, nt,bc);
01090       }
01091    }
01092   
01093 #if DEBUG 
01094    printf("Building INFORMATION Msg\n"); 
01095 #endif
01096    return msg; 
01097 }

static msg_t* build_notify ( struct isdn_msg  msgs[],
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 1021 of file isdn_msg_parser.c.

References misdn_stack::bc, create_l3msg(), HEADER_LEN, misdn_bchannel::l3_id, and mISDNUSER_HEAD_SIZE.

01022 {
01023    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
01024    NOTIFY_t *notify;
01025    msg_t *msg =(msg_t*)create_l3msg(CC_NOTIFY | REQUEST, MT_NOTIFY,  bc?bc->l3_id:-1, sizeof(NOTIFY_t) ,nt); 
01026  
01027    notify=(NOTIFY_t*)((msg->data+HEADER_LEN)); 
01028 
01029 #if DEBUG 
01030    printf("Building NOTIFY Msg\n"); 
01031 #endif
01032    return msg; 
01033 }

static msg_t* build_proceeding ( struct isdn_msg  msgs[],
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 72 of file isdn_msg_parser.c.

References misdn_stack::bc, misdn_bchannel::channel, create_l3msg(), enc_ie_channel_id(), enc_ie_progress(), HEADER_LEN, misdn_bchannel::l3_id, and mISDNUSER_HEAD_SIZE.

00073 {
00074    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
00075    CALL_PROCEEDING_t *proceeding;
00076    msg_t *msg =(msg_t*)create_l3msg(CC_PROCEEDING | REQUEST, MT_CALL_PROCEEDING,  bc?bc->l3_id:-1, sizeof(CALL_PROCEEDING_t) ,nt); 
00077   
00078    proceeding=(CALL_PROCEEDING_t*)((msg->data+HEADER_LEN));
00079 
00080    enc_ie_channel_id(&proceeding->CHANNEL_ID, msg, 1,bc->channel, nt,bc);
00081   
00082    if (nt) 
00083       enc_ie_progress(&proceeding->PROGRESS, msg, 0, nt?1:5, 8, nt,bc);
00084   
00085 
00086 #if DEBUG 
00087    printf("Building PROCEEDING Msg\n"); 
00088 #endif
00089    return msg; 
00090 }

static msg_t* build_progress ( struct isdn_msg  msgs[],
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 139 of file isdn_msg_parser.c.

References misdn_stack::bc, create_l3msg(), HEADER_LEN, misdn_bchannel::l3_id, and mISDNUSER_HEAD_SIZE.

00140 {
00141    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
00142    PROGRESS_t *progress;
00143    msg_t *msg =(msg_t*)create_l3msg(CC_PROGRESS | REQUEST, MT_PROGRESS,  bc?bc->l3_id:-1, sizeof(PROGRESS_t) ,nt); 
00144  
00145    progress=(PROGRESS_t*)((msg->data+HEADER_LEN)); 
00146 
00147 #if DEBUG 
00148    printf("Building PROGRESS Msg\n"); 
00149 #endif
00150    return msg; 
00151 }

static msg_t* build_release ( struct isdn_msg  msgs[],
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 872 of file isdn_msg_parser.c.

References misdn_stack::bc, cb_log, create_l3msg(), enc_ie_cause(), enc_ie_useruser(), HEADER_LEN, misdn_bchannel::l3_id, mISDNUSER_HEAD_SIZE, misdn_bchannel::out_cause, misdn_bchannel::port, misdn_bchannel::uu, and misdn_bchannel::uulen.

00873 {
00874    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
00875    RELEASE_t *release;
00876    msg_t *msg =(msg_t*)create_l3msg(CC_RELEASE | REQUEST, MT_RELEASE,  bc?bc->l3_id:-1, sizeof(RELEASE_t) ,nt); 
00877  
00878    release=(RELEASE_t*)((msg->data+HEADER_LEN)); 
00879   
00880    if (bc->out_cause>= 0)
00881       enc_ie_cause(&release->CAUSE, msg, nt?1:0, bc->out_cause, nt,bc);
00882 
00883    if (bc->uulen) {
00884       int  protocol=4;
00885       enc_ie_useruser(&release->USER_USER, msg, protocol, bc->uu, bc->uulen, nt,bc);
00886       cb_log(1,bc->port,"ENCODING USERUESRINFO:%s\n",bc->uu);
00887    }
00888   
00889 #if DEBUG 
00890    printf("Building RELEASE Msg\n"); 
00891 #endif
00892    return msg; 
00893 }

static msg_t* build_release_complete ( struct isdn_msg  msgs[],
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 929 of file isdn_msg_parser.c.

References misdn_stack::bc, cb_log, create_l3msg(), enc_ie_cause(), enc_ie_useruser(), HEADER_LEN, misdn_bchannel::l3_id, mISDNUSER_HEAD_SIZE, misdn_bchannel::out_cause, misdn_bchannel::port, misdn_bchannel::uu, and misdn_bchannel::uulen.

00930 {
00931    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
00932    RELEASE_COMPLETE_t *release_complete;
00933    msg_t *msg =(msg_t*)create_l3msg(CC_RELEASE_COMPLETE | REQUEST, MT_RELEASE_COMPLETE,  bc?bc->l3_id:-1, sizeof(RELEASE_COMPLETE_t) ,nt); 
00934  
00935    release_complete=(RELEASE_COMPLETE_t*)((msg->data+HEADER_LEN)); 
00936    
00937    enc_ie_cause(&release_complete->CAUSE, msg, nt?1:0, bc->out_cause, nt,bc);
00938 
00939    if (bc->uulen) {
00940       int  protocol=4;
00941       enc_ie_useruser(&release_complete->USER_USER, msg, protocol, bc->uu, bc->uulen, nt,bc);
00942       cb_log(1,bc->port,"ENCODING USERUESRINFO:%s\n",bc->uu);
00943    }
00944   
00945 #if DEBUG 
00946    printf("Building RELEASE_COMPLETE Msg\n"); 
00947 #endif
00948    return msg; 
00949 }

static msg_t* build_restart ( struct isdn_msg  msgs[],
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 832 of file isdn_msg_parser.c.

References misdn_stack::bc, cb_log, misdn_bchannel::channel, create_l3msg(), enc_ie_channel_id(), enc_ie_restart_ind(), HEADER_LEN, misdn_bchannel::l3_id, mISDNUSER_HEAD_SIZE, and misdn_bchannel::port.

00833 {
00834    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
00835    RESTART_t *restart;
00836    msg_t *msg =(msg_t*)create_l3msg(CC_RESTART | REQUEST, MT_RESTART,  bc?bc->l3_id:-1, sizeof(RESTART_t) ,nt); 
00837  
00838    restart=(RESTART_t*)((msg->data+HEADER_LEN)); 
00839    
00840 #if DEBUG 
00841    printf("Building RESTART Msg\n"); 
00842 #endif
00843 
00844    if (bc->channel > 0) {
00845       enc_ie_channel_id(&restart->CHANNEL_ID, msg, 1,bc->channel, nt,bc);
00846       enc_ie_restart_ind(&restart->RESTART_IND, msg, 0x80, nt, bc);
00847    } else {
00848       enc_ie_restart_ind(&restart->RESTART_IND, msg, 0x87, nt, bc);
00849    }
00850 
00851    cb_log(0,bc->port, "Restarting channel %d\n", bc->channel);
00852    
00853    return msg; 
00854 }

static msg_t* build_resume ( struct isdn_msg  msgs[],
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 597 of file isdn_msg_parser.c.

References misdn_stack::bc, create_l3msg(), HEADER_LEN, misdn_bchannel::l3_id, and mISDNUSER_HEAD_SIZE.

00598 {
00599    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
00600    RESUME_t *resume;
00601    msg_t *msg =(msg_t*)create_l3msg(CC_RESUME | REQUEST, MT_RESUME,  bc?bc->l3_id:-1, sizeof(RESUME_t) ,nt); 
00602  
00603    resume=(RESUME_t*)((msg->data+HEADER_LEN)); 
00604 
00605 #if DEBUG 
00606    printf("Building RESUME Msg\n"); 
00607 #endif
00608    return msg; 
00609 }

static msg_t* build_resume_acknowledge ( struct isdn_msg  msgs[],
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 666 of file isdn_msg_parser.c.

References misdn_stack::bc, create_l3msg(), HEADER_LEN, misdn_bchannel::l3_id, and mISDNUSER_HEAD_SIZE.

00667 {
00668    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
00669    RESUME_ACKNOWLEDGE_t *resume_acknowledge;
00670    msg_t *msg =(msg_t*)create_l3msg(CC_RESUME_ACKNOWLEDGE | REQUEST, MT_RESUME_ACKNOWLEDGE,  bc?bc->l3_id:-1, sizeof(RESUME_ACKNOWLEDGE_t) ,nt); 
00671  
00672    resume_acknowledge=(RESUME_ACKNOWLEDGE_t*)((msg->data+HEADER_LEN)); 
00673 
00674 #if DEBUG 
00675    printf("Building RESUME_ACKNOWLEDGE Msg\n"); 
00676 #endif
00677    return msg; 
00678 }

static msg_t* build_resume_reject ( struct isdn_msg  msgs[],
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 528 of file isdn_msg_parser.c.

References misdn_stack::bc, create_l3msg(), HEADER_LEN, misdn_bchannel::l3_id, and mISDNUSER_HEAD_SIZE.

00529 {
00530    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
00531    RESUME_REJECT_t *resume_reject;
00532    msg_t *msg =(msg_t*)create_l3msg(CC_RESUME_REJECT | REQUEST, MT_RESUME_REJECT,  bc?bc->l3_id:-1, sizeof(RESUME_REJECT_t) ,nt); 
00533  
00534    resume_reject=(RESUME_REJECT_t*)((msg->data+HEADER_LEN)); 
00535 
00536 #if DEBUG 
00537    printf("Building RESUME_REJECT Msg\n"); 
00538 #endif
00539    return msg; 
00540 }

static msg_t* build_retrieve ( struct isdn_msg  msgs[],
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 712 of file isdn_msg_parser.c.

References misdn_stack::bc, create_l3msg(), HEADER_LEN, misdn_bchannel::l3_id, and mISDNUSER_HEAD_SIZE.

00713 {
00714    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
00715    RETRIEVE_t *retrieve;
00716    msg_t *msg =(msg_t*)create_l3msg(CC_RETRIEVE | REQUEST, MT_RETRIEVE,  bc?bc->l3_id:-1, sizeof(RETRIEVE_t) ,nt); 
00717  
00718    retrieve=(RETRIEVE_t*)((msg->data+HEADER_LEN)); 
00719 
00720 #if DEBUG 
00721    printf("Building RETRIEVE Msg\n"); 
00722 #endif
00723    return msg; 
00724 }

static msg_t* build_retrieve_acknowledge ( struct isdn_msg  msgs[],
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 735 of file isdn_msg_parser.c.

References misdn_stack::bc, misdn_bchannel::channel, create_l3msg(), enc_ie_channel_id(), HEADER_LEN, misdn_bchannel::l3_id, and mISDNUSER_HEAD_SIZE.

00736 {
00737    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
00738    RETRIEVE_ACKNOWLEDGE_t *retrieve_acknowledge;
00739    msg_t *msg =(msg_t*)create_l3msg(CC_RETRIEVE_ACKNOWLEDGE | REQUEST, MT_RETRIEVE_ACKNOWLEDGE,  bc?bc->l3_id:-1, sizeof(RETRIEVE_ACKNOWLEDGE_t) ,nt); 
00740  
00741    retrieve_acknowledge=(RETRIEVE_ACKNOWLEDGE_t*)((msg->data+HEADER_LEN)); 
00742 
00743    enc_ie_channel_id(&retrieve_acknowledge->CHANNEL_ID, msg, 1, bc->channel, nt,bc);
00744 #if DEBUG 
00745    printf("Building RETRIEVE_ACKNOWLEDGE Msg\n"); 
00746 #endif
00747    return msg; 
00748 }

static msg_t* build_retrieve_reject ( struct isdn_msg  msgs[],
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 759 of file isdn_msg_parser.c.

References misdn_stack::bc, create_l3msg(), HEADER_LEN, misdn_bchannel::l3_id, and mISDNUSER_HEAD_SIZE.

00760 {
00761    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
00762    RETRIEVE_REJECT_t *retrieve_reject;
00763    msg_t *msg =(msg_t*)create_l3msg(CC_RETRIEVE_REJECT | REQUEST, MT_RETRIEVE_REJECT,  bc?bc->l3_id:-1, sizeof(RETRIEVE_REJECT_t) ,nt); 
00764  
00765    retrieve_reject=(RETRIEVE_REJECT_t*)((msg->data+HEADER_LEN)); 
00766 
00767 #if DEBUG 
00768    printf("Building RETRIEVE_REJECT Msg\n"); 
00769 #endif
00770    return msg; 
00771 }

static msg_t* build_setup ( struct isdn_msg  msgs[],
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 269 of file isdn_msg_parser.c.

References ANY_CHANNEL, misdn_stack::bc, misdn_bchannel::capability, capability, cb_log, misdn_bchannel::channel, create_l3msg(), misdn_bchannel::dad, misdn_bchannel::display, misdn_bchannel::dnumplan, enc_ie_bearer(), enc_ie_called_pn(), enc_ie_calling_pn(), enc_ie_channel_id(), enc_ie_complete(), enc_ie_display(), enc_ie_keypad(), enc_ie_redir_nr(), enc_ie_useruser(), HEADER_LEN, INFO_CAPABILITY_DIGITAL_RESTRICTED, INFO_CAPABILITY_DIGITAL_UNRESTRICTED, INFO_CAPABILITY_SPEECH, INFO_CODEC_ALAW, INFO_CODEC_ULAW, misdn_bchannel::keypad, misdn_bchannel::l3_id, misdn_bchannel::law, mISDNUSER_HEAD_SIZE, misdn_bchannel::mode, misdn_bchannel::oad, misdn_bchannel::onumplan, misdn_bchannel::port, misdn_bchannel::pres, misdn_bchannel::rad, misdn_bchannel::rate, misdn_bchannel::screen, misdn_bchannel::sending_complete, type, misdn_bchannel::uu, and misdn_bchannel::uulen.

00270 {
00271    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
00272    SETUP_t *setup;
00273    msg_t *msg =(msg_t*)create_l3msg(CC_SETUP | REQUEST, MT_SETUP,  bc?bc->l3_id:-1, sizeof(SETUP_t) ,nt); 
00274   
00275    setup=(SETUP_t*)((msg->data+HEADER_LEN)); 
00276   
00277    if (bc->channel == 0 || bc->channel == ANY_CHANNEL || bc->channel==-1)
00278       enc_ie_channel_id(&setup->CHANNEL_ID, msg, 0, bc->channel, nt,bc);
00279    else 
00280       enc_ie_channel_id(&setup->CHANNEL_ID, msg, 1, bc->channel, nt,bc);
00281    
00282    
00283    {
00284       int type=bc->onumplan,plan=1,present=bc->pres,screen=bc->screen;
00285       enc_ie_calling_pn(&setup->CALLING_PN, msg, type, plan, present,
00286               screen, bc->oad, nt, bc);
00287    }
00288   
00289    {
00290       if (bc->dad[0])
00291          enc_ie_called_pn(&setup->CALLED_PN, msg, bc->dnumplan, 1, bc->dad, nt,bc);
00292    }
00293 
00294    {
00295       if (bc->rad[0])
00296          enc_ie_redir_nr(&setup->REDIR_NR, msg, 1, 1,  bc->pres, bc->screen, 0, bc->rad, nt,bc);
00297    }
00298 
00299    {
00300       if (bc->keypad[0])
00301          enc_ie_keypad(&setup->KEYPAD, msg, bc->keypad, nt,bc);
00302    }
00303    
00304   
00305    if (*bc->display) {
00306       enc_ie_display(&setup->DISPLAY, msg, bc->display, nt,bc);
00307    }
00308   
00309    {
00310       int coding=0, capability, mode=0 /*  2 for packet ! */
00311          ,user, rate=0x10;
00312 
00313       switch (bc->law) {
00314       case INFO_CODEC_ULAW: user=2;
00315          break;
00316       case INFO_CODEC_ALAW: user=3;
00317          break;
00318       default:
00319          user=3;
00320       }
00321       
00322       switch (bc->capability) {
00323       case INFO_CAPABILITY_SPEECH: capability = 0;
00324          break;
00325       case INFO_CAPABILITY_DIGITAL_UNRESTRICTED: capability = 8;
00326          user=-1;
00327          mode=bc->mode;
00328          rate=bc->rate;
00329          break;
00330       case INFO_CAPABILITY_DIGITAL_RESTRICTED: capability = 9;
00331          user=-1;
00332          break;
00333       default:
00334          capability=bc->capability; 
00335       }
00336       
00337       
00338     
00339       enc_ie_bearer(&setup->BEARER, msg, coding, capability, mode, rate, -1, user, nt,bc);
00340    }
00341 
00342    if (bc->sending_complete) {
00343       enc_ie_complete(&setup->COMPLETE,msg, bc->sending_complete, nt, bc);
00344    }
00345   
00346    if (bc->uulen) {
00347       int  protocol=4;
00348       enc_ie_useruser(&setup->USER_USER, msg, protocol, bc->uu, bc->uulen, nt,bc);
00349       cb_log(1,bc->port,"ENCODING USERUESRINFO:%s\n",bc->uu);
00350    }
00351 
00352 #if DEBUG 
00353    printf("Building SETUP Msg\n"); 
00354 #endif
00355    return msg; 
00356 }

static msg_t* build_setup_acknowledge ( struct isdn_msg  msgs[],
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 429 of file isdn_msg_parser.c.

References misdn_stack::bc, misdn_bchannel::channel, create_l3msg(), enc_ie_channel_id(), enc_ie_progress(), HEADER_LEN, misdn_bchannel::l3_id, and mISDNUSER_HEAD_SIZE.

00430 {
00431    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
00432    SETUP_ACKNOWLEDGE_t *setup_acknowledge;
00433    msg_t *msg =(msg_t*)create_l3msg(CC_SETUP_ACKNOWLEDGE | REQUEST, MT_SETUP_ACKNOWLEDGE,  bc?bc->l3_id:-1, sizeof(SETUP_ACKNOWLEDGE_t) ,nt); 
00434  
00435    setup_acknowledge=(SETUP_ACKNOWLEDGE_t*)((msg->data+HEADER_LEN)); 
00436   
00437    enc_ie_channel_id(&setup_acknowledge->CHANNEL_ID, msg, 1,bc->channel, nt,bc);
00438   
00439    if (nt) 
00440       enc_ie_progress(&setup_acknowledge->PROGRESS, msg, 0, nt?1:5, 8, nt,bc);
00441   
00442 #if DEBUG 
00443    printf("Building SETUP_ACKNOWLEDGE Msg\n"); 
00444 #endif
00445    return msg; 
00446 }

static msg_t* build_status ( struct isdn_msg  msgs[],
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 1115 of file isdn_msg_parser.c.

References misdn_stack::bc, create_l3msg(), HEADER_LEN, misdn_bchannel::l3_id, and mISDNUSER_HEAD_SIZE.

01116 {
01117    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
01118    STATUS_t *status;
01119    msg_t *msg =(msg_t*)create_l3msg(CC_STATUS | REQUEST, MT_STATUS,  bc?bc->l3_id:-1, sizeof(STATUS_t) ,nt); 
01120  
01121    status=(STATUS_t*)((msg->data+HEADER_LEN)); 
01122 
01123 #if DEBUG 
01124    printf("Building STATUS Msg\n"); 
01125 #endif
01126    return msg; 
01127 }

static msg_t* build_status_enquiry ( struct isdn_msg  msgs[],
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 1042 of file isdn_msg_parser.c.

References misdn_stack::bc, create_l3msg(), HEADER_LEN, misdn_bchannel::l3_id, and mISDNUSER_HEAD_SIZE.

01043 {
01044    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
01045    STATUS_ENQUIRY_t *status_enquiry;
01046    msg_t *msg =(msg_t*)create_l3msg(CC_STATUS_ENQUIRY | REQUEST, MT_STATUS_ENQUIRY,  bc?bc->l3_id:-1, sizeof(STATUS_ENQUIRY_t) ,nt); 
01047  
01048    status_enquiry=(STATUS_ENQUIRY_t*)((msg->data+HEADER_LEN)); 
01049 
01050 #if DEBUG 
01051    printf("Building STATUS_ENQUIRY Msg\n"); 
01052 #endif
01053    return msg; 
01054 }

static msg_t* build_suspend ( struct isdn_msg  msgs[],
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 574 of file isdn_msg_parser.c.

References misdn_stack::bc, create_l3msg(), HEADER_LEN, misdn_bchannel::l3_id, and mISDNUSER_HEAD_SIZE.

00575 {
00576    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
00577    SUSPEND_t *suspend;
00578    msg_t *msg =(msg_t*)create_l3msg(CC_SUSPEND | REQUEST, MT_SUSPEND,  bc?bc->l3_id:-1, sizeof(SUSPEND_t) ,nt); 
00579  
00580    suspend=(SUSPEND_t*)((msg->data+HEADER_LEN)); 
00581 
00582 #if DEBUG 
00583    printf("Building SUSPEND Msg\n"); 
00584 #endif
00585    return msg; 
00586 }

static msg_t* build_suspend_acknowledge ( struct isdn_msg  msgs[],
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 643 of file isdn_msg_parser.c.

References misdn_stack::bc, create_l3msg(), HEADER_LEN, misdn_bchannel::l3_id, and mISDNUSER_HEAD_SIZE.

00644 {
00645    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
00646    SUSPEND_ACKNOWLEDGE_t *suspend_acknowledge;
00647    msg_t *msg =(msg_t*)create_l3msg(CC_SUSPEND_ACKNOWLEDGE | REQUEST, MT_SUSPEND_ACKNOWLEDGE,  bc?bc->l3_id:-1, sizeof(SUSPEND_ACKNOWLEDGE_t) ,nt); 
00648  
00649    suspend_acknowledge=(SUSPEND_ACKNOWLEDGE_t*)((msg->data+HEADER_LEN)); 
00650 
00651 #if DEBUG 
00652    printf("Building SUSPEND_ACKNOWLEDGE Msg\n"); 
00653 #endif
00654    return msg; 
00655 }

static msg_t* build_suspend_reject ( struct isdn_msg  msgs[],
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 505 of file isdn_msg_parser.c.

References misdn_stack::bc, create_l3msg(), HEADER_LEN, misdn_bchannel::l3_id, and mISDNUSER_HEAD_SIZE.

00506 {
00507    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
00508    SUSPEND_REJECT_t *suspend_reject;
00509    msg_t *msg =(msg_t*)create_l3msg(CC_SUSPEND_REJECT | REQUEST, MT_SUSPEND_REJECT,  bc?bc->l3_id:-1, sizeof(SUSPEND_REJECT_t) ,nt); 
00510  
00511    suspend_reject=(SUSPEND_REJECT_t*)((msg->data+HEADER_LEN)); 
00512 
00513 #if DEBUG 
00514    printf("Building SUSPEND_REJECT Msg\n"); 
00515 #endif
00516    return msg; 
00517 }

static msg_t* build_timeout ( struct isdn_msg  msgs[],
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 1136 of file isdn_msg_parser.c.

References misdn_stack::bc, create_l3msg(), HEADER_LEN, misdn_bchannel::l3_id, and mISDNUSER_HEAD_SIZE.

01137 {
01138    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
01139    STATUS_t *status;
01140    msg_t *msg =(msg_t*)create_l3msg(CC_STATUS | REQUEST, MT_STATUS,  bc?bc->l3_id:-1, sizeof(STATUS_t) ,nt); 
01141  
01142    status=(STATUS_t*)((msg->data+HEADER_LEN)); 
01143 
01144 #if DEBUG 
01145    printf("Building STATUS Msg\n"); 
01146 #endif
01147    return msg; 
01148 }

static msg_t* build_user_information ( struct isdn_msg  msgs[],
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 482 of file isdn_msg_parser.c.

References misdn_stack::bc, create_l3msg(), HEADER_LEN, misdn_bchannel::l3_id, and mISDNUSER_HEAD_SIZE.

00483 {
00484    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
00485    USER_INFORMATION_t *user_information;
00486    msg_t *msg =(msg_t*)create_l3msg(CC_USER_INFORMATION | REQUEST, MT_USER_INFORMATION,  bc?bc->l3_id:-1, sizeof(USER_INFORMATION_t) ,nt); 
00487  
00488    user_information=(USER_INFORMATION_t*)((msg->data+HEADER_LEN)); 
00489 
00490 #if DEBUG 
00491    printf("Building USER_INFORMATION Msg\n"); 
00492 #endif
00493    return msg; 
00494 }

char* isdn_get_info ( struct isdn_msg  msgs[],
enum event_e  event,
int  nt 
)

Definition at line 1313 of file isdn_msg_parser.c.

References EVENT_BCHAN_ACTIVATED, EVENT_BCHAN_ACTIVATED_INFO, EVENT_BCHAN_DATA, EVENT_BCHAN_DATA_INFO, EVENT_BCHAN_ERROR, EVENT_BCHAN_ERROR_INFO, EVENT_CLEAN_INFO, EVENT_CLEANUP, EVENT_DTMF_TONE, EVENT_DTMF_TONE_INFO, EVENT_NEW_BC, EVENT_NEW_BC_INFO, EVENT_NEW_CHANNEL, EVENT_NEW_CHANNEL_INFO, EVENT_NEW_L3ID, EVENT_NEW_L3ID_INFO, EVENT_PORT_ALARM, EVENT_PORT_ALARM_INFO, EVENT_TONE_GENERATE, EVENT_TONE_GENERATE_INFO, isdn_msg::info, and isdn_msg_get_index_by_event().

Referenced by handle_event_nt(), handle_frm(), handle_l1(), manager_isdn_get_info(), and misdn_lib_send_event().

01314 {
01315    int i=isdn_msg_get_index_by_event(msgs, event, nt);
01316    
01317    if(i>=0) return msgs[i].info;
01318    
01319    if (event == EVENT_CLEANUP) return EVENT_CLEAN_INFO;
01320    if (event == EVENT_DTMF_TONE) return EVENT_DTMF_TONE_INFO;
01321    if (event == EVENT_NEW_L3ID) return EVENT_NEW_L3ID_INFO;
01322    if (event == EVENT_NEW_BC) return EVENT_NEW_BC_INFO;
01323    if (event == EVENT_NEW_CHANNEL) return EVENT_NEW_CHANNEL_INFO;
01324    if (event == EVENT_BCHAN_DATA) return EVENT_BCHAN_DATA_INFO;
01325    if (event == EVENT_BCHAN_ACTIVATED) return EVENT_BCHAN_ACTIVATED_INFO;
01326    if (event == EVENT_TONE_GENERATE) return EVENT_TONE_GENERATE_INFO;
01327    if (event == EVENT_PORT_ALARM) return EVENT_PORT_ALARM_INFO;
01328    if (event == EVENT_BCHAN_ERROR) return EVENT_BCHAN_ERROR_INFO;
01329    
01330    return NULL;
01331 }

msg_t* isdn_msg_build_event ( struct isdn_msg  msgs[],
struct misdn_bchannel bc,
enum event_e  event,
int  nt 
)

Definition at line 1342 of file isdn_msg_parser.c.

References isdn_msg_get_index_by_event(), and isdn_msg::msg_builder.

Referenced by misdn_lib_send_event().

01343 {
01344    int i=isdn_msg_get_index_by_event(msgs, event, nt);
01345    if(i<0) return NULL;
01346   
01347    return  msgs[i].msg_builder(msgs, bc, nt);
01348 }

enum event_e isdn_msg_get_event ( struct isdn_msg  msgs[],
msg_t *  msg,
int  nt 
)

Definition at line 1287 of file isdn_msg_parser.c.

References isdn_msg::event, EVENT_UNKNOWN, and isdn_msg_get_index().

Referenced by handle_event_nt(), and handle_frm().

01288 {
01289    int i=isdn_msg_get_index(msgs, msg, nt);
01290    if(i>=0) return msgs[i].event;
01291    return EVENT_UNKNOWN;
01292 }

int isdn_msg_get_index ( struct isdn_msg  msgs[],
msg_t *  msg,
int  nt 
)

INTERFACE FCTS

Definition at line 1255 of file isdn_msg_parser.c.

References isdn_msg::misdn_msg, and msgs_max.

Referenced by isdn_msg_get_event(), isdn_msg_get_info(), and isdn_msg_parse_event().

01256 {
01257    int i;
01258 
01259    if (nt){
01260       mISDNuser_head_t *hh = (mISDNuser_head_t*)msg->data;
01261       
01262       for (i=0; i< msgs_max -1; i++) {
01263          if ( (hh->prim&COMMAND_MASK)==(msgs[i].misdn_msg&COMMAND_MASK)) return i;
01264       }
01265       
01266    } else {
01267       iframe_t *frm = (iframe_t*)msg->data;
01268     
01269       for (i=0; i< msgs_max -1; i++) 
01270          if ( (frm->prim&COMMAND_MASK)==(msgs[i].misdn_msg&COMMAND_MASK)) return i;
01271    }
01272 
01273    return -1;
01274 }

int isdn_msg_get_index_by_event ( struct isdn_msg  msgs[],
enum event_e  event,
int  nt 
)

Definition at line 1276 of file isdn_msg_parser.c.

References cb_log, and msgs_max.

Referenced by isdn_get_info(), and isdn_msg_build_event().

01277 {
01278    int i;
01279    for (i=0; i< msgs_max; i++) 
01280       if ( event == msgs[i].event) return i;
01281 
01282    cb_log(10,0, "get_index: event not found!\n");
01283    
01284    return -1;
01285 }

char* isdn_msg_get_info ( struct isdn_msg  msgs[],
msg_t *  msg,
int  nt 
)

Definition at line 1294 of file isdn_msg_parser.c.

References isdn_msg::info, and isdn_msg_get_index().

01295 {
01296    int i=isdn_msg_get_index(msgs, msg, nt);
01297    if(i>=0) return msgs[i].info;
01298    return NULL;
01299 }

int isdn_msg_parse_event ( struct isdn_msg  msgs[],
msg_t *  msg,
struct misdn_bchannel bc,
int  nt 
)

Definition at line 1333 of file isdn_msg_parser.c.

References isdn_msg_get_index(), and isdn_msg::msg_parser.

Referenced by handle_event_nt(), and handle_frm().

01334 {
01335    int i=isdn_msg_get_index(msgs, msg, nt);
01336    if(i<0) return -1;
01337 
01338    msgs[i].msg_parser(msgs, msg, bc, nt);
01339    return 0;
01340 }

static void parse_alerting ( struct isdn_msg  msgs[],
msg_t *  msg,
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 92 of file isdn_msg_parser.c.

References misdn_stack::bc, dec_ie_progress(), HEADER_LEN, mISDNUSER_HEAD_SIZE, misdn_bchannel::progress_coding, misdn_bchannel::progress_indicator, and misdn_bchannel::progress_location.

00093 {
00094    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN; 
00095    ALERTING_t *alerting=(ALERTING_t*)((unsigned long)(msg->data+HEADER_LEN));
00096    //Q931_info_t *qi=(Q931_info_t*)(msg->data+HEADER_LEN);
00097    
00098    dec_ie_progress(alerting->PROGRESS, (Q931_info_t *)alerting, &bc->progress_coding, &bc->progress_location, &bc->progress_indicator, nt, bc);
00099    
00100 #if DEBUG 
00101    printf("Parsing ALERTING Msg\n"); 
00102 #endif
00103 
00104  
00105 }

static void parse_connect ( struct isdn_msg  msgs[],
msg_t *  msg,
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 358 of file isdn_msg_parser.c.

References misdn_stack::bc, misdn_bchannel::cad, misdn_bchannel::ces, misdn_bchannel::cpnnumplan, dec_ie_connected_pn(), dec_ie_progress(), HEADER_LEN, mISDNUSER_HEAD_SIZE, misdn_bchannel::progress_coding, misdn_bchannel::progress_indicator, and misdn_bchannel::progress_location.

00359 {
00360    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
00361    CONNECT_t *connect=(CONNECT_t*)((unsigned long)(msg->data+HEADER_LEN));
00362   
00363    int plan,pres,screen;
00364    
00365    bc->ces = connect->ces;
00366    bc->ces = connect->ces;
00367 
00368    dec_ie_progress(connect->PROGRESS, (Q931_info_t *)connect, &bc->progress_coding, &bc->progress_location, &bc->progress_indicator, nt, bc);
00369 
00370    dec_ie_connected_pn(connect->CONNECT_PN,(Q931_info_t *)connect, &bc->cpnnumplan, &plan, &pres, &screen, bc->cad, 31, nt, bc);
00371 
00372    /*
00373       cb_log(1,bc->port,"CONNETED PN: %s cpn_dialplan:%d\n", connected_pn, type);
00374    */
00375    
00376 #if DEBUG 
00377    printf("Parsing CONNECT Msg\n"); 
00378 #endif
00379 }

static void parse_connect_acknowledge ( struct isdn_msg  msgs[],
msg_t *  msg,
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 448 of file isdn_msg_parser.c.

00449 {
00450 #if DEBUG 
00451    printf("Parsing CONNECT_ACKNOWLEDGE Msg\n"); 
00452 #endif
00453 
00454  
00455 }

static void parse_disconnect ( struct isdn_msg  msgs[],
msg_t *  msg,
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 773 of file isdn_msg_parser.c.

References misdn_stack::bc, misdn_bchannel::cause, dec_ie_cause(), dec_ie_progress(), HEADER_LEN, mISDNUSER_HEAD_SIZE, misdn_bchannel::progress_coding, misdn_bchannel::progress_indicator, and misdn_bchannel::progress_location.

00774 {
00775    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
00776    DISCONNECT_t *disconnect=(DISCONNECT_t*)((unsigned long)(msg->data+HEADER_LEN));
00777    int location;
00778    int cause; 
00779    dec_ie_cause(disconnect->CAUSE, (Q931_info_t *)(disconnect), &location, &cause, nt,bc);
00780    if (cause>0) bc->cause=cause;
00781 
00782    dec_ie_progress(disconnect->PROGRESS, (Q931_info_t *)disconnect, &bc->progress_coding, &bc->progress_location, &bc->progress_indicator, nt, bc);
00783 #if DEBUG 
00784    printf("Parsing DISCONNECT Msg\n"); 
00785 #endif
00786 
00787  
00788 }

static void parse_facility ( struct isdn_msg  msgs[],
msg_t *  msg,
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 951 of file isdn_msg_parser.c.

References misdn_stack::bc, cb_log, misdn_bchannel::fac_in, HEADER_LEN, mISDNUSER_HEAD_SIZE, misdn_bchannel::nt, and misdn_bchannel::port.

00952 {
00953    int HEADER_LEN = nt ? mISDNUSER_HEAD_SIZE : mISDN_HEADER_LEN;
00954    FACILITY_t *facility = (FACILITY_t*)(msg->data+HEADER_LEN); 
00955    Q931_info_t *qi = (Q931_info_t*)(msg->data+HEADER_LEN);  
00956    unsigned char *p = NULL;
00957    int err;
00958 
00959 #if DEBUG 
00960    printf("Parsing FACILITY Msg\n"); 
00961 #endif
00962 
00963    if (!bc->nt) {
00964       if (qi->QI_ELEMENT(facility))
00965          p = (unsigned char *)qi + sizeof(Q931_info_t) + qi->QI_ELEMENT(facility) + 1;
00966    } else {
00967       p = facility->FACILITY;
00968    }
00969    if (!p)
00970       return;
00971    
00972    err = decodeFac(p, &(bc->fac_in));
00973    if (err) {
00974       cb_log(1, bc->port, "Decoding FACILITY failed! (%d)\n", err);
00975    }
00976 }

static void parse_hold ( struct isdn_msg  msgs[],
msg_t *  msg,
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 542 of file isdn_msg_parser.c.

00543 {
00544 #if DEBUG 
00545    printf("Parsing HOLD Msg\n"); 
00546 #endif
00547 
00548  
00549 }

static void parse_hold_acknowledge ( struct isdn_msg  msgs[],
msg_t *  msg,
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 611 of file isdn_msg_parser.c.

00612 {
00613 #if DEBUG 
00614    printf("Parsing HOLD_ACKNOWLEDGE Msg\n"); 
00615 #endif
00616 
00617  
00618 }

static void parse_hold_reject ( struct isdn_msg  msgs[],
msg_t *  msg,
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 680 of file isdn_msg_parser.c.

00681 {
00682 #if DEBUG 
00683    printf("Parsing HOLD_REJECT Msg\n"); 
00684 #endif
00685 
00686  
00687 }

static void parse_information ( struct isdn_msg  msgs[],
msg_t *  msg,
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 1056 of file isdn_msg_parser.c.

References misdn_stack::bc, dec_ie_called_pn(), dec_ie_keypad(), HEADER_LEN, misdn_bchannel::info_dad, misdn_bchannel::keypad, mISDNUSER_HEAD_SIZE, and type.

01057 {
01058    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
01059    INFORMATION_t *information=(INFORMATION_t*)((unsigned long)(msg->data+HEADER_LEN));
01060    {
01061       int  type, plan;
01062       char number[32];
01063       char keypad[32];
01064       dec_ie_called_pn(information->CALLED_PN, (Q931_info_t *)information, &type, &plan, number, sizeof(number)-1, nt, bc);
01065       dec_ie_keypad(information->KEYPAD, (Q931_info_t *)information, keypad, sizeof(keypad)-1, nt, bc);
01066       strcpy(bc->info_dad, number);
01067       strcpy(bc->keypad,keypad);
01068    }
01069 #if DEBUG 
01070    printf("Parsing INFORMATION Msg\n"); 
01071 #endif
01072 }

static void parse_notify ( struct isdn_msg  msgs[],
msg_t *  msg,
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 1014 of file isdn_msg_parser.c.

01015 {
01016 #if DEBUG 
01017    printf("Parsing NOTIFY Msg\n"); 
01018 #endif
01019 }

static void parse_proceeding ( struct isdn_msg  msgs[],
msg_t *  msg,
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 51 of file isdn_msg_parser.c.

References misdn_stack::bc, dec_ie_channel_id(), dec_ie_progress(), HEADER_LEN, mISDNUSER_HEAD_SIZE, misdn_bchannel::progress_coding, misdn_bchannel::progress_indicator, misdn_bchannel::progress_location, and set_channel().

00052 {
00053    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
00054    CALL_PROCEEDING_t *proceeding=(CALL_PROCEEDING_t*)((unsigned long)msg->data+ HEADER_LEN);
00055    //struct misdn_stack *stack=get_stack_by_bc(bc);
00056    
00057    {
00058       int  exclusive, channel;
00059       dec_ie_channel_id(proceeding->CHANNEL_ID, (Q931_info_t *)proceeding, &exclusive, &channel, nt,bc);
00060 
00061       set_channel(bc,channel);
00062       
00063    }
00064    
00065    dec_ie_progress(proceeding->PROGRESS, (Q931_info_t *)proceeding, &bc->progress_coding, &bc->progress_location, &bc->progress_indicator, nt, bc);
00066    
00067    
00068 #if DEBUG 
00069    printf("Parsing PROCEEDING Msg\n"); 
00070 #endif
00071 }

static void parse_progress ( struct isdn_msg  msgs[],
msg_t *  msg,
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 126 of file isdn_msg_parser.c.

References misdn_stack::bc, dec_ie_progress(), HEADER_LEN, mISDNUSER_HEAD_SIZE, misdn_bchannel::progress_coding, misdn_bchannel::progress_indicator, and misdn_bchannel::progress_location.

00127 {
00128    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
00129    PROGRESS_t *progress=(PROGRESS_t*)((unsigned long)(msg->data+HEADER_LEN)); 
00130    //Q931_info_t *qi=(Q931_info_t*)(msg->data+HEADER_LEN);  
00131    
00132    dec_ie_progress(progress->PROGRESS, (Q931_info_t *)progress, &bc->progress_coding, &bc->progress_location, &bc->progress_indicator, nt, bc);
00133    
00134 #if DEBUG 
00135    printf("Parsing PROGRESS Msg\n"); 
00136 #endif
00137 }

static void parse_release ( struct isdn_msg  msgs[],
msg_t *  msg,
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 856 of file isdn_msg_parser.c.

References misdn_stack::bc, misdn_bchannel::cause, dec_ie_cause(), HEADER_LEN, and mISDNUSER_HEAD_SIZE.

00857 {
00858    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
00859    RELEASE_t *release=(RELEASE_t*)((unsigned long)(msg->data+HEADER_LEN));
00860    int location;
00861    int cause;
00862   
00863    dec_ie_cause(release->CAUSE, (Q931_info_t *)(release), &location, &cause, nt,bc);
00864    if (cause>0) bc->cause=cause;
00865 #if DEBUG 
00866    printf("Parsing RELEASE Msg\n"); 
00867 #endif
00868 
00869  
00870 }

static void parse_release_complete ( struct isdn_msg  msgs[],
msg_t *  msg,
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 895 of file isdn_msg_parser.c.

References misdn_stack::bc, misdn_bchannel::cause, cb_log, dec_ie_cause(), get_stack_by_bc(), HEADER_LEN, and mISDNUSER_HEAD_SIZE.

00896 {
00897    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
00898    RELEASE_COMPLETE_t *release_complete=(RELEASE_COMPLETE_t*)((unsigned long)(msg->data+HEADER_LEN));
00899    int location;
00900    int cause;
00901    iframe_t *frm = (iframe_t*) msg->data;
00902 
00903    struct misdn_stack *stack=get_stack_by_bc(bc);
00904    mISDNuser_head_t *hh;
00905    hh=(mISDNuser_head_t*)msg->data;
00906 
00907    /*hh=(mISDN_head_t*)msg->data;
00908    mISDN_head_t *hh;*/
00909 
00910    if (nt) {
00911       if (hh->prim == (CC_RELEASE_COMPLETE|CONFIRM)) {
00912          cb_log(0, stack->port, "CC_RELEASE_COMPLETE|CONFIRM [NT] \n");
00913          return;
00914       }
00915    } else {
00916       if (frm->prim == (CC_RELEASE_COMPLETE|CONFIRM)) {
00917          cb_log(0, stack->port, "CC_RELEASE_COMPLETE|CONFIRM [TE] \n");
00918          return;
00919       }
00920    }
00921    dec_ie_cause(release_complete->CAUSE, (Q931_info_t *)(release_complete), &location, &cause, nt,bc);
00922    if (cause>0) bc->cause=cause;
00923 
00924 #if DEBUG 
00925    printf("Parsing RELEASE_COMPLETE Msg\n"); 
00926 #endif
00927 }

static void parse_restart ( struct isdn_msg  msgs[],
msg_t *  msg,
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 813 of file isdn_msg_parser.c.

References misdn_stack::bc, cb_log, dec_ie_channel_id(), get_stack_by_bc(), HEADER_LEN, mISDNUSER_HEAD_SIZE, misdn_stack::port, and misdn_bchannel::restart_channel.

00814 {
00815    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
00816    RESTART_t *restart=(RESTART_t*)((unsigned long)(msg->data+HEADER_LEN));
00817 
00818    struct misdn_stack *stack=get_stack_by_bc(bc);
00819    
00820 #if DEBUG 
00821    printf("Parsing RESTART Msg\n");
00822 #endif
00823   
00824    {
00825       int  exclusive;
00826       dec_ie_channel_id(restart->CHANNEL_ID, (Q931_info_t *)restart, &exclusive, &bc->restart_channel, nt,bc);
00827       cb_log(3, stack->port, "CC_RESTART Request on channel:%d on this port.\n", bc->restart_channel);
00828    }
00829  
00830 }

static void parse_resume ( struct isdn_msg  msgs[],
msg_t *  msg,
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 588 of file isdn_msg_parser.c.

00589 {
00590 #if DEBUG 
00591    printf("Parsing RESUME Msg\n"); 
00592 #endif
00593 
00594  
00595 }

static void parse_resume_acknowledge ( struct isdn_msg  msgs[],
msg_t *  msg,
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 657 of file isdn_msg_parser.c.

00658 {
00659 #if DEBUG 
00660    printf("Parsing RESUME_ACKNOWLEDGE Msg\n"); 
00661 #endif
00662 
00663  
00664 }

static void parse_resume_reject ( struct isdn_msg  msgs[],
msg_t *  msg,
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 519 of file isdn_msg_parser.c.

00520 {
00521 #if DEBUG 
00522    printf("Parsing RESUME_REJECT Msg\n"); 
00523 #endif
00524 
00525  
00526 }

static void parse_retrieve ( struct isdn_msg  msgs[],
msg_t *  msg,
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 703 of file isdn_msg_parser.c.

00704 {
00705 #if DEBUG 
00706    printf("Parsing RETRIEVE Msg\n"); 
00707 #endif
00708 
00709  
00710 }

static void parse_retrieve_acknowledge ( struct isdn_msg  msgs[],
msg_t *  msg,
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 726 of file isdn_msg_parser.c.

00727 {
00728 #if DEBUG 
00729    printf("Parsing RETRIEVE_ACKNOWLEDGE Msg\n"); 
00730 #endif
00731 
00732  
00733 }

static void parse_retrieve_reject ( struct isdn_msg  msgs[],
msg_t *  msg,
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 750 of file isdn_msg_parser.c.

00751 {
00752 #if DEBUG 
00753    printf("Parsing RETRIEVE_REJECT Msg\n"); 
00754 #endif
00755 
00756  
00757 }

static void parse_setup ( struct isdn_msg  msgs[],
msg_t *  msg,
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 153 of file isdn_msg_parser.c.

References misdn_stack::bc, misdn_bchannel::capability, capability, cb_log, misdn_bchannel::dad, dec_ie_bearer(), dec_ie_called_pn(), dec_ie_calling_pn(), dec_ie_channel_id(), dec_ie_complete(), dec_ie_keypad(), dec_ie_progress(), dec_ie_redir_nr(), dec_ie_useruser(), misdn_bchannel::dnumplan, HEADER_LEN, INFO_CAPABILITY_DIGITAL_RESTRICTED, INFO_CAPABILITY_DIGITAL_UNRESTRICTED, INFO_CAPABILITY_SPEECH, INFO_CAPABILITY_VIDEO, INFO_CODEC_ALAW, INFO_CODEC_ULAW, misdn_bchannel::keypad, misdn_bchannel::law, mISDNUSER_HEAD_SIZE, misdn_bchannel::mode, misdn_bchannel::oad, misdn_bchannel::onumplan, misdn_bchannel::port, misdn_bchannel::pres, misdn_bchannel::progress_coding, misdn_bchannel::progress_indicator, misdn_bchannel::progress_location, misdn_bchannel::rad, misdn_bchannel::rate, misdn_bchannel::rnumplan, misdn_bchannel::sending_complete, set_channel(), type, misdn_bchannel::urate, misdn_bchannel::user1, misdn_bchannel::uu, and misdn_bchannel::uulen.

00154 { 
00155    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
00156    SETUP_t *setup= (SETUP_t*)((unsigned long)msg->data+HEADER_LEN);
00157    Q931_info_t *qi=(Q931_info_t*)((unsigned long)msg->data+HEADER_LEN);
00158 
00159 #if DEBUG 
00160    printf("Parsing SETUP Msg\n"); 
00161 #endif
00162    {
00163       int type,plan,present, screen;
00164       char id[32];
00165       dec_ie_calling_pn(setup->CALLING_PN, qi, &type, &plan, &present, &screen, id, sizeof(id)-1, nt,bc);
00166 
00167       bc->onumplan=type; 
00168       strcpy(bc->oad, id);
00169       switch (present) {
00170       case 0:
00171          bc->pres=0; /* screened */
00172          break;
00173       case 1:
00174          bc->pres=1; /* not screened */
00175          break;
00176       default:
00177          bc->pres=0;
00178       }
00179       switch (screen) {
00180       case 0:
00181          break;
00182       default:
00183          ;
00184       } 
00185    }
00186    {
00187       int  type, plan;
00188       char number[32]; 
00189       dec_ie_called_pn(setup->CALLED_PN, (Q931_info_t *)setup, &type, &plan, number, sizeof(number)-1, nt,bc);
00190       strcpy(bc->dad, number);
00191       bc->dnumplan=type; 
00192    }
00193    {
00194       char keypad[32];
00195       dec_ie_keypad(setup->KEYPAD, (Q931_info_t *)setup, keypad, sizeof(keypad)-1, nt,bc);
00196       strcpy(bc->keypad, keypad);
00197    }
00198 
00199    {
00200       dec_ie_complete(setup->COMPLETE, (Q931_info_t *)setup, &bc->sending_complete, nt,bc);
00201       
00202    }
00203   
00204    {
00205       int  type, plan, present, screen, reason;
00206       char id[32]; 
00207       dec_ie_redir_nr(setup->REDIR_NR, (Q931_info_t *)setup, &type, &plan, &present, &screen, &reason, id, sizeof(id)-1, nt,bc);
00208     
00209       strcpy(bc->rad, id);
00210       bc->rnumplan=type; 
00211    }
00212    {
00213       int  coding, capability, mode, rate, multi, user, async, urate, stopbits, dbits, parity;
00214       dec_ie_bearer(setup->BEARER, (Q931_info_t *)setup, &coding, &capability, &mode, &rate, &multi, &user, &async, &urate, &stopbits, &dbits, &parity, nt,bc);
00215       switch (capability) {
00216       case -1: bc->capability=INFO_CAPABILITY_DIGITAL_UNRESTRICTED; 
00217          break;
00218       case 0: bc->capability=INFO_CAPABILITY_SPEECH;
00219          break;
00220       case 18: bc->capability=INFO_CAPABILITY_VIDEO;
00221          break;
00222       case 8: bc->capability=INFO_CAPABILITY_DIGITAL_UNRESTRICTED;
00223          bc->user1 = user;
00224          bc->urate = urate;
00225          
00226          bc->rate = rate;
00227          bc->mode = mode;
00228          break;
00229       case 9: bc->capability=INFO_CAPABILITY_DIGITAL_RESTRICTED;
00230          break;
00231       default:
00232          break;
00233       }
00234       
00235       switch(user) {
00236       case 2:
00237          bc->law=INFO_CODEC_ULAW;
00238          break;
00239       case 3:
00240          bc->law=INFO_CODEC_ALAW;
00241          break;
00242       default:
00243          bc->law=INFO_CODEC_ALAW;
00244          
00245       }
00246       
00247       bc->capability=capability; 
00248    }
00249    {
00250       int  exclusive, channel;
00251       dec_ie_channel_id(setup->CHANNEL_ID, (Q931_info_t *)setup, &exclusive, &channel, nt,bc);
00252       
00253       set_channel(bc,channel);
00254    }
00255 
00256    {
00257       int  protocol ;
00258       dec_ie_useruser(setup->USER_USER, (Q931_info_t *)setup, &protocol, bc->uu, &bc->uulen, nt,bc);
00259       if (bc->uulen) cb_log(1,bc->port,"USERUESRINFO:%s\n",bc->uu);
00260       else
00261       cb_log(1,bc->port,"NO USERUESRINFO\n");
00262    }
00263    
00264    dec_ie_progress(setup->PROGRESS, (Q931_info_t *)setup, &bc->progress_coding, &bc->progress_location, &bc->progress_indicator, nt, bc);
00265    
00266 }

static void parse_setup_acknowledge ( struct isdn_msg  msgs[],
msg_t *  msg,
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 408 of file isdn_msg_parser.c.

References misdn_stack::bc, dec_ie_channel_id(), dec_ie_progress(), HEADER_LEN, mISDNUSER_HEAD_SIZE, misdn_bchannel::progress_coding, misdn_bchannel::progress_indicator, misdn_bchannel::progress_location, and set_channel().

00409 {
00410    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
00411    SETUP_ACKNOWLEDGE_t *setup_acknowledge=(SETUP_ACKNOWLEDGE_t*)((unsigned long)(msg->data+HEADER_LEN));
00412 
00413    {
00414       int  exclusive, channel;
00415       dec_ie_channel_id(setup_acknowledge->CHANNEL_ID, (Q931_info_t *)setup_acknowledge, &exclusive, &channel, nt,bc);
00416 
00417 
00418       set_channel(bc, channel);
00419    }
00420    
00421    dec_ie_progress(setup_acknowledge->PROGRESS, (Q931_info_t *)setup_acknowledge, &bc->progress_coding, &bc->progress_location, &bc->progress_indicator, nt, bc);
00422 #if DEBUG 
00423    printf("Parsing SETUP_ACKNOWLEDGE Msg\n"); 
00424 #endif
00425 
00426  
00427 }

static void parse_status ( struct isdn_msg  msgs[],
msg_t *  msg,
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 1099 of file isdn_msg_parser.c.

References misdn_stack::bc, misdn_bchannel::cause, dec_ie_cause(), HEADER_LEN, and mISDNUSER_HEAD_SIZE.

01100 {
01101    int HEADER_LEN = nt?mISDNUSER_HEAD_SIZE:mISDN_HEADER_LEN;
01102    STATUS_t *status=(STATUS_t*)((unsigned long)(msg->data+HEADER_LEN));
01103    int location;
01104    int cause;
01105   
01106    dec_ie_cause(status->CAUSE, (Q931_info_t *)(status), &location, &cause, nt,bc);
01107    if (cause>0) bc->cause=cause;
01108    ;
01109 
01110 #if DEBUG 
01111    printf("Parsing STATUS Msg\n"); 
01112 #endif
01113 }

static void parse_status_enquiry ( struct isdn_msg  msgs[],
msg_t *  msg,
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 1035 of file isdn_msg_parser.c.

01036 {
01037 #if DEBUG 
01038    printf("Parsing STATUS_ENQUIRY Msg\n"); 
01039 #endif
01040 }

static void parse_suspend ( struct isdn_msg  msgs[],
msg_t *  msg,
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 565 of file isdn_msg_parser.c.

00566 {
00567 #if DEBUG 
00568    printf("Parsing SUSPEND Msg\n"); 
00569 #endif
00570 
00571  
00572 }

static void parse_suspend_acknowledge ( struct isdn_msg  msgs[],
msg_t *  msg,
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 634 of file isdn_msg_parser.c.

00635 {
00636 #if DEBUG 
00637    printf("Parsing SUSPEND_ACKNOWLEDGE Msg\n"); 
00638 #endif
00639 
00640  
00641 }

static void parse_suspend_reject ( struct isdn_msg  msgs[],
msg_t *  msg,
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 496 of file isdn_msg_parser.c.

00497 {
00498 #if DEBUG 
00499    printf("Parsing SUSPEND_REJECT Msg\n"); 
00500 #endif
00501 
00502  
00503 }

static void parse_timeout ( struct isdn_msg  msgs[],
msg_t *  msg,
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 1129 of file isdn_msg_parser.c.

01130 {
01131 #if DEBUG 
01132    printf("Parsing STATUS Msg\n"); 
01133 #endif 
01134 }

static void parse_user_information ( struct isdn_msg  msgs[],
msg_t *  msg,
struct misdn_bchannel bc,
int  nt 
) [static]

Definition at line 473 of file isdn_msg_parser.c.

00474 {
00475 #if DEBUG 
00476    printf("Parsing USER_INFORMATION Msg\n"); 
00477 #endif
00478 
00479  
00480 }

static void set_channel ( struct misdn_bchannel bc,
int  channel 
) [static]

Definition at line 23 of file isdn_msg_parser.c.

References misdn_stack::bc, cb_event, cb_log, misdn_bchannel::channel, EVENT_NEW_CHANNEL, misdn_bchannel::nt, and misdn_bchannel::port.

Referenced by parse_proceeding(), parse_setup(), and parse_setup_acknowledge().

00024 {
00025 
00026    cb_log(3,bc->port,"set_channel: bc->channel:%d channel:%d\n", bc->channel, channel);
00027    
00028    
00029    if (channel==0xff) {
00030       /* any channel */
00031       channel=-1;
00032    }
00033    
00034    /*  ALERT: is that everytime true ?  */
00035    if (channel > 0 && bc->nt ) {
00036       
00037       if (bc->channel && ( bc->channel != 0xff) ) {
00038          cb_log(0,bc->port,"We already have a channel (%d)\n", bc->channel);
00039       } else {
00040          bc->channel = channel;
00041          cb_event(EVENT_NEW_CHANNEL,bc,NULL);
00042       }
00043    }
00044    
00045    if (channel > 0 && !bc->nt ) {
00046       bc->channel = channel;
00047       cb_event(EVENT_NEW_CHANNEL,bc,NULL);
00048    }
00049 }


Variable Documentation

char EVENT_BCHAN_ACTIVATED_INFO[] = "BCHAN_ACTIVATED"

Definition at line 1309 of file isdn_msg_parser.c.

Referenced by isdn_get_info().

char EVENT_BCHAN_DATA_INFO[] = "BCHAN_DATA"

Definition at line 1308 of file isdn_msg_parser.c.

Referenced by isdn_get_info().

char EVENT_BCHAN_ERROR_INFO[] = "BCHAN_ERROR"

Definition at line 1311 of file isdn_msg_parser.c.

Referenced by isdn_get_info().

char EVENT_CLEAN_INFO[] = "CLEAN_UP"

Definition at line 1302 of file isdn_msg_parser.c.

Referenced by isdn_get_info().

char EVENT_DTMF_TONE_INFO[] = "DTMF_TONE"

Definition at line 1303 of file isdn_msg_parser.c.

Referenced by isdn_get_info().

char EVENT_NEW_BC_INFO[] = "NEW_BC"

Definition at line 1305 of file isdn_msg_parser.c.

Referenced by isdn_get_info().

char EVENT_NEW_CHANNEL_INFO[] = "NEW_CHANNEL"

Definition at line 1307 of file isdn_msg_parser.c.

Referenced by isdn_get_info().

char EVENT_NEW_L3ID_INFO[] = "NEW_L3ID"

Definition at line 1304 of file isdn_msg_parser.c.

Referenced by isdn_get_info().

char EVENT_PORT_ALARM_INFO[] = "ALARM"

Definition at line 1306 of file isdn_msg_parser.c.

Referenced by isdn_get_info().

char EVENT_TONE_GENERATE_INFO[] = "TONE_GENERATE"

Definition at line 1310 of file isdn_msg_parser.c.

Referenced by isdn_get_info().

struct isdn_msg msgs_g[]

Msg Array

Definition at line 1158 of file isdn_msg_parser.c.

Referenced by handle_event_nt(), handle_frm(), handle_l1(), manager_isdn_get_info(), and misdn_lib_send_event().


Generated on Sat Aug 6 00:39:58 2011 for Asterisk - the Open Source PBX by  doxygen 1.4.7