]> git.ipfire.org Git - thirdparty/freeswitch.git/commitdiff
chlog: freetdm: SS7 - added TX of CPG message in progress media state
authorDavid Yat Sin <dyatsin@sangoma.com>
Mon, 8 Aug 2011 16:35:41 +0000 (12:35 -0400)
committeryannick <yannick@sangoma.com>
Mon, 8 Aug 2011 17:23:30 +0000 (13:23 -0400)
libs/freetdm/src/ftmod/ftmod_sangoma_ss7/ftmod_sangoma_ss7_main.c
libs/freetdm/src/ftmod/ftmod_sangoma_ss7/ftmod_sangoma_ss7_main.h
libs/freetdm/src/ftmod/ftmod_sangoma_ss7/ftmod_sangoma_ss7_out.c

index 6601c2e91a693ad2535ffd6ac4abe68e79124985..34f1211234f3664165ffcfdb694b854f6d099937 100644 (file)
@@ -656,10 +656,10 @@ ftdm_status_t ftdm_sangoma_ss7_process_state_change (ftdm_channel_t * ftdmchan)
                if (ftdm_test_flag (ftdmchan, FTDM_CHANNEL_OUTBOUND)) {
                        /* inform the user there is media avai */
                        sngss7_send_signal(sngss7_info, FTDM_SIGEVENT_PROGRESS_MEDIA);
+               } else {
+                       ft_to_sngss7_cpg(ftdmchan);
                }
-                       
 
-               /* nothing to do at this time */
                break;
        /**************************************************************************/
        case FTDM_CHANNEL_STATE_UP:     /*call is accpeted...both incoming and outgoing */
index b433bfb20dea4382d1d9cf47e4fea430eaa82a2e..159a02fc01b08bac3e5c14740f05fe1e2dcc6ecc 100644 (file)
@@ -739,6 +739,7 @@ int ftmod_ss7_isup_ckt_sta(uint32_t id, unsigned char *state);
 /* in ftmod_sangoma_ss7_out.c */
 void ft_to_sngss7_iam(ftdm_channel_t *ftdmchan);
 void ft_to_sngss7_acm(ftdm_channel_t *ftdmchan);
+void ft_to_sngss7_cpg (ftdm_channel_t *ftdmchan);
 void ft_to_sngss7_anm(ftdm_channel_t *ftdmchan);
 void ft_to_sngss7_rel(ftdm_channel_t *ftdmchan);
 void ft_to_sngss7_rlc(ftdm_channel_t *ftdmchan);
index 56238abdf9d3a9e57811ced2fda1c6ad311539d7..11ac14891d35e4d3be5c3c0d708f15389b25e83e 100644 (file)
@@ -36,6 +36,8 @@
 /******************************************************************************/
 
 /* DEFINES ********************************************************************/
+#define SNGSS7_EVNTINFO_IND_INBAND_AVAIL 0x03
+/******************************************************************************/
 
 /* GLOBALS ********************************************************************/
 
@@ -171,6 +173,7 @@ void ft_to_sngss7_acm (ftdm_channel_t * ftdmchan)
                acm.optBckCalInd.simpleSegmInd.pres             = PRSNT_DEF;
                acm.optBckCalInd.mlppUserInd.pres               = PRSNT_DEF;
                acm.optBckCalInd.usrNetIneractInd.pres  = PRSNT_DEF;
+               acm.optBckCalInd.netExcDelInd.pres              = PRSNT_DEF;
        } /* if (sngss7_test_options(isup_intf, SNGSS7_ACM_OBCI_BITA)) */
 
        /* send the ACM request to LibSngSS7 */
@@ -187,6 +190,32 @@ void ft_to_sngss7_acm (ftdm_channel_t * ftdmchan)
        return;
 }
 
+void ft_to_sngss7_cpg (ftdm_channel_t *ftdmchan)
+{
+       SiCnStEvnt cpg;
+       SS7_FUNC_TRACE_ENTER (__FUNCTION__);
+       
+       sngss7_chan_data_t *sngss7_info = ftdmchan->call_data;
+       
+
+       memset (&cpg, 0, sizeof (cpg));
+
+       cpg.evntInfo.eh.pres = PRSNT_NODEF;
+
+       cpg.evntInfo.evntInd.pres = PRSNT_NODEF;
+       cpg.evntInfo.evntInd.val = SNGSS7_EVNTINFO_IND_INBAND_AVAIL; /* Event Indicator = In-band info is now available */
+       
+       cpg.evntInfo.evntPresResInd.pres = PRSNT_NODEF;
+       cpg.evntInfo.evntPresResInd.val = 0;    /* Event presentation restricted indicator = no indication */
+       
+       /* send the CPG request to LibSngSS7 */
+       sng_cc_con_status  (1, sngss7_info->suInstId, sngss7_info->spInstId, sngss7_info->circuit->id, &cpg, PROGRESS);
+
+       ftdm_log_chan(ftdmchan, FTDM_LOG_INFO, "[CIC:%d]Tx CPG\n", sngss7_info->circuit->cic);
+       ftdm_call_clear_vars(&ftdmchan->caller_data);
+       SS7_FUNC_TRACE_EXIT (__FUNCTION__);
+       return;
+}
 void ft_to_sngss7_anm (ftdm_channel_t * ftdmchan)
 {
        SS7_FUNC_TRACE_ENTER (__FUNCTION__);