Merge pull request #1354 in FS/freeswitch from ~DRAGOS_OANCEA_NX/freeswitch-dragos-nx:feature/FS-10551/opus_16khz_init_fec_map to master

* commit '2f914e37fa663737fccc2ba4fe7cf17d2918ab9f':
  FS-10551: [mod_opus] added FEC bitrates map for opus@16000h (for the "keep-fec-enabled" setting)
This commit is contained in:
Mike Jerris 2017-08-10 16:20:02 +00:00
commit f48fc352b7
1 changed files with 17 additions and 3 deletions

View File

@ -437,7 +437,7 @@ static switch_bool_t switch_opus_has_fec(const uint8_t* payload,int payload_leng
* at the beginning of the call. */
static int switch_opus_get_fec_bitrate(int fs, int loss)
{
int threshold_bitrates[25] = {
int threshold_bitrates_8k[25] = {
15600,15200,15200,15200,14800,
14800,14800,14800,14400,14400,
14400,14000,14000,14000,13600,
@ -445,15 +445,29 @@ static int switch_opus_get_fec_bitrate(int fs, int loss)
13200,12800,12800,12800,12400
};
int threshold_bitrates_16k[25] = {
20400, 20400, 20000, 20000, 19600,
19600, 19600, 19200, 19200, 18800,
18800, 18800, 18400, 18400, 18000,
18000, 18000, 17600, 17600, 17200,
17200, 17200, 16800, 16800, 16400
};
if (loss <= 0){
return SWITCH_STATUS_FALSE;
}
if (fs == 8000) {
if (loss >=25) {
return threshold_bitrates[24];
return threshold_bitrates_8k[24];
} else {
return threshold_bitrates[loss-1];
return threshold_bitrates_8k[loss-1];
}
} else if (fs == 16000) {
if (loss >=25) {
return threshold_bitrates_16k[24];
} else {
return threshold_bitrates_16k[loss-1];
}
}