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/wfd_aac_decoder/sbrhfgen.c b/audio_codec/wfd_aac_decoder/sbrhfgen.c
new file mode 100644
index 0000000..0ab7dad
--- a/dev/null
+++ b/audio_codec/wfd_aac_decoder/sbrhfgen.c
@@ -0,0 +1,655 @@
+/* ***** BEGIN LICENSE BLOCK *****
+ * Source last modified: $Id: sbrhfgen.c,v 1.1.2.2 2005/05/19 21:00:01 jrecker Exp $
+ *
+ * Portions Copyright (c) 1995-2005 RealNetworks, Inc. All Rights Reserved.
+ *
+ * The contents of this file, and the files included with this file,
+ * are subject to the current version of the RealNetworks Public
+ * Source License (the "RPSL") available at
+ * http://www.helixcommunity.org/content/rpsl unless you have licensed
+ * the file under the current version of the RealNetworks Community
+ * Source License (the "RCSL") available at
+ * http://www.helixcommunity.org/content/rcsl, in which case the RCSL
+ * will apply. You may also obtain the license terms directly from
+ * RealNetworks. You may not use this file except in compliance with
+ * the RPSL or, if you have a valid RCSL with RealNetworks applicable
+ * to this file, the RCSL. Please see the applicable RPSL or RCSL for
+ * the rights, obligations and limitations governing use of the
+ * contents of the file.
+ *
+ * This file is part of the Helix DNA Technology. RealNetworks is the
+ * developer of the Original Code and owns the copyrights in the
+ * portions it created.
+ *
+ * This file, and the files included with this file, is distributed
+ * and made available on an 'AS IS' basis, WITHOUT WARRANTY OF ANY
+ * KIND, EITHER EXPRESS OR IMPLIED, AND REALNETWORKS HEREBY DISCLAIMS
+ * ALL SUCH WARRANTIES, INCLUDING WITHOUT LIMITATION, ANY WARRANTIES
+ * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, QUIET
+ * ENJOYMENT OR NON-INFRINGEMENT.
+ *
+ * Technology Compatibility Kit Test Suite(s) Location:
+ * http://www.helixcommunity.org/content/tck
+ *
+ * Contributor(s):
+ *
+ * ***** END LICENSE BLOCK ***** */
+
+/**************************************************************************************
+ * Fixed-point HE-AAC decoder
+ * Jon Recker (jrecker@real.com)
+ * February 2005
+ *
+ * sbrhfgen.c - high frequency generation for SBR
+ **************************************************************************************/
+
+#include "sbr.h"
+#include "assembly.h"
+
+#define FBITS_LPCOEFS 29 /* Q29 for range of (-4, 4) */
+#define MAG_16 (16 * (1 << (32 - (2*(32-FBITS_LPCOEFS))))) /* i.e. 16 in Q26 format */
+#define RELAX_COEF 0x7ffff79c /* 1.0 / (1.0 + 1e-6), Q31 */
+
+/* newBWTab[prev invfMode][curr invfMode], format = Q31 (table 4.158)
+ * sample file which uses all of these: al_sbr_sr_64_2_fsaac32.aac
+ */
+static const int newBWTab[4][4] = {
+ {0x00000000, 0x4ccccccd, 0x73333333, 0x7d70a3d7},
+ {0x4ccccccd, 0x60000000, 0x73333333, 0x7d70a3d7},
+ {0x00000000, 0x60000000, 0x73333333, 0x7d70a3d7},
+ {0x00000000, 0x60000000, 0x73333333, 0x7d70a3d7},
+};
+
+/**************************************************************************************
+ * Function: CVKernel1
+ *
+ * Description: kernel of covariance matrix calculation for p01, p11, p12, p22
+ *
+ * Inputs: buffer of low-freq samples, starting at time index = 0,
+ * freq index = patch subband
+ *
+ * Outputs: 64-bit accumulators for p01re, p01im, p12re, p12im, p11re, p22re
+ * stored in accBuf
+ *
+ * Return: none
+ *
+ * Notes: this is carefully written to be efficient on ARM
+ * use the assembly code version in sbrcov.s when building for ARM!
+ **************************************************************************************/
+#if 0// (defined (__arm) && defined (__ARMCC_VERSION)) || (defined (_WIN32) && defined (_WIN32_WCE) && defined (ARM)) || (defined(__GNUC__) && defined(__arm__))
+#ifdef __cplusplus
+extern "C"
+#endif
+void CVKernel1(int *XBuf, int *accBuf);
+#else
+void CVKernel1(int *XBuf, int *accBuf)
+{
+ U64 p01re, p01im, p12re, p12im, p11re, p22re;
+ int n, x0re, x0im, x1re, x1im;
+
+ x0re = XBuf[0];
+ x0im = XBuf[1];
+ XBuf += (2 * 64);
+ x1re = XBuf[0];
+ x1im = XBuf[1];
+ XBuf += (2 * 64);
+
+ p01re.w64 = p01im.w64 = 0;
+ p12re.w64 = p12im.w64 = 0;
+ p11re.w64 = 0;
+ p22re.w64 = 0;
+
+ p12re.w64 = MADD64(p12re.w64, x1re, x0re);
+ p12re.w64 = MADD64(p12re.w64, x1im, x0im);
+ p12im.w64 = MADD64(p12im.w64, x0re, x1im);
+ p12im.w64 = MADD64(p12im.w64, -x0im, x1re);
+ p22re.w64 = MADD64(p22re.w64, x0re, x0re);
+ p22re.w64 = MADD64(p22re.w64, x0im, x0im);
+ for (n = (NUM_TIME_SLOTS * SAMPLES_PER_SLOT + 6); n != 0; n--) {
+ /* 4 input, 3*2 acc, 1 ptr, 1 loop counter = 12 registers (use same for x0im, -x0im) */
+ x0re = x1re;
+ x0im = x1im;
+ x1re = XBuf[0];
+ x1im = XBuf[1];
+
+ p01re.w64 = MADD64(p01re.w64, x1re, x0re);
+ p01re.w64 = MADD64(p01re.w64, x1im, x0im);
+ p01im.w64 = MADD64(p01im.w64, x0re, x1im);
+ p01im.w64 = MADD64(p01im.w64, -x0im, x1re);
+ p11re.w64 = MADD64(p11re.w64, x0re, x0re);
+ p11re.w64 = MADD64(p11re.w64, x0im, x0im);
+
+ XBuf += (2 * 64);
+ }
+ /* these can be derived by slight changes to account for boundary conditions */
+ p12re.w64 += p01re.w64;
+ p12re.w64 = MADD64(p12re.w64, x1re, -x0re);
+ p12re.w64 = MADD64(p12re.w64, x1im, -x0im);
+ p12im.w64 += p01im.w64;
+ p12im.w64 = MADD64(p12im.w64, x0re, -x1im);
+ p12im.w64 = MADD64(p12im.w64, x0im, x1re);
+ p22re.w64 += p11re.w64;
+ p22re.w64 = MADD64(p22re.w64, x0re, -x0re);
+ p22re.w64 = MADD64(p22re.w64, x0im, -x0im);
+
+ accBuf[0] = p01re.r.lo32;
+ accBuf[1] = p01re.r.hi32;
+ accBuf[2] = p01im.r.lo32;
+ accBuf[3] = p01im.r.hi32;
+ accBuf[4] = p11re.r.lo32;
+ accBuf[5] = p11re.r.hi32;
+ accBuf[6] = p12re.r.lo32;
+ accBuf[7] = p12re.r.hi32;
+ accBuf[8] = p12im.r.lo32;
+ accBuf[9] = p12im.r.hi32;
+ accBuf[10] = p22re.r.lo32;
+ accBuf[11] = p22re.r.hi32;
+}
+#endif
+
+/**************************************************************************************
+ * Function: CalcCovariance1
+ *
+ * Description: calculate covariance matrix for p01, p12, p11, p22 (4.6.18.6.2)
+ *
+ * Inputs: buffer of low-freq samples, starting at time index 0,
+ * freq index = patch subband
+ *
+ * Outputs: complex covariance elements p01re, p01im, p12re, p12im, p11re, p22re
+ * (p11im = p22im = 0)
+ * format = integer (Q0) * 2^N, with scalefactor N >= 0
+ *
+ * Return: scalefactor N
+ *
+ * Notes: outputs are normalized to have 1 GB (sign in at least top 2 bits)
+ **************************************************************************************/
+static int CalcCovariance1(int *XBuf, int *p01reN, int *p01imN, int *p12reN, int *p12imN, int *p11reN, int *p22reN)
+{
+ int accBuf[2 * 6];
+ int n, z, s, loShift, hiShift, gbMask;
+ U64 p01re, p01im, p12re, p12im, p11re, p22re;
+
+ CVKernel1(XBuf, accBuf);
+ p01re.r.lo32 = accBuf[0];
+ p01re.r.hi32 = accBuf[1];
+ p01im.r.lo32 = accBuf[2];
+ p01im.r.hi32 = accBuf[3];
+ p11re.r.lo32 = accBuf[4];
+ p11re.r.hi32 = accBuf[5];
+ p12re.r.lo32 = accBuf[6];
+ p12re.r.hi32 = accBuf[7];
+ p12im.r.lo32 = accBuf[8];
+ p12im.r.hi32 = accBuf[9];
+ p22re.r.lo32 = accBuf[10];
+ p22re.r.hi32 = accBuf[11];
+
+ /* 64-bit accumulators now have 2*FBITS_OUT_QMFA fraction bits
+ * want to scale them down to integers (32-bit signed, Q0)
+ * with scale factor of 2^n, n >= 0
+ * leave 2 GB's for calculating determinant, so take top 30 non-zero bits
+ */
+ gbMask = ((p01re.r.hi32) ^(p01re.r.hi32 >> 31)) | ((p01im.r.hi32) ^(p01im.r.hi32 >> 31));
+ gbMask |= ((p12re.r.hi32) ^(p12re.r.hi32 >> 31)) | ((p12im.r.hi32) ^(p12im.r.hi32 >> 31));
+ gbMask |= ((p11re.r.hi32) ^(p11re.r.hi32 >> 31)) | ((p22re.r.hi32) ^(p22re.r.hi32 >> 31));
+ if (gbMask == 0) {
+ s = p01re.r.hi32 >> 31;
+ gbMask = (p01re.r.lo32 ^ s) - s;
+ s = p01im.r.hi32 >> 31;
+ gbMask |= (p01im.r.lo32 ^ s) - s;
+ s = p12re.r.hi32 >> 31;
+ gbMask |= (p12re.r.lo32 ^ s) - s;
+ s = p12im.r.hi32 >> 31;
+ gbMask |= (p12im.r.lo32 ^ s) - s;
+ s = p11re.r.hi32 >> 31;
+ gbMask |= (p11re.r.lo32 ^ s) - s;
+ s = p22re.r.hi32 >> 31;
+ gbMask |= (p22re.r.lo32 ^ s) - s;
+ z = 32 + CLZ(gbMask);
+ } else {
+ gbMask = FASTABS(p01re.r.hi32) | FASTABS(p01im.r.hi32);
+ gbMask |= FASTABS(p12re.r.hi32) | FASTABS(p12im.r.hi32);
+ gbMask |= FASTABS(p11re.r.hi32) | FASTABS(p22re.r.hi32);
+ z = CLZ(gbMask);
+ }
+
+ n = 64 - z; /* number of non-zero bits in bottom of 64-bit word */
+ if (n <= 30) {
+ loShift = (30 - n);
+ *p01reN = p01re.r.lo32 << loShift;
+ *p01imN = p01im.r.lo32 << loShift;
+ *p12reN = p12re.r.lo32 << loShift;
+ *p12imN = p12im.r.lo32 << loShift;
+ *p11reN = p11re.r.lo32 << loShift;
+ *p22reN = p22re.r.lo32 << loShift;
+ return -(loShift + 2 * FBITS_OUT_QMFA);
+ } else if (n < 32 + 30) {
+ loShift = (n - 30);
+ hiShift = 32 - loShift;
+ *p01reN = (p01re.r.hi32 << hiShift) | (p01re.r.lo32 >> loShift);
+ *p01imN = (p01im.r.hi32 << hiShift) | (p01im.r.lo32 >> loShift);
+ *p12reN = (p12re.r.hi32 << hiShift) | (p12re.r.lo32 >> loShift);
+ *p12imN = (p12im.r.hi32 << hiShift) | (p12im.r.lo32 >> loShift);
+ *p11reN = (p11re.r.hi32 << hiShift) | (p11re.r.lo32 >> loShift);
+ *p22reN = (p22re.r.hi32 << hiShift) | (p22re.r.lo32 >> loShift);
+ return (loShift - 2 * FBITS_OUT_QMFA);
+ } else {
+ hiShift = n - (32 + 30);
+ *p01reN = p01re.r.hi32 >> hiShift;
+ *p01imN = p01im.r.hi32 >> hiShift;
+ *p12reN = p12re.r.hi32 >> hiShift;
+ *p12imN = p12im.r.hi32 >> hiShift;
+ *p11reN = p11re.r.hi32 >> hiShift;
+ *p22reN = p22re.r.hi32 >> hiShift;
+ return (32 - 2 * FBITS_OUT_QMFA - hiShift);
+ }
+
+ return 0;
+}
+
+/**************************************************************************************
+ * Function: CVKernel2
+ *
+ * Description: kernel of covariance matrix calculation for p02
+ *
+ * Inputs: buffer of low-freq samples, starting at time index = 0,
+ * freq index = patch subband
+ *
+ * Outputs: 64-bit accumulators for p02re, p02im stored in accBuf
+ *
+ * Return: none
+ *
+ * Notes: this is carefully written to be efficient on ARM
+ * use the assembly code version in sbrcov.s when building for ARM!
+ **************************************************************************************/
+#if 0// (defined (__arm) && defined (__ARMCC_VERSION)) || (defined (_WIN32) && defined (_WIN32_WCE) && defined (ARM)) || (defined(__GNUC__) && defined(__arm__))
+#ifdef __cplusplus
+extern "C"
+#endif
+void CVKernel2(int *XBuf, int *accBuf);
+#else
+void CVKernel2(int *XBuf, int *accBuf)
+{
+ U64 p02re, p02im;
+ int n, x0re, x0im, x1re, x1im, x2re, x2im;
+
+ p02re.w64 = p02im.w64 = 0;
+
+ x0re = XBuf[0];
+ x0im = XBuf[1];
+ XBuf += (2 * 64);
+ x1re = XBuf[0];
+ x1im = XBuf[1];
+ XBuf += (2 * 64);
+
+ for (n = (NUM_TIME_SLOTS * SAMPLES_PER_SLOT + 6); n != 0; n--) {
+ /* 6 input, 2*2 acc, 1 ptr, 1 loop counter = 12 registers (use same for x0im, -x0im) */
+ x2re = XBuf[0];
+ x2im = XBuf[1];
+
+ p02re.w64 = MADD64(p02re.w64, x2re, x0re);
+ p02re.w64 = MADD64(p02re.w64, x2im, x0im);
+ p02im.w64 = MADD64(p02im.w64, x0re, x2im);
+ p02im.w64 = MADD64(p02im.w64, -x0im, x2re);
+
+ x0re = x1re;
+ x0im = x1im;
+ x1re = x2re;
+ x1im = x2im;
+ XBuf += (2 * 64);
+ }
+
+ accBuf[0] = p02re.r.lo32;
+ accBuf[1] = p02re.r.hi32;
+ accBuf[2] = p02im.r.lo32;
+ accBuf[3] = p02im.r.hi32;
+}
+#endif
+
+/**************************************************************************************
+ * Function: CalcCovariance2
+ *
+ * Description: calculate covariance matrix for p02 (4.6.18.6.2)
+ *
+ * Inputs: buffer of low-freq samples, starting at time index = 0,
+ * freq index = patch subband
+ *
+ * Outputs: complex covariance element p02re, p02im
+ * format = integer (Q0) * 2^N, with scalefactor N >= 0
+ *
+ * Return: scalefactor N
+ *
+ * Notes: outputs are normalized to have 1 GB (sign in at least top 2 bits)
+ **************************************************************************************/
+static int CalcCovariance2(int *XBuf, int *p02reN, int *p02imN)
+{
+ U64 p02re, p02im;
+ int n, z, s, loShift, hiShift, gbMask;
+ int accBuf[2 * 2];
+
+ CVKernel2(XBuf, accBuf);
+ p02re.r.lo32 = accBuf[0];
+ p02re.r.hi32 = accBuf[1];
+ p02im.r.lo32 = accBuf[2];
+ p02im.r.hi32 = accBuf[3];
+
+ /* 64-bit accumulators now have 2*FBITS_OUT_QMFA fraction bits
+ * want to scale them down to integers (32-bit signed, Q0)
+ * with scale factor of 2^n, n >= 0
+ * leave 1 GB for calculating determinant, so take top 30 non-zero bits
+ */
+ gbMask = ((p02re.r.hi32) ^(p02re.r.hi32 >> 31)) | ((p02im.r.hi32) ^(p02im.r.hi32 >> 31));
+ if (gbMask == 0) {
+ s = p02re.r.hi32 >> 31;
+ gbMask = (p02re.r.lo32 ^ s) - s;
+ s = p02im.r.hi32 >> 31;
+ gbMask |= (p02im.r.lo32 ^ s) - s;
+ z = 32 + CLZ(gbMask);
+ } else {
+ gbMask = FASTABS(p02re.r.hi32) | FASTABS(p02im.r.hi32);
+ z = CLZ(gbMask);
+ }
+ n = 64 - z; /* number of non-zero bits in bottom of 64-bit word */
+
+ if (n <= 30) {
+ loShift = (30 - n);
+ *p02reN = p02re.r.lo32 << loShift;
+ *p02imN = p02im.r.lo32 << loShift;
+ return -(loShift + 2 * FBITS_OUT_QMFA);
+ } else if (n < 32 + 30) {
+ loShift = (n - 30);
+ hiShift = 32 - loShift;
+ *p02reN = (p02re.r.hi32 << hiShift) | (p02re.r.lo32 >> loShift);
+ *p02imN = (p02im.r.hi32 << hiShift) | (p02im.r.lo32 >> loShift);
+ return (loShift - 2 * FBITS_OUT_QMFA);
+ } else {
+ hiShift = n - (32 + 30);
+ *p02reN = p02re.r.hi32 >> hiShift;
+ *p02imN = p02im.r.hi32 >> hiShift;
+ return (32 - 2 * FBITS_OUT_QMFA - hiShift);
+ }
+
+ return 0;
+}
+
+/**************************************************************************************
+ * Function: CalcLPCoefs
+ *
+ * Description: calculate linear prediction coefficients for one subband (4.6.18.6.2)
+ *
+ * Inputs: buffer of low-freq samples, starting at time index = 0,
+ * freq index = patch subband
+ * number of guard bits in input sample buffer
+ *
+ * Outputs: complex LP coefficients a0re, a0im, a1re, a1im, format = Q29
+ *
+ * Return: none
+ *
+ * Notes: output coefficients (a0re, a0im, a1re, a1im) clipped to range (-4, 4)
+ * if the comples coefficients have magnitude >= 4.0, they are all
+ * set to 0 (see spec)
+ **************************************************************************************/
+static int CalcLPCoefs(int *XBuf, int *a0re, int *a0im, int *a1re, int *a1im, int gb)
+{
+ int zFlag, n1, n2, nd, d, dInv, tre, tim;
+ int p01re, p01im, p02re, p02im, p12re, p12im, p11re, p22re;
+
+ /* pre-scale to avoid overflow - probably never happens in practice (see QMFA)
+ * max bit growth per accumulator = 38*2 = 76 mul-adds (X * X)
+ * using 64-bit MADD, so if X has n guard bits, X*X has 2n+1 guard bits
+ * gain 1 extra sign bit per multiply, so ensure ceil(log2(76/2) / 2) = 3 guard bits on inputs
+ */
+ if (gb < 3) {
+ nd = 3 - gb;
+ for (n1 = (NUM_TIME_SLOTS * SAMPLES_PER_SLOT + 6 + 2); n1 != 0; n1--) {
+ XBuf[0] >>= nd;
+ XBuf[1] >>= nd;
+ XBuf += (2 * 64);
+ }
+ XBuf -= (2 * 64 * (NUM_TIME_SLOTS * SAMPLES_PER_SLOT + 6 + 2));
+ }
+
+ /* calculate covariance elements */
+ n1 = CalcCovariance1(XBuf, &p01re, &p01im, &p12re, &p12im, &p11re, &p22re);
+ n2 = CalcCovariance2(XBuf, &p02re, &p02im);
+
+ /* normalize everything to larger power of 2 scalefactor, call it n1 */
+ if (n1 < n2) {
+ nd = MIN(n2 - n1, 31);
+ p01re >>= nd;
+ p01im >>= nd;
+ p12re >>= nd;
+ p12im >>= nd;
+ p11re >>= nd;
+ p22re >>= nd;
+ n1 = n2;
+ } else if (n1 > n2) {
+ nd = MIN(n1 - n2, 31);
+ p02re >>= nd;
+ p02im >>= nd;
+ }
+
+ /* calculate determinant of covariance matrix (at least 1 GB in pXX) */
+ d = MULSHIFT32(p12re, p12re) + MULSHIFT32(p12im, p12im);
+ d = MULSHIFT32(d, RELAX_COEF) << 1;
+ d = MULSHIFT32(p11re, p22re) - d;
+ //this assert always failed,no a fatal error when decoder sbr data ????.
+ //ASSERT(d >= 0,ERR_AAC_SBR_BITSTREAM); /* should never be < 0 */
+
+ zFlag = 0;
+ *a0re = *a0im = 0;
+ *a1re = *a1im = 0;
+ if (d > 0) {
+ /* input = Q31 d = Q(-2*n1 - 32 + nd) = Q31 * 2^(31 + 2*n1 + 32 - nd)
+ * inverse = Q29 dInv = Q29 * 2^(-31 - 2*n1 - 32 + nd) = Q(29 + 31 + 2*n1 + 32 - nd)
+ *
+ * numerator has same Q format as d, since it's sum of normalized squares
+ * so num * inverse = Q(-2*n1 - 32) * Q(29 + 31 + 2*n1 + 32 - nd)
+ * = Q(29 + 31 - nd), drop low 32 in MULSHIFT32
+ * = Q(29 + 31 - 32 - nd) = Q(28 - nd)
+ */
+ nd = CLZ(d) - 1;
+ d <<= nd;
+ dInv = InvRNormalized(d);
+
+ /* 1 GB in pXX */
+ tre = MULSHIFT32(p01re, p12re) - MULSHIFT32(p01im, p12im) - MULSHIFT32(p02re, p11re);
+ tre = MULSHIFT32(tre, dInv);
+ tim = MULSHIFT32(p01re, p12im) + MULSHIFT32(p01im, p12re) - MULSHIFT32(p02im, p11re);
+ tim = MULSHIFT32(tim, dInv);
+
+ /* if d is extremely small, just set coefs to 0 (would have poor precision anyway) */
+ if (nd > 28 || (FASTABS(tre) >> (28 - nd)) >= 4 || (FASTABS(tim) >> (28 - nd)) >= 4) {
+ zFlag = 1;
+ } else {
+ *a1re = tre << (FBITS_LPCOEFS - 28 + nd); /* i.e. convert Q(28 - nd) to Q(29) */
+ *a1im = tim << (FBITS_LPCOEFS - 28 + nd);
+ }
+ }
+
+ if (p11re) {
+ /* input = Q31 p11re = Q(-n1 + nd) = Q31 * 2^(31 + n1 - nd)
+ * inverse = Q29 dInv = Q29 * 2^(-31 - n1 + nd) = Q(29 + 31 + n1 - nd)
+ *
+ * numerator is Q(-n1 - 3)
+ * so num * inverse = Q(-n1 - 3) * Q(29 + 31 + n1 - nd)
+ * = Q(29 + 31 - 3 - nd), drop low 32 in MULSHIFT32
+ * = Q(29 + 31 - 3 - 32 - nd) = Q(25 - nd)
+ */
+ nd = CLZ(p11re) - 1; /* assume positive */
+ p11re <<= nd;
+ dInv = InvRNormalized(p11re);
+
+ /* a1re, a1im = Q29, so scaled by (n1 + 3) */
+ tre = (p01re >> 3) + MULSHIFT32(p12re, *a1re) + MULSHIFT32(p12im, *a1im);
+ tre = -MULSHIFT32(tre, dInv);
+ tim = (p01im >> 3) - MULSHIFT32(p12im, *a1re) + MULSHIFT32(p12re, *a1im);
+ tim = -MULSHIFT32(tim, dInv);
+
+ if (nd > 25 || (FASTABS(tre) >> (25 - nd)) >= 4 || (FASTABS(tim) >> (25 - nd)) >= 4) {
+ zFlag = 1;
+ } else {
+ *a0re = tre << (FBITS_LPCOEFS - 25 + nd); /* i.e. convert Q(25 - nd) to Q(29) */
+ *a0im = tim << (FBITS_LPCOEFS - 25 + nd);
+ }
+ }
+
+ /* see 4.6.18.6.2 - if magnitude of a0 or a1 >= 4 then a0 = a1 = 0
+ * i.e. a0re < 4, a0im < 4, a1re < 4, a1im < 4
+ * Q29*Q29 = Q26
+ */
+ if (zFlag || MULSHIFT32(*a0re, *a0re) + MULSHIFT32(*a0im, *a0im) >= MAG_16 || MULSHIFT32(*a1re, *a1re) + MULSHIFT32(*a1im, *a1im) >= MAG_16) {
+ *a0re = *a0im = 0;
+ *a1re = *a1im = 0;
+ }
+
+ /* no need to clip - we never changed the XBuf data, just used it to calculate a0 and a1 */
+ if (gb < 3) {
+ nd = 3 - gb;
+ for (n1 = (NUM_TIME_SLOTS * SAMPLES_PER_SLOT + 6 + 2); n1 != 0; n1--) {
+ XBuf[0] <<= nd;
+ XBuf[1] <<= nd;
+ XBuf += (2 * 64);
+ }
+ }
+ return ERR_AAC_NONE;
+}
+
+/**************************************************************************************
+ * Function: GenerateHighFreq
+ *
+ * Description: generate high frequencies with SBR (4.6.18.6)
+ *
+ * Inputs: initialized PSInfoSBR struct
+ * initialized SBRGrid struct for this channel
+ * initialized SBRFreq struct for this SCE/CPE block
+ * initialized SBRChan struct for this channel
+ * index of current channel (0 for SCE, 0 or 1 for CPE)
+ *
+ * Outputs: new high frequency samples starting at frequency kStart
+ *
+ * Return: none
+ **************************************************************************************/
+int GenerateHighFreq(PSInfoSBR *psi, SBRGrid *sbrGrid, SBRFreq *sbrFreq, SBRChan *sbrChan, int ch)
+{
+ int band, newBW, c, t, gb, gbMask, gbIdx;
+ int currPatch, p, x, k, g, i, iStart, iEnd, bw, bwsq;
+ int a0re, a0im, a1re, a1im;
+ int x1re, x1im, x2re, x2im;
+ int ACCre, ACCim;
+ int *XBufLo, *XBufHi;
+ int err = ERR_AAC_NONE;
+ /* calculate array of chirp factors */
+ for (band = 0; band < sbrFreq->numNoiseFloorBands; band++) {
+ c = sbrChan->chirpFact[band]; /* previous (bwArray') */
+ newBW = newBWTab[sbrChan->invfMode[0][band]][sbrChan->invfMode[1][band]];
+
+ /* weighted average of new and old (can't overflow - total gain = 1.0) */
+ if (newBW < c) {
+ t = MULSHIFT32(newBW, 0x60000000) + MULSHIFT32(0x20000000, c); /* new is smaller: 0.75*new + 0.25*old */
+ } else {
+ t = MULSHIFT32(newBW, 0x74000000) + MULSHIFT32(0x0c000000, c); /* new is larger: 0.90625*new + 0.09375*old */
+ }
+ t <<= 1;
+
+ if (t < 0x02000000) { /* below 0.015625, clip to 0 */
+ t = 0;
+ }
+ if (t > 0x7f800000) { /* clip to 0.99609375 */
+ t = 0x7f800000;
+ }
+
+ /* save curr as prev for next time */
+ sbrChan->chirpFact[band] = t;
+ sbrChan->invfMode[0][band] = sbrChan->invfMode[1][band];
+ }
+
+ iStart = sbrGrid->envTimeBorder[0] + HF_ADJ;
+ iEnd = sbrGrid->envTimeBorder[sbrGrid->numEnv] + HF_ADJ;
+
+ /* generate new high freqs from low freqs, patches, and chirp factors */
+ k = sbrFreq->kStart;
+ g = 0;
+ bw = sbrChan->chirpFact[g];
+ bwsq = MULSHIFT32(bw, bw) << 1;
+
+ gbMask = (sbrChan->gbMask[0] | sbrChan->gbMask[1]); /* older 32 | newer 8 */
+ gb = CLZ(gbMask) - 1;
+
+ for (currPatch = 0; currPatch < sbrFreq->numPatches; currPatch++) {
+ for (x = 0; x < sbrFreq->patchNumSubbands[currPatch]; x++) {
+ /* map k to corresponding noise floor band */
+ if (k >= sbrFreq->freqNoise[g + 1]) {
+ g++;
+ bw = sbrChan->chirpFact[g]; /* Q31 */
+ bwsq = MULSHIFT32(bw, bw) << 1; /* Q31 */
+ }
+
+ p = sbrFreq->patchStartSubband[currPatch] + x; /* low QMF band */
+ XBufHi = psi->XBuf[iStart][k];
+ if (bw) {
+ err = CalcLPCoefs(psi->XBuf[0][p], &a0re, &a0im, &a1re, &a1im, gb);
+ if (err) {
+ return err;
+ }
+ a0re = MULSHIFT32(bw, a0re); /* Q31 * Q29 = Q28 */
+ a0im = MULSHIFT32(bw, a0im);
+ a1re = MULSHIFT32(bwsq, a1re);
+ a1im = MULSHIFT32(bwsq, a1im);
+
+ XBufLo = psi->XBuf[iStart - 2][p];
+
+ x2re = XBufLo[0]; /* RE{XBuf[n-2]} */
+ x2im = XBufLo[1]; /* IM{XBuf[n-2]} */
+ XBufLo += (64 * 2);
+
+ x1re = XBufLo[0]; /* RE{XBuf[n-1]} */
+ x1im = XBufLo[1]; /* IM{XBuf[n-1]} */
+ XBufLo += (64 * 2);
+
+ for (i = iStart; i < iEnd; i++) {
+ /* a0re/im, a1re/im are Q28 with at least 1 GB,
+ * so the summing for AACre/im is fine (1 GB in, plus 1 from MULSHIFT32)
+ */
+ ACCre = MULSHIFT32(x2re, a1re) - MULSHIFT32(x2im, a1im);
+ ACCim = MULSHIFT32(x2re, a1im) + MULSHIFT32(x2im, a1re);
+ x2re = x1re;
+ x2im = x1im;
+
+ ACCre += MULSHIFT32(x1re, a0re) - MULSHIFT32(x1im, a0im);
+ ACCim += MULSHIFT32(x1re, a0im) + MULSHIFT32(x1im, a0re);
+ x1re = XBufLo[0]; /* RE{XBuf[n]} */
+ x1im = XBufLo[1]; /* IM{XBuf[n]} */
+ XBufLo += (64 * 2);
+
+ /* lost 4 fbits when scaling by a0re/im, a1re/im (Q28) */
+ CLIP_2N_SHIFT30(ACCre, 4);
+ ACCre += x1re;
+ CLIP_2N_SHIFT30(ACCim, 4);
+ ACCim += x1im;
+
+ XBufHi[0] = ACCre;
+ XBufHi[1] = ACCim;
+ XBufHi += (64 * 2);
+
+ /* update guard bit masks */
+ gbMask = FASTABS(ACCre);
+ gbMask |= FASTABS(ACCim);
+ gbIdx = (i >> 5) & 0x01; /* 0 if i < 32, 1 if i >= 32 */
+ sbrChan->gbMask[gbIdx] |= gbMask;
+ }
+ } else {
+ XBufLo = (int *)psi->XBuf[iStart][p];
+ for (i = iStart; i < iEnd; i++) {
+ XBufHi[0] = XBufLo[0];
+ XBufHi[1] = XBufLo[1];
+ XBufLo += (64 * 2);
+ XBufHi += (64 * 2);
+ }
+ }
+ k++; /* high QMF band */
+ }
+ }
+ return ERR_AAC_NONE;
+}
+
+