1*15dc779aSAndroid Build Coastguard Worker /******************************************************************************
2*15dc779aSAndroid Build Coastguard Worker * *
3*15dc779aSAndroid Build Coastguard Worker * Copyright (C) 2023 The Android Open Source Project
4*15dc779aSAndroid Build Coastguard Worker *
5*15dc779aSAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License");
6*15dc779aSAndroid Build Coastguard Worker * you may not use this file except in compliance with the License.
7*15dc779aSAndroid Build Coastguard Worker * You may obtain a copy of the License at:
8*15dc779aSAndroid Build Coastguard Worker *
9*15dc779aSAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0
10*15dc779aSAndroid Build Coastguard Worker *
11*15dc779aSAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software
12*15dc779aSAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS,
13*15dc779aSAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14*15dc779aSAndroid Build Coastguard Worker * See the License for the specific language governing permissions and
15*15dc779aSAndroid Build Coastguard Worker * limitations under the License.
16*15dc779aSAndroid Build Coastguard Worker *
17*15dc779aSAndroid Build Coastguard Worker *****************************************************************************
18*15dc779aSAndroid Build Coastguard Worker * Originally developed and contributed by Ittiam Systems Pvt. Ltd, Bangalore
19*15dc779aSAndroid Build Coastguard Worker */
20*15dc779aSAndroid Build Coastguard Worker
21*15dc779aSAndroid Build Coastguard Worker #include <stddef.h>
22*15dc779aSAndroid Build Coastguard Worker #include <string.h>
23*15dc779aSAndroid Build Coastguard Worker #include "ixheaac_type_def.h"
24*15dc779aSAndroid Build Coastguard Worker #include "ixheaac_constants.h"
25*15dc779aSAndroid Build Coastguard Worker #include "impd_drc_common_enc.h"
26*15dc779aSAndroid Build Coastguard Worker #include "impd_drc_uni_drc.h"
27*15dc779aSAndroid Build Coastguard Worker #include "impd_drc_tables.h"
28*15dc779aSAndroid Build Coastguard Worker #include "impd_drc_api.h"
29*15dc779aSAndroid Build Coastguard Worker #include "ixheaace_api.h"
30*15dc779aSAndroid Build Coastguard Worker #include "ixheaac_error_standards.h"
31*15dc779aSAndroid Build Coastguard Worker #include "ixheaace_error_codes.h"
32*15dc779aSAndroid Build Coastguard Worker #include "ixheaace_aac_constants.h"
33*15dc779aSAndroid Build Coastguard Worker #include "ixheaace_adjust_threshold_data.h"
34*15dc779aSAndroid Build Coastguard Worker #include "ixheaace_psy_const.h"
35*15dc779aSAndroid Build Coastguard Worker #include "ixheaace_tns.h"
36*15dc779aSAndroid Build Coastguard Worker #include "ixheaace_tns_params.h"
37*15dc779aSAndroid Build Coastguard Worker #include "ixheaace_rom.h"
38*15dc779aSAndroid Build Coastguard Worker #include "ixheaace_common_rom.h"
39*15dc779aSAndroid Build Coastguard Worker #include "ixheaace_bitbuffer.h"
40*15dc779aSAndroid Build Coastguard Worker
41*15dc779aSAndroid Build Coastguard Worker #include "ixheaace_dynamic_bits.h"
42*15dc779aSAndroid Build Coastguard Worker #include "ixheaace_qc_data.h"
43*15dc779aSAndroid Build Coastguard Worker #include "ixheaace_channel_map.h"
44*15dc779aSAndroid Build Coastguard Worker #include "ixheaace_block_switch.h"
45*15dc779aSAndroid Build Coastguard Worker #include "ixheaace_psy_data.h"
46*15dc779aSAndroid Build Coastguard Worker #include "ixheaace_interface.h"
47*15dc779aSAndroid Build Coastguard Worker #include "ixheaace_write_bitstream.h"
48*15dc779aSAndroid Build Coastguard Worker
ia_enhaacplus_enc_init_element(ixheaace_element_info * pstr_element_info,ixheaace_element_type el_type,WORD32 element_instance_tag)49*15dc779aSAndroid Build Coastguard Worker static IA_ERRORCODE ia_enhaacplus_enc_init_element(ixheaace_element_info *pstr_element_info,
50*15dc779aSAndroid Build Coastguard Worker ixheaace_element_type el_type,
51*15dc779aSAndroid Build Coastguard Worker WORD32 element_instance_tag) {
52*15dc779aSAndroid Build Coastguard Worker IA_ERRORCODE error = IA_NO_ERROR;
53*15dc779aSAndroid Build Coastguard Worker
54*15dc779aSAndroid Build Coastguard Worker pstr_element_info->el_type = el_type;
55*15dc779aSAndroid Build Coastguard Worker
56*15dc779aSAndroid Build Coastguard Worker switch (pstr_element_info->el_type) {
57*15dc779aSAndroid Build Coastguard Worker case ID_SCE:
58*15dc779aSAndroid Build Coastguard Worker case ID_CCE:
59*15dc779aSAndroid Build Coastguard Worker pstr_element_info->n_channels_in_el = NUM_CHANS_MONO;
60*15dc779aSAndroid Build Coastguard Worker
61*15dc779aSAndroid Build Coastguard Worker pstr_element_info->channel_index[0] = 0;
62*15dc779aSAndroid Build Coastguard Worker
63*15dc779aSAndroid Build Coastguard Worker pstr_element_info->instance_tag = element_instance_tag;
64*15dc779aSAndroid Build Coastguard Worker break;
65*15dc779aSAndroid Build Coastguard Worker
66*15dc779aSAndroid Build Coastguard Worker case ID_LFE:
67*15dc779aSAndroid Build Coastguard Worker pstr_element_info->n_channels_in_el = NUM_CHANS_MONO;
68*15dc779aSAndroid Build Coastguard Worker
69*15dc779aSAndroid Build Coastguard Worker pstr_element_info->channel_index[0] = 0;
70*15dc779aSAndroid Build Coastguard Worker
71*15dc779aSAndroid Build Coastguard Worker pstr_element_info->instance_tag = element_instance_tag;
72*15dc779aSAndroid Build Coastguard Worker break;
73*15dc779aSAndroid Build Coastguard Worker
74*15dc779aSAndroid Build Coastguard Worker case ID_CPE:
75*15dc779aSAndroid Build Coastguard Worker
76*15dc779aSAndroid Build Coastguard Worker pstr_element_info->n_channels_in_el = NUM_CHANS_STEREO;
77*15dc779aSAndroid Build Coastguard Worker
78*15dc779aSAndroid Build Coastguard Worker pstr_element_info->channel_index[0] = 0;
79*15dc779aSAndroid Build Coastguard Worker pstr_element_info->channel_index[1] = 1;
80*15dc779aSAndroid Build Coastguard Worker
81*15dc779aSAndroid Build Coastguard Worker pstr_element_info->instance_tag = element_instance_tag;
82*15dc779aSAndroid Build Coastguard Worker break;
83*15dc779aSAndroid Build Coastguard Worker
84*15dc779aSAndroid Build Coastguard Worker default:
85*15dc779aSAndroid Build Coastguard Worker return IA_EXHEAACE_INIT_FATAL_INVALID_ELEMENT_TYPE;
86*15dc779aSAndroid Build Coastguard Worker }
87*15dc779aSAndroid Build Coastguard Worker
88*15dc779aSAndroid Build Coastguard Worker return error;
89*15dc779aSAndroid Build Coastguard Worker }
90*15dc779aSAndroid Build Coastguard Worker
ia_enhaacplus_enc_init_element_info(WORD32 num_channels,ixheaace_element_info * pstr_element_info,WORD32 ele_type,WORD32 element_instance_tag)91*15dc779aSAndroid Build Coastguard Worker IA_ERRORCODE ia_enhaacplus_enc_init_element_info(WORD32 num_channels,
92*15dc779aSAndroid Build Coastguard Worker ixheaace_element_info *pstr_element_info,
93*15dc779aSAndroid Build Coastguard Worker WORD32 ele_type, WORD32 element_instance_tag) {
94*15dc779aSAndroid Build Coastguard Worker IA_ERRORCODE error = IA_NO_ERROR;
95*15dc779aSAndroid Build Coastguard Worker
96*15dc779aSAndroid Build Coastguard Worker if (ele_type != ID_LFE) {
97*15dc779aSAndroid Build Coastguard Worker switch (num_channels) {
98*15dc779aSAndroid Build Coastguard Worker case NUM_CHANS_MONO:
99*15dc779aSAndroid Build Coastguard Worker if (ele_type == -1) {
100*15dc779aSAndroid Build Coastguard Worker error = ia_enhaacplus_enc_init_element(pstr_element_info, ID_SCE, element_instance_tag);
101*15dc779aSAndroid Build Coastguard Worker } else {
102*15dc779aSAndroid Build Coastguard Worker error =
103*15dc779aSAndroid Build Coastguard Worker ia_enhaacplus_enc_init_element(pstr_element_info, ele_type, element_instance_tag);
104*15dc779aSAndroid Build Coastguard Worker }
105*15dc779aSAndroid Build Coastguard Worker break;
106*15dc779aSAndroid Build Coastguard Worker
107*15dc779aSAndroid Build Coastguard Worker case NUM_CHANS_STEREO:
108*15dc779aSAndroid Build Coastguard Worker error = ia_enhaacplus_enc_init_element(pstr_element_info, ID_CPE, element_instance_tag);
109*15dc779aSAndroid Build Coastguard Worker break;
110*15dc779aSAndroid Build Coastguard Worker
111*15dc779aSAndroid Build Coastguard Worker default:
112*15dc779aSAndroid Build Coastguard Worker return IA_EXHEAACE_INIT_FATAL_NUM_CHANNELS_NOT_SUPPORTED;
113*15dc779aSAndroid Build Coastguard Worker }
114*15dc779aSAndroid Build Coastguard Worker } else {
115*15dc779aSAndroid Build Coastguard Worker error = ia_enhaacplus_enc_init_element(pstr_element_info, ID_LFE, element_instance_tag);
116*15dc779aSAndroid Build Coastguard Worker }
117*15dc779aSAndroid Build Coastguard Worker
118*15dc779aSAndroid Build Coastguard Worker return error;
119*15dc779aSAndroid Build Coastguard Worker }
120*15dc779aSAndroid Build Coastguard Worker
ia_enhaacplus_enc_init_element_bits(ixheaace_element_bits * element_bits,ixheaace_element_info pstr_element_info,WORD32 bitrate_tot,WORD32 average_bits_tot,WORD32 aot,WORD32 static_bits_tot,WORD32 bit_res,FLAG flag_framelength_small)121*15dc779aSAndroid Build Coastguard Worker IA_ERRORCODE ia_enhaacplus_enc_init_element_bits(ixheaace_element_bits *element_bits,
122*15dc779aSAndroid Build Coastguard Worker ixheaace_element_info pstr_element_info,
123*15dc779aSAndroid Build Coastguard Worker WORD32 bitrate_tot, WORD32 average_bits_tot,
124*15dc779aSAndroid Build Coastguard Worker WORD32 aot, WORD32 static_bits_tot,
125*15dc779aSAndroid Build Coastguard Worker WORD32 bit_res, FLAG flag_framelength_small) {
126*15dc779aSAndroid Build Coastguard Worker IA_ERRORCODE error = IA_NO_ERROR;
127*15dc779aSAndroid Build Coastguard Worker
128*15dc779aSAndroid Build Coastguard Worker switch (pstr_element_info.n_channels_in_el) {
129*15dc779aSAndroid Build Coastguard Worker case NUM_CHANS_MONO:
130*15dc779aSAndroid Build Coastguard Worker element_bits->ch_bitrate = bitrate_tot;
131*15dc779aSAndroid Build Coastguard Worker
132*15dc779aSAndroid Build Coastguard Worker element_bits->average_bits = (average_bits_tot - static_bits_tot);
133*15dc779aSAndroid Build Coastguard Worker switch (aot) {
134*15dc779aSAndroid Build Coastguard Worker case AOT_AAC_LC:
135*15dc779aSAndroid Build Coastguard Worker case AOT_SBR:
136*15dc779aSAndroid Build Coastguard Worker case AOT_PS:
137*15dc779aSAndroid Build Coastguard Worker if (flag_framelength_small) {
138*15dc779aSAndroid Build Coastguard Worker element_bits->max_bits = MAXIMUM_CHANNEL_BITS_960;
139*15dc779aSAndroid Build Coastguard Worker
140*15dc779aSAndroid Build Coastguard Worker element_bits->max_bit_res_bits = MAXIMUM_CHANNEL_BITS_960 - average_bits_tot;
141*15dc779aSAndroid Build Coastguard Worker } else {
142*15dc779aSAndroid Build Coastguard Worker element_bits->max_bits = MAXIMUM_CHANNEL_BITS_1024;
143*15dc779aSAndroid Build Coastguard Worker
144*15dc779aSAndroid Build Coastguard Worker element_bits->max_bit_res_bits = MAXIMUM_CHANNEL_BITS_1024 - average_bits_tot;
145*15dc779aSAndroid Build Coastguard Worker }
146*15dc779aSAndroid Build Coastguard Worker break;
147*15dc779aSAndroid Build Coastguard Worker
148*15dc779aSAndroid Build Coastguard Worker case AOT_AAC_LD:
149*15dc779aSAndroid Build Coastguard Worker case AOT_AAC_ELD:
150*15dc779aSAndroid Build Coastguard Worker if (bit_res) {
151*15dc779aSAndroid Build Coastguard Worker element_bits->max_bits = bit_res;
152*15dc779aSAndroid Build Coastguard Worker element_bits->max_bit_res_bits = bit_res - average_bits_tot;
153*15dc779aSAndroid Build Coastguard Worker } else {
154*15dc779aSAndroid Build Coastguard Worker element_bits->max_bits = average_bits_tot;
155*15dc779aSAndroid Build Coastguard Worker element_bits->max_bit_res_bits = 0;
156*15dc779aSAndroid Build Coastguard Worker }
157*15dc779aSAndroid Build Coastguard Worker break;
158*15dc779aSAndroid Build Coastguard Worker }
159*15dc779aSAndroid Build Coastguard Worker
160*15dc779aSAndroid Build Coastguard Worker element_bits->max_bit_res_bits -= (element_bits[0].max_bit_res_bits % 8);
161*15dc779aSAndroid Build Coastguard Worker element_bits->bit_res_level = element_bits[0].max_bit_res_bits;
162*15dc779aSAndroid Build Coastguard Worker element_bits->relative_bits = 1;
163*15dc779aSAndroid Build Coastguard Worker break;
164*15dc779aSAndroid Build Coastguard Worker
165*15dc779aSAndroid Build Coastguard Worker case NUM_CHANS_STEREO:
166*15dc779aSAndroid Build Coastguard Worker element_bits->ch_bitrate = bitrate_tot >> 1;
167*15dc779aSAndroid Build Coastguard Worker
168*15dc779aSAndroid Build Coastguard Worker element_bits->average_bits = (average_bits_tot - static_bits_tot);
169*15dc779aSAndroid Build Coastguard Worker switch (aot) {
170*15dc779aSAndroid Build Coastguard Worker case AOT_AAC_LC:
171*15dc779aSAndroid Build Coastguard Worker case AOT_SBR:
172*15dc779aSAndroid Build Coastguard Worker case AOT_PS:
173*15dc779aSAndroid Build Coastguard Worker if (flag_framelength_small) {
174*15dc779aSAndroid Build Coastguard Worker element_bits->max_bits = NUM_CHANS_STEREO * MAXIMUM_CHANNEL_BITS_960;
175*15dc779aSAndroid Build Coastguard Worker
176*15dc779aSAndroid Build Coastguard Worker element_bits->max_bit_res_bits =
177*15dc779aSAndroid Build Coastguard Worker NUM_CHANS_STEREO * MAXIMUM_CHANNEL_BITS_960 - average_bits_tot;
178*15dc779aSAndroid Build Coastguard Worker } else {
179*15dc779aSAndroid Build Coastguard Worker element_bits->max_bits = NUM_CHANS_STEREO * MAXIMUM_CHANNEL_BITS_1024;
180*15dc779aSAndroid Build Coastguard Worker
181*15dc779aSAndroid Build Coastguard Worker element_bits->max_bit_res_bits =
182*15dc779aSAndroid Build Coastguard Worker NUM_CHANS_STEREO * MAXIMUM_CHANNEL_BITS_1024 - average_bits_tot;
183*15dc779aSAndroid Build Coastguard Worker }
184*15dc779aSAndroid Build Coastguard Worker break;
185*15dc779aSAndroid Build Coastguard Worker
186*15dc779aSAndroid Build Coastguard Worker case AOT_AAC_LD:
187*15dc779aSAndroid Build Coastguard Worker case AOT_AAC_ELD:
188*15dc779aSAndroid Build Coastguard Worker if (bit_res) {
189*15dc779aSAndroid Build Coastguard Worker element_bits->max_bits = bit_res;
190*15dc779aSAndroid Build Coastguard Worker element_bits->max_bit_res_bits = bit_res - average_bits_tot;
191*15dc779aSAndroid Build Coastguard Worker } else {
192*15dc779aSAndroid Build Coastguard Worker element_bits->max_bits = average_bits_tot;
193*15dc779aSAndroid Build Coastguard Worker element_bits->max_bit_res_bits = 0;
194*15dc779aSAndroid Build Coastguard Worker }
195*15dc779aSAndroid Build Coastguard Worker break;
196*15dc779aSAndroid Build Coastguard Worker }
197*15dc779aSAndroid Build Coastguard Worker
198*15dc779aSAndroid Build Coastguard Worker element_bits->max_bit_res_bits -= (element_bits[0].max_bit_res_bits % 8);
199*15dc779aSAndroid Build Coastguard Worker
200*15dc779aSAndroid Build Coastguard Worker element_bits->bit_res_level = element_bits[0].max_bit_res_bits;
201*15dc779aSAndroid Build Coastguard Worker element_bits->relative_bits = 1;
202*15dc779aSAndroid Build Coastguard Worker break;
203*15dc779aSAndroid Build Coastguard Worker
204*15dc779aSAndroid Build Coastguard Worker default:
205*15dc779aSAndroid Build Coastguard Worker return IA_EXHEAACE_INIT_FATAL_INVALID_NUM_CHANNELS_IN_ELE;
206*15dc779aSAndroid Build Coastguard Worker }
207*15dc779aSAndroid Build Coastguard Worker /* Bits carried over from previous frame */
208*15dc779aSAndroid Build Coastguard Worker element_bits->carry_bits = 0;
209*15dc779aSAndroid Build Coastguard Worker
210*15dc779aSAndroid Build Coastguard Worker return error;
211*15dc779aSAndroid Build Coastguard Worker }
212