aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorHarish Mahendrakar <hmahendrakar@google.com>2024-01-09 04:54:50 +0000
committerHarish Mahendrakar <hmahendrakar@google.com>2024-01-09 04:56:30 +0000
commit532ee05579fbfa90e34714aa81bcf3405d9ca558 (patch)
tree777f95c241e2ea72678ed01e868c846e87fbe3c9
parentb6394afda3e8320d4eeec67ec9baec0f1062246a (diff)
parent87f206b42d71fbf1c5601ce6679d22d0777e79bb (diff)
downloadlibxaac-532ee05579fbfa90e34714aa81bcf3405d9ca558.tar.gz
Upgrade libxaac to v0.1.10
This project was upgraded with external_updater. Usage: tools/external_updater/updater.sh update libxaac For more info, check https://cs.android.com/android/platform/superproject/+/main:tools/external_updater/README.md Bug: 319187474 Test: TreeHugger Change-Id: Ic9ef5e37600d7c129e4e42a2d7ac3a09f754d6ff
-rw-r--r--METADATA16
-rw-r--r--decoder/ixheaacd_aacdecoder.c6
-rw-r--r--decoder/ixheaacd_api.c7
-rw-r--r--decoder/ixheaacd_headerdecode.c5
-rw-r--r--decoder/ixheaacd_init_config.c3
-rw-r--r--decoder/ixheaacd_mps_bitdec.c20
-rw-r--r--decoder/ixheaacd_mps_parse.c18
-rw-r--r--encoder/drc_src/impd_drc_api.c12
-rw-r--r--encoder/drc_src/impd_drc_uni_drc.h1
-rw-r--r--encoder/iusace_enc_main.c1
-rw-r--r--encoder/iusace_main.h1
-rw-r--r--encoder/ixheaace_adjust_threshold.c101
-rw-r--r--encoder/ixheaace_adjust_threshold.h2
-rw-r--r--encoder/ixheaace_api.c25
-rw-r--r--encoder/ixheaace_api.h2
-rw-r--r--encoder/ixheaace_enc_init.c42
-rw-r--r--encoder/ixheaace_enc_main.c20
-rw-r--r--encoder/ixheaace_fd_quant.c2
-rw-r--r--encoder/ixheaace_ms_stereo.c18
-rw-r--r--encoder/ixheaace_ms_stereo.h2
-rw-r--r--encoder/ixheaace_psy_mod.c144
-rw-r--r--encoder/ixheaace_psy_mod.h6
-rw-r--r--encoder/ixheaace_qc_main_hp.c66
-rw-r--r--encoder/ixheaace_qc_util.h4
-rw-r--r--encoder/ixheaace_sbr_env_est.c195
-rw-r--r--encoder/ixheaace_sbr_frame_info_gen.c10
-rw-r--r--encoder/ixheaace_sbr_frame_info_gen.h4
-rw-r--r--encoder/ixheaace_sbr_main.c110
-rw-r--r--encoder/ixheaace_sbr_main.h1
-rw-r--r--encoder/ixheaace_sbr_qmf_enc.c9
-rw-r--r--encoder/ixheaace_sbr_qmf_enc.h3
-rw-r--r--encoder/ixheaace_sf_estimation.c26
-rw-r--r--encoder/ixheaace_sf_estimation.h4
-rw-r--r--encoder/ixheaace_static_bits.c16
-rw-r--r--encoder/ixheaace_static_bits.h2
-rw-r--r--encoder/ixheaace_stereo_preproc.c10
-rw-r--r--encoder/ixheaace_stereo_preproc.h2
-rw-r--r--fuzzer/xaac_enc_fuzzer.cpp14
38 files changed, 528 insertions, 402 deletions
diff --git a/METADATA b/METADATA
index b99da5f..4a1ff42 100644
--- a/METADATA
+++ b/METADATA
@@ -5,15 +5,15 @@
name: "libxaac"
description: "Android fork of the xaac library."
third_party {
- url {
- type: GIT
- value: "https://github.com/ittiam-systems/libxaac.git"
- }
- version: "v0.1.9"
license_type: NOTICE
last_upgrade_date {
- year: 2023
- month: 10
- day: 26
+ year: 2024
+ month: 1
+ day: 9
+ }
+ identifier {
+ type: "Git"
+ value: "https://github.com/ittiam-systems/libxaac.git"
+ version: "v0.1.10"
}
}
diff --git a/decoder/ixheaacd_aacdecoder.c b/decoder/ixheaacd_aacdecoder.c
index a5b958f..449c984 100644
--- a/decoder/ixheaacd_aacdecoder.c
+++ b/decoder/ixheaacd_aacdecoder.c
@@ -1120,8 +1120,10 @@ WORD32 ixheaacd_extension_payload(ia_bit_buf_struct *it_bit_buff, WORD32 *cnt,
ixheaacd_read_bits_buf(it_bit_buff, 2);/*anc_type*/
ixheaacd_read_bits_buf(it_bit_buff, 2);/*anc_start_stop*/
- err = ixheaacd_ld_mps_frame_parsing(self, it_bit_buff);
- if (err) return err;
+ if (self->ldmps_config.ldmps_present_flag == 1) {
+ err = ixheaacd_ld_mps_frame_parsing(self, it_bit_buff);
+ if (err) return err;
+ }
*cnt = it_bit_buff->cnt_bits;
break;
diff --git a/decoder/ixheaacd_api.c b/decoder/ixheaacd_api.c
index 9f60ef7..066bf9d 100644
--- a/decoder/ixheaacd_api.c
+++ b/decoder/ixheaacd_api.c
@@ -2452,11 +2452,8 @@ IA_ERRORCODE ixheaacd_dec_init(
(p_obj_exhaacplus_dec->p_state_aac->audio_object_type ==
AOT_ER_AAC_ELD)))
p_obj_exhaacplus_dec->aac_config.flag_to_stereo = 1;
- if (p_state_enhaacplus_dec->mps_dec_handle.ldmps_config
- .ldmps_present_flag == 1) {
- copy_qmf_to_ldmps(&p_obj_exhaacplus_dec->p_state_aac->mps_dec_handle,
- p_state_enhaacplus_dec->sbr_persistent_mem_v);
- }
+ copy_qmf_to_ldmps(&p_obj_exhaacplus_dec->p_state_aac->mps_dec_handle,
+ p_state_enhaacplus_dec->sbr_persistent_mem_v);
if (p_state_enhaacplus_dec->audio_object_type == AOT_AAC_LC &&
p_state_enhaacplus_dec->ui_mps_out_bytes != 0) {
p_state_enhaacplus_dec->heaac_mps_handle.heaac_mps_present = 1;
diff --git a/decoder/ixheaacd_headerdecode.c b/decoder/ixheaacd_headerdecode.c
index 41c4594..03fb067 100644
--- a/decoder/ixheaacd_headerdecode.c
+++ b/decoder/ixheaacd_headerdecode.c
@@ -535,6 +535,11 @@ WORD32 ixheaacd_ga_hdr_dec(ia_aac_dec_state_struct *aac_state_struct,
aac_state_struct->ch_config = ixheaacd_read_bits_buf(it_bit_buff, 4);
+ if (aac_state_struct->audio_object_type == AOT_USAC &&
+ ((aac_state_struct->ch_config >= 3) && (aac_state_struct->ch_config != 8))) {
+ return IA_XHEAAC_DEC_INIT_FATAL_DEC_INIT_FAIL;
+ }
+
pstr_audio_specific_config->channel_configuration =
aac_state_struct->ch_config;
diff --git a/decoder/ixheaacd_init_config.c b/decoder/ixheaacd_init_config.c
index d5373a8..f58b72e 100644
--- a/decoder/ixheaacd_init_config.c
+++ b/decoder/ixheaacd_init_config.c
@@ -644,6 +644,9 @@ WORD32 ixheaacd_config(ia_bit_buf_struct *it_bit_buff, ia_usac_config_struct *ps
if (BS_MAX_NUM_OUT_CHANNELS < pstr_usac_conf->num_out_channels) {
return IA_XHEAAC_DEC_INIT_FATAL_STREAM_CHAN_GT_MAX;
}
+ if (pstr_usac_conf->num_out_channels < 1) {
+ return IA_XHEAAC_DEC_INIT_FATAL_DEC_INIT_FAIL;
+ }
for (i = 0; i < pstr_usac_conf->num_out_channels; i++)
pstr_usac_conf->output_channel_pos[i] =
ixheaacd_read_bits_buf(it_bit_buff, 5);
diff --git a/decoder/ixheaacd_mps_bitdec.c b/decoder/ixheaacd_mps_bitdec.c
index d8a10e4..76d2e32 100644
--- a/decoder/ixheaacd_mps_bitdec.c
+++ b/decoder/ixheaacd_mps_bitdec.c
@@ -511,6 +511,26 @@ static IA_ERRORCODE ixheaacd_ec_data_dec(ia_heaac_mps_state_struct *pstr_mps_sta
(!frame->bs_independency_flag || (set_idx > 0)), 0, 1, pstr_mps_state->ec_flag);
if (error_code != IA_NO_ERROR) return error_code;
+ if (datatype == CLD) {
+ WORD32 band;
+ for (i = 0; i < pstr_mps_state->num_parameter_sets; i++) {
+ for (band = start_band; band < stop_band; band++) {
+ if (data[box_idx][i][band] > 15 || data[box_idx][i][band] < -15) {
+ return IA_FATAL_ERROR;
+ }
+ }
+ }
+ } else if (datatype == ICC) {
+ WORD32 band;
+ for (i = 0; i < pstr_mps_state->num_parameter_sets; i++) {
+ for (band = start_band; band < stop_band; band++) {
+ if (data[box_idx][i][band] > 7 || data[box_idx][i][band] < 0) {
+ return IA_FATAL_ERROR;
+ }
+ }
+ }
+ }
+
for (pb = 0; pb < data_bands; pb++) {
for (i = a_strides[pb]; i < a_strides[pb + 1]; i++) {
lastdata[box_idx][i] = data[box_idx][set_idx + bs_data_pair][start_band + pb];
diff --git a/decoder/ixheaacd_mps_parse.c b/decoder/ixheaacd_mps_parse.c
index 83ffdf3..19b7212 100644
--- a/decoder/ixheaacd_mps_parse.c
+++ b/decoder/ixheaacd_mps_parse.c
@@ -825,12 +825,21 @@ IA_ERRORCODE ixheaacd_ld_mps_frame_parsing(
bits_param_slot = 4;
if (bs_frame_type) {
+ WORD32 prev_param_slot = -1;
for (i = 0; i < self->num_parameter_sets; i++) {
- self->param_slots[i] =
- ixheaacd_read_bits_buf(it_bit_buff, bits_param_slot);
+ self->param_slots[i] = ixheaacd_read_bits_buf(it_bit_buff, bits_param_slot);
+
+ if (prev_param_slot >= self->param_slots[i] || self->param_slots[i] >= self->time_slots) {
+ return IA_FATAL_ERROR;
+ }
+ prev_param_slot = self->param_slots[i];
}
} else {
- self->param_slots[0] = self->time_slots - 1;
+ for (i = 0; i < self->num_parameter_sets; i++) {
+ self->param_slots[i] = (((self->time_slots * (i + 1)) + self->num_parameter_sets - 1) /
+ self->num_parameter_sets) -
+ 1;
+ }
}
frame->independency_flag = ixheaacd_read_bits_buf(it_bit_buff, 1);
@@ -1304,7 +1313,8 @@ IA_ERRORCODE ixheaacd_mps_frame_decode(ia_mps_dec_state_struct *self) {
(WORD32)floor(self->inv_param_slot_diff[0] * 1073741824 + 0.5);
for (i = 1; i < self->num_parameter_sets; i++) {
self->param_slot_diff[i] = self->param_slots[i] - self->param_slots[i - 1];
- if (MAX_TIME_SLOTS < (self->param_slot_diff[0] + self->param_slot_diff[i])) {
+ if ((MAX_TIME_SLOTS < (self->param_slot_diff[0] + self->param_slot_diff[i])) ||
+ (self->param_slot_diff[i] == 0)) {
if (self->ec_flag == 0) {
return -1;
} else {
diff --git a/encoder/drc_src/impd_drc_api.c b/encoder/drc_src/impd_drc_api.c
index 4218903..0a1b6e1 100644
--- a/encoder/drc_src/impd_drc_api.c
+++ b/encoder/drc_src/impd_drc_api.c
@@ -126,6 +126,18 @@ static IA_ERRORCODE impd_drc_validate_config_params(ia_drc_input_config *pstr_in
.gain_params[k]
.start_sub_band_index,
0, STFT256_HOP_SIZE - 1);
+ IMPD_DRC_BOUND_CHECK(pstr_uni_drc_config->str_drc_coefficients_uni_drc[i]
+ .str_gain_set_params[j].gain_params[k].width,
+ -MAX_FLT_VAL_DB, MAX_FLT_VAL_DB);
+ for (WORD32 m = 0; m < pstr_uni_drc_config->str_drc_coefficients_uni_drc[i]
+ .str_gain_set_params[j].gain_params[k].nb_points; m++) {
+ IMPD_DRC_BOUND_CHECK(pstr_uni_drc_config->str_drc_coefficients_uni_drc[i]
+ .str_gain_set_params[j].gain_params[k].gain_points[m].x,
+ -MAX_FLT_VAL_DB, MAX_FLT_VAL_DB);
+ IMPD_DRC_BOUND_CHECK(pstr_uni_drc_config->str_drc_coefficients_uni_drc[i]
+ .str_gain_set_params[j].gain_params[k].gain_points[m].y,
+ -MAX_FLT_VAL_DB, MAX_FLT_VAL_DB);
+ }
}
for (k = 0; k <
pstr_uni_drc_config->str_drc_coefficients_uni_drc[i].str_gain_set_params[j].band_count
diff --git a/encoder/drc_src/impd_drc_uni_drc.h b/encoder/drc_src/impd_drc_uni_drc.h
index 02a03ab..95f656a 100644
--- a/encoder/drc_src/impd_drc_uni_drc.h
+++ b/encoder/drc_src/impd_drc_uni_drc.h
@@ -129,6 +129,7 @@
#define MAX_METHOD_DEFINITION_TYPE (9)
#define MIN_METHOD_VALUE (-116.0f)
#define MAX_METHOD_VALUE (121.0f)
+#define MAX_FLT_VAL_DB (770.6367883810890080451095799195f)
typedef struct {
WORD32 level_estim_k_weighting_type;
diff --git a/encoder/iusace_enc_main.c b/encoder/iusace_enc_main.c
index fa2a0ac..293db83 100644
--- a/encoder/iusace_enc_main.c
+++ b/encoder/iusace_enc_main.c
@@ -1218,6 +1218,7 @@ IA_ERRORCODE ixheaace_usac_encode(FLOAT32 **ptr_input,
return err;
}
num_bits += num_bits_ext_elem;
+ ptr_usac_data->num_drc_bits = num_bits_ext_elem;
#ifdef DRC_BITRATE_CONSIDERATION
ptr_usac_data->drc_data_bit_cnt = num_bits_ext_elem;
#endif
diff --git a/encoder/iusace_main.h b/encoder/iusace_main.h
index dcacb14..e717286 100644
--- a/encoder/iusace_main.h
+++ b/encoder/iusace_main.h
@@ -95,6 +95,7 @@ typedef struct {
UWORD32 ext_elem_config_len[MAX_EXTENSION_PAYLOADS];
iusace_scratch_mem str_scratch;
WORD32 min_bits_needed;
+ WORD32 num_drc_bits;
} ia_usac_data_struct;
typedef struct {
diff --git a/encoder/ixheaace_adjust_threshold.c b/encoder/ixheaace_adjust_threshold.c
index 9e4e91c..3e38b22 100644
--- a/encoder/ixheaace_adjust_threshold.c
+++ b/encoder/ixheaace_adjust_threshold.c
@@ -129,7 +129,7 @@ VOID iaace_adj_thr_init(ia_adj_thr_state_struct *pstr_adj_thr_state, const FLOAT
}
FLOAT32 iaace_bits_to_pe(const FLOAT32 bits) { return (bits * 1.18f); }
static VOID iaace_calc_sfb_pe_data(ia_qc_pe_data_struct *pstr_qc_pe_data,
- ixheaace_psy_out_channel *pstr_psy_out, WORD32 num_channels,
+ ixheaace_psy_out_channel **pstr_psy_out, WORD32 num_channels,
WORD32 chn) {
WORD32 ch;
WORD32 scf_band_grp;
@@ -148,11 +148,11 @@ static VOID iaace_calc_sfb_pe_data(ia_qc_pe_data_struct *pstr_qc_pe_data,
pstr_qc_pe_data->num_active_lines = 0.0f;
for (ch = chn; ch < chn + num_channels; ch++) {
- sfb_count = pstr_psy_out[ch].sfb_count;
- scf_band_per_grp = pstr_psy_out[ch].sfb_per_group;
- max_sfb_per_grp = pstr_psy_out[ch].max_sfb_per_grp;
- ptr_sfb_energy = pstr_psy_out[ch].ptr_sfb_energy;
- ptr_sfb_thr = pstr_psy_out[ch].ptr_sfb_thr;
+ sfb_count = pstr_psy_out[ch]->sfb_count;
+ scf_band_per_grp = pstr_psy_out[ch]->sfb_per_group;
+ max_sfb_per_grp = pstr_psy_out[ch]->max_sfb_per_grp;
+ ptr_sfb_energy = pstr_psy_out[ch]->ptr_sfb_energy;
+ ptr_sfb_thr = pstr_psy_out[ch]->ptr_sfb_thr;
pstr_qc_pe_chan_data = &pstr_qc_pe_data->pe_ch_data[ch];
pstr_qc_pe_chan_data->pe = 0;
pstr_qc_pe_chan_data->num_active_lines = 0;
@@ -190,7 +190,7 @@ static VOID iaace_calc_sfb_pe_data(ia_qc_pe_data_struct *pstr_qc_pe_data,
pstr_qc_pe_data->pe += pstr_qc_pe_chan_data->pe;
pstr_qc_pe_data->const_part += pstr_qc_pe_chan_data->const_part;
pstr_qc_pe_data->num_active_lines += pstr_qc_pe_chan_data->num_active_lines;
- pstr_psy_out[ch].pe = pstr_qc_pe_data->pe;
+ pstr_psy_out[ch]->pe = pstr_qc_pe_data->pe;
}
}
static FLOAT32 iaace_calc_bit_save(ia_bitres_param_struct *pstr_bitres_params, FLOAT32 fill_lvl) {
@@ -334,13 +334,13 @@ static VOID iaace_calc_pe_correction(FLOAT32 *ptr_correction_fac, const FLOAT32
static VOID iaace_calc_thr_exp(
FLOAT32 thr_exp[IXHEAACE_MAX_CH_IN_BS_ELE][MAXIMUM_GROUPED_SCALE_FACTOR_BAND],
- ixheaace_psy_out_channel *pstr_psy_out, WORD32 num_chans, WORD32 chn) {
+ ixheaace_psy_out_channel **pstr_psy_out, WORD32 num_chans, WORD32 chn) {
WORD32 sfb, ch, scf_band_grp;
ixheaace_psy_out_channel *pstr_psy_chan_out;
FLOAT32 *ptr_scf_band_thr;
FLOAT32 *ptr_thr_exp;
for (ch = chn; ch < chn + num_chans; ch++) {
- pstr_psy_chan_out = &pstr_psy_out[ch];
+ pstr_psy_chan_out = pstr_psy_out[ch];
ptr_thr_exp = thr_exp[ch];
for (scf_band_grp = 0; scf_band_grp < pstr_psy_chan_out->sfb_count;
scf_band_grp += pstr_psy_chan_out->sfb_per_group) {
@@ -353,7 +353,7 @@ static VOID iaace_calc_thr_exp(
}
}
-static VOID iaace_adapt_min_snr(ixheaace_psy_out_channel *pstr_psy_out,
+static VOID iaace_adapt_min_snr(ixheaace_psy_out_channel **pstr_psy_out,
ia_min_snr_adapt_param_struct *pstr_min_snr_params,
WORD32 num_chans, WORD32 chn) {
WORD32 num_scf_band = 0, ch, scf_band_cnt, scf_band_offs, sfb;
@@ -361,7 +361,7 @@ static VOID iaace_adapt_min_snr(ixheaace_psy_out_channel *pstr_psy_out,
WORD32 i;
for (ch = chn; ch < chn + num_chans; ch++) {
- ixheaace_psy_out_channel *pstr_psy_chan_out = &pstr_psy_out[ch];
+ ixheaace_psy_out_channel *pstr_psy_chan_out = pstr_psy_out[ch];
num_scf_band = 0;
avg_energy = 0;
scf_band_cnt = pstr_psy_chan_out->max_sfb_per_grp;
@@ -392,8 +392,9 @@ static VOID iaace_adapt_min_snr(ixheaace_psy_out_channel *pstr_psy_out,
pstr_min_snr_params->red_offs + pstr_min_snr_params->red_ratio_fac * db_ratio;
min_snr_red = MAX(min_snr_red, pstr_min_snr_params->max_red);
pstr_psy_chan_out->sfb_min_snr[i] =
- (FLOAT32)pow(pstr_psy_out[ch].sfb_min_snr[i], min_snr_red);
- pstr_psy_chan_out->sfb_min_snr[i] = MIN(MIN_SNR_LIMIT, pstr_psy_out[ch].sfb_min_snr[i]);
+ (FLOAT32)pow(pstr_psy_out[ch]->sfb_min_snr[i], min_snr_red);
+ pstr_psy_chan_out->sfb_min_snr[i] =
+ MIN(MIN_SNR_LIMIT, pstr_psy_out[ch]->sfb_min_snr[i]);
}
}
}
@@ -402,7 +403,7 @@ static VOID iaace_adapt_min_snr(ixheaace_psy_out_channel *pstr_psy_out,
static VOID iaace_init_avoid_hole_flag(
WORD32 ah_flag[IXHEAACE_MAX_CH_IN_BS_ELE][MAXIMUM_GROUPED_SCALE_FACTOR_BAND],
- ixheaace_psy_out_channel *pstr_psy_out, ia_ah_param_struct *pstr_ah_param, WORD32 num_chans,
+ ixheaace_psy_out_channel **pstr_psy_out, ia_ah_param_struct *pstr_ah_param, WORD32 num_chans,
WORD32 chn, WORD32 aot) {
WORD32 ch;
FLOAT32 sfb_energy;
@@ -410,7 +411,7 @@ static VOID iaace_init_avoid_hole_flag(
WORD32 scf_band_grp, scf_band_cnt, scf_band;
FLOAT32 *ptr_scf_band_spread_energy, *ptr_scf_band_energy, *ptr_scf_band_min_snr;
for (ch = chn; ch < chn + num_chans; ch++) {
- ixheaace_psy_out_channel *pstr_psy_chan_out = &pstr_psy_out[ch];
+ ixheaace_psy_out_channel *pstr_psy_chan_out = pstr_psy_out[ch];
if (pstr_psy_chan_out->window_sequence != SHORT_WINDOW) {
switch (aot) {
@@ -442,7 +443,7 @@ static VOID iaace_init_avoid_hole_flag(
if (pstr_ah_param->modify_min_snr) {
for (ch = chn; ch < chn + num_chans; ch++) {
- ixheaace_psy_out_channel *pstr_psy_chan_out = &pstr_psy_out[ch];
+ ixheaace_psy_out_channel *pstr_psy_chan_out = pstr_psy_out[ch];
ptr_scf_band_energy = pstr_psy_chan_out->ptr_sfb_energy;
ptr_scf_band_min_snr = pstr_psy_chan_out->sfb_min_snr;
@@ -509,12 +510,12 @@ static VOID iaace_init_avoid_hole_flag(
}
if (num_chans == 2) {
- ixheaace_psy_out_channel *pstr_psy_out_mid = &pstr_psy_out[chn];
- ixheaace_psy_out_channel *pstr_psy_out_side = &pstr_psy_out[chn + 1];
+ ixheaace_psy_out_channel *pstr_psy_out_mid = pstr_psy_out[chn];
+ ixheaace_psy_out_channel *pstr_psy_out_side = pstr_psy_out[chn + 1];
WORD32 sfb;
for (sfb = 0; sfb < pstr_psy_out_mid->sfb_count; sfb++) {
- if (pstr_psy_out[chn].ms_used[sfb]) {
+ if (pstr_psy_out[chn]->ms_used[sfb]) {
FLOAT32 sfb_en_mid = pstr_psy_out_mid->ptr_sfb_energy[sfb];
FLOAT32 sfb_en_side = pstr_psy_out_side->ptr_sfb_energy[sfb];
FLOAT32 max_sfb_en = MAX(sfb_en_mid, sfb_en_side);
@@ -541,7 +542,7 @@ static VOID iaace_init_avoid_hole_flag(
}
for (ch = chn; ch < chn + num_chans; ch++) {
- ixheaace_psy_out_channel *pstr_psy_chan_out = &pstr_psy_out[ch];
+ ixheaace_psy_out_channel *pstr_psy_chan_out = pstr_psy_out[ch];
for (scf_band_grp = 0; scf_band_grp < pstr_psy_chan_out->sfb_count;
scf_band_grp += pstr_psy_chan_out->sfb_per_group) {
for (scf_band = 0; scf_band < pstr_psy_chan_out->max_sfb_per_grp; scf_band++) {
@@ -563,7 +564,7 @@ static VOID iaace_init_avoid_hole_flag(
}
static VOID iaace_reduce_thr(
- ixheaace_psy_out_channel *pstr_psy_out,
+ ixheaace_psy_out_channel **pstr_psy_out,
WORD32 ah_flag[IXHEAACE_MAX_CH_IN_BS_ELE][MAXIMUM_GROUPED_SCALE_FACTOR_BAND],
FLOAT32 thr_exp[IXHEAACE_MAX_CH_IN_BS_ELE][MAXIMUM_GROUPED_SCALE_FACTOR_BAND],
const FLOAT32 red_value, WORD32 num_channels, WORD32 chn) {
@@ -572,7 +573,7 @@ static VOID iaace_reduce_thr(
FLOAT32 *ptr_sfb_energy_fix, *ptr_sfb_threshold_fix, *ptr_sfb_min_snr_fix, *ptr_thr_exp_fix;
for (ch = chn; ch < chn + num_channels; ch++) {
- ixheaace_psy_out_channel *pstr_psy_chan_out = &pstr_psy_out[ch];
+ ixheaace_psy_out_channel *pstr_psy_chan_out = pstr_psy_out[ch];
ptr_sfb_energy_fix = pstr_psy_chan_out->ptr_sfb_energy;
ptr_sfb_threshold_fix = pstr_psy_chan_out->ptr_sfb_thr;
ptr_sfb_min_snr_fix = pstr_psy_chan_out->sfb_min_snr;
@@ -603,14 +604,14 @@ static VOID iaace_calc_pe_no_active_holes(
FLOAT32 *ptr_pe, FLOAT32 *ptr_const_part, FLOAT32 *ptr_num_active_lines,
ia_qc_pe_data_struct *pstr_qs_pe_data,
WORD32 ah_flag[IXHEAACE_MAX_CH_IN_BS_ELE][MAXIMUM_GROUPED_SCALE_FACTOR_BAND],
- ixheaace_psy_out_channel *pstr_psy_out, WORD32 num_channels, WORD32 chn) {
+ ixheaace_psy_out_channel **pstr_psy_out, WORD32 num_channels, WORD32 chn) {
WORD32 ch, sfb_group, sfb;
*ptr_pe = 0.0f;
*ptr_const_part = 0.0f;
*ptr_num_active_lines = 0;
for (ch = chn; ch < chn + num_channels; ch++) {
- ixheaace_psy_out_channel *pstr_psy_chan_out = &pstr_psy_out[ch];
+ ixheaace_psy_out_channel *pstr_psy_chan_out = pstr_psy_out[ch];
ia_qc_pe_chan_data_struct *ptr_pe_chan_data = &pstr_qs_pe_data->pe_ch_data[ch];
for (sfb_group = 0; sfb_group < pstr_psy_chan_out->sfb_count;
@@ -627,7 +628,7 @@ static VOID iaace_calc_pe_no_active_holes(
}
static VOID iaace_correct_thr(
- ixheaace_psy_out_channel *pstr_psy_out,
+ ixheaace_psy_out_channel **pstr_psy_out,
WORD32 ah_flag[IXHEAACE_MAX_CH_IN_BS_ELE][MAXIMUM_GROUPED_SCALE_FACTOR_BAND],
ia_qc_pe_data_struct *pstr_qs_pe_data,
FLOAT32 thr_exp[IXHEAACE_MAX_CH_IN_BS_ELE][MAXIMUM_GROUPED_SCALE_FACTOR_BAND],
@@ -644,7 +645,7 @@ static VOID iaace_correct_thr(
ia_qc_pe_chan_data_struct *pstr_pe_chan_data = NULL;
for (ch = chn; ch < chn + num_channels; ch++) {
- pstr_psy_chan_out = &pstr_psy_out[ch];
+ pstr_psy_chan_out = pstr_psy_out[ch];
pstr_pe_chan_data = &pstr_qs_pe_data->pe_ch_data[ch];
norm_factor[ch] = MIN_FLT_VAL;
ptr_thr_exp = thr_exp[ch];
@@ -669,7 +670,7 @@ static VOID iaace_correct_thr(
norm_factor[chn] = 1.0f / norm_factor[chn];
for (ch = chn; ch < chn + num_channels; ch++) {
- pstr_psy_chan_out = &pstr_psy_out[ch];
+ pstr_psy_chan_out = pstr_psy_out[ch];
pstr_pe_chan_data = &pstr_qs_pe_data->pe_ch_data[ch];
ptr_sfb_energy = pstr_psy_chan_out->ptr_sfb_energy;
ptr_sfb_thr = pstr_psy_chan_out->ptr_sfb_thr;
@@ -700,23 +701,23 @@ static VOID iaace_correct_thr(
}
static VOID iaace_reduce_min_snr(
- ixheaace_psy_out_channel *pstr_psy_out, ia_qc_pe_data_struct *pstr_qs_pe_data,
+ ixheaace_psy_out_channel **pstr_psy_out, ia_qc_pe_data_struct *pstr_qs_pe_data,
WORD32 ah_flag[IXHEAACE_MAX_CH_IN_BS_ELE][MAXIMUM_GROUPED_SCALE_FACTOR_BAND],
const FLOAT32 desired_pe, WORD32 num_channels, WORD32 chn) {
WORD32 sfb, sfb_sub_win, ch;
FLOAT32 delta_pe;
- sfb_sub_win = pstr_psy_out[chn].max_sfb_per_grp;
+ sfb_sub_win = pstr_psy_out[chn]->max_sfb_per_grp;
while (pstr_qs_pe_data->pe > desired_pe && sfb_sub_win > 0) {
sfb_sub_win--;
- for (sfb = sfb_sub_win; sfb < pstr_psy_out[chn].sfb_count;
- sfb += pstr_psy_out[chn].sfb_per_group) {
+ for (sfb = sfb_sub_win; sfb < pstr_psy_out[chn]->sfb_count;
+ sfb += pstr_psy_out[chn]->sfb_per_group) {
for (ch = chn; ch < chn + num_channels; ch++) {
- if (ah_flag[ch][sfb] != NO_AH && pstr_psy_out[ch].sfb_min_snr[sfb] < MIN_SNR_LIMIT) {
- pstr_psy_out[ch].sfb_min_snr[sfb] = MIN_SNR_LIMIT;
- pstr_psy_out[ch].ptr_sfb_thr[sfb] =
- pstr_psy_out[ch].ptr_sfb_energy[sfb] * pstr_psy_out[ch].sfb_min_snr[sfb];
+ if (ah_flag[ch][sfb] != NO_AH && pstr_psy_out[ch]->sfb_min_snr[sfb] < MIN_SNR_LIMIT) {
+ pstr_psy_out[ch]->sfb_min_snr[sfb] = MIN_SNR_LIMIT;
+ pstr_psy_out[ch]->ptr_sfb_thr[sfb] =
+ pstr_psy_out[ch]->ptr_sfb_energy[sfb] * pstr_psy_out[ch]->sfb_min_snr[sfb];
delta_pe = pstr_qs_pe_data->pe_ch_data[ch].sfb_lines[sfb] * 1.5f -
pstr_qs_pe_data->pe_ch_data[ch].sfb_pe[sfb];
pstr_qs_pe_data->pe += delta_pe;
@@ -731,7 +732,7 @@ static VOID iaace_reduce_min_snr(
}
static VOID iaace_allow_more_holes(
- ixheaace_psy_out_channel *pstr_psy_out, ia_qc_pe_data_struct *pstr_qs_pe_data,
+ ixheaace_psy_out_channel **pstr_psy_out, ia_qc_pe_data_struct *pstr_qs_pe_data,
WORD32 ah_flag[IXHEAACE_MAX_CH_IN_BS_ELE][MAXIMUM_GROUPED_SCALE_FACTOR_BAND],
const ia_ah_param_struct *pstr_str_ah_param, const FLOAT32 desired_pe, WORD32 num_channels,
WORD32 chn) {
@@ -739,12 +740,12 @@ static VOID iaace_allow_more_holes(
FLOAT32 act_pe = pstr_qs_pe_data->pe;
if (num_channels == 2 &&
- pstr_psy_out[chn].window_sequence == pstr_psy_out[chn + 1].window_sequence) {
- ixheaace_psy_out_channel *pstr_psy_out_left = &pstr_psy_out[chn];
- ixheaace_psy_out_channel *pstr_psy_out_right = &pstr_psy_out[chn + 1];
+ pstr_psy_out[chn]->window_sequence == pstr_psy_out[chn + 1]->window_sequence) {
+ ixheaace_psy_out_channel *pstr_psy_out_left = pstr_psy_out[chn];
+ ixheaace_psy_out_channel *pstr_psy_out_right = pstr_psy_out[chn + 1];
for (sfb = 0; sfb < pstr_psy_out_left->sfb_count; sfb++) {
- if (pstr_psy_out[chn].ms_used[sfb]) {
+ if (pstr_psy_out[chn]->ms_used[sfb]) {
if (ah_flag[chn + 1][sfb] != NO_AH &&
0.4f * pstr_psy_out_left->sfb_min_snr[sfb] * pstr_psy_out_left->ptr_sfb_energy[sfb] >
pstr_psy_out_right->ptr_sfb_energy[sfb]) {
@@ -780,7 +781,7 @@ static VOID iaace_allow_more_holes(
WORD32 done;
for (ch = chn; ch < chn + num_channels; ch++) {
- if (pstr_psy_out[ch].window_sequence != SHORT_WINDOW) {
+ if (pstr_psy_out[ch]->window_sequence != SHORT_WINDOW) {
start_sfb[ch] = pstr_str_ah_param->start_sfb_long;
} else {
start_sfb[ch] = pstr_str_ah_param->start_sfb_short;
@@ -791,7 +792,7 @@ static VOID iaace_allow_more_holes(
min_energy = MAX_FLT_VAL;
ah_cnt = 0;
for (ch = chn; ch < chn + num_channels; ch++) {
- ixheaace_psy_out_channel *pstr_psy_chan_out = &pstr_psy_out[ch];
+ ixheaace_psy_out_channel *pstr_psy_chan_out = pstr_psy_out[ch];
for (sfb = start_sfb[ch]; sfb < pstr_psy_chan_out->sfb_count; sfb++) {
if ((ah_flag[ch][sfb] != NO_AH) &&
(pstr_psy_chan_out->ptr_sfb_energy[sfb] > pstr_psy_chan_out->ptr_sfb_thr[sfb])) {
@@ -808,11 +809,11 @@ static VOID iaace_allow_more_holes(
energy[en_idx] = min_energy * (FLOAT32)pow(average_energy / (min_energy + MIN_FLT_VAL),
(2 * en_idx + 1) / 7.0f);
}
- max_sfb = pstr_psy_out[chn].sfb_count - 1;
+ max_sfb = pstr_psy_out[chn]->sfb_count - 1;
min_sfb = start_sfb[chn];
if (num_channels == 2) {
- max_sfb = MAX(max_sfb, pstr_psy_out[chn + 1].sfb_count - 1);
+ max_sfb = MAX(max_sfb, pstr_psy_out[chn + 1]->sfb_count - 1);
min_sfb = MIN(min_sfb, start_sfb[chn + 1]);
}
@@ -822,7 +823,7 @@ static VOID iaace_allow_more_holes(
done = 0;
while (!done) {
for (ch = chn; ch < chn + num_channels; ch++) {
- ixheaace_psy_out_channel *pstr_psy_chan_out = &pstr_psy_out[ch];
+ ixheaace_psy_out_channel *pstr_psy_chan_out = pstr_psy_out[ch];
if (sfb >= start_sfb[ch] && sfb < pstr_psy_chan_out->sfb_count) {
if (ah_flag[ch][sfb] != NO_AH &&
pstr_psy_chan_out->ptr_sfb_energy[sfb] < energy[en_idx]) {
@@ -850,7 +851,7 @@ static VOID iaace_allow_more_holes(
}
static VOID iaace_adapt_thr_to_pe(
- ixheaace_psy_out_channel pstr_psy_out[IXHEAACE_MAX_CH_IN_BS_ELE],
+ ixheaace_psy_out_channel **pstr_psy_out,
ia_qc_pe_data_struct *pstr_qs_pe_data, const FLOAT32 desired_pe,
ia_ah_param_struct *pstr_ah_param, ia_min_snr_adapt_param_struct *pstr_msa_param,
WORD32 num_channels, WORD32 chn, WORD32 aot) {
@@ -918,7 +919,7 @@ static VOID iaace_adapt_thr_to_pe(
VOID iaace_adjust_threshold(ia_adj_thr_state_struct *pstr_adj_thr_state,
ia_adj_thr_elem_struct *pstr_adj_thr_elem,
- ixheaace_psy_out_channel pstr_psy_out[IXHEAACE_MAX_CH_IN_BS_ELE],
+ ixheaace_psy_out_channel **pstr_psy_out,
FLOAT32 *ptr_ch_bit_dist, ixheaace_qc_out_element *pstr_qc_out_el,
const WORD32 avg_bits, const WORD32 bitres_bits,
const WORD32 max_bitres_bits, const WORD32 side_info_bits,
@@ -945,12 +946,12 @@ VOID iaace_adjust_threshold(ia_adj_thr_state_struct *pstr_adj_thr_state,
curr_win_sequence = LONG_WINDOW;
if (num_channels == 2) {
- if ((pstr_psy_out[chn].window_sequence == SHORT_WINDOW) ||
- (pstr_psy_out[chn + 1].window_sequence == SHORT_WINDOW)) {
+ if ((pstr_psy_out[chn]->window_sequence == SHORT_WINDOW) ||
+ (pstr_psy_out[chn + 1]->window_sequence == SHORT_WINDOW)) {
curr_win_sequence = SHORT_WINDOW;
}
} else {
- curr_win_sequence = pstr_psy_out[chn].window_sequence;
+ curr_win_sequence = pstr_psy_out[chn]->window_sequence;
}
bit_factor = iaace_bitres_calc_bitfac(
diff --git a/encoder/ixheaace_adjust_threshold.h b/encoder/ixheaace_adjust_threshold.h
index e18855f..b538b9d 100644
--- a/encoder/ixheaace_adjust_threshold.h
+++ b/encoder/ixheaace_adjust_threshold.h
@@ -45,7 +45,7 @@ VOID iaace_adj_thr_init(ia_adj_thr_state_struct *pstr_adj_thr_state, const FLOAT
VOID iaace_adjust_threshold(ia_adj_thr_state_struct *pstr_adj_thr_state,
ia_adj_thr_elem_struct *pstr_adj_thr_elem,
- ixheaace_psy_out_channel pstr_psy_out[IXHEAACE_MAX_CH_IN_BS_ELE],
+ ixheaace_psy_out_channel **pstr_psy_out,
FLOAT32 *ptr_ch_bit_dist, ixheaace_qc_out_element *pstr_qc_out_el,
const WORD32 avg_bits, const WORD32 bitres_bits,
const WORD32 max_bitres_bits, const WORD32 side_info_bits,
diff --git a/encoder/ixheaace_api.c b/encoder/ixheaace_api.c
index 4bc7ddd..5242d78 100644
--- a/encoder/ixheaace_api.c
+++ b/encoder/ixheaace_api.c
@@ -539,9 +539,6 @@ static VOID ixheaace_validate_config_params(ixheaace_input_config *pstr_input_co
pstr_input_config->aot != AOT_SBR && pstr_input_config->aot != AOT_USAC) {
pstr_input_config->aot = AOT_AAC_LC;
}
- if (1 == pstr_input_config->usac_en) {
- pstr_input_config->aot = AOT_USAC;
- }
pstr_input_config->i_native_samp_freq = pstr_input_config->i_samp_freq;
if (pstr_input_config->i_samp_freq < 9391) {
pstr_input_config->i_samp_freq = 8000;
@@ -677,25 +674,26 @@ static VOID ixheaace_validate_config_params(ixheaace_input_config *pstr_input_co
if (pstr_input_config->ccfl_idx == NO_SBR_CCFL_768 ||
pstr_input_config->ccfl_idx == NO_SBR_CCFL_1024) {
if (pstr_input_config->i_bitrate >
- (6 * pstr_input_config->i_samp_freq * pstr_input_config->i_channels)) {
+ (WORD32)(6 * pstr_input_config->i_samp_freq * pstr_input_config->i_channels)) {
pstr_input_config->i_bitrate =
(6 * pstr_input_config->i_samp_freq * pstr_input_config->i_channels);
}
} else if (pstr_input_config->ccfl_idx == SBR_8_3) {
if (pstr_input_config->i_bitrate >
- (6 * ((pstr_input_config->i_samp_freq * 3) / 8) * pstr_input_config->i_channels)) {
+ (WORD32)(6 * ((pstr_input_config->i_samp_freq * 3) / 8) *
+ pstr_input_config->i_channels)) {
pstr_input_config->i_bitrate =
(6 * ((pstr_input_config->i_samp_freq * 3) / 8) * pstr_input_config->i_channels);
}
} else if (pstr_input_config->ccfl_idx == SBR_2_1) {
if (pstr_input_config->i_bitrate >
- (6 * (pstr_input_config->i_samp_freq / 2) * pstr_input_config->i_channels)) {
+ (WORD32)(6 * (pstr_input_config->i_samp_freq / 2) * pstr_input_config->i_channels)) {
pstr_input_config->i_bitrate =
(6 * (pstr_input_config->i_samp_freq / 2) * pstr_input_config->i_channels);
}
} else if (pstr_input_config->ccfl_idx == SBR_4_1) {
if (pstr_input_config->i_bitrate >
- (6 * (pstr_input_config->i_samp_freq / 4) * pstr_input_config->i_channels)) {
+ (WORD32)(6 * (pstr_input_config->i_samp_freq / 4) * pstr_input_config->i_channels)) {
pstr_input_config->i_bitrate =
(6 * (pstr_input_config->i_samp_freq / 4) * pstr_input_config->i_channels);
}
@@ -763,7 +761,7 @@ static VOID ixheaace_validate_config_params(ixheaace_input_config *pstr_input_co
pstr_input_config->i_bitrate = MINIMUM_BITRATE * pstr_input_config->i_channels;
}
if (pstr_input_config->i_bitrate >
- (6 * pstr_input_config->i_samp_freq * pstr_input_config->i_channels)) {
+ (WORD32)(6 * pstr_input_config->i_samp_freq * pstr_input_config->i_channels)) {
pstr_input_config->i_bitrate =
(6 * pstr_input_config->i_samp_freq * pstr_input_config->i_channels);
}
@@ -785,6 +783,10 @@ static VOID ixheaace_validate_config_params(ixheaace_input_config *pstr_input_co
pstr_input_config->frame_length = LEN_SUPERFRAME;
}
}
+ if ((pstr_input_config->frame_length == FRAME_LEN_960) &&
+ (pstr_input_config->esbr_flag == 1)) {
+ pstr_input_config->esbr_flag = 0;
+ }
}
}
@@ -3318,7 +3320,9 @@ IA_ERRORCODE ixheaace_allocate(pVOID pv_input, pVOID pv_output) {
ixheaace_input_config *pstr_input_config = (ixheaace_input_config *)pv_input;
ixheaace_output_config *pstr_output_config = (ixheaace_output_config *)pv_output;
ixheaace_api_struct *pstr_api_struct;
-
+ if (1 == pstr_input_config->usac_en) {
+ pstr_input_config->aot = AOT_USAC;
+ }
if (pstr_input_config->aot != AOT_AAC_ELD && pstr_input_config->aot != AOT_AAC_LC &&
pstr_input_config->aot != AOT_AAC_LD && pstr_input_config->aot != AOT_SBR &&
pstr_input_config->aot != AOT_PS && pstr_input_config->aot != AOT_USAC) {
@@ -3601,6 +3605,9 @@ IA_ERRORCODE ixheaace_process(pVOID pstr_obj_ixheaace, pVOID pv_input, pVOID pv_
if (!pstr_api_struct->usac_en) {
for (ele_idx = 0; ele_idx < pstr_api_struct->config[0].num_bs_elements; ele_idx++) {
error = ia_enhaacplus_enc_execute(pstr_api_struct, ele_idx);
+ if (error != IA_NO_ERROR) {
+ return error;
+ }
}
if ((error == IA_NO_ERROR) && (pstr_api_struct->pstr_state->is_quant_spec_zero)) {
error = IA_EXHEAACE_EXE_NONFATAL_QUANTIZATION_SPECTRUM_ZERO;
diff --git a/encoder/ixheaace_api.h b/encoder/ixheaace_api.h
index c38d43d..3bd594a 100644
--- a/encoder/ixheaace_api.h
+++ b/encoder/ixheaace_api.h
@@ -87,7 +87,7 @@ typedef struct {
WORD32 i_mps_tree_config;
WORD32 esbr_flag;
WORD32 i_channels;
- WORD32 i_samp_freq;
+ UWORD32 i_samp_freq;
WORD32 i_native_samp_freq;
WORD32 i_channels_mask;
WORD32 i_num_coupling_chan;
diff --git a/encoder/ixheaace_enc_init.c b/encoder/ixheaace_enc_init.c
index c744297..5abcb2a 100644
--- a/encoder/ixheaace_enc_init.c
+++ b/encoder/ixheaace_enc_init.c
@@ -155,18 +155,23 @@ static VOID ixheaace_determine_bandwidth(const WORD32 proposed_bandwidth, const
WORD32 ia_enhaacplus_enc_aac_enc_pers_size(WORD32 num_aac_chan, WORD32 aot) {
WORD32 num_bytes;
- num_bytes = sizeof(iexheaac_encoder_str);
- num_bytes += num_aac_chan * sizeof(ixheaace_psy_out_channel);
- num_bytes += num_aac_chan * sizeof(ixheaace_psy_data);
- num_bytes += num_aac_chan * sizeof(ixheaace_temporal_noise_shaping_data);
+ num_bytes = IXHEAACE_GET_SIZE_ALIGNED(sizeof(iexheaac_encoder_str), BYTE_ALIGN_8);
+ num_bytes += (num_aac_chan *
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(ixheaace_psy_out_channel), BYTE_ALIGN_8));
+ num_bytes += (num_aac_chan *
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(ixheaace_psy_data), BYTE_ALIGN_8));
+ num_bytes += (num_aac_chan *
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(ixheaace_temporal_noise_shaping_data), BYTE_ALIGN_8));
if (aot == AOT_AAC_LC || aot == AOT_SBR || aot == AOT_PS) {
- num_bytes += num_aac_chan * BLK_SWITCH_OFFSET_LC_128 * sizeof(FLOAT32);
+ num_bytes += (num_aac_chan *
+ IXHEAACE_GET_SIZE_ALIGNED(BLK_SWITCH_OFFSET_LC_128 * sizeof(FLOAT32), BYTE_ALIGN_8));
} else if (aot == AOT_AAC_LD || aot == AOT_AAC_ELD) {
- num_bytes += num_aac_chan * BLK_SWITCH_OFFSET_LD * sizeof(FLOAT32);
+ num_bytes += (num_aac_chan *
+ IXHEAACE_GET_SIZE_ALIGNED(BLK_SWITCH_OFFSET_LD * sizeof(FLOAT32), BYTE_ALIGN_8));
}
- num_bytes += num_aac_chan * sizeof(ixheaace_qc_out_channel);
- num_bytes = IXHEAACE_GET_SIZE_ALIGNED(num_bytes, BYTE_ALIGN_8);
+ num_bytes += (num_aac_chan *
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(ixheaace_qc_out_channel), BYTE_ALIGN_8));
return num_bytes;
}
@@ -219,25 +224,29 @@ VOID ia_enhaacplus_enc_init_aac_tabs(ixheaace_aac_tables *pstr_aac_tabs) {
static VOID ia_enhaacplus_enc_aac_set_persist_buf(WORD8 *ptr_base, WORD32 num_chan, WORD32 aot) {
iexheaac_encoder_str *pstr_exheaac_encoder;
- WORD8 *ptr_curr_mem = (WORD8 *)((WORD8 *)ptr_base + sizeof(iexheaac_encoder_str));
+ WORD8 *ptr_curr_mem = ptr_base +
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(iexheaac_encoder_str), BYTE_ALIGN_8);
WORD32 i;
pstr_exheaac_encoder = (iexheaac_encoder_str *)ptr_base;
for (i = 0; i < num_chan; i++) {
pstr_exheaac_encoder->psy_out.psy_out_ch[i] = (ixheaace_psy_out_channel *)(ptr_curr_mem);
- ptr_curr_mem = ptr_curr_mem + sizeof(ixheaace_psy_out_channel);
+ ptr_curr_mem = ptr_curr_mem +
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(ixheaace_psy_out_channel), BYTE_ALIGN_8);
}
for (i = 0; i < num_chan; i++) {
pstr_exheaac_encoder->psy_kernel.psy_data[i] = (ixheaace_psy_data *)(ptr_curr_mem);
- ptr_curr_mem = ptr_curr_mem + sizeof(ixheaace_psy_data);
+ ptr_curr_mem = ptr_curr_mem +
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(ixheaace_psy_data), BYTE_ALIGN_8);
}
for (i = 0; i < num_chan; i++) {
pstr_exheaac_encoder->psy_kernel.temporal_noise_shaping_data[i] =
(ixheaace_temporal_noise_shaping_data *)(ptr_curr_mem);
- ptr_curr_mem = ptr_curr_mem + sizeof(ixheaace_temporal_noise_shaping_data);
+ ptr_curr_mem = ptr_curr_mem +
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(ixheaace_temporal_noise_shaping_data), BYTE_ALIGN_8);
}
for (i = 0; i < num_chan; i++) {
@@ -247,21 +256,24 @@ static VOID ia_enhaacplus_enc_aac_set_persist_buf(WORD8 *ptr_base, WORD32 num_ch
case AOT_PS:
pstr_exheaac_encoder->psy_kernel.psy_data[i]->ptr_mdct_delay_buf =
(FLOAT32 *)(ptr_curr_mem);
- ptr_curr_mem = ptr_curr_mem + sizeof(FLOAT32) * BLK_SWITCH_OFFSET_LC_128;
+ ptr_curr_mem = ptr_curr_mem +
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(FLOAT32) * BLK_SWITCH_OFFSET_LC_128, BYTE_ALIGN_8);
break;
case AOT_AAC_LD:
case AOT_AAC_ELD:
pstr_exheaac_encoder->psy_kernel.psy_data[i]->ptr_mdct_delay_buf =
(FLOAT32 *)(ptr_curr_mem);
- ptr_curr_mem = ptr_curr_mem + sizeof(FLOAT32) * BLK_SWITCH_OFFSET_LD;
+ ptr_curr_mem = ptr_curr_mem +
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(FLOAT32) * BLK_SWITCH_OFFSET_LD, BYTE_ALIGN_8);
break;
}
}
for (i = 0; i < num_chan; i++) {
pstr_exheaac_encoder->qc_out.qc_channel[i] = (ixheaace_qc_out_channel *)(ptr_curr_mem);
- ptr_curr_mem = ptr_curr_mem + sizeof(ixheaace_qc_out_channel);
+ ptr_curr_mem = ptr_curr_mem +
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(ixheaace_qc_out_channel), BYTE_ALIGN_8);
}
}
diff --git a/encoder/ixheaace_enc_main.c b/encoder/ixheaace_enc_main.c
index 1c25924..46c7bd5 100644
--- a/encoder/ixheaace_enc_main.c
+++ b/encoder/ixheaace_enc_main.c
@@ -136,11 +136,10 @@ IA_ERRORCODE ia_enhaacplus_enc_aac_core_encode(
err_code = ia_enhaacplus_enc_psy_main(
time_sn_stride, pstr_element_info, ptr_time_signal, aot,
- pstr_aac_encoder->psy_kernel.psy_data[pstr_element_info->channel_index[0]],
- pstr_aac_encoder->psy_kernel
- .temporal_noise_shaping_data[pstr_element_info->channel_index[0]],
+ pstr_aac_encoder->psy_kernel.psy_data,
+ pstr_aac_encoder->psy_kernel.temporal_noise_shaping_data,
&pstr_aac_encoder->psy_kernel.psy_conf_long, &pstr_aac_encoder->psy_kernel.psy_conf_short,
- pstr_aac_encoder->psy_out.psy_out_ch[pstr_element_info->channel_index[0]],
+ pstr_aac_encoder->psy_out.psy_out_ch,
&pstr_aac_encoder->psy_out.psy_out_element,
pstr_aac_encoder->psy_kernel.p_scratch_tns_float,
(FLOAT32 *)pstr_aac_encoder->pstr_aac_scratch->shared_buffer1,
@@ -155,23 +154,22 @@ IA_ERRORCODE ia_enhaacplus_enc_aac_core_encode(
pstr_aac_encoder->config.core_sample_rate, flag_last_element, frame_len_long);
for (ch = 0; ch < pstr_element_info->n_channels_in_el; ch++) {
- pstr_aac_encoder->psy_out.psy_out_ch[pstr_element_info->channel_index[0]][ch].ms_digest =
+ pstr_aac_encoder->psy_out.psy_out_ch[ch]->ms_digest =
pstr_aac_encoder->psy_out.psy_out_element.tools_info.ms_digest;
memcpy(
- &pstr_aac_encoder->psy_out.psy_out_ch[pstr_element_info->channel_index[0]][ch].ms_used[0],
+ &pstr_aac_encoder->psy_out.psy_out_ch[ch]->ms_used[0],
&pstr_aac_encoder->psy_out.psy_out_element.tools_info.ms_mask[0],
MAXIMUM_GROUPED_SCALE_FACTOR_BAND *
- sizeof(pstr_aac_encoder->psy_out.psy_out_ch[pstr_element_info->channel_index[0]][ch]
- .ms_used[0]));
+ sizeof(pstr_aac_encoder->psy_out.psy_out_ch[ch]->ms_used[0]));
}
err_code = ia_enhaacplus_enc_qc_main(
&pstr_aac_encoder->qc_kernel, pstr_element_info->n_channels_in_el,
&pstr_aac_encoder->qc_kernel.element_bits,
- pstr_aac_encoder->psy_out.psy_out_ch[pstr_element_info->channel_index[0]],
+ pstr_aac_encoder->psy_out.psy_out_ch,
&pstr_aac_encoder->psy_out.psy_out_element,
- pstr_aac_encoder->qc_out.qc_channel[pstr_element_info->channel_index[0]],
+ pstr_aac_encoder->qc_out.qc_channel,
&pstr_aac_encoder->qc_out.qc_element, MIN(anc_data_bytes_left, anc_data_bytes),
pstr_aac_tabs, adts_flag, aot, stat_bits_flag, flag_last_element, frame_len_long,
pstr_aac_encoder->pstr_aac_scratch->shared_buffer5, is_quant_spec_zero,
@@ -184,7 +182,7 @@ IA_ERRORCODE ia_enhaacplus_enc_aac_core_encode(
if (pstr_element_info->el_type == ID_CPE) {
if (!pstr_aac_encoder->config.num_stereo_preprocessing) {
iaace_update_stereo_pre_process(
- pstr_aac_encoder->psy_out.psy_out_ch[pstr_element_info->channel_index[0]],
+ pstr_aac_encoder->psy_out.psy_out_ch,
&pstr_aac_encoder->qc_out.qc_element, &pstr_aac_encoder->str_stereo_pre_pro,
pstr_aac_encoder->psy_out.psy_out_element.weight_ms_lr_pe_ratio);
}
diff --git a/encoder/ixheaace_fd_quant.c b/encoder/ixheaace_fd_quant.c
index 4be4670..6d43ab1 100644
--- a/encoder/ixheaace_fd_quant.c
+++ b/encoder/ixheaace_fd_quant.c
@@ -170,7 +170,7 @@ static WORD32 iusace_count_static_bits(ia_usac_data_struct *ptr_usac_data,
stat_bits += ptr_usac_data->str_scratch.ptr_num_fac_bits[i];
}
- stat_bits += ptr_usac_data->num_sbr_bits;
+ stat_bits += (ptr_usac_data->num_sbr_bits + ptr_usac_data->num_drc_bits);
return stat_bits;
}
diff --git a/encoder/ixheaace_ms_stereo.c b/encoder/ixheaace_ms_stereo.c
index bf2f1e2..48ecfce 100644
--- a/encoder/ixheaace_ms_stereo.c
+++ b/encoder/ixheaace_ms_stereo.c
@@ -45,19 +45,19 @@
#include "ixheaace_ms_stereo.h"
#include "ixheaace_common_utils.h"
-VOID iaace_ms_apply(ixheaace_psy_data *ptr_psy_data, FLOAT32 *ptr_spec_left,
+VOID iaace_ms_apply(ixheaace_psy_data **ptr_psy_data, FLOAT32 *ptr_spec_left,
FLOAT32 *ptr_spec_right, WORD32 *ptr_ms_select, WORD32 *ptr_ms_used,
const WORD32 sfb_count, const WORD32 sfb_per_group,
const WORD32 max_sfb_per_grp, const WORD32 *ptr_sfb_offset,
FLOAT32 *ptr_weight_ms_lr_pe_ratio) {
- FLOAT32 *ptr_sfb_enegry_left = ptr_psy_data[0].sfb_energy.long_nrg;
- FLOAT32 *ptr_sfb_energy_right = ptr_psy_data[1].sfb_energy.long_nrg;
- const FLOAT32 *ptr_sfb_energy_mid = ptr_psy_data[0].sfb_energy_ms.long_nrg;
- const FLOAT32 *ptr_sfb_energy_side = ptr_psy_data[1].sfb_energy_ms.long_nrg;
- FLOAT32 *ptr_sfb_thr_left = ptr_psy_data[0].sfb_threshold.long_nrg;
- FLOAT32 *ptr_sfb_thr_right = ptr_psy_data[1].sfb_threshold.long_nrg;
- FLOAT32 *ptr_sfb_spread_energy_left = ptr_psy_data[0].sfb_sreaded_energy.long_nrg;
- FLOAT32 *ptr_sfb_spread_energy_right = ptr_psy_data[1].sfb_sreaded_energy.long_nrg;
+ FLOAT32 *ptr_sfb_enegry_left = ptr_psy_data[0]->sfb_energy.long_nrg;
+ FLOAT32 *ptr_sfb_energy_right = ptr_psy_data[1]->sfb_energy.long_nrg;
+ const FLOAT32 *ptr_sfb_energy_mid = ptr_psy_data[0]->sfb_energy_ms.long_nrg;
+ const FLOAT32 *ptr_sfb_energy_side = ptr_psy_data[1]->sfb_energy_ms.long_nrg;
+ FLOAT32 *ptr_sfb_thr_left = ptr_psy_data[0]->sfb_threshold.long_nrg;
+ FLOAT32 *ptr_sfb_thr_right = ptr_psy_data[1]->sfb_threshold.long_nrg;
+ FLOAT32 *ptr_sfb_spread_energy_left = ptr_psy_data[0]->sfb_sreaded_energy.long_nrg;
+ FLOAT32 *ptr_sfb_spread_energy_right = ptr_psy_data[1]->sfb_sreaded_energy.long_nrg;
WORD32 sfb, sfb_offsets, j;
WORD32 grp = 0;
WORD32 ms_counter = 0;
diff --git a/encoder/ixheaace_ms_stereo.h b/encoder/ixheaace_ms_stereo.h
index 12e7425..834b1ad 100644
--- a/encoder/ixheaace_ms_stereo.h
+++ b/encoder/ixheaace_ms_stereo.h
@@ -20,7 +20,7 @@
#pragma once
-VOID iaace_ms_apply(ixheaace_psy_data *ptr_psy_data, FLOAT32 *ptr_spec_left,
+VOID iaace_ms_apply(ixheaace_psy_data **ptr_psy_data, FLOAT32 *ptr_spec_left,
FLOAT32 *ptr_spec_right, WORD32 *ptr_ms_select, WORD32 *ptr_ms_used,
const WORD32 sfb_count,
diff --git a/encoder/ixheaace_psy_mod.c b/encoder/ixheaace_psy_mod.c
index 013c1db..02ef9ca 100644
--- a/encoder/ixheaace_psy_mod.c
+++ b/encoder/ixheaace_psy_mod.c
@@ -174,17 +174,17 @@ IA_ERRORCODE ia_enhaacplus_enc_psy_main_init(ixheaace_psy_kernel *pstr_h_psy, WO
}
static VOID ia_enhaacplus_enc_advance_psy_long_ms(
- ixheaace_psy_data psy_data[IXHEAACE_MAX_CH_IN_BS_ELE],
+ ixheaace_psy_data **psy_data,
ixheaace_psy_configuration_long *pstr_psy_conf_long) {
ia_enhaacplus_enc_calc_band_energy_ms(
- psy_data[0].ptr_spec_coeffs, psy_data[1].ptr_spec_coeffs, pstr_psy_conf_long->sfb_offsets,
+ psy_data[0]->ptr_spec_coeffs, psy_data[1]->ptr_spec_coeffs, pstr_psy_conf_long->sfb_offsets,
pstr_psy_conf_long->sfb_active, pstr_psy_conf_long->sfb_cnt,
- psy_data[0].sfb_energy_ms.long_nrg, &psy_data[0].sfb_energy_sum_ms.long_nrg,
- psy_data[1].sfb_energy_ms.long_nrg, &psy_data[1].sfb_energy_sum_ms.long_nrg);
+ psy_data[0]->sfb_energy_ms.long_nrg, &psy_data[0]->sfb_energy_sum_ms.long_nrg,
+ psy_data[1]->sfb_energy_ms.long_nrg, &psy_data[1]->sfb_energy_sum_ms.long_nrg);
}
static VOID ia_enhaacplus_enc_advance_psy_short_ms(
- ixheaace_psy_data psy_data[IXHEAACE_MAX_CH_IN_BS_ELE],
+ ixheaace_psy_data **psy_data,
ixheaace_psy_configuration_short *pstr_psy_conf_short, WORD32 ccfl) {
WORD32 w;
WORD32 frame_len_short = FRAME_LEN_SHORT_128;
@@ -196,11 +196,11 @@ static VOID ia_enhaacplus_enc_advance_psy_short_ms(
WORD32 w_offset = w * frame_len_short;
ia_enhaacplus_enc_calc_band_energy_ms(
- psy_data[0].ptr_spec_coeffs + w_offset, psy_data[1].ptr_spec_coeffs + w_offset,
+ psy_data[0]->ptr_spec_coeffs + w_offset, psy_data[1]->ptr_spec_coeffs + w_offset,
pstr_psy_conf_short->sfb_offsets, pstr_psy_conf_short->sfb_active,
- pstr_psy_conf_short->sfb_cnt, psy_data[0].sfb_energy_ms.short_nrg[w],
- &psy_data[0].sfb_energy_sum_ms.short_nrg[w], psy_data[1].sfb_energy_ms.short_nrg[w],
- &psy_data[1].sfb_energy_sum_ms.short_nrg[w]);
+ pstr_psy_conf_short->sfb_cnt, psy_data[0]->sfb_energy_ms.short_nrg[w],
+ &psy_data[0]->sfb_energy_sum_ms.short_nrg[w], psy_data[1]->sfb_energy_ms.short_nrg[w],
+ &psy_data[1]->sfb_energy_sum_ms.short_nrg[w]);
}
}
@@ -461,11 +461,11 @@ static IA_ERRORCODE ia_enhaacplus_enc_advance_psy_long(
IA_ERRORCODE ia_enhaacplus_enc_psy_main(
WORD32 time_sn_stride, ixheaace_element_info *pstr_elem_info, const FLOAT32 *ptr_time_signal,
- WORD32 aot, ixheaace_psy_data psy_data[IXHEAACE_MAX_CH_IN_BS_ELE],
- ixheaace_temporal_noise_shaping_data tns_data[IXHEAACE_MAX_CH_IN_BS_ELE],
+ WORD32 aot, ixheaace_psy_data **psy_data,
+ ixheaace_temporal_noise_shaping_data **tns_data,
ixheaace_psy_configuration_long *pstr_psy_conf_long,
ixheaace_psy_configuration_short *pstr_psy_conf_short,
- ixheaace_psy_out_channel psy_out_ch[IXHEAACE_MAX_CH_IN_BS_ELE],
+ ixheaace_psy_out_channel **psy_out_ch,
ixheaace_psy_out_element *pstr_psy_out_element, FLOAT32 *ptr_scratch_tns,
FLOAT32 *ptr_shared_buffer1, WORD8 *ptr_shared_buffer5, ixheaace_aac_tables *pstr_aac_tables,
WORD32 frame_len_long)
@@ -482,66 +482,71 @@ IA_ERRORCODE ia_enhaacplus_enc_psy_main(
if (aot == AOT_AAC_LC || aot == AOT_SBR || aot == AOT_PS) {
if (pstr_elem_info->el_type != ID_LFE) {
for (ch = 0; ch < num_channels; ch++) {
- iaace_block_switching(&psy_data[ch].blk_switch_cntrl,
+ iaace_block_switching(&psy_data[ch]->blk_switch_cntrl,
ptr_time_signal + pstr_elem_info->channel_index[ch], frame_len_long,
num_channels);
}
} else {
- psy_data[0].blk_switch_cntrl.win_seq = psy_data[1].blk_switch_cntrl.win_seq = LONG_WINDOW;
+ for (ch = 0; ch < num_channels; ch++) {
+ psy_data[ch]->blk_switch_cntrl.win_seq = LONG_WINDOW;
+ }
}
/* synch left and right block type */
- iaace_sync_block_switching(&psy_data[0].blk_switch_cntrl, &psy_data[1].blk_switch_cntrl,
- num_channels);
+ if (num_channels == NUM_CHANS_MONO) {
+ iaace_sync_block_switching(&psy_data[0]->blk_switch_cntrl, NULL, num_channels);
+ }
+ else {
+ iaace_sync_block_switching(&psy_data[0]->blk_switch_cntrl, &psy_data[1]->blk_switch_cntrl,
+ num_channels);
+ }
} else if (aot == AOT_AAC_LD || aot == AOT_AAC_ELD) {
- { psy_data[0].blk_switch_cntrl.win_seq = psy_data[1].blk_switch_cntrl.win_seq = LONG_WINDOW; }
-
for (ch = 0; ch < num_channels; ch++) {
- psy_data[ch].blk_switch_cntrl.win_seq_ld = LONG_WINDOW;
- psy_data[ch].blk_switch_cntrl.next_win_seq_ld = LONG_WINDOW;
- psy_data[ch].blk_switch_cntrl.win_seq = LONG_WINDOW;
- psy_data[ch].blk_switch_cntrl.nxt_win_seq = LONG_WINDOW;
- psy_data[ch].blk_switch_cntrl.total_groups_cnt = 1;
+ psy_data[ch]->blk_switch_cntrl.win_seq_ld = LONG_WINDOW;
+ psy_data[ch]->blk_switch_cntrl.next_win_seq_ld = LONG_WINDOW;
+ psy_data[ch]->blk_switch_cntrl.win_seq = LONG_WINDOW;
+ psy_data[ch]->blk_switch_cntrl.nxt_win_seq = LONG_WINDOW;
+ psy_data[ch]->blk_switch_cntrl.total_groups_cnt = 1;
}
}
/* transform */
for (ch = 0; ch < num_channels; ch++) {
if (aot == AOT_AAC_LC || aot == AOT_SBR || aot == AOT_PS) {
ixheaace_transform_real_lc_ld(
- psy_data[ch].ptr_mdct_delay_buf, ptr_time_signal + pstr_elem_info->channel_index[ch],
- time_sn_stride, psy_data[ch].ptr_spec_coeffs, psy_data[ch].blk_switch_cntrl.win_seq,
+ psy_data[ch]->ptr_mdct_delay_buf, ptr_time_signal + pstr_elem_info->channel_index[ch],
+ time_sn_stride, psy_data[ch]->ptr_spec_coeffs, psy_data[ch]->blk_switch_cntrl.win_seq,
frame_len_long, ptr_shared_buffer5);
} else if (aot == AOT_AAC_LD) {
if (frame_len_long == FRAME_LEN_480) {
ia_enhaacplus_enc_transform_real(
- psy_data[ch].ptr_mdct_delay_buf, ptr_time_signal + pstr_elem_info->channel_index[ch],
- time_sn_stride, psy_data[ch].ptr_spec_coeffs, pstr_aac_tables->pstr_mdct_tab,
+ psy_data[ch]->ptr_mdct_delay_buf, ptr_time_signal + pstr_elem_info->channel_index[ch],
+ time_sn_stride, psy_data[ch]->ptr_spec_coeffs, pstr_aac_tables->pstr_mdct_tab,
ptr_scratch_tns, ptr_shared_buffer5, frame_len_long);
} else {
ixheaace_transform_real_lc_ld(
- psy_data[ch].ptr_mdct_delay_buf, ptr_time_signal + pstr_elem_info->channel_index[ch],
- time_sn_stride, psy_data[ch].ptr_spec_coeffs, psy_data[ch].blk_switch_cntrl.win_seq,
+ psy_data[ch]->ptr_mdct_delay_buf, ptr_time_signal + pstr_elem_info->channel_index[ch],
+ time_sn_stride, psy_data[ch]->ptr_spec_coeffs, psy_data[ch]->blk_switch_cntrl.win_seq,
frame_len_long, ptr_shared_buffer5);
}
} else if (aot == AOT_AAC_ELD) {
if (frame_len_long == FRAME_LEN_480) {
ia_enhaacplus_enc_transform_real(
- psy_data[ch].ptr_mdct_delay_buf, ptr_time_signal + pstr_elem_info->channel_index[ch],
- time_sn_stride, psy_data[ch].ptr_spec_coeffs, pstr_aac_tables->pstr_mdct_tab,
+ psy_data[ch]->ptr_mdct_delay_buf, ptr_time_signal + pstr_elem_info->channel_index[ch],
+ time_sn_stride, psy_data[ch]->ptr_spec_coeffs, pstr_aac_tables->pstr_mdct_tab,
ptr_scratch_tns, ptr_shared_buffer5, frame_len_long);
} else {
ia_enhaacplus_enc_transform_real_eld(
- psy_data[ch].ptr_mdct_delay_buf, ptr_time_signal + pstr_elem_info->channel_index[ch],
- time_sn_stride, psy_data[ch].ptr_spec_coeffs, ptr_shared_buffer5, frame_len_long);
+ psy_data[ch]->ptr_mdct_delay_buf, ptr_time_signal + pstr_elem_info->channel_index[ch],
+ time_sn_stride, psy_data[ch]->ptr_spec_coeffs, ptr_shared_buffer5, frame_len_long);
}
}
}
for (ch = 0; ch < num_channels; ch++) {
- if (psy_data[ch].blk_switch_cntrl.win_seq != SHORT_WINDOW) {
+ if (psy_data[ch]->blk_switch_cntrl.win_seq != SHORT_WINDOW) {
error_code = ia_enhaacplus_enc_advance_psy_long(
- &psy_data[ch], &tns_data[ch], pstr_psy_conf_long, &psy_out_ch[ch], ptr_scratch_tns,
- &tns_data[1 - ch], ch, aot, ptr_shared_buffer1, pstr_aac_tables, frame_len_long);
+ psy_data[ch], tns_data[ch], pstr_psy_conf_long, psy_out_ch[ch], ptr_scratch_tns,
+ tns_data[1 - ch], ch, aot, ptr_shared_buffer1, pstr_aac_tables, frame_len_long);
if (error_code != IA_NO_ERROR) {
return error_code;
@@ -550,7 +555,7 @@ IA_ERRORCODE ia_enhaacplus_enc_psy_main(
for (sfb = pstr_psy_conf_long->sfb_cnt - 1; sfb >= 0; sfb--) {
for (line = pstr_psy_conf_long->sfb_offsets[sfb + 1] - 1;
line >= pstr_psy_conf_long->sfb_offsets[sfb]; line--) {
- if (psy_data[ch].ptr_spec_coeffs[line] != 0) {
+ if (psy_data[ch]->ptr_spec_coeffs[line] != 0) {
break;
}
}
@@ -567,8 +572,8 @@ IA_ERRORCODE ia_enhaacplus_enc_psy_main(
}
} else {
error_code = ia_enhaacplus_enc_advance_psy_short(
- &psy_data[ch], &tns_data[ch], pstr_psy_conf_short, &psy_out_ch[ch], ptr_scratch_tns,
- &tns_data[1 - ch], ch, aot, ptr_shared_buffer1, pstr_aac_tables, frame_len_long / 8);
+ psy_data[ch], tns_data[ch], pstr_psy_conf_short, psy_out_ch[ch], ptr_scratch_tns,
+ tns_data[1 - ch], ch, aot, ptr_shared_buffer1, pstr_aac_tables, frame_len_long / 8);
if (error_code != IA_NO_ERROR) {
return error_code;
@@ -584,15 +589,15 @@ IA_ERRORCODE ia_enhaacplus_enc_psy_main(
/* Group short data (max_sfb for short blocks is determined here) */
if (aot == AOT_AAC_LC || aot == AOT_SBR || aot == AOT_PS) {
for (ch = 0; ch < num_channels; ch++) {
- if (psy_data[ch].blk_switch_cntrl.win_seq == SHORT_WINDOW) {
- iaace_group_short_data(psy_data[ch].ptr_spec_coeffs, ptr_scratch_tns,
- &psy_data[ch].sfb_threshold, &psy_data[ch].sfb_energy,
- &psy_data[ch].sfb_energy_ms, &psy_data[ch].sfb_sreaded_energy,
+ if (psy_data[ch]->blk_switch_cntrl.win_seq == SHORT_WINDOW) {
+ iaace_group_short_data(psy_data[ch]->ptr_spec_coeffs, ptr_scratch_tns,
+ &psy_data[ch]->sfb_threshold, &psy_data[ch]->sfb_energy,
+ &psy_data[ch]->sfb_energy_ms, &psy_data[ch]->sfb_sreaded_energy,
pstr_psy_conf_short->sfb_cnt, pstr_psy_conf_short->sfb_offsets,
pstr_psy_conf_short->sfb_min_snr, grouped_sfb_offset[ch],
&max_sfb_per_grp[ch], grouped_sfb_min_snr[ch],
- psy_data[ch].blk_switch_cntrl.total_groups_cnt,
- psy_data[ch].blk_switch_cntrl.group_len, frame_len_long);
+ psy_data[ch]->blk_switch_cntrl.total_groups_cnt,
+ psy_data[ch]->blk_switch_cntrl.group_len, frame_len_long);
}
}
}
@@ -604,17 +609,18 @@ IA_ERRORCODE ia_enhaacplus_enc_psy_main(
max_sfb_per_grp[0] = max_sfb_per_grp[1] = MAX(max_sfb_per_grp[0], max_sfb_per_grp[1]);
- if (psy_data[0].blk_switch_cntrl.win_seq != SHORT_WINDOW) {
+ if (psy_data[0]->blk_switch_cntrl.win_seq != SHORT_WINDOW) {
iaace_ms_apply(
- psy_data, psy_data[0].ptr_spec_coeffs, psy_data[1].ptr_spec_coeffs,
+ psy_data, psy_data[0]->ptr_spec_coeffs, psy_data[1]->ptr_spec_coeffs,
&pstr_psy_out_element->tools_info.ms_digest, pstr_psy_out_element->tools_info.ms_mask,
pstr_psy_conf_long->sfb_cnt, pstr_psy_conf_long->sfb_cnt, max_sfb_per_grp[0],
pstr_psy_conf_long->sfb_offsets, &pstr_psy_out_element->weight_ms_lr_pe_ratio);
} else {
- iaace_ms_apply(psy_data, psy_data[0].ptr_spec_coeffs, psy_data[1].ptr_spec_coeffs,
+ iaace_ms_apply(psy_data, psy_data[0]->ptr_spec_coeffs, psy_data[1]->ptr_spec_coeffs,
&pstr_psy_out_element->tools_info.ms_digest,
pstr_psy_out_element->tools_info.ms_mask,
- psy_data[0].blk_switch_cntrl.total_groups_cnt * pstr_psy_conf_short->sfb_cnt,
+ psy_data[0]->blk_switch_cntrl.total_groups_cnt *
+ pstr_psy_conf_short->sfb_cnt,
pstr_psy_conf_short->sfb_cnt, max_sfb_per_grp[0], grouped_sfb_offset[0],
&pstr_psy_out_element->weight_ms_lr_pe_ratio);
}
@@ -624,39 +630,41 @@ IA_ERRORCODE ia_enhaacplus_enc_psy_main(
/* Build output */
if (aot == AOT_AAC_LC || aot == AOT_SBR || aot == AOT_PS) {
for (ch = 0; ch < num_channels; ch++) {
- if (psy_data[ch].blk_switch_cntrl.win_seq != SHORT_WINDOW) {
+ if (psy_data[ch]->blk_switch_cntrl.win_seq != SHORT_WINDOW) {
ia_enhaacplus_enc_build_interface(
- psy_data[ch].ptr_spec_coeffs, &psy_data[ch].sfb_threshold, &psy_data[ch].sfb_energy,
- &psy_data[ch].sfb_sreaded_energy, psy_data[ch].sfb_energy_sum,
- psy_data[ch].sfb_energy_sum_ms, psy_data[ch].blk_switch_cntrl.win_seq,
+ psy_data[ch]->ptr_spec_coeffs, &psy_data[ch]->sfb_threshold,
+ &psy_data[ch]->sfb_energy,
+ &psy_data[ch]->sfb_sreaded_energy, psy_data[ch]->sfb_energy_sum,
+ psy_data[ch]->sfb_energy_sum_ms, psy_data[ch]->blk_switch_cntrl.win_seq,
ia_enhaacplus_enc_block_type_to_window_shape_lc[psy_data[ch]
- .blk_switch_cntrl.win_seq],
+ ->blk_switch_cntrl.win_seq],
pstr_psy_conf_long->sfb_cnt, pstr_psy_conf_long->sfb_offsets, max_sfb_per_grp[ch],
- pstr_psy_conf_long->sfb_min_snr, psy_data[ch].blk_switch_cntrl.total_groups_cnt,
- psy_data[ch].blk_switch_cntrl.group_len, &psy_out_ch[ch]);
+ pstr_psy_conf_long->sfb_min_snr, psy_data[ch]->blk_switch_cntrl.total_groups_cnt,
+ psy_data[ch]->blk_switch_cntrl.group_len, psy_out_ch[ch]);
} else {
ia_enhaacplus_enc_build_interface(
- psy_data[ch].ptr_spec_coeffs, &psy_data[ch].sfb_threshold, &psy_data[ch].sfb_energy,
- &psy_data[ch].sfb_sreaded_energy, psy_data[ch].sfb_energy_sum,
- psy_data[ch].sfb_energy_sum_ms, SHORT_WINDOW, SINE_WINDOW,
- psy_data[ch].blk_switch_cntrl.total_groups_cnt * pstr_psy_conf_short->sfb_cnt,
+ psy_data[ch]->ptr_spec_coeffs, &psy_data[ch]->sfb_threshold,
+ &psy_data[ch]->sfb_energy,
+ &psy_data[ch]->sfb_sreaded_energy, psy_data[ch]->sfb_energy_sum,
+ psy_data[ch]->sfb_energy_sum_ms, SHORT_WINDOW, SINE_WINDOW,
+ psy_data[ch]->blk_switch_cntrl.total_groups_cnt * pstr_psy_conf_short->sfb_cnt,
grouped_sfb_offset[ch], max_sfb_per_grp[ch], grouped_sfb_min_snr[ch],
- psy_data[ch].blk_switch_cntrl.total_groups_cnt,
- psy_data[ch].blk_switch_cntrl.group_len, &psy_out_ch[ch]);
+ psy_data[ch]->blk_switch_cntrl.total_groups_cnt,
+ psy_data[ch]->blk_switch_cntrl.group_len, psy_out_ch[ch]);
}
}
} else if (aot == AOT_AAC_LD || aot == AOT_AAC_ELD) {
for (ch = 0; ch < num_channels; ch++) {
ia_enhaacplus_enc_build_interface(
- psy_data[ch].ptr_spec_coeffs, &psy_data[ch].sfb_threshold, &psy_data[ch].sfb_energy,
- &psy_data[ch].sfb_sreaded_energy, psy_data[ch].sfb_energy_sum,
- psy_data[ch].sfb_energy_sum_ms, LONG_WINDOW,
+ psy_data[ch]->ptr_spec_coeffs, &psy_data[ch]->sfb_threshold, &psy_data[ch]->sfb_energy,
+ &psy_data[ch]->sfb_sreaded_energy, psy_data[ch]->sfb_energy_sum,
+ psy_data[ch]->sfb_energy_sum_ms, LONG_WINDOW,
ia_enhaacplus_enc_block_type_to_window_shape_ld[psy_data[ch]
- .blk_switch_cntrl.win_seq_ld],
+ ->blk_switch_cntrl.win_seq_ld],
((aot == AOT_AAC_ELD) ? pstr_psy_conf_long->sfb_active : pstr_psy_conf_long->sfb_cnt),
pstr_psy_conf_long->sfb_offsets, max_sfb_per_grp[ch], pstr_psy_conf_long->sfb_min_snr,
- psy_data[ch].blk_switch_cntrl.total_groups_cnt, psy_data[ch].blk_switch_cntrl.group_len,
- &psy_out_ch[ch]);
+ psy_data[ch]->blk_switch_cntrl.total_groups_cnt,
+ psy_data[ch]->blk_switch_cntrl.group_len, psy_out_ch[ch]);
}
}
return error_code;
diff --git a/encoder/ixheaace_psy_mod.h b/encoder/ixheaace_psy_mod.h
index 59c8461..26a04d0 100644
--- a/encoder/ixheaace_psy_mod.h
+++ b/encoder/ixheaace_psy_mod.h
@@ -39,11 +39,11 @@ IA_ERRORCODE ia_enhaacplus_enc_psy_main_init(ixheaace_psy_kernel *pstr_h_psy, WO
IA_ERRORCODE ia_enhaacplus_enc_psy_main(
WORD32 time_sn_stride, /* total number of channels */
ixheaace_element_info *pstr_elem_info, const FLOAT32 *ptr_time_signal, WORD32 aot,
- ixheaace_psy_data psy_data[IXHEAACE_MAX_CH_IN_BS_ELE],
- ixheaace_temporal_noise_shaping_data tns_data[IXHEAACE_MAX_CH_IN_BS_ELE],
+ ixheaace_psy_data **psy_data,
+ ixheaace_temporal_noise_shaping_data **tns_data,
ixheaace_psy_configuration_long *pstr_psy_conf_long,
ixheaace_psy_configuration_short *pstr_psy_conf_short,
- ixheaace_psy_out_channel psy_out_ch[IXHEAACE_MAX_CH_IN_BS_ELE],
+ ixheaace_psy_out_channel **psy_out_ch,
ixheaace_psy_out_element *pstr_psy_out_element, FLOAT32 *ptr_scratch_tns,
FLOAT32 *ptr_shared_buffer1, WORD8 *ptr_shared_buffer5, ixheaace_aac_tables *pstr_aac_tables,
WORD32 frame_len_long);
diff --git a/encoder/ixheaace_qc_main_hp.c b/encoder/ixheaace_qc_main_hp.c
index 0eae6e6..986bbb7 100644
--- a/encoder/ixheaace_qc_main_hp.c
+++ b/encoder/ixheaace_qc_main_hp.c
@@ -66,12 +66,11 @@
#include "ixheaace_qc_util.h"
#include "ixheaace_common_utils.h"
-#define OPT_QC_STACK
IA_ERRORCODE ia_enhaacplus_enc_qc_main(
ixheaace_qc_state *pstr_qc_state, WORD32 num_channels, ixheaace_element_bits *pstr_el_bits,
- ixheaace_psy_out_channel psy_out_ch[IXHEAACE_MAX_CH_IN_BS_ELE],
+ ixheaace_psy_out_channel **psy_out_ch,
ixheaace_psy_out_element *pstr_psy_out_element,
- ixheaace_qc_out_channel pstr_qc_out_ch[IXHEAACE_MAX_CH_IN_BS_ELE],
+ ixheaace_qc_out_channel **pstr_qc_out_ch,
ixheaace_qc_out_element *pstr_qc_out_element, WORD32 ancillary_data_bytes,
ixheaace_aac_tables *pstr_aac_tables, WORD32 adts_flag, WORD32 aot, WORD32 stat_bits_flag,
WORD32 flag_last_element, WORD32 frame_len_long, WORD8 *ptr_scratch,
@@ -112,7 +111,7 @@ IA_ERRORCODE ia_enhaacplus_enc_qc_main(
for (ch = 0; ch < num_channels; ch++) {
iaace_calc_form_fac_per_chan(ptr_stack->sfb_form_fac[ch],
- ptr_stack->sfb_num_relevant_lines[ch], &psy_out_ch[ch],
+ ptr_stack->sfb_num_relevant_lines[ch], psy_out_ch[ch],
ptr_stack->sfb_ld_energy[ch]);
}
@@ -146,44 +145,46 @@ IA_ERRORCODE ia_enhaacplus_enc_qc_main(
iterations = 0;
gain = 0;
for (spec_idx = 0; spec_idx < frame_len_long; spec_idx++) {
- ptr_stack->exp_spec[spec_idx] = (FLOAT32)psy_out_ch[ch].ptr_spec_coeffs[spec_idx];
- ptr_stack->mdct_spec_float[spec_idx] = (FLOAT32)psy_out_ch[ch].ptr_spec_coeffs[spec_idx];
+ ptr_stack->exp_spec[spec_idx] = (FLOAT32)psy_out_ch[ch]->ptr_spec_coeffs[spec_idx];
+ ptr_stack->mdct_spec_float[spec_idx] = (FLOAT32)psy_out_ch[ch]->ptr_spec_coeffs[spec_idx];
}
do {
WORD32 max_val;
constraints_fulfilled = 1;
WORD32 quant_spec_is_zero = 1;
if (iterations > 0) {
- for (sfb_offs = 0; sfb_offs < psy_out_ch[ch].sfb_count;
- sfb_offs += psy_out_ch[ch].sfb_per_group) {
- for (sfb = 0; sfb < psy_out_ch[ch].max_sfb_per_grp; sfb++) {
- WORD32 scalefactor = pstr_qc_out_ch[ch].scalefactor[sfb + sfb_offs];
- gain = MAX(gain, pstr_qc_out_ch[ch].global_gain - scalefactor);
+ for (sfb_offs = 0; sfb_offs < psy_out_ch[ch]->sfb_count;
+ sfb_offs += psy_out_ch[ch]->sfb_per_group) {
+ for (sfb = 0; sfb < psy_out_ch[ch]->max_sfb_per_grp; sfb++) {
+ WORD32 scalefactor = pstr_qc_out_ch[ch]->scalefactor[sfb + sfb_offs];
+ gain = MAX(gain, pstr_qc_out_ch[ch]->global_gain - scalefactor);
iaace_quantize_lines(
- pstr_qc_out_ch[ch].global_gain - scalefactor,
- psy_out_ch[ch].sfb_offsets[sfb_offs + sfb + 1] -
- psy_out_ch[ch].sfb_offsets[sfb_offs + sfb],
- ptr_stack->exp_spec + psy_out_ch[ch].sfb_offsets[sfb_offs + sfb],
- pstr_qc_out_ch[ch].quant_spec + psy_out_ch[ch].sfb_offsets[sfb_offs + sfb],
- ptr_stack->mdct_spec_float + psy_out_ch[ch].sfb_offsets[sfb_offs + sfb]);
+ pstr_qc_out_ch[ch]->global_gain - scalefactor,
+ psy_out_ch[ch]->sfb_offsets[sfb_offs + sfb + 1] -
+ psy_out_ch[ch]->sfb_offsets[sfb_offs + sfb],
+ ptr_stack->exp_spec + psy_out_ch[ch]->sfb_offsets[sfb_offs + sfb],
+ pstr_qc_out_ch[ch]->quant_spec + psy_out_ch[ch]->sfb_offsets[sfb_offs + sfb],
+ ptr_stack->mdct_spec_float + psy_out_ch[ch]->sfb_offsets[sfb_offs + sfb]);
}
}
}
max_val = iaace_calc_max_val_in_sfb(
- psy_out_ch[ch].sfb_count, psy_out_ch[ch].max_sfb_per_grp, psy_out_ch[ch].sfb_per_group,
- psy_out_ch[ch].sfb_offsets, pstr_qc_out_ch[ch].quant_spec,
- pstr_qc_out_ch[ch].max_val_in_sfb);
+ psy_out_ch[ch]->sfb_count, psy_out_ch[ch]->max_sfb_per_grp,
+ psy_out_ch[ch]->sfb_per_group,
+ psy_out_ch[ch]->sfb_offsets, pstr_qc_out_ch[ch]->quant_spec,
+ pstr_qc_out_ch[ch]->max_val_in_sfb);
if (max_val > MAXIMUM_QUANT) {
constraints_fulfilled = 0;
}
- for (k = 0; ((k < psy_out_ch[ch].sfb_count) && (quant_spec_is_zero));
- k += psy_out_ch[ch].sfb_per_group) {
- for (i = 0; ((i < psy_out_ch[ch].max_sfb_per_grp) && (quant_spec_is_zero)); i++) {
- for (j = psy_out_ch[ch].sfb_offsets[i+k]; j < psy_out_ch[ch].sfb_offsets[i+k+1]; j++) {
- if (pstr_qc_out_ch[ch].quant_spec[j] != 0) {
+ for (k = 0; ((k < psy_out_ch[ch]->sfb_count) && (quant_spec_is_zero));
+ k += psy_out_ch[ch]->sfb_per_group) {
+ for (i = 0; ((i < psy_out_ch[ch]->max_sfb_per_grp) && (quant_spec_is_zero)); i++) {
+ for (j = psy_out_ch[ch]->sfb_offsets[i+k]; j < psy_out_ch[ch]->sfb_offsets[i+k+1]; j++)
+ {
+ if (pstr_qc_out_ch[ch]->quant_spec[j] != 0) {
quant_spec_is_zero = 0;
break;
}
@@ -191,10 +192,11 @@ IA_ERRORCODE ia_enhaacplus_enc_qc_main(
}
}
err_code = ia_enhaacplus_enc_dyn_bitcount(
- pstr_qc_out_ch[ch].quant_spec, pstr_qc_out_ch[ch].max_val_in_sfb,
- pstr_qc_out_ch[ch].scalefactor, psy_out_ch[ch].window_sequence,
- psy_out_ch[ch].sfb_count, psy_out_ch[ch].max_sfb_per_grp, psy_out_ch[ch].sfb_per_group,
- psy_out_ch[ch].sfb_offsets, &pstr_qc_out_ch[ch].section_data,
+ pstr_qc_out_ch[ch]->quant_spec, pstr_qc_out_ch[ch]->max_val_in_sfb,
+ pstr_qc_out_ch[ch]->scalefactor, psy_out_ch[ch]->window_sequence,
+ psy_out_ch[ch]->sfb_count, psy_out_ch[ch]->max_sfb_per_grp,
+ psy_out_ch[ch]->sfb_per_group,
+ psy_out_ch[ch]->sfb_offsets, &pstr_qc_out_ch[ch]->section_data,
pstr_qc_state->side_info_tab_long, pstr_qc_state->side_info_tab_short,
pstr_aac_tables->pstr_huff_tab, pstr_qc_state->qc_scr.shared_buffer_2, aot,
&ch_dyn_bits);
@@ -225,7 +227,7 @@ IA_ERRORCODE ia_enhaacplus_enc_qc_main(
ch_dyn_bits = max_ch_dyn_bits[ch];
}
if (!constraints_fulfilled) {
- pstr_qc_out_ch[ch].global_gain++;
+ pstr_qc_out_ch[ch]->global_gain++;
}
iterations++;
@@ -233,8 +235,8 @@ IA_ERRORCODE ia_enhaacplus_enc_qc_main(
pstr_qc_out_element->dyn_bits_used += ch_dyn_bits;
- pstr_qc_out_ch[ch].grouping_mask = psy_out_ch[ch].grouping_mask;
- pstr_qc_out_ch[ch].win_shape = psy_out_ch[ch].window_shape;
+ pstr_qc_out_ch[ch]->grouping_mask = psy_out_ch[ch]->grouping_mask;
+ pstr_qc_out_ch[ch]->win_shape = psy_out_ch[ch]->window_shape;
}
pstr_adj_thr_elem->dyn_bits_last = pstr_qc_out_element->dyn_bits_used;
diff --git a/encoder/ixheaace_qc_util.h b/encoder/ixheaace_qc_util.h
index 6e971cd..117c6eb 100644
--- a/encoder/ixheaace_qc_util.h
+++ b/encoder/ixheaace_qc_util.h
@@ -32,9 +32,9 @@ IA_ERRORCODE ia_enhaacplus_enc_qc_init(ixheaace_qc_state *pstr_qc_state, WORD32
IA_ERRORCODE ia_enhaacplus_enc_qc_main(
ixheaace_qc_state *pstr_qc_state, WORD32 num_channels, ixheaace_element_bits *pstr_el_bits,
- ixheaace_psy_out_channel psy_out_ch[IXHEAACE_MAX_CH_IN_BS_ELE],
+ ixheaace_psy_out_channel **psy_out_ch,
ixheaace_psy_out_element *pstr_psy_out_element,
- ixheaace_qc_out_channel pstr_qc_out_ch[IXHEAACE_MAX_CH_IN_BS_ELE],
+ ixheaace_qc_out_channel **pstr_qc_out_ch,
ixheaace_qc_out_element *pstr_qc_out_element, WORD32 ancillary_data_bytes,
ixheaace_aac_tables *pstr_aac_tables, WORD32 adts_flag, WORD32 aot, WORD32 stat_bits_flag,
WORD32 flag_last_element, WORD32 frame_len_long, WORD8 *ptr_scratch,
diff --git a/encoder/ixheaace_sbr_env_est.c b/encoder/ixheaace_sbr_env_est.c
index 7f3cc83..4011802 100644
--- a/encoder/ixheaace_sbr_env_est.c
+++ b/encoder/ixheaace_sbr_env_est.c
@@ -1918,115 +1918,108 @@ IA_ERRORCODE ixheaace_extract_sbr_envelope(FLOAT32 *ptr_in_time, FLOAT32 *ptr_co
while (ch < n_in_channels) {
ixheaace_str_sbr_extr_env *pstr_sbr_extract_env = &(pstr_env_ch[ch]->str_sbr_extract_env);
- if (pstr_ps_enc) {
- ixheaace_sbr_analysis_filtering(
- ptr_in_time ? ptr_in_time + ch : NULL, IXHEAACE_MAX_CH_IN_BS_ELE,
- pstr_sbr_extract_env->ptr_r_buffer, pstr_sbr_extract_env->ptr_i_buffer,
- &pstr_env_ch[ch]->str_sbr_qmf, ptr_sbr_tab->ptr_qmf_tab,
- pstr_env_ch[ch]->str_sbr_qmf.num_time_slots * pstr_env_ch[ch]->str_sbr_qmf.rate,
- pstr_sbr_cfg->is_ld_sbr, (FLOAT32 *)ptr_sbr_scratch);
- } else {
- ixheaace_sbr_analysis_filtering(
- ptr_in_time ? ptr_in_time + ch : NULL, time_sn_stride,
- pstr_sbr_extract_env->ptr_r_buffer, pstr_sbr_extract_env->ptr_i_buffer,
- &pstr_env_ch[ch]->str_sbr_qmf, ptr_sbr_tab->ptr_qmf_tab,
- pstr_env_ch[ch]->str_sbr_qmf.num_time_slots * pstr_env_ch[ch]->str_sbr_qmf.rate,
- pstr_sbr_cfg->is_ld_sbr, (FLOAT32 *)ptr_sbr_scratch);
- if ((1 == n_in_channels) && (USAC_SBR == pstr_sbr_cfg->sbr_codec) &&
- (pstr_sbr_hdr->sbr_pvc_active)) {
- ixheaace_pvc_scratch *pstr_pvc_scr = (ixheaace_pvc_scratch *)ptr_sbr_scratch;
- WORD32 ts, bd;
- FLOAT32 nrg_0, nrg_1;
- FLOAT32 *ptr_r_0, *ptr_r_1, *ptr_i_0, *ptr_i_1;
- FLOAT32 *ptr_r_2, *ptr_r_3, *ptr_i_2, *ptr_i_3, nrg_2, nrg_3;
- WORD32 pvc_rate = pstr_env_enc->pstr_pvc_enc->pvc_param.pvc_rate;
-
- // update header_active to send SBR header when previous PVC mode is different from
- // current frame's
- if (pstr_env_enc->str_sbr_hdr.sbr_pvc_mode !=
- pstr_env_enc->pstr_pvc_enc->pvc_param.pvc_mode) {
- pstr_sbr_bs->header_active = 1;
- }
-
- switch (pvc_rate) {
- case 2: {
- for (ts = 0; ts < IXHEAACE_ESBR_PVC_NUM_TS; ts++) {
- ptr_r_0 = pstr_sbr_extract_env->ptr_r_buffer[pvc_rate * ts];
- ptr_r_1 = pstr_sbr_extract_env->ptr_r_buffer[pvc_rate * ts + 1];
- ptr_i_0 = pstr_sbr_extract_env->ptr_i_buffer[pvc_rate * ts];
- ptr_i_1 = pstr_sbr_extract_env->ptr_i_buffer[pvc_rate * ts + 1];
-
- for (bd = 0; bd < MAX_QMF_TIME_SLOTS; bd++) {
- nrg_0 = ptr_r_0[bd] * ptr_r_0[bd] + ptr_i_0[bd] * ptr_i_0[bd];
- nrg_1 = ptr_r_1[bd] * ptr_r_1[bd] + ptr_i_1[bd] * ptr_i_1[bd];
- pstr_pvc_scr->pvc_qmf_high[ts * IXHEAACE_ESBR_PVC_NUM_QMF_BANDS + bd] =
- (nrg_0 + nrg_1) / 2.0f;
- }
- WORD32 num_low_bands = MAX_QMF_TIME_SLOTS >> 1;
- for (bd = 0; bd < num_low_bands; bd++) {
- pstr_pvc_scr->pvc_qmf_low[ts * num_low_bands + bd] =
- pstr_pvc_scr->pvc_qmf_high[ts * IXHEAACE_ESBR_PVC_NUM_QMF_BANDS + bd];
- }
+ ixheaace_sbr_analysis_filtering(
+ ptr_in_time ? ptr_in_time + ch : NULL, time_sn_stride,
+ pstr_sbr_extract_env->ptr_r_buffer, pstr_sbr_extract_env->ptr_i_buffer,
+ &pstr_env_ch[ch]->str_sbr_qmf, ptr_sbr_tab->ptr_qmf_tab,
+ pstr_env_ch[ch]->str_sbr_qmf.num_time_slots * pstr_env_ch[ch]->str_sbr_qmf.rate,
+ pstr_sbr_cfg->is_ld_sbr, (FLOAT32 *)ptr_sbr_scratch,
+ (pstr_ps_enc != NULL && flag_framelength_small));
+
+ if ((1 == n_in_channels) && (USAC_SBR == pstr_sbr_cfg->sbr_codec) &&
+ (pstr_sbr_hdr->sbr_pvc_active)) {
+ ixheaace_pvc_scratch *pstr_pvc_scr = (ixheaace_pvc_scratch *)ptr_sbr_scratch;
+ WORD32 ts, bd;
+ FLOAT32 nrg_0, nrg_1;
+ FLOAT32 *ptr_r_0, *ptr_r_1, *ptr_i_0, *ptr_i_1;
+ FLOAT32 *ptr_r_2, *ptr_r_3, *ptr_i_2, *ptr_i_3, nrg_2, nrg_3;
+ WORD32 pvc_rate = pstr_env_enc->pstr_pvc_enc->pvc_param.pvc_rate;
+
+ // update header_active to send SBR header when previous PVC mode is different from
+ // current frame's
+ if (pstr_env_enc->str_sbr_hdr.sbr_pvc_mode !=
+ pstr_env_enc->pstr_pvc_enc->pvc_param.pvc_mode) {
+ pstr_sbr_bs->header_active = 1;
+ }
+
+ switch (pvc_rate) {
+ case 2: {
+ for (ts = 0; ts < IXHEAACE_ESBR_PVC_NUM_TS; ts++) {
+ ptr_r_0 = pstr_sbr_extract_env->ptr_r_buffer[pvc_rate * ts];
+ ptr_r_1 = pstr_sbr_extract_env->ptr_r_buffer[pvc_rate * ts + 1];
+ ptr_i_0 = pstr_sbr_extract_env->ptr_i_buffer[pvc_rate * ts];
+ ptr_i_1 = pstr_sbr_extract_env->ptr_i_buffer[pvc_rate * ts + 1];
+
+ for (bd = 0; bd < MAX_QMF_TIME_SLOTS; bd++) {
+ nrg_0 = ptr_r_0[bd] * ptr_r_0[bd] + ptr_i_0[bd] * ptr_i_0[bd];
+ nrg_1 = ptr_r_1[bd] * ptr_r_1[bd] + ptr_i_1[bd] * ptr_i_1[bd];
+ pstr_pvc_scr->pvc_qmf_high[ts * IXHEAACE_ESBR_PVC_NUM_QMF_BANDS + bd] =
+ (nrg_0 + nrg_1) / 2.0f;
}
- break;
- }
- case 4: {
- for (ts = 0; ts < IXHEAACE_ESBR_PVC_NUM_TS; ts++) {
- ptr_r_0 = pstr_sbr_extract_env->ptr_r_buffer[pvc_rate * ts];
- ptr_r_1 = pstr_sbr_extract_env->ptr_r_buffer[pvc_rate * ts + 1];
- ptr_r_2 = pstr_sbr_extract_env->ptr_r_buffer[pvc_rate * ts + 2];
- ptr_r_3 = pstr_sbr_extract_env->ptr_r_buffer[pvc_rate * ts + 3];
- ptr_i_0 = pstr_sbr_extract_env->ptr_i_buffer[pvc_rate * ts];
- ptr_i_1 = pstr_sbr_extract_env->ptr_i_buffer[pvc_rate * ts + 1];
- ptr_i_2 = pstr_sbr_extract_env->ptr_i_buffer[pvc_rate * ts + 2];
- ptr_i_3 = pstr_sbr_extract_env->ptr_i_buffer[pvc_rate * ts + 3];
-
- for (bd = 0; bd < MAX_QMF_TIME_SLOTS; bd++) {
- nrg_0 = ptr_r_0[bd] * ptr_r_0[bd] + ptr_i_0[bd] * ptr_i_0[bd];
- nrg_1 = ptr_r_1[bd] * ptr_r_1[bd] + ptr_i_1[bd] * ptr_i_1[bd];
- nrg_2 = ptr_r_2[bd] * ptr_r_2[bd] + ptr_i_2[bd] * ptr_i_2[bd];
- nrg_3 = ptr_r_3[bd] * ptr_r_3[bd] + ptr_i_3[bd] * ptr_i_3[bd];
- pstr_pvc_scr->pvc_qmf_high[ts * IXHEAACE_ESBR_PVC_NUM_QMF_BANDS + bd] =
- (nrg_0 + nrg_1 + nrg_2 + nrg_3) / 4.0f;
- }
- WORD32 num_low_bands = (MAX_QMF_TIME_SLOTS >> 2);
- for (bd = 0; bd < num_low_bands; bd++) {
- pstr_pvc_scr->pvc_qmf_low[ts * num_low_bands + bd] =
- pstr_pvc_scr->pvc_qmf_high[ts * IXHEAACE_ESBR_PVC_NUM_QMF_BANDS + bd];
- }
+ WORD32 num_low_bands = MAX_QMF_TIME_SLOTS >> 1;
+ for (bd = 0; bd < num_low_bands; bd++) {
+ pstr_pvc_scr->pvc_qmf_low[ts * num_low_bands + bd] =
+ pstr_pvc_scr->pvc_qmf_high[ts * IXHEAACE_ESBR_PVC_NUM_QMF_BANDS + bd];
}
- break;
}
+ break;
}
- pstr_env_enc->pstr_pvc_enc->pvc_param.usac_indep_flag = pstr_sbr_bs->usac_indep_flag;
- err_code = ixheaace_pvc_encode_frame(
- pstr_env_enc->pstr_pvc_enc, (UWORD8)pstr_env_enc->str_sbr_hdr.sbr_pvc_mode,
- pstr_pvc_scr->pvc_qmf_low, pstr_pvc_scr->pvc_qmf_high,
- pstr_sbr_cfg->ptr_v_k_master[0],
- pstr_sbr_cfg->ptr_v_k_master[pstr_sbr_cfg->num_master] - 1);
- if (err_code) {
- return err_code;
+ case 4: {
+ for (ts = 0; ts < IXHEAACE_ESBR_PVC_NUM_TS; ts++) {
+ ptr_r_0 = pstr_sbr_extract_env->ptr_r_buffer[pvc_rate * ts];
+ ptr_r_1 = pstr_sbr_extract_env->ptr_r_buffer[pvc_rate * ts + 1];
+ ptr_r_2 = pstr_sbr_extract_env->ptr_r_buffer[pvc_rate * ts + 2];
+ ptr_r_3 = pstr_sbr_extract_env->ptr_r_buffer[pvc_rate * ts + 3];
+ ptr_i_0 = pstr_sbr_extract_env->ptr_i_buffer[pvc_rate * ts];
+ ptr_i_1 = pstr_sbr_extract_env->ptr_i_buffer[pvc_rate * ts + 1];
+ ptr_i_2 = pstr_sbr_extract_env->ptr_i_buffer[pvc_rate * ts + 2];
+ ptr_i_3 = pstr_sbr_extract_env->ptr_i_buffer[pvc_rate * ts + 3];
+
+ for (bd = 0; bd < MAX_QMF_TIME_SLOTS; bd++) {
+ nrg_0 = ptr_r_0[bd] * ptr_r_0[bd] + ptr_i_0[bd] * ptr_i_0[bd];
+ nrg_1 = ptr_r_1[bd] * ptr_r_1[bd] + ptr_i_1[bd] * ptr_i_1[bd];
+ nrg_2 = ptr_r_2[bd] * ptr_r_2[bd] + ptr_i_2[bd] * ptr_i_2[bd];
+ nrg_3 = ptr_r_3[bd] * ptr_r_3[bd] + ptr_i_3[bd] * ptr_i_3[bd];
+ pstr_pvc_scr->pvc_qmf_high[ts * IXHEAACE_ESBR_PVC_NUM_QMF_BANDS + bd] =
+ (nrg_0 + nrg_1 + nrg_2 + nrg_3) / 4.0f;
+ }
+ WORD32 num_low_bands = (MAX_QMF_TIME_SLOTS >> 2);
+ for (bd = 0; bd < num_low_bands; bd++) {
+ pstr_pvc_scr->pvc_qmf_low[ts * num_low_bands + bd] =
+ pstr_pvc_scr->pvc_qmf_high[ts * IXHEAACE_ESBR_PVC_NUM_QMF_BANDS + bd];
+ }
+ }
+ break;
}
-
- memcpy(&pstr_env_ch[ch]->enc_env_data.pvc_info, &pstr_env_enc->pstr_pvc_enc->pvc_bs_info,
- sizeof(ixheaace_pvc_bs_info));
+ }
+ pstr_env_enc->pstr_pvc_enc->pvc_param.usac_indep_flag = pstr_sbr_bs->usac_indep_flag;
+ err_code = ixheaace_pvc_encode_frame(
+ pstr_env_enc->pstr_pvc_enc, (UWORD8)pstr_env_enc->str_sbr_hdr.sbr_pvc_mode,
+ pstr_pvc_scr->pvc_qmf_low, pstr_pvc_scr->pvc_qmf_high,
+ pstr_sbr_cfg->ptr_v_k_master[0],
+ pstr_sbr_cfg->ptr_v_k_master[pstr_sbr_cfg->num_master] - 1);
+ if (err_code) {
+ return err_code;
}
- // COPY generated spectrum for inter-TES encoder
- if ((USAC_SBR == pstr_sbr_cfg->sbr_codec) && (1 == pstr_sbr_hdr->sbr_inter_tes_active)) {
- WORD32 ts, num_ts, delay;
- num_ts = pstr_env_ch[ch]->str_sbr_qmf.num_time_slots;
+ memcpy(&pstr_env_ch[ch]->enc_env_data.pvc_info, &pstr_env_enc->pstr_pvc_enc->pvc_bs_info,
+ sizeof(ixheaace_pvc_bs_info));
+ }
- ixheaace_str_inter_tes_params *pstr_tes_enc = &pstr_env_ch[ch]->str_inter_tes_enc;
- delay = pstr_tes_enc->op_delay + pstr_tes_enc->codec_delay + IXHEAACE_SBR_HF_ADJ_OFFSET;
- ts = 0;
- while (ts < num_ts) {
- memcpy(pstr_tes_enc->qmf_buf_real[delay + ts], pstr_sbr_extract_env->ptr_r_buffer[ts],
- IXHEAACE_QMF_CHANNELS * sizeof(pstr_tes_enc->qmf_buf_real[0][0]));
- memcpy(pstr_tes_enc->qmf_buf_imag[delay + ts], pstr_sbr_extract_env->ptr_i_buffer[ts],
- IXHEAACE_QMF_CHANNELS * sizeof(pstr_tes_enc->qmf_buf_imag[0][0]));
- ts++;
- }
+ // COPY generated spectrum for inter-TES encoder
+ if ((USAC_SBR == pstr_sbr_cfg->sbr_codec) && (1 == pstr_sbr_hdr->sbr_inter_tes_active)) {
+ WORD32 ts, num_ts, delay;
+ num_ts = pstr_env_ch[ch]->str_sbr_qmf.num_time_slots;
+
+ ixheaace_str_inter_tes_params *pstr_tes_enc = &pstr_env_ch[ch]->str_inter_tes_enc;
+ delay = pstr_tes_enc->op_delay + pstr_tes_enc->codec_delay + IXHEAACE_SBR_HF_ADJ_OFFSET;
+ ts = 0;
+ while (ts < num_ts) {
+ memcpy(pstr_tes_enc->qmf_buf_real[delay + ts], pstr_sbr_extract_env->ptr_r_buffer[ts],
+ IXHEAACE_QMF_CHANNELS * sizeof(pstr_tes_enc->qmf_buf_real[0][0]));
+ memcpy(pstr_tes_enc->qmf_buf_imag[delay + ts], pstr_sbr_extract_env->ptr_i_buffer[ts],
+ IXHEAACE_QMF_CHANNELS * sizeof(pstr_tes_enc->qmf_buf_imag[0][0]));
+ ts++;
}
}
diff --git a/encoder/ixheaace_sbr_frame_info_gen.c b/encoder/ixheaace_sbr_frame_info_gen.c
index 45eb3aa..1265470 100644
--- a/encoder/ixheaace_sbr_frame_info_gen.c
+++ b/encoder/ixheaace_sbr_frame_info_gen.c
@@ -945,6 +945,9 @@ ixheaace_frame_info_generator(ixheaace_pstr_sbr_env_frame pstr_sbr_env_frame,
ixheaace_freq_res *ptr_tuning_freq = (ixheaace_freq_res *)(ptr_v_tuning + 3);
ixheaace_freq_res freq_res_fix = pstr_sbr_env_frame->freq_res_fix;
+ if (pstr_sbr_env_frame->use_low_freq_res == 1) {
+ freq_res_fix = FREQ_RES_LOW;
+ }
if (is_ld_sbr) {
if ((!tran_flag && ptr_v_pre_transient_info[1]) &&
(num_time_slots - ptr_v_pre_transient_info[0] < 4)) {
@@ -1108,7 +1111,8 @@ ixheaace_frame_info_generator(ixheaace_pstr_sbr_env_frame pstr_sbr_env_frame,
case IXHEAACE_LD_TRAN: {
ixheaace_create_ld_transient_frame_info(&pstr_sbr_env_frame->sbr_frame_info,
&pstr_sbr_env_frame->sbr_grid, tran_pos,
- num_time_slots, 0);
+ num_time_slots,
+ pstr_sbr_env_frame->use_low_freq_res);
} break;
default:
break;
@@ -1122,7 +1126,8 @@ ixheaace_frame_info_generator(ixheaace_pstr_sbr_env_frame pstr_sbr_env_frame,
VOID ixheaace_create_frame_info_generator(ixheaace_pstr_sbr_env_frame pstr_sbr_env_frame,
WORD32 allow_spread, WORD32 num_env_static,
- WORD32 static_framing, ixheaace_freq_res freq_res_fix) {
+ WORD32 static_framing, ixheaace_freq_res freq_res_fix,
+ WORD32 use_low_freq_res) {
memset(pstr_sbr_env_frame, 0, sizeof(ixheaace_str_sbr_env_frame));
pstr_sbr_env_frame->frame_type_old = IXHEAACE_FIXFIX;
@@ -1132,6 +1137,7 @@ VOID ixheaace_create_frame_info_generator(ixheaace_pstr_sbr_env_frame pstr_sbr_e
pstr_sbr_env_frame->num_env_static = num_env_static;
pstr_sbr_env_frame->static_framing = static_framing;
pstr_sbr_env_frame->freq_res_fix = freq_res_fix;
+ pstr_sbr_env_frame->use_low_freq_res = use_low_freq_res;
pstr_sbr_env_frame->length_v_bord = 0;
pstr_sbr_env_frame->length_v_bord_follow = 0;
diff --git a/encoder/ixheaace_sbr_frame_info_gen.h b/encoder/ixheaace_sbr_frame_info_gen.h
index cc63173..7f74e4e 100644
--- a/encoder/ixheaace_sbr_frame_info_gen.h
+++ b/encoder/ixheaace_sbr_frame_info_gen.h
@@ -84,13 +84,15 @@ typedef struct {
WORD32 length_v_freq_follow;
ixheaace_str_sbr_grid sbr_grid;
ixheaace_str_frame_info_sbr sbr_frame_info;
+ WORD32 use_low_freq_res;
} ixheaace_str_sbr_env_frame;
typedef ixheaace_str_sbr_env_frame *ixheaace_pstr_sbr_env_frame;
VOID ixheaace_create_frame_info_generator(ixheaace_pstr_sbr_env_frame sbr_env_frame_handle,
WORD32 allow_spread, WORD32 num_env_static,
- WORD32 static_framing, ixheaace_freq_res freq_res_fix);
+ WORD32 static_framing, ixheaace_freq_res freq_res_fix,
+ WORD32 use_low_freq_res);
IA_ERRORCODE
ixheaace_frame_info_generator(ixheaace_pstr_sbr_env_frame pstr_sbr_env_frame,
diff --git a/encoder/ixheaace_sbr_main.c b/encoder/ixheaace_sbr_main.c
index 62919f2..ba8fd00 100644
--- a/encoder/ixheaace_sbr_main.c
+++ b/encoder/ixheaace_sbr_main.c
@@ -276,7 +276,8 @@ static IA_ERRORCODE ixheaace_create_env_channel(
}
ixheaace_create_frame_info_generator(&pstr_env->str_sbr_env_frame, params->spread, e,
- params->stat, pstr_env->enc_env_data.freq_res_fix);
+ params->stat, pstr_env->enc_env_data.freq_res_fix,
+ params->use_low_freq_res);
ixheaace_create_sbr_transient_detector(
&pstr_env->str_sbr_trans_detector, pstr_sbr_cfg->sample_freq,
@@ -502,8 +503,23 @@ VOID ixheaace_adjust_sbr_settings(const ixheaace_pstr_sbr_cfg pstr_config, UWORD
break;
}
}
+
if (pstr_config->sbr_codec == ELD_SBR) {
pstr_config->send_header_data_time = -1;
+ if ((num_ch == NUM_CHANS_MONO) && (bit_rate <= 22000)) {
+ pstr_config->use_low_freq_res = 1;
+ }
+ if ((num_ch == NUM_CHANS_STEREO) && (bit_rate <= 48000)) {
+ pstr_config->use_low_freq_res = 1;
+ }
+ }
+ else {
+ if ((num_ch == NUM_CHANS_MONO) && (bit_rate <= 18000)) {
+ pstr_config->use_low_freq_res = 1;
+ }
+ if ((num_ch == NUM_CHANS_STEREO) && (bit_rate <= 28000)) {
+ pstr_config->use_low_freq_res = 1;
+ }
}
if (bit_rate <= 20000) {
pstr_config->parametric_coding = 0;
@@ -565,6 +581,7 @@ VOID ixheaace_initialize_sbr_defaults(ixheaace_pstr_sbr_cfg pstr_config) {
pstr_config->sbr_pvc_active = 0;
pstr_config->sbr_harmonic = 0;
pstr_config->sbr_ratio_idx = 0; // NO_SBR
+ pstr_config->use_low_freq_res = 0;
}
static IA_ERRORCODE ia_enhaacplus_enc_update_freq_band_tab(
@@ -739,107 +756,120 @@ VOID ixheaace_sbr_set_scratch_ptr(ixheaace_pstr_sbr_enc pstr_env_enc, VOID *ptr_
WORD32 ixheaace_sbr_enc_pers_size(WORD32 num_ch, WORD32 use_ps, WORD32 harmonic_sbr) {
WORD32 num_bytes;
- num_bytes = sizeof(struct ixheaace_str_sbr_enc);
- num_bytes += sizeof(struct ixheaace_str_enc_channel) * num_ch;
- num_bytes += sizeof(ixheaace_pvc_enc);
- num_bytes += 2 * sizeof(FLOAT32) * num_ch * QMF_FILTER_LENGTH;
+ num_bytes = IXHEAACE_GET_SIZE_ALIGNED(sizeof(struct ixheaace_str_sbr_enc), BYTE_ALIGN_8);
+ num_bytes += (IXHEAACE_GET_SIZE_ALIGNED(sizeof(struct ixheaace_str_enc_channel), BYTE_ALIGN_8) *
+ num_ch);
+ num_bytes += IXHEAACE_GET_SIZE_ALIGNED(sizeof(ixheaace_pvc_enc), BYTE_ALIGN_8);
+ num_bytes += (IXHEAACE_GET_SIZE_ALIGNED(2 * sizeof(FLOAT32) * QMF_FILTER_LENGTH, BYTE_ALIGN_8) *
+ num_ch);
if (1 == harmonic_sbr) {
- num_bytes += sizeof(ixheaace_str_hbe_enc) * num_ch;
- num_bytes += sizeof(ixheaace_str_esbr_hbe_txposer) * num_ch;
- num_bytes += IXHEAACE_MAX_HBE_PERSISTENT_SIZE * num_ch;
- num_bytes += ESBR_RESAMP_SAMPLES * sizeof(FLOAT32);
+ num_bytes += (IXHEAACE_GET_SIZE_ALIGNED(sizeof(ixheaace_str_hbe_enc), BYTE_ALIGN_8) * num_ch);
+ num_bytes += (IXHEAACE_GET_SIZE_ALIGNED(sizeof(ixheaace_str_esbr_hbe_txposer), BYTE_ALIGN_8) *
+ num_ch);
+ num_bytes += (IXHEAACE_GET_SIZE_ALIGNED(IXHEAACE_MAX_HBE_PERSISTENT_SIZE, BYTE_ALIGN_8) *
+ num_ch);
+ num_bytes += IXHEAACE_GET_SIZE_ALIGNED(ESBR_RESAMP_SAMPLES * sizeof(FLOAT32), BYTE_ALIGN_8);
}
- num_bytes += sizeof(FLOAT32) * num_ch * 5 * NO_OF_ESTIMATES * MAXIMUM_FREQ_COEFFS;
+ num_bytes += (IXHEAACE_GET_SIZE_ALIGNED(sizeof(FLOAT32) * 5 * NO_OF_ESTIMATES *
+ MAXIMUM_FREQ_COEFFS, BYTE_ALIGN_8) * num_ch);
- num_bytes += sizeof(FLOAT32) * num_ch * MAX_QMF_TIME_SLOTS * IXHEAACE_QMF_CHANNELS;
+ num_bytes += (IXHEAACE_GET_SIZE_ALIGNED(sizeof(FLOAT32) * MAX_QMF_TIME_SLOTS *
+ IXHEAACE_QMF_CHANNELS, BYTE_ALIGN_8) * num_ch);
if (use_ps) {
- num_bytes += sizeof(struct ixheaace_str_enc_channel);
- num_bytes += sizeof(struct ixheaace_ps_enc);
- num_bytes += sizeof(FLOAT32) * QMF_FILTER_LENGTH;
+ num_bytes += IXHEAACE_GET_SIZE_ALIGNED(sizeof(struct ixheaace_str_enc_channel), BYTE_ALIGN_8);
+ num_bytes += IXHEAACE_GET_SIZE_ALIGNED(sizeof(struct ixheaace_ps_enc), BYTE_ALIGN_8);
+ num_bytes += IXHEAACE_GET_SIZE_ALIGNED(sizeof(FLOAT32) * QMF_FILTER_LENGTH, BYTE_ALIGN_8);
- num_bytes += sizeof(WORD32) * 5 * NO_OF_ESTIMATES * MAXIMUM_FREQ_COEFFS;
+ num_bytes += IXHEAACE_GET_SIZE_ALIGNED(sizeof(WORD32) * 5 * NO_OF_ESTIMATES *
+ MAXIMUM_FREQ_COEFFS, BYTE_ALIGN_8);
/*shared between spectral_band_replication_envYBuffer_fix and IIC IDD PS data buffers*/
- num_bytes += sizeof(WORD32) * IXHEAACE_QMF_TIME_SLOTS * IXHEAACE_QMF_CHANNELS;
+ num_bytes += IXHEAACE_GET_SIZE_ALIGNED(sizeof(WORD32) * IXHEAACE_QMF_TIME_SLOTS *
+ IXHEAACE_QMF_CHANNELS, BYTE_ALIGN_8);
}
- num_bytes += sizeof(ixheaace_str_sbr_qmf_filter_bank);
- num_bytes = IXHEAACE_GET_SIZE_ALIGNED(num_bytes, BYTE_ALIGN_8);
+ num_bytes += IXHEAACE_GET_SIZE_ALIGNED(sizeof(ixheaace_str_sbr_qmf_filter_bank), BYTE_ALIGN_8);
return num_bytes;
}
VOID ia_enhaacplus_enc_sbr_set_persist_buf(WORD8 *ptr_base, WORD32 num_ch, WORD32 use_ps,
WORD32 harmonic_sbr) {
struct ixheaace_str_sbr_enc *pstr_env_enc;
- WORD8 *ptr_curr_mem = (WORD8 *)((WORD8 *)ptr_base + sizeof(struct ixheaace_str_sbr_enc));
+ WORD8 *ptr_curr_mem = ptr_base +
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(struct ixheaace_str_sbr_enc), BYTE_ALIGN_8);
WORD32 i;
pstr_env_enc = (struct ixheaace_str_sbr_enc *)ptr_base;
for (i = 0; i < num_ch; i++) {
pstr_env_enc->pstr_env_channel[i] = (struct ixheaace_str_enc_channel *)(ptr_curr_mem);
- ptr_curr_mem = ptr_curr_mem + sizeof(struct ixheaace_str_enc_channel);
+ ptr_curr_mem = ptr_curr_mem +
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(struct ixheaace_str_enc_channel), BYTE_ALIGN_8);
}
for (i = 0; i < num_ch; i++) {
pstr_env_enc->pstr_env_channel[i]->str_sbr_qmf.ptr_sbr_qmf_states_ana =
(FLOAT32 *)ptr_curr_mem;
- ptr_curr_mem +=
+ ptr_curr_mem += IXHEAACE_GET_SIZE_ALIGNED(
sizeof(pstr_env_enc->pstr_env_channel[i]->str_sbr_qmf.ptr_sbr_qmf_states_ana[0]) *
- QMF_FILTER_LENGTH;
+ QMF_FILTER_LENGTH, BYTE_ALIGN_8);
}
if (!use_ps) {
pstr_env_enc->ptr_common_buffer1 = (WORD32 *)ptr_curr_mem;
- ptr_curr_mem += sizeof(pstr_env_enc->ptr_common_buffer1[0]) * num_ch * 5 * NO_OF_ESTIMATES *
- MAXIMUM_FREQ_COEFFS;
+ ptr_curr_mem += IXHEAACE_GET_SIZE_ALIGNED(sizeof(pstr_env_enc->ptr_common_buffer1[0]) *
+ num_ch * 5 * NO_OF_ESTIMATES * MAXIMUM_FREQ_COEFFS, BYTE_ALIGN_8);
pstr_env_enc->ptr_common_buffer2 = (WORD32 *)ptr_curr_mem;
- ptr_curr_mem += sizeof(pstr_env_enc->ptr_common_buffer2[0]) * num_ch * MAX_QMF_TIME_SLOTS *
- IXHEAACE_QMF_CHANNELS;
+ ptr_curr_mem += IXHEAACE_GET_SIZE_ALIGNED(sizeof(pstr_env_enc->ptr_common_buffer2[0]) *
+ num_ch * MAX_QMF_TIME_SLOTS * IXHEAACE_QMF_CHANNELS, BYTE_ALIGN_8);
} else {
pstr_env_enc->ptr_common_buffer1 = (WORD32 *)ptr_curr_mem;
- ptr_curr_mem += 2 * sizeof(pstr_env_enc->ptr_common_buffer1[0]) * 5 * NO_OF_ESTIMATES *
- MAXIMUM_FREQ_COEFFS;
+ ptr_curr_mem += IXHEAACE_GET_SIZE_ALIGNED(2 * sizeof(pstr_env_enc->ptr_common_buffer1[0]) *
+ 5 * NO_OF_ESTIMATES * MAXIMUM_FREQ_COEFFS, BYTE_ALIGN_8);
pstr_env_enc->ptr_common_buffer2 = (WORD32 *)ptr_curr_mem;
- ptr_curr_mem += 2 * sizeof(pstr_env_enc->ptr_common_buffer2[0]) * IXHEAACE_QMF_TIME_SLOTS *
- IXHEAACE_QMF_CHANNELS;
+ ptr_curr_mem += IXHEAACE_GET_SIZE_ALIGNED(2 * sizeof(pstr_env_enc->ptr_common_buffer2[0]) *
+ IXHEAACE_QMF_TIME_SLOTS * IXHEAACE_QMF_CHANNELS, BYTE_ALIGN_8);
}
// PVC encoder
pstr_env_enc->pstr_pvc_enc = (ixheaace_pvc_enc *)ptr_curr_mem;
- ptr_curr_mem = ptr_curr_mem + sizeof(ixheaace_pvc_enc);
+ ptr_curr_mem = ptr_curr_mem + IXHEAACE_GET_SIZE_ALIGNED(sizeof(ixheaace_pvc_enc), BYTE_ALIGN_8);
// Harmonic SBR
if (1 == harmonic_sbr) {
for (i = 0; i < num_ch; i++) {
pstr_env_enc->pstr_env_channel[i]->pstr_hbe_enc = (ixheaace_str_hbe_enc *)ptr_curr_mem;
- ptr_curr_mem = ptr_curr_mem + sizeof(ixheaace_str_hbe_enc);
+ ptr_curr_mem = ptr_curr_mem +
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(ixheaace_str_hbe_enc), BYTE_ALIGN_8);
pstr_env_enc->pstr_env_channel[i]->pstr_hbe_enc->pstr_hbe_txposer =
(ixheaace_str_esbr_hbe_txposer *)ptr_curr_mem;
- ptr_curr_mem = ptr_curr_mem + sizeof(ixheaace_str_esbr_hbe_txposer);
+ ptr_curr_mem = ptr_curr_mem +
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(ixheaace_str_esbr_hbe_txposer), BYTE_ALIGN_8);
pstr_env_enc->pstr_env_channel[i]->pstr_hbe_enc->ptr_hbe_txposer_buffers =
(VOID *)ptr_curr_mem;
ptr_curr_mem = ptr_curr_mem + IXHEAACE_MAX_HBE_PERSISTENT_SIZE;
}
pstr_env_enc->ptr_hbe_resample_buf = (FLOAT32 *)ptr_curr_mem;
- ptr_curr_mem =
- ptr_curr_mem + (ESBR_RESAMP_SAMPLES * sizeof(pstr_env_enc->ptr_hbe_resample_buf[0]));
+ ptr_curr_mem = ptr_curr_mem + IXHEAACE_GET_SIZE_ALIGNED(
+ (ESBR_RESAMP_SAMPLES * sizeof(pstr_env_enc->ptr_hbe_resample_buf[0])), BYTE_ALIGN_8);
}
if (use_ps) {
pstr_env_enc->pstr_env_channel[1] = (struct ixheaace_str_enc_channel *)(ptr_curr_mem);
- ptr_curr_mem = ptr_curr_mem + sizeof(struct ixheaace_str_enc_channel);
+ ptr_curr_mem = ptr_curr_mem +
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(struct ixheaace_str_enc_channel), BYTE_ALIGN_8);
memset(pstr_env_enc->pstr_env_channel[1], 0, sizeof(struct ixheaace_str_enc_channel));
pstr_env_enc->pstr_env_channel[1]->str_sbr_qmf.ptr_sbr_qmf_states_ana =
(FLOAT32 *)ptr_curr_mem;
- ptr_curr_mem +=
- sizeof(pstr_env_enc->pstr_env_channel[1]->str_sbr_qmf.ptr_sbr_qmf_states_ana[0]) *
- QMF_FILTER_LENGTH;
+ ptr_curr_mem += IXHEAACE_GET_SIZE_ALIGNED(
+ sizeof(pstr_env_enc->pstr_env_channel[1]->str_sbr_qmf.ptr_sbr_qmf_states_ana[0]) *
+ QMF_FILTER_LENGTH, BYTE_ALIGN_8);
memset(pstr_env_enc->pstr_env_channel[1]->str_sbr_qmf.ptr_sbr_qmf_states_ana, 0,
sizeof(pstr_env_enc->pstr_env_channel[1]->str_sbr_qmf.ptr_sbr_qmf_states_ana[0]) *
QMF_FILTER_LENGTH);
pstr_env_enc->pstr_ps_enc = (struct ixheaace_ps_enc *)(ptr_curr_mem);
- ptr_curr_mem = ptr_curr_mem + sizeof(struct ixheaace_ps_enc);
+ ptr_curr_mem = ptr_curr_mem +
+ IXHEAACE_GET_SIZE_ALIGNED(sizeof(struct ixheaace_ps_enc), BYTE_ALIGN_8);
memset(pstr_env_enc->pstr_ps_enc, 0, sizeof(struct ixheaace_ps_enc));
}
pstr_env_enc->pstr_synthesis_qmf_bank = (ixheaace_str_sbr_qmf_filter_bank *)(ptr_curr_mem);
diff --git a/encoder/ixheaace_sbr_main.h b/encoder/ixheaace_sbr_main.h
index e53b972..3603fdf 100644
--- a/encoder/ixheaace_sbr_main.h
+++ b/encoder/ixheaace_sbr_main.h
@@ -84,6 +84,7 @@ typedef struct ixheaace_str_sbr_cfg {
WORD32 sbr_harmonic;
WORD32 hq_esbr;
ixheaace_sbr_codec_type sbr_codec;
+ WORD32 use_low_freq_res;
} ixheaace_str_sbr_cfg, *ixheaace_pstr_sbr_cfg;
typedef struct ixheaace_str_sbr_enc *ixheaace_pstr_sbr_enc;
diff --git a/encoder/ixheaace_sbr_qmf_enc.c b/encoder/ixheaace_sbr_qmf_enc.c
index 281ba31..cfe485f 100644
--- a/encoder/ixheaace_sbr_qmf_enc.c
+++ b/encoder/ixheaace_sbr_qmf_enc.c
@@ -801,7 +801,8 @@ VOID ixheaace_sbr_analysis_filtering(const FLOAT32 *ptr_time_in, WORD32 time_sn_
FLOAT32 **ptr_ana_r, FLOAT32 **ptr_ana_i,
ixheaace_pstr_sbr_qmf_filter_bank pstr_qmf_bank,
ixheaace_str_qmf_tabs *pstr_qmf_tab, WORD32 num_qmf_subsamp,
- WORD32 is_ld_sbr, FLOAT32 *ptr_sbr_scratch) {
+ WORD32 is_ld_sbr, FLOAT32 *ptr_sbr_scratch,
+ WORD32 is_ps_960) {
WORD32 i, k;
const FLOAT32 *ptr_pf_l, *ptr_pf_r;
FLOAT32 *ptr_fp1, *ptr_fp2, *ptr_tmp;
@@ -939,6 +940,12 @@ VOID ixheaace_sbr_analysis_filtering(const FLOAT32 *ptr_time_in, WORD32 time_sn_
pstr_qmf_bank->offset_r = pstr_qmf_bank->ptr_ref_coeff_r - ptr_start_coeff_r;
pstr_qmf_bank->flag = flag;
}
+ if (is_ps_960 == 1) {
+ memset(&ptr_ana_r[num_qmf_subsamp][0], 0, sizeof(ptr_ana_r[num_qmf_subsamp][0]) *
+ IXHEAACE_QMF_CHANNELS * (IXHEAACE_QMF_TIME_SLOTS - num_qmf_subsamp));
+ memset(&ptr_ana_i[num_qmf_subsamp][0], 0, sizeof(ptr_ana_i[num_qmf_subsamp][0]) *
+ IXHEAACE_QMF_CHANNELS * (IXHEAACE_QMF_TIME_SLOTS - num_qmf_subsamp));
+ }
}
VOID ixheaace_get_energy_from_cplx_qmf(
diff --git a/encoder/ixheaace_sbr_qmf_enc.h b/encoder/ixheaace_sbr_qmf_enc.h
index 5a1dcd6..a7d4f48 100644
--- a/encoder/ixheaace_sbr_qmf_enc.h
+++ b/encoder/ixheaace_sbr_qmf_enc.h
@@ -62,7 +62,8 @@ VOID ixheaace_sbr_analysis_filtering(const FLOAT32 *ptr_time_in, WORD32 time_sn_
FLOAT32 **ptr_ana_r, FLOAT32 **ptr_ana_i,
ixheaace_pstr_sbr_qmf_filter_bank pstr_qmf_bank,
ixheaace_str_qmf_tabs *pstr_qmf_tab, WORD32 num_qmf_subsamp,
- WORD32 is_ld_sbr, FLOAT32 *ptr_sbr_scratch);
+ WORD32 is_ld_sbr, FLOAT32 *ptr_sbr_scratch,
+ WORD32 is_ps_960);
VOID ixheaace_create_qmf_bank(ixheaace_pstr_sbr_qmf_filter_bank pstr_sbr_qmf_handle,
ixheaace_str_sbr_tabs *pstr_sbr_tab, WORD32 is_ld_sbr);
diff --git a/encoder/ixheaace_sf_estimation.c b/encoder/ixheaace_sf_estimation.c
index cbd67d0..1a39734 100644
--- a/encoder/ixheaace_sf_estimation.c
+++ b/encoder/ixheaace_sf_estimation.c
@@ -621,8 +621,8 @@ static VOID iaace_assimilate_multiple_scf(ixheaace_psy_out_channel *pstr_psy_out
}
VOID iaace_estimate_scfs_chan(
- ixheaace_psy_out_channel pstr_psy_out[IXHEAACE_MAX_CH_IN_BS_ELE],
- ixheaace_qc_out_channel pstr_qc_out_chan[IXHEAACE_MAX_CH_IN_BS_ELE],
+ ixheaace_psy_out_channel **pstr_psy_out,
+ ixheaace_qc_out_channel **pstr_qc_out_chan,
FLOAT32 sfb_form_factor_ch[IXHEAACE_MAX_CH_IN_BS_ELE][MAXIMUM_GROUPED_SCALE_FACTOR_BAND],
FLOAT32 sfb_num_relevant_lines_ch[][MAXIMUM_GROUPED_SCALE_FACTOR_BAND], WORD32 num_channels,
WORD32 chn, WORD32 frame_len_long) {
@@ -648,19 +648,19 @@ VOID iaace_estimate_scfs_chan(
memset(ptr_exp_spec, 0, frame_len_long * sizeof(ptr_exp_spec[0]));
for (ch = chn; ch < chn + num_channels; ch++) {
- ixheaace_psy_out_channel *pstr_psy_out_chan = &pstr_psy_out[ch];
- pstr_qc_out_chan[ch].global_gain = 0;
+ ixheaace_psy_out_channel *pstr_psy_out_chan = pstr_psy_out[ch];
+ pstr_qc_out_chan[ch]->global_gain = 0;
- memset(pstr_qc_out_chan[ch].scalefactor, 0,
- sizeof(*pstr_qc_out_chan[ch].scalefactor) * pstr_psy_out[ch].sfb_count);
- memset(pstr_qc_out_chan[ch].quant_spec, 0,
- sizeof(*pstr_qc_out_chan[ch].quant_spec) * frame_len_long);
+ memset(pstr_qc_out_chan[ch]->scalefactor, 0,
+ sizeof(*pstr_qc_out_chan[ch]->scalefactor) * pstr_psy_out[ch]->sfb_count);
+ memset(pstr_qc_out_chan[ch]->quant_spec, 0,
+ sizeof(*pstr_qc_out_chan[ch]->quant_spec) * frame_len_long);
- ptr_scalefactor = pstr_qc_out_chan[ch].scalefactor;
- global_gain = &pstr_qc_out_chan[ch].global_gain;
+ ptr_scalefactor = pstr_qc_out_chan[ch]->scalefactor;
+ global_gain = &pstr_qc_out_chan[ch]->global_gain;
ptr_sfb_form_factor = &sfb_form_factor_ch[ch][0];
ptr_sfb_num_relevant_lines_ch = &sfb_num_relevant_lines_ch[ch][0];
- ptr_quant_spec = pstr_qc_out_chan[ch].quant_spec;
+ ptr_quant_spec = pstr_qc_out_chan[ch]->quant_spec;
for (i = 0; i < pstr_psy_out_chan->sfb_count; i++) {
thresh = pstr_psy_out_chan->ptr_sfb_thr[i];
@@ -684,7 +684,7 @@ VOID iaace_estimate_scfs_chan(
min_sf_max_quant[i] = (WORD16)floor(C1_SF + C2_SF * log(max_spec));
scf_int = MAX(scf_int, min_sf_max_quant[i]);
scf_int = MAX(scf_int, MIN_GAIN_INDEX_AAC);
- scf_int = MIN(scf_int, (MAX_GAIN_INDEX_AAC - SCF_COUNT_LIMIT_AAC));
+ scf_int = MIN(scf_int, (MAX_GAIN_INDEX_AAC - SCF_COUNT_LIMIT_AAC - 1));
for (j = 0; j < pstr_psy_out_chan->sfb_offsets[i + 1] - pstr_psy_out_chan->sfb_offsets[i];
j++) {
ptr_exp_spec[pstr_psy_out_chan->sfb_offsets[i] + j] = (FLOAT32)(
@@ -739,7 +739,7 @@ VOID iaace_estimate_scfs_chan(
}
}
- for (i = 0; i < pstr_psy_out[ch].sfb_count; i++) {
+ for (i = 0; i < pstr_psy_out[ch]->sfb_count; i++) {
if ((ptr_scalefactor[i] != MIN_SHRT_VAL) &&
(min_scf + MAX_SCF_DELTA) < ptr_scalefactor[i]) {
ptr_scalefactor[i] = min_scf + MAX_SCF_DELTA;
diff --git a/encoder/ixheaace_sf_estimation.h b/encoder/ixheaace_sf_estimation.h
index ec085d0..954cb89 100644
--- a/encoder/ixheaace_sf_estimation.h
+++ b/encoder/ixheaace_sf_estimation.h
@@ -28,8 +28,8 @@ VOID iaace_calc_form_fac_per_chan(FLOAT32 *ptr_sfb_form_factor,
FLOAT32 *ptr_sfb_ld_energy);
VOID iaace_estimate_scfs_chan(
- ixheaace_psy_out_channel pstr_psy_out_ch[IXHEAACE_MAX_CH_IN_BS_ELE],
- ixheaace_qc_out_channel pstr_qc_out_ch[IXHEAACE_MAX_CH_IN_BS_ELE],
+ ixheaace_psy_out_channel **pstr_psy_out_ch,
+ ixheaace_qc_out_channel **pstr_qc_out_ch,
FLOAT32 sfb_form_factor_ch[IXHEAACE_MAX_CH_IN_BS_ELE][MAXIMUM_GROUPED_SCALE_FACTOR_BAND],
FLOAT32 sfb_num_relevant_lines_ch[][MAXIMUM_GROUPED_SCALE_FACTOR_BAND], WORD32 num_channels,
WORD32 chn, WORD32 frame_len_long);
diff --git a/encoder/ixheaace_static_bits.c b/encoder/ixheaace_static_bits.c
index 9d23afd..3fe26bb 100644
--- a/encoder/ixheaace_static_bits.c
+++ b/encoder/ixheaace_static_bits.c
@@ -132,7 +132,7 @@ static WORD32 ia_enhaacplus_enc_count_tns_bits(
}
WORD32 ia_enhaacplus_enc_count_static_bitdemand(
- ixheaace_psy_out_channel psy_out_ch[IXHEAACE_MAX_CH_IN_BS_ELE],
+ ixheaace_psy_out_channel **psy_out_ch,
ixheaace_psy_out_element *pstr_psy_out_element, WORD32 channels, WORD32 aot, WORD32 adts_flag,
WORD32 stat_bits_flag, WORD32 flag_last_element) {
WORD32 static_bits = 0;
@@ -143,9 +143,9 @@ WORD32 ia_enhaacplus_enc_count_static_bitdemand(
static_bits += SI_ID_BITS + SI_SCE_BITS + SI_ICS_BITS;
- static_bits += ia_enhaacplus_enc_count_tns_bits(&(psy_out_ch[0].tns_info),
- psy_out_ch[0].window_sequence);
- switch (psy_out_ch[0].window_sequence) {
+ static_bits += ia_enhaacplus_enc_count_tns_bits(&(psy_out_ch[0]->tns_info),
+ psy_out_ch[0]->window_sequence);
+ switch (psy_out_ch[0]->window_sequence) {
case LONG_WINDOW:
case START_WINDOW:
case STOP_WINDOW:
@@ -166,10 +166,10 @@ WORD32 ia_enhaacplus_enc_count_static_bitdemand(
static_bits += SI_CPE_MS_MASK_BITS;
static_bits += ia_enhaacplus_enc_count_ms_mask_bits(
- psy_out_ch[0].sfb_count, psy_out_ch[0].sfb_per_group, psy_out_ch[0].max_sfb_per_grp,
+ psy_out_ch[0]->sfb_count, psy_out_ch[0]->sfb_per_group, psy_out_ch[0]->max_sfb_per_grp,
&pstr_psy_out_element->tools_info);
- switch (psy_out_ch[0].window_sequence) {
+ switch (psy_out_ch[0]->window_sequence) {
case LONG_WINDOW:
case START_WINDOW:
case STOP_WINDOW:
@@ -184,8 +184,8 @@ WORD32 ia_enhaacplus_enc_count_static_bitdemand(
}
for (ch = 0; ch < 2; ch++) {
- static_bits += ia_enhaacplus_enc_count_tns_bits(&(psy_out_ch[ch].tns_info),
- psy_out_ch[ch].window_sequence);
+ static_bits += ia_enhaacplus_enc_count_tns_bits(&(psy_out_ch[ch]->tns_info),
+ psy_out_ch[ch]->window_sequence);
}
break;
diff --git a/encoder/ixheaace_static_bits.h b/encoder/ixheaace_static_bits.h
index b1c969b..61cfbc9 100644
--- a/encoder/ixheaace_static_bits.h
+++ b/encoder/ixheaace_static_bits.h
@@ -21,6 +21,6 @@
#pragma once
WORD32 ia_enhaacplus_enc_count_static_bitdemand(
- ixheaace_psy_out_channel psy_out_ch[IXHEAACE_MAX_CH_IN_BS_ELE],
+ ixheaace_psy_out_channel **psy_out_ch,
ixheaace_psy_out_element *pstr_psy_out_element, WORD32 channels, WORD32 aot, WORD32 adts_flag,
WORD32 stat_bits_flag, WORD32 flag_last_element);
diff --git a/encoder/ixheaace_stereo_preproc.c b/encoder/ixheaace_stereo_preproc.c
index a14fe7e..d981406 100644
--- a/encoder/ixheaace_stereo_preproc.c
+++ b/encoder/ixheaace_stereo_preproc.c
@@ -237,17 +237,17 @@ VOID iaace_apply_stereo_preproc(ixheaace_stereo_pre_pro_pstr pstr_stereo_pre_pro
pstr_stereo_pre_pro->average_freq_energy_l + pstr_stereo_pre_pro->average_freq_energy_r;
}
-VOID iaace_update_stereo_pre_process(ixheaace_psy_out_channel *pstr_psy_out,
+VOID iaace_update_stereo_pre_process(ixheaace_psy_out_channel **pstr_psy_out,
ixheaace_qc_out_element *pstr_qc_out,
ixheaace_stereo_pre_pro_pstr pstr_stereo_pre_pro,
FLOAT32 weight_pe_fac) {
if (pstr_stereo_pre_pro->stereo_attenuation_flag) {
FLOAT32 delta = 0.1f;
- pstr_stereo_pre_pro->average_freq_energy_l = pstr_psy_out[0].sfb_sum_lr_energy;
- pstr_stereo_pre_pro->average_freq_energy_r = pstr_psy_out[1].sfb_sum_lr_energy;
- pstr_stereo_pre_pro->average_freq_energy_m = pstr_psy_out[0].sfb_sum_ms_energy;
- pstr_stereo_pre_pro->average_freq_energy_s = pstr_psy_out[1].sfb_sum_ms_energy;
+ pstr_stereo_pre_pro->average_freq_energy_l = pstr_psy_out[0]->sfb_sum_lr_energy;
+ pstr_stereo_pre_pro->average_freq_energy_r = pstr_psy_out[1]->sfb_sum_lr_energy;
+ pstr_stereo_pre_pro->average_freq_energy_m = pstr_psy_out[0]->sfb_sum_ms_energy;
+ pstr_stereo_pre_pro->average_freq_energy_s = pstr_psy_out[1]->sfb_sum_ms_energy;
pstr_stereo_pre_pro->smoothed_pe_sum_sum =
delta * pstr_qc_out->pe * weight_pe_fac +
diff --git a/encoder/ixheaace_stereo_preproc.h b/encoder/ixheaace_stereo_preproc.h
index 9ecb046..58fe76c 100644
--- a/encoder/ixheaace_stereo_preproc.h
+++ b/encoder/ixheaace_stereo_preproc.h
@@ -58,7 +58,7 @@ VOID iaace_apply_stereo_preproc(ixheaace_stereo_pre_pro_pstr pstr_stereo_pre_pro
WORD32 num_channels, ixheaace_element_info *pstr_elem_info,
FLOAT32 *ptr_time_data, WORD32 granule_len);
-VOID iaace_update_stereo_pre_process(ixheaace_psy_out_channel *pstr_psy_out,
+VOID iaace_update_stereo_pre_process(ixheaace_psy_out_channel **pstr_psy_out,
ixheaace_qc_out_element *pstr_qc_out,
ixheaace_stereo_pre_pro_pstr pstr_stereo_pre_pro,
FLOAT32 weight_pe_fac);
diff --git a/fuzzer/xaac_enc_fuzzer.cpp b/fuzzer/xaac_enc_fuzzer.cpp
index 252d898..1952e97 100644
--- a/fuzzer/xaac_enc_fuzzer.cpp
+++ b/fuzzer/xaac_enc_fuzzer.cpp
@@ -34,8 +34,10 @@ extern "C" {
#include "ixheaace_api.h"
}
-static constexpr WORD32 kSampleRates[] = {7350, 8000, 11025, 12000, 16000, 22050, 24000,
+static constexpr WORD32 k_sample_rates[] = {7350, 8000, 11025, 12000, 16000, 22050, 24000,
32000, 44100, 48000, 64000, 88200, 96000};
+static constexpr WORD16 k_frame_length[] = {480, 512, 768, 960, 1024};
+
pVOID malloc_global(UWORD32 size, UWORD32 alignment) {
pVOID ptr = NULL;
if (posix_memalign((VOID **)&ptr, alignment, size)) {
@@ -315,11 +317,15 @@ static VOID ixheaace_fuzzer_flag(ixheaace_input_config *pstr_in_cfg,
pstr_in_cfg->ui_pcm_wd_sz = fuzzed_data->ConsumeIntegral<WORD8>();
pstr_in_cfg->i_channels = fuzzed_data->ConsumeIntegral<WORD8>();
if (fuzzed_data->ConsumeBool()) {
- pstr_in_cfg->i_samp_freq = fuzzed_data->PickValueInArray(kSampleRates);
+ pstr_in_cfg->i_samp_freq = fuzzed_data->PickValueInArray(k_sample_rates);
+ } else {
+ pstr_in_cfg->i_samp_freq = fuzzed_data->ConsumeIntegral<UWORD32>();
+ }
+ if (fuzzed_data->ConsumeBool()) {
+ pstr_in_cfg->frame_length = fuzzed_data->PickValueInArray(k_frame_length);
} else {
- pstr_in_cfg->i_samp_freq = fuzzed_data->ConsumeIntegral<WORD32>();
+ pstr_in_cfg->frame_length = fuzzed_data->ConsumeIntegral<WORD16>();
}
- pstr_in_cfg->frame_length = fuzzed_data->ConsumeIntegral<WORD8>();
pstr_in_cfg->aot = fuzzed_data->ConsumeIntegral<WORD8>();
pstr_in_cfg->esbr_flag = fuzzed_data->ConsumeBool();
pstr_in_cfg->aac_config.full_bandwidth = fuzzed_data->ConsumeBool();