freetdm: ss7 - updated to allow TMR/bearer cap pass-through

This commit is contained in:
Konrad Hammel 2010-09-01 12:44:28 -04:00 committed by David Yat Sin
parent e3b9db8894
commit e15d52bd80
2 changed files with 117 additions and 91 deletions

View File

@ -41,7 +41,6 @@
/* GLOBALS ********************************************************************/ /* GLOBALS ********************************************************************/
/******************************************************************************/ /******************************************************************************/
/* PROTOTYPES *****************************************************************/
/* PROTOTYPES *****************************************************************/ /* PROTOTYPES *****************************************************************/
ftdm_status_t handle_con_ind(uint32_t suInstId, uint32_t spInstId, uint32_t circuit, SiConEvnt *siConEvnt); ftdm_status_t handle_con_ind(uint32_t suInstId, uint32_t spInstId, uint32_t circuit, SiConEvnt *siConEvnt);
ftdm_status_t handle_con_sta(uint32_t suInstId, uint32_t spInstId, uint32_t circuit, SiCnStEvnt *siCnStEvnt, uint8_t evntType); ftdm_status_t handle_con_sta(uint32_t suInstId, uint32_t spInstId, uint32_t circuit, SiCnStEvnt *siCnStEvnt, uint8_t evntType);
@ -140,43 +139,68 @@ ftdm_status_t handle_con_ind(uint32_t suInstId, uint32_t spInstId, uint32_t circ
} else { } else {
/* fill in cid/ani number */ /* fill in calling party information */
if (siConEvnt->cgPtyNum.addrSig.pres) { if (siConEvnt->cgPtyNum.eh.pres) {
copy_tknStr_from_sngss7(siConEvnt->cgPtyNum.addrSig, if (siConEvnt->cgPtyNum.addrSig.pres) {
ftdmchan->caller_data.cid_num.digits, /* fill in cid_num */
siConEvnt->cgPtyNum.oddEven); copy_tknStr_from_sngss7(siConEvnt->cgPtyNum.addrSig,
ftdmchan->caller_data.cid_num.digits,
siConEvnt->cgPtyNum.oddEven);
/* fill in cid Name */ /* fill in cid Name */
ftdm_set_string(ftdmchan->caller_data.cid_name, ftdmchan->caller_data.cid_num.digits); ftdm_set_string(ftdmchan->caller_data.cid_name, ftdmchan->caller_data.cid_num.digits);
ftdm_set_string(ftdmchan->caller_data.ani.digits, ftdmchan->caller_data.cid_num.digits); /* fill in ANI */
ftdm_set_string(ftdmchan->caller_data.ani.digits, ftdmchan->caller_data.cid_num.digits);
}
if (siConEvnt->cgPtyNum.scrnInd.pres) {
/* fill in the screening indication value */
ftdmchan->caller_data.screen = siConEvnt->cgPtyNum.scrnInd.val;
}
if (siConEvnt->cgPtyNum.presRest.pres) {
/* fill in the presentation value */
ftdmchan->caller_data.pres = siConEvnt->cgPtyNum.presRest.val;
}
} else { } else {
SS7_INFO("No Calling party (ANI) information in IAM!\n"); SS7_INFO_CHAN(ftdmchan,"No Calling party (ANI) information in IAM!%s\n", " ");
} }
/* fill in dnis */ /* fill in called party infomation */
if (siConEvnt->cdPtyNum.addrSig.pres) { if (siConEvnt->cdPtyNum.eh.pres) {
copy_tknStr_from_sngss7(siConEvnt->cdPtyNum.addrSig, if (siConEvnt->cdPtyNum.addrSig.pres) {
ftdmchan->caller_data.dnis.digits, /* fill in the called number/dnis */
siConEvnt->cdPtyNum.oddEven); copy_tknStr_from_sngss7(siConEvnt->cdPtyNum.addrSig,
ftdmchan->caller_data.dnis.digits,
siConEvnt->cdPtyNum.oddEven);
}
} else {
SS7_INFO_CHAN(ftdmchan,"No Called party (DNIS) information in IAM!%s\n", " ");
}
/* fill in rdnis information*/
if (siConEvnt->redirgNum.eh.pres) {
if (siConEvnt->redirgNum.addrSig.pres) {
/* fill in the rdnis digits */
copy_tknStr_from_sngss7(siConEvnt->redirgNum.addrSig,
ftdmchan->caller_data.rdnis.digits,
siConEvnt->cgPtyNum.oddEven);
}
} else { } else {
SS7_INFO("No Called party (DNIS) information in IAM!\n"); SS7_DEBUG_CHAN(ftdmchan,"No RDNIS party information in IAM!%s\n", " ");
} }
/* fill in rdnis */ /* fill in the TMR/bearer capability */
if (siConEvnt->redirgNum.addrSig.pres) { if (siConEvnt->txMedReq.eh.pres) {
copy_tknStr_from_sngss7(siConEvnt->redirgNum.addrSig, if (siConEvnt->txMedReq.trMedReq.pres) {
ftdmchan->caller_data.rdnis.digits, /* fill in the bearer type */
siConEvnt->cgPtyNum.oddEven); ftdmchan->caller_data.bearer_capability = siConEvnt->txMedReq.trMedReq.val;
} else { }
SS7_INFO("No RDNIS party information in IAM!\n"); } else {
SS7_DEBUG_CHAN(ftdmchan,"No TMR/Bearer Cap information in IAM!%s\n", " ");
} }
/* fill in screening/presentation */
ftdmchan->caller_data.screen = siConEvnt->cgPtyNum.scrnInd.val;
ftdmchan->caller_data.pres = siConEvnt->cgPtyNum.presRest.val;
/* set the state of the channel to collecting...the rest is done by the chan monitor */ /* set the state of the channel to collecting...the rest is done by the chan monitor */
ftdm_set_state_locked(ftdmchan, FTDM_CHANNEL_STATE_COLLECT); ftdm_set_state_locked(ftdmchan, FTDM_CHANNEL_STATE_COLLECT);

View File

@ -64,70 +64,72 @@ void ft_to_sngss7_grs (ftdm_channel_t * ftdmchan);
void void
ft_to_sngss7_iam (ftdm_channel_t * ftdmchan) ft_to_sngss7_iam (ftdm_channel_t * ftdmchan)
{ {
SS7_FUNC_TRACE_ENTER (__FUNCTION__); SS7_FUNC_TRACE_ENTER (__FUNCTION__);
sngss7_chan_data_t *sngss7_info = ftdmchan->call_data;; sngss7_chan_data_t *sngss7_info = ftdmchan->call_data;;
SiConEvnt iam; SiConEvnt iam;
sngss7_info->suInstId = get_unique_id (); sngss7_info->suInstId = get_unique_id ();
sngss7_info->spInstId = 0; sngss7_info->spInstId = 0;
sngss7_info->spId = 1; sngss7_info->spId = 1;
memset (&iam, 0x0, sizeof (iam)); memset (&iam, 0x0, sizeof (iam));
/* copy down the nature of connection indicators */ /* copy down the nature of connection indicators */
iam.natConInd.eh.pres = PRSNT_NODEF; iam.natConInd.eh.pres = PRSNT_NODEF;
iam.natConInd.satInd.pres = PRSNT_NODEF; iam.natConInd.satInd.pres = PRSNT_NODEF;
iam.natConInd.satInd.val = 0; iam.natConInd.satInd.val = 0; /* no satellite circuit */
iam.natConInd.contChkInd.pres = PRSNT_NODEF; iam.natConInd.contChkInd.pres = PRSNT_NODEF;
iam.natConInd.contChkInd.val = 0x00; iam.natConInd.contChkInd.val = CONTCHK_NOTREQ;
iam.natConInd.echoCntrlDevInd.pres = PRSNT_NODEF; iam.natConInd.echoCntrlDevInd.pres = PRSNT_NODEF;
iam.natConInd.echoCntrlDevInd.val = 0x01; iam.natConInd.echoCntrlDevInd.val = ECHOCDEV_INCL;
/* copy down the forward call indicators */ /* copy down the forward call indicators */
iam.fwdCallInd.eh.pres = PRSNT_NODEF; iam.fwdCallInd.eh.pres = PRSNT_NODEF;
iam.fwdCallInd.natIntCallInd.pres = PRSNT_NODEF; iam.fwdCallInd.natIntCallInd.pres = PRSNT_NODEF;
iam.fwdCallInd.natIntCallInd.val = 0x00; iam.fwdCallInd.natIntCallInd.val = 0x00;
iam.fwdCallInd.end2EndMethInd.pres = PRSNT_NODEF; iam.fwdCallInd.end2EndMethInd.pres = PRSNT_NODEF;
iam.fwdCallInd.end2EndMethInd.val = 0x00; iam.fwdCallInd.end2EndMethInd.val = E2EMTH_NOMETH;
iam.fwdCallInd.intInd.pres = PRSNT_NODEF; iam.fwdCallInd.intInd.pres = PRSNT_NODEF;
iam.fwdCallInd.intInd.val = 0x01; iam.fwdCallInd.intInd.val = INTIND_NOINTW;
iam.fwdCallInd.end2EndInfoInd.pres = PRSNT_NODEF; iam.fwdCallInd.end2EndInfoInd.pres = PRSNT_NODEF;
iam.fwdCallInd.end2EndInfoInd.val = 0x00; iam.fwdCallInd.end2EndInfoInd.val = E2EINF_NOINFO;
iam.fwdCallInd.isdnUsrPrtInd.pres = PRSNT_NODEF; iam.fwdCallInd.isdnUsrPrtInd.pres = PRSNT_NODEF;
iam.fwdCallInd.isdnUsrPrtInd.val = 0x01; iam.fwdCallInd.isdnUsrPrtInd.val = ISUP_USED;
iam.fwdCallInd.isdnUsrPrtPrfInd.pres = PRSNT_NODEF; iam.fwdCallInd.isdnUsrPrtPrfInd.pres = PRSNT_NODEF;
iam.fwdCallInd.isdnUsrPrtPrfInd.val = 0x02; iam.fwdCallInd.isdnUsrPrtPrfInd.val = PREF_REQAW;
iam.fwdCallInd.isdnAccInd.pres = PRSNT_NODEF; iam.fwdCallInd.isdnAccInd.pres = PRSNT_NODEF;
iam.fwdCallInd.isdnAccInd.val = 0x01; iam.fwdCallInd.isdnAccInd.val = ISDNACC_ISDN;
iam.fwdCallInd.sccpMethInd.pres = PRSNT_NODEF; iam.fwdCallInd.sccpMethInd.pres = PRSNT_NODEF;
iam.fwdCallInd.sccpMethInd.val = 0x00; iam.fwdCallInd.sccpMethInd.val = SCCPMTH_NOIND;
/* copy down the calling number information */ /* copy down the calling number information */
iam.cgPtyCat.eh.pres = PRSNT_NODEF; iam.cgPtyCat.eh.pres = PRSNT_NODEF;
iam.cgPtyCat.cgPtyCat.pres = PRSNT_NODEF; iam.cgPtyCat.cgPtyCat.pres = PRSNT_NODEF;
iam.cgPtyCat.cgPtyCat.val = 0x0a; iam.cgPtyCat.cgPtyCat.val = CAT_ORD; /* ordinary suscriber */
/* copy down the transmission medium requirements */ /* copy down the transmission medium requirements */
iam.txMedReq.eh.pres = PRSNT_NODEF; iam.txMedReq.eh.pres = PRSNT_NODEF;
iam.txMedReq.trMedReq.pres = PRSNT_NODEF; iam.txMedReq.trMedReq.pres = PRSNT_NODEF;
iam.txMedReq.trMedReq.val = 0; /* SPEECH = 0, 3.1Khz = 3, 64k unres = 2 */ iam.txMedReq.trMedReq.val = ftdmchan->caller_data.bearer_capability;
/* copy down the called number information */ /* copy down the called number information */
copy_cdPtyNum_to_sngss7 (&ftdmchan->caller_data, &iam.cdPtyNum); copy_cdPtyNum_to_sngss7 (&ftdmchan->caller_data, &iam.cdPtyNum);
/* copy down the calling number information */ /* copy down the calling number information */
copy_cgPtyNum_to_sngss7 (&ftdmchan->caller_data, &iam.cgPtyNum); copy_cgPtyNum_to_sngss7 (&ftdmchan->caller_data, &iam.cgPtyNum);
sng_cc_con_request (sngss7_info->spId, sng_cc_con_request (sngss7_info->spId,
sngss7_info->suInstId, sngss7_info->suInstId,
sngss7_info->spInstId, sngss7_info->spInstId,
sngss7_info->circuit->id, &iam, 0); sngss7_info->circuit->id,
&iam,
SS7_MSG_TRACE(ftdmchan, sngss7_info, "Tx IAM\n"); 0);
SS7_FUNC_TRACE_EXIT (__FUNCTION__); SS7_MSG_TRACE(ftdmchan, sngss7_info, "Tx IAM\n");
return;
SS7_FUNC_TRACE_EXIT (__FUNCTION__);
return;
} }
/******************************************************************************/ /******************************************************************************/