[Android] [PATCH 1/4] HWDecoderUtil: use a DecoderBySOC per key/value

Thomas Guillem thomas at gllm.fr
Tue Mar 31 17:24:25 CEST 2015


---
 libvlc/src/org/videolan/libvlc/HWDecoderUtil.java | 66 +++++++++++------------
 1 file changed, 30 insertions(+), 36 deletions(-)

diff --git a/libvlc/src/org/videolan/libvlc/HWDecoderUtil.java b/libvlc/src/org/videolan/libvlc/HWDecoderUtil.java
index 7d48899..58ffd25 100644
--- a/libvlc/src/org/videolan/libvlc/HWDecoderUtil.java
+++ b/libvlc/src/org/videolan/libvlc/HWDecoderUtil.java
@@ -32,14 +32,15 @@ public class HWDecoderUtil {
         UNKNOWN, NONE, OMX, MEDIACODEC, ALL
     }
 
+
     private static class DecoderBySOC {
         public final String key;
+        public final String value;
         public final Decoder dec;
-        public final String[] list;
-        public DecoderBySOC(String key, Decoder dec, String[] list) {
+        public DecoderBySOC(String key, String value, Decoder dec) {
             this.key = key;
+            this.value = value;
             this.dec = dec;
-            this.list = list;
         }
     }
 
@@ -48,42 +49,36 @@ public class HWDecoderUtil {
          *  Put first devices you want to blacklist
          *  because theses devices can match the next rules.
          */
-        new DecoderBySOC ("ro.product.brand", Decoder.NONE, new  String[] {
-                "SEMC",             // Xperia S
-        }),
-        new DecoderBySOC ("ro.board.platform", Decoder.NONE, new  String[] {
-                "msm7627",          // QCOM S1
-        }),
+        new DecoderBySOC("ro.product.brand", "SEMC", Decoder.NONE), // Xperia S
+        new DecoderBySOC("ro.board.platform", "msm7627", Decoder.NONE), // QCOM S1
+
         /*
          * Devices working on OMX
          */
-        new DecoderBySOC ("ro.board.platform", Decoder.OMX, new  String[] {
-                "omap3",            // Omap 3
-                "rockchip", "rk29", // Rockchip RK29
-                "msm7630",          // QCOM S2
-                "s5pc",             // Exynos 3
-                "montblanc",        // Montblanc
-                "exdroid",          // Allwinner A31
-        }),
-        new DecoderBySOC ("ro.hardware", Decoder.OMX, new  String[] {
-                "sun6i",            // Allwinner A31
-        }),
+        new DecoderBySOC("ro.board.platform", "omap3", Decoder.OMX), // Omap 3
+        new DecoderBySOC("ro.board.platform", "rockchip", Decoder.OMX), // Rockchip RK29
+        new DecoderBySOC("ro.board.platform", "rk29", Decoder.OMX), // Rockchip RK29
+        new DecoderBySOC("ro.board.platform", "msm7630", Decoder.OMX), // QCOM S2
+        new DecoderBySOC("ro.board.platform", "s5pc", Decoder.OMX), // Exynos 3
+        new DecoderBySOC("ro.board.platform",  "montblanc", Decoder.OMX), // Montblanc
+        new DecoderBySOC("ro.board.platform", "exdroid", Decoder.OMX), // Allwinner A31
+        new DecoderBySOC("ro.board.platform", "sun6i", Decoder.OMX), // Allwinner A31
+
         /*
          * Devices working on Mediacodec and OMX
          */
-        new DecoderBySOC ("ro.board.platform", Decoder.ALL, new  String[] {
-                "omap4",            // Omap 4
-                "tegra",            // Tegra 2 & 3
-                "tegra3",           // Tegra 3
-                "msm8660",          // QCOM S3
-                "exynos4",          // Exynos 4 (Samsung Galaxy S2/S3)
-                "exynos5",          // Exynos 5 (Samsung Galaxy S4)
-                "rk30", "rk31",     // Rockchip RK3*
-                "mv88de3100",       // Marvell ARMADA 1500
-        }),
-        new DecoderBySOC ("ro.hardware", Decoder.ALL, new  String[] {
-                "mt65", "mt83",     // MTK
-        }),
+        new DecoderBySOC("ro.board.platform", "omap4", Decoder.ALL), // Omap 4
+        new DecoderBySOC("ro.board.platform", "tegra", Decoder.ALL), // Tegra 2 & 3
+        new DecoderBySOC("ro.board.platform", "tegra3", Decoder.ALL), // Tegra 3
+        new DecoderBySOC("ro.board.platform", "msm8660", Decoder.ALL), // QCOM S3
+        new DecoderBySOC("ro.board.platform", "exynos4", Decoder.ALL), // Exynos 4 (Samsung Galaxy S2/S3)
+        new DecoderBySOC("ro.board.platform", "exynos5", Decoder.ALL), // Exynos 5 (Samsung Galaxy S4)
+        new DecoderBySOC("ro.board.platform", "rk30", Decoder.ALL), // Rockchip RK30
+        new DecoderBySOC("ro.board.platform", "rk31", Decoder.ALL), // Rockchip RK31
+        new DecoderBySOC("ro.board.platform", "mv88de3100", Decoder.ALL), // Marvell ARMADA 1500
+
+        new DecoderBySOC("ro.hardware", "mt65", Decoder.ALL), //MTK
+        new DecoderBySOC("ro.hardware", "mt83", Decoder.ALL), //MTK
     };
 
     private static final HashMap<String, String> sSystemPropertyMap = new HashMap<String, String>();
@@ -108,9 +103,8 @@ public class HWDecoderUtil {
                     sSystemPropertyMap.put(decBySOC.key, prop);
                 }
                 if (prop != null) {
-                    for (String decProp: decBySOC.list)
-                        if (prop.contains(decProp))
-                            return decBySOC.dec;
+                    if (prop.contains(decBySOC.value))
+                        return decBySOC.dec;
                 }
             }
         }
-- 
2.1.3



More information about the Android mailing list