OSDN Git Service

Return false instead of assertion failure
[android-x86/hardware-intel-common-vaapi.git] / src / intel_driver.c
index 5ccdfa5..37e2fc6 100644 (file)
  *
  */
 
-#include <assert.h>
+#include "sysdeps.h"
 
-#include "va_dricommon.h"
+#include <va/va_drmcommon.h>
 
 #include "intel_batchbuffer.h"
 #include "intel_memman.h"
 #include "intel_driver.h"
+uint32_t g_intel_debug_option_flags = 0;
+
+#ifdef I915_PARAM_HAS_BSD2
+#define LOCAL_I915_PARAM_HAS_BSD2 I915_PARAM_HAS_BSD2
+#endif
+
+#ifndef LOCAL_I915_PARAM_HAS_BSD2
+#define LOCAL_I915_PARAM_HAS_BSD2   30
+#endif
+
+#ifdef I915_PARAM_HAS_HUC
+#define LOCAL_I915_PARAM_HAS_HUC I915_PARAM_HAS_HUC
+#else
+#define LOCAL_I915_PARAM_HAS_HUC 42
+#endif
+
+#ifdef I915_PARAM_EU_TOTAL
+#define LOCAL_I915_PARAM_EU_TOTAL I915_PARAM_EU_TOTAL
+#else
+#define LOCAL_I915_PARAM_EU_TOTAL 34
+#endif
 
 static Bool
 intel_driver_get_param(struct intel_driver_data *intel, int param, int *value)
 {
-   struct drm_i915_getparam gp;
+    struct drm_i915_getparam gp;
+
+    gp.param = param;
+    gp.value = value;
 
-   gp.param = param;
-   gp.value = value;
+    return drmCommandWriteRead(intel->fd, DRM_I915_GETPARAM, &gp, sizeof(gp)) == 0;
+}
+
+static void intel_driver_get_revid(struct intel_driver_data *intel, int *value)
+{
+#define PCI_REVID   8
+    FILE *fp;
+    char config_data[16];
+
+    fp = fopen("/sys/devices/pci0000:00/0000:00:02.0/config", "r");
+
+    if (fp) {
+        if (fread(config_data, 1, 16, fp))
+            *value = config_data[PCI_REVID];
+        else
+            *value = 2; /* assume it is at least  B-steping */
+        fclose(fp);
+    } else {
+        *value = 2; /* assume it is at least  B-steping */
+    }
 
-   return drmCommandWriteRead(intel->fd, DRM_I915_GETPARAM, &gp, sizeof(gp)) == 0;
+    return;
 }
 
