summaryrefslogtreecommitdiff
path: root/src/i965_device_info.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/i965_device_info.c')
-rw-r--r--src/i965_device_info.c889
1 files changed, 0 insertions, 889 deletions
diff --git a/src/i965_device_info.c b/src/i965_device_info.c
deleted file mode 100644
index 0fc8930..0000000
--- a/src/i965_device_info.c
+++ /dev/null
@@ -1,889 +0,0 @@
-/*
- * Copyright © 2014 Intel Corporation
- *
- * Permission is hereby granted, free of charge, to any person obtaining a
- * copy of this software and associated documentation files (the
- * "Software"), to deal in the Software without restriction, including
- * without limitation the rights to use, copy, modify, merge, publish,
- * distribute, sub license, and/or sell copies of the Software, and to
- * permit persons to whom the Software is furnished to do so, subject to
- * the following conditions:
- *
- * The above copyright notice and this permission notice (including the
- * next paragraph) shall be included in all copies or substantial portions
- * of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
- * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
- * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
- * IN NO EVENT SHALL PRECISION INSIGHT AND/OR ITS SUPPLIERS BE LIABLE FOR
- * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
- * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
- * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
- *
- */
-
-#include <stdio.h>
-#include <stdlib.h>
-#include "i965_drv_video.h"
-
-#include <string.h>
-#include <strings.h>
-#include <errno.h>
-#include <cpuid.h>
-
-/* Extra set of chroma formats supported for H.264 decoding (beyond YUV 4:2:0) */
-#define EXTRA_H264_DEC_CHROMA_FORMATS \
- (VA_RT_FORMAT_YUV400)
-
-/* Extra set of chroma formats supported for JPEG decoding (beyond YUV 4:2:0) */
-#define EXTRA_JPEG_DEC_CHROMA_FORMATS \
- (VA_RT_FORMAT_YUV400 | VA_RT_FORMAT_YUV411 | VA_RT_FORMAT_YUV422 | \
- VA_RT_FORMAT_YUV444)
-
-/* Extra set of chroma formats supported for JPEG encoding (beyond YUV 4:2:0) */
-#define EXTRA_JPEG_ENC_CHROMA_FORMATS \
- (VA_RT_FORMAT_YUV400| VA_RT_FORMAT_YUV422 | VA_RT_FORMAT_YUV444 | VA_RT_FORMAT_RGB32)
-
-#define EXTRA_HEVC_DEC_CHROMA_FORMATS \
- (VA_RT_FORMAT_YUV420_10BPP)
-
-#define EXTRA_VP9_DEC_CHROMA_FORMATS \
- (VA_RT_FORMAT_YUV420_10BPP)
-
-/* Defines VA profile as a 32-bit unsigned integer mask */
-#define VA_PROFILE_MASK(PROFILE) \
- (1U << VAProfile##PROFILE)
-
-#define VP9_PROFILE_MASK(PROFILE) \
- (1U << PROFILE)
-
-extern struct hw_context *i965_proc_context_init(VADriverContextP, struct object_config *);
-extern struct hw_context *g4x_dec_hw_context_init(VADriverContextP, struct object_config *);
-extern bool genx_render_init(VADriverContextP);
-
-static struct hw_codec_info g4x_hw_codec_info = {
- .dec_hw_context_init = g4x_dec_hw_context_init,
- .enc_hw_context_init = NULL,
- .proc_hw_context_init = NULL,
- .render_init = genx_render_init,
- .post_processing_context_init = NULL,
-
- .max_width = 2048,
- .max_height = 2048,
- .min_linear_wpitch = 16,
- .min_linear_hpitch = 16,
-
- .has_mpeg2_decoding = 1,
-
- .num_filters = 0,
-};
-
-extern struct hw_context *ironlake_dec_hw_context_init(VADriverContextP, struct object_config *);
-extern void i965_post_processing_context_init(VADriverContextP, void *, struct intel_batchbuffer *);
-
-static struct hw_codec_info ilk_hw_codec_info = {
- .dec_hw_context_init = ironlake_dec_hw_context_init,
- .enc_hw_context_init = NULL,
- .proc_hw_context_init = i965_proc_context_init,
- .render_init = genx_render_init,
- .post_processing_context_init = i965_post_processing_context_init,
-
- .max_width = 2048,
- .max_height = 2048,
- .min_linear_wpitch = 16,
- .min_linear_hpitch = 16,
-
- .has_mpeg2_decoding = 1,
- .has_h264_decoding = 1,
- .has_vpp = 1,
- .has_accelerated_putimage = 1,
-
- .num_filters = 0,
-};
-
-static void gen6_hw_codec_preinit(VADriverContextP ctx, struct hw_codec_info *codec_info);
-
-extern struct hw_context *gen6_dec_hw_context_init(VADriverContextP, struct object_config *);
-extern struct hw_context *gen6_enc_hw_context_init(VADriverContextP, struct object_config *);
-static struct hw_codec_info snb_hw_codec_info = {
- .dec_hw_context_init = gen6_dec_hw_context_init,
- .enc_hw_context_init = gen6_enc_hw_context_init,
- .proc_hw_context_init = i965_proc_context_init,
- .render_init = genx_render_init,
- .post_processing_context_init = i965_post_processing_context_init,
- .preinit_hw_codec = gen6_hw_codec_preinit,
-
- .max_width = 2048,
- .max_height = 2048,
- .min_linear_wpitch = 16,
- .min_linear_hpitch = 16,
-
- .h264_mvc_dec_profiles = VA_PROFILE_MASK(H264StereoHigh),
- .h264_dec_chroma_formats = EXTRA_H264_DEC_CHROMA_FORMATS,
-
- .has_mpeg2_decoding = 1,
- .has_h264_decoding = 1,
- .has_h264_encoding = 1,
- .has_vc1_decoding = 1,
- .has_vpp = 1,
- .has_accelerated_getimage = 1,
- .has_accelerated_putimage = 1,
- .has_tiled_surface = 1,
- .has_di_motion_adptive = 1,
-
- .num_filters = 2,
- .filters = {
- { VAProcFilterNoiseReduction, I965_RING_NULL },
- { VAProcFilterDeinterlacing, I965_RING_NULL },
- },
-};
-
-static void gen7_hw_codec_preinit(VADriverContextP ctx, struct hw_codec_info *codec_info);
-
-extern struct hw_context *gen7_dec_hw_context_init(VADriverContextP, struct object_config *);
-extern struct hw_context *gen7_enc_hw_context_init(VADriverContextP, struct object_config *);
-static struct hw_codec_info ivb_hw_codec_info = {
- .dec_hw_context_init = gen7_dec_hw_context_init,
- .enc_hw_context_init = gen7_enc_hw_context_init,
- .proc_hw_context_init = i965_proc_context_init,
- .render_init = genx_render_init,
- .post_processing_context_init = i965_post_processing_context_init,
- .preinit_hw_codec = gen7_hw_codec_preinit,
-
- .max_width = 4096,
- .max_height = 4096,
- .min_linear_wpitch = 64,
- .min_linear_hpitch = 16,
-
- .h264_mvc_dec_profiles = VA_PROFILE_MASK(H264StereoHigh),
- .h264_dec_chroma_formats = EXTRA_H264_DEC_CHROMA_FORMATS,
- .jpeg_dec_chroma_formats = EXTRA_JPEG_DEC_CHROMA_FORMATS,
-
- .has_mpeg2_decoding = 1,
- .has_mpeg2_encoding = 1,
- .has_h264_decoding = 1,
- .has_h264_encoding = 1,
- .has_vc1_decoding = 1,
- .has_jpeg_decoding = 1,
- .has_vpp = 1,
- .has_accelerated_getimage = 1,
- .has_accelerated_putimage = 1,
- .has_tiled_surface = 1,
- .has_di_motion_adptive = 1,
- .has_di_motion_compensated = 1,
-
- .num_filters = 2,
- .filters = {
- { VAProcFilterNoiseReduction, I965_RING_NULL },
- { VAProcFilterDeinterlacing, I965_RING_NULL },
- },
-};
-
-static void hsw_hw_codec_preinit(VADriverContextP ctx, struct hw_codec_info *codec_info);
-
-extern struct hw_context *gen75_dec_hw_context_init(VADriverContextP, struct object_config *);
-extern struct hw_context *gen75_enc_hw_context_init(VADriverContextP, struct object_config *);
-extern struct hw_context *gen75_proc_context_init(VADriverContextP, struct object_config *);
-static struct hw_codec_info hsw_hw_codec_info = {
- .dec_hw_context_init = gen75_dec_hw_context_init,
- .enc_hw_context_init = gen75_enc_hw_context_init,
- .proc_hw_context_init = gen75_proc_context_init,
- .render_init = genx_render_init,
- .post_processing_context_init = i965_post_processing_context_init,
- .preinit_hw_codec = hsw_hw_codec_preinit,
-
- .max_width = 4096,
- .max_height = 4096,
- .min_linear_wpitch = 64,
- .min_linear_hpitch = 16,
-
- .h264_mvc_dec_profiles = (VA_PROFILE_MASK(H264StereoHigh) |
- VA_PROFILE_MASK(H264MultiviewHigh)),
- .h264_dec_chroma_formats = EXTRA_H264_DEC_CHROMA_FORMATS,
- .jpeg_dec_chroma_formats = EXTRA_JPEG_DEC_CHROMA_FORMATS,
-
- .has_mpeg2_decoding = 1,
- .has_mpeg2_encoding = 1,
- .has_h264_decoding = 1,
- .has_h264_encoding = 1,
- .has_vc1_decoding = 1,
- .has_jpeg_decoding = 1,
- .has_vpp = 1,
- .has_accelerated_getimage = 1,
- .has_accelerated_putimage = 1,
- .has_tiled_surface = 1,
- .has_di_motion_adptive = 1,
- .has_di_motion_compensated = 1,
- .has_h264_mvc_encoding = 1,
-
- .num_filters = 5,
- .filters = {
- { VAProcFilterNoiseReduction, I965_RING_VEBOX },
- { VAProcFilterDeinterlacing, I965_RING_VEBOX },
- { VAProcFilterSharpening, I965_RING_NULL },
- { VAProcFilterColorBalance, I965_RING_VEBOX},
- { VAProcFilterSkinToneEnhancement, I965_RING_VEBOX},
- },
-};
-
-extern struct hw_context *gen8_dec_hw_context_init(VADriverContextP, struct object_config *);
-extern struct hw_context *gen8_enc_hw_context_init(VADriverContextP, struct object_config *);
-extern void gen8_post_processing_context_init(VADriverContextP, void *, struct intel_batchbuffer *);
-static struct hw_codec_info bdw_hw_codec_info = {
- .dec_hw_context_init = gen8_dec_hw_context_init,
- .enc_hw_context_init = gen8_enc_hw_context_init,
- .proc_hw_context_init = gen75_proc_context_init,
- .render_init = gen8_render_init,
- .post_processing_context_init = gen8_post_processing_context_init,
-
- .max_width = 4096,
- .max_height = 4096,
- .min_linear_wpitch = 64,
- .min_linear_hpitch = 16,
-
- .h264_mvc_dec_profiles = (VA_PROFILE_MASK(H264StereoHigh) |
- VA_PROFILE_MASK(H264MultiviewHigh)),
- .h264_dec_chroma_formats = EXTRA_H264_DEC_CHROMA_FORMATS,
- .jpeg_dec_chroma_formats = EXTRA_JPEG_DEC_CHROMA_FORMATS,
-
- .has_mpeg2_decoding = 1,
- .has_mpeg2_encoding = 1,
- .has_h264_decoding = 1,
- .has_h264_encoding = 1,
- .has_vc1_decoding = 1,
- .has_jpeg_decoding = 1,
- .has_vpp = 1,
- .has_accelerated_getimage = 1,
- .has_accelerated_putimage = 1,
- .has_tiled_surface = 1,
- .has_di_motion_adptive = 1,
- .has_di_motion_compensated = 1,
- .has_vp8_decoding = 1,
- .has_h264_mvc_encoding = 1,
-
- .num_filters = 5,
- .filters = {
- { VAProcFilterNoiseReduction, I965_RING_VEBOX },
- { VAProcFilterDeinterlacing, I965_RING_VEBOX },
- { VAProcFilterSharpening, I965_RING_NULL }, /* need to rebuild the shader for BDW */
- { VAProcFilterColorBalance, I965_RING_VEBOX},
- { VAProcFilterSkinToneEnhancement, I965_RING_VEBOX},
- },
-};
-
-extern struct hw_context *gen9_dec_hw_context_init(VADriverContextP, struct object_config *);
-static struct hw_codec_info chv_hw_codec_info = {
- .dec_hw_context_init = gen9_dec_hw_context_init,
- .enc_hw_context_init = gen8_enc_hw_context_init,
- .proc_hw_context_init = gen75_proc_context_init,
- .render_init = gen8_render_init,
- .post_processing_context_init = gen8_post_processing_context_init,
-
- .max_width = 4096,
- .max_height = 4096,
- .min_linear_wpitch = 64,
- .min_linear_hpitch = 16,
-
- .h264_mvc_dec_profiles = (VA_PROFILE_MASK(H264StereoHigh) |
- VA_PROFILE_MASK(H264MultiviewHigh)),
- .h264_dec_chroma_formats = EXTRA_H264_DEC_CHROMA_FORMATS,
- .jpeg_dec_chroma_formats = EXTRA_JPEG_DEC_CHROMA_FORMATS,
- .jpeg_enc_chroma_formats = EXTRA_JPEG_ENC_CHROMA_FORMATS,
-
- .has_mpeg2_decoding = 1,
- .has_mpeg2_encoding = 1,
- .has_h264_decoding = 1,
- .has_h264_encoding = 1,
- .has_vc1_decoding = 1,
- .has_jpeg_decoding = 1,
- .has_jpeg_encoding = 1,
- .has_vpp = 1,
- .has_accelerated_getimage = 1,
- .has_accelerated_putimage = 1,
- .has_tiled_surface = 1,
- .has_di_motion_adptive = 1,
- .has_di_motion_compensated = 1,
- .has_vp8_decoding = 1,
- .has_vp8_encoding = 1,
- .has_h264_mvc_encoding = 1,
- .has_hevc_decoding = 1,
-
- .num_filters = 5,
- .filters = {
- { VAProcFilterNoiseReduction, I965_RING_VEBOX },
- { VAProcFilterDeinterlacing, I965_RING_VEBOX },
- { VAProcFilterSharpening, I965_RING_NULL }, /* need to rebuild the shader for BDW */
- { VAProcFilterColorBalance, I965_RING_VEBOX},
- { VAProcFilterSkinToneEnhancement, I965_RING_VEBOX},
- },
-};
-
-static void gen9_hw_codec_preinit(VADriverContextP ctx, struct hw_codec_info *codec_info);
-
-extern struct hw_context *gen9_enc_hw_context_init(VADriverContextP, struct object_config *);
-extern void gen9_post_processing_context_init(VADriverContextP, void *, struct intel_batchbuffer *);
-extern void gen9_max_resolution(struct i965_driver_data *, struct object_config *, int *, int *);
-static struct hw_codec_info skl_hw_codec_info = {
- .dec_hw_context_init = gen9_dec_hw_context_init,
- .enc_hw_context_init = gen9_enc_hw_context_init,
- .proc_hw_context_init = gen75_proc_context_init,
- .render_init = gen9_render_init,
- .post_processing_context_init = gen9_post_processing_context_init,
- .max_resolution = gen9_max_resolution,
- .preinit_hw_codec = gen9_hw_codec_preinit,
-
- .max_width = 4096, /* default. See max_resolution */
- .max_height = 4096, /* default. See max_resolution */
- .min_linear_wpitch = 64,
- .min_linear_hpitch = 16,
-
- .h264_mvc_dec_profiles = (VA_PROFILE_MASK(H264StereoHigh) |
- VA_PROFILE_MASK(H264MultiviewHigh)),
- .h264_dec_chroma_formats = EXTRA_H264_DEC_CHROMA_FORMATS,
- .jpeg_dec_chroma_formats = EXTRA_JPEG_DEC_CHROMA_FORMATS,
- .jpeg_enc_chroma_formats = EXTRA_JPEG_ENC_CHROMA_FORMATS,
-
- .has_mpeg2_decoding = 1,
- .has_mpeg2_encoding = 1,
- .has_h264_decoding = 1,
- .has_h264_encoding = 1,
- .has_vc1_decoding = 1,
- .has_jpeg_decoding = 1,
- .has_jpeg_encoding = 1,
- .has_vpp = 1,
- .has_accelerated_getimage = 1,
- .has_accelerated_putimage = 1,
- .has_tiled_surface = 1,
- .has_di_motion_adptive = 1,
- .has_di_motion_compensated = 1,
- .has_vp8_decoding = 1,
- .has_vp8_encoding = 1,
- .has_h264_mvc_encoding = 1,
- .has_hevc_decoding = 1,
- .has_hevc_encoding = 1,
- .has_lp_h264_encoding = 1,
-
- .lp_h264_brc_mode = VA_RC_CQP,
-
- .num_filters = 5,
- .filters = {
- { VAProcFilterNoiseReduction, I965_RING_VEBOX },
- { VAProcFilterDeinterlacing, I965_RING_VEBOX },
- { VAProcFilterSharpening, I965_RING_NULL }, /* need to rebuild the shader for BDW */
- { VAProcFilterColorBalance, I965_RING_VEBOX},
- { VAProcFilterSkinToneEnhancement, I965_RING_VEBOX},
- },
-};
-
-
-static struct hw_codec_info bxt_hw_codec_info = {
- .dec_hw_context_init = gen9_dec_hw_context_init,
- .enc_hw_context_init = gen9_enc_hw_context_init,
- .proc_hw_context_init = gen75_proc_context_init,
- .render_init = gen9_render_init,
- .post_processing_context_init = gen9_post_processing_context_init,
- .max_resolution = gen9_max_resolution,
-
- .max_width = 4096, /* default. See max_resolution */
- .max_height = 4096, /* default. See max_resolution */
- .min_linear_wpitch = 64,
- .min_linear_hpitch = 16,
-
- .h264_mvc_dec_profiles = (VA_PROFILE_MASK(H264StereoHigh) |
- VA_PROFILE_MASK(H264MultiviewHigh)),
- .vp9_dec_profiles = VP9_PROFILE_MASK(0),
-
- .h264_dec_chroma_formats = EXTRA_H264_DEC_CHROMA_FORMATS,
- .jpeg_dec_chroma_formats = EXTRA_JPEG_DEC_CHROMA_FORMATS,
- .jpeg_enc_chroma_formats = EXTRA_JPEG_ENC_CHROMA_FORMATS,
- .hevc_dec_chroma_formats = EXTRA_HEVC_DEC_CHROMA_FORMATS,
-
- .has_mpeg2_decoding = 1,
- .has_h264_decoding = 1,
- .has_h264_encoding = 1,
- .has_vc1_decoding = 1,
- .has_jpeg_decoding = 1,
- .has_jpeg_encoding = 1,
- .has_vpp = 1,
- .has_accelerated_getimage = 1,
- .has_accelerated_putimage = 1,
- .has_tiled_surface = 1,
- .has_di_motion_adptive = 1,
- .has_di_motion_compensated = 1,
- .has_vp8_decoding = 1,
- .has_vp8_encoding = 1,
- .has_h264_mvc_encoding = 1,
- .has_hevc_decoding = 1,
- .has_hevc_encoding = 1,
- .has_hevc10_decoding = 1,
- .has_vp9_decoding = 1,
- .has_vpp_p010 = 1,
- .has_lp_h264_encoding = 1,
-
- .lp_h264_brc_mode = VA_RC_CQP,
-
- .num_filters = 5,
- .filters = {
- { VAProcFilterNoiseReduction, I965_RING_VEBOX },
- { VAProcFilterDeinterlacing, I965_RING_VEBOX },
- { VAProcFilterSharpening, I965_RING_NULL },
- { VAProcFilterColorBalance, I965_RING_VEBOX},
- { VAProcFilterSkinToneEnhancement, I965_RING_VEBOX},
- },
-};
-
-static struct hw_codec_info kbl_hw_codec_info = {
- .dec_hw_context_init = gen9_dec_hw_context_init,
- .enc_hw_context_init = gen9_enc_hw_context_init,
- .proc_hw_context_init = gen75_proc_context_init,
- .render_init = gen9_render_init,
- .post_processing_context_init = gen9_post_processing_context_init,
- .max_resolution = gen9_max_resolution,
-
- .max_width = 4096, /* default. See max_resolution */
- .max_height = 4096, /* default. See max_resolution */
- .min_linear_wpitch = 64,
- .min_linear_hpitch = 16,
-
- .h264_mvc_dec_profiles = (VA_PROFILE_MASK(H264StereoHigh) |
- VA_PROFILE_MASK(H264MultiviewHigh)),
- .vp9_dec_profiles = VP9_PROFILE_MASK(0) |
- VP9_PROFILE_MASK(2),
- .vp9_enc_profiles = VP9_PROFILE_MASK(0),
-
- .h264_dec_chroma_formats = EXTRA_H264_DEC_CHROMA_FORMATS,
- .jpeg_dec_chroma_formats = EXTRA_JPEG_DEC_CHROMA_FORMATS,
- .jpeg_enc_chroma_formats = EXTRA_JPEG_ENC_CHROMA_FORMATS,
- .hevc_dec_chroma_formats = EXTRA_HEVC_DEC_CHROMA_FORMATS,
- .vp9_dec_chroma_formats = EXTRA_VP9_DEC_CHROMA_FORMATS,
-
- .has_mpeg2_decoding = 1,
- .has_mpeg2_encoding = 1,
- .has_h264_decoding = 1,
- .has_h264_encoding = 1,
- .has_vc1_decoding = 1,
- .has_jpeg_decoding = 1,
- .has_jpeg_encoding = 1,
- .has_vpp = 1,
- .has_accelerated_getimage = 1,
- .has_accelerated_putimage = 1,
- .has_tiled_surface = 1,
- .has_di_motion_adptive = 1,
- .has_di_motion_compensated = 1,
- .has_vp8_decoding = 1,
- .has_vp8_encoding = 1,
- .has_h264_mvc_encoding = 1,
- .has_hevc_decoding = 1,
- .has_hevc_encoding = 1,
- .has_hevc10_encoding = 1,
- .has_hevc10_decoding = 1,
- .has_vp9_decoding = 1,
- .has_vpp_p010 = 1,
- .has_vp9_encoding = 1,
- .has_lp_h264_encoding = 1,
-
- .lp_h264_brc_mode = VA_RC_CQP,
-
- .num_filters = 5,
- .filters = {
- { VAProcFilterNoiseReduction, I965_RING_VEBOX },
- { VAProcFilterDeinterlacing, I965_RING_VEBOX },
- { VAProcFilterSharpening, I965_RING_NULL },
- { VAProcFilterColorBalance, I965_RING_VEBOX},
- { VAProcFilterSkinToneEnhancement, I965_RING_VEBOX},
- },
-};
-
-struct hw_codec_info *
-i965_get_codec_info(int devid)
-{
- switch (devid) {
-#undef CHIPSET
-#define CHIPSET(id, family, dev, str) case id: return &family##_hw_codec_info;
-#include "i965_pciids.h"
- default:
- return NULL;
- }
-}
-
-static const struct intel_device_info g4x_device_info = {
- .gen = 4,
-
- .urb_size = 384,
- .max_wm_threads = 50, /* 10 * 5 */
-
- .is_g4x = 1,
-};
-
-static const struct intel_device_info ilk_device_info = {
- .gen = 5,
-
- .urb_size = 1024,
- .max_wm_threads = 72, /* 12 * 6 */
-};
-
-static const struct intel_device_info snb_gt1_device_info = {
- .gen = 6,
- .gt = 1,
-
- .urb_size = 1024,
- .max_wm_threads = 40,
-};
-
-static const struct intel_device_info snb_gt2_device_info = {
- .gen = 6,
- .gt = 2,
-
- .urb_size = 1024,
- .max_wm_threads = 80,
-};
-
-static const struct intel_device_info ivb_gt1_device_info = {
- .gen = 7,
- .gt = 1,
-
- .urb_size = 4096,
- .max_wm_threads = 48,
-
- .is_ivybridge = 1,
-};
-
-static const struct intel_device_info ivb_gt2_device_info = {
- .gen = 7,
- .gt = 2,
-
- .urb_size = 4096,
- .max_wm_threads = 172,
-
- .is_ivybridge = 1,
-};
-
-static const struct intel_device_info byt_device_info = {
- .gen = 7,
- .gt = 1,
-
- .urb_size = 4096,
- .max_wm_threads = 48,
-
- .is_ivybridge = 1,
- .is_baytrail = 1,
-};
-
-static const struct intel_device_info hsw_gt1_device_info = {
- .gen = 7,
- .gt = 1,
-
- .urb_size = 4096,
- .max_wm_threads = 102,
-
- .is_haswell = 1,
-};
-
-static const struct intel_device_info hsw_gt2_device_info = {
- .gen = 7,
- .gt = 2,
-
- .urb_size = 4096,
- .max_wm_threads = 204,
-
- .is_haswell = 1,
-};
-
-static const struct intel_device_info hsw_gt3_device_info = {
- .gen = 7,
- .gt = 3,
-
- .urb_size = 4096,
- .max_wm_threads = 408,
-
- .is_haswell = 1,
-};
-
-static const struct intel_device_info bdw_device_info = {
- .gen = 8,
-
- .urb_size = 4096,
- .max_wm_threads = 64, /* per PSD */
-};
-
-static const struct intel_device_info chv_device_info = {
- .gen = 8,
-
- .urb_size = 4096,
- .max_wm_threads = 64, /* per PSD */
-
- .is_cherryview = 1,
-};
-
-static const struct intel_device_info skl_device_info = {
- .gen = 9,
-
- .urb_size = 4096,
- .max_wm_threads = 64, /* per PSD */
-
- .is_skylake = 1,
-};
-
-static const struct intel_device_info bxt_device_info = {
- .gen = 9,
-
- .urb_size = 4096,
- .max_wm_threads = 64, /* per PSD */
- .is_broxton = 1,
-};
-
-static const struct intel_device_info kbl_device_info = {
- .gen = 9,
-
- .urb_size = 4096,
- .max_wm_threads = 64, /* per PSD */
-
- .is_kabylake = 1,
-};
-
-const struct intel_device_info *
-i965_get_device_info(int devid)
-{
- switch (devid) {
-#undef CHIPSET
-#define CHIPSET(id, family, dev, str) case id: return &dev##_device_info;
-#include "i965_pciids.h"
- default:
- return NULL;
- }
-}
-
-static void cpuid(unsigned int op,
- uint32_t *eax, uint32_t *ebx,
- uint32_t *ecx, uint32_t *edx)
-{
- __cpuid_count(op, 0, *eax, *ebx, *ecx, *edx);
-}
-
-/*
- * This function doesn't check the length. And the caller should
- * assure that the length of input string should be greater than 48.
- */
-static int intel_driver_detect_cpustring(char *model_id)
-{
- uint32_t *rdata;
-
- if (model_id == NULL)
- return -EINVAL;
-
- rdata = (uint32_t *)model_id;
-
- /* obtain the max supported extended CPUID info */
- cpuid(0x80000000, &rdata[0], &rdata[1], &rdata[2], &rdata[3]);
-
- /* If the max extended CPUID info is less than 0x80000004, fail */
- if (rdata[0] < 0x80000004)
- return -EINVAL;
-
- /* obtain the CPUID string */
- cpuid(0x80000002, &rdata[0], &rdata[1], &rdata[2], &rdata[3]);
- cpuid(0x80000003, &rdata[4], &rdata[5], &rdata[6], &rdata[7]);
- cpuid(0x80000004, &rdata[8], &rdata[9], &rdata[10], &rdata[11]);
-
- *(model_id + 48) = '\0';
- return 0;
-}
-
-/*
- * the hook_list for HSW.
- * It is captured by /proc/cpuinfo and the space character is stripped.
- */
-const static char *hsw_cpu_hook_list[] = {
-"Intel(R)Pentium(R)3556U",
-"Intel(R)Pentium(R)3560Y",
-"Intel(R)Pentium(R)3550M",
-"Intel(R)Celeron(R)2980U",
-"Intel(R)Celeron(R)2955U",
-"Intel(R)Celeron(R)2950M",
-};
-
-static void hsw_hw_codec_preinit(VADriverContextP ctx, struct hw_codec_info *codec_info)
-{
- char model_string[64];
- char *model_ptr, *tmp_ptr;
- int i, model_len, list_len;
- bool found;
-
- memset(model_string, 0, sizeof(model_string));
-
- /* If it can't detect cpu model_string, leave it alone */
- if (intel_driver_detect_cpustring(model_string))
- return;
-
- /* strip the cpufreq info */
- model_ptr = model_string;
- tmp_ptr = strstr(model_ptr, "@");
-
- if (tmp_ptr)
- *tmp_ptr = '\0';
-
- /* strip the space character and convert to the lower case */
- model_ptr = model_string;
- model_len = strlen(model_string);
- for (i = 0; i < model_len; i++) {
- if (model_string[i] != ' ') {
- *model_ptr = model_string[i];
- model_ptr++;
- }
- }
- *model_ptr = '\0';
-
- found = false;
- list_len = sizeof(hsw_cpu_hook_list) / sizeof(char *);
- model_len = strlen(model_string);
- for (i = 0; i < list_len; i++) {
- model_ptr = (char *)hsw_cpu_hook_list[i];
-
- if (strlen(model_ptr) != model_len)
- continue;
-
- if (strncasecmp(model_string, model_ptr, model_len) == 0) {
- found = true;
- break;
- }
- }
-
- if (found) {
- codec_info->has_h264_encoding = 0;
- codec_info->has_h264_mvc_encoding = 0;
- codec_info->has_mpeg2_encoding = 0;
- }
- return;
-}
-
-/*
- * the hook_list for Sandybride.
- * It is captured by /proc/cpuinfo and the space character is stripped.
- */
-const static char *gen6_cpu_hook_list[] = {
-"Intel(R)Celeron(R)CPU847",
-"Intel(R)Celeron(R)CPU867",
-};
-
-static void gen6_hw_codec_preinit(VADriverContextP ctx, struct hw_codec_info *codec_info)
-{
- char model_string[64];
- char *model_ptr, *tmp_ptr;
- int i, model_len, list_len;
- bool found;
-
- memset(model_string, 0, sizeof(model_string));
-
- /* If it can't detect cpu model_string, leave it alone */
- if (intel_driver_detect_cpustring(model_string))
- return;
-
- /* strip the cpufreq info */
- model_ptr = model_string;
- tmp_ptr = strstr(model_ptr, "@");
-
- if (tmp_ptr)
- *tmp_ptr = '\0';
-
- /* strip the space character and convert to the lower case */
- model_ptr = model_string;
- model_len = strlen(model_string);
- for (i = 0; i < model_len; i++) {
- if (model_string[i] != ' ') {
- *model_ptr = model_string[i];
- model_ptr++;
- }
- }
- *model_ptr = '\0';
-
- found = false;
- list_len = sizeof(gen6_cpu_hook_list) / sizeof(char *);
- model_len = strlen(model_string);
- for (i = 0; i < list_len; i++) {
- model_ptr = (char *)gen6_cpu_hook_list[i];
-
- if (strlen(model_ptr) != model_len)
- continue;
-
- if (strncasecmp(model_string, model_ptr, model_len) == 0) {
- found = true;
- break;
- }
- }
-
- if (found) {
- codec_info->has_h264_encoding = 0;
- }
- return;
-}
-
-/*
- * the hook_list for Ivybridge.
- * It is captured by /proc/cpuinfo and the space character is stripped.
- */
-const static char *gen7_cpu_hook_list[] = {
-"Intel(R)Celeron(R)CPU1007U",
-"Intel(R)Pentium(R)CPUG2130",
-};
-
-static void gen7_hw_codec_preinit(VADriverContextP ctx, struct hw_codec_info *codec_info)
-{
- char model_string[64];
- char *model_ptr, *tmp_ptr;
- int i, model_len, list_len;
- bool found;
-
- memset(model_string, 0, sizeof(model_string));
-
- /* If it can't detect cpu model_string, leave it alone */
- if (intel_driver_detect_cpustring(model_string))
- return;
-
- /* strip the cpufreq info */
- model_ptr = model_string;
- tmp_ptr = strstr(model_ptr, "@");
-
- if (tmp_ptr)
- *tmp_ptr = '\0';
-
- /* strip the space character and convert to the lower case */
- model_ptr = model_string;
- model_len = strlen(model_string);
- for (i = 0; i < model_len; i++) {
- if (model_string[i] != ' ') {
- *model_ptr = model_string[i];
- model_ptr++;
- }
- }
- *model_ptr = '\0';
-
- found = false;
- list_len = sizeof(gen7_cpu_hook_list) / sizeof(char *);
- model_len = strlen(model_string);
- for (i = 0; i < list_len; i++) {
- model_ptr = (char *)gen7_cpu_hook_list[i];
-
- if (strlen(model_ptr) != model_len)
- continue;
-
- if (strncasecmp(model_string, model_ptr, model_len) == 0) {
- found = true;
- break;
- }
- }
-
- if (found) {
- codec_info->has_h264_encoding = 0;
- codec_info->has_mpeg2_encoding = 0;
- }
- return;
-}
-
-static void gen9_hw_codec_preinit(VADriverContextP ctx, struct hw_codec_info *codec_info)
-{
- struct i965_driver_data *i965 = i965_driver_data(ctx);
-
- if (i965->intel.has_huc && codec_info->has_lp_h264_encoding)
- codec_info->lp_h264_brc_mode |= (VA_RC_CBR | VA_RC_VBR);
-}