diff options
author | Krishnankutty Kolathappilly <kkolat@codeaurora.org> | 2012-08-22 19:24:48 -0700 |
---|---|---|
committer | Steve Kondik <shade@chemlab.org> | 2013-06-18 19:17:54 -0700 |
commit | 1216ed8d00080619bb04c398bb0072945c58511b (patch) | |
tree | 82b758f07572e1cd2c4af8b50fecd777937fbe1f /include/media | |
parent | eaa35b4fdd81af7dd6ad35a10d9eb27ff9758739 (diff) | |
download | frameworks_av-1216ed8d00080619bb04c398bb0072945c58511b.zip frameworks_av-1216ed8d00080619bb04c398bb0072945c58511b.tar.gz frameworks_av-1216ed8d00080619bb04c398bb0072945c58511b.tar.bz2 |
Squashed commit of A/V changes from CodeAurora
* Brings us current with AU_LINUX_ANDROID_JB_2.5.04.02.02.040.367
Camera: Fix deadlock due to mLock in pcb and takepicture
In non-zsl case of takepicture, we do streamoff for preview
stream which is waiting on preview callback thread to exit.
By that time the lock has already been acquired by takePicture.
So preivew callback will not exit until it acquires lock and
takePicture cannot continue until PCB call back is returned.
Fix: Avoid the mLock at services when both Preview cb &
Compressed cb are enabled.
Change-Id: I6c264928bf1540c7b51f1add65f9c3e968506e15
CRs-fixed: 479419
audioflinger: Fix the LPA-AudioEffects crash issue
- Issue:crash is observed during LPA playback on enabling
effects followed by plug-out->plug-in of wired headset
- Rootcause: while deleteing the effectchain in deleteEffect
EffctChain is being unlocked after clearing the chain
which leads to accessing the lock which might already deleted.
- Fix: first unlock the effectChain and then call clear
CRs-Fixed: 491774
Change-Id: I518ff086c5ad71486cd29142563145137ebc15b6
libstagefright: Fix for crash in sound recorder during device switch
-Crash seen in sound recorder during frequent insertion and removal
of wired headset
-During device switch some time Codec's input buffers are too small to
accomodate buffer read from source. Omx codec doesn't read the fix size
buffer from source, during device switch scenario sometime buffer read
from source exceeds input buffer size so it goes in error state which
leads to crash.
-Increasing the input buffer size fix this issue
Change-Id: Id15378670880d0c3c0bd4408841b28be963549a0
CRs-Fixed: 488449
libstagefright: Fix for FPS drop issue during A-V playback.
Issues:
-The AAC decoder was not updating the timestamp when EOS is reached.
-Logic to smoothen the real time update in AudioPlayer uses system
time. This introduces corrupt timestamp during EOS.
Fix:
-Update the timestamp in AAC decoder when EOS is reached.
-Extrapolate realtime using system time in AudioPlayer when EOS is
reached. Cap the value to realtime if extrapolated time becomes greater
than realtime.
CRs-Fixed: 384183
Change-Id: Ice54501436431d2527fcd3d710d65d9732fcffdd
libstagefright: Reset buffer size value with SurfaceTexture
- OMXCodec explicitly sets the decoder output buffer size using the
native window perform API. (to accomodate extra-data)
- This size is reset only when the SurfaceTexture is destroyed.
- Unless reset, this size will be assumed for all output buffers
if the SurfaceTexture is re-used.
CRs-Fixed: 337660, 432309
Change-Id: I28aed12ad02adeac61caffbb00e3082640a5f6d4
audio: Add support for tunnel mode recording
- Add support for tunnel mode recording.
Change-Id: I95cdfff729affd784141487521c9f2f714221d11
audio: Add support for non-pcm VOIP vocoders
- Add support for non-pcm VOIP vocoders
- non-pcm vocoders use AUDIO_SOURCE_VOICE_COMMUNICATION
as inputSource. Add check to verify inputSource and
then configure framecount accordingly
Change-Id: Ia38da4f6ba0ee40c794d3c97325327cdb7dcb32a
CRs-Fixed: 467850
frameworks/av: Add metadata mode changes to LPAPlayer
-Seek to EOS was causing playback to hang for 3 seconds before
switching to the next clip.
-This is because the lpa driver works on period size. Partial
buffers are not handled.
-Add support for metadata mode changes to LPAPlayer to support
partial frames.
CRs-Fixed: 458904
Change-Id: I8673756b54ae7bca18855d326c85ae1064652514
libstagefright: Add support for WMA in ACodec
- WMA support is not there in ACodec
- In the case of wma format, since not getting the complete information of
wma version so instead of allocating the component in onAllocateComponent
function it will create in onConfigureCompoenent function.
bitspersample is find as "bsps" from AMessage while configuring the
WMA10PRO and WMALOSSLESS format
CRs-Fixed: 453951
Change-Id: I98baa701dbf8a5c012f4be5e83831c0be2111dcc
libstagefright: Flush the pending buffers when EOS is received
For the use case where the first frame in the buffer is EOS, decode
the aac config frame buffer to update the sample rate and channel
mode and flush out the buffer.
Change-Id: I0354802cdbf61ac1ba0fecbbdf616705806b0f4a
CRs-Fixed: 459334
audio: Fix The Linux Foundation copyright
- Fix copyright format based on The Linux
Foundation copyright template
Change-Id: I100a5c86302d1a1a3d79543d95e242734daae746
media, audioflinger: check for divide by zero possibilities and err
When output stream is not available to audioflinger due to any reason
, sampleRate and frameCount have zero values when trying to create
new Audiotrack. This might result in divide by 0 situation.
Change-Id: Ic13cb51facb8497e68ab596abb027b44f496b907
CRs-Fixed: 478480
framewroks/av:Fix ANR at the end of video recording
- While doing video recording, when the recording
ends ANR observed while doing stress test for
many hours
- When the recording is stopped, audio HAL receives error
from driver and audio HAL propagates this error to
AudioFlinger. But AudioFlinger is not sending error
status to audio source to stop recording. Because of
this audiorecord thread keeps on waiting for buffers
which is resulting in ANR.
- To avoid indefinite wait, a timeout of 1 sec is set for buffer
in audioSource and after timeout, -ETIMEDOUT is returned
to recorder thread.
CRs-Fixed: 479968
Change-Id: I91aba6922086e711992d9d991dea9c35d33eaee9
audioflinger: Integrate SRS TruMedia
Change-Id: If61ae91556120ddd5f5ebcc6dbbfe6583c7df67d
audioflinger: Fix apply SRS effects if tones diabled in tunnel mode
For the use case of SRS post processing in Tunnel mode, the API's
of SRS are called only from write. With the huge buffering for
tunnel mode, once EOS is received there would not be further write.
With system tone enabled, the SRS API's are called during the
check for Parameters change through normal mixer thread.
With system tones disabled, SRS will not be applied after EOS as
no write and mixer thread would not be active.
Fix the issue by adding the Effects Thread for SRS in Tunnel mode.
Fix the compilation issue with ALOGV messages enabled
Change-Id: Ic7e62894840f786119dfe8ae471c5d24812917d7
audioflinger: Enhance LPA-effect logic to handle rapid config.
-Issue:Rapid Config events cause pops/glitches, raw data
playback.
-Rootcause1:Raw data leakage to DSP: applyEffectsOn() applies
effects chunk by chunk in a loop, if effects change during
this time the loop exits and this results in creation of
a buffer in which part of it is effects processed and rest
raw, this causes raw data to leak to DSP.
-RootCause2:Effectsthread directly works on the DSP buffers,
while DSP is rendering from there, so that effect application
is instantaneous and for this it gives the DSP buffers as
output to effects chain, this means that all the effects in
the chain update the DSP buffers one after the other, this
can create unpredictable rendering patterns.
RootCause1 and 2 combined seem to fragment memory with
parts of it with effects and parts with raw data etc.
-Fix1:Dont update DSP mem unless the effects are applied
completely on a buffer.
-Fix2:Effectschain will work on a temp scrath buffer
instead of DSP mem and when effects are applied
completely on this scrath buffer, memcpy this to DSP mem
with this DSP mem is updated in one shot.
-Remove repetetive logs which clutter the logcat if
msgs are enabled in audioflinger.
Change-Id: I9051e7b8531aa5c8cb3dcfafe0be3136a2cf0f9d
CRs-Fixed: 463880
frameworks/av: Update framecount and buffersize values
-framecount should be calculated based on mMaxBufferSize
returned from HAL
-update the buffersize with the value returned from HAL
CRs-Fixed: 482744
Change-Id: I90dd9c3ebbbc8a9f1f2f92c5347ae9cb01719e13
audioflinger: Fix the LPA-AudioEffects dead lock issue.
- Issue:Deadlock occurs when the LPA clips are subjected to
rapid next from BT device and simultaneously on/off the
audio effects.
- Rootcause:some times flinger thread processing
LPAPlayer/directtrack next deadlocks with the thread
working on effect configuration as both of them
contend for the audioflinger::mlock and effectmodule::mlock.
- Fix1:AudioFlinger::deleteEffectSession() not to acquire
audioflinger:mLock instead take the mLPAEffectChain.mlock.
- Fix2:ThreadBase::effectConfigChanged() not to acquire
audioflinger::mlock.
Change-Id: I056c8297802f81644fa1371836db42bdbd3825fd
CRs-Fixed: 477511
libstagefright: Add support for High Frame Rate Encoding
- Based on kkeyhfr key value from meta data, add support in OMXCodec and
MPEG4Writer for HFR mode
- Assume normal mode recording if kKeyHfr is absent
- Increase bit rate for high frame rate (HFR) recording feature to reflect
the corresponding increase in frame rate
Change-Id: I0a69f8d9322a768677781d08dd910dc5772c5292
libstagefright: Support some userdefine properties
- support property to disable audio
- support property to change recorder profile mode
- support b frame encoding
Change-Id: I175decec83f6027cbd7988caf680f7fec2836f83
CRs-Fixed: 443327
libstagefright: Add support for H/W AAC decoder
- Currently, only software AAC decoding is supported.
- Add support for H/W AAC decoding by including it in the
list of available decoders and use it for decoding only
if the property 'media.aaccodectype' is set to 0.
Change-Id: I4bb9df1bd10bd8ee91e63dadd6c473fc4e29813a
CRs-Fixed: 449145
libstagefright: Move checks for creating new extractor to ExtendedExtractor
- Move all the checks and creation of the extended extractor
into ExtendedExtractor.
- Restrict creation of new extractor to the following conditions
o default extractor is NULL
o default extractor says the content is video only
or has an unrecognized audio stream
o the audio stream is a amr-wb (plus).
- This change is being added to avoid unnecessary creation of
two extractors thereby improving the startup latency.
CRs-Fixed: 462087
Change-Id: Ia87eca73c4f81d37697fa85fd4f7c8cc8d406104
[StageFright] Enable 4 channel support
This patches enables 4 channel WAV audio support and fixes invalid
data size in WAV header field if it exceeds the actual source size.
This patch is needed to support WebAudio in WebKit as some of the
chrome demos use 4 channel WAV audio and bogus header information.
Change-Id: I307026107ab4e4342b1c0d7bb64761a416fb2c65
audioflinger: Fix crash on LPA shutdown
* Decrement the refcount after unlocking the mutex
Change-Id: Ic3210700e0aaf5e8df78f85f501621a455058e24
libstagefright: Accept vendor specific NV12 colorformat from component
- Accept OMX_QCOM_COLOR_FormatYUV420PackedSemiPlanar32m color format
which is NV12 + 32 aligned stride and slice.
- This is different from vanilla NV12 which is 16 aligned.
Change-Id: I6de2ec3a78215dbcc28a6006b746e3e0afe69c3c
libstagefright: various fixes for avc_utils
- skip seq_scaling_matrix_present_flag assertion if checking for
interlaced property.
- correct interlace check to outside of if-block
Change-Id: Ia5854110feb1c56ddc86b312d2ba2dbb73d37804
CRs-Fixed: 445527, 445692
libstagefright: print stats at end of playback
- prints statistics before reset at the end of playback onto
logcat
- print statistics after each pause and seek
Change-Id: I68edcc3153a04209e7382e4d3fba0bf734f3e33f
CRs-Fixed: 457926, 447109
frameworks/base : Fix to play a specific Mp4 clip due to SYNCH_LOST_ERROR.
-Unable to play a Specific Mp4 clip.
-Mp3 playback is stopped if the Decoder errors out with SYNCH_LOST_ERROR.
-Ignore the frame with SYNCH_LOST_ERROR and play silence instead.
Change-Id: I6b94a83cf89e8bc6792d8ee3804042d629aa505b
Add checks before removing an active buffer in OMXNodeInstance
With this change, OMXNodeInstance will remove a buffer from it's
active list only if OMX_FreeBuffer returns successfully.
Change-Id: I685b39ac7ba762a2fc1b64d7f6c1efd391513598
libstagefright: Add interlaced video support
- Adds call to set output buffer size on the native window
Change-Id: If4a67b3f877bef557c46bb67b29d1e7051553335
audio: fix for AMRWB param overwritten issue
- Overwrite AMRWB params with default value only
when setParameters is not invoked
CRs-Fixed: 456459
Change-Id: I3fa6b56101ca408ed5b5b82707c6dc75a9d9f17b
audio: fix encoder parameters for AMRWB format
- AMRWB encoder only accepts SampleRate 16k and channel count 1.
Always overwrite AMRWB SampleRate and channel count to default values.
- AMRWB encoder accepts BitRate from 6.6k to 23.85k, only overwrite
AMRWB BitRate to default(23.85k)if setParameters() is not invoked
Change-Id: I75a96b54ef04bc59dab9074ec112071e62fd51aa
CRs-Fixed: 460931
stagefright: Add QCOM_BSP ifdefs for interlaced video handling
Change-Id: I856ae4a97f1bf13ab18d386b3486e742a4804b2a
Camera : Changes to support camcorder profiles.
Change-Id: I9c4bf14f273839fd36d5f52db0f215873e8291a0
av: Ifdef all the things!
Change-Id: If9dd6c6442e9d2ac9e55e48369f2da85f5f951f7
Camera: Add profiles for camcorder.
Change-Id: Icdaf1fae0018de1fb04f41125cfbe34a91b5eda7
libvideoeditor: use vWidth and vHeight for buffer allocation
- video editor detects crop information from decoder, crop
width and height will override metadata width and height.
- decoder is capable of sending crop information where
crop width and height are smaller than actual resolution.
- use actual metadata width and height for calculating
buffer size.
Change-Id: Id1d77c316e3892e6d51a00418052f256629f495f
CRs-Fixed: 452511
Add ifdefs around enhanced media types
Change-Id: I64b8853660ac4fe90ddb218b237f63b635cdb47b
Diffstat (limited to 'include/media')
-rw-r--r-- | include/media/MediaPlayerInterface.h | 6 | ||||
-rwxr-xr-x[-rw-r--r--] | include/media/MediaProfiles.h | 17 | ||||
-rw-r--r-- | include/media/stagefright/AudioSource.h | 14 | ||||
-rw-r--r-- | include/media/stagefright/MediaCodecList.h | 4 | ||||
-rw-r--r-- | include/media/stagefright/MediaDefs.h | 24 | ||||
-rw-r--r-- | include/media/stagefright/OMXCodec.h | 4 | ||||
-rw-r--r-- | include/media/stagefright/QCOMXCodec.h | 2 |
7 files changed, 59 insertions, 12 deletions
diff --git a/include/media/MediaPlayerInterface.h b/include/media/MediaPlayerInterface.h index 5f9eb01..e17bbbe 100644 --- a/include/media/MediaPlayerInterface.h +++ b/include/media/MediaPlayerInterface.h @@ -1,8 +1,8 @@ /* - * Copyright (C) 2007 The Android Open Source Project * Copyright (c) 2013, The Linux Foundation. All rights reserved. - * Not a Contribution, Apache license notifications and license are retained - * for attribution purposes only. + * Not a Contribution. + * + * Copyright (C) 2007 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. diff --git a/include/media/MediaProfiles.h b/include/media/MediaProfiles.h index 0df9fd4..9ea3449 100644..100755 --- a/include/media/MediaProfiles.h +++ b/include/media/MediaProfiles.h @@ -33,12 +33,11 @@ enum camcorder_quality { CAMCORDER_QUALITY_480P = 4, CAMCORDER_QUALITY_720P = 5, CAMCORDER_QUALITY_1080P = 6, - CAMCORDER_QUALITY_QVGA = 11, - CAMCORDER_QUALITY_FWVGA = 7, - CAMCORDER_QUALITY_WVGA = 8, - CAMCORDER_QUALITY_VGA = 9, - CAMCORDER_QUALITY_WQVGA = 10, - + CAMCORDER_QUALITY_QVGA = 7, + CAMCORDER_QUALITY_FWVGA = 8, + CAMCORDER_QUALITY_WVGA = 9, + CAMCORDER_QUALITY_VGA = 10, + CAMCORDER_QUALITY_WQVGA = 11, CAMCORDER_QUALITY_LIST_END = 11, CAMCORDER_QUALITY_TIME_LAPSE_LIST_START = 1000, @@ -50,7 +49,11 @@ enum camcorder_quality { CAMCORDER_QUALITY_TIME_LAPSE_720P = 1005, CAMCORDER_QUALITY_TIME_LAPSE_1080P = 1006, CAMCORDER_QUALITY_TIME_LAPSE_QVGA = 1007, - CAMCORDER_QUALITY_TIME_LAPSE_LIST_END = 1007, + CAMCORDER_QUALITY_TIME_LAPSE_FWVGA = 1008, + CAMCORDER_QUALITY_TIME_LAPSE_WVGA = 1009, + CAMCORDER_QUALITY_TIME_LAPSE_VGA = 1010, + CAMCORDER_QUALITY_TIME_LAPSE_WQVGA = 1011, + CAMCORDER_QUALITY_TIME_LAPSE_LIST_END = 1011, }; /** diff --git a/include/media/stagefright/AudioSource.h b/include/media/stagefright/AudioSource.h index 4489254..33081cc 100644 --- a/include/media/stagefright/AudioSource.h +++ b/include/media/stagefright/AudioSource.h @@ -1,5 +1,6 @@ /* * Copyright (C) 2009 The Android Open Source Project + * Copyright (c) 2013, The Linux Foundation. All rights reserved. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -104,6 +105,19 @@ private: AudioSource(const AudioSource &); AudioSource &operator=(const AudioSource &); + +#ifdef QCOM_HARDWARE + //additions for tunnel source +public: + AudioSource( + audio_source_t inputSource, const sp<MetaData>& meta ); + +private: + audio_format_t mFormat; + String8 mMime; + int32_t mMaxBufferSize; + int64_t bufferDurationUs( ssize_t n ); +#endif }; } // namespace android diff --git a/include/media/stagefright/MediaCodecList.h b/include/media/stagefright/MediaCodecList.h index dfb845b..8f2b624 100644 --- a/include/media/stagefright/MediaCodecList.h +++ b/include/media/stagefright/MediaCodecList.h @@ -99,6 +99,10 @@ private: status_t addTypeFromAttributes(const char **attrs); void addType(const char *name); +#ifdef QCOM_HARDWARE + friend class QCUtilityClass; +#endif + DISALLOW_EVIL_CONSTRUCTORS(MediaCodecList); }; diff --git a/include/media/stagefright/MediaDefs.h b/include/media/stagefright/MediaDefs.h index f63926c..db8d89e 100644 --- a/include/media/stagefright/MediaDefs.h +++ b/include/media/stagefright/MediaDefs.h @@ -1,5 +1,6 @@ /* * Copyright (C) 2009 The Android Open Source Project + * Copyright (c) 2013, The Linux Foundation. All rights reserved. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -31,7 +32,6 @@ extern const char *MEDIA_MIMETYPE_VIDEO_RAW; extern const char *MEDIA_MIMETYPE_AUDIO_AMR_NB; extern const char *MEDIA_MIMETYPE_AUDIO_AMR_WB; -extern const char *MEDIA_MIMETYPE_AUDIO_AMR_WB_PLUS; extern const char *MEDIA_MIMETYPE_AUDIO_MPEG; // layer III extern const char *MEDIA_MIMETYPE_AUDIO_MPEG_LAYER_I; extern const char *MEDIA_MIMETYPE_AUDIO_MPEG_LAYER_II; @@ -43,6 +43,7 @@ extern const char *MEDIA_MIMETYPE_AUDIO_G711_MLAW; extern const char *MEDIA_MIMETYPE_AUDIO_RAW; extern const char *MEDIA_MIMETYPE_AUDIO_FLAC; extern const char *MEDIA_MIMETYPE_AUDIO_AAC_ADTS; +extern const char *MEDIA_MIMETYPE_AUDIO_DTS; extern const char *MEDIA_MIMETYPE_CONTAINER_MPEG4; extern const char *MEDIA_MIMETYPE_CONTAINER_WAV; @@ -57,6 +58,27 @@ extern const char *MEDIA_MIMETYPE_CONTAINER_WVM; extern const char *MEDIA_MIMETYPE_TEXT_3GPP; extern const char *MEDIA_MIMETYPE_TEXT_SUBRIP; +#ifdef QCOM_HARDWARE +extern const char *MEDIA_MIMETYPE_AUDIO_AC3; +extern const char *MEDIA_MIMETYPE_AUDIO_AMR_WB_PLUS; +extern const char *MEDIA_MIMETYPE_AUDIO_DTS; +extern const char *MEDIA_MIMETYPE_AUDIO_DTS_LBR; +extern const char *MEDIA_MIMETYPE_AUDIO_EAC3; +extern const char *MEDIA_MIMETYPE_AUDIO_EVRC; +extern const char *MEDIA_MIMETYPE_AUDIO_WMA; + +extern const char *MEDIA_MIMETYPE_CONTAINER_3G2; +extern const char *MEDIA_MIMETYPE_CONTAINER_AAC; +extern const char *MEDIA_MIMETYPE_CONTAINER_ASF; +extern const char *MEDIA_MIMETYPE_CONTAINER_MPEG2; +extern const char *MEDIA_MIMETYPE_CONTAINER_QCP; + +extern const char *MEDIA_MIMETYPE_VIDEO_DIVX; +extern const char *MEDIA_MIMETYPE_VIDEO_DIVX311; +extern const char *MEDIA_MIMETYPE_VIDEO_DIVX4; +extern const char *MEDIA_MIMETYPE_VIDEO_WMV; +#endif + } // namespace android #endif // MEDIA_DEFS_H_ diff --git a/include/media/stagefright/OMXCodec.h b/include/media/stagefright/OMXCodec.h index bdd35a4..630f5af 100644 --- a/include/media/stagefright/OMXCodec.h +++ b/include/media/stagefright/OMXCodec.h @@ -1,6 +1,6 @@ /* * Copyright (C) 2009 The Android Open Source Project - * Copyright (c) 2010 - 2012, The Linux Foundation. All rights reserved. + * Copyright (c) 2010 - 2013, The Linux Foundation. All rights reserved. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -392,7 +392,9 @@ private: #ifdef QCOM_HARDWARE status_t setWMAFormat(const sp<MetaData> &inputFormat); void setAC3Format(int32_t numChannels, int32_t sampleRate); + bool mNumBFrames; #endif + }; struct CodecCapabilities { diff --git a/include/media/stagefright/QCOMXCodec.h b/include/media/stagefright/QCOMXCodec.h index ee6ea88..333487d 100644 --- a/include/media/stagefright/QCOMXCodec.h +++ b/include/media/stagefright/QCOMXCodec.h @@ -96,6 +96,8 @@ struct QCOMXCodec { static void checkIfInterlaced(const uint8_t *ptr, const sp<MetaData> &meta); + static bool useHWAACDecoder(const char *mime); + }; } |