[Freeswitch-svn] [commit] r4232 - freeswitch/trunk/src

Freeswitch SVN anthm at freeswitch.org
Tue Feb 13 12:13:57 EST 2007


Author: anthm
Date: Tue Feb 13 12:13:57 2007
New Revision: 4232

Modified:
   freeswitch/trunk/src/switch_rtp.c

Log:
2833 bs

Modified: freeswitch/trunk/src/switch_rtp.c
==============================================================================
--- freeswitch/trunk/src/switch_rtp.c	(original)
+++ freeswitch/trunk/src/switch_rtp.c	Tue Feb 13 12:13:57 2007
@@ -107,6 +107,7 @@
 	unsigned int out_digit_sofar;
 	unsigned int out_digit_dur;
 	uint16_t out_digit_seq;
+	uint32_t out_digit_ssrc;
 	int32_t timestamp_dtmf;
 	char last_digit;
 	unsigned int dc;
@@ -137,6 +138,7 @@
 	uint32_t ts;
 	uint32_t last_write_ts;
 	uint16_t last_write_seq;
+	uint16_t last_write_ssrc;
 	uint32_t flags;
 	switch_memory_pool_t *pool;
 	switch_sockaddr_t *from_addr;
@@ -656,8 +658,14 @@
 
 		for (x = 0; x < loops; x++) {
 			switch_rtp_write_manual(rtp_session, 
-									rtp_session->dtmf_data.out_digit_packet, 4, 0, rtp_session->te, rtp_session->dtmf_data.timestamp_dtmf,
-									rtp_session->dtmf_data.out_digit_seq, &flags);
+									rtp_session->dtmf_data.out_digit_packet,
+									4,
+									0,
+									rtp_session->te,
+									rtp_session->dtmf_data.timestamp_dtmf,
+									rtp_session->dtmf_data.out_digit_seq,
+									rtp_session->dtmf_data.out_digit_ssrc,
+									&flags);
 			switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "Send %s packet for [%c] ts=%d sofar=%u dur=%d seq=%d\n", 
 							  loops == 1 ? "middle" : "end",
 							  rtp_session->dtmf_data.out_digit,
@@ -689,6 +697,7 @@
 
 			rtp_session->dtmf_data.timestamp_dtmf = rtp_session->last_write_ts;
 			rtp_session->dtmf_data.out_digit_seq = rtp_session->last_write_seq;
+			rtp_session->dtmf_data.out_digit_ssrc = rtp_session->last_write_ssrc;
 			
 
 			for (x = 0; x < 3; x++) {
@@ -699,6 +708,7 @@
 										rtp_session->te,
 										rtp_session->dtmf_data.timestamp_dtmf,
 										rtp_session->dtmf_data.out_digit_seq,
+										rtp_session->dtmf_data.out_digit_ssrc,
 										&flags);
 				switch_log_printf(SWITCH_CHANNEL_LOG,
 								  SWITCH_LOG_DEBUG,
@@ -1048,10 +1058,11 @@
 static int rtp_common_write(switch_rtp_t *rtp_session, void *data, uint32_t datalen, uint8_t m, switch_payload_t payload, switch_frame_flag_t *flags)
 {
 	switch_size_t bytes;
-	uint8_t fwd = (switch_test_flag(rtp_session, SWITCH_RTP_FLAG_RAW_WRITE) && (*flags & SFF_RAW_RTP)) ? 1 : 0;
+	uint8_t fwd = (!flags || (switch_test_flag(rtp_session, SWITCH_RTP_FLAG_RAW_WRITE) && (*flags & SFF_RAW_RTP)));
 	rtp_msg_t *send_msg;
 	uint8_t send = 1;
 
+	assert(fwd);
 	if (fwd) {
 		bytes = datalen;
 		send_msg = (rtp_msg_t *) data;
@@ -1060,7 +1071,6 @@
 		send_msg->header.pt = payload;
 		send_msg->header.m = m ? 1 : 0;
         memcpy(send_msg->body, data, datalen);
-
 		bytes = datalen + rtp_header_len;	
 	}
 
@@ -1194,6 +1204,7 @@
 	}
 
 	rtp_session->last_write_ts = ntohl(send_msg->header.ts);
+	rtp_session->last_write_ssrc = ntohl(send_msg->header.ssrc);
 	rtp_session->last_write_seq = ntohs((u_short)send_msg->header.seq);
 
 	if (send) {
@@ -1305,17 +1316,32 @@
 
 }
 
-SWITCH_DECLARE(int) switch_rtp_write_manual(switch_rtp_t *rtp_session, void *data, uint16_t datalen, uint8_t m, switch_payload_t payload, uint32_t ts, uint16_t mseq, switch_frame_flag_t *flags)
+SWITCH_DECLARE(int) switch_rtp_write_manual(switch_rtp_t *rtp_session,
+											void *data,
+											uint16_t datalen,
+											uint8_t m,
+											switch_payload_t payload,
+											uint32_t ts,
+											uint16_t mseq,
+											uint32_t ssrc,
+											switch_frame_flag_t *flags)
 {
+	rtp_msg_t send_msg = {{0}};
 
 	if (!switch_test_flag(rtp_session, SWITCH_RTP_FLAG_IO) || !rtp_session->remote_addr) {
 		return -1;
 	}
 
-	rtp_session->send_msg.header.seq = htons(mseq);
-	rtp_session->send_msg.header.ts = htonl(ts);
+	send_msg = rtp_session->send_msg;
+
+	send_msg.header.seq = htons(mseq);
+	send_msg.header.ts = htonl(ts);
+	send_msg.header.ssrc = htonl(ssrc);
+	send_msg.header.pt = payload;
+	send_msg.header.m = m ? 1 : 0;
+	memcpy(send_msg.body, data, datalen);
 
-	return rtp_common_write(rtp_session, data, datalen, m, payload, flags);
+	return rtp_common_write(rtp_session, (void *) &send_msg, rtp_header_len + datalen, m, payload, NULL);
 }
 
 SWITCH_DECLARE(uint32_t) switch_rtp_get_ssrc(switch_rtp_t *rtp_session)



More information about the Freeswitch-svn mailing list