From 8c961ae80d0839ef0e462e7a274ec0c55a8221b2 Mon Sep 17 00:00:00 2001 From: Andreas Eversberg Date: Tue, 26 Mar 2013 08:21:46 +0100 Subject: Fixed AMR payload type selection and handling --- src/libtrau/rtp_proxy.c | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/src/libtrau/rtp_proxy.c b/src/libtrau/rtp_proxy.c index 8f931cf24..fb8f04055 100644 --- a/src/libtrau/rtp_proxy.c +++ b/src/libtrau/rtp_proxy.c @@ -177,6 +177,9 @@ static int rtp_decode(struct msgb *msg, uint32_t callref, struct msgb **data, in case RTP_PT_GSM_HALF: msg_type = GSM_TCHH_FRAME; break; + case RTP_PT_AMR: + msg_type = GSM_TCH_FRAME_AMR; + break; default: DEBUGPC(DLMUX, "received RTP frame with unknown " "payload type %d\n", rtph->payload_type); @@ -312,7 +315,7 @@ int rtp_send_frame(struct rtp_socket *rs, struct gsm_data_frame *frame) duration = 160; break; case GSM_TCH_FRAME_AMR: - if ((frame->data[1] & 0x04) != 0x04) + if ((frame->data[2] & 0x04) != 0x04) goto bfi; payload_type = (dynamic_pt) ? : RTP_PT_AMR; payload_len = frame->data[0]; -- cgit v1.2.3