projects
/
lcr.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
[SIP] Allow setting local port for SIP interface
[lcr.git]
/
gsm_bs.cpp
diff --git
a/gsm_bs.cpp
b/gsm_bs.cpp
index
92a2ffc
..
fc59125
100644
(file)
--- a/
gsm_bs.cpp
+++ b/
gsm_bs.cpp
@@
-296,6
+296,7
@@
void Pgsm_bs::select_payload_type(struct gsm_mncc *mncc, unsigned char *payload_
if ((mncc->fields & MNCC_F_BEARER_CAP)) {
/* select preferred payload type from list */
int i;
if ((mncc->fields & MNCC_F_BEARER_CAP)) {
/* select preferred payload type from list */
int i;
+ uint8_t dynamic_type = 96;
add_trace("bearer", "capa", "given by MS");
for (i = 0; mncc->bearer_cap.speech_ver[i] >= 0; i++) {
add_trace("bearer", "capa", "given by MS");
for (i = 0; mncc->bearer_cap.speech_ver[i] >= 0; i++) {
@@
-309,17
+310,22
@@
void Pgsm_bs::select_payload_type(struct gsm_mncc *mncc, unsigned char *payload_
case 2:
add_trace("speech", "version", "EFR given");
media_type = MEDIA_TYPE_GSM_EFR;
case 2:
add_trace("speech", "version", "EFR given");
media_type = MEDIA_TYPE_GSM_EFR;
- payload_type =
100 + *payloads
;
+ payload_type =
dynamic_type++
;
break;
case 4:
add_trace("speech", "version", "AMR given");
media_type = MEDIA_TYPE_AMR;
break;
case 4:
add_trace("speech", "version", "AMR given");
media_type = MEDIA_TYPE_AMR;
- payload_type =
100 + *payloads
;
+ payload_type =
dynamic_type++
;
break;
case 1:
add_trace("speech", "version", "Half Rate given");
media_type = MEDIA_TYPE_GSM_HR;
break;
case 1:
add_trace("speech", "version", "Half Rate given");
media_type = MEDIA_TYPE_GSM_HR;
- payload_type = 100 + *payloads;
+ payload_type = dynamic_type++;
+ break;
+ case 5:
+ add_trace("speech", "version", "AMR Half Rate given");
+ media_type = MEDIA_TYPE_AMR;
+ payload_type = dynamic_type++;
break;
default:
add_trace("speech", "version", "%d given", mncc->bearer_cap.speech_ver[i]);
break;
default:
add_trace("speech", "version", "%d given", mncc->bearer_cap.speech_ver[i]);
@@
-582,7
+588,7
@@
int message_bsc(struct lcr_gsm *lcr_gsm, int msg_type, void *arg)
}
if (msg_type == GSM_TCHF_FRAME
}
if (msg_type == GSM_TCHF_FRAME
- || msg_type == GSM_
TCHF_
BAD_FRAME) {
+ || msg_type == GSM_BAD_FRAME) {
if (port) {
/* inject DTMF, if enabled */
if (pgsm_bs->p_g_dtmf) {
if (port) {
/* inject DTMF, if enabled */
if (pgsm_bs->p_g_dtmf) {