summaryrefslogtreecommitdiff
Diffstat
-rw-r--r--Android.mk1
-rwxr-xr-xamadec/Android.mk282
-rw-r--r--amadec/acodec_lib_50/libstagefright_soft_dcvdec.so80
-rw-r--r--amadec/acodec_lib_50/libstagefright_soft_dtshd.so85
-rw-r--r--amadec/acodec_lib_50/libstagefright_soft_truehddec.so41
-rw-r--r--amadec/acodec_lib_android_n/libstagefright_soft_dcvdec.so109
-rw-r--r--amadec/acodec_lib_android_n/libstagefright_soft_dtshd.so272
-rw-r--r--amadec/acodec_lib_android_n/libstagefright_soft_truehddec.so87
-rwxr-xr-xamadec/acodec_lib_mx/libstagefright_soft_ddpdec.so113
-rwxr-xr-xamadec/acodec_lib_mx/libstagefright_soft_dtshd.so121
-rw-r--r--amadec/adec-armdec-mgt.h57
-rw-r--r--amadec/adec-external-ctrl.c899
-rw-r--r--amadec/adec-ffmpeg-mgt.c1550
-rw-r--r--amadec/adec-internal-mgt.c772
-rw-r--r--amadec/adec-message.c156
-rw-r--r--amadec/adec-message.h61
-rwxr-xr-xamadec/adec-pts-mgt.c1107
-rw-r--r--amadec/adec-pts-mgt.h82
-rw-r--r--amadec/adec-wfd-out.cpp361
-rw-r--r--amadec/adec-wfd.c811
-rw-r--r--amadec/adec_omx_brige.c284
-rw-r--r--amadec/adec_omx_brige.h56
-rw-r--r--amadec/adec_read.c200
-rw-r--r--amadec/adec_reg.h76
-rw-r--r--amadec/adec_write.c189
-rw-r--r--amadec/adec_write.h42
-rw-r--r--amadec/audio-dec.h314
-rw-r--r--amadec/audio_out/alsa-out.c1082
-rw-r--r--amadec/audio_out/aml_resample.c708
-rw-r--r--amadec/audio_out/aml_resample.h86
-rwxr-xr-xamadec/audio_out/android-out.cpp1640
-rw-r--r--amadec/audiodsp_update_format.c188
-rw-r--r--amadec/dsp/audiodsp-ctl.c471
-rw-r--r--amadec/dts_enc.c209
-rw-r--r--amadec/dts_enc.h11
-rw-r--r--amadec/dts_transenc_api.c143
-rw-r--r--amadec/dts_transenc_api.h19
-rw-r--r--amadec/feeder.c231
-rw-r--r--amadec/feeder.h26
-rw-r--r--amadec/include/adec-external-ctrl.h63
-rwxr-xr-xamadec/include/adec-macros.h41
-rw-r--r--amadec/include/adec-types.h53
-rwxr-xr-xamadec/include/alsa-out.h26
-rw-r--r--amadec/include/audio-out.h41
-rw-r--r--amadec/include/audiodsp.h142
-rw-r--r--amadec/include/audiodsp_update_format.h25
-rw-r--r--amadec/include/log-print.h26
-rwxr-xr-xamadec/omx_audio/ALAC_mediasource.cpp205
-rw-r--r--amadec/omx_audio/ALAC_mediasource.h62
-rwxr-xr-xamadec/omx_audio/ASF_mediasource.cpp184
-rw-r--r--amadec/omx_audio/ASF_mediasource.h127
-rwxr-xr-xamadec/omx_audio/Android.mk34
-rwxr-xr-xamadec/omx_audio/DDP_mediasource.cpp528
-rw-r--r--amadec/omx_audio/DDP_mediasource.h141
-rw-r--r--amadec/omx_audio/DTSHD_mediasource.cpp316
-rw-r--r--amadec/omx_audio/DTSHD_mediasource.h74
-rwxr-xr-xamadec/omx_audio/MP3_mediasource.cpp579
-rw-r--r--amadec/omx_audio/MP3_mediasource.h80
-rw-r--r--amadec/omx_audio/THD_mediasource.cpp229
-rw-r--r--amadec/omx_audio/THD_mediasource.h74
-rwxr-xr-xamadec/omx_audio/Vorbis_mediasource.cpp245
-rw-r--r--amadec/omx_audio/Vorbis_mediasource.h58
-rw-r--r--amadec/omx_audio/adec_omx.cpp421
-rw-r--r--amadec/omx_audio/adec_omx.h71
-rwxr-xr-xamadec/omx_audio/audio_mediasource.cpp37
-rw-r--r--amadec/omx_audio/audio_mediasource.h46
-rw-r--r--amadec/omx_audio/audio_medissource.h137
-rw-r--r--amadec/pcmenc_api.c147
-rw-r--r--amadec/pcmenc_api.h25
-rw-r--r--amadec/spdif_api.c306
-rw-r--r--amadec/spdif_api.h26
-rwxr-xr-xaudio_codec/Android.mk1
-rw-r--r--audio_codec/config.mk10
-rwxr-xr-xaudio_codec/libadpcm/Android.mk12
-rw-r--r--audio_codec/libadpcm/adpcm.h346
-rw-r--r--audio_codec/libadpcm/adpcm_decode.c841
-rwxr-xr-xaudio_codec/libamr/Android.mk25
-rwxr-xr-xaudio_codec/libamr/Makefile5
-rw-r--r--audio_codec/libamr/amr_decode.c186
-rw-r--r--audio_codec/libamr/amr_decode.h8
-rwxr-xr-xaudio_codec/libamr/dec.h18
-rw-r--r--audio_codec/libamr/dec_acelp.c620
-rwxr-xr-xaudio_codec/libamr/dec_acelp.h17
-rw-r--r--audio_codec/libamr/dec_dtx.c683
-rw-r--r--audio_codec/libamr/dec_dtx.h49
-rw-r--r--audio_codec/libamr/dec_gain.c853
-rw-r--r--audio_codec/libamr/dec_gain.h28
-rw-r--r--audio_codec/libamr/dec_if.c834
-rwxr-xr-xaudio_codec/libamr/dec_if.h23
-rw-r--r--audio_codec/libamr/dec_lpc.c789
-rw-r--r--audio_codec/libamr/dec_lpc.h25
-rw-r--r--audio_codec/libamr/dec_main.c842
-rw-r--r--audio_codec/libamr/dec_main.h57
-rw-r--r--audio_codec/libamr/dec_rom.c2114
-rw-r--r--audio_codec/libamr/dec_util.c1304
-rw-r--r--audio_codec/libamr/dec_util.h33
-rw-r--r--audio_codec/libamr/if_rom.c1030
-rwxr-xr-xaudio_codec/libamr/if_rom.h70
-rw-r--r--audio_codec/libamr/interf_dec.c906
-rw-r--r--audio_codec/libamr/interf_dec.h56
-rw-r--r--audio_codec/libamr/interf_rom.h1788
-rw-r--r--audio_codec/libamr/rom_dec.h13274
-rw-r--r--audio_codec/libamr/sp_dec.c6078
-rw-r--r--audio_codec/libamr/sp_dec.h83
-rwxr-xr-xaudio_codec/libamr/typedef.h17
-rwxr-xr-xaudio_codec/libape/Android.mk28
-rw-r--r--audio_codec/libape/Ape_decoder.h216
-rw-r--r--audio_codec/libape/amlogic_r30813_audio_ape_lib.c1
-rw-r--r--audio_codec/libape/apedec.c1120
-rw-r--r--audio_codec/libcook/Android.mk28
-rw-r--r--audio_codec/libcook/aac_bitstream.h133
-rw-r--r--audio_codec/libcook/aac_decode.h148
-rw-r--r--audio_codec/libcook/aac_reorder.h53
-rw-r--r--audio_codec/libcook/assembly.h119
-rw-r--r--audio_codec/libcook/challenge.h132
-rw-r--r--audio_codec/libcook/codec_defines.h93
-rw-r--r--audio_codec/libcook/coder.h287
-rw-r--r--audio_codec/libcook/cook_codec.h30
-rw-r--r--audio_codec/libcook/cook_decode.c624
-rw-r--r--audio_codec/libcook/cook_decode.h35
-rw-r--r--audio_codec/libcook/ga_config.h86
-rw-r--r--audio_codec/libcook/gecko2codec.c833
-rw-r--r--audio_codec/libcook/gecko2codec.h60
-rw-r--r--audio_codec/libcook/helix_config.h92
-rw-r--r--audio_codec/libcook/helix_mime_types.h56
-rw-r--r--audio_codec/libcook/helix_result.h107
-rw-r--r--audio_codec/libcook/helix_types.h305
-rw-r--r--audio_codec/libcook/helix_utils.h106
-rw-r--r--audio_codec/libcook/md5.h113
-rw-r--r--audio_codec/libcook/memory_utils.c100
-rw-r--r--audio_codec/libcook/memory_utils.h58
-rw-r--r--audio_codec/libcook/pack_utils.c306
-rw-r--r--audio_codec/libcook/pack_utils.h93
-rw-r--r--audio_codec/libcook/packet_defines.h48
-rw-r--r--audio_codec/libcook/ra8lbr_decode.c378
-rw-r--r--audio_codec/libcook/ra8lbr_decode.h161
-rw-r--r--audio_codec/libcook/ra_backend.h94
-rw-r--r--audio_codec/libcook/ra_bitpack.c197
-rw-r--r--audio_codec/libcook/ra_buffers.c127
-rw-r--r--audio_codec/libcook/ra_category.c298
-rw-r--r--audio_codec/libcook/ra_couple.c224
-rw-r--r--audio_codec/libcook/ra_decode.c321
-rw-r--r--audio_codec/libcook/ra_decode.h183
-rw-r--r--audio_codec/libcook/ra_depack.c230
-rw-r--r--audio_codec/libcook/ra_depack.h177
-rw-r--r--audio_codec/libcook/ra_depack_internal.c1710
-rw-r--r--audio_codec/libcook/ra_depack_internal.h232
-rw-r--r--audio_codec/libcook/ra_envelope.c123
-rw-r--r--audio_codec/libcook/ra_fft.c368
-rw-r--r--audio_codec/libcook/ra_format_info.h60
-rw-r--r--audio_codec/libcook/ra_gainctrl.c584
-rw-r--r--audio_codec/libcook/ra_huffman.c86
-rw-r--r--audio_codec/libcook/ra_hufftabs.c244
-rw-r--r--audio_codec/libcook/ra_mlt.c357
-rw-r--r--audio_codec/libcook/ra_sqvh.c431
-rw-r--r--audio_codec/libcook/ra_trigtabs.c932
-rw-r--r--audio_codec/libcook/rasl.c376
-rw-r--r--audio_codec/libcook/rasl.h71
-rw-r--r--audio_codec/libcook/rdtpck.h153
-rw-r--r--audio_codec/libcook/rm_error.h54
-rw-r--r--audio_codec/libcook/rm_error_default.c58
-rw-r--r--audio_codec/libcook/rm_error_default.h53
-rw-r--r--audio_codec/libcook/rm_io_default.c101
-rw-r--r--audio_codec/libcook/rm_io_default.h49
-rw-r--r--audio_codec/libcook/rm_memory.h54
-rw-r--r--audio_codec/libcook/rm_memory_default.c54
-rw-r--r--audio_codec/libcook/rm_memory_default.h46
-rw-r--r--audio_codec/libcook/rm_packet.c117
-rw-r--r--audio_codec/libcook/rm_packet.h80
-rw-r--r--audio_codec/libcook/rm_parse.h302
-rw-r--r--audio_codec/libcook/rm_parser.c649
-rw-r--r--audio_codec/libcook/rm_parser_internal.c3342
-rw-r--r--audio_codec/libcook/rm_parser_internal.h420
-rw-r--r--audio_codec/libcook/rm_property.c105
-rw-r--r--audio_codec/libcook/rm_property.h107
-rw-r--r--audio_codec/libcook/rm_stream.c356
-rw-r--r--audio_codec/libcook/rm_stream.h115
-rw-r--r--audio_codec/libcook/rm_stream_internal.h77
-rw-r--r--audio_codec/libcook/rv20backend.h69
-rw-r--r--audio_codec/libcook/rv30backend.h68
-rw-r--r--audio_codec/libcook/rv_backend.h84
-rw-r--r--audio_codec/libcook/rv_backend_types.h198
-rw-r--r--audio_codec/libcook/rv_decode.h208
-rw-r--r--audio_codec/libcook/rv_decode_message.h492
-rw-r--r--audio_codec/libcook/rv_depack.c271
-rw-r--r--audio_codec/libcook/rv_depack.h162
-rw-r--r--audio_codec/libcook/rv_depack_internal.c1071
-rw-r--r--audio_codec/libcook/rv_depack_internal.h171
-rw-r--r--audio_codec/libcook/rv_format_info.h91
-rw-r--r--audio_codec/libcook/statname.h118
-rw-r--r--audio_codec/libcook/stream_hdr_structs.h66
-rw-r--r--audio_codec/libcook/stream_hdr_utils.c136
-rw-r--r--audio_codec/libcook/stream_hdr_utils.h77
-rw-r--r--audio_codec/libcook/string_utils.c87
-rw-r--r--audio_codec/libcook/string_utils.h62
-rw-r--r--audio_codec/libcook/tngpkt.h400
-rwxr-xr-xaudio_codec/libfaad/Android.mk101
-rwxr-xr-xaudio_codec/libfaad/Makefile130
-rw-r--r--audio_codec/libfaad/analysis.h52
-rwxr-xr-xaudio_codec/libfaad/audio.d3
-rw-r--r--audio_codec/libfaad/bits.c261
-rwxr-xr-xaudio_codec/libfaad/bits.d18
-rw-r--r--audio_codec/libfaad/bits.h446
-rw-r--r--audio_codec/libfaad/cfft.c988
-rw-r--r--audio_codec/libfaad/cfft.h55
-rw-r--r--audio_codec/libfaad/cfft_tab.h1816
-rw-r--r--audio_codec/libfaad/codebook/hcb.h140
-rw-r--r--audio_codec/libfaad/codebook/hcb_1.h186
-rw-r--r--audio_codec/libfaad/codebook/hcb_10.h312
-rw-r--r--audio_codec/libfaad/codebook/hcb_11.h415
-rw-r--r--audio_codec/libfaad/codebook/hcb_2.h185
-rw-r--r--audio_codec/libfaad/codebook/hcb_3.h196
-rw-r--r--audio_codec/libfaad/codebook/hcb_4.h199
-rw-r--r--audio_codec/libfaad/codebook/hcb_5.h196
-rw-r--r--audio_codec/libfaad/codebook/hcb_6.h182
-rw-r--r--audio_codec/libfaad/codebook/hcb_7.h162
-rw-r--r--audio_codec/libfaad/codebook/hcb_8.h173
-rw-r--r--audio_codec/libfaad/codebook/hcb_9.h372
-rw-r--r--audio_codec/libfaad/codebook/hcb_sf.h276
-rw-r--r--audio_codec/libfaad/common.c558
-rw-r--r--audio_codec/libfaad/common.h453
-rw-r--r--audio_codec/libfaad/decoder.c2266
-rw-r--r--audio_codec/libfaad/drc.c173
-rw-r--r--audio_codec/libfaad/drc.h49
-rw-r--r--audio_codec/libfaad/drm_dec.c912
-rw-r--r--audio_codec/libfaad/drm_dec.h99
-rw-r--r--audio_codec/libfaad/error.c72
-rw-r--r--audio_codec/libfaad/error.h44
-rw-r--r--audio_codec/libfaad/filtbank.c408
-rw-r--r--audio_codec/libfaad/filtbank.h61
-rw-r--r--audio_codec/libfaad/fixed.h287
-rw-r--r--audio_codec/libfaad/hcr.c422
-rw-r--r--audio_codec/libfaad/helixaac/aaccommon.h210
-rw-r--r--audio_codec/libfaad/helixaac/aacdec.c508
-rw-r--r--audio_codec/libfaad/helixaac/aacdec.h206
-rw-r--r--audio_codec/libfaad/helixaac/aactabs.c157
-rw-r--r--audio_codec/libfaad/helixaac/assembly.h631
-rw-r--r--audio_codec/libfaad/helixaac/assembly_mw.h743
-rw-r--r--audio_codec/libfaad/helixaac/bitstream.c261
-rw-r--r--audio_codec/libfaad/helixaac/bitstream.h74
-rw-r--r--audio_codec/libfaad/helixaac/buffers.c140
-rw-r--r--audio_codec/libfaad/helixaac/coder.h369
-rw-r--r--audio_codec/libfaad/helixaac/dct4.c337
-rw-r--r--audio_codec/libfaad/helixaac/decelmnt.c445
-rw-r--r--audio_codec/libfaad/helixaac/dequant.c379
-rw-r--r--audio_codec/libfaad/helixaac/fft.c391
-rw-r--r--audio_codec/libfaad/helixaac/filefmt.c539
-rw-r--r--audio_codec/libfaad/helixaac/huffman_helix.c450
-rw-r--r--audio_codec/libfaad/helixaac/hufftabs.c177
-rw-r--r--audio_codec/libfaad/helixaac/imdct.c596
-rw-r--r--audio_codec/libfaad/helixaac/noiseless.c513
-rw-r--r--audio_codec/libfaad/helixaac/pns_helix.c371
-rw-r--r--audio_codec/libfaad/helixaac/sbr.c433
-rw-r--r--audio_codec/libfaad/helixaac/sbr.h380
-rw-r--r--audio_codec/libfaad/helixaac/sbrfft.c368
-rw-r--r--audio_codec/libfaad/helixaac/sbrfreq.c673
-rw-r--r--audio_codec/libfaad/helixaac/sbrhfadj.c882
-rw-r--r--audio_codec/libfaad/helixaac/sbrhfgen.c655
-rw-r--r--audio_codec/libfaad/helixaac/sbrhuff.c494
-rw-r--r--audio_codec/libfaad/helixaac/sbrimdct.c447
-rw-r--r--audio_codec/libfaad/helixaac/sbrmath.c198
-rw-r--r--audio_codec/libfaad/helixaac/sbrqmf.c648
-rw-r--r--audio_codec/libfaad/helixaac/sbrside.c634
-rw-r--r--audio_codec/libfaad/helixaac/sbrtabs.c400
-rw-r--r--audio_codec/libfaad/helixaac/statname.h115
-rw-r--r--audio_codec/libfaad/helixaac/stproc.c251
-rw-r--r--audio_codec/libfaad/helixaac/tns_helix.c307
-rw-r--r--audio_codec/libfaad/helixaac/trigtabs.c1000
-rw-r--r--audio_codec/libfaad/helixaac/trigtabs_fltgen.c357
-rw-r--r--audio_codec/libfaad/huffman.c582
-rw-r--r--audio_codec/libfaad/huffman.h47
-rw-r--r--audio_codec/libfaad/ic_predict.c258
-rw-r--r--audio_codec/libfaad/ic_predict.h252
-rw-r--r--audio_codec/libfaad/iq_table.h16456
-rw-r--r--audio_codec/libfaad/is.c106
-rw-r--r--audio_codec/libfaad/is.h67
-rw-r--r--audio_codec/libfaad/kbd_win.h2294
-rw-r--r--audio_codec/libfaad/libaacdec.c544
-rw-r--r--audio_codec/libfaad/libaacdec.h64
-rwxr-xr-xaudio_codec/libfaad/libfaad2.def14
-rw-r--r--audio_codec/libfaad/lt_predict.c205
-rw-r--r--audio_codec/libfaad/lt_predict.h66
-rw-r--r--audio_codec/libfaad/mdct.c307
-rw-r--r--audio_codec/libfaad/mdct.h48
-rw-r--r--audio_codec/libfaad/mdct_tab.h3639
-rw-r--r--audio_codec/libfaad/mp4.c307
-rw-r--r--audio_codec/libfaad/mp4.h52
-rw-r--r--audio_codec/libfaad/ms.c71
-rw-r--r--audio_codec/libfaad/ms.h44
-rw-r--r--audio_codec/libfaad/neaacdec.h257
-rw-r--r--audio_codec/libfaad/output.c583
-rw-r--r--audio_codec/libfaad/output.h48
-rw-r--r--audio_codec/libfaad/pns.c273
-rw-r--r--audio_codec/libfaad/pns.h58
-rw-r--r--audio_codec/libfaad/ps_dec.c1905
-rw-r--r--audio_codec/libfaad/ps_dec.h151
-rw-r--r--audio_codec/libfaad/ps_syntax.c532
-rw-r--r--audio_codec/libfaad/ps_tables.h547
-rw-r--r--audio_codec/libfaad/pulse.c59
-rw-r--r--audio_codec/libfaad/pulse.h43
-rw-r--r--audio_codec/libfaad/rvlc.c524
-rw-r--r--audio_codec/libfaad/rvlc.h55
-rw-r--r--audio_codec/libfaad/sbr_dct.c2267
-rw-r--r--audio_codec/libfaad/sbr_dct.h52
-rw-r--r--audio_codec/libfaad/sbr_dec.c679
-rw-r--r--audio_codec/libfaad/sbr_dec.h253
-rw-r--r--audio_codec/libfaad/sbr_e_nf.c475
-rw-r--r--audio_codec/libfaad/sbr_e_nf.h50
-rw-r--r--audio_codec/libfaad/sbr_fbt.c737
-rw-r--r--audio_codec/libfaad/sbr_fbt.h55
-rw-r--r--audio_codec/libfaad/sbr_hfadj.c1644
-rw-r--r--audio_codec/libfaad/sbr_hfadj.h56
-rw-r--r--audio_codec/libfaad/sbr_hfgen.c647
-rw-r--r--audio_codec/libfaad/sbr_hfgen.h49
-rw-r--r--audio_codec/libfaad/sbr_huff.c344
-rw-r--r--audio_codec/libfaad/sbr_huff.h46
-rw-r--r--audio_codec/libfaad/sbr_noise.h564
-rw-r--r--audio_codec/libfaad/sbr_qmf.c614
-rw-r--r--audio_codec/libfaad/sbr_qmf.h55
-rw-r--r--audio_codec/libfaad/sbr_qmf_c.h368
-rw-r--r--audio_codec/libfaad/sbr_syntax.c893
-rw-r--r--audio_codec/libfaad/sbr_syntax.h68
-rw-r--r--audio_codec/libfaad/sbr_tf_grid.c247
-rw-r--r--audio_codec/libfaad/sbr_tf_grid.h47
-rw-r--r--audio_codec/libfaad/sine_win.h4296
-rw-r--r--audio_codec/libfaad/specrec.c1249
-rw-r--r--audio_codec/libfaad/specrec.h49
-rw-r--r--audio_codec/libfaad/ssr.c170
-rw-r--r--audio_codec/libfaad/ssr.h59
-rw-r--r--audio_codec/libfaad/ssr_fb.c191
-rw-r--r--audio_codec/libfaad/ssr_fb.h53
-rw-r--r--audio_codec/libfaad/ssr_ipqf.c171
-rw-r--r--audio_codec/libfaad/ssr_ipqf.h46
-rw-r--r--audio_codec/libfaad/ssr_win.h635
-rw-r--r--audio_codec/libfaad/structs.h513
-rw-r--r--audio_codec/libfaad/syntax.c2539
-rw-r--r--audio_codec/libfaad/syntax.h129
-rw-r--r--audio_codec/libfaad/tns.c304
-rw-r--r--audio_codec/libfaad/tns.h51
-rwxr-xr-xaudio_codec/libflac/Android.mk22
-rw-r--r--audio_codec/libflac/avcodec.h337
-rw-r--r--audio_codec/libflac/bswap.h94
-rw-r--r--audio_codec/libflac/codec.h36
-rw-r--r--audio_codec/libflac/codec_message.h109
-rw-r--r--audio_codec/libflac/common.h356
-rw-r--r--audio_codec/libflac/crc.c146
-rw-r--r--audio_codec/libflac/crc.h46
-rw-r--r--audio_codec/libflac/flac.c43
-rw-r--r--audio_codec/libflac/flac.h124
-rw-r--r--audio_codec/libflac/flac_decode.c943
-rw-r--r--audio_codec/libflac/flacdata.c38
-rw-r--r--audio_codec/libflac/flacdata.h29
-rw-r--r--audio_codec/libflac/get_bits.h564
-rw-r--r--audio_codec/libflac/golomb.h585
-rw-r--r--audio_codec/libflac/internal.h195
-rw-r--r--audio_codec/libflac/intreadwrite.h390
-rw-r--r--audio_codec/libflac/mathops.h78
-rw-r--r--audio_codec/libflac/types.h49
-rwxr-xr-xaudio_codec/liblpcm/Android.mk13
-rw-r--r--audio_codec/liblpcm/lpcm_decode.c437
-rwxr-xr-xaudio_codec/libmad/Android.mk13
-rwxr-xr-xaudio_codec/libmad/D.dat607
-rw-r--r--audio_codec/libmad/bit.c244
-rw-r--r--audio_codec/libmad/bit.h47
-rw-r--r--audio_codec/libmad/config.h133
-rw-r--r--audio_codec/libmad/decoder.c1102
-rw-r--r--audio_codec/libmad/decoder.h91
-rw-r--r--audio_codec/libmad/fixed.c85
-rw-r--r--audio_codec/libmad/fixed.h499
-rw-r--r--audio_codec/libmad/frame.c525
-rw-r--r--audio_codec/libmad/frame.h118
-rw-r--r--audio_codec/libmad/global.h58
-rw-r--r--audio_codec/libmad/huffman.c3109
-rw-r--r--audio_codec/libmad/huffman.h66
-rwxr-xr-xaudio_codec/libmad/imdct_l_arm.S1000
-rwxr-xr-xaudio_codec/libmad/imdct_s.dat62
-rw-r--r--audio_codec/libmad/layer12.c552
-rwxr-xr-xaudio_codec/libmad/layer12.h31
-rw-r--r--audio_codec/libmad/layer3.c2742
-rwxr-xr-xaudio_codec/libmad/layer3.h30
-rw-r--r--audio_codec/libmad/mad.h966
-rwxr-xr-xaudio_codec/libmad/qc_table.dat77
-rwxr-xr-xaudio_codec/libmad/rq_table.dat8747
-rwxr-xr-xaudio_codec/libmad/sf_table.dat106
-rw-r--r--audio_codec/libmad/stream.c185
-rw-r--r--audio_codec/libmad/stream.h111
-rw-r--r--audio_codec/libmad/synth.c921
-rw-r--r--audio_codec/libmad/synth.h69
-rw-r--r--audio_codec/libmad/timer.c493
-rw-r--r--audio_codec/libmad/timer.h100
-rw-r--r--audio_codec/libmad/version.c91
-rw-r--r--audio_codec/libmad/version.h47
-rwxr-xr-xaudio_codec/libpcm/Android.mk11
-rw-r--r--audio_codec/libpcm/intreadwrite.h390
-rw-r--r--audio_codec/libpcm/pcm_decode.c780
-rw-r--r--audio_codec/libraac/Android.mk51
-rw-r--r--audio_codec/libraac/aac_bitstream.c200
-rw-r--r--audio_codec/libraac/aac_bitstream.h133
-rw-r--r--audio_codec/libraac/aac_decode.h148
-rw-r--r--audio_codec/libraac/aac_decode_main.c396
-rw-r--r--audio_codec/libraac/aac_reorder.c85
-rw-r--r--audio_codec/libraac/aac_reorder.h53
-rw-r--r--audio_codec/libraac/aaccommon.h200
-rw-r--r--audio_codec/libraac/aacdec.c607
-rw-r--r--audio_codec/libraac/aacdec.h200
-rw-r--r--audio_codec/libraac/aactabs.c157
-rw-r--r--audio_codec/libraac/assembly.h147
-rw-r--r--audio_codec/libraac/bitstream.c451
-rw-r--r--audio_codec/libraac/bitstream.h76
-rw-r--r--audio_codec/libraac/buffers.c132
-rw-r--r--audio_codec/libraac/coder.h370
-rw-r--r--audio_codec/libraac/dct4.c339
-rw-r--r--audio_codec/libraac/decelmnt.c451
-rw-r--r--audio_codec/libraac/dequant.c382
-rw-r--r--audio_codec/libraac/fft.c393
-rw-r--r--audio_codec/libraac/filefmt.c531
-rw-r--r--audio_codec/libraac/ga_config.c209
-rw-r--r--audio_codec/libraac/ga_config.h86
-rw-r--r--audio_codec/libraac/huffman.c449
-rw-r--r--audio_codec/libraac/hufftabs.c177
-rw-r--r--audio_codec/libraac/imdct.c598
-rw-r--r--audio_codec/libraac/include/challenge.h132
-rw-r--r--audio_codec/libraac/include/codec_defines.h93
-rw-r--r--audio_codec/libraac/include/gecko2codec.h60
-rw-r--r--audio_codec/libraac/include/helix_config.h92
-rw-r--r--audio_codec/libraac/include/helix_mime_types.h56
-rw-r--r--audio_codec/libraac/include/helix_result.h107
-rw-r--r--audio_codec/libraac/include/helix_types.h305
-rw-r--r--audio_codec/libraac/include/helix_utils.h106
-rw-r--r--audio_codec/libraac/include/md5.h113
-rw-r--r--audio_codec/libraac/include/memory_utils.h58
-rw-r--r--audio_codec/libraac/include/pack_utils.h93
-rw-r--r--audio_codec/libraac/include/packet_defines.h48
-rw-r--r--audio_codec/libraac/include/ra8lbr_decode.h161
-rw-r--r--audio_codec/libraac/include/ra_backend.h94
-rw-r--r--audio_codec/libraac/include/ra_decode.h183
-rw-r--r--audio_codec/libraac/include/ra_depack.h177
-rw-r--r--audio_codec/libraac/include/ra_format_info.h60
-rw-r--r--audio_codec/libraac/include/rasl.h71
-rw-r--r--audio_codec/libraac/include/rdtpck.h153
-rw-r--r--audio_codec/libraac/include/rm_error.h54
-rw-r--r--audio_codec/libraac/include/rm_error_default.h53
-rw-r--r--audio_codec/libraac/include/rm_io_default.h49
-rw-r--r--audio_codec/libraac/include/rm_memory.h54
-rw-r--r--audio_codec/libraac/include/rm_memory_default.h46
-rw-r--r--audio_codec/libraac/include/rm_packet.h80
-rw-r--r--audio_codec/libraac/include/rm_parse.h302
-rw-r--r--audio_codec/libraac/include/rm_property.h107
-rw-r--r--audio_codec/libraac/include/rm_stream.h115
-rw-r--r--audio_codec/libraac/include/rm_stream_internal.h77
-rw-r--r--audio_codec/libraac/include/rv20backend.h69
-rw-r--r--audio_codec/libraac/include/rv30backend.h68
-rw-r--r--audio_codec/libraac/include/rv_backend.h84
-rw-r--r--audio_codec/libraac/include/rv_backend_types.h198
-rw-r--r--audio_codec/libraac/include/rv_decode.h208
-rw-r--r--audio_codec/libraac/include/rv_decode_message.h492
-rw-r--r--audio_codec/libraac/include/rv_depack.h162
-rw-r--r--audio_codec/libraac/include/rv_format_info.h91
-rw-r--r--audio_codec/libraac/include/statname.h118
-rw-r--r--audio_codec/libraac/include/stream_hdr_structs.h66
-rw-r--r--audio_codec/libraac/include/stream_hdr_utils.h77
-rw-r--r--audio_codec/libraac/include/string_utils.h62
-rw-r--r--audio_codec/libraac/include/tngpkt.h400
-rw-r--r--audio_codec/libraac/memory_utils.c100
-rw-r--r--audio_codec/libraac/noiseless.c503
-rw-r--r--audio_codec/libraac/pack_utils.c306
-rw-r--r--audio_codec/libraac/pns.c369
-rw-r--r--audio_codec/libraac/ra_depack.c230
-rw-r--r--audio_codec/libraac/ra_depack_internal.c1713
-rw-r--r--audio_codec/libraac/ra_depack_internal.h232
-rw-r--r--audio_codec/libraac/raac_decode.c854
-rw-r--r--audio_codec/libraac/raac_decode.h37
-rw-r--r--audio_codec/libraac/rm_error_default.c60
-rw-r--r--audio_codec/libraac/rm_io_default.c101
-rw-r--r--audio_codec/libraac/rm_memory_default.c54
-rw-r--r--audio_codec/libraac/rm_packet.c117
-rw-r--r--audio_codec/libraac/rm_parser.c649
-rw-r--r--audio_codec/libraac/rm_parser_internal.c3342
-rw-r--r--audio_codec/libraac/rm_parser_internal.h420
-rw-r--r--audio_codec/libraac/rm_property.c105
-rw-r--r--audio_codec/libraac/rm_stream.c356
-rw-r--r--audio_codec/libraac/rv_depack.c271
-rw-r--r--audio_codec/libraac/rv_depack_internal.c1071
-rw-r--r--audio_codec/libraac/rv_depack_internal.h171
-rw-r--r--audio_codec/libraac/sbr.c431
-rw-r--r--audio_codec/libraac/sbr.h381
-rwxr-xr-xaudio_codec/libraac/sbrcov.s164
-rw-r--r--audio_codec/libraac/sbrfft.c368
-rw-r--r--audio_codec/libraac/sbrfreq.c667
-rw-r--r--audio_codec/libraac/sbrhfadj.c877
-rw-r--r--audio_codec/libraac/sbrhfgen.c646
-rw-r--r--audio_codec/libraac/sbrhuff.c492
-rw-r--r--audio_codec/libraac/sbrimdct.c447
-rw-r--r--audio_codec/libraac/sbrmath.c198
-rw-r--r--audio_codec/libraac/sbrqmf.c643
-rwxr-xr-xaudio_codec/libraac/sbrqmfak.s182
-rwxr-xr-xaudio_codec/libraac/sbrqmfsk.s130
-rw-r--r--audio_codec/libraac/sbrside.c615
-rw-r--r--audio_codec/libraac/sbrtabs.c400
-rw-r--r--audio_codec/libraac/statname.h115
-rw-r--r--audio_codec/libraac/stproc.c252
-rw-r--r--audio_codec/libraac/stream_hdr_utils.c136
-rw-r--r--audio_codec/libraac/string_utils.c87
-rw-r--r--audio_codec/libraac/tns.c307
-rw-r--r--audio_codec/libraac/trigtabs.c1000
-rw-r--r--audio_codec/libraac/trigtabs_fltgen.c357
-rwxr-xr-xaudio_codec/wfd_aac_decoder/Android.mk23
-rw-r--r--audio_codec/wfd_aac_decoder/aaccommon.h210
-rw-r--r--audio_codec/wfd_aac_decoder/aacdec.c508
-rw-r--r--audio_codec/wfd_aac_decoder/aacdec.h206
-rw-r--r--audio_codec/wfd_aac_decoder/aactabs.c157
-rw-r--r--audio_codec/wfd_aac_decoder/assembly.h640
-rw-r--r--audio_codec/wfd_aac_decoder/assembly_mw.h743
-rw-r--r--audio_codec/wfd_aac_decoder/bitstream.c261
-rw-r--r--audio_codec/wfd_aac_decoder/bitstream.h74
-rw-r--r--audio_codec/wfd_aac_decoder/buffers.c140
-rw-r--r--audio_codec/wfd_aac_decoder/coder.h369
-rw-r--r--audio_codec/wfd_aac_decoder/dct4.c337
-rw-r--r--audio_codec/wfd_aac_decoder/decelmnt.c445
-rw-r--r--audio_codec/wfd_aac_decoder/dequant.c379
-rw-r--r--audio_codec/wfd_aac_decoder/fft.c391
-rw-r--r--audio_codec/wfd_aac_decoder/filefmt.c539
-rw-r--r--audio_codec/wfd_aac_decoder/helix_aac_decode.c548
-rw-r--r--audio_codec/wfd_aac_decoder/huffman.c450
-rw-r--r--audio_codec/wfd_aac_decoder/hufftabs.c177
-rw-r--r--audio_codec/wfd_aac_decoder/imdct.c596
-rw-r--r--audio_codec/wfd_aac_decoder/noiseless.c513
-rw-r--r--audio_codec/wfd_aac_decoder/pns.c371
-rw-r--r--audio_codec/wfd_aac_decoder/sbr.c434
-rw-r--r--audio_codec/wfd_aac_decoder/sbr.h380
-rw-r--r--audio_codec/wfd_aac_decoder/sbrfft.c368
-rw-r--r--audio_codec/wfd_aac_decoder/sbrfreq.c673
-rw-r--r--audio_codec/wfd_aac_decoder/sbrhfadj.c882
-rw-r--r--audio_codec/wfd_aac_decoder/sbrhfgen.c655
-rw-r--r--audio_codec/wfd_aac_decoder/sbrhuff.c494
-rw-r--r--audio_codec/wfd_aac_decoder/sbrimdct.c447
-rw-r--r--audio_codec/wfd_aac_decoder/sbrmath.c198
-rw-r--r--audio_codec/wfd_aac_decoder/sbrqmf.c648
-rw-r--r--audio_codec/wfd_aac_decoder/sbrside.c634
-rw-r--r--audio_codec/wfd_aac_decoder/sbrtabs.c400
-rw-r--r--audio_codec/wfd_aac_decoder/statname.h115
-rw-r--r--audio_codec/wfd_aac_decoder/stproc.c251
-rw-r--r--audio_codec/wfd_aac_decoder/tns.c307
-rw-r--r--audio_codec/wfd_aac_decoder/trigtabs.c1000
-rw-r--r--audio_codec/wfd_aac_decoder/trigtabs_fltgen.c357
545 files changed, 230976 insertions, 0 deletions
diff --git a/audio_codec/libamr/dec_gain.c b/audio_codec/libamr/dec_gain.c
new file mode 100644
index 0000000..aa69cf2
--- a/dev/null
+++ b/audio_codec/libamr/dec_gain.c
@@ -0,0 +1,853 @@
+/*
+ *===================================================================
+ * 3GPP AMR Wideband Floating-point Speech Codec
+ *===================================================================
+ */
+#include <memory.h>
+#include "typedef.h"
+#include "dec_util.h"
+
+#define L_SUBFR 64 /* Subframe size */
+#define L_LTPHIST 5
+#define ONE_PER_3 10923
+#define ONE_PER_LTPHIST 6554
+#define UP_SAMP 4
+#define L_INTERPOL2 16
+
+extern const Word16 D_ROM_inter4_2[];
+extern const Word16 D_ROM_pdown_unusable[];
+extern const Word16 D_ROM_pdown_usable[];
+extern const Word16 D_ROM_cdown_unusable[];
+extern const Word16 D_ROM_cdown_usable[];
+extern const Word16 D_ROM_qua_gain6b[];
+extern const Word16 D_ROM_qua_gain7b[];
+
+/*
+ * D_GAIN_init
+ *
+ * Parameters:
+ * mem O: static memory
+ *
+ * Function:
+ * Initialisation of 2nd order quantiser energy predictor.
+ *
+ * Returns:
+ * void
+ */
+void D_GAIN_init(Word16 *mem)
+{
+
+ /* 4nd order quantizer energy predictor (init to -14.0 in Q10) */
+ mem[0] = -14336; /* past_qua_en[0] */
+ mem[1] = -14336; /* past_qua_en[1] */
+ mem[2] = -14336; /* past_qua_en[2] */
+ mem[3] = -14336; /* past_qua_en[3] */
+ /*
+ * mem[4] = 0; past_gain_pit
+ * mem[5] = 0; past_gain_code
+ * mem[6] = 0; prev_gc
+ * mem[7 - 11] = 0; pbuf[i]
+ * mem[12 - 16] = 0; gbuf[i]
+ * mem[17 - 21] = 0; pbuf2[i]
+ */
+ memset(&mem[4], 0, 18 * sizeof(Word16));
+
+ mem[22] = 21845; /* seed */
+ return;
+}
+
+
+/*
+ * D_GAIN_median
+ *
+ * Parameters:
+ * buf I: previous gains
+ *
+ * Function:
+ * Median of gains
+ *
+ * Returns:
+ * median of 5 previous gains
+ */
+static Word16 D_GAIN_median(Word16 x[])
+{
+ Word16 x1, x2, x3, x4, x5;
+ Word16 tmp;
+ x1 = x[ - 2];
+ x2 = x[ - 1];
+ x3 = x[0];
+ x4 = x[1];
+ x5 = x[2];
+
+ if (x2 < x1) {
+ tmp = x1;
+ x1 = x2;
+ x2 = tmp;
+ }
+
+ if (x3 < x1) {
+ tmp = x1;
+ x1 = x3;
+ x3 = tmp;
+ }
+
+ if (x4 < x1) {
+ tmp = x1;
+ x1 = x4;
+ x4 = tmp;
+ }
+
+ if (x5 < x1) {
+ x5 = x1;
+ }
+
+ if (x3 < x2) {
+ tmp = x2;
+ x2 = x3;
+ x3 = tmp;
+ }
+
+ if (x4 < x2) {
+ tmp = x2;
+ x2 = x4;
+ x4 = tmp;
+ }
+
+ if (x5 < x2) {
+ x5 = x2;
+ }
+
+ if (x4 < x3) {
+ x3 = x4;
+ }
+
+ if (x5 < x3) {
+ x3 = x5;
+ }
+
+ return(x3);
+}
+
+
+/*
+ * D_GAIN_decode
+ *
+ * Parameters:
+ * index I: Quantization index
+ * nbits I: number of bits (6 or 7)
+ * code I: Innovative code vector
+ * L_subfr I: Subframe size
+ * gain_pit O: (Q14) Quantized pitch gain
+ * gain_code O: (Q16) Quantized codebook gain
+ * bfi I: Bad frame indicator
+ * prev_bfi I: Previous BF indicator
+ * state I: State of BFH
+ * unusable_frame I: UF indicator
+ * vad_hist I: number of non-speech frames
+ * mem I/O: static memory (4 words)
+ *
+ *
+ * Function:
+ * Decoding of pitch and codebook gains
+ *
+ * Returns:
+ * void
+ */
+void D_GAIN_decode(Word16 index, Word16 nbits, Word16 code[], Word16 *gain_pit,
+ Word32 *gain_cod, Word16 bfi, Word16 prev_bfi,
+ Word16 state, Word16 unusable_frame, Word16 vad_hist,
+ Word16 *mem)
+{
+
+ Word32 gcode0, qua_ener, L_tmp;
+ const Word16 * p;
+ Word16 *past_gain_pit, *past_gain_code, *past_qua_en, *prev_gc;
+ Word16 *gbuf, *pbuf, *pbuf2;
+ Word16 i, tmp, exp, frac, exp_gcode0, gcode_inov;
+ Word16 g_code;
+
+ past_qua_en = mem;
+ past_gain_pit = mem + 4;
+ past_gain_code = mem + 5;
+ prev_gc = mem + 6;
+ pbuf = mem + 7;
+ gbuf = mem + 12;
+ pbuf2 = mem + 17;
+
+ /*
+ * Find energy of code and compute:
+ *
+ * L_tmp = 1.0 / sqrt(energy of code/ L_subfr)
+ */
+ L_tmp = D_UTIL_dot_product12(code, code, L_SUBFR, &exp);
+ exp = (Word16)(exp - (18 + 6)); /* exp: -18 (code in Q9), -6 (/L_subfr) */
+ D_UTIL_normalised_inverse_sqrt(&L_tmp, &exp);
+
+ if (exp > 3) {
+ L_tmp <<= (exp - 3);
+ } else {
+ L_tmp >>= (3 - exp);
+ }
+
+ gcode_inov = (Word16)(L_tmp >> 16); /* g_code_inov in Q12 */
+
+ /*
+ * Case of erasure.
+ */
+ if (bfi != 0) {
+ tmp = D_GAIN_median(&pbuf[2]);
+ *past_gain_pit = tmp;
+
+ if (*past_gain_pit > 15565) {
+ *past_gain_pit = 15565; /* 0.95 in Q14 */
+ }
+
+ if (unusable_frame != 0) {
+ *gain_pit =
+ (Word16)((D_ROM_pdown_unusable[state] * *past_gain_pit) >> 15);
+ } else {
+ *gain_pit =
+ (Word16)((D_ROM_pdown_usable[state] * *past_gain_pit) >> 15);
+ }
+
+ tmp = D_GAIN_median(&gbuf[2]);
+
+ if (vad_hist > 2) {
+ *past_gain_code = tmp;
+ } else {
+ if (unusable_frame != 0) {
+ *past_gain_code =
+ (Word16)((D_ROM_cdown_unusable[state] * tmp) >> 15);
+ } else {
+ *past_gain_code =
+ (Word16)((D_ROM_cdown_usable[state] * tmp) >> 15);
+ }
+ }
+
+ /* update table of past quantized energies */
+ L_tmp = past_qua_en[0] + past_qua_en[1] + past_qua_en[2] + past_qua_en[3];
+ qua_ener = L_tmp >> 2;
+ qua_ener = qua_ener - 3072; /* -3 in Q10 */
+
+ if (qua_ener < - 14336) {
+ qua_ener = -14336; /* -14 in Q10 */
+ }
+
+ past_qua_en[3] = past_qua_en[2];
+ past_qua_en[2] = past_qua_en[1];
+ past_qua_en[1] = past_qua_en[0];
+ past_qua_en[0] = (Word16)qua_ener;
+
+ for (i = 1; i < 5; i++) {
+ gbuf[i - 1] = gbuf[i];
+ }
+ gbuf[4] = *past_gain_code;
+
+ for (i = 1; i < 5; i++) {
+ pbuf[i - 1] = pbuf[i];
+ }
+ pbuf[4] = *past_gain_pit;
+
+ /* adjust gain according to energy of code */
+ /* past_gain_code(Q3) * gcode_inov(Q12) => Q16 */
+ *gain_cod = (*past_gain_code * gcode_inov) << 1;
+
+ return;
+ }
+
+ /*
+ * Compute gcode0.
+ * = Sum(i=0,1) pred[i]*past_qua_en[i] + mean_ener - ener_code
+ */
+
+ /* MEAN_ENER in Q24 = 0x1e000000 */
+ /* MA prediction coeff = {0.5, 0.4, 0.3, 0.2} in Q13 */
+ L_tmp = 0xF000000 + (4096 * past_qua_en[0]); /* Q13*Q10 -> Q24 */
+ L_tmp = L_tmp + (3277 * past_qua_en[1]); /* Q13*Q10 -> Q24 */
+ L_tmp = L_tmp + (2458 * past_qua_en[2]); /* Q13*Q10 -> Q24 */
+ L_tmp = L_tmp + (1638 * past_qua_en[3]); /* Q13*Q10 -> Q24 */
+ gcode0 = L_tmp >> 15; /* From Q24 to Q8 */
+
+ /*
+ * gcode0 = pow(10.0, gcode0/20)
+ * = pow(2, 3.321928*gcode0/20)
+ * = pow(2, 0.166096*gcode0)
+ */
+ L_tmp = (gcode0 * 5443) >> 7;
+ /* *0.166096 in Q15 -> Q24, From Q24 to Q16 */
+ D_UTIL_l_extract(L_tmp, &exp_gcode0, &frac);
+ /* Extract exponant of gcode0 */
+ gcode0 = D_UTIL_pow2(14, frac); /* Put 14 as exponant so that */
+
+ /*
+ * output of Pow2() will be:
+ * 16384 < Pow2() <= 32767
+ */
+ exp_gcode0 = (Word16)(exp_gcode0 - 14);
+
+ /* Read the quantized gains */
+ if (nbits == 6) {
+ p = &D_ROM_qua_gain6b[(index << 1)];
+ } else {
+ p = &D_ROM_qua_gain7b[(index << 1)];
+ }
+
+ *gain_pit = *p++; /* selected pitch gain in Q14 */
+ g_code = *p++; /* selected code gain in Q11 */
+ L_tmp = g_code * gcode0;
+ exp_gcode0 += 5;
+
+ if (exp_gcode0 >= 0) {
+ *gain_cod = L_tmp << exp_gcode0; /* gain of code in Q16 */
+ } else {
+ *gain_cod = L_tmp >> -exp_gcode0; /* gain of code in Q16 */
+ }
+
+ if (prev_bfi == 1) {
+ L_tmp = (*prev_gc * 5120) << 1; /* prev_gc(Q3) * 1.25(Q12) = Q16 */
+
+ /* if((*gain_cod > ((*prev_gc) * 1.25)) && (*gain_cod > 100.0)) */
+ if ((*gain_cod > L_tmp) & (*gain_cod > 6553600)) {
+ *gain_cod = L_tmp;
+ }
+ }
+
+ /* keep past gain code in Q3 for frame erasure (can saturate) */
+ L_tmp = (*gain_cod + 0x1000) >> 13;
+
+ if (L_tmp < 32768) {
+ *past_gain_code = (Word16)L_tmp;
+ } else {
+ *past_gain_code = 32767;
+ }
+
+ *past_gain_pit = *gain_pit;
+ *prev_gc = *past_gain_code;
+
+ for (i = 1; i < 5; i++) {
+ gbuf[i - 1] = gbuf[i];
+ }
+ gbuf[4] = *past_gain_code;
+
+ for (i = 1; i < 5; i++) {
+ pbuf[i - 1] = pbuf[i];
+ }
+ pbuf[4] = *past_gain_pit;
+
+ for (i = 1; i < 5; i++) {
+ pbuf2[i - 1] = pbuf2[i];
+ }
+ pbuf2[4] = *past_gain_pit;
+
+ /* adjust gain according to energy of code */
+ D_UTIL_l_extract(*gain_cod, &exp, &frac);
+ L_tmp = D_UTIL_mpy_32_16(exp, frac, gcode_inov);
+
+ if (L_tmp < 0xFFFFFFF) {
+ *gain_cod = (L_tmp << 3); /* gcode_inov in Q12 */
+ } else {
+ *gain_cod = 0x7FFFFFFF;
+ }
+
+ /*
+ * qua_ener = 20*log10(g_code)
+ * = 6.0206*log2(g_code)
+ * = 6.0206*(log2(g_codeQ11) - 11)
+ */
+ L_tmp = (Word32)(g_code);
+ D_UTIL_log2(L_tmp, &exp, &frac);
+ exp = (Word16)(exp - 11);
+ L_tmp = D_UTIL_mpy_32_16(exp, frac, 24660); /* x 6.0206 in Q12 */
+ qua_ener = L_tmp >> 3; /* result in Q10 */
+
+ /* update table of past quantized energies */
+ past_qua_en[3] = past_qua_en[2];
+ past_qua_en[2] = past_qua_en[1];
+ past_qua_en[1] = past_qua_en[0];
+ past_qua_en[0] = (Word16)qua_ener;
+
+ return;
+}
+
+
+/*
+ * D_GAIN_adaptive_control
+ *
+ * Parameters:
+ * sig_in I: postfilter input signal
+ * sig_out I/O: postfilter output signal
+ * l_trm I: subframe size
+ *
+ * Function:
+ * Adaptive gain control is used to compensate for
+ * the gain difference between the non-emphasized excitation and
+ * emphasized excitation.
+ *
+ * Returns:
+ * void
+ */
+void D_GAIN_adaptive_control(Word16 *sig_in, Word16 *sig_out, Word16 l_trm)
+{
+ Word32 s, temp, i, exp;
+ Word32 gain_in, gain_out, g0;
+
+ /* calculate gain_out with exponent */
+ temp = sig_out[0] >> 2;
+ s = temp * temp;
+
+ for (i = 1; i < l_trm; i++) {
+ temp = sig_out[i] >> 2;
+ s += temp * temp;
+ }
+
+ s <<= 1;
+
+ if (s == 0) {
+ return;
+ }
+ exp = (D_UTIL_norm_l(s) - 1);
+
+ if (exp >= 0) {
+ gain_out = ((s << exp) + 0x8000) >> 16;
+ } else {
+ gain_out = ((s >> -exp) + 0x8000) >> 16;
+ }
+
+ /* calculate gain_in with exponent */
+ temp = sig_in[0] >> 2;
+ s = temp * temp;
+
+ for (i = 1; i < l_trm; i++) {
+ temp = sig_in[i] >> 2;
+ s += temp * temp;
+ }
+
+ s <<= 1;
+
+ if (s == 0) {
+ g0 = 0;
+ } else {
+ i = D_UTIL_norm_l(s);
+ s = ((s << i) + 0x8000) >> 16;
+
+ if ((s < 32768) & (s > 0)) {
+ gain_in = s;
+ } else {
+ gain_in = 32767;
+ }
+ exp = exp - i;
+
+ /*
+ * g0 = sqrt(gain_in/gain_out)
+ */
+ s = (gain_out << 15) / gain_in;
+ s = s << (7 - exp); /* s = gain_out / gain_in */
+ s = D_UTIL_inverse_sqrt(s);
+ g0 = ((s << 9) + 0x8000) >> 16;
+ }
+
+ /* sig_out(n) = gain(n) sig_out(n) */
+ for (i = 0; i < l_trm; i++) {
+ s = (sig_out[i] * g0) >> 13;
+ sig_out[i] = D_UTIL_saturate(s);
+ }
+
+ return;
+}
+
+
+/*
+ * D_GAIN_insert_lag
+ *
+ * Parameters:
+ * array I/O: pitch lag history
+ * n I: history size
+ * x I: lag value
+ *
+ * Function:
+ * Insert lag into correct location
+ *
+ * Returns:
+ * void
+ */
+static void D_GAIN_insert_lag(Word16 array[], Word32 n, Word16 x)
+{
+ Word32 i;
+
+ for (i = n - 1; i >= 0; i--) {
+ if (x < array[i]) {
+ array[i + 1] = array[i];
+ } else {
+ break;
+ }
+ }
+
+ array[i + 1] = x;
+}
+
+
+/*
+ * D_GAIN_sort_lag
+ *
+ * Parameters:
+ * array I/O: pitch lag history
+ * n I: history size
+ *
+ * Function:
+ * Sorting of the lag history
+ *
+ * Returns:
+ * void
+ */
+static void D_GAIN_sort_lag(Word16 array[], Word16 n)
+{
+ Word32 i;
+
+ for (i = 0; i < n; i++) {
+ D_GAIN_insert_lag(array, i, array[i]);
+ }
+}
+
+
+/*
+ * D_GAIN_lag_concealment_init
+ *
+ * Parameters:
+ * lag_hist O: pitch lag history
+ *
+ * Function:
+ * Initialise lag history to 64
+ *
+ * Returns:
+ * void
+ */
+void D_GAIN_lag_concealment_init(Word16 lag_hist[])
+{
+ Word32 i;
+
+ for (i = 0; i < L_LTPHIST; i++) {
+ lag_hist[i] = 64;
+ }
+}
+
+
+/*
+ * D_GAIN_lag_concealment
+ *
+ * Parameters:
+ * gain_hist I: gain history
+ * lag_hist I: pitch lag history
+ * T0 O: current lag
+ * old_T0 I: previous lag
+ * seed I/O: seed for random
+ * unusable_frame I: lost frame
+ *
+ * Function:
+ * Concealment of LTP lags during bad frames
+ *
+ * Returns:
+ * void
+ */
+void D_GAIN_lag_concealment(Word16 gain_hist[], Word16 lag_hist[],
+ Word32 *T0, Word16 *old_T0, Word16 *seed,
+ Word16 unusable_frame)
+{
+ Word32 i, lagDif, tmp, tmp2, D2, meanLag = 0;
+ Word16 lag_hist2[L_LTPHIST] = {0};
+ Word16 maxLag, minLag, lastLag;
+ Word16 minGain, lastGain, secLastGain;
+ Word16 D;
+
+ /*
+ * Is lag index such that it can be aplied directly
+ * or does it has to be subtituted
+ */
+ lastGain = gain_hist[4];
+ secLastGain = gain_hist[3];
+ lastLag = lag_hist[0];
+
+ /* SMALLEST history lag */
+ minLag = lag_hist[0];
+
+ for (i = 1; i < L_LTPHIST; i++) {
+ if (lag_hist[i] < minLag) {
+ minLag = lag_hist[i];
+ }
+ }
+
+ /* BIGGEST history lag */
+ maxLag = lag_hist[0];
+
+ for (i = 1; i < L_LTPHIST; i++) {
+ if (lag_hist[i] > maxLag) {
+ maxLag = lag_hist[i];
+ }
+ }
+
+ /* SMALLEST history gain */
+ minGain = gain_hist[0];
+
+ for (i = 1; i < L_LTPHIST; i++) {
+ if (gain_hist[i] < minGain) {
+ minGain = gain_hist[i];
+ }
+ }
+
+ /* Difference between MAX and MIN lag */
+ lagDif = maxLag - minLag;
+
+ if (unusable_frame != 0) {
+ /*
+ * LTP-lag for RX_SPEECH_LOST
+ * Recognition of the LTP-history
+ */
+ if ((minGain > 8192) & (lagDif < 10)) {
+ *T0 = *old_T0;
+ } else if ((lastGain > 8192) && (secLastGain > 8192)) {
+ *T0 = lag_hist[0];
+ } else {
+ /*
+ * SORT
+ * The sorting of the lag history
+ */
+ for (i = 0; i < L_LTPHIST; i++) {
+ lag_hist2[i] = lag_hist[i];
+ }
+ D_GAIN_sort_lag(lag_hist2, 5);
+
+ /*
+ * Lag is weighted towards bigger lags
+ * and random variation is added
+ */
+ lagDif = (lag_hist2[4] - lag_hist2[2]);
+
+ if (lagDif > 40) {
+ lagDif = 40;
+ }
+
+ D = D_UTIL_random(seed); /* D={-1, ...,1} */
+
+ /* D2={-lagDif/2..lagDif/2} */
+ tmp = lagDif >> 1;
+ D2 = (tmp * D) >> 15;
+ tmp = (lag_hist2[2] + lag_hist2[3]) + lag_hist2[4];
+ *T0 = ((tmp * ONE_PER_3) >> 15) + D2;
+ }
+
+ /* New lag is not allowed to be bigger or smaller than last lag values */
+ if (*T0 > maxLag) {
+ *T0 = maxLag;
+ }
+
+ if (*T0 < minLag) {
+ *T0 = minLag;
+ }
+ } else {
+ /*
+ * LTP-lag for RX_BAD_FRAME
+ * MEAN lag
+ */
+ meanLag = 0;
+
+ for (i = 0; i < L_LTPHIST; i++) {
+ meanLag = meanLag + lag_hist[i];
+ }
+
+ meanLag = (meanLag * ONE_PER_LTPHIST) >> 15;
+ tmp = *T0 - maxLag;
+ tmp2 = *T0 - lastLag;
+
+ if ((lagDif < 10) & (*T0 > (minLag - 5)) & (tmp < 5)) {
+ *T0 = *T0;
+ } else if ((lastGain > 8192) & (secLastGain > 8192) & ((tmp2 > - 10)
+ & (tmp2 < 10))) {
+ *T0 = *T0;
+ } else if ((minGain < 6554) & (lastGain == minGain) & ((*T0 > minLag)
+ & (*T0 < maxLag))) {
+ *T0 = *T0;
+ } else if ((lagDif < 70) & (*T0 > minLag) & (*T0 < maxLag)) {
+ *T0 = *T0;
+ } else if ((*T0 > meanLag) & (*T0 < maxLag)) {
+ *T0 = *T0;
+ } else {
+ if ((minGain > 8192) & (lagDif < 10)) {
+ *T0 = lag_hist[0];
+ } else if ((lastGain > 8192) & (secLastGain > 8192)) {
+ *T0 = lag_hist[0];
+ } else {
+ /*
+ * SORT
+ * The sorting of the lag history
+ */
+ for (i = 0; i < L_LTPHIST; i++) {
+ lag_hist2[i] = lag_hist[i];
+ }
+
+ D_GAIN_sort_lag(lag_hist2, 5);
+
+ /*
+ * Lag is weighted towards bigger lags
+ * and random variation is added
+ */
+ lagDif = lag_hist2[4] - lag_hist2[2];
+
+ if (lagDif > 40) {
+ lagDif = 40;
+ }
+
+ D = D_UTIL_random(seed); /* D={-1,.., 1} */
+
+ /* D2={-lagDif/2..lagDif/2} */
+ tmp = lagDif >> 1;
+ D2 = (tmp * D) >> 15;
+ tmp = (lag_hist2[2] + lag_hist2[3]) + lag_hist2[4];
+ *T0 = ((tmp * ONE_PER_3) >> 15) + D2;
+ }
+
+ /*
+ * New lag is not allowed to be bigger or
+ * smaller than last lag values
+ */
+ if (*T0 > maxLag) {
+ *T0 = maxLag;
+ }
+
+ if (*T0 < minLag) {
+ *T0 = minLag;
+ }
+ }
+ }
+}
+
+
+/*
+ * D_GAIN_adaptive_codebook_excitation
+ *
+ * Parameters:
+ * exc I/O: excitation buffer
+ * T0 I: integer pitch lag
+ * frac I: fraction of lag
+ *
+ * Function:
+ * Compute the result of Word32 term prediction with fractional
+ * interpolation of resolution 1/4.
+ *
+ * Returns:
+ * interpolated signal (adaptive codebook excitation)
+ */
+void D_GAIN_adaptive_codebook_excitation(Word16 exc[], Word32 T0, Word32 frac)
+{
+ Word32 i, j, k, sum;
+ Word16 *x;
+
+ x = &exc[ - T0];
+ frac = -(frac);
+
+ if (frac < 0) {
+ frac = (frac + UP_SAMP);
+ x--;
+ }
+ x = x - L_INTERPOL2 + 1;
+
+ for (j = 0; j < L_SUBFR + 1; j++) {
+ sum = 0L;
+
+ for (i = 0, k = ((UP_SAMP - 1) - frac); i < 2 * L_INTERPOL2; i++,
+ k += UP_SAMP) {
+ sum += x[i] * D_ROM_inter4_2[k];
+ }
+ sum = (sum + 0x2000) >> 14;
+
+ exc[j] = D_UTIL_saturate(sum);
+
+ x++;
+ }
+ return;
+}
+
+
+/*
+ * D_GAIN_pitch_sharpening
+ *
+ * Parameters:
+ * x I/O: impulse response (or algebraic code)
+ * pit_lag I: pitch lag
+ * sharp I: (Q15) pitch sharpening factor
+ *
+ * Function:
+ * Performs Pitch sharpening routine for one subframe.
+ *
+ * Returns:
+ * void
+ */
+void D_GAIN_pitch_sharpening(Word16 *x, Word32 pit_lag, Word16 sharp)
+{
+ Word32 i;
+ Word32 tmp;
+
+ for (i = pit_lag; i < L_SUBFR; i++) {
+ tmp = x[i] << 15;
+ tmp += x[i - pit_lag] * sharp;
+ x[i] = (Word16)((tmp + 0x4000) >> 15);
+ }
+ return;
+}
+
+
+/*
+ * D_GAIN_find_voice_factor
+ *
+ * Parameters:
+ * exc I: pitch excitation
+ * Q_exc I: exc format
+ * gain_pit I: (Q14) gain of pitch
+ * code I: (Q9) fixed codebook excitation
+ * gain_code I: (Q0) gain of code
+ * L_subfr I: subframe length
+ *
+ * Function:
+ * Find the voicing factor.
+ *
+ * Returns:
+ * (Q15) 1=voice to -1=unvoiced
+ */
+Word16 D_GAIN_find_voice_factor(Word16 exc[], Word16 Q_exc,
+ Word16 gain_pit, Word16 code[],
+ Word16 gain_code, Word16 L_subfr)
+{
+
+ Word32 tmp, ener1, ener2, i;
+ Word16 exp, exp1, exp2;
+
+ ener1 = (D_UTIL_dot_product12(exc, exc, L_subfr, &exp1)) >> 16;
+ exp1 = (Word16)(exp1 - (Q_exc + Q_exc));
+ tmp = (gain_pit * gain_pit) << 1;
+ exp = D_UTIL_norm_l(tmp);
+ tmp = (tmp << exp) >> 16;
+ ener1 = (ener1 * tmp) >> 15;
+ exp1 = (Word16)((exp1 - exp) - 10); /* 10 -> gain_pit Q14 to Q9 */
+ ener2 = D_UTIL_dot_product12(code, code, L_subfr, &exp2) >> 16;
+ exp = D_UTIL_norm_s(gain_code);
+ tmp = gain_code << exp;
+ tmp = (tmp * tmp) >> 15;
+ ener2 = (ener2 * tmp) >> 15;
+ exp2 = (Word16)(exp2 - (exp << 1));
+ i = exp1 - exp2;
+
+ if (i >= 0) {
+ ener1 = ener1 >> 1;
+ ener2 = ener2 >> (i + 1);
+ } else if (i > (-16)) {
+ ener1 = ener1 >> (1 - i);
+ ener2 = ener2 >> 1;
+ } else {
+ ener1 = 0;
+ ener2 = ener2 >> 1;
+ }
+
+ tmp = ener1 - ener2;
+ ener1 = (ener1 + ener2) + 1;
+ tmp = (tmp << 15) / ener1;
+
+ return((Word16)tmp);
+}