[vlc-devel] [PATCH 1/2] mediacodec/omxil: use same blacklist

Thomas Guillem thomas at gllm.fr
Fri Apr 3 17:17:40 CEST 2015


A crashing decoder via MediaCodec has a lot of chances to crash via omxil.
---
 modules/codec/omxil/android_mediacodec.c | 24 +-----------
 modules/codec/omxil/omxil.c              | 35 +----------------
 modules/codec/omxil/omxil_utils.h        |  5 +++
 modules/codec/omxil/utils.c              | 66 ++++++++++++++++++++++++++++++++
 4 files changed, 73 insertions(+), 57 deletions(-)

diff --git a/modules/codec/omxil/android_mediacodec.c b/modules/codec/omxil/android_mediacodec.c
index adf88e2..94c0113 100644
--- a/modules/codec/omxil/android_mediacodec.c
+++ b/modules/codec/omxil/android_mediacodec.c
@@ -390,28 +390,6 @@ end:
     return ret;
 }
 
-static bool codec_is_blacklisted( const char *p_name, unsigned int i_name_len )
-{
-     static const char *blacklisted_codecs[] = {
-        /* software decoders */
-        "OMX.google.",
-        /* crashes mediaserver */
-        "OMX.MTK.VIDEO.DECODER.MPEG4",
-        /* Not working or crashing (Samsung) */
-        "OMX.SEC.vp8.dec",
-        NULL,
-     };
-
-     for( const char **pp_bl_codecs = blacklisted_codecs; *pp_bl_codecs != NULL;
-          pp_bl_codecs++ )
-     {
-        if( !strncmp( p_name, *pp_bl_codecs,
-            __MIN( strlen(*pp_bl_codecs), i_name_len ) ) )
-            return true;
-     }
-     return false;
-}
-
 /*****************************************************************************
  * OpenDecoder: Create the decoder instance
  *****************************************************************************/
@@ -499,7 +477,7 @@ static int OpenDecoder(vlc_object_t *p_this)
         name_ptr = (*env)->GetStringUTFChars(env, name, NULL);
         found = false;
 
