From a1bcfefbae97382ccc0bd1263143f48773ecc7b0 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 --- openbsc/src/libtrau/rtp_proxy.c | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/openbsc/src/libtrau/rtp_proxy.c b/openbsc/src/libtrau/rtp_proxy.c index 8f931cf24..fb8f04055 100644 --- a/openbsc/src/libtrau/rtp_proxy.c +++ b/openbsc/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