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/amadec/adec-ffmpeg-mgt.c b/amadec/adec-ffmpeg-mgt.c
new file mode 100644
index 0000000..2a84c45
--- a/dev/null
+++ b/amadec/adec-ffmpeg-mgt.c
@@ -0,0 +1,1550 @@
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <fcntl.h>
+#include <pthread.h>
+#include <sys/ioctl.h>
+#include <dlfcn.h>
+
+#include "audiodsp_update_format.h"
+#include "adec_omx_brige.h"
+#include "adec_reg.h"
+#include <adec-pts-mgt.h>
+#include <adec_write.h>
+#include "Amsysfsutils.h"
+#include "amconfigutils.h"
+
+#include <audio-dec.h>
+#include <amthreadpool.h>
+#include <cutils/properties.h>
+
+extern int read_buffer(unsigned char *buffer, int size);
+void *audio_decode_loop(void *args);
+void *audio_dtsdecode_loop(void *args);
+void *audio_getpackage_loop(void *args);
+static int set_sysfs_int(const char *path, int val);
+static void stop_decode_thread(aml_audio_dec_t *audec);
+
+/*audio decoder list structure*/
+typedef struct {
+ //enum CodecID codec_id;
+ int codec_id;
+ char name[64];
+} audio_lib_t;
+
+audio_lib_t audio_lib_list[] = {
+ {ACODEC_FMT_AAC, "libfaad.so"},
+ {ACODEC_FMT_AAC_LATM, "libfaad.so"},
+ {ACODEC_FMT_APE, "libape.so"},
+ {ACODEC_FMT_MPEG, "libmad.so"},
+ {ACODEC_FMT_MPEG2, "libmad.so"},
+ {ACODEC_FMT_MPEG1, "libmad.so"},
+ {ACODEC_FMT_FLAC, "libflac.so"},
+ {ACODEC_FMT_COOK, "libcook.so"},
+ {ACODEC_FMT_RAAC, "libraac.so"},
+ {ACODEC_FMT_AMR, "libamr.so"},
+
+ {ACODEC_FMT_PCM_S16BE, "libpcm.so"},
+ {ACODEC_FMT_PCM_S16LE, "libpcm.so"},
+ {ACODEC_FMT_PCM_U8, "libpcm.so"},
+ {ACODEC_FMT_PCM_BLURAY, "libpcm.so"},
+ {ACODEC_FMT_WIFIDISPLAY, "libpcm.so"},
+ {ACODEC_FMT_ALAW, "libpcm.so"},
+ {ACODEC_FMT_MULAW, "libpcm.so"},
+ {ACODEC_FMT_ADPCM, "libadpcm.so"},
+ {ACODEC_FMT_DRA, "libdra.so"},
+ 0
+} ;
+
+int find_audio_lib(aml_audio_dec_t *audec)
+{
+ int i;
+ int num;
+ audio_lib_t *f;
+
+ adec_print("[%s %d]audec->format/%d audec->codec_id/0x%x\n", __FUNCTION__, __LINE__, audec->format, audec->codec_id);
+ num = ARRAY_SIZE(audio_lib_list);
+ audio_decoder_operations_t *adec_ops = audec->adec_ops;
+ //-------------------------
+ if (find_omx_lib(audec)) {
+ return 0;
+ }
+ //-----------------------
+ for (i = 0; i < num; i++) {
+ f = &audio_lib_list[i];
+ if (f->codec_id == audec->format) {
+ void *fd = dlopen(audio_lib_list[i].name, RTLD_NOW);
+ if (fd != 0) {
+ adec_ops->init = dlsym(fd, "audio_dec_init");
+ adec_ops->decode = dlsym(fd, "audio_dec_decode");
+ adec_ops->release = dlsym(fd, "audio_dec_release");
+ adec_ops->getinfo = dlsym(fd, "audio_dec_getinfo");
+ } else {
+ adec_print("cant find decoder lib\n");
+ return -1;
+ }
+ return 0;
+ }
+ }
+ return -1;
+}
+
+
+audio_decoder_operations_t AudioArmDecoder = {
+ "FFmpegDecoder",
+ AUDIO_ARM_DECODER,
+ 0,
+};
+static int FFmpegDecoderInit(audio_decoder_operations_t *adec_ops)
+{
+ return 0;
+}
+static int FFmpegDecode(audio_decoder_operations_t *adec_ops, char *outbuf, int *outlen, char *inbuf, int inlen)
+{
+ int ret;
+ return ret;
+}
+static int FFmpegDecoderRelease(audio_decoder_operations_t *adec_ops)
+{
+ aml_audio_dec_t *audec = (aml_audio_dec_t *)(adec_ops->priv_data);
+ return 0;
+}
+audio_decoder_operations_t AudioFFmpegDecoder = {
+ .name = "FFmpegDecoder",
+ .nAudioDecoderType = AUDIO_FFMPEG_DECODER,
+ .init = FFmpegDecoderInit,
+ .decode = FFmpegDecode,
+ .release = FFmpegDecoderRelease,
+ .getinfo = NULL,
+};
+
+int package_list_free(aml_audio_dec_t * audec)
+{
+ lp_lock(&(audec->pack_list.tslock));
+ while (audec->pack_list.pack_num) {
+ struct package * p = audec->pack_list.first;
+ audec->pack_list.first = audec->pack_list.first->next;
+ free(p->data);
+ free(p);
+ audec->pack_list.pack_num--;
+ }
+ lp_unlock(&(audec->pack_list.tslock));
+ return 0;
+}
+static int64_t gettime_ms(void)
+{
+ struct timeval tv;
+ gettimeofday(&tv, NULL);
+ return (int64_t)tv.tv_sec * 1000 + tv.tv_usec/1000;
+}
+
+
+int package_list_init(aml_audio_dec_t * audec)
+{
+ audec->pack_list.first = NULL;
+ audec->pack_list.pack_num = 0;
+ audec->pack_list.current = NULL;
+ lp_lock_init(&(audec->pack_list.tslock), NULL);
+ return 0;
+}
+
+int package_add(aml_audio_dec_t * audec, char * data, int size)
+{
+ lp_lock(&(audec->pack_list.tslock));
+ if (audec->pack_list.pack_num == 4) { //enough
+ lp_unlock(&(audec->pack_list.tslock));
+ return -2;
+ }
+ struct package *p = malloc(sizeof(struct package));
+ if (!p) { //malloc failed
+ lp_unlock(&(audec->pack_list.tslock));
+ return -1;
+ }
+ p->data = data;
+ p->size = size;
+ if (audec->pack_list.pack_num == 0) { //first package
+ audec->pack_list.first = p;
+ audec->pack_list.current = p;
+ audec->pack_list.pack_num = 1;
+ } else {
+ audec->pack_list.current->next = p;
+ audec->pack_list.current = p;
+ audec->pack_list.pack_num++;
+ }
+ lp_unlock(&(audec->pack_list.tslock));
+ return 0;
+}
+
+struct package * package_get(aml_audio_dec_t * audec) {
+ lp_lock(&(audec->pack_list.tslock));
+ if (audec->pack_list.pack_num == 0) {
+ lp_unlock(&(audec->pack_list.tslock));
+ return NULL;
+ }
+ struct package *p = audec->pack_list.first;
+ if (audec->pack_list.pack_num == 1) {
+ audec->pack_list.first = NULL;
+ audec->pack_list.pack_num = 0;
+ audec->pack_list.current = NULL;
+ } else if (audec->pack_list.pack_num > 1) {
+ audec->pack_list.first = audec->pack_list.first->next;
+ audec->pack_list.pack_num--;
+ }
+ lp_unlock(&(audec->pack_list.tslock));
+ return p;
+}
+
+
+int armdec_stream_read(dsp_operations_t *dsp_ops, char *buffer, int size)
+{
+ int read_size = 0;
+ aml_audio_dec_t *audec = (aml_audio_dec_t *)dsp_ops->audec;
+ read_size = read_pcm_buffer(buffer, audec->g_bst, size);
+ audec->out_len_after_last_valid_pts += read_size;
+ return read_size;
+}
+
+int armdec_stream_read_raw(dsp_operations_t *dsp_ops, char *buffer, int size)
+{
+ aml_audio_dec_t *audec = (aml_audio_dec_t *)dsp_ops->audec;
+ return read_pcm_buffer(buffer, audec->g_bst_raw, size);
+}
+unsigned long armdec_get_pts(dsp_operations_t *dsp_ops)
+{
+ unsigned long val, offset;
+ unsigned long pts;
+ int data_width, channels, samplerate;
+ unsigned long long frame_nums ;
+ unsigned long delay_pts;
+ char value[PROPERTY_VALUE_MAX];
+ aml_audio_dec_t *audec = (aml_audio_dec_t *)dsp_ops->audec;
+ audio_out_operations_t * aout_ops = &audec->aout_ops;
+ float track_speed = 1.0f;
+ if (aout_ops->track_rate != 8.8f)
+ track_speed = aout_ops->track_rate;
+ switch (audec->g_bst->data_width) {
+ case AV_SAMPLE_FMT_U8:
+ data_width = 8;
+ break;
+ case AV_SAMPLE_FMT_S16:
+ data_width = 16;
+ break;
+ case AV_SAMPLE_FMT_S32:
+ data_width = 32;
+ break;
+ default:
+ data_width = 16;
+ }
+
+ int pts_delta = 0;
+ if ( property_get("media.libplayer.pts_delta",value,NULL) > 0)
+ {
+ pts_delta = atoi(value);
+ }
+
+ channels = audec->g_bst->channels;
+ samplerate = audec->g_bst->samplerate;
+ if (!channels || !samplerate) {
+ adec_print("warning ::::zero channels %d, sample rate %d \n", channels, samplerate);
+ if (!samplerate) {
+ samplerate = 48000;
+ }
+ if (!channels) {
+ channels = 2;
+ }
+ }
+ offset = audec->decode_offset;
+ if (dsp_ops->dsp_file_fd >= 0) {
+ if (audec->g_bst->format != ACODEC_FMT_COOK && audec->g_bst->format != ACODEC_FMT_RAAC) {
+ //when first look up apts,set offset 0
+ if (!audec->first_apts_lookup_over) {
+ offset = 0;
+ }
+ ioctl(dsp_ops->dsp_file_fd, AMSTREAM_IOC_APTS_LOOKUP, &offset);
+ }
+ //for cook/raac should wait to get first apts from decoder
+ else {
+ int wait_count = 10;
+ while (offset == 0xffffffff && wait_count-- > 0) {
+ amthreadpool_thread_usleep(10000);
+ }
+ offset = audec->decode_offset;
+ if (offset == 0xffffffff) {
+ adec_print(" cook/raac get apts 100 ms timeout \n");
+ }
+
+ }
+ } else {
+ adec_print("====abuf have not open!\n", val);
+ }
+
+ if (am_getconfig_bool("media.arm.audio.apts_add")) {
+ offset = 0;
+ }
+ pts = offset;
+ if (!audec->first_apts_lookup_over) {
+ audec->last_valid_pts = pts;
+ audec->first_apts_lookup_over = 1;
+ return pts;
+ }
+
+ if (audec->use_get_out_posion && audec->aout_ops.get_out_position) {
+ /*add by zz*/
+ int64_t postion, time_us;
+ struct timespec timenow;
+ int ret;
+ ret = audec->aout_ops.get_out_position(audec, &postion, &time_us);
+ if (!ret) {
+ int decodered_samples;
+ int cache_samples;
+ int delay_us, t_us;
+ decodered_samples = audec->decode_pcm_offset * 8 /(channels * data_width);
+ cache_samples = decodered_samples - postion;
+ if (cache_samples < 0)
+ cache_samples = 0;
+ delay_us = 1000 * (cache_samples * 1000 / samplerate);
+ clock_gettime(CLOCK_MONOTONIC, &timenow);
+ t_us = timenow.tv_sec * 1000000LL + timenow.tv_nsec/1000 - time_us;
+ if (t_us > 0)
+ delay_us -= t_us;
+ if (delay_us < 0)
+ delay_us = 0;
+ delay_pts = delay_us * 90/1000;
+ if (pts == 0) {
+ int outsamples = postion - audec->last_out_postion ;
+ /*delay_us out samples after last refresh pts*/
+ delay_us = 1000 * (outsamples * 1000 / samplerate);
+ delay_us = delay_us * track_speed;
+ if (delay_us < 0)
+ delay_us = 0;
+ pts = audec->last_valid_pts + delay_us * 90 /1000;
+ audec->last_valid_pts = pts;
+ pts += 90000 / 1000 * pts_delta;
+ audec->last_out_postion = postion;
+ audec->last_get_postion_time_us = time_us;
+ return pts;
+ }
+ audec->last_out_postion = postion;
+ audec->last_get_postion_time_us = time_us;
+ } else {
+ delay_pts = 0;/*audio track not ready? used buf_level add for pts*/
+ }
+ } else {
+ delay_pts = 0;
+ }
+ if (delay_pts == 0)
+ {
+ if (pts == 0) {
+ if (audec->last_valid_pts) {
+ pts = audec->last_valid_pts;
+ }
+ frame_nums = (audec->out_len_after_last_valid_pts * 8 / (data_width * channels));
+ pts += (frame_nums * 90000 / samplerate);
+ pts += 90000 / 1000 * pts_delta;
+ if (pts < 0)
+ pts = 0;
+ //adec_print("decode_offset:%d out_pcm:%d pts:%d \n",decode_offset,out_len_after_last_valid_pts,pts);
+ return pts;
+ }
+ {
+ int len = audec->g_bst->buf_level + audec->pcm_cache_size;
+ frame_nums = (len * 8 / (data_width * channels));
+ delay_pts = (frame_nums * 90000 / samplerate);
+ }
+ }
+ delay_pts = delay_pts * track_speed;
+ if (pts > delay_pts) {
+ pts -= delay_pts;
+ } else {
+ pts = 0;
+ }
+ val = pts;
+ audec->last_valid_pts = pts;
+ audec->out_len_after_last_valid_pts = 0;
+ //adec_print("====get pts:%ld offset:%ld frame_num:%lld delay:%ld \n",val,decode_offset,frame_nums,delay_pts);
+
+ val += 90000 / 1000 * pts_delta; // for a/v sync test,some times audio ahead video +28ms.so add +15ms to apts to .....
+ if (val < 0)
+ val = 0;
+ return val;
+}
+
+unsigned long armdec_get_pcrscr(dsp_operations_t *dsp_ops)
+{
+ unsigned int val;
+ if (dsp_ops->dsp_file_fd < 0) {
+ adec_print("read error!! audiodsp have not opened\n");
+ return -1;
+ }
+ ioctl(dsp_ops->dsp_file_fd, AMSTREAM_IOC_PCRSCR, &val);
+ return val;
+}
+unsigned long armdec_set_pts(dsp_operations_t *dsp_ops, unsigned long apts)
+{
+ if (dsp_ops->dsp_file_fd < 0) {
+ adec_print("armdec_set_apts err!\n");
+ return -1;
+ }
+ ioctl(dsp_ops->dsp_file_fd, AMSTREAM_IOC_SET_APTS, &apts);
+ return 0;
+}
+int armdec_set_skip_bytes(dsp_operations_t* dsp_ops, unsigned int bytes)
+{
+ return 0;
+}
+static int set_sysfs_int(const char *path, int val)
+{
+ return amsysfs_set_sysfs_int(path, val);
+}
+int get_decoder_status(void *p, struct adec_status *adec)
+{
+ aml_audio_dec_t *audec = (aml_audio_dec_t *)p;
+ if (audec && audec->g_bst) {
+ adec->channels = audec->g_bst->channels;
+ adec->sample_rate = audec->g_bst->samplerate;
+ adec->resolution = audec->g_bst->data_width;
+ adec->error_count = audec->nDecodeErrCount; //need count
+ adec->status = (audec->state > INITTED) ? 1 : 0;
+ return 0;
+ } else {
+ return -1;
+ }
+}
+
+/**
+ * \brief register audio decoder
+ * \param audec pointer to audec ,codec_type
+ * \return 0 on success otherwise -1 if an error occurred
+ */
+int RegisterDecode(aml_audio_dec_t *audec, int type)
+{
+ switch (type) {
+ case AUDIO_ARM_DECODER:
+ memset(&AudioArmDecoder, 0, sizeof(audio_decoder_operations_t));
+ audec->adec_ops = &AudioArmDecoder;
+ find_audio_lib(audec);
+ audec->adec_ops->priv_data = audec;
+ break;
+ case AUDIO_FFMPEG_DECODER:
+ audec->adec_ops = &AudioFFmpegDecoder;
+ audec->adec_ops->priv_data = audec;
+ break;
+ default:
+ audec->adec_ops = &AudioFFmpegDecoder;
+ audec->adec_ops->priv_data = audec;
+ break;
+ }
+ return 0;
+}
+
+static int InBufferInit(aml_audio_dec_t *audec)
+{
+ int ret = uio_init(audec);
+ if (ret < 0) {
+ adec_print("uio init error! \n");
+ return -1;
+ }
+ return 0;
+}
+static int InBufferRelease(aml_audio_dec_t *audec)
+{
+ // close(audec->fd_uio);
+ // audec->fd_uio=-1;
+ uio_deinit(audec);
+ return 0;
+}
+
+
+static int OutBufferInit(aml_audio_dec_t *audec)
+{
+ audec->g_bst = malloc(sizeof(buffer_stream_t));
+ if (!audec->g_bst) {
+ adec_print("[%s %d]g_bst malloc failed! \n", __FUNCTION__, __LINE__);
+ audec->g_bst = NULL;
+ return -1;
+ } else {
+ adec_print("[%s %d] audec->g_bst/%p", __FUNCTION__, __LINE__, audec->g_bst);
+ }
+
+ memset(audec->g_bst, 0, sizeof(buffer_stream_t));
+
+ if (audec->adec_ops->nOutBufSize <= 0) { //set default if not set
+ audec->adec_ops->nOutBufSize = DEFAULT_PCM_BUFFER_SIZE;
+ }
+
+ int ret = init_buff(audec->g_bst, audec->adec_ops->nOutBufSize);
+ if (ret == -1) {
+ adec_print("[%s %d]pcm buffer init failed !\n", __FUNCTION__, __LINE__);
+ return -1;
+ }
+ adec_print("[%s %d]pcm buffer init ok buf_size:%d\n", __FUNCTION__, __LINE__, audec->g_bst->buf_length);
+
+ audec->g_bst->data_width = audec->data_width = AV_SAMPLE_FMT_S16;
+
+ if (audec->channels > 0) {
+ audec->g_bst->channels = audec->channels;
+ }
+ if (audec->samplerate > 0) {
+ audec->g_bst->samplerate = audec->samplerate;
+ }
+ audec->g_bst->format = audec->format;
+
+ return 0;
+}
+static int OutBufferInit_raw(aml_audio_dec_t *audec)
+{
+ audec->g_bst_raw = malloc(sizeof(buffer_stream_t));
+ if (!audec->g_bst_raw) {
+ adec_print("[%s %d]g_bst_raw malloc failed!\n", __FUNCTION__, __LINE__);
+ audec->g_bst_raw = NULL;
+ return -1;
+ } else {
+ adec_print("[%s %d] audec->audec->g_bst_raw/%p", __FUNCTION__, __LINE__, audec->g_bst_raw);
+ }
+
+ if (audec->adec_ops->nOutBufSize <= 0) { //set default if not set
+ audec->adec_ops->nOutBufSize = DEFAULT_PCM_BUFFER_SIZE;
+ }
+ if ((audec->format == ACODEC_FMT_DTS || audec->format == ACODEC_FMT_TRUEHD) && amsysfs_get_sysfs_int("/sys/class/audiodsp/digital_raw") == 2) {
+ audec->adec_ops->nOutBufSize *= 2;
+ }
+ int ret = init_buff(audec->g_bst_raw, audec->adec_ops->nOutBufSize);
+ if (ret == -1) {
+ adec_print("[%s %d]raw_buf init failed !\n", __FUNCTION__, __LINE__);
+ return -1;
+ }
+ adec_print("[%s %d]raw buffer init ok buf_size/%d\n", __FUNCTION__, __LINE__, audec->g_bst_raw->buf_length);
+
+ audec->g_bst_raw->data_width = audec->data_width = AV_SAMPLE_FMT_S16;
+ if (audec->channels > 0) {
+ audec->g_bst_raw->channels = audec->channels;
+ } else {
+ audec->g_bst_raw->channels = audec->channels = 2;
+ }
+
+ if (audec->samplerate > 0) {
+ audec->g_bst_raw->samplerate = audec->samplerate;
+ } else {
+ audec->g_bst_raw->samplerate = audec->samplerate = 48000;
+ }
+
+ return 0;
+}
+static int OutBufferRelease(aml_audio_dec_t *audec)
+{
+ if (audec->g_bst) {
+ adec_print("[%s %d] audec->g_bst/%p", __FUNCTION__, __LINE__, audec->g_bst);
+ release_buffer(audec->g_bst);
+ audec->g_bst = NULL;
+ }
+ return 0;
+}
+
+static int OutBufferRelease_raw(aml_audio_dec_t *audec)
+{
+ if (audec->g_bst_raw) {
+ adec_print("[%s %d] audec->g_bst_raw/%p", __FUNCTION__, __LINE__, audec->g_bst_raw);
+ release_buffer(audec->g_bst_raw);
+ audec->g_bst_raw = NULL;
+ }
+ return 0;
+}
+
+static int enable_raw_output(aml_audio_dec_t *audec)
+{
+ int enable = 0;
+ enable = amsysfs_get_sysfs_int("/sys/class/audiodsp/digital_raw");
+ if (enable) {
+ if (audec->format == ACODEC_FMT_AC3 || audec->format == ACODEC_FMT_EAC3 || audec->format == ACODEC_FMT_DTS ||
+ audec->format == ACODEC_FMT_TRUEHD) {
+ return 1;
+ }
+ }
+ return 0;
+}
+static int audio_codec_init(aml_audio_dec_t *audec)
+{
+ //reset static&global
+ audec->exit_decode_thread = 0;
+ audec->exit_decode_thread_success = 0;
+ audec->decode_offset = 0;
+ audec->decode_pcm_offset = 0;
+ audec->nDecodeErrCount = 0;
+ audec->g_bst = NULL;
+ audec->g_bst_raw = NULL;
+ audec->fd_uio = -1;
+ audec->last_valid_pts = 0;
+ audec->out_len_after_last_valid_pts = 0;
+ audec->pcm_cache_size = 0;
+ audec->sn_threadid = -1;
+ audec->sn_getpackage_threadid = -1;
+ audec->OmxFirstFrameDecoded = 0;
+ audec->use_get_out_posion = am_getconfig_bool_def("media.audio.pts.use_get_posion", 0);
+ package_list_init(audec);
+ while (0 != set_sysfs_int(DECODE_ERR_PATH, DECODE_NONE_ERR)) {
+ adec_print("[%s %d]set codec fatal failed ! \n", __FUNCTION__, __LINE__);
+ amthreadpool_thread_usleep(100000);
+ }
+
+ adec_print("[%s %d]param:data_width:%d samplerate:%d channel:%d \n",
+ __FUNCTION__, __LINE__, audec->data_width, audec->samplerate, audec->channels);
+
+ audec->data_width = AV_SAMPLE_FMT_S16;
+ if (audec->channels > 0) {
+ int NumChSave = audec->channels;
+ audec->channels = (audec->channels > 2 ? 2 : audec->channels);
+ audec->adec_ops->channels = audec->channels;
+ if (audec->format == ACODEC_FMT_PCM_S16BE || audec->format == ACODEC_FMT_PCM_S16LE ||
+ audec->format == ACODEC_FMT_PCM_U8 || audec->format == ACODEC_FMT_PCM_BLURAY ||
+ audec->format == ACODEC_FMT_WIFIDISPLAY || audec->format == ACODEC_FMT_ALAW ||
+ audec->format == ACODEC_FMT_MULAW || audec->format == ACODEC_FMT_ADPCM) {
+ audec->adec_ops->channels = NumChSave;
+ }
+ }
+ //for raac/cook audio pts are updated from audio decoder,so set a invalid pts default.
+ else if (audec->format == ACODEC_FMT_RAAC || audec->format == ACODEC_FMT_COOK) {
+ audec->decode_offset = 0xffffffff;
+ }
+ if (audec->samplerate > 0) {
+ audec->adec_ops->samplerate = audec->samplerate;
+ } else {
+ // audec->adec_ops->samplerate=audec->samplerate=48000;
+ }
+ switch (audec->data_width) {
+ case AV_SAMPLE_FMT_U8:
+ audec->adec_ops->bps = 8;
+ break;
+ case AV_SAMPLE_FMT_S16:
+ audec->adec_ops->bps = 16;
+ break;
+ case AV_SAMPLE_FMT_S32:
+ audec->adec_ops->bps = 32;
+ break;
+ default:
+ audec->adec_ops->bps = 16;
+ }
+ adec_print("[%s %d]param_applied: bps:%d samplerate:%d channel:%d \n",
+ __FUNCTION__, __LINE__, audec->adec_ops->bps, audec->adec_ops->samplerate, audec->adec_ops->channels);
+
+ audec->adec_ops->extradata_size = audec->extradata_size;
+ if (audec->extradata_size > 0) {
+ memcpy(audec->adec_ops->extradata, audec->extradata, audec->extradata_size);
+ }
+
+ int ret = 0;
+ if (!audec->StageFrightCodecEnableType) { //1-decoder init
+ ret = audec->adec_ops->init(audec->adec_ops);
+ }
+ if (ret == -1) {
+ adec_print("[%s %d]adec_ops init err\n", __FUNCTION__, __LINE__);
+ goto err1;
+ }
+
+ ret = OutBufferInit(audec); //2-pcm_buffer init
+ if (ret == -1) {
+ adec_print("[%s %d]out buffer init err\n", __FUNCTION__, __LINE__);
+ goto err2;
+ }
+ if (enable_raw_output(audec)) {
+ ret = OutBufferInit_raw(audec);
+ if (ret == -1) {
+ adec_print("[%s %d]out_raw buffer init err\n", __FUNCTION__, __LINE__);
+ OutBufferRelease_raw(audec);
+ goto err2;
+ }
+ }
+ ret = InBufferInit(audec); //3-init uio
+ if (ret == -1) {
+ adec_print("====in buffer init err \n");
+ goto err3;
+ }
+
+ //4-other init
+ audec->adsp_ops.dsp_on = 1;
+ audec->adsp_ops.dsp_read = armdec_stream_read;
+ audec->adsp_ops.get_cur_pts = armdec_get_pts;
+ audec->adsp_ops.get_cur_pcrscr = armdec_get_pcrscr;
+ audec->adsp_ops.set_cur_apts = armdec_set_pts;
+ audec->adsp_ops.set_skip_bytes = armdec_set_skip_bytes;
+ audec->adsp_ops.dsp_read_raw = armdec_stream_read_raw;
+ audec->pcm_bytes_readed = 0;
+ audec->raw_bytes_readed = 0;
+ audec->raw_frame_size = 0;
+ audec->pcm_frame_size = 0;
+ audec->i2s_iec958_sync_flag = 1;
+ audec->i2s_iec958_sync_gate = 0;
+ audec->codec_type = 0;
+ return 0;
+
+err1:
+ audec->adec_ops->release(audec->adec_ops);
+ return -1;
+err2:
+ audec->adec_ops->release(audec->adec_ops);
+ OutBufferRelease(audec);
+ return -1;
+err3:
+ audec->adec_ops->release(audec->adec_ops);
+ OutBufferRelease(audec);
+ InBufferRelease(audec);
+ OutBufferRelease_raw(audec);
+ return -1;
+}
+int audio_codec_release(aml_audio_dec_t *audec)
+{
+ //1-decode thread quit
+ if (!audec->StageFrightCodecEnableType) {
+ stop_decode_thread(audec);//1-decode thread quit
+ audec->adec_ops->release(audec->adec_ops);//2-decoder release
+ } else {
+ stop_decode_thread_omx(audec);
+ }
+
+ InBufferRelease(audec);//3-uio uninit
+ OutBufferRelease(audec);//4-outbufferrelease
+ OutBufferRelease_raw(audec);
+ audec->adsp_ops.dsp_on = -1;//5-other release
+ audec->adsp_ops.dsp_read = NULL;
+ audec->adsp_ops.get_cur_pts = NULL;
+ audec->adsp_ops.dsp_file_fd = -1;
+
+ return 0;
+}
+
+
+static int audio_hardware_ctrl(hw_command_t cmd)
+{
+ int fd;
+ fd = open(AUDIO_CTRL_DEVICE, O_RDONLY);
+ if (fd < 0) {
+ adec_print("Open Device %s Failed!", AUDIO_CTRL_DEVICE);
+ return -1;
+ }
+
+ switch (cmd) {
+ case HW_CHANNELS_SWAP:
+ ioctl(fd, AMAUDIO_IOC_SET_CHANNEL_SWAP, 0);
+ break;
+
+ case HW_LEFT_CHANNEL_MONO:
+ ioctl(fd, AMAUDIO_IOC_SET_LEFT_MONO, 0);
+ break;
+
+ case HW_RIGHT_CHANNEL_MONO:
+ ioctl(fd, AMAUDIO_IOC_SET_RIGHT_MONO, 0);
+ break;
+
+ case HW_STEREO_MODE:
+ ioctl(fd, AMAUDIO_IOC_SET_STEREO, 0);
+ break;
+
+ default:
+ adec_print("Unknow Command %d!", cmd);
+ break;
+
+ };
+
+ close(fd);
+ return 0;
+}
+
+static int get_first_apts_flag(dsp_operations_t *dsp_ops)
+{
+ int val;
+ if (dsp_ops->dsp_file_fd < 0) {
+ adec_print("[%s %d]read error!! audiodsp have not opened\n", __FUNCTION__, __LINE__);
+ return -1;
+ }
+ ioctl(dsp_ops->dsp_file_fd, GET_FIRST_APTS_FLAG, &val);
+ return val;
+}
+
+
+/**
+ * \brief start audio dec when receive START command.
+ * \param audec pointer to audec
+ */
+static int start_adec(aml_audio_dec_t *audec)
+{
+ int ret;
+ audio_out_operations_t *aout_ops = &audec->aout_ops;
+ dsp_operations_t *dsp_ops = &audec->adsp_ops;
+ unsigned long vpts, apts;
+ int times = 0;
+ char buf[32];
+ apts = vpts = 0;
+ audec->no_first_apts = 0;
+ audec->apts_start_flag = 0;
+ audec->first_apts = 0;
+
+ char value[PROPERTY_VALUE_MAX] = {0};
+ int wait_count = 100;
+ if (property_get("media.amadec.wait_count", value, NULL) > 0) {
+ wait_count = atoi(value);
+ }
+ adec_print("wait first apts count :%d \n", wait_count);
+
+ if (audec->state == INITTED) {
+ //get info from the audiodsp == can get from amstreamer
+ while ((!get_first_apts_flag(dsp_ops)) && (!audec->need_stop) && (!audec->no_first_apts)) {
+ adec_print("wait first pts checkin complete !");
+ if (amthreadpool_on_requare_exit(pthread_self())) {
+ adec_print("[%s:%d] quick interrupt \n", __FUNCTION__, __LINE__);
+ break;
+ }
+ times++;
+ if (times >= wait_count) {
+ amsysfs_get_sysfs_str(TSYNC_VPTS, buf, sizeof(buf));// read vpts
+ if (sscanf(buf, "0x%lx", &vpts) < 1) {
+ adec_print("unable to get vpts from: %s", buf);
+ return -1;
+ }
+ // save vpts to apts
+ if (vpts == 0) { // vpts invalid too
+ times = 0; // loop again
+ continue;
+ }
+ adec_print("## can't get first apts, save vpts to apts,vpts=%lx, \n", vpts);
+ sprintf(buf, "0x%lx", vpts);
+ amsysfs_set_sysfs_str(TSYNC_APTS, buf);
+ audec->no_first_apts = 1;
+ }
+ amthreadpool_thread_usleep(100000);
+ }
+ adec_print("get first apts ok, times:%d need_stop:%d auto_mute %d\n", times, audec->need_stop, audec->auto_mute);
+ if (audec->need_stop) {
+ return 0;
+ }
+
+ /*start the the pts scr,...*/
+ ret = adec_pts_start(audec);
+ if (audec->auto_mute) {
+ avsync_en(0);
+ adec_pts_pause();
+ while ((!audec->need_stop) && track_switch_pts(audec)) {
+ amthreadpool_thread_usleep(1000);
+ }
+ avsync_en(1);
+ adec_pts_resume();
+ audec->auto_mute = 0;
+ }
+ if (audec->tsync_mode == TSYNC_MODE_PCRMASTER) {
+ adec_print("[wcs-%s]-before audio track start,sleep 200ms\n",__FUNCTION__);
+ amthreadpool_thread_usleep(200 * 1000); //200ms
+ }
+ aout_ops->start(audec);
+ audec->state = ACTIVE;
+ } else {
+ adec_print("amadec status invalid, start adec failed \n");
+ return -1;
+ }
+
+ return 0;
+}
+
+/**
+ * \brief pause audio dec when receive PAUSE command.
+ * \param audec pointer to audec
+ */
+static void pause_adec(aml_audio_dec_t *audec)
+{
+ audio_out_operations_t *aout_ops = &audec->aout_ops;
+ if (audec->state == ACTIVE) {
+ audec->state = PAUSED;
+ adec_pts_pause();
+ aout_ops->pause(audec);
+ }
+}
+
+/**
+ * \brief resume audio dec when receive RESUME command.
+ * \param audec pointer to audec
+ */
+static void resume_adec(aml_audio_dec_t *audec)
+{
+ audio_out_operations_t *aout_ops = &audec->aout_ops;
+ if (audec->state == PAUSED) {
+ audec->state = ACTIVE;
+ audec->refresh_pts_readytime_ms = gettime_ms() +
+ am_getconfig_int_def("media.amadec.wait_fresh_ms", 200);
+ aout_ops->resume(audec);
+ adec_pts_resume();
+ }
+}
+
+/**
+ * \brief stop audio dec when receive STOP command.
+ * \param audec pointer to audec
+ */
+static void stop_adec(aml_audio_dec_t *audec)
+{
+ audio_out_operations_t *aout_ops = &audec->aout_ops;
+ adec_print("[%s %d]audec->state/%d\n", __FUNCTION__, __LINE__, audec->state);
+ if (audec->state > INITING) {
+ char buf[64];
+
+ audec->state = STOPPED;
+ aout_ops->mute(audec, 1); //mute output, some repeat sound in audioflinger after stop
+ aout_ops->stop(audec);
+ audio_codec_release(audec);
+
+ sprintf(buf, "0x%lx", 0);
+ amsysfs_set_sysfs_str(TSYNC_FIRSTAPTS, buf);
+ }
+}
+
+/**
+ * \brief release audio dec when receive RELEASE command.
+ * \param audec pointer to audec
+ */
+static void release_adec(aml_audio_dec_t *audec)
+{
+ audec->state = TERMINATED;
+}
+
+/**
+ * \brief mute audio dec when receive MUTE command.
+ * \param audec pointer to audec
+ * \param en 1 = mute, 0 = unmute
+ */
+static void mute_adec(aml_audio_dec_t *audec, int en)
+{
+ audio_out_operations_t *aout_ops = &audec->aout_ops;
+ if (aout_ops->mute) {
+ adec_print("%s the output !\n", (en ? "mute" : "unmute"));
+ aout_ops->mute(audec, en);
+ audec->muted = en;
+ }
+}
+
+/**
+ * \brief set volume to audio dec when receive SET_VOL command.
+ * \param audec pointer to audec
+ * \param vol volume value
+ */
+static void adec_set_volume(aml_audio_dec_t *audec, float vol)
+{
+ audio_out_operations_t *aout_ops = &audec->aout_ops;
+ if (aout_ops->set_volume) {
+ adec_print("set audio volume! vol = %f\n", vol);
+ aout_ops->set_volume(audec, vol);
+ }
+}
+
+/**
+ * \brief set volume to audio dec when receive SET_LRVOL command.
+ * \param audec pointer to audec
+ * \param lvol left channel volume value
+ * \param rvol right channel volume value
+ */
+static void adec_set_lrvolume(aml_audio_dec_t *audec, float lvol, float rvol)
+{
+ audio_out_operations_t *aout_ops = &audec->aout_ops;
+ if (aout_ops->set_lrvolume) {
+ adec_print("set audio volume! left vol = %f,right vol:%f\n", lvol, rvol);
+ aout_ops->set_lrvolume(audec, lvol, rvol);
+ }
+}
+static void adec_flag_check(aml_audio_dec_t *audec)
+{
+ audio_out_operations_t *aout_ops = &audec->aout_ops;
+ if (audec->auto_mute && (audec->state > INITTED)) {
+ aout_ops->pause(audec);
+ amthreadpool_thread_usleep(10000);
+ while ((!audec->need_stop) && track_switch_pts(audec)) {
+ amthreadpool_thread_usleep(1000);
+ }
+ aout_ops->resume(audec);
+ audec->auto_mute = 0;
+ }
+}
+
+
+static void start_decode_thread(aml_audio_dec_t *audec)
+{
+ if (audec->state != INITTED) {
+ adec_print("decode not inited quit \n");
+ return;
+ }
+
+ pthread_t tid;
+ int ret = amthreadpool_pthread_create_name(&tid, NULL, (void *)audio_getpackage_loop, (void *)audec, "getpackagelp");
+ audec->sn_getpackage_threadid = tid;
+ adec_print("[%s]Create get package thread success! tid = %d\n", __FUNCTION__, tid);
+
+ ret = amthreadpool_pthread_create_name(&tid, NULL, (void *)audio_decode_loop, (void *)audec, "decodeloop");
+ if (ret != 0) {
+ adec_print("[%s]Create ffmpeg decode thread failed!\n", __FUNCTION__);
+ return;
+ }
+ audec->sn_threadid = tid;
+ audec->audio_decoder_enabled = 0x1;
+ pthread_setname_np(tid, "AmadecDecodeLP");
+ adec_print("[%s]Create ffmpeg decode thread success! tid = %d\n", __FUNCTION__, tid);
+}
+static void stop_decode_thread(aml_audio_dec_t *audec)
+{
+ audec->exit_decode_thread = 1;
+ int ret = amthreadpool_pthread_join(audec->sn_threadid, NULL);
+ adec_print("[%s]decode thread exit success\n", __FUNCTION__);
+ ret = amthreadpool_pthread_join(audec->sn_getpackage_threadid, NULL);
+ adec_print("[%s]get package thread exit success\n", __FUNCTION__);
+
+ audec->sn_threadid = -1;
+ audec->sn_getpackage_threadid = -1;
+}
+
+/* --------------------------------------------------------------------------*/
+/**
+* @brief getNextFrameSize Get next frame size
+*
+* @param[in] format audio format
+*
+* @return -1: no frame_size use default 0: need get again non_zero: success
+*/
+/* --------------------------------------------------------------------------*/
+
+static int get_frame_size(aml_audio_dec_t *audec)
+{
+ int frame_szie = 0;
+ int ret = 0;
+ int extra_data = 8; //?
+ StartCode *start_code = &audec->start_code;
+
+ if (start_code->status == 0 || start_code->status == 3) {
+ memset(start_code, 0, sizeof(StartCode));
+ }
+ /*ape case*/
+ if (audec->format == ACODEC_FMT_APE) {
+ if (start_code->status == 0) { //have not get the sync data
+ ret = read_buffer(start_code->buff, 4);
+ if (ret <= 0) {
+ return 0;
+ }
+ start_code->size = 4;
+ start_code->status = 1;
+ }
+
+ if (start_code->status == 1) { //start find sync word
+ if (start_code->size < 4) {
+ ret = read_buffer(start_code->buff + start_code->size, 4 - start_code->size);
+ if (ret <= 0) {
+ return 0;
+ }
+ start_code->size = 4;
+ }
+ if (start_code->size == 4) {
+ if ((start_code->buff[0] == 'A') && (start_code->buff[1] == 'P') && (start_code->buff[2] == 'T') && (start_code->buff[3] == 'S')) {
+ start_code->size = 0;
+ start_code->status = 2; //sync word found ,start find frame size
+ } else {
+ start_code->size = 3;
+ start_code->buff[0] = start_code->buff[1];
+ start_code->buff[1] = start_code->buff[2];
+ start_code->buff[2] = start_code->buff[3];
+ return 0;
+ }
+ }
+
+ }
+
+ if (start_code->status == 2) {
+ ret = read_buffer(start_code->buff, 4);
+ if (ret <= 0) {
+ return 0;
+ }
+ start_code->size = 4;
+ frame_szie = start_code->buff[3] << 24 | start_code->buff[2] << 16 | start_code->buff[1] << 8 | start_code->buff[0] + extra_data;
+ frame_szie = (frame_szie + 3) & (~3);
+ start_code->status = 3; //found frame size
+ return frame_szie;
+ }
+ }
+ return -1;
+}
+// check if audio format info changed,if changed, apply new parameters to audio track
+static void check_audio_info_changed(aml_audio_dec_t *audec)
+{
+ buffer_stream_t *g_bst = audec->g_bst;
+ AudioInfo g_AudioInfo = {0};
+ int BufLevelAllowDoFmtChg = 0;
+ audio_decoder_operations_t *adec_ops = audec->adec_ops;
+ adec_ops->getinfo(audec->adec_ops, &g_AudioInfo);
+ if (g_AudioInfo.channels != 0 && g_AudioInfo.samplerate != 0) {
+ if ((g_AudioInfo.channels != g_bst->channels) || (g_AudioInfo.samplerate != g_bst->samplerate)) {
+ // the first time we get sample rate/channel num info,we use that to set audio track.
+ if (audec->channels == 0 || audec->samplerate == 0) {
+ g_bst->channels = audec->channels = g_AudioInfo.channels;
+ g_bst->samplerate = audec->samplerate = g_AudioInfo.samplerate;
+ } else {
+ //experienc value:0.2 Secs
+ BufLevelAllowDoFmtChg = audec->samplerate * audec->channels * (audec->adec_ops->bps >> 3) / 5;
+ while ((audec->format_changed_flag || g_bst->buf_level > BufLevelAllowDoFmtChg) && !audec->exit_decode_thread) {
+ amthreadpool_thread_usleep(20000);
+ }
+ if (!audec->exit_decode_thread) {
+ adec_print("[%s]Info Changed: src:sample:%d channel:%d dest sample:%d channel:%d PCMBufLevel:%d\n",
+ __FUNCTION__, audec->samplerate, audec->channels, g_AudioInfo.samplerate, g_AudioInfo.channels, g_bst->buf_level);
+ g_bst->channels = g_AudioInfo.channels;
+ g_bst->samplerate = g_AudioInfo.samplerate;
+ if (audec->state == ACTIVE)
+ audec->aout_ops.pause(audec);
+ audec->format_changed_flag = 1;
+ }
+ }
+ }
+ }
+}
+void *audio_getpackage_loop(void *args)
+{
+ int ret;
+ aml_audio_dec_t *audec;
+ audio_decoder_operations_t *adec_ops;
+ int nNextFrameSize = 0; //next read frame size
+ int inlen = 0;//real data size in in_buf
+ int nInBufferSize = 0; //full buffer size
+ char *inbuf = NULL;//real buffer
+ int rlen = 0;//read buffer ret size
+ int nAudioFormat;
+ unsigned wfd = 0;
+ if (am_getconfig_bool("media.libplayer.wfd")) {
+ wfd = 1;
+ }
+
+ adec_print("[%s]adec_getpackage_loop start!\n", __FUNCTION__);
+ audec = (aml_audio_dec_t *)args;
+ adec_ops = audec->adec_ops;
+ nAudioFormat = audec->format;
+ inlen = 0;
+ nNextFrameSize = adec_ops->nInBufSize;
+ while (1) {
+exit_decode_loop:
+ if (audec->exit_decode_thread) { /*detect quit condition*/
+ if (inbuf) {
+ free(inbuf);
+ }
+ package_list_free(audec);
+ break;
+ }
+
+ nNextFrameSize = get_frame_size(audec); /*step 2 get read buffer size*/
+ if (nNextFrameSize == -1) {
+ nNextFrameSize = adec_ops->nInBufSize;
+ } else if (nNextFrameSize == 0) {
+ amthreadpool_thread_usleep(1000);
+ continue;
+ }
+
+ nInBufferSize = nNextFrameSize;/*step 3 read buffer*/
+ if (inbuf != NULL) {
+ free(inbuf);
+ inbuf = NULL;
+ }
+ inbuf = malloc(nInBufferSize);
+
+ int nNextReadSize = nInBufferSize;
+ int nRet = 0;
+ int nReadErrCount = 0;
+ int nCurrentReadCount = 0;
+ int nReadSizePerTime = 1 * 1024;
+ rlen = 0;
+ int sleeptime = 0;
+ while (nNextReadSize > 0 && !audec->exit_decode_thread) {
+ if (nNextReadSize <= nReadSizePerTime) {
+ nReadSizePerTime = nNextReadSize;
+ }
+ nRet = read_buffer(inbuf + rlen, nReadSizePerTime); //read 10K per time
+ if (nRet <= 0) {
+ sleeptime++;
+ amthreadpool_thread_usleep(1000);
+ continue;
+ }
+ rlen += nRet;
+ nNextReadSize -= nRet;
+ if (wfd && nAudioFormat == ACODEC_FMT_AAC) {
+ if (rlen > 300) {
+ break;
+ }
+ }
+ }
+ // adec_print(" read data %d,sleep time %d ms \n", rlen,sleeptime);
+
+ sleeptime = 0;
+ nCurrentReadCount = rlen;
+ rlen += inlen;
+ ret = -1;
+ while ((ret = package_add(audec, inbuf, rlen)) && !audec->exit_decode_thread) {
+ amthreadpool_thread_usleep(1000);
+ }
+ if (ret) {
+ free(inbuf);
+ }
+ inbuf = NULL;
+ }
+QUIT:
+ adec_print("[%s]Exit adec_getpackage_loop Thread finished!", __FUNCTION__);
+ pthread_exit(NULL);
+ return NULL;
+}
+
+static char pcm_buf_tmp[AVCODEC_MAX_AUDIO_FRAME_SIZE];//max frame size out buf
+void *audio_decode_loop(void *args)
+{
+ int ret;
+ aml_audio_dec_t *audec;
+ audio_out_operations_t *aout_ops;
+ audio_decoder_operations_t *adec_ops;
+ int nNextFrameSize = 0; //next read frame size
+ int inlen = 0;//real data size in in_buf
+ int nRestLen = 0; //left data after last decode
+ int nInBufferSize = 0; //full buffer size
+ //int nStartDecodePoint=0;//start decode point in in_buf
+ char *inbuf = NULL;//real buffer
+ int rlen = 0;//read buffer ret size
+ char *pRestData = NULL;
+ char *inbuf2;
+
+ int dlen = 0;//decode size one time
+ int declen = 0;//current decoded size
+ int nCurrentReadCount = 0;
+ int needdata = 0;
+ char startcode[5];
+ int extra_data = 8;
+ int nCodecID;
+ int nAudioFormat;
+ char *outbuf = pcm_buf_tmp;
+ int outlen = 0;
+ struct package *p_Package;
+ buffer_stream_t *g_bst;
+ AudioInfo g_AudioInfo;
+ adec_print("[%s]adec_armdec_loop start!\n", __FUNCTION__);
+ audec = (aml_audio_dec_t *)args;
+ aout_ops = &audec->aout_ops;
+ adec_ops = audec->adec_ops;
+ memset(outbuf, 0, AVCODEC_MAX_AUDIO_FRAME_SIZE);
+ g_bst = audec->g_bst;
+
+ nAudioFormat = audec->format;
+ g_bst->format = audec->format;
+ inlen = 0;
+ nNextFrameSize = adec_ops->nInBufSize;
+ adec_ops->nAudioDecoderType = audec->format;
+ while (1) {
+exit_decode_loop:
+
+ if (audec->exit_decode_thread) { //detect quit condition
+ if (inbuf) {
+ free(inbuf);
+ inbuf = NULL;
+ }
+ if (pRestData) {
+ free(pRestData);
+ pRestData = NULL;
+ }
+ audec->exit_decode_thread_success = 1;
+ break;
+ }
+ //step 2 get read buffer size
+ p_Package = package_get(audec);
+ if (!p_Package) {
+ amthreadpool_thread_usleep(1000);
+ continue;
+ }
+ if (inbuf != NULL) {
+ free(inbuf);
+ inbuf = NULL;
+ }
+
+ if (inlen && pRestData) {
+ rlen = p_Package->size + inlen;
+ inbuf = malloc(rlen);
+ memcpy(inbuf, pRestData, inlen);
+ memcpy(inbuf + inlen, p_Package->data, p_Package->size);
+ free(pRestData);
+ free(p_Package->data);
+ pRestData = NULL;
+ p_Package->data = NULL;
+ } else {
+ rlen = p_Package->size;
+ inbuf = p_Package->data;
+ p_Package->data = NULL;
+ }
+ free(p_Package);
+ p_Package = NULL;
+
+ nCurrentReadCount = rlen;
+ inlen = rlen;
+ declen = 0;
+ if (nCurrentReadCount > 0) {
+ while (declen < rlen && !audec->exit_decode_thread) {
+ outlen = AVCODEC_MAX_AUDIO_FRAME_SIZE;
+ if (nAudioFormat == ACODEC_FMT_COOK || nAudioFormat == ACODEC_FMT_RAAC || nAudioFormat == ACODEC_FMT_AMR) {
+ if (needdata > 0) {
+ pRestData = malloc(inlen);
+ if (pRestData) {
+ memcpy(pRestData, (uint8_t *)(inbuf + declen), inlen);
+ }
+ needdata = 0;
+ break;
+ }
+ }
+
+ dlen = adec_ops->decode(audec->adec_ops, outbuf, &outlen, inbuf + declen, inlen);
+ if (outlen > 0) {
+ check_audio_info_changed(audec);
+ }
+ if (outlen > AVCODEC_MAX_AUDIO_FRAME_SIZE) {
+ adec_print("!!!!!fatal error,out buffer overwriten,out len %d,actual %d", outlen, AVCODEC_MAX_AUDIO_FRAME_SIZE);
+ }
+ if (dlen <= 0) {
+
+ if (nAudioFormat == ACODEC_FMT_APE) {
+ inlen = 0;
+ } else if (inlen > 0) {
+ pRestData = malloc(inlen);
+ if (pRestData) {
+ memcpy(pRestData, (uint8_t *)(inbuf + declen), inlen);
+ }
+ }
+ audec->nDecodeErrCount++;//decode failed, add err_count
+ needdata = 0;
+ break;
+ }
+ audec->nDecodeErrCount = 0; //decode success reset to 0
+ declen += dlen;
+ inlen -= dlen;
+
+ /* decoder input buffer not enough,need new data burst */
+ if (nAudioFormat == ACODEC_FMT_COOK || nAudioFormat == ACODEC_FMT_RAAC || nAudioFormat == ACODEC_FMT_AMR) {
+ if (inlen <= declen) {
+ needdata ++;
+ }
+ }
+ // for aac decoder, if decoder cost es data but no pcm output,may need more data ,which is needed by frame resync
+ else if (nAudioFormat == ACODEC_FMT_AAC_LATM || nAudioFormat == ACODEC_FMT_AAC) {
+ if (outlen == 0 && inlen) {
+ pRestData = malloc(inlen);
+ if (pRestData) {
+ memcpy(pRestData, (uint8_t *)(inbuf + declen), inlen);
+ }
+ audec->decode_offset += dlen; //update es offset for apts look up
+ break;
+ }
+ }
+ //write to the pcm buffer
+ if (nAudioFormat == ACODEC_FMT_RAAC || nAudioFormat == ACODEC_FMT_COOK) {
+ audec->decode_offset = audec->adec_ops->pts;
+ } else {
+ audec->decode_offset += dlen;
+ }
+ audec->decode_pcm_offset += outlen;
+ audec->pcm_cache_size = outlen;
+ if (g_bst) {
+ int wlen = 0;
+ while (outlen && !audec->exit_decode_thread) {
+ if (g_bst->buf_length - g_bst->buf_level < outlen) {
+ amthreadpool_thread_usleep(100000);
+ continue;
+ }
+ wlen = write_pcm_buffer(outbuf, g_bst, outlen);
+ outlen -= wlen;
+ audec->pcm_cache_size -= wlen;
+ }
+ }
+ }
+ } else {
+ amthreadpool_thread_usleep(1000);
+ continue;
+ }
+ }
+
+ adec_print("[%s]exit adec_armdec_loop Thread finished!", __FUNCTION__);
+ pthread_exit(NULL);
+error:
+ pthread_exit(NULL);
+ return NULL;
+}
+
+void *adec_armdec_loop(void *args)
+{
+ int ret;
+ aml_audio_dec_t *audec;
+ audio_out_operations_t *aout_ops;
+ adec_cmd_t *msg = NULL;
+
+ audec = (aml_audio_dec_t *)args;
+ aout_ops = &audec->aout_ops;
+
+ // codec init
+ audec->state = INITING;
+ while (1) {
+ if (audec->need_stop) {
+ goto MSG_LOOP;
+ }
+
+ ret = audio_codec_init(audec);
+ if (ret == 0) {
+ break;
+ }
+ usleep(10000);
+ }
+ audec->state = INITTED;
+
+ //start decode thread
+ while (1) {
+ if (audec->need_stop) {
+ //no need to call release, will do it in stop_adec
+ goto MSG_LOOP;
+ }
+ if (audec->StageFrightCodecEnableType) {
+ start_decode_thread_omx(audec);
+ if (audec->OmxFirstFrameDecoded != 1) { // just one case, need_stop == 1
+ //usleep(10000); // no need
+ continue;
+ }
+ } else {
+ start_decode_thread(audec);
+ }
+ //ok
+ break;
+ }
+
+ //aout init
+ while (1) {
+ if (audec->need_stop) {
+ //no need to call release, will do it in stop_adec
+ goto MSG_LOOP;
+ }
+ //wait the audio sr/ch ready to set audio track.
+ adec_print("wait audio sr/channel begin \n");
+ while (((!audec->channels) || (!audec->samplerate)) && !audec->need_stop) {
+ amthreadpool_thread_usleep(10000);
+ }
+ adec_print("wait audio sr/channel done \n");
+ ret = aout_ops->init(audec);
+ if (ret) {
+ adec_print("[%s %d]Audio out device init failed!", __FUNCTION__, __LINE__);
+ amthreadpool_thread_usleep(10000);
+ continue;
+ }
+ //ok
+ break;
+ }
+
+ //wait first pts decoded
+ start_adec(audec);
+
+MSG_LOOP:
+ do {
+
+ adec_reset_track(audec);
+ adec_flag_check(audec);
+ if (audec->state == ACTIVE)
+ adec_refresh_pts(audec);
+ msg = adec_get_message(audec);
+ if (!msg) {
+ amthreadpool_thread_usleep(10 * 1000); //if not wait,need changed to amthread usleep
+ continue;
+ }
+
+ switch (msg->ctrl_cmd) {
+ case CMD_START:
+
+ adec_print("Receive START Command!\n");
+ //------------------------
+ if (!audec->StageFrightCodecEnableType) {
+ start_decode_thread(audec);
+ }
+ //------------------------
+ start_adec(audec);
+ break;
+
+ case CMD_PAUSE:
+
+ adec_print("Receive PAUSE Command!");
+ pause_adec(audec);
+ break;
+
+ case CMD_RESUME:
+
+ adec_print("Receive RESUME Command!");
+ resume_adec(audec);
+ break;
+
+ case CMD_STOP:
+
+ adec_print("Receive STOP Command!");
+ stop_adec(audec);
+ break;
+
+ case CMD_MUTE:
+
+ adec_print("Receive Mute Command!");
+ if (msg->has_arg) {
+ mute_adec(audec, msg->value.en);
+ }
+ break;
+
+ case CMD_SET_VOL:
+
+ adec_print("Receive Set Vol Command!");
+ if (msg->has_arg) {
+ adec_set_volume(audec, msg->value.volume);
+ }
+ break;
+ case CMD_SET_LRVOL:
+
+ adec_print("Receive Set LRVol Command!");
+ if (msg->has_arg) {
+ adec_set_lrvolume(audec, msg->value.volume, msg->value_ext.volume);
+ }
+ break;
+
+ case CMD_CHANL_SWAP:
+
+ adec_print("Receive Channels Swap Command!");
+ audio_hardware_ctrl(HW_CHANNELS_SWAP);
+ break;
+
+ case CMD_LEFT_MONO:
+
+ adec_print("Receive Left Mono Command!");
+ audio_hardware_ctrl(HW_LEFT_CHANNEL_MONO);
+ break;
+
+ case CMD_RIGHT_MONO:
+
+ adec_print("Receive Right Mono Command!");
+ audio_hardware_ctrl(HW_RIGHT_CHANNEL_MONO);
+ break;
+
+ case CMD_STEREO:
+
+ adec_print("Receive Stereo Command!");
+ audio_hardware_ctrl(HW_STEREO_MODE);
+ break;
+
+ case CMD_RELEASE:
+
+ adec_print("Receive RELEASE Command!");
+ release_adec(audec);
+ break;
+
+ default:
+ adec_print("Unknow Command!");
+ break;
+
+ }
+
+ if (msg) {
+ adec_message_free(msg);
+ msg = NULL;
+ }
+ } while (audec->state != TERMINATED);
+
+ adec_print("Exit Message Loop Thread!");
+ pthread_exit(NULL);
+ return NULL;
+}
+
+