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_util.c b/audio_codec/libamr/dec_util.c
new file mode 100644
index 0000000..9d0f6c5
--- a/dev/null
+++ b/audio_codec/libamr/dec_util.c
@@ -0,0 +1,1304 @@
+/*
+ *===================================================================
+ * 3GPP AMR Wideband Floating-point Speech Codec
+ *===================================================================
+ */
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <fcntl.h>
+#include <math.h>
+//#include <memory.h>
+#include "typedef.h"
+#include "dec_main.h"
+#include "dec_lpc.h"
+
+#define MAX_16 (Word16)0x7FFF
+#define MIN_16 (Word16)0x8000
+#define L_SUBFR 64 /* Subframe size */
+#define L_SUBFR16k 80 /* Subframe size at 16kHz */
+#define M16k 20 /* Order of LP filter */
+#define PREEMPH_FAC 22282 /* preemphasis factor (0.68 in Q15) */
+#define FAC4 4
+#define FAC5 5
+#define UP_FAC 20480 /* 5/4 in Q14 */
+#define INV_FAC5 6554 /* 1/5 in Q15 */
+#define NB_COEF_UP 12
+#define L_FIR 31
+#define MODE_7k 0
+#define MODE_24k 8
+
+
+extern const Word16 D_ROM_pow2[];
+extern const Word16 D_ROM_isqrt[];
+extern const Word16 D_ROM_log2[];
+extern const Word16 D_ROM_fir_up[];
+extern const Word16 D_ROM_fir_6k_7k[];
+extern const Word16 D_ROM_fir_7k[];
+extern const Word16 D_ROM_hp_gain[];
+
+#ifdef WIN32
+#pragma warning( disable : 4310)
+#endif
+/*
+ * D_UTIL_random
+ *
+ * Parameters:
+ * seed I/O: seed for random number
+ *
+ * Function:
+ * Signed 16 bits random generator.
+ *
+ * Returns:
+ * random number
+ */
+Word16 D_UTIL_random(Word16 *seed)
+{
+ /*static Word16 seed = 21845;*/
+ *seed = (Word16)(*seed * 31821L + 13849L);
+ return(*seed);
+}
+
+
+/*
+ * D_UTIL_pow2
+ *
+ * Parameters:
+ * exponant I: (Q0) Integer part. (range: 0 <= val <= 30)
+ * fraction I: (Q15) Fractionnal part. (range: 0.0 <= val < 1.0)
+ *
+ * Function:
+ * L_x = pow(2.0, exponant.fraction) (exponant = interger part)
+ * = pow(2.0, 0.fraction) << exponant
+ *
+ * Algorithm:
+ *
+ * The function Pow2(L_x) is approximated by a table and linear
+ * interpolation.
+ *
+ * 1 - i = bit10 - b15 of fraction, 0 <= i <= 31
+ * 2 - a = bit0 - b9 of fraction
+ * 3 - L_x = table[i] << 16 - (table[i] - table[i + 1]) * a * 2
+ * 4 - L_x = L_x >> (30-exponant) (with rounding)
+ *
+ * Returns:
+ * range 0 <= val <= 0x7fffffff
+ */
+Word32 D_UTIL_pow2(Word16 exponant, Word16 fraction)
+{
+ Word32 L_x, tmp, i, exp;
+ Word16 a;
+
+ L_x = fraction * 32; /* L_x = fraction<<6 */
+ i = L_x >> 15; /* Extract b10-b16 of fraction */
+ a = (Word16)(L_x); /* Extract b0-b9 of fraction */
+ a = (Word16)(a & (Word16)0x7fff);
+ L_x = D_ROM_pow2[i] << 16; /* table[i] << 16 */
+ tmp = D_ROM_pow2[i] - D_ROM_pow2[i + 1]; /* table[i] - table[i+1] */
+ tmp = L_x - ((tmp * a) << 1); /* L_x -= tmp*a*2 */
+ exp = 30 - exponant;
+ if (exp <= 31) {
+ L_x = tmp >> exp;
+
+ if ((1 << (exp - 1)) & tmp) {
+ L_x++;
+ }
+ } else {
+ L_x = 0;
+ }
+
+ return(L_x);
+}
+
+
+/*
+ * D_UTIL_norm_l
+ *
+ * Parameters:
+ * L_var1 I: 32 bit Word32 signed integer (Word32) whose value
+ * falls in the range 0x8000 0000 <= var1 <= 0x7fff ffff.
+ *
+ * Function:
+ * Produces the number of left shifts needed to normalize the 32 bit
+ * variable L_var1 for positive values on the interval with minimum of
+ * 1073741824 and maximum of 2147483647, and for negative values on
+ * the interval with minimum of -2147483648 and maximum of -1073741824;
+ * in order to normalize the result, the following operation must be done :
+ * norm_L_var1 = L_shl(L_var1,norm_l(L_var1)).
+ *
+ * Returns:
+ * 16 bit Word16 signed integer (Word16) whose value falls in the range
+ * 0x0000 0000 <= var_out <= 0x0000 001f.
+ */
+Word16 D_UTIL_norm_l(Word32 L_var1)
+{
+ Word16 var_out;
+
+ if (L_var1 == 0) {
+ var_out = 0;
+ } else {
+ if (L_var1 == (Word32)0xffffffffL) {
+ var_out = 31;
+ } else {
+ if (L_var1 < 0) {
+ L_var1 = ~L_var1;
+ }
+
+ for (var_out = 0; L_var1 < (Word32)0x40000000L; var_out++) {
+ L_var1 <<= 1;
+ }
+ }
+ }
+
+ return(var_out);
+}
+
+
+/*
+ * D_UTIL_norm_s
+ *
+ * Parameters:
+ * L_var1 I: 32 bit Word32 signed integer (Word32) whose value
+ * falls in the range 0xffff 8000 <= var1 <= 0x0000 7fff.
+ *
+ * Function:
+ * Produces the number of left shift needed to normalize the 16 bit
+ * variable var1 for positive values on the interval with minimum
+ * of 16384 and maximum of 32767, and for negative values on
+ * the interval with minimum of -32768 and maximum of -16384.
+ *
+ * Returns:
+ * 16 bit Word16 signed integer (Word16) whose value falls in the range
+ * 0x0000 0000 <= var_out <= 0x0000 000f.
+ */
+Word16 D_UTIL_norm_s(Word16 var1)
+{
+ Word16 var_out;
+
+ if (var1 == 0) {
+ var_out = 0;
+ } else {
+ if (var1 == -1) {
+ var_out = 15;
+ } else {
+ if (var1 < 0) {
+ var1 = (Word16)~var1;
+ }
+
+ for (var_out = 0; var1 < 0x4000; var_out++) {
+ var1 <<= 1;
+ }
+ }
+ }
+ return(var_out);
+}
+
+
+/*
+ * D_UTIL_dot_product12
+ *
+ * Parameters:
+ * x I: 12bit x vector
+ * y I: 12bit y vector
+ * lg I: vector length
+ * exp O: exponent of result (0..+30)
+ *
+ * Function:
+ * Compute scalar product of <x[],y[]> using accumulator.
+ * The result is normalized (in Q31) with exponent (0..30).
+ *
+ * Returns:
+ * Q31 normalised result (1 < val <= -1)
+ */
+Word32 D_UTIL_dot_product12(Word16 x[], Word16 y[], Word16 lg, Word16 *exp)
+{
+ Word32 sum, i, sft;
+
+ sum = 0L;
+
+ for (i = 0; i < lg; i++) {
+ sum += x[i] * y[i];
+ }
+ sum = (sum << 1) + 1;
+
+ /* Normalize acc in Q31 */
+ sft = D_UTIL_norm_l(sum);
+ sum = sum << sft;
+ *exp = (Word16)(30 - sft); /* exponent = 0..30 */
+
+ return(sum);
+}
+
+
+/*
+ * D_UTIL_normalised_inverse_sqrt
+ *
+ * Parameters:
+ * frac I/O: (Q31) normalized value (1.0 < frac <= 0.5)
+ * exp I/O: exponent (value = frac x 2^exponent)
+ *
+ * Function:
+ * Compute 1/sqrt(value).
+ * If value is negative or zero, result is 1 (frac=7fffffff, exp=0).
+ *
+ * The function 1/sqrt(value) is approximated by a table and linear
+ * interpolation.
+ * 1. If exponant is odd then shift fraction right once.
+ * 2. exponant = -((exponant - 1) >> 1)
+ * 3. i = bit25 - b30 of fraction, 16 <= i <= 63 ->because of normalization.
+ * 4. a = bit10 - b24
+ * 5. i -= 16
+ * 6. fraction = table[i]<<16 - (table[i] - table[i+1]) * a * 2
+ *
+ * Returns:
+ * void
+ */
+void D_UTIL_normalised_inverse_sqrt(Word32 *frac, Word16 *exp)
+{
+ Word32 i, tmp;
+ Word16 a;
+
+ if (*frac <= (Word32)0) {
+ *exp = 0;
+ *frac = 0x7fffffffL;
+ return;
+ }
+
+ if ((*exp & 0x1) == 1) { /* If exponant odd -> shift right */
+ *frac = *frac >> 1;
+ }
+ *exp = (Word16)(-((*exp - 1) >> 1));
+ *frac = *frac >> 9;
+ i = *frac >> 16; /* Extract b25-b31 */
+ *frac = *frac >> 1;
+ a = (Word16)(*frac); /* Extract b10-b24 */
+ a = (Word16)(a & (Word16)0x7fff);
+ i = i - 16;
+ *frac = D_ROM_isqrt[i] << 16; /* table[i] << 16 */
+ tmp = D_ROM_isqrt[i] - D_ROM_isqrt[i + 1]; /* table[i] - table[i+1]) */
+ *frac = *frac - ((tmp * a) << 1); /* frac -= tmp*a*2 */
+
+ return;
+}
+
+
+/*
+ * D_UTIL_inverse_sqrt
+ *
+ * Parameters:
+ * L_x I/O: (Q0) input value (range: 0<=val<=7fffffff)
+ *
+ * Function:
+ * Compute 1/sqrt(L_x).
+ * If value is negative or zero, result is 1 (7fffffff).
+ *
+ * The function 1/sqrt(value) is approximated by a table and linear
+ * interpolation.
+ * 1. Normalization of L_x
+ * 2. call Normalised_Inverse_sqrt(L_x, exponant)
+ * 3. L_y = L_x << exponant
+ *
+ * Returns:
+ * (Q31) output value (range: 0 <= val < 1)
+ */
+Word32 D_UTIL_inverse_sqrt(Word32 L_x)
+{
+ Word32 L_y;
+ Word16 exp;
+
+ exp = D_UTIL_norm_l(L_x);
+ L_x = (L_x << exp); /* L_x is normalized */
+ exp = (Word16)(31 - exp);
+ D_UTIL_normalised_inverse_sqrt(&L_x, &exp);
+
+ if (exp < 0) {
+ L_y = (L_x >> -exp); /* denormalization */
+ } else {
+ L_y = (L_x << exp); /* denormalization */
+ }
+
+ return(L_y);
+}
+
+
+/*
+ * D_UTIL_normalised_log2
+ *
+ * Parameters:
+ * L_x I: input value (normalized)
+ * exp I: norm_l (L_x)
+ * exponent O: Integer part of Log2. (range: 0<=val<=30)
+ * fraction O: Fractional part of Log2. (range: 0<=val<1)
+ *
+ * Function:
+ * Computes log2(L_x, exp), where L_x is positive and
+ * normalized, and exp is the normalisation exponent
+ * If L_x is negative or zero, the result is 0.
+ *
+ * The function Log2(L_x) is approximated by a table and linear
+ * interpolation. The following steps are used to compute Log2(L_x)
+ *
+ * 1. exponent = 30 - norm_exponent
+ * 2. i = bit25 - b31 of L_x; 32 <= i <= 63 (because of normalization).
+ * 3. a = bit10 - b24
+ * 4. i -= 32
+ * 5. fraction = table[i] << 16 - (table[i] - table[i + 1]) * a * 2
+ *
+ *
+ * Returns:
+ * void
+ */
+static void D_UTIL_normalised_log2(Word32 L_x, Word16 exp, Word16 *exponent,
+ Word16 *fraction)
+{
+ Word32 i, a, tmp;
+ Word32 L_y;
+
+ if (L_x <= 0) {
+ *exponent = 0;
+ *fraction = 0;
+ return;
+ }
+
+ *exponent = (Word16)(30 - exp);
+
+ L_x = L_x >> 10;
+ i = L_x >> 15; /* Extract b25-b31 */
+ a = L_x; /* Extract b10-b24 of fraction */
+ a = a & 0x00007fff;
+ i = i - 32;
+ L_y = D_ROM_log2[i] << 16; /* table[i] << 16 */
+ tmp = D_ROM_log2[i] - D_ROM_log2[i + 1]; /* table[i] - table[i+1] */
+ L_y = L_y - ((tmp * a) << 1); /* L_y -= tmp*a*2 */
+ *fraction = (Word16)(L_y >> 16);
+
+ return;
+}
+
+
+/*
+ * D_UTIL_log2
+ *
+ * Parameters:
+ * L_x I: input value
+ * exponent O: Integer part of Log2. (range: 0<=val<=30)
+ * fraction O: Fractional part of Log2. (range: 0<=val<1)
+ *
+ * Function:
+ * Computes log2(L_x), where L_x is positive.
+ * If L_x is negative or zero, the result is 0.
+ *
+ * Returns:
+ * void
+ */
+void D_UTIL_log2(Word32 L_x, Word16 *exponent, Word16 *fraction)
+{
+ Word16 exp;
+
+ exp = D_UTIL_norm_l(L_x);
+ D_UTIL_normalised_log2((L_x << exp), exp, exponent, fraction);
+}
+
+
+/*
+ * D_UTIL_l_extract
+ *
+ * Parameters:
+ * L_32 I: 32 bit integer.
+ * hi O: b16 to b31 of L_32
+ * lo O: (L_32 - hi<<16)>>1
+ *
+ * Function:
+ * Extract from a 32 bit integer two 16 bit DPF.
+ *
+ * Returns:
+ * void
+ */
+void D_UTIL_l_extract(Word32 L_32, Word16 *hi, Word16 *lo)
+{
+ *hi = (Word16)(L_32 >> 16);
+ *lo = (Word16)((L_32 >> 1) - (*hi * 32768));
+
+ return;
+}
+
+
+/*
+ * D_UTIL_mpy_32_16
+ *
+ * Parameters:
+ * hi I: hi part of 32 bit number
+ * lo I: lo part of 32 bit number
+ * n I: 16 bit number
+ *
+ * Function:
+ * Multiply a 16 bit integer by a 32 bit (DPF). The result is divided
+ * by 2^15.
+ *
+ * L_32 = (hi1*lo2)<<1 + ((lo1*lo2)>>15)<<1
+ *
+ * Returns:
+ * 32 bit result
+ */
+Word32 D_UTIL_mpy_32_16(Word16 hi, Word16 lo, Word16 n)
+{
+ Word32 L_32;
+
+ L_32 = hi * n;
+ L_32 += (lo * n) >> 15;
+
+ return(L_32 << 1);
+}
+
+
+/*
+ * D_UTIL_mpy_32
+ *
+ * Parameters:
+ * hi1 I: hi part of first number
+ * lo1 I: lo part of first number
+ * hi2 I: hi part of second number
+ * lo2 I: lo part of second number
+ *
+ * Function:
+ * Multiply two 32 bit integers (DPF). The result is divided by 2^31
+ *
+ * L_32 = (hi1*lo2)<<1 + ((lo1*lo2)>>15)<<1
+ *
+ * Returns:
+ * 32 bit result
+ */
+Word32 D_UTIL_mpy_32(Word16 hi1, Word16 lo1, Word16 hi2, Word16 lo2)
+{
+ Word32 L_32;
+
+ L_32 = hi1 * hi2;
+ L_32 += (hi1 * lo2) >> 15;
+ L_32 += (lo1 * hi2) >> 15;
+
+ return(L_32 << 1);
+}
+
+/*
+ * D_UTIL_saturate
+ *
+ * Parameters:
+ * inp I: 32-bit number
+ *
+ * Function:
+ * Saturation to 16-bit number
+ *
+ * Returns:
+ * 16-bit number
+ */
+Word16 D_UTIL_saturate(Word32 inp)
+{
+ Word16 out;
+ if ((inp < MAX_16) & (inp > MIN_16)) {
+ out = (Word16)inp;
+ } else {
+ if (inp > 0) {
+ out = MAX_16;
+ } else {
+ out = MIN_16;
+ }
+ }
+
+ return(out);
+}
+
+/*
+ * D_UTIL_signal_up_scale
+ *
+ * Parameters:
+ * x I/O: signal to scale
+ * lg I: size of x[]
+ * exp I: exponent: x = round(x << exp)
+ *
+ * Function:
+ * Scale signal up to get maximum of dynamic.
+ *
+ * Returns:
+ * 32 bit result
+ */
+void D_UTIL_signal_up_scale(Word16 x[], Word16 lg, Word16 exp)
+{
+ Word32 i, tmp;
+
+ for (i = 0; i < lg; i++) {
+ tmp = x[i] << exp;
+ x[i] = D_UTIL_saturate(tmp);
+ }
+
+ return;
+}
+
+
+/*
+ * D_UTIL_signal_down_scale
+ *
+ * Parameters:
+ * x I/O: signal to scale
+ * lg I: size of x[]
+ * exp I: exponent: x = round(x << exp)
+ *
+ * Function:
+ * Scale signal up to get maximum of dynamic.
+ *
+ * Returns:
+ * 32 bit result
+ */
+void D_UTIL_signal_down_scale(Word16 x[], Word16 lg, Word16 exp)
+{
+ Word32 i, tmp;
+
+ for (i = 0; i < lg; i++) {
+ tmp = x[i] << 16;
+ tmp = tmp >> exp;
+ x[i] = (Word16)((tmp + 0x8000) >> 16);
+ }
+
+ return;
+}
+
+
+/*
+ * D_UTIL_deemph_32
+ *
+ * Parameters:
+ * x_hi I: input signal (bit31..16)
+ * x_lo I: input signal (bit15..4)
+ * y O: output signal (x16)
+ * mu I: (Q15) deemphasis factor
+ * L I: vector size
+ * mem I/O: memory (y[-1])
+ *
+ * Function:
+ * Filtering through 1/(1-mu z^-1)
+ *
+ * Returns:
+ * void
+ */
+static void D_UTIL_deemph_32(Word16 x_hi[], Word16 x_lo[], Word16 y[],
+ Word16 mu, Word16 L, Word16 *mem)
+{
+ Word32 i, fac;
+ Word32 tmp;
+
+ fac = mu >> 1; /* Q15 --> Q14 */
+
+ /* L_tmp = hi<<16 + lo<<4 */
+ tmp = (x_hi[0] << 12) + x_lo[0];
+ tmp = (tmp << 6) + (*mem * fac);
+ tmp = (tmp + 0x2000) >> 14;
+ y[0] = D_UTIL_saturate(tmp);
+
+ for (i = 1; i < L; i++) {
+ tmp = (x_hi[i] << 12) + x_lo[i];
+ tmp = (tmp << 6) + (y[i - 1] * fac);
+ tmp = (tmp + 0x2000) >> 14;
+ y[i] = D_UTIL_saturate(tmp);
+ }
+
+ *mem = y[L - 1];
+
+ return;
+}
+
+
+/*
+ * D_UTIL_synthesis_32
+ *
+ * Parameters:
+ * a I: LP filter coefficients
+ * m I: order of LP filter
+ * exc I: excitation
+ * Qnew I: exc scaling = 0(min) to 8(max)
+ * sig_hi O: synthesis high
+ * sig_lo O: synthesis low
+ * lg I: size of filtering
+ *
+ * Function:
+ * Perform the synthesis filtering 1/A(z).
+ *
+ * Returns:
+ * void
+ */
+static void D_UTIL_synthesis_32(Word16 a[], Word16 m, Word16 exc[],
+ Word16 Qnew, Word16 sig_hi[], Word16 sig_lo[],
+ Word16 lg)
+{
+ Word32 i, j, a0, s;
+ Word32 tmp, tmp2;
+
+ /* See if a[0] is scaled */
+ s = D_UTIL_norm_s((Word16)a[0]) - 2;
+
+ a0 = a[0] >> (4 + Qnew); /* input / 16 and >>Qnew */
+
+ /* Do the filtering. */
+ for (i = 0; i < lg; i++) {
+ tmp = 0;
+
+ for (j = 1; j <= m; j++) {
+ tmp -= sig_lo[i - j] * a[j];
+ }
+
+ tmp = tmp >> (15 - 4); /* -4 : sig_lo[i] << 4 */
+
+ tmp2 = exc[i] * a0;
+
+ for (j = 1; j <= m; j++) {
+ tmp2 -= sig_hi[i - j] * a[j];
+ }
+
+ tmp += tmp2 << 1;
+ tmp <<= s;
+
+ /* sig_hi = bit16 to bit31 of synthesis */
+ sig_hi[i] = (Word16)(tmp >> 13);
+
+ /* sig_lo = bit4 to bit15 of synthesis */
+ sig_lo[i] = (Word16)((tmp >> 1) - (sig_hi[i] * 4096));
+ }
+
+ return;
+}
+
+
+/*
+ * D_UTIL_hp50_12k8
+ *
+ * Parameters:
+ * signal I/O: signal
+ * lg I: lenght of signal
+ * mem I/O: filter memory [6]
+ *
+ * Function:
+ * 2nd order high pass filter with cut off frequency at 50 Hz.
+ *
+ * Algorithm:
+ *
+ * y[i] = b[0]*x[i] + b[1]*x[i-1] + b[2]*x[i-2]
+ * + a[1]*y[i-1] + a[2]*y[i-2];
+ *
+ * b[3] = {0.989501953f, -1.979003906f, 0.989501953f};
+ * a[3] = {1.000000000F, 1.978881836f,-0.966308594f};
+ *
+ *
+ * Returns:
+ * void
+ */
+static void D_UTIL_hp50_12k8(Word16 signal[], Word16 lg, Word16 mem[])
+{
+ Word32 i, L_tmp;
+ Word16 y2_hi, y2_lo, y1_hi, y1_lo, x0, x1, x2;
+
+ y2_hi = mem[0];
+ y2_lo = mem[1];
+ y1_hi = mem[2];
+ y1_lo = mem[3];
+ x0 = mem[4];
+ x1 = mem[5];
+
+ for (i = 0; i < lg; i++) {
+ x2 = x1;
+ x1 = x0;
+ x0 = signal[i];
+
+ /* y[i] = b[0]*x[i] + b[1]*x[i-1] + b140[2]*x[i-2] */
+ /* + a[1]*y[i-1] + a[2] * y[i-2]; */
+ L_tmp = 8192L; /* rounding to maximise precision */
+ L_tmp = L_tmp + (y1_lo * 16211);
+ L_tmp = L_tmp + (y2_lo * (-8021));
+ L_tmp = L_tmp >> 14;
+ L_tmp = L_tmp + (y1_hi * 32422);
+ L_tmp = L_tmp + (y2_hi * (-16042));
+ L_tmp = L_tmp + (x0 * 8106);
+ L_tmp = L_tmp + (x1 * (-16212));
+ L_tmp = L_tmp + (x2 * 8106);
+ L_tmp = L_tmp << 2; /* coeff Q11 --> Q14 */
+ y2_hi = y1_hi;
+ y2_lo = y1_lo;
+ D_UTIL_l_extract(L_tmp, &y1_hi, &y1_lo);
+ L_tmp = (L_tmp + 0x4000) >> 15; /* coeff Q14 --> Q15 with saturation */
+ signal[i] = D_UTIL_saturate(L_tmp);
+
+ }
+ mem[0] = y2_hi;
+ mem[1] = y2_lo;
+ mem[2] = y1_hi;
+ mem[3] = y1_lo;
+ mem[4] = x0;
+ mem[5] = x1;
+
+ return;
+}
+
+
+/*
+ * D_UTIL_interpol
+ *
+ * Parameters:
+ * x I: input vector
+ * fir I: filter coefficient
+ * frac I: fraction (0..resol)
+ * up_samp I: resolution
+ * nb_coef I: number of coefficients
+ *
+ * Function:
+ * Fractional interpolation of signal at position (frac/up_samp)
+ *
+ * Returns:
+ * result of interpolation
+ */
+Word16 D_UTIL_interpol(Word16 *x, Word16 const *fir, Word16 frac,
+ Word16 resol, Word16 nb_coef)
+{
+ Word32 i, k;
+ Word32 sum;
+
+ x = x - nb_coef + 1;
+ sum = 0L;
+
+ for (i = 0, k = ((resol - 1) - frac); i < 2 * nb_coef; i++,
+ k = (Word16)(k + resol)) {
+ sum = sum + (x[i] * fir[k]);
+ }
+
+ if ((sum < 536846336) & (sum > -536879104)) {
+ sum = (sum + 0x2000) >> 14;
+ } else if (sum > 536846336) {
+ sum = 32767;
+ } else {
+ sum = -32768;
+ }
+
+ return((Word16)sum); /* saturation can occur here */
+}
+
+
+/*
+ * D_UTIL_up_samp
+ *
+ * Parameters:
+ * res_d I: signal to upsampling
+ * res_u O: upsampled output
+ * L_frame I: length of output
+ *
+ * Function:
+ * Upsampling
+ *
+ * Returns:
+ * void
+ */
+static void D_UTIL_up_samp(Word16 *sig_d, Word16 *sig_u, Word16 L_frame)
+{
+ Word32 pos, i, j;
+ Word16 frac;
+
+ pos = 0; /* position with 1/5 resolution */
+
+ for (j = 0; j < L_frame; j++) {
+ i = (pos * INV_FAC5) >> 15; /* integer part = pos * 1/5 */
+ frac = (Word16)(pos - ((i << 2) + i)); /* frac = pos - (pos/5)*5 */
+ sig_u[j] = D_UTIL_interpol(&sig_d[i], D_ROM_fir_up, frac, FAC5, NB_COEF_UP);
+ pos = pos + FAC4; /* position + 4/5 */
+ }
+
+ return;
+}
+
+
+/*
+ * D_UTIL_oversamp_16k
+ *
+ * Parameters:
+ * sig12k8 I: signal to oversampling
+ * lg I: length of input
+ * sig16k O: oversampled signal
+ * mem I/O: memory (2*12)
+ *
+ * Function:
+ * Oversampling from 12.8kHz to 16kHz
+ *
+ * Returns:
+ * void
+ */
+static void D_UTIL_oversamp_16k(Word16 sig12k8[], Word16 lg, Word16 sig16k[],
+ Word16 mem[])
+{
+ Word16 lg_up;
+ Word16 signal[L_SUBFR + (2 * NB_COEF_UP)];
+
+ memcpy(signal, mem, (2 * NB_COEF_UP) * sizeof(Word16));
+ memcpy(signal + (2 * NB_COEF_UP), sig12k8, lg * sizeof(Word16));
+ lg_up = (Word16)(((lg * UP_FAC) >> 15) << 1);
+ D_UTIL_up_samp(signal + NB_COEF_UP, sig16k, lg_up);
+ memcpy(mem, signal + lg, (2 * NB_COEF_UP) * sizeof(Word16));
+
+ return;
+}
+
+
+/*
+ * D_UTIL_hp400_12k8
+ *
+ * Parameters:
+ * signal I/O: signal
+ * lg I: lenght of signal
+ * mem I/O: filter memory [6]
+ *
+ * Function:
+ * 2nd order high pass filter with cut off frequency at 400 Hz.
+ *
+ * Algorithm:
+ *
+ * y[i] = b[0]*x[i] + b[1]*x[i-1] + b[2]*x[i-2]
+ * + a[1]*y[i-1] + a[2]*y[i-2];
+ *
+ * b[3] = {0.893554687, -1.787109375, 0.893554687};
+ * a[3] = {1.000000000, 1.787109375, -0.864257812};
+ *
+ *
+ * Returns:
+ * void
+ */
+void D_UTIL_hp400_12k8(Word16 signal[], Word16 lg, Word16 mem[])
+{
+
+ Word32 i, L_tmp;
+ Word16 y2_hi, y2_lo, y1_hi, y1_lo, x0, x1, x2;
+
+ y2_hi = mem[0];
+ y2_lo = mem[1];
+ y1_hi = mem[2];
+ y1_lo = mem[3];
+ x0 = mem[4];
+ x1 = mem[5];
+
+ for (i = 0; i < lg; i++) {
+ x2 = x1;
+ x1 = x0;
+ x0 = signal[i];
+
+ /* y[i] = b[0]*x[i] + b[1]*x[i-1] + b140[2]*x[i-2] */
+ /* + a[1]*y[i-1] + a[2] * y[i-2]; */
+ L_tmp = 8192L + (y1_lo * 29280);
+ L_tmp = L_tmp + (y2_lo * (-14160));
+ L_tmp = (L_tmp >> 14);
+ L_tmp = L_tmp + (y1_hi * 58560);
+ L_tmp = L_tmp + (y2_hi * (-28320));
+ L_tmp = L_tmp + (x0 * 1830);
+ L_tmp = L_tmp + (x1 * (-3660));
+ L_tmp = L_tmp + (x2 * 1830);
+ L_tmp = (L_tmp << 1); /* coeff Q12 --> Q13 */
+ y2_hi = y1_hi;
+ y2_lo = y1_lo;
+ D_UTIL_l_extract(L_tmp, &y1_hi, &y1_lo);
+
+ /* signal is divided by 16 to avoid overflow in energy computation */
+ signal[i] = (Word16)((L_tmp + 0x8000) >> 16);
+ }
+ mem[0] = y2_hi;
+ mem[1] = y2_lo;
+ mem[2] = y1_hi;
+ mem[3] = y1_lo;
+ mem[4] = x0;
+ mem[5] = x1;
+
+ return;
+}
+
+
+/*
+ * D_UTIL_synthesis
+ *
+ * Parameters:
+ * a I: LP filter coefficients
+ * m I: order of LP filter
+ * x I: input signal
+ * y O: output signal
+ * lg I: size of filtering
+ * mem I/O: initial filter states
+ * update_m I: update memory flag
+ *
+ * Function:
+ * Perform the synthesis filtering 1/A(z).
+ *
+ * Returns:
+ * void
+ */
+static void D_UTIL_synthesis(Word16 a[], Word16 m, Word16 x[], Word16 y[],
+ Word16 lg, Word16 mem[], Word16 update)
+{
+ Word32 i, j, tmp, s;
+ Word16 y_buf[L_SUBFR16k + M16k], a0;
+ Word16 *yy;
+
+ yy = &y_buf[m];
+
+ /* See if a[0] is scaled */
+ s = D_UTIL_norm_s(a[0]) - 2;
+ /* copy initial filter states into synthesis buffer */
+ memcpy(y_buf, mem, m * sizeof(Word16));
+
+ a0 = (Word16)(a[0] >> 1); /* input / 2 */
+
+ /* Do the filtering. */
+ for (i = 0; i < lg; i++) {
+ tmp = x[i] * a0;
+
+ for (j = 1; j <= m; j++) {
+ tmp -= a[j] * yy[i - j];
+ }
+ tmp <<= s;
+
+ y[i] = yy[i] = (Word16)((tmp + 0x800) >> 12);
+ }
+
+ /* Update memory if required */
+ if (update) {
+ memcpy(mem, &yy[lg - m], m * sizeof(Word16));
+ }
+
+ return;
+}
+
+
+/*
+ * D_UTIL_bp_6k_7k
+ *
+ * Parameters:
+ * signal I/O: signal
+ * lg I: lenght of signal
+ * mem I/O: filter memory [4]
+ *
+ * Function:
+ * 15th order band pass 6kHz to 7kHz FIR filter.
+ *
+ * Returns:
+ * void
+ */
+void D_UTIL_bp_6k_7k(Word16 signal[], Word16 lg, Word16 mem[])
+{
+ Word32 x[L_SUBFR16k + (L_FIR - 1)];
+ Word32 i, j, tmp;
+
+ for (i = 0; i < (L_FIR - 1); i++) {
+ x[i] = (Word16)mem[i]; /* gain of filter = 4 */
+ }
+
+ for (i = 0; i < lg; i++) {
+ x[i + L_FIR - 1] = signal[i] >> 2; /* gain of filter = 4 */
+ }
+
+ for (i = 0; i < lg; i++) {
+ tmp = 0;
+
+ for (j = 0; j < L_FIR; j++) {
+ tmp += x[i + j] * D_ROM_fir_6k_7k[j];
+ }
+
+ signal[i] = (Word16)((tmp + 0x4000) >> 15);
+ }
+
+ for (i = 0; i < (L_FIR - 1); i++) {
+ mem[i] = (Word16)x[lg + i]; /* gain of filter = 4 */
+ }
+
+ return;
+}
+
+
+/*
+ * D_UTIL_hp_7k
+ *
+ * Parameters:
+ * signal I/O: ISF vector
+ * lg I: length of signal
+ * mem I/O: memory (30)
+ *
+ * Function:
+ * 15th order high pass 7kHz FIR filter
+ *
+ * Returns:
+ * void
+ */
+static void D_UTIL_hp_7k(Word16 signal[], Word16 lg, Word16 mem[])
+{
+
+ Word32 i, j, tmp;
+ Word16 x[L_SUBFR16k + (L_FIR - 1)];
+
+ memcpy(x, mem, (L_FIR - 1) * sizeof(Word16));
+ memcpy(&x[L_FIR - 1], signal, lg * sizeof(Word16));
+
+ for (i = 0; i < lg; i++) {
+ tmp = 0;
+
+ for (j = 0; j < L_FIR; j++) {
+ tmp += x[i + j] * D_ROM_fir_7k[j];
+ }
+
+ signal[i] = (Word16)((tmp + 0x4000) >> 15);
+ }
+
+ memcpy(mem, x + lg, (L_FIR - 1) * sizeof(Word16));
+
+ return;
+}
+
+
+/*
+ * D_UTIL_Dec_synthesis
+ *
+ * Parameters:
+ * Aq I: quantized Az
+ * exc I: excitation at 12kHz
+ * Q_new I: scaling performed on exc
+ * synth16k O: 16kHz synthesis signal
+ * prms I: parameters
+ * HfIsf I/O: High frequency ISF:s
+ * mode I: codec mode
+ * newDTXState I: dtx state
+ * bfi I: bad frame indicator
+ * st I/O: State structure
+ *
+ * Function:
+ * Synthesis of signal at 16kHz with HF extension.
+ *
+ * Returns:
+ * void
+ */
+void D_UTIL_dec_synthesis(Word16 Aq[], Word16 exc[], Word16 Q_new,
+ Word16 synth16k[], Word16 prms, Word16 HfIsf[],
+ Word16 mode, Word16 newDTXState, Word16 bfi,
+ Decoder_State *st)
+{
+ Word32 tmp, i;
+ Word16 exp;
+ Word16 ener, exp_ener;
+ Word32 fac;
+ Word16 synth_hi[M + L_SUBFR], synth_lo[M + L_SUBFR];
+ Word16 synth[L_SUBFR];
+ Word16 HF[L_SUBFR16k]; /* High Frequency vector */
+ Word16 Ap[M16k + 1];
+ Word16 HfA[M16k + 1];
+ Word16 HF_corr_gain;
+ Word16 HF_gain_ind;
+ Word32 gain1, gain2;
+ Word16 weight1, weight2;
+
+ /*
+ * Speech synthesis
+ *
+ * - Find synthesis speech corresponding to exc2[].
+ * - Perform fixed deemphasis and hp 50hz filtering.
+ * - Oversampling from 12.8kHz to 16kHz.
+ */
+ memcpy(synth_hi, st->mem_syn_hi, M * sizeof(Word16));
+ memcpy(synth_lo, st->mem_syn_lo, M * sizeof(Word16));
+ D_UTIL_synthesis_32(Aq, M, exc, Q_new, synth_hi + M, synth_lo + M, L_SUBFR);
+ memcpy(st->mem_syn_hi, synth_hi + L_SUBFR, M * sizeof(Word16));
+ memcpy(st->mem_syn_lo, synth_lo + L_SUBFR, M * sizeof(Word16));
+ D_UTIL_deemph_32(synth_hi + M, synth_lo + M, synth, PREEMPH_FAC, L_SUBFR,
+ &(st->mem_deemph));
+ D_UTIL_hp50_12k8(synth, L_SUBFR, st->mem_sig_out);
+ D_UTIL_oversamp_16k(synth, L_SUBFR, synth16k, st->mem_oversamp);
+
+ /*
+ * HF noise synthesis
+ *
+ * - Generate HF noise between 5.5 and 7.5 kHz.
+ * - Set energy of noise according to synthesis tilt.
+ * tilt > 0.8 ==> - 14 dB (voiced)
+ * tilt 0.5 ==> - 6 dB (voiced or noise)
+ * tilt < 0.0 ==> 0 dB (noise)
+ */
+
+ /* generate white noise vector */
+ for (i = 0; i < L_SUBFR16k; i++) {
+ HF[i] = (Word16)(D_UTIL_random(&(st->mem_seed2)) >> 3);
+ }
+
+ /* energy of excitation */
+ D_UTIL_signal_down_scale(exc, L_SUBFR, 3);
+ Q_new = (Word16)(Q_new - 3);
+ ener = (Word16)(D_UTIL_dot_product12(exc, exc, L_SUBFR, &exp_ener) >> 16);
+ exp_ener = (Word16)(exp_ener - (Q_new << 1));
+
+ /* set energy of white noise to energy of excitation */
+ tmp = (Word16)(D_UTIL_dot_product12(HF, HF, L_SUBFR16k, &exp) >> 16);
+
+ if (tmp > ener) {
+ tmp = tmp >> 1; /* Be sure tmp < ener */
+ exp = (Word16)(exp + 1);
+ }
+
+ tmp = (tmp << 15) / ener;
+
+ if (tmp > 32767) {
+ tmp = 32767;
+ }
+
+ tmp = tmp << 16; /* result is normalized */
+ exp = (Word16)(exp - exp_ener);
+ D_UTIL_normalised_inverse_sqrt(&tmp, &exp);
+
+ /* L_tmp x 2, L_tmp in Q31 */
+ /* tmp = 2 x sqrt(ener_exc/ener_hf) */
+ if (exp >= 0) {
+ tmp = tmp >> (15 - exp);
+ } else {
+ tmp = tmp >> (-exp);
+ tmp = tmp >> 15;
+ }
+
+ /* saturation */
+ if (tmp > 0x7FFF) {
+ tmp = 0x7FFF;
+ }
+
+ for (i = 0; i < L_SUBFR16k; i++) {
+ HF[i] = (Word16)((HF[i] * tmp) >> 15);
+ }
+
+ /* find tilt of synthesis speech (tilt: 1=voiced, -1=unvoiced) */
+ D_UTIL_hp400_12k8(synth, L_SUBFR, st->mem_hp400);
+ tmp = 0L;
+
+ for (i = 0; i < L_SUBFR; i++) {
+ tmp = tmp + (synth[i] * synth[i]);
+ }
+
+ tmp = (tmp << 1) + 1;
+ exp = D_UTIL_norm_l(tmp);
+ ener = (Word16)((tmp << exp) >> 16); /* ener = r[0] */
+ tmp = 0L;
+
+ for (i = 1; i < L_SUBFR; i++) {
+ tmp = tmp + (synth[i] * synth[i - 1]);
+ }
+
+ tmp = (tmp << 1) + 1;
+ tmp = (tmp << exp) >> 16; /* tmp = r[1] */
+
+ if (tmp > 0) {
+ fac = ((tmp << 15) / ener);
+
+ if (fac > 32767) {
+ fac = 32767;
+ }
+ } else {
+ fac = 0;
+ }
+
+ /* modify energy of white noise according to synthesis tilt */
+ gain1 = (32767 - fac);
+ gain2 = ((32767 - fac) * 20480) >> 15;
+ gain2 = (gain2 << 1);
+
+ if (gain2 > 32767) {
+ gain2 = 32767;
+ }
+
+ if (st->mem_vad_hist > 0) {
+ weight1 = 0;
+ weight2 = 32767;
+ } else {
+ weight1 = 32767;
+ weight2 = 0;
+ }
+
+ tmp = (weight1 * gain1) >> 15;
+ tmp = tmp + ((weight2 * gain2) >> 15);
+
+ if (tmp != 0) {
+ tmp = tmp + 1;
+ }
+
+ if (tmp < 3277) {
+ tmp = 3277; /* 0.1 in Q15 */
+ }
+
+ if ((mode == MODE_24k) & (bfi == 0)) {
+ /* HF correction gain */
+ HF_gain_ind = prms;
+ HF_corr_gain = D_ROM_hp_gain[HF_gain_ind];
+
+ /* HF gain */
+ for (i = 0; i < L_SUBFR16k; i++) {
+ HF[i] = (Word16)(((HF[i] * HF_corr_gain) >> 15) << 1);
+ }
+ } else {
+ for (i = 0; i < L_SUBFR16k; i++) {
+ HF[i] = (Word16)((HF[i] * tmp) >> 15);
+ }
+ }
+
+ if ((mode <= MODE_7k) & (newDTXState == SPEECH)) {
+ D_LPC_isf_extrapolation(HfIsf);
+ D_LPC_isp_a_conversion(HfIsf, HfA, 0, M16k);
+ D_LPC_a_weight(HfA, Ap, 29491, M16k); /* fac=0.9 */
+ D_UTIL_synthesis(Ap, M16k, HF, HF, L_SUBFR16k, st->mem_syn_hf, 1);
+ } else {
+ /* synthesis of noise: 4.8kHz..5.6kHz --> 6kHz..7kHz */
+ D_LPC_a_weight(Aq, Ap, 19661, M); /* fac=0.6 */
+ D_UTIL_synthesis(Ap, M, HF, HF, L_SUBFR16k, st->mem_syn_hf + (M16k - M), 1);
+ }
+
+ /* noise High Pass filtering (1ms of delay) */
+ D_UTIL_bp_6k_7k(HF, L_SUBFR16k, st->mem_hf);
+
+ if (mode == MODE_24k) {
+ /* Low Pass filtering (7 kHz) */
+ D_UTIL_hp_7k(HF, L_SUBFR16k, st->mem_hf3);
+ }
+
+ /* add filtered HF noise to speech synthesis */
+ for (i = 0; i < L_SUBFR16k; i++) {
+ tmp = (synth16k[i] + HF[i]);
+ synth16k[i] = D_UTIL_saturate(tmp);
+ }
+
+ return;
+}
+
+
+/*
+ * D_UTIL_preemph
+ *
+ * Parameters:
+ * x I/O: signal
+ * mu I: preemphasis factor
+ * lg I: vector size
+ * mem I/O: memory (x[-1])
+ *
+ * Function:
+ * Filtering through 1 - mu z^-1
+ *
+ *
+ * Returns:
+ * void
+ */
+void D_UTIL_preemph(Word16 x[], Word16 mu, Word16 lg, Word16 *mem)
+{
+ Word32 i, L_tmp;
+ Word16 temp;
+
+ temp = x[lg - 1];
+
+ for (i = lg - 1; i > 0; i--) {
+ L_tmp = x[i] << 15;
+ L_tmp = L_tmp - (x[i - 1] * mu);
+ x[i] = (Word16)((L_tmp + 0x4000) >> 15);
+ }
+
+ L_tmp = x[0] << 15;
+ L_tmp = L_tmp - (*mem * mu);
+ x[0] = (Word16)((L_tmp + 0x4000) >> 15);
+ *mem = temp;
+
+ return;
+}