From 219acbcc0765fb934a3dbfcb4723d62849c2d34a Mon Sep 17 00:00:00 2001
From: Mark Spencer <markster@digium.com>
Date: Mon, 1 Nov 2004 02:01:37 +0000
Subject: [PATCH] Accept %d/%d in m= line of SDP (bug #2625, but not their
 patch)

git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@4138 65c4cc65-6c06-0410-ace0-fbb531ad65f3
---
 channels/chan_sip.c | 5 +++--
 1 file changed, 3 insertions(+), 2 deletions(-)

diff --git a/channels/chan_sip.c b/channels/chan_sip.c
index b385aa2a71..71e29c42d7 100755
--- a/channels/chan_sip.c
+++ b/channels/chan_sip.c
@@ -2607,7 +2607,7 @@ static int process_sdp(struct sip_pvt *p, struct sip_request *req)
 	int codec;
 	int iterator;
 	int sendonly = 0;
-	int x;
+	int x,y;
 	int debug=sip_debug_test_pvt(p);
 
 	/* Update our last rtprx when we receive an SDP, too */
@@ -2637,7 +2637,8 @@ static int process_sdp(struct sip_pvt *p, struct sip_request *req)
 	sdpLineNum_iterator_init(&iterator);
 	p->novideo = 1;
 	while ((m = get_sdp_iterate(&iterator, req, "m"))[0] != '\0') {
-		if ((sscanf(m, "audio %d RTP/AVP %n", &x, &len) == 1)) {
+		if ((sscanf(m, "audio %d RTP/AVP %n", &x, &len) == 1) ||
+		    (sscanf(m, "audio %d/%d RTP/AVP %n", &x, &y, &len) == 1)) {
 			portno = x;
 			/* Scan through the RTP payload types specified in a "m=" line: */
 			ast_rtp_pt_clear(p->rtp);
-- 
GitLab