OSDN Git Service

Add a new CFL PCI ID
[android-x86/hardware-intel-common-vaapi.git] / src / gen9_mfc.c
index 63fc4c0..8a5e090 100644 (file)
 #include "i965_encoder_api.h"
 
 extern Bool i965_encoder_vp8_pak_context_init(VADriverContextP ctx, struct intel_encoder_context *encoder_context);
+extern Bool gen10_vdenc_vp9_context_init(VADriverContextP ctx, struct intel_encoder_context *encoder_context);
 
 Bool gen9_mfc_context_init(VADriverContextP ctx, struct intel_encoder_context *encoder_context)
 {
+    struct i965_driver_data *i965 = i965_driver_data(ctx);
+
     switch (encoder_context->codec) {
     case CODEC_VP8:
         return i965_encoder_vp8_pak_context_init(ctx, encoder_context);
@@ -64,10 +67,17 @@ Bool gen9_mfc_context_init(VADriverContextP ctx, struct intel_encoder_context *e
             return gen9_avc_pak_context_init(ctx, encoder_context);
 
     case CODEC_HEVC:
-        return gen9_hevc_pak_context_init(ctx, encoder_context);
+        if (IS_GEN10(i965->intel.device_info))
+            return gen10_hevc_pak_context_init(ctx, encoder_context);
+        else
+            return gen9_hevc_pak_context_init(ctx, encoder_context);
 
     case CODEC_VP9:
-        return gen9_vp9_pak_context_init(ctx, encoder_context);
+        if (encoder_context->low_power_mode) {
+            assert(IS_GEN10(i965->intel.device_info));
+            return gen10_vdenc_vp9_context_init(ctx, encoder_context);
+        } else
+            return gen9_vp9_pak_context_init(ctx, encoder_context);
     }
 
     /* Other profile/entrypoint pairs never get here, see gen9_enc_hw_context_init() */