summaryrefslogtreecommitdiff
path: root/omx/gstomxh264enc.c
diff options
context:
space:
mode:
authorSebastian Dröge <sebastian.droege@collabora.co.uk>2013-03-11 13:49:38 +0100
committerSebastian Dröge <sebastian.droege@collabora.co.uk>2013-03-11 13:49:38 +0100
commit77f95de529700b702937b359777388dabe2447d1 (patch)
tree5f145cc8b2976a9deb39874b7e3ef438d91fa1a9 /omx/gstomxh264enc.c
parent3c13502b75a8fa64d106e28c6b964c2c0f8a0f7e (diff)
downloadgst-omx-77f95de529700b702937b359777388dabe2447d1.tar.gz
omxh264enc: If caps specify no profile/level use the component's defaults
Diffstat (limited to 'omx/gstomxh264enc.c')
-rw-r--r--omx/gstomxh264enc.c69
1 files changed, 37 insertions, 32 deletions
diff --git a/omx/gstomxh264enc.c b/omx/gstomxh264enc.c
index ad981d7..75f7897 100644
--- a/omx/gstomxh264enc.c
+++ b/omx/gstomxh264enc.c
@@ -86,8 +86,6 @@ gst_omx_h264_enc_set_format (GstOMXVideoEnc * enc, GstOMXPort * port,
GstOMXH264Enc *self = GST_OMX_H264_ENC (enc);
GstCaps *peercaps;
OMX_PARAM_PORTDEFINITIONTYPE port_def;
- OMX_VIDEO_AVCPROFILETYPE profile = OMX_VIDEO_AVCProfileBaseline;
- OMX_VIDEO_AVCLEVELTYPE level = OMX_VIDEO_AVCLevel11;
OMX_VIDEO_PARAM_PROFILELEVELTYPE param;
OMX_ERRORTYPE err;
const gchar *profile_string, *level_string;
@@ -101,6 +99,18 @@ gst_omx_h264_enc_set_format (GstOMXVideoEnc * enc, GstOMXPort * port,
if (err != OMX_ErrorNone)
return FALSE;
+ GST_OMX_INIT_STRUCT (&param);
+ param.nPortIndex = GST_OMX_VIDEO_ENC (self)->enc_out_port->index;
+
+ err =
+ gst_omx_component_get_parameter (GST_OMX_VIDEO_ENC (self)->enc,
+ OMX_IndexParamVideoProfileLevelCurrent, &param);
+ if (err != OMX_ErrorNone) {
+ GST_WARNING_OBJECT (self,
+ "Setting profile/level not supported by component");
+ return TRUE;
+ }
+
peercaps = gst_pad_peer_query_caps (GST_VIDEO_ENCODER_SRC_PAD (enc),
gst_pad_get_pad_template_caps (GST_VIDEO_ENCODER_SRC_PAD (enc)));
if (peercaps) {
@@ -116,19 +126,19 @@ gst_omx_h264_enc_set_format (GstOMXVideoEnc * enc, GstOMXPort * port,
profile_string = gst_structure_get_string (s, "profile");
if (profile_string) {
if (g_str_equal (profile_string, "baseline")) {
- profile = OMX_VIDEO_AVCProfileBaseline;
+ param.eProfile = OMX_VIDEO_AVCProfileBaseline;
} else if (g_str_equal (profile_string, "main")) {
- profile = OMX_VIDEO_AVCProfileMain;
+ param.eProfile = OMX_VIDEO_AVCProfileMain;
} else if (g_str_equal (profile_string, "extended")) {
- profile = OMX_VIDEO_AVCProfileExtended;
+ param.eProfile = OMX_VIDEO_AVCProfileExtended;
} else if (g_str_equal (profile_string, "high")) {
- profile = OMX_VIDEO_AVCProfileHigh;
+ param.eProfile = OMX_VIDEO_AVCProfileHigh;
} else if (g_str_equal (profile_string, "high-10")) {
- profile = OMX_VIDEO_AVCProfileHigh10;
+ param.eProfile = OMX_VIDEO_AVCProfileHigh10;
} else if (g_str_equal (profile_string, "high-4:2:2")) {
- profile = OMX_VIDEO_AVCProfileHigh422;
+ param.eProfile = OMX_VIDEO_AVCProfileHigh422;
} else if (g_str_equal (profile_string, "high-4:4:4")) {
- profile = OMX_VIDEO_AVCProfileHigh444;
+ param.eProfile = OMX_VIDEO_AVCProfileHigh444;
} else {
goto unsupported_profile;
}
@@ -136,37 +146,37 @@ gst_omx_h264_enc_set_format (GstOMXVideoEnc * enc, GstOMXPort * port,
level_string = gst_structure_get_string (s, "level");
if (level_string) {
if (g_str_equal (level_string, "1")) {
- level = OMX_VIDEO_AVCLevel1;
+ param.eLevel = OMX_VIDEO_AVCLevel1;
} else if (g_str_equal (level_string, "1b")) {
- level = OMX_VIDEO_AVCLevel1b;
+ param.eLevel = OMX_VIDEO_AVCLevel1b;
} else if (g_str_equal (level_string, "1.1")) {
- level = OMX_VIDEO_AVCLevel11;
+ param.eLevel = OMX_VIDEO_AVCLevel11;
} else if (g_str_equal (level_string, "1.2")) {
- level = OMX_VIDEO_AVCLevel12;
+ param.eLevel = OMX_VIDEO_AVCLevel12;
} else if (g_str_equal (level_string, "1.3")) {
- level = OMX_VIDEO_AVCLevel13;
+ param.eLevel = OMX_VIDEO_AVCLevel13;
} else if (g_str_equal (level_string, "2")) {
- level = OMX_VIDEO_AVCLevel2;
+ param.eLevel = OMX_VIDEO_AVCLevel2;
} else if (g_str_equal (level_string, "2.1")) {
- level = OMX_VIDEO_AVCLevel21;
+ param.eLevel = OMX_VIDEO_AVCLevel21;
} else if (g_str_equal (level_string, "2.2")) {
- level = OMX_VIDEO_AVCLevel22;
+ param.eLevel = OMX_VIDEO_AVCLevel22;
} else if (g_str_equal (level_string, "3")) {
- level = OMX_VIDEO_AVCLevel3;
+ param.eLevel = OMX_VIDEO_AVCLevel3;
} else if (g_str_equal (level_string, "3.1")) {
- level = OMX_VIDEO_AVCLevel31;
+ param.eLevel = OMX_VIDEO_AVCLevel31;
} else if (g_str_equal (level_string, "3.2")) {
- level = OMX_VIDEO_AVCLevel32;
+ param.eLevel = OMX_VIDEO_AVCLevel32;
} else if (g_str_equal (level_string, "4")) {
- level = OMX_VIDEO_AVCLevel4;
+ param.eLevel = OMX_VIDEO_AVCLevel4;
} else if (g_str_equal (level_string, "4.1")) {
- level = OMX_VIDEO_AVCLevel41;
+ param.eLevel = OMX_VIDEO_AVCLevel41;
} else if (g_str_equal (level_string, "4.2")) {
- level = OMX_VIDEO_AVCLevel42;
+ param.eLevel = OMX_VIDEO_AVCLevel42;
} else if (g_str_equal (level_string, "5")) {
- level = OMX_VIDEO_AVCLevel5;
+ param.eLevel = OMX_VIDEO_AVCLevel5;
} else if (g_str_equal (level_string, "5.1")) {
- level = OMX_VIDEO_AVCLevel51;
+ param.eLevel = OMX_VIDEO_AVCLevel51;
} else {
goto unsupported_level;
}
@@ -174,11 +184,6 @@ gst_omx_h264_enc_set_format (GstOMXVideoEnc * enc, GstOMXPort * port,
gst_caps_unref (peercaps);
}
- GST_OMX_INIT_STRUCT (&param);
- param.nPortIndex = GST_OMX_VIDEO_ENC (self)->enc_out_port->index;
- param.eProfile = profile;
- param.eLevel = level;
-
err =
gst_omx_component_set_parameter (GST_OMX_VIDEO_ENC (self)->enc,
OMX_IndexParamVideoProfileLevelCurrent, &param);
@@ -187,8 +192,8 @@ gst_omx_h264_enc_set_format (GstOMXVideoEnc * enc, GstOMXPort * port,
"Setting profile/level not supported by component");
} else if (err != OMX_ErrorNone) {
GST_ERROR_OBJECT (self,
- "Error setting profile %d and level %d: %s (0x%08x)", profile, level,
- gst_omx_error_to_string (err), err);
+ "Error setting profile %d and level %d: %s (0x%08x)", param.eProfile,
+ param.eLevel, gst_omx_error_to_string (err), err);
return FALSE;
}