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;
40 intel_driver_get_param(struct intel_driver_data *intel, int param, int *value)
42 struct drm_i915_getparam gp;
47 return drmCommandWriteRead(intel->fd, DRM_I915_GETPARAM, &gp, sizeof(gp)) == 0;
50 static void intel_driver_get_revid(struct intel_driver_data *intel, int *value)
56 fp = fopen("/sys/devices/pci0000:00/0000:00:02.0/config", "r");
59 if (fread(config_data, 1, 16, fp))
60 *value = config_data[PCI_REVID];
62 *value = 2; /* assume it is at least B-steping */
65 *value = 2; /* assume it is at least B-steping */
71 extern const struct intel_device_info *i965_get_device_info(int devid);
74 intel_driver_init(VADriverContextP ctx)
76 struct intel_driver_data *intel = intel_driver_data(ctx);
77 struct drm_state * const drm_state = (struct drm_state *)ctx->drm_state;
78 int has_exec2 = 0, has_bsd = 0, has_blt = 0, has_vebox = 0;
81 g_intel_debug_option_flags = 0;
82 if ((env_str = getenv("VA_INTEL_DEBUG")))
83 g_intel_debug_option_flags = atoi(env_str);
85 if (g_intel_debug_option_flags)
86 fprintf(stderr, "g_intel_debug_option_flags:%x\n", g_intel_debug_option_flags);
89 assert(VA_CHECK_DRM_AUTH_TYPE(ctx, VA_DRM_AUTH_DRI1) ||
90 VA_CHECK_DRM_AUTH_TYPE(ctx, VA_DRM_AUTH_DRI2) ||
91 VA_CHECK_DRM_AUTH_TYPE(ctx, VA_DRM_AUTH_CUSTOM));
93 intel->fd = drm_state->fd;
94 intel->dri2Enabled = (VA_CHECK_DRM_AUTH_TYPE(ctx, VA_DRM_AUTH_DRI2) ||
95 VA_CHECK_DRM_AUTH_TYPE(ctx, VA_DRM_AUTH_CUSTOM));
97 if (!intel->dri2Enabled) {
102 pthread_mutex_init(&intel->ctxmutex, NULL);
104 intel_driver_get_param(intel, I915_PARAM_CHIPSET_ID, &intel->device_id);
105 intel->device_info = i965_get_device_info(intel->device_id);
107 if (!intel->device_info)
110 if (intel_driver_get_param(intel, I915_PARAM_HAS_EXECBUF2, &has_exec2))
111 intel->has_exec2 = has_exec2;
112 if (intel_driver_get_param(intel, I915_PARAM_HAS_BSD, &has_bsd))
113 intel->has_bsd = has_bsd;
114 if (intel_driver_get_param(intel, I915_PARAM_HAS_BLT, &has_blt))
115 intel->has_blt = has_blt;
116 if (intel_driver_get_param(intel, I915_PARAM_HAS_VEBOX, &has_vebox))
117 intel->has_vebox = !!has_vebox;
119 intel_driver_get_revid(intel, &intel->revision);
120 intel_memman_init(intel);
125 intel_driver_terminate(VADriverContextP ctx)
127 struct intel_driver_data *intel = intel_driver_data(ctx);
129 intel_memman_terminate(intel);
130 pthread_mutex_destroy(&intel->ctxmutex);