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_dtx.c b/audio_codec/libamr/dec_dtx.c
new file mode 100644
index 0000000..f6c9caf
--- a/dev/null
+++ b/audio_codec/libamr/dec_dtx.c
@@ -0,0 +1,683 @@
+/*
+ *===================================================================
+ * 3GPP AMR Wideband Floating-point Speech Codec
+ *===================================================================
+ */
+#include <stdlib.h>
+#include <memory.h>
+#include <math.h>
+#include "typedef.h"
+#include "dec_dtx.h"
+#include "dec_lpc.h"
+#include "dec_util.h"
+
+
+#define MAX_31 (Word32)0x3FFFFFFF
+#define L_FRAME 256 /* Frame size */
+#define RX_SPEECH_LOST 2
+#define RX_SPEECH_BAD 3
+#define RX_SID_FIRST 4
+#define RX_SID_UPDATE 5
+#define RX_SID_BAD 6
+#define RX_NO_DATA 7
+#define ISF_GAP 128 /* 50 */
+#define D_DTX_MAX_EMPTY_THRESH 50
+#define GAIN_FACTOR 75
+#define ISF_FACTOR_LOW 256
+#define ISF_FACTOR_STEP 2
+#define ISF_DITH_GAP 448
+#define D_DTX_HANG_CONST 7 /* yields eight frames of SP HANGOVER */
+#define D_DTX_ELAPSED_FRAMES_THRESH (24 + 7 - 1)
+#define RANDOM_INITSEED 21845 /* own random init value */
+
+
+/*
+ * D_DTX_reset
+ *
+ * Parameters:
+ * st O: state struct
+ *
+ * Function:
+ * Initializes state memory
+ *
+ * Returns:
+ * non-zero with error, zero for ok
+ */
+int D_DTX_reset(D_DTX_State *st, const Word16 *isf_init)
+{
+ Word32 i;
+
+ if (st == (D_DTX_State*)NULL) {
+ return(-1);
+ }
+ st->mem_since_last_sid = 0;
+ st->mem_true_sid_period_inv = (1 << 13); /* 0.25 in Q15 */
+ st->mem_log_en = 3500;
+ st->mem_log_en_prev = 3500;
+
+ /* low level noise for better performance in DTX handover cases */
+ st->mem_cng_seed = RANDOM_INITSEED;
+ st->mem_hist_ptr = 0;
+
+ /* Init isf_hist[] and decoder log frame energy */
+ memcpy(st->mem_isf, isf_init, M * sizeof(Word16));
+ memcpy(st->mem_isf_prev, isf_init, M * sizeof(Word16));
+
+ for (i = 0; i < D_DTX_HIST_SIZE; i++) {
+ memcpy(&st->mem_isf_buf[i * M], isf_init, M * sizeof(Word16));
+ st->mem_log_en_buf[i] = 3500;
+ }
+ st->mem_dtx_hangover_count = D_DTX_HANG_CONST;
+ st->mem_dec_ana_elapsed_count = 127;
+ st->mem_sid_frame = 0;
+ st->mem_valid_data = 0;
+ st->mem_dtx_hangover_added = 0;
+ st->mem_dtx_global_state = SPEECH;
+ st->mem_data_updated = 0;
+ st->mem_dither_seed = RANDOM_INITSEED;
+ st->mem_cn_dith = 0;
+
+ return(0);
+}
+
+
+/*
+ * D_DTX_init
+ *
+ * Parameters:
+ * st I/O: state struct
+ *
+ * Function:
+ * Allocates state memory and initializes state memory
+ *
+ * Returns:
+ * non-zero with error, zero for ok
+ */
+int D_DTX_init(D_DTX_State **st, const Word16 *isf_init)
+{
+ D_DTX_State *s;
+
+ if (st == (D_DTX_State**)NULL) {
+ return(-1);
+ }
+
+ *st = NULL;
+
+ /* allocate memory */
+ if ((s = (D_DTX_State*)malloc(sizeof(D_DTX_State))) == NULL) {
+ return(-1);
+ }
+
+ D_DTX_reset(s, isf_init);
+ *st = s;
+
+ return(0);
+}
+
+
+/*
+ * D_DTX_exit
+ *
+ * Parameters:
+ * state I/0: State struct
+ *
+ * Function:
+ * The memory used for state memory is freed
+ *
+ * Returns:
+ * void
+ */
+void D_DTX_exit(D_DTX_State **st)
+{
+ if (st == NULL || *st == NULL) {
+ return;
+ }
+
+ /* deallocate memory */
+ free(*st);
+ *st = NULL;
+
+ return;
+}
+
+
+/*
+ * D_DTX_rx_handler
+ *
+ * Parameters:
+ * st I/O: State struct
+ * frame_type I: Frame type
+ *
+ * Function:
+ * Analyze received frame
+ *
+ * Table of new SPD synthesis states
+ *
+ * | previous SPD_synthesis_state
+ * Incoming |
+ * frame_type | SPEECH | DTX | D_DTX_MUTE
+ * ---------------------------------------------------------------
+ * RX_SPEECH_GOOD , | | |
+ * RX_SPEECH_PR_DEGRADED | SPEECH | SPEECH | SPEECH
+ * ----------------------------------------------------------------
+ * RX_SPEECH_BAD, | SPEECH | DTX | D_DTX_MUTE
+ * ----------------------------------------------------------------
+ * RX_SID_FIRST, | DTX | DTX/(D_DTX_MUTE)| D_DTX_MUTE
+ * ----------------------------------------------------------------
+ * RX_SID_UPDATE, | DTX | DTX | DTX
+ * ----------------------------------------------------------------
+ * RX_SID_BAD, | DTX | DTX/(D_DTX_MUTE)| D_DTX_MUTE
+ * ----------------------------------------------------------------
+ * RX_NO_DATA, | SPEECH | DTX/(D_DTX_MUTE)| D_DTX_MUTE
+ * RX_SPARE |(class2 garb.)| |
+ * ----------------------------------------------------------------
+ *
+ * Returns:
+ * new state
+ */
+UWord8 D_DTX_rx_handler(D_DTX_State *st, UWord8 frame_type)
+{
+ UWord8 newState;
+ UWord8 encState;
+
+ /* DTX if SID frame or previously in DTX{_MUTE}
+ * and (NO_RX OR BAD_SPEECH)
+ */
+ if ((frame_type == RX_SID_FIRST) | (frame_type == RX_SID_UPDATE) |
+ (frame_type == RX_SID_BAD) | (((st->mem_dtx_global_state == DTX) |
+ (st->mem_dtx_global_state == D_DTX_MUTE)) & ((frame_type == RX_NO_DATA) |
+ (frame_type == RX_SPEECH_BAD) | (frame_type == RX_SPEECH_LOST)))) {
+ newState = DTX;
+
+ /* stay in mute for these input types */
+ if ((st->mem_dtx_global_state == D_DTX_MUTE) &
+ ((frame_type == RX_SID_BAD) | (frame_type == RX_SID_FIRST) |
+ (frame_type == RX_SPEECH_LOST) | (frame_type == RX_NO_DATA))) {
+ newState = D_DTX_MUTE;
+ }
+
+ /* evaluate if noise parameters are too old */
+ /* since_last_sid is reset when CN parameters have been updated */
+ st->mem_since_last_sid = D_UTIL_saturate(st->mem_since_last_sid + 1);
+
+ /* no update of sid parameters in DTX for a Word32 while */
+ if ((frame_type != RX_SID_UPDATE) &&
+ (st->mem_since_last_sid > D_DTX_MAX_EMPTY_THRESH)) {
+ newState = D_DTX_MUTE;
+ }
+ } else {
+ newState = SPEECH;
+ st->mem_since_last_sid = 0;
+ }
+
+ /*
+ * reset the decAnaElapsed Counter when receiving CNI data the first
+ * time, to robustify counter missmatch after handover
+ * this might delay the bwd CNI analysis in the new decoder slightly.
+ */
+ if ((st->mem_data_updated == 0) & (frame_type == RX_SID_UPDATE)) {
+ st->mem_dec_ana_elapsed_count = 0;
+ }
+
+ /*
+ * update the SPE-SPD DTX hangover synchronization
+ * to know when SPE has added dtx hangover
+ */
+ st->mem_dec_ana_elapsed_count++;
+
+ /* saturate */
+ if (st->mem_dec_ana_elapsed_count > 127) {
+ st->mem_dec_ana_elapsed_count = 127;
+ }
+
+ st->mem_dtx_hangover_added = 0;
+
+ if ((frame_type == RX_SID_FIRST) | (frame_type == RX_SID_UPDATE) |
+ (frame_type == RX_SID_BAD) | (frame_type == RX_NO_DATA)) {
+ encState = DTX;
+ } else {
+ encState = SPEECH;
+ }
+
+ if (encState == SPEECH) {
+ st->mem_dtx_hangover_count = D_DTX_HANG_CONST;
+ } else {
+ if (st->mem_dec_ana_elapsed_count > D_DTX_ELAPSED_FRAMES_THRESH) {
+ st->mem_dtx_hangover_added = 1;
+ st->mem_dec_ana_elapsed_count = 0;
+ st->mem_dtx_hangover_count = 0;
+ } else if (st->mem_dtx_hangover_count == 0) {
+ st->mem_dec_ana_elapsed_count = 0;
+ } else {
+ st->mem_dtx_hangover_count--;
+ }
+ }
+
+ if (newState != SPEECH) {
+ /*
+ * DTX or D_DTX_MUTE
+ * CN data is not in a first SID, first SIDs are marked as SID_BAD
+ * but will do backwards analysis if a hangover period has been added
+ * according to the state machine above
+ */
+ st->mem_sid_frame = 0;
+ st->mem_valid_data = 0;
+
+ if (frame_type == RX_SID_FIRST) {
+ st->mem_sid_frame = 1;
+ } else if (frame_type == RX_SID_UPDATE) {
+ st->mem_sid_frame = 1;
+ st->mem_valid_data = 1;
+ } else if (frame_type == RX_SID_BAD) {
+ st->mem_sid_frame = 1;
+ st->mem_dtx_hangover_added = 0; /* use old data */
+ }
+ }
+
+ return newState;
+
+ /* newState is used by both SPEECH AND DTX synthesis routines */
+}
+
+
+/*
+ * D_DTX_cn_dithering
+ *
+ * Parameters:
+ * isf I/O: CN ISF vector
+ * L_log_en_int I/O: energy parameter
+ * dither_seed I/O: random seed
+ *
+ * Function:
+ * Confort noise dithering
+ *
+ * Returns:
+ * void
+ */
+static void D_DTX_cn_dithering(Word16 isf[M], Word32 *L_log_en_int,
+ Word16 *dither_seed)
+{
+ Word32 temp, temp1, i, dither_fac, rand_dith, rand_dith2;
+
+ /* Insert comfort noise dithering for energy parameter */
+ rand_dith = D_UTIL_random(dither_seed) >> 1;
+ rand_dith2 = D_UTIL_random(dither_seed) >> 1;
+ rand_dith = rand_dith + rand_dith2;
+ *L_log_en_int = *L_log_en_int + ((rand_dith * GAIN_FACTOR) << 1);
+
+ if (*L_log_en_int < 0) {
+ *L_log_en_int = 0;
+ }
+
+ /* Insert comfort noise dithering for spectral parameters (ISF-vector) */
+ dither_fac = ISF_FACTOR_LOW;
+ rand_dith = D_UTIL_random(dither_seed) >> 1;
+ rand_dith2 = D_UTIL_random(dither_seed) >> 1;
+ rand_dith = rand_dith + rand_dith2;
+ temp = isf[0] + (((rand_dith * dither_fac) + 0x4000) >> 15);
+
+ /* Make sure that isf[0] will not get negative values */
+ if (temp < ISF_GAP) {
+ isf[0] = ISF_GAP;
+ } else {
+ isf[0] = (Word16)temp;
+ }
+
+ for (i = 1; i < M - 1; i++) {
+ dither_fac = dither_fac + ISF_FACTOR_STEP;
+ rand_dith = D_UTIL_random(dither_seed) >> 1;
+ rand_dith2 = D_UTIL_random(dither_seed) >> 1;
+ rand_dith = rand_dith + rand_dith2;
+ temp = isf[i] + (((rand_dith * dither_fac) + 0x4000) >> 15);
+ temp1 = temp - isf[i - 1];
+
+ /* Make sure that isf spacing remains at least ISF_DITH_GAP Hz */
+ if (temp1 < ISF_DITH_GAP) {
+ isf[i] = (Word16)(isf[i - 1] + ISF_DITH_GAP);
+ } else {
+ isf[i] = (Word16)temp;
+ }
+ }
+
+ /* Make sure that isf[M-2] will not get values above 16384 */
+ if (isf[M - 2] > 16384) {
+ isf[M - 2] = 16384;
+ }
+
+ return;
+}
+
+
+/*
+ * D_DTX_exe
+ *
+ * Parameters:
+ * st I/O: state struct
+ * exc2 O: CN excitation
+ * new_state I: New DTX state
+ * prms I: Vector of synthesis parameters
+ * isf O: CN ISF vector
+ *
+ * Function:
+ * Confort noise generation
+ *
+ * Returns:
+ * void
+ */
+void D_DTX_exe(D_DTX_State *st, Word16 *exc2, Word16 new_state, Word16 isf[],
+ Word16 **prms)
+{
+
+ Word32 i, j, L_tmp, ptr;
+ Word32 exp0, int_fac;
+ Word32 gain;
+ Word32 L_isf[M], L_log_en_int, level32, ener32;
+ Word16 log_en_index;
+ Word16 tmp_int_length;
+ Word16 exp, log_en_int_e, log_en_int_m, level;
+
+
+ /*
+ * This function is called if synthesis state is not SPEECH.
+ * The globally passed inputs to this function are
+ * st->sid_frame
+ * st->valid_data
+ * st->dtxHangoverAdded
+ * new_state (SPEECH, DTX, D_DTX_MUTE)
+ */
+ if ((st->mem_dtx_hangover_added != 0) & (st->mem_sid_frame != 0)) {
+ /* sid_first after dtx hangover period
+ * or sid_upd after dtxhangover
+ * consider twice the last frame
+ */
+ ptr = st->mem_hist_ptr + 1;
+
+ if (ptr == D_DTX_HIST_SIZE) {
+ ptr = 0;
+ }
+
+ memcpy(&st->mem_isf_buf[ptr * M], &st->mem_isf_buf[st->mem_hist_ptr * M],
+ M * sizeof(Word16));
+
+ st->mem_log_en_buf[ptr] = st->mem_log_en_buf[st->mem_hist_ptr];
+
+ /* compute mean log energy and isf from decoded signal (SID_FIRST) */
+ st->mem_log_en = 0;
+ memset(L_isf, 0, M * sizeof(Word32));
+
+ /* average energy and isf */
+ for (i = 0; i < D_DTX_HIST_SIZE; i++) {
+ /*
+ * Division by D_DTX_HIST_SIZE = 8 has been done in dtx_buffer log_en
+ * is in Q10
+ */
+ st->mem_log_en = (Word16)(st->mem_log_en + st->mem_log_en_buf[i]);
+
+ for (j = 0; j < M; j++) {
+ L_isf[j] = L_isf[j] + st->mem_isf_buf[i * M + j];
+ }
+ }
+
+ /* st->log_en in Q9 */
+ st->mem_log_en = (Word16)(st->mem_log_en >> 1);
+
+ /*
+ * Add 2 in Q9, in order to have only positive values for Pow2
+ * this value is subtracted back after Pow2 function
+ */
+ st->mem_log_en = (Word16)(st->mem_log_en + 1024);
+
+ if (st->mem_log_en < 0) {
+ st->mem_log_en = 0;
+ }
+
+ for (j = 0; j < M; j++) {
+ st->mem_isf[j] = (Word16)(L_isf[j] >> 3); /* divide by 8 */
+ }
+ }
+
+ if (st->mem_sid_frame != 0) {
+ /*
+ * Set old SID parameters, always shift
+ * even if there is no new valid_data
+ */
+ memcpy(st->mem_isf_prev, st->mem_isf, M * sizeof(Word16));
+ st->mem_log_en_prev = st->mem_log_en;
+
+ if (st->mem_valid_data != 0) { /* new data available (no CRC) */
+ /* st->true_sid_period_inv = 1.0f/st->since_last_sid; */
+
+ /*
+ * Compute interpolation factor, since the division only works
+ * for values of since_last_sid < 32 we have to limit
+ * the interpolation to 32 frames
+ */
+ tmp_int_length = st->mem_since_last_sid;
+
+ if (tmp_int_length > 32) {
+ tmp_int_length = 32;
+ }
+
+ if (tmp_int_length >= 2) {
+ st->mem_true_sid_period_inv =
+ (Word16)(0x2000000 / (tmp_int_length << 10));
+ } else {
+ st->mem_true_sid_period_inv = 1 << 14; /* 0.5 it Q15 */
+ }
+
+ D_LPC_isf_noise_d(*prms, st->mem_isf);
+ (*prms) += 5;
+ log_en_index = *(*prms)++;
+
+ /* read background noise stationarity information */
+ st->mem_cn_dith = *(*prms)++;
+
+ /*
+ * st->log_en = (Float32)log_en_index / 2.625 - 2.0;
+ * log2(E) in Q9 (log2(E) lies in between -2:22)
+ */
+ st->mem_log_en = (Word16)(log_en_index << (15 - 6));
+
+ /* Divide by 2.625 */
+ st->mem_log_en = (Word16)((st->mem_log_en * 12483) >> 15);
+
+ /*
+ * Subtract 2 in Q9 is done later, after Pow2 function
+ * no interpolation at startup after coder reset
+ * or when SID_UPD has been received right after SPEECH
+ */
+ if ((st->mem_data_updated == 0) ||
+ (st->mem_dtx_global_state == SPEECH)) {
+ memcpy(st->mem_isf_prev, st->mem_isf, M * sizeof(Word16));
+ st->mem_log_en_prev = st->mem_log_en;
+ }
+ } /* endif valid_data */
+ } /* endif sid_frame */
+
+ if ((st->mem_sid_frame != 0) && (st->mem_valid_data != 0)) {
+ st->mem_since_last_sid = 0;
+ }
+
+ /* Interpolate SID info */
+ if (st->mem_since_last_sid < 32) {
+ int_fac = st->mem_since_last_sid << 10; /* Q10 */
+ } else {
+ int_fac = 32767;
+ }
+ /* Q10 * Q15 -> Q10 */
+ int_fac = (int_fac * st->mem_true_sid_period_inv) >> 15;
+
+ /* Maximize to 1.0 in Q10 */
+ if (int_fac > 1024) {
+ int_fac = 1024;
+ }
+ int_fac = int_fac << 4; /* Q10 -> Q14 */
+ L_log_en_int = (int_fac * st->mem_log_en) << 1; /* Q14 * Q9 -> Q24 */
+
+ for (i = 0; i < M; i++) {
+ /* Q14 * Q15 -> Q14 */
+ isf[i] = (Word16)((int_fac * st->mem_isf[i]) >> 15);
+ }
+ int_fac = 16384 - int_fac; /* 1-k in Q14 */
+
+ /* ( Q14 * Q9 -> Q24 ) + Q24 -> Q24 */
+ L_log_en_int = L_log_en_int + ((int_fac * st->mem_log_en_prev) << 1);
+
+ for (i = 0; i < M; i++) {
+ /* Q14 + (Q14 * Q15 -> Q14) -> Q14 */
+ L_tmp = isf[i] + ((int_fac * st->mem_isf_prev[i]) >> 15);
+ isf[i] = (Word16)(L_tmp << 1); /* Q14 -> Q15 */
+ }
+
+ /* If background noise is non-stationary, insert comfort noise dithering */
+ if (st->mem_cn_dith != 0) {
+ D_DTX_cn_dithering(isf, &L_log_en_int, &st->mem_dither_seed);
+ }
+
+ /* L_log_en_int corresponds to log2(E)+2 in Q24, i.e log2(gain)+1 in Q25 */
+ L_log_en_int = (L_log_en_int >> 9); /* Q25 -> Q16 */
+
+ /* Find integer part */
+ log_en_int_e = (Word16)((L_log_en_int) >> 16);
+
+ /* Find fractional part */
+ log_en_int_m = (Word16)((L_log_en_int - (log_en_int_e << 16)) >> 1);
+
+ /*
+ * Subtract 2 from L_log_en_int in Q9,
+ * i.e divide the gain by 2 (energy by 4)
+ * Add 16 in order to have the result of pow2 in Q16
+ */
+ log_en_int_e = (Word16)(log_en_int_e + (16 - 1));
+
+ /* level = (Float32)( pow( 2.0f, log_en ) ); */
+ level32 = D_UTIL_pow2(log_en_int_e, log_en_int_m); /* Q16 */
+ exp0 = D_UTIL_norm_l(level32);
+ level32 = (level32 << exp0); /* level in Q31 */
+ exp0 = (15 - exp0);
+ level = (Word16)(level32 >> 16); /* level in Q15 */
+
+ /* generate white noise vector */
+ for (i = 0; i < L_FRAME; i++) {
+ exc2[i] = (Word16)((D_UTIL_random(&(st->mem_cng_seed)) >> 4));
+ }
+
+ /* gain = level / sqrt(ener) * sqrt(L_FRAME) */
+ /* energy of generated excitation */
+ ener32 = D_UTIL_dot_product12(exc2, exc2, L_FRAME, &exp);
+ D_UTIL_normalised_inverse_sqrt(&ener32, &exp);
+ gain = ener32 >> 16;
+ gain = (level * gain) >> 15; /* gain in Q15 */
+
+ /* Multiply by sqrt(L_FRAME)=16, i.e. shift left by 4 */
+ exp = (Word16)(exp0 + exp + 4);
+
+ if (exp >= 0) {
+ for (i = 0; i < L_FRAME; i++) {
+ L_tmp = (exc2[i] * gain) >> 15; /* Q0 * Q15 */
+ exc2[i] = (Word16)(L_tmp << exp);
+ }
+ } else {
+ exp = (Word16) - exp;
+
+ for (i = 0; i < L_FRAME; i++) {
+ L_tmp = (exc2[i] * gain) >> 15; /* Q0 * Q15 */
+ exc2[i] = (Word16)(L_tmp >> exp);
+ }
+ }
+
+ if (new_state == D_DTX_MUTE) {
+ /*
+ * mute comfort noise as it has been quite a long time since
+ * last SID update was performed
+ */
+ tmp_int_length = st->mem_since_last_sid;
+
+ if (tmp_int_length > 32) {
+ tmp_int_length = 32;
+ }
+
+ /* safety guard against division by zero */
+ if (tmp_int_length <= 0) {
+ tmp_int_length = 8;
+ }
+ st->mem_true_sid_period_inv = D_UTIL_saturate((0x02000000 / (tmp_int_length << 10)));
+ st->mem_since_last_sid = 0;
+ st->mem_log_en_prev = st->mem_log_en;
+
+ /* subtract 1/8 in Q9 (energy), i.e -3/8 dB */
+ st->mem_log_en = D_UTIL_saturate(st->mem_log_en - 64);
+ }
+
+ /* reset interpolation length timer if data has been updated. */
+ if ((st->mem_sid_frame != 0) && ((st->mem_valid_data != 0) ||
+ ((st->mem_valid_data == 0) && (st->mem_dtx_hangover_added) != 0))) {
+ st->mem_since_last_sid = 0;
+ st->mem_data_updated = 1;
+ }
+
+ return;
+}
+
+
+/*
+ * D_DTX_activity_update
+ *
+ * Parameters:
+ * st I/O: state struct
+ * isf O: ISF vector
+ * exc O: excitation
+ *
+ * Function:
+ * Confort noise generation
+ *
+ * Returns:
+ * void
+ */
+void D_DTX_activity_update(D_DTX_State *st, Word16 isf[], Word16 exc[])
+{
+
+ Word32 L_frame_en, log_en;
+ Word32 i;
+ Word16 log_en_e, log_en_m;
+
+ st->mem_hist_ptr = (Word16)(st->mem_hist_ptr + 1);
+
+ if (st->mem_hist_ptr == D_DTX_HIST_SIZE) {
+ st->mem_hist_ptr = 0;
+ }
+
+ memcpy(&st->mem_isf_buf[st->mem_hist_ptr * M], isf, M * sizeof(Word16));
+
+ /* compute log energy based on excitation frame energy in Q0 */
+ L_frame_en = 0;
+
+ for (i = 0; i < L_FRAME; i++) {
+ L_frame_en = L_frame_en + (exc[i] * exc[i]);
+ if (L_frame_en > MAX_31) {
+ L_frame_en = MAX_31;
+ break;
+ }
+ }
+
+ /*
+ * log_en =
+ * (Float32)log10(L_frame_en/(Float32)L_FRAME)/(Float32)log10(2.0f);
+ */
+ D_UTIL_log2(L_frame_en, &log_en_e, &log_en_m);
+
+ /*
+ * convert exponent and mantissa to Word16 Q7.
+ * Q7 is used to simplify averaging in dtx_enc
+ */
+ log_en = log_en_e << 7; /* Q7 */
+ log_en = log_en + (log_en_m >> (15 - 7));
+
+ /* Divide by L_FRAME = 256, i.e subtract 8 in Q7 = 1024 */
+ log_en = log_en - 1024;
+
+ /* insert into log energy buffer */
+ st->mem_log_en_buf[st->mem_hist_ptr] = (Word16)log_en;
+
+ return;
+}