-        if (codec_is_blacklisted( name_ptr, name_len))
+        if (OMXCodec_IsBlacklisted( name_ptr, name_len))
             goto loopclean;
         for (int j = 0; j < num_types && !found; j++) {
             jobject type = (*env)->GetObjectArrayElement(env, types, j);
diff --git a/modules/codec/omxil/omxil.c b/modules/codec/omxil/omxil.c
index 16eb50e..1f6ebf4 100644
--- a/modules/codec/omxil/omxil.c
+++ b/modules/codec/omxil/omxil.c
@@ -1109,40 +1109,7 @@ static int OpenGeneric( vlc_object_t *p_this, bool b_encode )
     for(i = 0; i < p_sys->components; i++)
     {
 #ifdef __ANDROID__
-        /* ignore OpenCore software codecs */
-        if (!strncmp(p_sys->ppsz_components[i], "OMX.PV.", 7))
-            continue;
-        /* The same sw codecs, renamed in ICS (perhaps also in honeycomb) */
-        if (!strncmp(p_sys->ppsz_components[i], "OMX.google.", 11))
-            continue;
-        /* This one has been seen on HTC One V - it behaves like it works,
-         * but FillBufferDone returns buffers filled with 0 bytes. The One V
-         * has got a working OMX.qcom.video.decoder.avc instead though. */
-        if (!strncmp(p_sys->ppsz_components[i], "OMX.ARICENT.", 12))
-            continue;
-        /* Codecs with DRM, that don't output plain YUV data but only
-         * support direct rendering where the output can't be intercepted. */
-        if (strstr(p_sys->ppsz_components[i], ".secure"))
-            continue;
-        /* Use VC1 decoder for WMV3 for now */
-        if (!strcmp(p_sys->ppsz_components[i], "OMX.SEC.WMV.Decoder"))
-            continue;
-        /* This decoder does work, but has an insane latency (leading to errors
-         * about "main audio output playback way too late" and dropped frames).
-         * At least Samsung Galaxy S III (where this decoder is present) has
-         * got another one, OMX.SEC.mp3.dec, that works well and has a
-         * sensible latency. (Also, even if that one isn't found, in general,
-         * using SW codecs is usually more than fast enough for MP3.) */
-        if (!strcmp(p_sys->ppsz_components[i], "OMX.SEC.MP3.Decoder"))
-            continue;
-        /* This codec should be able to handle both VC1 and WMV3, but
-         * for VC1 it doesn't output any buffers at all (in the way we use
-         * it) and for WMV3 it outputs plain black buffers. Thus ignore
-         * it until we can make it work properly. */
-        if (!strcmp(p_sys->ppsz_components[i], "OMX.Nvidia.vc1.decode"))
-            continue;
-        /* This codec doesn't work or crashes */
-        if (!strcmp(p_sys->ppsz_components[i], "OMX.SEC.vp8.dec"))
+        if (OMXCodec_IsBlacklisted(p_sys->ppsz_components[i], strlen(p_sys->ppsz_components[i])))
             continue;
 #endif
         omx_error = InitialiseComponent(p_dec, p_sys->ppsz_components[i],
diff --git a/modules/codec/omxil/omxil_utils.h b/modules/codec/omxil/omxil_utils.h
index a1d564b..04a56bd 100644
--- a/modules/codec/omxil/omxil_utils.h
+++ b/modules/codec/omxil/omxil_utils.h
@@ -222,6 +222,11 @@ const char *ErrorToString(OMX_ERRORTYPE error);
 void PrintOmx(decoder_t *p_dec, OMX_HANDLETYPE omx_handle, OMX_U32 i_port);
 
 /*****************************************************************************
+ * Utility functions
+ *****************************************************************************/
+bool OMXCodec_IsBlacklisted( const char *p_name, unsigned int i_name_len );
+
+/*****************************************************************************
  * fourcc -> omx id mapping
  *****************************************************************************/
 int GetOmxVideoFormat( vlc_fourcc_t i_fourcc,
diff --git a/modules/codec/omxil/utils.c b/modules/codec/omxil/utils.c
index 3f9501d..6ec82cc 100644
--- a/modules/codec/omxil/utils.c
+++ b/modules/codec/omxil/utils.c
@@ -307,6 +307,72 @@ int IgnoreOmxDecoderPadding(const char *name)
 }
 
 /*****************************************************************************
+ * Utility functions
+ *****************************************************************************/
+bool OMXCodec_IsBlacklisted( const char *p_name, unsigned int i_name_len )
+{
+    static const char *blacklisted_prefix[] = {
+        /* ignore OpenCore software codecs */
+        "OMX.PV.",
+        /* The same sw codecs, renamed in ICS (perhaps also in honeycomb) */
+        "OMX.google.",
+        /* This one has been seen on HTC One V - it behaves like it works,
+         * but FillBufferDone returns buffers filled with 0 bytes. The One V
+         * has got a working OMX.qcom.video.decoder.avc instead though. */
+        "OMX.ARICENT.",
+        /* Use VC1 decoder for WMV3 for now */
+        "OMX.SEC.WMV.Decoder",
+        /* This decoder does work, but has an insane latency (leading to errors
+         * about "main audio output playback way too late" and dropped frames).
+         * At least Samsung Galaxy S III (where this decoder is present) has
+         * got another one, OMX.SEC.mp3.dec, that works well and has a
+         * sensible latency. (Also, even if that one isn't found, in general,
+         * using SW codecs is usually more than fast enough for MP3.) */
+        "OMX.SEC.MP3.Decoder",
+        /* This codec should be able to handle both VC1 and WMV3, but
+         * for VC1 it doesn't output any buffers at all (in the way we use
+         * it) and for WMV3 it outputs plain black buffers. Thus ignore
+         * it until we can make it work properly. */
+        "OMX.Nvidia.vc1.decode",
+        /* crashes mediaserver */
+        "OMX.MTK.VIDEO.DECODER.MPEG4",
+        /* Not working or crashing (Samsung) */
+        "OMX.SEC.vp8.dec",
+        NULL
+    };
+
+    static const char *blacklisted_suffix[] = {
+        /* Codecs with DRM, that don't output plain YUV data but only
+         * support direct rendering where the output can't be intercepted. */
+        ".secure",
+        NULL
+    };
+
+    /* p_name is not '\0' terminated */
+
+    for( const char **pp_bl_prefix = blacklisted_prefix; *pp_bl_prefix != NULL;
+          pp_bl_prefix++ )
+    {
+        if( !strncmp( p_name, *pp_bl_prefix,
+           __MIN( strlen(*pp_bl_prefix), i_name_len ) ) )
+           return true;
+    }
+
+    for( const char **pp_bl_suffix = blacklisted_suffix; *pp_bl_suffix != NULL;
+         pp_bl_suffix++ )
+    {
+       size_t i_suffix_len = strlen( *pp_bl_suffix );
+
+       if( i_name_len > i_suffix_len
+        && !strncmp( p_name + i_name_len - i_suffix_len, *pp_bl_suffix,
+                     i_suffix_len ) )
+           return true;
+    }
+
+    return false;
+}
+
+/*****************************************************************************
  * Logging utility functions
  *****************************************************************************/
 const char *StateToString(OMX_STATETYPE state)
-- 
2.1.3




More information about the vlc-devel mailing list