2 * Copyright © 2009 Intel Corporation
4 * Permission is hereby granted, free of charge, to any person obtaining a
5 * copy of this software and associated documentation files (the
6 * "Software"), to deal in the Software without restriction, including
7 * without limitation the rights to use, copy, modify, merge, publish,
8 * distribute, sub license, and/or sell copies of the Software, and to
9 * permit persons to whom the Software is furnished to do so, subject to
10 * the following conditions:
12 * The above copyright notice and this permission notice (including the
13 * next paragraph) shall be included in all copies or substantial portions
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
17 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
18 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
19 * IN NO EVENT SHALL PRECISION INSIGHT AND/OR ITS SUPPLIERS BE LIABLE FOR
20 * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
21 * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
22 * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
25 * Xiang Haihao <haihao.xiang@intel.com>
26 * Zou Nan hai <nanhai.zou@intel.com>
32 #include <va/va_drmcommon.h>
34 #include "intel_batchbuffer.h"
35 #include "intel_memman.h"
36 #include "intel_driver.h"
37 uint32_t g_intel_debug_option_flags = 0;
39 #ifdef I915_PARAM_HAS_BSD2
40 #define LOCAL_I915_PARAM_HAS_BSD2 I915_PARAM_HAS_BSD2
43 #ifndef LOCAL_I915_PARAM_HAS_BSD2
44 #define LOCAL_I915_PARAM_HAS_BSD2 30
47 #ifdef I915_PARAM_HAS_HUC
48 #define LOCAL_I915_PARAM_HAS_HUC I915_PARAM_HAS_HUC
50 #define LOCAL_I915_PARAM_HAS_HUC 42
53 #ifdef I915_PARAM_EU_TOTAL
54 #define LOCAL_I915_PARAM_EU_TOTAL I915_PARAM_EU_TOTAL
56 #define LOCAL_I915_PARAM_EU_TOTAL 34
60 intel_driver_get_param(struct intel_driver_data *intel, int param, int *value)
62 struct drm_i915_getparam gp;
67 return drmCommandWriteRead(intel->fd, DRM_I915_GETPARAM, &gp, sizeof(gp)) == 0;
70 static void intel_driver_get_revid(struct intel_driver_data *intel, int *value)
76 fp = fopen("/sys/devices/pci0000:00/0000:00:02.0/config", "r");
79 if (fread(config_data, 1, 16, fp))
80 *value = config_data[PCI_REVID];
82 *value = 2; /* assume it is at least B-steping */
85 *value = 2; /* assume it is at least B-steping */
91 extern const struct intel_device_info *i965_get_device_info(int devid);
94 intel_driver_init(VADriverContextP ctx)
96 struct intel_driver_data *intel = intel_driver_data(ctx);
97 struct drm_state * const drm_state = (struct drm_state *)ctx->drm_state;
98 int has_exec2 = 0, has_bsd = 0, has_blt = 0, has_vebox = 0;
102 g_intel_debug_option_flags = 0;
103 if ((env_str = getenv("VA_INTEL_DEBUG")))
104 g_intel_debug_option_flags = atoi(env_str);
106 if (g_intel_debug_option_flags)
107 fprintf(stderr, "g_intel_debug_option_flags:%x\n", g_intel_debug_option_flags);
110 assert(VA_CHECK_DRM_AUTH_TYPE(ctx, VA_DRM_AUTH_DRI1) ||
111 VA_CHECK_DRM_AUTH_TYPE(ctx, VA_DRM_AUTH_DRI2) ||
112 VA_CHECK_DRM_AUTH_TYPE(ctx, VA_DRM_AUTH_CUSTOM));
114 intel->fd = drm_state->fd;
115 intel->dri2Enabled = (VA_CHECK_DRM_AUTH_TYPE(ctx, VA_DRM_AUTH_DRI2) ||
116 VA_CHECK_DRM_AUTH_TYPE(ctx, VA_DRM_AUTH_CUSTOM));
118 if (!intel->dri2Enabled) {
123 pthread_mutex_init(&intel->ctxmutex, NULL);
125 intel_memman_init(intel);
126 intel->device_id = drm_intel_bufmgr_gem_get_devid(intel->bufmgr);
127 intel->device_info = i965_get_device_info(intel->device_id);
129 if (!intel->device_info)
132 if (intel_driver_get_param(intel, I915_PARAM_HAS_EXECBUF2, &has_exec2))
133 intel->has_exec2 = has_exec2;
134 if (intel_driver_get_param(intel, I915_PARAM_HAS_BSD, &has_bsd))
135 intel->has_bsd = has_bsd;
136 if (intel_driver_get_param(intel, I915_PARAM_HAS_BLT, &has_blt))
137 intel->has_blt = has_blt;
138 if (intel_driver_get_param(intel, I915_PARAM_HAS_VEBOX, &has_vebox))
139 intel->has_vebox = !!has_vebox;
142 if (intel_driver_get_param(intel, LOCAL_I915_PARAM_HAS_BSD2, &ret_value))
143 intel->has_bsd2 = !!ret_value;
148 if (intel_driver_get_param(intel, LOCAL_I915_PARAM_HAS_HUC, &ret_value))
149 intel->has_huc = !!ret_value;
152 if (intel_driver_get_param(intel, LOCAL_I915_PARAM_EU_TOTAL, &ret_value)) {
153 intel->eu_total = ret_value;
156 intel->mocs_state = 0;
158 #define GEN9_PTE_CACHE 2
160 if (IS_GEN9(intel->device_info))
161 intel->mocs_state = GEN9_PTE_CACHE;
163 intel_driver_get_revid(intel, &intel->revision);
168 intel_driver_terminate(VADriverContextP ctx)
170 struct intel_driver_data *intel = intel_driver_data(ctx);
172 intel_memman_terminate(intel);
173 pthread_mutex_destroy(&intel->ctxmutex);