summaryrefslogtreecommitdiffstats
path: root/libvideoeditor/vss
diff options
context:
space:
mode:
authorRajneesh Chowdury <rajneeshc@google.com>2011-09-14 11:08:05 -0700
committerRajneesh Chowdury <rajneeshc@google.com>2011-09-14 11:08:05 -0700
commit95651ebc7fbb2efba3f407f4825b7805874bbdf2 (patch)
treede9f000280256a97edb394075a7181cb2de581db /libvideoeditor/vss
parent816cd5ae8896f4965b2f1a5ea72d59dcac7257cb (diff)
downloadframeworks_av-95651ebc7fbb2efba3f407f4825b7805874bbdf2.zip
frameworks_av-95651ebc7fbb2efba3f407f4825b7805874bbdf2.tar.gz
frameworks_av-95651ebc7fbb2efba3f407f4825b7805874bbdf2.tar.bz2
Fix for 5247764 profile and level settings are not always correctly set
Correct video bitrate value is set from 3gpReader node. Also, bitrate is limited to max supported by encoder as per profile and level. This patch also fixes bug 5309520 [Prime] Native crash while running CTS test testExportEffectOverlay. Change-Id: Icd649c02465e88553b6e69ea8bcd01baf66ded9e
Diffstat (limited to 'libvideoeditor/vss')
-rwxr-xr-xlibvideoeditor/vss/mcs/src/Android.mk3
-rwxr-xr-xlibvideoeditor/vss/mcs/src/M4MCS_API.c301
-rwxr-xr-xlibvideoeditor/vss/stagefrightshells/src/VideoEditor3gpReader.cpp24
3 files changed, 316 insertions, 12 deletions
diff --git a/libvideoeditor/vss/mcs/src/Android.mk b/libvideoeditor/vss/mcs/src/Android.mk
index 2e30edb..cef7217 100755
--- a/libvideoeditor/vss/mcs/src/Android.mk
+++ b/libvideoeditor/vss/mcs/src/Android.mk
@@ -42,7 +42,8 @@ LOCAL_C_INCLUDES += \
$(TOP)/frameworks/media/libvideoeditor/osal/inc \
$(TOP)/frameworks/media/libvideoeditor/vss/mcs/inc \
$(TOP)/frameworks/media/libvideoeditor/vss/common/inc \
- $(TOP)/frameworks/media/libvideoeditor/vss/stagefrightshells/inc
+ $(TOP)/frameworks/media/libvideoeditor/vss/stagefrightshells/inc \
+ $(TOP)/frameworks/base/include/media/stagefright/openmax
LOCAL_SHARED_LIBRARIES += libdl
diff --git a/libvideoeditor/vss/mcs/src/M4MCS_API.c b/libvideoeditor/vss/mcs/src/M4MCS_API.c
index 6eb60a0..b48dfe7 100755
--- a/libvideoeditor/vss/mcs/src/M4MCS_API.c
+++ b/libvideoeditor/vss/mcs/src/M4MCS_API.c
@@ -71,6 +71,7 @@ FILE *file_pcm_encoder = NULL;
#endif /* M4VSS_ENABLE_EXTERNAL_DECODERS */
#include "M4AIR_API.h"
+#include "OMX_Video.h"
/* Version */
#define M4MCS_VERSION_MAJOR 3
@@ -122,6 +123,15 @@ static M4OSA_ERR M4MCS_intReallocTemporaryAU(
static M4OSA_ERR M4MCS_intCheckAndGetCodecProperties(
M4MCS_InternalContext *pC);
+static M4OSA_ERR M4MCS_intLimitBitratePerCodecProfileLevel(
+ M4ENCODER_AdvancedParams* EncParams);
+static M4OSA_Int32 M4MCS_intLimitBitrateForH263Enc(M4OSA_Int32 profile,
+ M4OSA_Int32 level, M4OSA_Int32 bitrate);
+static M4OSA_Int32 M4MCS_intLimitBitrateForMpeg4Enc(M4OSA_Int32 profile,
+ M4OSA_Int32 level, M4OSA_Int32 bitrate);
+static M4OSA_Int32 M4MCS_intLimitBitrateForH264Enc(M4OSA_Int32 profile,
+ M4OSA_Int32 level, M4OSA_Int32 bitrate);
+
/**
**********************************************************************
* External function used only by VideoEditor and that does not appear
@@ -5845,6 +5855,17 @@ static M4OSA_ERR M4MCS_intPrepareVideoEncoder( M4MCS_InternalContext *pC )
}
/**
+ * Limit the video bitrate according to encoder profile
+ * and level */
+ err = M4MCS_intLimitBitratePerCodecProfileLevel(&EncParams);
+ if (M4NO_ERROR != err) {
+ M4OSA_TRACE1_1(
+ "M4MCS_intPrepareVideoEncoder: limit bitrate returned err \
+ 0x%x", err);
+ return err;
+ }
+
+ /**
* Create video encoder */
err = pC->pVideoEncoderGlobalFcts->pFctInit(&pC->pViEncCtxt,
pC->pWriterDataFcts, \
@@ -10642,3 +10663,283 @@ M4OSA_ERR M4MCS_intCheckAndGetCodecProperties(
return err;
}
+
+M4OSA_ERR M4MCS_intLimitBitratePerCodecProfileLevel(
+ M4ENCODER_AdvancedParams* EncParams) {
+
+ M4OSA_ERR err = M4NO_ERROR;
+
+ switch (EncParams->Format) {
+ case M4ENCODER_kH263:
+ EncParams->Bitrate = M4MCS_intLimitBitrateForH263Enc(
+ EncParams->videoProfile,
+ EncParams->videoLevel, EncParams->Bitrate);
+ break;
+
+ case M4ENCODER_kMPEG4:
+ EncParams->Bitrate = M4MCS_intLimitBitrateForMpeg4Enc(
+ EncParams->videoProfile,
+ EncParams->videoLevel, EncParams->Bitrate);
+ break;
+
+ case M4ENCODER_kH264:
+ EncParams->Bitrate = M4MCS_intLimitBitrateForH264Enc(
+ EncParams->videoProfile,
+ EncParams->videoLevel, EncParams->Bitrate);
+ break;
+
+ default:
+ M4OSA_TRACE1_1("M4MCS_intLimitBitratePerCodecProfileLevel: \
+ Wrong enc format %d", EncParams->Format);
+ err = M4ERR_PARAMETER;
+ break;
+ }
+
+ return err;
+
+}
+
+M4OSA_Int32 M4MCS_intLimitBitrateForH264Enc(M4OSA_Int32 profile,
+ M4OSA_Int32 level, M4OSA_Int32 bitrate) {
+
+ M4OSA_Int32 vidBitrate = 0;
+
+ switch (profile) {
+ case OMX_VIDEO_AVCProfileBaseline:
+ case OMX_VIDEO_AVCProfileMain:
+
+ switch (level) {
+
+ case OMX_VIDEO_AVCLevel1:
+ vidBitrate = (bitrate > 64000) ? 64000 : bitrate;
+ break;
+
+ case OMX_VIDEO_AVCLevel1b:
+ vidBitrate = (bitrate > 128000) ? 128000 : bitrate;
+ break;
+
+ case OMX_VIDEO_AVCLevel11:
+ vidBitrate = (bitrate > 192000) ? 192000 : bitrate;
+ break;
+
+ case OMX_VIDEO_AVCLevel12:
+ vidBitrate = (bitrate > 384000) ? 384000 : bitrate;
+ break;
+
+ case OMX_VIDEO_AVCLevel13:
+ vidBitrate = (bitrate > 768000) ? 768000 : bitrate;
+ break;
+
+ case OMX_VIDEO_AVCLevel2:
+ vidBitrate = (bitrate > 2000000) ? 2000000 : bitrate;
+ break;
+
+ case OMX_VIDEO_AVCLevel21:
+ vidBitrate = (bitrate > 4000000) ? 4000000 : bitrate;
+ break;
+
+ case OMX_VIDEO_AVCLevel22:
+ vidBitrate = (bitrate > 4000000) ? 4000000 : bitrate;
+ break;
+
+ case OMX_VIDEO_AVCLevel3:
+ vidBitrate = (bitrate > 10000000) ? 10000000 : bitrate;
+ break;
+
+ case OMX_VIDEO_AVCLevel31:
+ vidBitrate = (bitrate > 14000000) ? 14000000 : bitrate;
+ break;
+
+ case OMX_VIDEO_AVCLevel32:
+ vidBitrate = (bitrate > 20000000) ? 20000000 : bitrate;
+ break;
+
+ case OMX_VIDEO_AVCLevel4:
+ vidBitrate = (bitrate > 20000000) ? 20000000 : bitrate;
+ break;
+
+ case OMX_VIDEO_AVCLevel41:
+ vidBitrate = (bitrate > 50000000) ? 50000000 : bitrate;
+ break;
+
+ case OMX_VIDEO_AVCLevel42:
+ vidBitrate = (bitrate > 50000000) ? 50000000 : bitrate;
+ break;
+
+ case OMX_VIDEO_AVCLevel5:
+ vidBitrate = (bitrate > 135000000) ? 135000000 : bitrate;
+ break;
+
+ case OMX_VIDEO_AVCLevel51:
+ vidBitrate = (bitrate > 240000000) ? 240000000 : bitrate;
+ break;
+
+ default:
+ vidBitrate = bitrate;
+ break;
+ }
+ break;
+
+ case OMX_VIDEO_AVCProfileHigh:
+ switch (level) {
+ case OMX_VIDEO_AVCLevel1:
+ vidBitrate = (bitrate > 80000) ? 80000 : bitrate;
+ break;
+
+ case OMX_VIDEO_AVCLevel1b:
+ vidBitrate = (bitrate > 160000) ? 160000 : bitrate;
+ break;
+
+ case OMX_VIDEO_AVCLevel11:
+ vidBitrate = (bitrate > 240000) ? 240000 : bitrate;
+ break;
+
+ case OMX_VIDEO_AVCLevel12:
+ vidBitrate = (bitrate > 480000) ? 480000 : bitrate;
+ break;
+
+ case OMX_VIDEO_AVCLevel13:
+ vidBitrate = (bitrate > 960000) ? 960000 : bitrate;
+ break;
+
+ case OMX_VIDEO_AVCLevel2:
+ vidBitrate = (bitrate > 2500000) ? 2500000 : bitrate;
+ break;
+
+ case OMX_VIDEO_AVCLevel21:
+ vidBitrate = (bitrate > 5000000) ? 5000000 : bitrate;
+ break;
+
+ case OMX_VIDEO_AVCLevel22:
+ vidBitrate = (bitrate > 5000000) ? 5000000 : bitrate;
+ break;
+
+ case OMX_VIDEO_AVCLevel3:
+ vidBitrate = (bitrate > 12500000) ? 12500000 : bitrate;
+ break;
+
+ case OMX_VIDEO_AVCLevel31:
+ vidBitrate = (bitrate > 17500000) ? 17500000 : bitrate;
+ break;
+
+ case OMX_VIDEO_AVCLevel32:
+ vidBitrate = (bitrate > 25000000) ? 25000000 : bitrate;
+ break;
+
+ case OMX_VIDEO_AVCLevel4:
+ vidBitrate = (bitrate > 25000000) ? 25000000 : bitrate;
+ break;
+
+ case OMX_VIDEO_AVCLevel41:
+ vidBitrate = (bitrate > 62500000) ? 62500000 : bitrate;
+ break;
+
+ case OMX_VIDEO_AVCLevel42:
+ vidBitrate = (bitrate > 62500000) ? 62500000 : bitrate;
+ break;
+
+ case OMX_VIDEO_AVCLevel5:
+ vidBitrate = (bitrate > 168750000) ? 168750000 : bitrate;
+ break;
+
+ case OMX_VIDEO_AVCLevel51:
+ vidBitrate = (bitrate > 300000000) ? 300000000 : bitrate;
+ break;
+
+ default:
+ vidBitrate = bitrate;
+ break;
+ }
+ break;
+
+ default:
+ // We do not handle any other AVC profile for now.
+ // Return input bitrate
+ vidBitrate = bitrate;
+ break;
+ }
+
+ return vidBitrate;
+}
+
+M4OSA_Int32 M4MCS_intLimitBitrateForMpeg4Enc(M4OSA_Int32 profile,
+ M4OSA_Int32 level, M4OSA_Int32 bitrate) {
+
+ M4OSA_Int32 vidBitrate = 0;
+
+ switch (profile) {
+ case OMX_VIDEO_MPEG4ProfileSimple:
+ switch (level) {
+
+ case OMX_VIDEO_MPEG4Level0:
+ vidBitrate = (bitrate > 64000) ? 64000 : bitrate;
+ break;
+
+ case OMX_VIDEO_MPEG4Level0b:
+ vidBitrate = (bitrate > 128000) ? 128000 : bitrate;
+ break;
+
+ case OMX_VIDEO_MPEG4Level1:
+ vidBitrate = (bitrate > 64000) ? 64000 : bitrate;
+ break;
+
+ case OMX_VIDEO_MPEG4Level2:
+ vidBitrate = (bitrate > 128000) ? 128000 : bitrate;
+ break;
+
+ case OMX_VIDEO_MPEG4Level3:
+ vidBitrate = (bitrate > 384000) ? 384000 : bitrate;
+ break;
+
+ default:
+ vidBitrate = bitrate;
+ break;
+ }
+ break;
+
+ default:
+ // We do not handle any other MPEG4 profile for now.
+ // Return input bitrate
+ vidBitrate = bitrate;
+ break;
+ }
+
+ return vidBitrate;
+}
+
+M4OSA_Int32 M4MCS_intLimitBitrateForH263Enc(M4OSA_Int32 profile,
+ M4OSA_Int32 level, M4OSA_Int32 bitrate) {
+
+ M4OSA_Int32 vidBitrate = 0;
+
+ switch (profile) {
+ case OMX_VIDEO_H263ProfileBaseline:
+ switch (level) {
+
+ case OMX_VIDEO_H263Level10:
+ vidBitrate = (bitrate > 64000) ? 64000 : bitrate;
+ break;
+
+ case OMX_VIDEO_H263Level20:
+ vidBitrate = (bitrate > 128000) ? 128000 : bitrate;
+ break;
+
+ case OMX_VIDEO_H263Level30:
+ vidBitrate = (bitrate > 384000) ? 384000 : bitrate;
+ break;
+
+ default:
+ vidBitrate = bitrate;
+ break;
+ }
+ break;
+
+ default:
+ // We do not handle any other H263 profile for now.
+ // Return input bitrate
+ vidBitrate = bitrate;
+ break;
+ }
+
+ return vidBitrate;
+}
diff --git a/libvideoeditor/vss/stagefrightshells/src/VideoEditor3gpReader.cpp b/libvideoeditor/vss/stagefrightshells/src/VideoEditor3gpReader.cpp
index 52478ee..3c27673 100755
--- a/libvideoeditor/vss/stagefrightshells/src/VideoEditor3gpReader.cpp
+++ b/libvideoeditor/vss/stagefrightshells/src/VideoEditor3gpReader.cpp
@@ -93,7 +93,7 @@ typedef struct {
M4SYS_AccessUnit mAudioAu;
M4SYS_AccessUnit mVideoAu;
M4OSA_Time mMaxDuration;
- int32_t mFileSize;
+ int64_t mFileSize;
M4_StreamType mStreamType;
M4OSA_UInt32 mStreamId;
int32_t mTracks;
@@ -670,11 +670,8 @@ M4OSA_ERR VideoEditor3gpReader_getOption(M4OSA_Context context,
if (pC->mMaxDuration != 0) {
M4OSA_UInt32 ui32Tmp = (M4OSA_UInt32)pC->mMaxDuration;
- *pBitrate = (M4OSA_UInt32)((M4OSA_Double)pC->mFileSize * \
- 8000.0 / (M4OSA_Double)ui32Tmp);
- LOGV("3gpReader_getOption bitrate: %d", *pBitrate);
+ *pBitrate = (M4OSA_UInt32)(pC->mFileSize * 8000.0 / pC->mMaxDuration);
}
- *pBitrate = 384000; //check
LOGV("VideoEditor3gpReader_getOption bitrate %ld", *pBitrate);
}
break;
@@ -1494,7 +1491,12 @@ M4OSA_ERR VideoEditor3gpReader_getNextStreamHandler(M4OSA_Context context,
LOGV("VideoEditor3gpReader_getNextStreamHandler m_duration %d",
(*pStreamHandler)->m_duration);
- pC->mFileSize = 0;
+ off64_t fileSize = 0;
+ pC->mDataSource->getSize(&fileSize);
+ pC->mFileSize = fileSize;
+
+ LOGV("VideoEditor3gpReader_getNextStreamHandler m_fileSize %d",
+ pC->mFileSize);
meta->findInt32(kKeyMaxInputSize, (int32_t*)&(maxAUSize));
if(maxAUSize == 0) {
@@ -1504,11 +1506,11 @@ M4OSA_ERR VideoEditor3gpReader_getNextStreamHandler(M4OSA_Context context,
LOGV("<<<<<<<<<< video: mMaxAUSize from MP4 extractor: %d",
(*pStreamHandler)->m_maxAUSize);
- if( (M4DA_StreamTypeVideoH263 == streamType) ||
- (M4DA_StreamTypeVideoMpeg4Avc == streamType)){
- ((M4_StreamHandler*)pVideoStreamHandler)->m_averageBitRate =
- 384000;
- }
+ ((M4_StreamHandler*)pVideoStreamHandler)->m_averageBitRate =
+ (pC->mFileSize * 8000)/pC->mMaxDuration;
+ LOGV("VideoEditor3gpReader_getNextStreamHandler m_averageBitrate %d",
+ ((M4_StreamHandler*)pVideoStreamHandler)->m_averageBitRate);
+
meta->findInt32(kKeyFrameRate,
(int32_t*)&(avgFPS));