xref: /aosp_15_r20/external/libxaac/encoder/iusace_bitbuffer.c (revision 15dc779a375ca8b5125643b829a8aa4b70d7f451)
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 "ixheaac_type_def.h"
22*15dc779aSAndroid Build Coastguard Worker #include "ixheaac_constants.h"
23*15dc779aSAndroid Build Coastguard Worker #include "iusace_cnst.h"
24*15dc779aSAndroid Build Coastguard Worker #include "iusace_bitbuffer.h"
25*15dc779aSAndroid Build Coastguard Worker #include "ixheaac_basic_ops32.h"
26*15dc779aSAndroid Build Coastguard Worker #include "ixheaac_basic_ops40.h"
27*15dc779aSAndroid Build Coastguard Worker #include "ixheaac_basic_ops.h"
28*15dc779aSAndroid Build Coastguard Worker 
iusace_create_bit_buffer(ia_bit_buf_struct * it_bit_buf,UWORD8 * ptr_bit_buf_base,UWORD32 bit_buffer_size,WORD32 init)29*15dc779aSAndroid Build Coastguard Worker ia_bit_buf_struct *iusace_create_bit_buffer(ia_bit_buf_struct *it_bit_buf,
30*15dc779aSAndroid Build Coastguard Worker                                             UWORD8 *ptr_bit_buf_base, UWORD32 bit_buffer_size,
31*15dc779aSAndroid Build Coastguard Worker                                             WORD32 init) {
32*15dc779aSAndroid Build Coastguard Worker   it_bit_buf->ptr_bit_buf_base = ptr_bit_buf_base;
33*15dc779aSAndroid Build Coastguard Worker   it_bit_buf->ptr_bit_buf_end = ptr_bit_buf_base + bit_buffer_size - 1;
34*15dc779aSAndroid Build Coastguard Worker   it_bit_buf->ptr_read_next = ptr_bit_buf_base;
35*15dc779aSAndroid Build Coastguard Worker   it_bit_buf->ptr_write_next = ptr_bit_buf_base;
36*15dc779aSAndroid Build Coastguard Worker 
37*15dc779aSAndroid Build Coastguard Worker   if (init) {
38*15dc779aSAndroid Build Coastguard Worker     it_bit_buf->write_position = 7;
39*15dc779aSAndroid Build Coastguard Worker     it_bit_buf->read_position = 7;
40*15dc779aSAndroid Build Coastguard Worker     it_bit_buf->cnt_bits = 0;
41*15dc779aSAndroid Build Coastguard Worker     it_bit_buf->size = bit_buffer_size * 8;
42*15dc779aSAndroid Build Coastguard Worker   }
43*15dc779aSAndroid Build Coastguard Worker 
44*15dc779aSAndroid Build Coastguard Worker   return (it_bit_buf);
45*15dc779aSAndroid Build Coastguard Worker }
46*15dc779aSAndroid Build Coastguard Worker 
iusace_reset_bit_buffer(ia_bit_buf_struct * it_bit_buf)47*15dc779aSAndroid Build Coastguard Worker VOID iusace_reset_bit_buffer(ia_bit_buf_struct *it_bit_buf) {
48*15dc779aSAndroid Build Coastguard Worker   it_bit_buf->ptr_read_next = it_bit_buf->ptr_bit_buf_base;
49*15dc779aSAndroid Build Coastguard Worker   it_bit_buf->ptr_write_next = it_bit_buf->ptr_bit_buf_base;
50*15dc779aSAndroid Build Coastguard Worker 
51*15dc779aSAndroid Build Coastguard Worker   it_bit_buf->write_position = 7;
52*15dc779aSAndroid Build Coastguard Worker   it_bit_buf->read_position = 7;
53*15dc779aSAndroid Build Coastguard Worker   it_bit_buf->cnt_bits = 0;
54*15dc779aSAndroid Build Coastguard Worker 
55*15dc779aSAndroid Build Coastguard Worker   return;
56*15dc779aSAndroid Build Coastguard Worker }
57*15dc779aSAndroid Build Coastguard Worker 
iusace_write_bits_buf(ia_bit_buf_struct * it_bit_buf,UWORD32 write_val,UWORD8 num_bits)58*15dc779aSAndroid Build Coastguard Worker UWORD8 iusace_write_bits_buf(ia_bit_buf_struct *it_bit_buf, UWORD32 write_val, UWORD8 num_bits) {
59*15dc779aSAndroid Build Coastguard Worker   WORD8 bits_to_write;
60*15dc779aSAndroid Build Coastguard Worker   WORD32 write_position;
61*15dc779aSAndroid Build Coastguard Worker   UWORD8 *ptr_write_next;
62*15dc779aSAndroid Build Coastguard Worker   UWORD8 *ptr_bit_buf_end;
63*15dc779aSAndroid Build Coastguard Worker   UWORD8 *ptr_bit_buf_base;
64*15dc779aSAndroid Build Coastguard Worker   UWORD8 bits_written = num_bits;
65*15dc779aSAndroid Build Coastguard Worker   if (it_bit_buf) {
66*15dc779aSAndroid Build Coastguard Worker     it_bit_buf->cnt_bits += num_bits;
67*15dc779aSAndroid Build Coastguard Worker 
68*15dc779aSAndroid Build Coastguard Worker     write_position = it_bit_buf->write_position;
69*15dc779aSAndroid Build Coastguard Worker     ptr_write_next = it_bit_buf->ptr_write_next;
70*15dc779aSAndroid Build Coastguard Worker     ptr_bit_buf_end = it_bit_buf->ptr_bit_buf_end;
71*15dc779aSAndroid Build Coastguard Worker     ptr_bit_buf_base = it_bit_buf->ptr_bit_buf_base;
72*15dc779aSAndroid Build Coastguard Worker     while (num_bits) {
73*15dc779aSAndroid Build Coastguard Worker       UWORD8 tmp, msk;
74*15dc779aSAndroid Build Coastguard Worker 
75*15dc779aSAndroid Build Coastguard Worker       bits_to_write = (WORD8)MIN(write_position + 1, num_bits);
76*15dc779aSAndroid Build Coastguard Worker 
77*15dc779aSAndroid Build Coastguard Worker       tmp = (UWORD8)(write_val << (32 - num_bits) >> (32 - bits_to_write)
78*15dc779aSAndroid Build Coastguard Worker                                                          << (write_position + 1 - bits_to_write));
79*15dc779aSAndroid Build Coastguard Worker 
80*15dc779aSAndroid Build Coastguard Worker       msk = ~(((1 << bits_to_write) - 1) << (write_position + 1 - bits_to_write));
81*15dc779aSAndroid Build Coastguard Worker 
82*15dc779aSAndroid Build Coastguard Worker       *ptr_write_next &= msk;
83*15dc779aSAndroid Build Coastguard Worker       *ptr_write_next |= tmp;
84*15dc779aSAndroid Build Coastguard Worker 
85*15dc779aSAndroid Build Coastguard Worker       write_position -= bits_to_write;
86*15dc779aSAndroid Build Coastguard Worker 
87*15dc779aSAndroid Build Coastguard Worker       num_bits -= bits_to_write;
88*15dc779aSAndroid Build Coastguard Worker 
89*15dc779aSAndroid Build Coastguard Worker       if (write_position < 0) {
90*15dc779aSAndroid Build Coastguard Worker         write_position += 8;
91*15dc779aSAndroid Build Coastguard Worker         ptr_write_next++;
92*15dc779aSAndroid Build Coastguard Worker 
93*15dc779aSAndroid Build Coastguard Worker         if (ptr_write_next > ptr_bit_buf_end) {
94*15dc779aSAndroid Build Coastguard Worker           ptr_write_next = ptr_bit_buf_base;
95*15dc779aSAndroid Build Coastguard Worker         }
96*15dc779aSAndroid Build Coastguard Worker       }
97*15dc779aSAndroid Build Coastguard Worker     }
98*15dc779aSAndroid Build Coastguard Worker 
99*15dc779aSAndroid Build Coastguard Worker     it_bit_buf->write_position = write_position;
100*15dc779aSAndroid Build Coastguard Worker     it_bit_buf->ptr_write_next = ptr_write_next;
101*15dc779aSAndroid Build Coastguard Worker   }
102*15dc779aSAndroid Build Coastguard Worker 
103*15dc779aSAndroid Build Coastguard Worker   return (bits_written);
104*15dc779aSAndroid Build Coastguard Worker }
105*15dc779aSAndroid Build Coastguard Worker 
iusace_write_escape_value(ia_bit_buf_struct * pstr_it_bit_buff,UWORD32 value,UWORD8 no_bits1,UWORD8 no_bits2,UWORD8 no_bits3)106*15dc779aSAndroid Build Coastguard Worker WORD32 iusace_write_escape_value(ia_bit_buf_struct *pstr_it_bit_buff, UWORD32 value,
107*15dc779aSAndroid Build Coastguard Worker                                  UWORD8 no_bits1, UWORD8 no_bits2, UWORD8 no_bits3) {
108*15dc779aSAndroid Build Coastguard Worker   WORD32 bit_cnt = 0;
109*15dc779aSAndroid Build Coastguard Worker   UWORD32 esc_val = 0;
110*15dc779aSAndroid Build Coastguard Worker   UWORD32 max_val1 = (1 << no_bits1) - 1;
111*15dc779aSAndroid Build Coastguard Worker   UWORD32 max_val2 = (1 << no_bits2) - 1;
112*15dc779aSAndroid Build Coastguard Worker   UWORD32 max_val3 = (1 << no_bits3) - 1;
113*15dc779aSAndroid Build Coastguard Worker 
114*15dc779aSAndroid Build Coastguard Worker   esc_val = MIN(value, max_val1);
115*15dc779aSAndroid Build Coastguard Worker   bit_cnt += iusace_write_bits_buf(pstr_it_bit_buff, esc_val, no_bits1);
116*15dc779aSAndroid Build Coastguard Worker 
117*15dc779aSAndroid Build Coastguard Worker   if (esc_val == max_val1) {
118*15dc779aSAndroid Build Coastguard Worker     value = value - esc_val;
119*15dc779aSAndroid Build Coastguard Worker 
120*15dc779aSAndroid Build Coastguard Worker     esc_val = MIN(value, max_val2);
121*15dc779aSAndroid Build Coastguard Worker     bit_cnt += iusace_write_bits_buf(pstr_it_bit_buff, esc_val, no_bits2);
122*15dc779aSAndroid Build Coastguard Worker 
123*15dc779aSAndroid Build Coastguard Worker     if (esc_val == max_val2) {
124*15dc779aSAndroid Build Coastguard Worker       value = value - esc_val;
125*15dc779aSAndroid Build Coastguard Worker 
126*15dc779aSAndroid Build Coastguard Worker       esc_val = MIN(value, max_val3);
127*15dc779aSAndroid Build Coastguard Worker       bit_cnt += iusace_write_bits_buf(pstr_it_bit_buff, esc_val, no_bits3);
128*15dc779aSAndroid Build Coastguard Worker     }
129*15dc779aSAndroid Build Coastguard Worker   }
130*15dc779aSAndroid Build Coastguard Worker 
131*15dc779aSAndroid Build Coastguard Worker   return bit_cnt;
132*15dc779aSAndroid Build Coastguard Worker }
133