-Bool 
+extern const struct intel_device_info *i965_get_device_info(int devid);
+
+bool
 intel_driver_init(VADriverContextP ctx)
 {
     struct intel_driver_data *intel = intel_driver_data(ctx);
-    struct dri_state *dri_state = (struct dri_state *)ctx->dri_state;
-    int has_exec2, has_bsd, has_blt;
+    struct drm_state * const drm_state = (struct drm_state *)ctx->drm_state;
+    int has_exec2 = 0, has_bsd = 0, has_blt = 0, has_vebox = 0;
+    char *env_str = NULL;
+    int ret_value = 0;
 
-    assert(dri_state);
-    assert(dri_state->driConnectedFlag == VA_DRI2 || 
-           dri_state->driConnectedFlag == VA_DRI1);
+    g_intel_debug_option_flags = 0;
+    if ((env_str = getenv("VA_INTEL_DEBUG")))
+        g_intel_debug_option_flags = atoi(env_str);
 
-    intel->fd = dri_state->fd;
-    intel->dri2Enabled = (dri_state->driConnectedFlag == VA_DRI2);
+    if (g_intel_debug_option_flags)
+        fprintf(stderr, "g_intel_debug_option_flags:%x\n", g_intel_debug_option_flags);
 
-    if (!intel->dri2Enabled) {
-        drm_sarea_t *pSAREA;
+    ASSERT_RET(drm_state, false);
+    ASSERT_RET((VA_CHECK_DRM_AUTH_TYPE(ctx, VA_DRM_AUTH_DRI1) ||
+                VA_CHECK_DRM_AUTH_TYPE(ctx, VA_DRM_AUTH_DRI2) ||
+                VA_CHECK_DRM_AUTH_TYPE(ctx, VA_DRM_AUTH_CUSTOM)),
+               false);
+
+    intel->fd = drm_state->fd;
+    intel->dri2Enabled = (VA_CHECK_DRM_AUTH_TYPE(ctx, VA_DRM_AUTH_DRI2) ||
+                          VA_CHECK_DRM_AUTH_TYPE(ctx, VA_DRM_AUTH_CUSTOM));
 
-        pSAREA = (drm_sarea_t *)dri_state->pSAREA;
-        intel->hHWContext = dri_state->hwContext;
-        intel->driHwLock = (drmLock *)(&pSAREA->lock);
-        intel->pPrivSarea = (void *)pSAREA + sizeof(drm_sarea_t);
+    if (!intel->dri2Enabled) {
+        return false;
     }
 
     intel->locked = 0;
     pthread_mutex_init(&intel->ctxmutex, NULL);
 
-    intel_driver_get_param(intel, I915_PARAM_CHIPSET_ID, &intel->device_id);
+    if (!intel_memman_init(intel))
+        return false;
+
+    intel->device_id = drm_intel_bufmgr_gem_get_devid(intel->bufmgr);
+    intel->device_info = i965_get_device_info(intel->device_id);
+
+    if (!intel->device_info)
+        return false;
+
     if (intel_driver_get_param(intel, I915_PARAM_HAS_EXECBUF2, &has_exec2))
         intel->has_exec2 = has_exec2;
     if (intel_driver_get_param(intel, I915_PARAM_HAS_BSD, &has_bsd))
         intel->has_bsd = has_bsd;
     if (intel_driver_get_param(intel, I915_PARAM_HAS_BLT, &has_blt))
         intel->has_blt = has_blt;
+    if (intel_driver_get_param(intel, I915_PARAM_HAS_VEBOX, &has_vebox))
+        intel->has_vebox = !!has_vebox;
 
-    intel_memman_init(intel);
-    return True;
-}
-
-Bool 
-intel_driver_terminate(VADriverContextP ctx)
-{
-    struct intel_driver_data *intel = intel_driver_data(ctx);
+    intel->has_bsd2 = 0;
+    if (intel_driver_get_param(intel, LOCAL_I915_PARAM_HAS_BSD2, &ret_value))
+        intel->has_bsd2 = !!ret_value;
 
-    intel_memman_terminate(intel);
-    pthread_mutex_destroy(&intel->ctxmutex);
+    intel->has_huc = 0;
+    ret_value = 0;
 
-    return True;
-}
+    if (intel_driver_get_param(intel, LOCAL_I915_PARAM_HAS_HUC, &ret_value))
+        intel->has_huc = !!ret_value;
 
-void 
-intel_lock_hardware(VADriverContextP ctx)
-{
-    struct intel_driver_data *intel = intel_driver_data(ctx);
-    char __ret = 0;
+    intel->eu_total = 0;
+    if (intel_driver_get_param(intel, LOCAL_I915_PARAM_EU_TOTAL, &ret_value)) {
+        intel->eu_total = ret_value;
+    }
 
-    PPTHREAD_MUTEX_LOCK();
+    intel->mocs_state = 0;
 
-    assert(!intel->locked);
+#define GEN9_PTE_CACHE    2
 
-    if (!intel->dri2Enabled) {
-        DRM_CAS(intel->driHwLock, 
-                intel->hHWContext,
-                (DRM_LOCK_HELD|intel->hHWContext),
-                __ret);
-
-        if (__ret) {
-            drmGetLock(intel->fd, intel->hHWContext, 0);
-        }      
-    }
+    if (IS_GEN9(intel->device_info) ||
+        IS_GEN10(intel->device_info))
+        intel->mocs_state = GEN9_PTE_CACHE;
 
-    intel->locked = 1;
+    intel_driver_get_revid(intel, &intel->revision);
+    return true;
 }
 
-void 
-intel_unlock_hardware(VADriverContextP ctx)
+void
+intel_driver_terminate(VADriverContextP ctx)
 {
     struct intel_driver_data *intel = intel_driver_data(ctx);
 
-    if (!intel->dri2Enabled) {
-        DRM_UNLOCK(intel->fd, 
-                   intel->driHwLock,
-                   intel->hHWContext);
-    }
-
-    intel->locked = 0;
-    PPTHREAD_MUTEX_UNLOCK();
+    intel_memman_terminate(intel);
+    pthread_mutex_destroy(&intel->ctxmutex);
 }