2016-06-24 14:00:26 +01:00
/*
* Copyright © 2016 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 , sublicense ,
* 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 NONINFRINGEMENT . IN NO EVENT SHALL
* THE AUTHORS OR COPYRIGHT HOLDERS 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 .
*
*/
2022-02-10 17:45:50 +02:00
# include <drm/drm_color_mgmt.h>
2019-01-17 22:03:34 +01:00
# include <drm/drm_drv.h>
2020-02-25 15:31:31 +02:00
# include <drm/i915_pciids.h>
2019-01-17 22:03:34 +01:00
2021-11-11 12:13:02 +02:00
# include "i915_driver.h"
2016-06-24 14:00:26 +01:00
# include "i915_drv.h"
2021-07-27 14:10:37 +02:00
# include "i915_pci.h"
2022-01-27 15:43:34 -08:00
# include "i915_reg.h"
2016-06-24 14:00:26 +01:00
2019-03-27 14:23:28 +00:00
# define PLATFORM(x) .platform = (x)
2021-04-12 22:09:54 -07:00
# define GEN(x) \
2021-10-19 17:23:51 -07:00
. graphics . ver = ( x ) , \
. media . ver = ( x ) , \
2021-04-12 22:09:54 -07:00
. display . ver = ( x )
2018-02-15 08:19:28 +00:00
2019-03-05 21:29:05 +02:00
# define I845_PIPE_OFFSETS \
. pipe_offsets = { \
[ TRANSCODER_A ] = PIPE_A_OFFSET , \
} , \
. trans_offsets = { \
[ TRANSCODER_A ] = TRANSCODER_A_OFFSET , \
}
# define I9XX_PIPE_OFFSETS \
. pipe_offsets = { \
[ TRANSCODER_A ] = PIPE_A_OFFSET , \
[ TRANSCODER_B ] = PIPE_B_OFFSET , \
} , \
. trans_offsets = { \
[ TRANSCODER_A ] = TRANSCODER_A_OFFSET , \
[ TRANSCODER_B ] = TRANSCODER_B_OFFSET , \
}
# define IVB_PIPE_OFFSETS \
. pipe_offsets = { \
[ TRANSCODER_A ] = PIPE_A_OFFSET , \
[ TRANSCODER_B ] = PIPE_B_OFFSET , \
[ TRANSCODER_C ] = PIPE_C_OFFSET , \
} , \
. trans_offsets = { \
[ TRANSCODER_A ] = TRANSCODER_A_OFFSET , \
[ TRANSCODER_B ] = TRANSCODER_B_OFFSET , \
[ TRANSCODER_C ] = TRANSCODER_C_OFFSET , \
}
# define HSW_PIPE_OFFSETS \
2018-11-20 11:23:23 +02:00
. pipe_offsets = { \
[ TRANSCODER_A ] = PIPE_A_OFFSET , \
[ TRANSCODER_B ] = PIPE_B_OFFSET , \
[ TRANSCODER_C ] = PIPE_C_OFFSET , \
[ TRANSCODER_EDP ] = PIPE_EDP_OFFSET , \
} , \
. trans_offsets = { \
[ TRANSCODER_A ] = TRANSCODER_A_OFFSET , \
[ TRANSCODER_B ] = TRANSCODER_B_OFFSET , \
[ TRANSCODER_C ] = TRANSCODER_C_OFFSET , \
[ TRANSCODER_EDP ] = TRANSCODER_EDP_OFFSET , \
}
2016-06-24 14:00:26 +01:00
2019-03-05 21:29:05 +02:00
# define CHV_PIPE_OFFSETS \
2018-11-20 11:23:23 +02:00
. pipe_offsets = { \
[ TRANSCODER_A ] = PIPE_A_OFFSET , \
[ TRANSCODER_B ] = PIPE_B_OFFSET , \
[ TRANSCODER_C ] = CHV_PIPE_C_OFFSET , \
} , \
. trans_offsets = { \
[ TRANSCODER_A ] = TRANSCODER_A_OFFSET , \
[ TRANSCODER_B ] = TRANSCODER_B_OFFSET , \
[ TRANSCODER_C ] = CHV_TRANSCODER_C_OFFSET , \
}
2016-06-24 14:00:26 +01:00
2019-03-05 21:29:05 +02:00
# define I845_CURSOR_OFFSETS \
. cursor_offsets = { \
[ PIPE_A ] = CURSOR_A_OFFSET , \
}
# define I9XX_CURSOR_OFFSETS \
. cursor_offsets = { \
[ PIPE_A ] = CURSOR_A_OFFSET , \
[ PIPE_B ] = CURSOR_B_OFFSET , \
}
# define CHV_CURSOR_OFFSETS \
. cursor_offsets = { \
[ PIPE_A ] = CURSOR_A_OFFSET , \
[ PIPE_B ] = CURSOR_B_OFFSET , \
[ PIPE_C ] = CHV_CURSOR_C_OFFSET , \
}
2016-06-24 14:00:26 +01:00
# define IVB_CURSOR_OFFSETS \
2019-03-05 21:29:05 +02:00
. cursor_offsets = { \
[ PIPE_A ] = CURSOR_A_OFFSET , \
[ PIPE_B ] = IVB_CURSOR_B_OFFSET , \
[ PIPE_C ] = IVB_CURSOR_C_OFFSET , \
}
2016-06-24 14:00:26 +01:00
2019-09-24 13:01:52 +05:30
# define TGL_CURSOR_OFFSETS \
. cursor_offsets = { \
[ PIPE_A ] = CURSOR_A_OFFSET , \
[ PIPE_B ] = IVB_CURSOR_B_OFFSET , \
[ PIPE_C ] = IVB_CURSOR_C_OFFSET , \
[ PIPE_D ] = TGL_CURSOR_D_OFFSET , \
}
2019-04-01 23:02:30 +03:00
# define I9XX_COLORS \
. color = { . gamma_lut_size = 256 }
2019-04-01 23:02:29 +03:00
# define I965_COLORS \
. color = { . gamma_lut_size = 129 , \
. gamma_lut_tests = DRM_COLOR_LUT_NON_DECREASING , \
}
2019-04-01 23:02:28 +03:00
# define ILK_COLORS \
. color = { . gamma_lut_size = 1024 }
2019-04-01 23:02:27 +03:00
# define IVB_COLORS \
2019-04-03 22:16:33 +03:00
. color = { . degamma_lut_size = 1024 , . gamma_lut_size = 1024 }
2016-06-24 14:00:26 +01:00
# define CHV_COLORS \
2019-01-30 10:10:22 -08:00
. color = { . degamma_lut_size = 65 , . gamma_lut_size = 257 , \
. degamma_lut_tests = DRM_COLOR_LUT_NON_DECREASING , \
. gamma_lut_tests = DRM_COLOR_LUT_NON_DECREASING , \
}
2017-10-02 23:36:52 -07:00
# define GLK_COLORS \
2019-02-11 19:20:21 +05:30
. color = { . degamma_lut_size = 33 , . gamma_lut_size = 1024 , \
2019-01-30 10:10:22 -08:00
. degamma_lut_tests = DRM_COLOR_LUT_NON_DECREASING | \
DRM_COLOR_LUT_EQUAL_CHANNELS , \
}
2021-10-14 21:18:55 +03:00
# define ICL_COLORS \
. color = { . degamma_lut_size = 33 , . gamma_lut_size = 262145 , \
. degamma_lut_tests = DRM_COLOR_LUT_NON_DECREASING | \
DRM_COLOR_LUT_EQUAL_CHANNELS , \
. gamma_lut_tests = DRM_COLOR_LUT_NON_DECREASING , \
}
2016-06-24 14:00:26 +01:00
2016-11-30 17:43:02 +02:00
/* Keep in gen based order, and chronological order within a gen */
2017-10-06 23:18:16 +01:00
# define GEN_DEFAULT_PAGE_SIZES \
. page_sizes = I915_GTT_PAGE_SIZE_4K
2019-10-18 10:07:50 +01:00
# define GEN_DEFAULT_REGIONS \
2021-02-05 10:20:26 +00:00
. memory_regions = REGION_SMEM | REGION_STOLEN_SMEM
2019-10-18 10:07:50 +01:00
2019-03-05 21:29:05 +02:00
# define I830_FEATURES \
GEN ( 2 ) , \
. is_mobile = 1 , \
2021-12-10 14:27:26 +02:00
. display . pipe_mask = BIT ( PIPE_A ) | BIT ( PIPE_B ) , \
. display . cpu_transcoder_mask = BIT ( TRANSCODER_A ) | BIT ( TRANSCODER_B ) , \
2019-03-05 21:29:05 +02:00
. display . has_overlay = 1 , \
. display . cursor_needs_physical = 1 , \
. display . overlay_needs_physical = 1 , \
. display . has_gmch = 1 , \
. gpu_reset_clobbers_display = true , \
. hws_needs_physical = 1 , \
. unfenced_needs_alignment = 1 , \
2020-07-07 17:39:47 -07:00
. platform_engine_mask = BIT ( RCS0 ) , \
2019-03-05 21:29:05 +02:00
. has_snoop = true , \
. has_coherent_ggtt = false , \
2020-04-17 15:51:07 -04:00
. dma_mask_size = 32 , \
2019-03-05 21:29:05 +02:00
I9XX_PIPE_OFFSETS , \
I9XX_CURSOR_OFFSETS , \
2019-04-01 23:02:30 +03:00
I9XX_COLORS , \
2019-10-18 10:07:50 +01:00
GEN_DEFAULT_PAGE_SIZES , \
GEN_DEFAULT_REGIONS
2019-03-05 21:29:05 +02:00
# define I845_FEATURES \
2018-02-15 08:19:28 +00:00
GEN ( 2 ) , \
2021-12-10 14:27:26 +02:00
. display . pipe_mask = BIT ( PIPE_A ) , \
. display . cpu_transcoder_mask = BIT ( TRANSCODER_A ) , \
2018-11-30 15:20:48 -08:00
. display . has_overlay = 1 , \
. display . overlay_needs_physical = 1 , \
2019-02-04 14:25:38 -08:00
. display . has_gmch = 1 , \
2019-01-03 11:21:04 +00:00
. gpu_reset_clobbers_display = true , \
2016-08-17 12:30:56 -07:00
. hws_needs_physical = 1 , \
2017-03-25 11:32:43 +00:00
. unfenced_needs_alignment = 1 , \
2020-07-07 17:39:47 -07:00
. platform_engine_mask = BIT ( RCS0 ) , \
2017-09-06 11:56:53 +01:00
. has_snoop = true , \
2018-07-20 11:19:10 +01:00
. has_coherent_ggtt = false , \
2020-04-17 15:51:07 -04:00
. dma_mask_size = 32 , \
2019-03-05 21:29:05 +02:00
I845_PIPE_OFFSETS , \
I845_CURSOR_OFFSETS , \
2019-04-01 23:02:30 +03:00
I9XX_COLORS , \
2019-10-18 10:07:50 +01:00
GEN_DEFAULT_PAGE_SIZES , \
GEN_DEFAULT_REGIONS
2016-08-17 12:30:51 -07:00
2019-12-24 00:40:03 -08:00
static const struct intel_device_info i830_info = {
2019-03-05 21:29:05 +02:00
I830_FEATURES ,
2018-02-15 08:19:30 +00:00
PLATFORM ( INTEL_I830 ) ,
2016-06-24 14:00:26 +01:00
} ;
2019-12-24 00:40:03 -08:00
static const struct intel_device_info i845g_info = {
2019-03-05 21:29:05 +02:00
I845_FEATURES ,
2018-02-15 08:19:30 +00:00
PLATFORM ( INTEL_I845G ) ,
2016-06-24 14:00:26 +01:00
} ;
2019-12-24 00:40:03 -08:00
static const struct intel_device_info i85x_info = {
2019-03-05 21:29:05 +02:00
I830_FEATURES ,
2018-02-15 08:19:30 +00:00
PLATFORM ( INTEL_I85X ) ,
2021-12-13 15:44:49 +02:00
. display . fbc_mask = BIT ( INTEL_FBC_A ) ,
2016-06-24 14:00:26 +01:00
} ;
2019-12-24 00:40:03 -08:00
static const struct intel_device_info i865g_info = {
2019-03-05 21:29:05 +02:00
I845_FEATURES ,
2018-02-15 08:19:30 +00:00
PLATFORM ( INTEL_I865G ) ,
2021-12-13 15:44:49 +02:00
. display . fbc_mask = BIT ( INTEL_FBC_A ) ,
2016-06-24 14:00:26 +01:00
} ;
2016-08-17 12:30:50 -07:00
# define GEN3_FEATURES \
2018-02-15 08:19:28 +00:00
GEN ( 3 ) , \
2021-12-10 14:27:26 +02:00
. display . pipe_mask = BIT ( PIPE_A ) | BIT ( PIPE_B ) , \
. display . cpu_transcoder_mask = BIT ( TRANSCODER_A ) | BIT ( TRANSCODER_B ) , \
2019-02-04 14:25:38 -08:00
. display . has_gmch = 1 , \
2019-01-03 11:21:04 +00:00
. gpu_reset_clobbers_display = true , \
2020-07-07 17:39:47 -07:00
. platform_engine_mask = BIT ( RCS0 ) , \
2017-09-06 11:56:53 +01:00
. has_snoop = true , \
2018-07-20 11:19:10 +01:00
. has_coherent_ggtt = true , \
2020-04-17 15:51:07 -04:00
. dma_mask_size = 32 , \
2019-03-05 21:29:05 +02:00
I9XX_PIPE_OFFSETS , \
I9XX_CURSOR_OFFSETS , \
2019-04-01 23:02:30 +03:00
I9XX_COLORS , \
2019-10-18 10:07:50 +01:00
GEN_DEFAULT_PAGE_SIZES , \
GEN_DEFAULT_REGIONS
2016-08-17 12:30:50 -07:00
2019-12-24 00:40:03 -08:00
static const struct intel_device_info i915g_info = {
2016-08-17 12:30:50 -07:00
GEN3_FEATURES ,
2018-02-15 08:19:30 +00:00
PLATFORM ( INTEL_I915G ) ,
2018-07-20 11:19:10 +01:00
. has_coherent_ggtt = false ,
2018-11-30 15:20:48 -08:00
. display . cursor_needs_physical = 1 ,
. display . has_overlay = 1 ,
. display . overlay_needs_physical = 1 ,
2016-08-17 12:30:56 -07:00
. hws_needs_physical = 1 ,
2017-03-25 11:32:43 +00:00
. unfenced_needs_alignment = 1 ,
2016-06-24 14:00:26 +01:00
} ;
2016-11-30 17:43:02 +02:00
2019-12-24 00:40:03 -08:00
static const struct intel_device_info i915gm_info = {
2016-08-17 12:30:50 -07:00
GEN3_FEATURES ,
2018-02-15 08:19:30 +00:00
PLATFORM ( INTEL_I915GM ) ,
2016-08-17 12:30:50 -07:00
. is_mobile = 1 ,
2018-11-30 15:20:48 -08:00
. display . cursor_needs_physical = 1 ,
. display . has_overlay = 1 ,
. display . overlay_needs_physical = 1 ,
. display . supports_tv = 1 ,
2021-12-13 15:44:49 +02:00
. display . fbc_mask = BIT ( INTEL_FBC_A ) ,
2016-08-17 12:30:56 -07:00
. hws_needs_physical = 1 ,
2017-03-25 11:32:43 +00:00
. unfenced_needs_alignment = 1 ,
2016-06-24 14:00:26 +01:00
} ;
2016-11-30 17:43:02 +02:00
2019-12-24 00:40:03 -08:00
static const struct intel_device_info i945g_info = {
2016-08-17 12:30:50 -07:00
GEN3_FEATURES ,
2018-02-15 08:19:30 +00:00
PLATFORM ( INTEL_I945G ) ,
2018-11-30 15:20:48 -08:00
. display . has_hotplug = 1 ,
. display . cursor_needs_physical = 1 ,
. display . has_overlay = 1 ,
. display . overlay_needs_physical = 1 ,
2016-08-17 12:30:56 -07:00
. hws_needs_physical = 1 ,
2017-03-25 11:32:43 +00:00
. unfenced_needs_alignment = 1 ,
2016-06-24 14:00:26 +01:00
} ;
2016-11-30 17:43:02 +02:00
2019-12-24 00:40:03 -08:00
static const struct intel_device_info i945gm_info = {
2016-08-17 12:30:50 -07:00
GEN3_FEATURES ,
2018-02-15 08:19:30 +00:00
PLATFORM ( INTEL_I945GM ) ,
. is_mobile = 1 ,
2018-11-30 15:20:48 -08:00
. display . has_hotplug = 1 ,
. display . cursor_needs_physical = 1 ,
. display . has_overlay = 1 ,
. display . overlay_needs_physical = 1 ,
. display . supports_tv = 1 ,
2021-12-13 15:44:49 +02:00
. display . fbc_mask = BIT ( INTEL_FBC_A ) ,
2016-08-17 12:30:56 -07:00
. hws_needs_physical = 1 ,
2017-03-25 11:32:43 +00:00
. unfenced_needs_alignment = 1 ,
2016-06-24 14:00:26 +01:00
} ;
2019-12-24 00:40:03 -08:00
static const struct intel_device_info g33_info = {
2016-11-30 17:43:02 +02:00
GEN3_FEATURES ,
2018-02-15 08:19:30 +00:00
PLATFORM ( INTEL_G33 ) ,
2018-11-30 15:20:48 -08:00
. display . has_hotplug = 1 ,
. display . has_overlay = 1 ,
2020-04-17 15:51:07 -04:00
. dma_mask_size = 36 ,
2016-11-30 17:43:02 +02:00
} ;
2019-12-24 00:40:03 -08:00
static const struct intel_device_info pnv_g_info = {
2019-03-26 07:40:54 +00:00
GEN3_FEATURES ,
PLATFORM ( INTEL_PINEVIEW ) ,
. display . has_hotplug = 1 ,
. display . has_overlay = 1 ,
2020-04-17 15:51:07 -04:00
. dma_mask_size = 36 ,
2019-03-26 07:40:54 +00:00
} ;
2019-12-24 00:40:03 -08:00
static const struct intel_device_info pnv_m_info = {
2016-11-30 17:43:02 +02:00
GEN3_FEATURES ,
2018-02-15 08:19:30 +00:00
PLATFORM ( INTEL_PINEVIEW ) ,
. is_mobile = 1 ,
2018-11-30 15:20:48 -08:00
. display . has_hotplug = 1 ,
. display . has_overlay = 1 ,
2020-04-17 15:51:07 -04:00
. dma_mask_size = 36 ,
2016-11-30 17:43:02 +02:00
} ;
2016-08-17 12:30:49 -07:00
# define GEN4_FEATURES \
2018-02-15 08:19:28 +00:00
GEN ( 4 ) , \
2021-12-10 14:27:26 +02:00
. display . pipe_mask = BIT ( PIPE_A ) | BIT ( PIPE_B ) , \
. display . cpu_transcoder_mask = BIT ( TRANSCODER_A ) | BIT ( TRANSCODER_B ) , \
2018-11-30 15:20:48 -08:00
. display . has_hotplug = 1 , \
2019-02-04 14:25:38 -08:00
. display . has_gmch = 1 , \
2019-01-03 11:21:04 +00:00
. gpu_reset_clobbers_display = true , \
2020-07-07 17:39:47 -07:00
. platform_engine_mask = BIT ( RCS0 ) , \
2017-09-06 11:56:53 +01:00
. has_snoop = true , \
2018-07-20 11:19:10 +01:00
. has_coherent_ggtt = true , \
2020-04-17 15:51:07 -04:00
. dma_mask_size = 36 , \
2019-03-05 21:29:05 +02:00
I9XX_PIPE_OFFSETS , \
I9XX_CURSOR_OFFSETS , \
2019-04-01 23:02:29 +03:00
I965_COLORS , \
2019-10-18 10:07:50 +01:00
GEN_DEFAULT_PAGE_SIZES , \
GEN_DEFAULT_REGIONS
2016-08-17 12:30:49 -07:00
2019-12-24 00:40:03 -08:00
static const struct intel_device_info i965g_info = {
2016-08-17 12:30:49 -07:00
GEN4_FEATURES ,
2018-02-15 08:19:30 +00:00
PLATFORM ( INTEL_I965G ) ,
2018-11-30 15:20:48 -08:00
. display . has_overlay = 1 ,
2016-08-17 12:30:56 -07:00
. hws_needs_physical = 1 ,
2017-09-06 20:24:24 +01:00
. has_snoop = false ,
2016-06-24 14:00:26 +01:00
} ;
2019-12-24 00:40:03 -08:00
static const struct intel_device_info i965gm_info = {
2016-08-17 12:30:49 -07:00
GEN4_FEATURES ,
2018-02-15 08:19:30 +00:00
PLATFORM ( INTEL_I965GM ) ,
2018-11-30 15:20:48 -08:00
. is_mobile = 1 ,
2021-12-13 15:44:49 +02:00
. display . fbc_mask = BIT ( INTEL_FBC_A ) ,
2018-11-30 15:20:48 -08:00
. display . has_overlay = 1 ,
. display . supports_tv = 1 ,
2016-08-17 12:30:56 -07:00
. hws_needs_physical = 1 ,
2017-09-06 20:24:24 +01:00
. has_snoop = false ,
2016-06-24 14:00:26 +01:00
} ;
2019-12-24 00:40:03 -08:00
static const struct intel_device_info g45_info = {
2016-08-17 12:30:49 -07:00
GEN4_FEATURES ,
2018-02-15 08:19:30 +00:00
PLATFORM ( INTEL_G45 ) ,
2020-07-07 17:39:47 -07:00
. platform_engine_mask = BIT ( RCS0 ) | BIT ( VCS0 ) ,
2019-01-03 11:21:04 +00:00
. gpu_reset_clobbers_display = false ,
2016-06-24 14:00:26 +01:00
} ;
2019-12-24 00:40:03 -08:00
static const struct intel_device_info gm45_info = {
2016-08-17 12:30:49 -07:00
GEN4_FEATURES ,
2018-02-15 08:19:30 +00:00
PLATFORM ( INTEL_GM45 ) ,
2018-11-30 15:20:48 -08:00
. is_mobile = 1 ,
2021-12-13 15:44:49 +02:00
. display . fbc_mask = BIT ( INTEL_FBC_A ) ,
2018-11-30 15:20:48 -08:00
. display . supports_tv = 1 ,
2020-07-07 17:39:47 -07:00
. platform_engine_mask = BIT ( RCS0 ) | BIT ( VCS0 ) ,
2019-01-03 11:21:04 +00:00
. gpu_reset_clobbers_display = false ,
2016-06-24 14:00:26 +01:00
} ;
2016-08-17 12:30:47 -07:00
# define GEN5_FEATURES \
2018-02-15 08:19:28 +00:00
GEN ( 5 ) , \
2021-12-10 14:27:26 +02:00
. display . pipe_mask = BIT ( PIPE_A ) | BIT ( PIPE_B ) , \
. display . cpu_transcoder_mask = BIT ( TRANSCODER_A ) | BIT ( TRANSCODER_B ) , \
2018-11-30 15:20:48 -08:00
. display . has_hotplug = 1 , \
2020-07-07 17:39:47 -07:00
. platform_engine_mask = BIT ( RCS0 ) | BIT ( VCS0 ) , \
2017-09-06 11:56:53 +01:00
. has_snoop = true , \
2018-07-20 11:19:10 +01:00
. has_coherent_ggtt = true , \
2017-12-01 11:30:30 +00:00
/* ilk does support rc6, but we do not implement [power] contexts */ \
. has_rc6 = 0 , \
2020-04-17 15:51:07 -04:00
. dma_mask_size = 36 , \
2019-03-05 21:29:05 +02:00
I9XX_PIPE_OFFSETS , \
I9XX_CURSOR_OFFSETS , \
2019-04-01 23:02:28 +03:00
ILK_COLORS , \
2019-10-18 10:07:50 +01:00
GEN_DEFAULT_PAGE_SIZES , \
GEN_DEFAULT_REGIONS
2016-08-17 12:30:47 -07:00
2019-12-24 00:40:03 -08:00
static const struct intel_device_info ilk_d_info = {
2016-08-17 12:30:47 -07:00
GEN5_FEATURES ,
2018-02-15 08:19:30 +00:00
PLATFORM ( INTEL_IRONLAKE ) ,
2016-06-24 14:00:26 +01:00
} ;
2019-12-24 00:40:03 -08:00
static const struct intel_device_info ilk_m_info = {
2016-08-17 12:30:47 -07:00
GEN5_FEATURES ,
2018-02-15 08:19:30 +00:00
PLATFORM ( INTEL_IRONLAKE ) ,
2018-11-30 15:20:48 -08:00
. is_mobile = 1 ,
2020-10-21 16:14:39 +03:00
. has_rps = true ,
2021-12-13 15:44:49 +02:00
. display . fbc_mask = BIT ( INTEL_FBC_A ) ,
2016-06-24 14:00:26 +01:00
} ;
2016-08-17 12:30:38 -07:00
# define GEN6_FEATURES \
2018-02-15 08:19:28 +00:00
GEN ( 6 ) , \
2021-12-10 14:27:26 +02:00
. display . pipe_mask = BIT ( PIPE_A ) | BIT ( PIPE_B ) , \
. display . cpu_transcoder_mask = BIT ( TRANSCODER_A ) | BIT ( TRANSCODER_B ) , \
2018-11-30 15:20:48 -08:00
. display . has_hotplug = 1 , \
2021-12-13 15:44:49 +02:00
. display . fbc_mask = BIT ( INTEL_FBC_A ) , \
2020-07-07 17:39:47 -07:00
. platform_engine_mask = BIT ( RCS0 ) | BIT ( VCS0 ) | BIT ( BCS0 ) , \
2018-07-20 11:19:10 +01:00
. has_coherent_ggtt = true , \
2016-08-17 12:30:38 -07:00
. has_llc = 1 , \
2016-08-17 12:30:44 -07:00
. has_rc6 = 1 , \
2016-08-17 12:30:45 -07:00
. has_rc6p = 1 , \
2019-04-19 14:48:36 +01:00
. has_rps = true , \
2020-04-17 15:51:07 -04:00
. dma_mask_size = 40 , \
2019-03-14 22:38:36 +00:00
. ppgtt_type = INTEL_PPGTT_ALIASING , \
. ppgtt_size = 31 , \
2019-03-05 21:29:05 +02:00
I9XX_PIPE_OFFSETS , \
I9XX_CURSOR_OFFSETS , \
2019-04-01 23:02:28 +03:00
ILK_COLORS , \
2019-10-18 10:07:50 +01:00
GEN_DEFAULT_PAGE_SIZES , \
GEN_DEFAULT_REGIONS
2016-08-17 12:30:38 -07:00
2017-08-30 17:12:05 +01:00
# define SNB_D_PLATFORM \
GEN6_FEATURES , \
2018-02-15 08:19:30 +00:00
PLATFORM ( INTEL_SANDYBRIDGE )
2017-08-30 17:12:05 +01:00
2019-12-24 00:40:03 -08:00
static const struct intel_device_info snb_d_gt1_info = {
2017-08-30 17:12:05 +01:00
SNB_D_PLATFORM ,
. gt = 1 ,
2016-06-24 14:00:26 +01:00
} ;
2019-12-24 00:40:03 -08:00
static const struct intel_device_info snb_d_gt2_info = {
2017-08-30 17:12:05 +01:00
SNB_D_PLATFORM ,
. gt = 2 ,
} ;
# define SNB_M_PLATFORM \
GEN6_FEATURES , \
2018-02-15 08:19:30 +00:00
PLATFORM ( INTEL_SANDYBRIDGE ) , \
2017-08-30 17:12:05 +01:00
. is_mobile = 1
2019-12-24 00:40:03 -08:00
static const struct intel_device_info snb_m_gt1_info = {
2017-08-30 17:12:05 +01:00
SNB_M_PLATFORM ,
. gt = 1 ,
} ;
2019-12-24 00:40:03 -08:00
static const struct intel_device_info snb_m_gt2_info = {
2017-08-30 17:12:05 +01:00
SNB_M_PLATFORM ,
. gt = 2 ,
2016-06-24 14:00:26 +01:00
} ;
# define GEN7_FEATURES \
2018-02-15 08:19:28 +00:00
GEN ( 7 ) , \
2021-12-10 14:27:26 +02:00
. display . pipe_mask = BIT ( PIPE_A ) | BIT ( PIPE_B ) | BIT ( PIPE_C ) , \
. display . cpu_transcoder_mask = BIT ( TRANSCODER_A ) | BIT ( TRANSCODER_B ) | BIT ( TRANSCODER_C ) , \
2018-11-30 15:20:48 -08:00
. display . has_hotplug = 1 , \
2021-12-13 15:44:49 +02:00
. display . fbc_mask = BIT ( INTEL_FBC_A ) , \
2020-07-07 17:39:47 -07:00
. platform_engine_mask = BIT ( RCS0 ) | BIT ( VCS0 ) | BIT ( BCS0 ) , \
2018-07-20 11:19:10 +01:00
. has_coherent_ggtt = true , \
2016-06-24 14:00:26 +01:00
. has_llc = 1 , \
2016-08-17 12:30:44 -07:00
. has_rc6 = 1 , \
2016-08-17 12:30:45 -07:00
. has_rc6p = 1 , \
2021-01-19 11:08:02 +00:00
. has_reset_engine = true , \
2019-04-19 14:48:36 +01:00
. has_rps = true , \
2020-04-17 15:51:07 -04:00
. dma_mask_size = 40 , \
2020-02-24 10:11:20 +00:00
. ppgtt_type = INTEL_PPGTT_ALIASING , \
2019-03-14 22:38:36 +00:00
. ppgtt_size = 31 , \
2019-03-05 21:29:05 +02:00
IVB_PIPE_OFFSETS , \
IVB_CURSOR_OFFSETS , \
2019-04-01 23:02:27 +03:00
IVB_COLORS , \
2019-10-18 10:07:50 +01:00
GEN_DEFAULT_PAGE_SIZES , \
GEN_DEFAULT_REGIONS
2016-06-24 14:00:26 +01:00
2017-08-30 17:12:05 +01:00
# define IVB_D_PLATFORM \
GEN7_FEATURES , \
2018-02-15 08:19:30 +00:00
PLATFORM ( INTEL_IVYBRIDGE ) , \
2017-08-30 17:12:05 +01:00
. has_l3_dpf = 1
2019-12-24 00:40:03 -08:00
static const struct intel_device_info ivb_d_gt1_info = {
2017-08-30 17:12:05 +01:00
IVB_D_PLATFORM ,
. gt = 1 ,
2016-06-24 14:00:26 +01:00
} ;
2019-12-24 00:40:03 -08:00
static const struct intel_device_info ivb_d_gt2_info = {
2017-08-30 17:12:05 +01:00
IVB_D_PLATFORM ,
. gt = 2 ,
} ;
# define IVB_M_PLATFORM \
GEN7_FEATURES , \
2018-02-15 08:19:30 +00:00
PLATFORM ( INTEL_IVYBRIDGE ) , \
2017-08-30 17:12:05 +01:00
. is_mobile = 1 , \
. has_l3_dpf = 1
2019-12-24 00:40:03 -08:00
static const struct intel_device_info ivb_m_gt1_info = {
2017-08-30 17:12:05 +01:00
IVB_M_PLATFORM ,
. gt = 1 ,
} ;
2019-12-24 00:40:03 -08:00
static const struct intel_device_info ivb_m_gt2_info = {
2017-08-30 17:12:05 +01:00
IVB_M_PLATFORM ,
. gt = 2 ,
2016-06-24 14:00:26 +01:00
} ;
2019-12-24 00:40:03 -08:00
static const struct intel_device_info ivb_q_info = {
2016-06-24 14:00:26 +01:00
GEN7_FEATURES ,
2018-02-15 08:19:30 +00:00
PLATFORM ( INTEL_IVYBRIDGE ) ,
2017-08-30 17:12:05 +01:00
. gt = 2 ,
2021-12-10 14:27:26 +02:00
. display . pipe_mask = 0 , /* legal, last one wins */
. display . cpu_transcoder_mask = 0 ,
2016-08-17 12:30:54 -07:00
. has_l3_dpf = 1 ,
2016-06-24 14:00:26 +01:00
} ;
2019-12-24 00:40:03 -08:00
static const struct intel_device_info vlv_info = {
2018-02-15 08:19:30 +00:00
PLATFORM ( INTEL_VALLEYVIEW ) ,
2018-02-15 08:19:28 +00:00
GEN ( 7 ) ,
2016-12-19 13:55:08 -08:00
. is_lp = 1 ,
2021-12-10 14:27:26 +02:00
. display . pipe_mask = BIT ( PIPE_A ) | BIT ( PIPE_B ) ,
. display . cpu_transcoder_mask = BIT ( TRANSCODER_A ) | BIT ( TRANSCODER_B ) ,
2016-12-19 13:55:08 -08:00
. has_runtime_pm = 1 ,
. has_rc6 = 1 ,
2021-01-19 11:08:02 +00:00
. has_reset_engine = true ,
2019-04-19 14:48:36 +01:00
. has_rps = true ,
2019-02-04 14:25:38 -08:00
. display . has_gmch = 1 ,
2018-11-30 15:20:48 -08:00
. display . has_hotplug = 1 ,
2020-04-17 15:51:07 -04:00
. dma_mask_size = 40 ,
2020-02-24 10:11:20 +00:00
. ppgtt_type = INTEL_PPGTT_ALIASING ,
2019-03-14 22:38:36 +00:00
. ppgtt_size = 31 ,
2017-09-06 11:56:53 +01:00
. has_snoop = true ,
2018-07-20 11:19:10 +01:00
. has_coherent_ggtt = false ,
2020-07-07 17:39:47 -07:00
. platform_engine_mask = BIT ( RCS0 ) | BIT ( VCS0 ) | BIT ( BCS0 ) ,
2016-12-19 13:55:08 -08:00
. display_mmio_offset = VLV_DISPLAY_BASE ,
2019-03-05 21:29:05 +02:00
I9XX_PIPE_OFFSETS ,
I9XX_CURSOR_OFFSETS ,
2019-04-01 23:02:29 +03:00
I965_COLORS ,
2017-10-06 23:18:16 +01:00
GEN_DEFAULT_PAGE_SIZES ,
2019-10-18 10:07:50 +01:00
GEN_DEFAULT_REGIONS ,
2016-06-24 14:00:26 +01:00
} ;
2017-10-02 23:36:51 -07:00
# define G75_FEATURES \
2016-06-24 14:00:26 +01:00
GEN7_FEATURES , \
2020-07-07 17:39:47 -07:00
. platform_engine_mask = BIT ( RCS0 ) | BIT ( VCS0 ) | BIT ( BCS0 ) | BIT ( VECS0 ) , \
2021-12-10 14:27:26 +02:00
. display . cpu_transcoder_mask = BIT ( TRANSCODER_A ) | BIT ( TRANSCODER_B ) | \
2020-03-18 19:02:35 +02:00
BIT ( TRANSCODER_C ) | BIT ( TRANSCODER_EDP ) , \
2018-11-30 15:20:48 -08:00
. display . has_ddi = 1 , \
2021-02-12 14:20:49 -08:00
. display . has_fpga_dbg = 1 , \
2018-11-30 15:20:48 -08:00
. display . has_dp_mst = 1 , \
2016-08-17 12:30:45 -07:00
. has_rc6p = 0 /* RC6p removed-by HSW */ , \
2019-03-05 21:29:05 +02:00
HSW_PIPE_OFFSETS , \
2016-08-17 12:30:39 -07:00
. has_runtime_pm = 1
2016-06-24 14:00:26 +01:00
2017-08-30 17:12:05 +01:00
# define HSW_PLATFORM \
2017-10-02 23:36:51 -07:00
G75_FEATURES , \
2018-02-15 08:19:30 +00:00
PLATFORM ( INTEL_HASWELL ) , \
2017-08-30 17:12:05 +01:00
. has_l3_dpf = 1
2019-12-24 00:40:03 -08:00
static const struct intel_device_info hsw_gt1_info = {
2017-08-30 17:12:05 +01:00
HSW_PLATFORM ,
. gt = 1 ,
} ;
2019-12-24 00:40:03 -08:00
static const struct intel_device_info hsw_gt2_info = {
2017-08-30 17:12:05 +01:00
HSW_PLATFORM ,
. gt = 2 ,
} ;
2019-12-24 00:40:03 -08:00
static const struct intel_device_info hsw_gt3_info = {
2017-08-30 17:12:05 +01:00
HSW_PLATFORM ,
. gt = 3 ,
2016-06-24 14:00:26 +01:00
} ;
2017-10-02 23:36:51 -07:00
# define GEN8_FEATURES \
G75_FEATURES , \
2018-02-15 08:19:29 +00:00
GEN ( 8 ) , \
2016-11-03 10:39:46 +02:00
. has_logical_ring_contexts = 1 , \
2020-04-17 15:51:07 -04:00
. dma_mask_size = 39 , \
2019-03-14 22:38:37 +00:00
. ppgtt_type = INTEL_PPGTT_FULL , \
2019-03-14 22:38:36 +00:00
. ppgtt_size = 48 , \
2021-01-19 11:08:02 +00:00
. has_64bit_reloc = 1
2016-06-24 14:00:26 +01:00
2017-06-06 09:06:06 -07:00
# define BDW_PLATFORM \
2017-10-02 23:36:51 -07:00
GEN8_FEATURES , \
2018-02-15 08:19:30 +00:00
PLATFORM ( INTEL_BROADWELL )
2017-06-06 09:06:06 -07:00
2019-12-24 00:40:03 -08:00
static const struct intel_device_info bdw_gt1_info = {
2017-08-30 17:12:05 +01:00
BDW_PLATFORM ,
. gt = 1 ,
} ;
2019-12-24 00:40:03 -08:00
static const struct intel_device_info bdw_gt2_info = {
2017-06-06 09:06:06 -07:00
BDW_PLATFORM ,
2017-08-30 17:12:05 +01:00
. gt = 2 ,
} ;
2019-12-24 00:40:03 -08:00
static const struct intel_device_info bdw_rsvd_info = {
2017-08-30 17:12:05 +01:00
BDW_PLATFORM ,
. gt = 3 ,
/* According to the device ID those devices are GT3, they were
* previously treated as not GT3 , keep it like that .
*/
2016-06-24 14:00:26 +01:00
} ;
2019-12-24 00:40:03 -08:00
static const struct intel_device_info bdw_gt3_info = {
2017-06-06 09:06:06 -07:00
BDW_PLATFORM ,
2017-08-30 17:12:05 +01:00
. gt = 3 ,
2020-07-07 17:39:47 -07:00
. platform_engine_mask =
2019-03-05 18:03:30 +00:00
BIT ( RCS0 ) | BIT ( VCS0 ) | BIT ( BCS0 ) | BIT ( VECS0 ) | BIT ( VCS1 ) ,
2016-06-24 14:00:26 +01:00
} ;
2019-12-24 00:40:03 -08:00
static const struct intel_device_info chv_info = {
2018-02-15 08:19:30 +00:00
PLATFORM ( INTEL_CHERRYVIEW ) ,
2018-02-15 08:19:28 +00:00
GEN ( 8 ) ,
2021-12-10 14:27:26 +02:00
. display . pipe_mask = BIT ( PIPE_A ) | BIT ( PIPE_B ) | BIT ( PIPE_C ) ,
. display . cpu_transcoder_mask = BIT ( TRANSCODER_A ) | BIT ( TRANSCODER_B ) | BIT ( TRANSCODER_C ) ,
2018-11-30 15:20:48 -08:00
. display . has_hotplug = 1 ,
2016-12-18 13:36:26 -08:00
. is_lp = 1 ,
2020-07-07 17:39:47 -07:00
. platform_engine_mask = BIT ( RCS0 ) | BIT ( VCS0 ) | BIT ( BCS0 ) | BIT ( VECS0 ) ,
2016-11-03 10:39:46 +02:00
. has_64bit_reloc = 1 ,
2016-08-17 12:30:39 -07:00
. has_runtime_pm = 1 ,
2016-08-17 12:30:44 -07:00
. has_rc6 = 1 ,
2019-04-19 14:48:36 +01:00
. has_rps = true ,
2016-08-17 12:30:53 -07:00
. has_logical_ring_contexts = 1 ,
2019-02-04 14:25:38 -08:00
. display . has_gmch = 1 ,
2020-04-17 15:51:07 -04:00
. dma_mask_size = 39 ,
2020-05-10 11:24:31 +01:00
. ppgtt_type = INTEL_PPGTT_FULL ,
2019-03-14 22:38:36 +00:00
. ppgtt_size = 32 ,
drm/i915: Modify error handler for per engine hang recovery
This is a preparatory patch which modifies error handler to do per engine
hang recovery. The actual patch which implements this sequence follows
later in the series. The aim is to prepare existing recovery function to
adapt to this new function where applicable (which fails at this point
because core implementation is lacking) and continue recovery using legacy
full gpu reset.
A helper function is also added to query the availability of engine
reset. A subsequent patch will add the capability to query which type
of reset is present (engine -> full -> no-reset) via the get-param
ioctl.
It has been decided that the error events that are used to notify user of
reset will only be sent in case if full chip reset. In case of just
single (or multiple) engine resets, userspace won't be notified by these
events.
Note that this implementation of engine reset is for i915 directly
submitting to the ELSP, where the driver manages the hang detection,
recovery and resubmission. With GuC submission these tasks are shared
between driver and firmware; i915 will still responsible for detecting a
hang, and when it does it will have to request GuC to reset that Engine and
remind the firmware about the outstanding submissions. This will be
added in different patch.
v2: rebase, advertise engine reset availability in platform definition,
add note about GuC submission.
v3: s/*engine_reset*/*reset_engine*/. (Chris)
Handle reset as 2 level resets, by first going to engine only and fall
backing to full/chip reset as needed, i.e. reset_engine will need the
struct_mutex.
v4: Pass the engine mask to i915_reset. (Chris)
v5: Rebase, update selftests.
v6: Rebase, prepare for mutex-less reset engine.
v7: Pass reset_engine mask as a function parameter, and iterate over the
engine mask for reset_engine. (Chris)
v8: Use i915.reset >=2 in has_reset_engine; remove redundant reset
logging; add a reset-engine-in-progress flag to prevent concurrent
resets, and avoid dual purposing of reset-backoff. (Chris)
v9: Support reset of different engines in parallel (Chris)
v10: Handle reset-engine flag locking better (Chris)
v11: Squash in reporting of per-engine-reset availability.
Cc: Chris Wilson <chris@chris-wilson.co.uk>
Cc: Mika Kuoppala <mika.kuoppala@linux.intel.com>
Signed-off-by: Ian Lister <ian.lister@intel.com>
Signed-off-by: Tomas Elf <tomas.elf@intel.com>
Signed-off-by: Arun Siluvery <arun.siluvery@linux.intel.com>
Signed-off-by: Michel Thierry <michel.thierry@intel.com>
Link: http://patchwork.freedesktop.org/patch/msgid/20170615201828.23144-4-michel.thierry@intel.com
Reviewed-by: Chris Wilson <chris@chris-wilson.co.uk>
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Link: http://patchwork.freedesktop.org/patch/msgid/20170620095751.13127-5-chris@chris-wilson.co.uk
2017-06-20 10:57:46 +01:00
. has_reset_engine = 1 ,
2017-09-06 11:56:53 +01:00
. has_snoop = true ,
2018-07-20 11:19:10 +01:00
. has_coherent_ggtt = false ,
2016-06-24 14:00:26 +01:00
. display_mmio_offset = VLV_DISPLAY_BASE ,
2019-03-05 21:29:05 +02:00
CHV_PIPE_OFFSETS ,
CHV_CURSOR_OFFSETS ,
2016-06-24 14:00:26 +01:00
CHV_COLORS ,
2019-03-05 21:29:05 +02:00
GEN_DEFAULT_PAGE_SIZES ,
2019-10-18 10:07:50 +01:00
GEN_DEFAULT_REGIONS ,
2016-06-24 14:00:26 +01:00
} ;
2017-10-06 23:18:16 +01:00
# define GEN9_DEFAULT_PAGE_SIZES \
2017-10-06 23:18:32 +01:00
. page_sizes = I915_GTT_PAGE_SIZE_4K | \
2019-08-09 20:34:56 +01:00
I915_GTT_PAGE_SIZE_64K
2017-10-06 23:18:16 +01:00
2017-10-02 23:36:51 -07:00
# define GEN9_FEATURES \
GEN8_FEATURES , \
2018-02-15 08:19:29 +00:00
GEN ( 9 ) , \
2017-10-06 23:18:16 +01:00
GEN9_DEFAULT_PAGE_SIZES , \
2021-05-18 14:34:41 -07:00
. display . has_dmc = 1 , \
2019-07-24 17:18:06 -07:00
. has_gt_uc = 1 , \
2019-10-25 17:13:20 -07:00
. display . has_hdcp = 1 , \
2018-11-30 15:20:48 -08:00
. display . has_ipc = 1 , \
2021-08-27 10:42:51 -07:00
. display . has_psr = 1 , \
. display . has_psr_hw_tracking = 1 , \
2021-04-16 20:10:05 +03:00
. dbuf . size = 896 - 4 , /* 4 blocks for bypass path allocation */ \
2021-04-16 20:10:06 +03:00
. dbuf . slice_mask = BIT ( DBUF_S1 )
2017-06-06 09:06:06 -07:00
2017-10-02 23:36:51 -07:00
# define SKL_PLATFORM \
GEN9_FEATURES , \
2018-02-15 08:19:30 +00:00
PLATFORM ( INTEL_SKYLAKE )
2017-10-02 23:36:51 -07:00
2019-12-24 00:40:03 -08:00
static const struct intel_device_info skl_gt1_info = {
2017-06-06 09:06:06 -07:00
SKL_PLATFORM ,
2017-08-30 17:12:05 +01:00
. gt = 1 ,
2016-06-24 14:00:26 +01:00
} ;
2019-12-24 00:40:03 -08:00
static const struct intel_device_info skl_gt2_info = {
2017-06-06 09:06:06 -07:00
SKL_PLATFORM ,
2017-08-30 17:12:05 +01:00
. gt = 2 ,
} ;
# define SKL_GT3_PLUS_PLATFORM \
SKL_PLATFORM , \
2020-07-07 17:39:47 -07:00
. platform_engine_mask = \
2019-03-05 18:03:30 +00:00
BIT ( RCS0 ) | BIT ( VCS0 ) | BIT ( BCS0 ) | BIT ( VECS0 ) | BIT ( VCS1 )
2017-08-30 17:12:05 +01:00
2019-12-24 00:40:03 -08:00
static const struct intel_device_info skl_gt3_info = {
2017-08-30 17:12:05 +01:00
SKL_GT3_PLUS_PLATFORM ,
. gt = 3 ,
} ;
2019-12-24 00:40:03 -08:00
static const struct intel_device_info skl_gt4_info = {
2017-08-30 17:12:05 +01:00
SKL_GT3_PLUS_PLATFORM ,
. gt = 4 ,
2016-06-24 14:00:26 +01:00
} ;
2016-12-01 11:33:16 +02:00
# define GEN9_LP_FEATURES \
2018-02-15 08:19:28 +00:00
GEN ( 9 ) , \
2016-11-10 17:23:09 +02:00
. is_lp = 1 , \
2021-04-16 20:10:06 +03:00
. dbuf . slice_mask = BIT ( DBUF_S1 ) , \
2018-11-30 15:20:48 -08:00
. display . has_hotplug = 1 , \
2020-07-07 17:39:47 -07:00
. platform_engine_mask = BIT ( RCS0 ) | BIT ( VCS0 ) | BIT ( BCS0 ) | BIT ( VECS0 ) , \
2021-12-10 14:27:26 +02:00
. display . pipe_mask = BIT ( PIPE_A ) | BIT ( PIPE_B ) | BIT ( PIPE_C ) , \
. display . cpu_transcoder_mask = BIT ( TRANSCODER_A ) | BIT ( TRANSCODER_B ) | \
2020-03-18 19:02:35 +02:00
BIT ( TRANSCODER_C ) | BIT ( TRANSCODER_EDP ) | \
BIT ( TRANSCODER_DSI_A ) | BIT ( TRANSCODER_DSI_C ) , \
2016-12-01 11:33:16 +02:00
. has_64bit_reloc = 1 , \
2018-11-30 15:20:48 -08:00
. display . has_ddi = 1 , \
2021-02-12 14:20:49 -08:00
. display . has_fpga_dbg = 1 , \
2021-12-13 15:44:49 +02:00
. display . fbc_mask = BIT ( INTEL_FBC_A ) , \
2019-10-25 17:13:20 -07:00
. display . has_hdcp = 1 , \
2018-11-30 15:20:48 -08:00
. display . has_psr = 1 , \
2020-06-03 14:15:28 -07:00
. display . has_psr_hw_tracking = 1 , \
2016-12-01 11:33:16 +02:00
. has_runtime_pm = 1 , \
2021-05-18 14:34:41 -07:00
. display . has_dmc = 1 , \
2016-12-01 11:33:16 +02:00
. has_rc6 = 1 , \
2019-04-19 14:48:36 +01:00
. has_rps = true , \
2018-11-30 15:20:48 -08:00
. display . has_dp_mst = 1 , \
2016-12-01 11:33:16 +02:00
. has_logical_ring_contexts = 1 , \
2019-07-24 17:18:06 -07:00
. has_gt_uc = 1 , \
2020-04-17 15:51:07 -04:00
. dma_mask_size = 39 , \
2019-03-14 22:38:37 +00:00
. ppgtt_type = INTEL_PPGTT_FULL , \
2019-03-14 22:38:36 +00:00
. ppgtt_size = 48 , \
drm/i915: Modify error handler for per engine hang recovery
This is a preparatory patch which modifies error handler to do per engine
hang recovery. The actual patch which implements this sequence follows
later in the series. The aim is to prepare existing recovery function to
adapt to this new function where applicable (which fails at this point
because core implementation is lacking) and continue recovery using legacy
full gpu reset.
A helper function is also added to query the availability of engine
reset. A subsequent patch will add the capability to query which type
of reset is present (engine -> full -> no-reset) via the get-param
ioctl.
It has been decided that the error events that are used to notify user of
reset will only be sent in case if full chip reset. In case of just
single (or multiple) engine resets, userspace won't be notified by these
events.
Note that this implementation of engine reset is for i915 directly
submitting to the ELSP, where the driver manages the hang detection,
recovery and resubmission. With GuC submission these tasks are shared
between driver and firmware; i915 will still responsible for detecting a
hang, and when it does it will have to request GuC to reset that Engine and
remind the firmware about the outstanding submissions. This will be
added in different patch.
v2: rebase, advertise engine reset availability in platform definition,
add note about GuC submission.
v3: s/*engine_reset*/*reset_engine*/. (Chris)
Handle reset as 2 level resets, by first going to engine only and fall
backing to full/chip reset as needed, i.e. reset_engine will need the
struct_mutex.
v4: Pass the engine mask to i915_reset. (Chris)
v5: Rebase, update selftests.
v6: Rebase, prepare for mutex-less reset engine.
v7: Pass reset_engine mask as a function parameter, and iterate over the
engine mask for reset_engine. (Chris)
v8: Use i915.reset >=2 in has_reset_engine; remove redundant reset
logging; add a reset-engine-in-progress flag to prevent concurrent
resets, and avoid dual purposing of reset-backoff. (Chris)
v9: Support reset of different engines in parallel (Chris)
v10: Handle reset-engine flag locking better (Chris)
v11: Squash in reporting of per-engine-reset availability.
Cc: Chris Wilson <chris@chris-wilson.co.uk>
Cc: Mika Kuoppala <mika.kuoppala@linux.intel.com>
Signed-off-by: Ian Lister <ian.lister@intel.com>
Signed-off-by: Tomas Elf <tomas.elf@intel.com>
Signed-off-by: Arun Siluvery <arun.siluvery@linux.intel.com>
Signed-off-by: Michel Thierry <michel.thierry@intel.com>
Link: http://patchwork.freedesktop.org/patch/msgid/20170615201828.23144-4-michel.thierry@intel.com
Reviewed-by: Chris Wilson <chris@chris-wilson.co.uk>
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Link: http://patchwork.freedesktop.org/patch/msgid/20170620095751.13127-5-chris@chris-wilson.co.uk
2017-06-20 10:57:46 +01:00
. has_reset_engine = 1 , \
2017-09-06 11:56:53 +01:00
. has_snoop = true , \
2018-07-20 11:19:10 +01:00
. has_coherent_ggtt = false , \
2018-11-30 15:20:48 -08:00
. display . has_ipc = 1 , \
2019-03-05 21:29:05 +02:00
HSW_PIPE_OFFSETS , \
2016-12-01 11:33:16 +02:00
IVB_CURSOR_OFFSETS , \
2019-04-01 23:02:27 +03:00
IVB_COLORS , \
2019-10-18 10:07:50 +01:00
GEN9_DEFAULT_PAGE_SIZES , \
GEN_DEFAULT_REGIONS
2016-12-01 11:33:16 +02:00
2019-12-24 00:40:03 -08:00
static const struct intel_device_info bxt_info = {
2016-12-01 11:33:16 +02:00
GEN9_LP_FEATURES ,
2018-02-15 08:19:30 +00:00
PLATFORM ( INTEL_BROXTON ) ,
2021-04-16 20:10:05 +03:00
. dbuf . size = 512 - 4 , /* 4 blocks for bypass path allocation */
2016-06-24 14:00:26 +01:00
} ;
2019-12-24 00:40:03 -08:00
static const struct intel_device_info glk_info = {
2016-11-14 16:25:26 +02:00
GEN9_LP_FEATURES ,
2018-02-15 08:19:30 +00:00
PLATFORM ( INTEL_GEMINILAKE ) ,
2021-04-12 22:09:52 -07:00
. display . ver = 10 ,
2021-04-16 20:10:05 +03:00
. dbuf . size = 1024 - 4 , /* 4 blocks for bypass path allocation */
2017-10-02 23:36:52 -07:00
GLK_COLORS ,
2016-11-14 16:25:26 +02:00
} ;
2017-06-06 09:06:06 -07:00
# define KBL_PLATFORM \
2017-10-02 23:36:51 -07:00
GEN9_FEATURES , \
2018-02-15 08:19:30 +00:00
PLATFORM ( INTEL_KABYLAKE )
2017-06-06 09:06:06 -07:00
2019-12-24 00:40:03 -08:00
static const struct intel_device_info kbl_gt1_info = {
2017-06-06 09:06:06 -07:00
KBL_PLATFORM ,
2017-08-30 17:12:05 +01:00
. gt = 1 ,
} ;
2019-12-24 00:40:03 -08:00
static const struct intel_device_info kbl_gt2_info = {
2017-08-30 17:12:05 +01:00
KBL_PLATFORM ,
. gt = 2 ,
2016-06-24 14:00:26 +01:00
} ;
2019-12-24 00:40:03 -08:00
static const struct intel_device_info kbl_gt3_info = {
2017-06-06 09:06:06 -07:00
KBL_PLATFORM ,
2017-08-30 17:12:05 +01:00
. gt = 3 ,
2020-07-07 17:39:47 -07:00
. platform_engine_mask =
2019-03-05 18:03:30 +00:00
BIT ( RCS0 ) | BIT ( VCS0 ) | BIT ( BCS0 ) | BIT ( VECS0 ) | BIT ( VCS1 ) ,
2016-06-24 14:00:26 +01:00
} ;
2017-06-08 08:49:58 -07:00
# define CFL_PLATFORM \
2017-10-02 23:36:51 -07:00
GEN9_FEATURES , \
2018-02-15 08:19:30 +00:00
PLATFORM ( INTEL_COFFEELAKE )
2017-06-08 08:49:58 -07:00
2019-12-24 00:40:03 -08:00
static const struct intel_device_info cfl_gt1_info = {
2017-08-30 17:12:05 +01:00
CFL_PLATFORM ,
. gt = 1 ,
} ;
2019-12-24 00:40:03 -08:00
static const struct intel_device_info cfl_gt2_info = {
2017-06-08 08:49:58 -07:00
CFL_PLATFORM ,
2017-08-30 17:12:05 +01:00
. gt = 2 ,
2017-06-08 08:49:58 -07:00
} ;
2019-12-24 00:40:03 -08:00
static const struct intel_device_info cfl_gt3_info = {
2017-06-08 08:49:58 -07:00
CFL_PLATFORM ,
2017-08-30 17:12:05 +01:00
. gt = 3 ,
2020-07-07 17:39:47 -07:00
. platform_engine_mask =
2019-03-05 18:03:30 +00:00
BIT ( RCS0 ) | BIT ( VCS0 ) | BIT ( BCS0 ) | BIT ( VECS0 ) | BIT ( VCS1 ) ,
2017-06-08 08:49:58 -07:00
} ;
2020-06-02 15:05:40 +01:00
# define CML_PLATFORM \
GEN9_FEATURES , \
PLATFORM ( INTEL_COMETLAKE )
static const struct intel_device_info cml_gt1_info = {
CML_PLATFORM ,
. gt = 1 ,
} ;
static const struct intel_device_info cml_gt2_info = {
CML_PLATFORM ,
. gt = 2 ,
} ;
2019-08-09 20:34:56 +01:00
# define GEN11_DEFAULT_PAGE_SIZES \
. page_sizes = I915_GTT_PAGE_SIZE_4K | \
I915_GTT_PAGE_SIZE_64K | \
I915_GTT_PAGE_SIZE_2M
2018-01-11 16:00:04 -02:00
# define GEN11_FEATURES \
2021-07-28 14:59:46 -07:00
GEN9_FEATURES , \
2019-08-09 20:34:56 +01:00
GEN11_DEFAULT_PAGE_SIZES , \
2021-12-10 14:27:26 +02:00
. display . abox_mask = BIT ( 0 ) , \
. display . cpu_transcoder_mask = BIT ( TRANSCODER_A ) | BIT ( TRANSCODER_B ) | \
2020-03-18 19:02:35 +02:00
BIT ( TRANSCODER_C ) | BIT ( TRANSCODER_EDP ) | \
BIT ( TRANSCODER_DSI_0 ) | BIT ( TRANSCODER_DSI_1 ) , \
2018-11-20 11:23:23 +02:00
. pipe_offsets = { \
[ TRANSCODER_A ] = PIPE_A_OFFSET , \
[ TRANSCODER_B ] = PIPE_B_OFFSET , \
[ TRANSCODER_C ] = PIPE_C_OFFSET , \
[ TRANSCODER_EDP ] = PIPE_EDP_OFFSET , \
[ TRANSCODER_DSI_0 ] = PIPE_DSI0_OFFSET , \
[ TRANSCODER_DSI_1 ] = PIPE_DSI1_OFFSET , \
} , \
. trans_offsets = { \
[ TRANSCODER_A ] = TRANSCODER_A_OFFSET , \
[ TRANSCODER_B ] = TRANSCODER_B_OFFSET , \
[ TRANSCODER_C ] = TRANSCODER_C_OFFSET , \
[ TRANSCODER_EDP ] = TRANSCODER_EDP_OFFSET , \
[ TRANSCODER_DSI_0 ] = TRANSCODER_DSI0_OFFSET , \
[ TRANSCODER_DSI_1 ] = TRANSCODER_DSI1_OFFSET , \
} , \
2018-02-15 08:19:28 +00:00
GEN ( 11 ) , \
2021-10-14 21:18:55 +03:00
ICL_COLORS , \
2021-04-16 20:10:04 +03:00
. dbuf . size = 2048 , \
2021-04-16 20:10:06 +03:00
. dbuf . slice_mask = BIT ( DBUF_S1 ) | BIT ( DBUF_S2 ) , \
2021-07-28 14:59:46 -07:00
. display . has_dsc = 1 , \
. has_coherent_ggtt = false , \
. has_logical_ring_elsq = 1
2018-01-11 16:00:04 -02:00
2019-12-24 00:40:03 -08:00
static const struct intel_device_info icl_info = {
2018-01-11 16:00:04 -02:00
GEN11_FEATURES ,
2018-02-15 08:19:30 +00:00
PLATFORM ( INTEL_ICELAKE ) ,
2020-07-07 17:39:47 -07:00
. platform_engine_mask =
2019-03-05 18:03:30 +00:00
BIT ( RCS0 ) | BIT ( BCS0 ) | BIT ( VECS0 ) | BIT ( VCS0 ) | BIT ( VCS2 ) ,
2018-01-11 16:00:04 -02:00
} ;
2019-12-24 00:40:03 -08:00
static const struct intel_device_info ehl_info = {
2019-03-22 10:58:42 -07:00
GEN11_FEATURES ,
2019-03-22 10:58:43 -07:00
PLATFORM ( INTEL_ELKHARTLAKE ) ,
2020-07-07 17:39:47 -07:00
. platform_engine_mask = BIT ( RCS0 ) | BIT ( BCS0 ) | BIT ( VCS0 ) | BIT ( VECS0 ) ,
2019-03-22 10:58:42 -07:00
. ppgtt_size = 36 ,
} ;
2020-10-14 00:59:48 +05:30
static const struct intel_device_info jsl_info = {
GEN11_FEATURES ,
PLATFORM ( INTEL_JASPERLAKE ) ,
. platform_engine_mask = BIT ( RCS0 ) | BIT ( BCS0 ) | BIT ( VCS0 ) | BIT ( VECS0 ) ,
. ppgtt_size = 36 ,
} ;
2019-07-11 10:30:56 -07:00
# define GEN12_FEATURES \
GEN11_FEATURES , \
GEN ( 12 ) , \
2021-12-10 14:27:26 +02:00
. display . abox_mask = GENMASK ( 2 , 1 ) , \
. display . pipe_mask = BIT ( PIPE_A ) | BIT ( PIPE_B ) | BIT ( PIPE_C ) | BIT ( PIPE_D ) , \
. display . cpu_transcoder_mask = BIT ( TRANSCODER_A ) | BIT ( TRANSCODER_B ) | \
2020-03-18 19:02:35 +02:00
BIT ( TRANSCODER_C ) | BIT ( TRANSCODER_D ) | \
BIT ( TRANSCODER_DSI_0 ) | BIT ( TRANSCODER_DSI_1 ) , \
2019-07-11 10:30:56 -07:00
. pipe_offsets = { \
[ TRANSCODER_A ] = PIPE_A_OFFSET , \
[ TRANSCODER_B ] = PIPE_B_OFFSET , \
[ TRANSCODER_C ] = PIPE_C_OFFSET , \
[ TRANSCODER_D ] = PIPE_D_OFFSET , \
[ TRANSCODER_DSI_0 ] = PIPE_DSI0_OFFSET , \
[ TRANSCODER_DSI_1 ] = PIPE_DSI1_OFFSET , \
} , \
. trans_offsets = { \
[ TRANSCODER_A ] = TRANSCODER_A_OFFSET , \
[ TRANSCODER_B ] = TRANSCODER_B_OFFSET , \
[ TRANSCODER_C ] = TRANSCODER_C_OFFSET , \
[ TRANSCODER_D ] = TRANSCODER_D_OFFSET , \
[ TRANSCODER_DSI_0 ] = TRANSCODER_DSI0_OFFSET , \
[ TRANSCODER_DSI_1 ] = TRANSCODER_DSI1_OFFSET , \
2019-07-30 11:04:06 -07:00
} , \
2019-09-24 13:01:52 +05:30
TGL_CURSOR_OFFSETS , \
2019-09-20 17:29:29 +05:30
. has_global_mocs = 1 , \
2021-09-24 12:14:52 -07:00
. has_pxp = 1 , \
2021-10-14 21:18:56 +03:00
. display . has_dsb = 0 /* FIXME: LUT load is broken with DSB */
2019-07-11 10:30:56 -07:00
2019-12-24 00:40:03 -08:00
static const struct intel_device_info tgl_info = {
2019-07-11 10:30:56 -07:00
GEN12_FEATURES ,
PLATFORM ( INTEL_TIGERLAKE ) ,
2019-07-11 22:57:06 -07:00
. display . has_modular_fia = 1 ,
2020-07-07 17:39:47 -07:00
. platform_engine_mask =
2019-07-11 10:30:56 -07:00
BIT ( RCS0 ) | BIT ( BCS0 ) | BIT ( VECS0 ) | BIT ( VCS0 ) | BIT ( VCS2 ) ,
} ;
2020-05-04 15:52:06 -07:00
static const struct intel_device_info rkl_info = {
GEN12_FEATURES ,
PLATFORM ( INTEL_ROCKETLAKE ) ,
2021-12-10 14:27:26 +02:00
. display . abox_mask = BIT ( 0 ) ,
. display . pipe_mask = BIT ( PIPE_A ) | BIT ( PIPE_B ) | BIT ( PIPE_C ) ,
. display . cpu_transcoder_mask = BIT ( TRANSCODER_A ) | BIT ( TRANSCODER_B ) |
2020-06-03 14:15:15 -07:00
BIT ( TRANSCODER_C ) ,
2020-07-16 15:05:50 -07:00
. display . has_hti = 1 ,
2020-06-03 14:15:28 -07:00
. display . has_psr_hw_tracking = 0 ,
2020-07-07 17:39:47 -07:00
. platform_engine_mask =
2020-05-04 15:52:06 -07:00
BIT ( RCS0 ) | BIT ( BCS0 ) | BIT ( VECS0 ) | BIT ( VCS0 ) ,
} ;
2021-04-12 22:10:02 -07:00
# define DGFX_FEATURES \
2021-04-21 11:46:55 +01:00
. memory_regions = REGION_SMEM | REGION_LMEM | REGION_STOLEN_LMEM , \
2020-10-14 12:19:37 -07:00
. has_llc = 0 , \
2021-09-24 12:14:52 -07:00
. has_pxp = 0 , \
2020-10-14 12:19:37 -07:00
. has_snoop = 1 , \
2019-10-24 12:51:20 -07:00
. is_dgfx = 1
2021-08-19 14:03:49 -07:00
static const struct intel_device_info dg1_info = {
2021-04-12 22:10:02 -07:00
GEN12_FEATURES ,
DGFX_FEATURES ,
2021-10-19 17:23:51 -07:00
. graphics . rel = 10 ,
2020-07-13 11:23:17 -07:00
PLATFORM ( INTEL_DG1 ) ,
2021-12-10 14:27:26 +02:00
. display . pipe_mask = BIT ( PIPE_A ) | BIT ( PIPE_B ) | BIT ( PIPE_C ) | BIT ( PIPE_D ) ,
2020-07-13 11:23:17 -07:00
. require_force_probe = 1 ,
. platform_engine_mask =
BIT ( RCS0 ) | BIT ( BCS0 ) | BIT ( VECS0 ) |
BIT ( VCS0 ) | BIT ( VCS2 ) ,
2020-10-14 12:19:34 -07:00
/* Wa_16011227922 */
. ppgtt_size = 47 ,
2020-07-13 11:23:17 -07:00
} ;
2021-01-19 11:29:31 -08:00
static const struct intel_device_info adl_s_info = {
GEN12_FEATURES ,
PLATFORM ( INTEL_ALDERLAKE_S ) ,
2021-12-10 14:27:26 +02:00
. display . pipe_mask = BIT ( PIPE_A ) | BIT ( PIPE_B ) | BIT ( PIPE_C ) | BIT ( PIPE_D ) ,
2021-01-19 11:29:31 -08:00
. display . has_hti = 1 ,
. display . has_psr_hw_tracking = 0 ,
. platform_engine_mask =
BIT ( RCS0 ) | BIT ( BCS0 ) | BIT ( VECS0 ) | BIT ( VCS0 ) | BIT ( VCS2 ) ,
2021-07-08 12:42:22 +05:30
. dma_mask_size = 39 ,
2021-01-19 11:29:31 -08:00
} ;
2021-06-11 22:35:31 -07:00
# define XE_LPD_CURSOR_OFFSETS \
. cursor_offsets = { \
[ PIPE_A ] = CURSOR_A_OFFSET , \
[ PIPE_B ] = IVB_CURSOR_B_OFFSET , \
[ PIPE_C ] = IVB_CURSOR_C_OFFSET , \
[ PIPE_D ] = TGL_CURSOR_D_OFFSET , \
}
2021-05-06 19:19:21 +03:00
# define XE_LPD_FEATURES \
2021-12-10 14:27:26 +02:00
. display . abox_mask = GENMASK ( 1 , 0 ) , \
2021-12-07 12:41:35 +05:30
. color = { . degamma_lut_size = 128 , . gamma_lut_size = 1024 , \
. degamma_lut_tests = DRM_COLOR_LUT_NON_DECREASING | \
DRM_COLOR_LUT_EQUAL_CHANNELS , \
} , \
2021-06-11 22:35:31 -07:00
. dbuf . size = 4096 , \
. dbuf . slice_mask = BIT ( DBUF_S1 ) | BIT ( DBUF_S2 ) | BIT ( DBUF_S3 ) | \
BIT ( DBUF_S4 ) , \
. display . has_ddi = 1 , \
. display . has_dmc = 1 , \
. display . has_dp_mst = 1 , \
. display . has_dsb = 1 , \
. display . has_dsc = 1 , \
2021-12-13 15:44:49 +02:00
. display . fbc_mask = BIT ( INTEL_FBC_A ) , \
2021-06-11 22:35:31 -07:00
. display . has_fpga_dbg = 1 , \
. display . has_hdcp = 1 , \
. display . has_hotplug = 1 , \
. display . has_ipc = 1 , \
. display . has_psr = 1 , \
. display . ver = 13 , \
2021-12-10 14:27:26 +02:00
. display . pipe_mask = BIT ( PIPE_A ) | BIT ( PIPE_B ) | BIT ( PIPE_C ) | BIT ( PIPE_D ) , \
2021-06-11 22:35:31 -07:00
. pipe_offsets = { \
[ TRANSCODER_A ] = PIPE_A_OFFSET , \
[ TRANSCODER_B ] = PIPE_B_OFFSET , \
[ TRANSCODER_C ] = PIPE_C_OFFSET , \
[ TRANSCODER_D ] = PIPE_D_OFFSET , \
2021-10-19 20:44:33 +05:30
[ TRANSCODER_DSI_0 ] = PIPE_DSI0_OFFSET , \
[ TRANSCODER_DSI_1 ] = PIPE_DSI1_OFFSET , \
2021-06-11 22:35:31 -07:00
} , \
. trans_offsets = { \
[ TRANSCODER_A ] = TRANSCODER_A_OFFSET , \
[ TRANSCODER_B ] = TRANSCODER_B_OFFSET , \
[ TRANSCODER_C ] = TRANSCODER_C_OFFSET , \
[ TRANSCODER_D ] = TRANSCODER_D_OFFSET , \
2021-10-19 20:44:33 +05:30
[ TRANSCODER_DSI_0 ] = TRANSCODER_DSI0_OFFSET , \
[ TRANSCODER_DSI_1 ] = TRANSCODER_DSI1_OFFSET , \
2021-06-11 22:35:31 -07:00
} , \
XE_LPD_CURSOR_OFFSETS
2021-05-06 19:19:21 +03:00
2021-05-06 19:19:23 +03:00
static const struct intel_device_info adl_p_info = {
GEN12_FEATURES ,
XE_LPD_FEATURES ,
PLATFORM ( INTEL_ALDERLAKE_P ) ,
2021-12-10 14:27:26 +02:00
. display . cpu_transcoder_mask = BIT ( TRANSCODER_A ) | BIT ( TRANSCODER_B ) |
2021-10-19 20:44:33 +05:30
BIT ( TRANSCODER_C ) | BIT ( TRANSCODER_D ) |
BIT ( TRANSCODER_DSI_0 ) | BIT ( TRANSCODER_DSI_1 ) ,
2021-07-07 16:42:06 -07:00
. display . has_cdclk_crawl = 1 ,
2021-05-14 08:37:02 -07:00
. display . has_modular_fia = 1 ,
2021-06-11 22:35:31 -07:00
. display . has_psr_hw_tracking = 0 ,
2021-05-06 19:19:23 +03:00
. platform_engine_mask =
BIT ( RCS0 ) | BIT ( BCS0 ) | BIT ( VECS0 ) | BIT ( VCS0 ) | BIT ( VCS2 ) ,
. ppgtt_size = 48 ,
. dma_mask_size = 39 ,
} ;
2018-02-15 08:19:28 +00:00
# undef GEN
2021-07-21 15:30:26 -07:00
# define XE_HP_PAGE_SIZES \
. page_sizes = I915_GTT_PAGE_SIZE_4K | \
I915_GTT_PAGE_SIZE_64K | \
I915_GTT_PAGE_SIZE_2M
# define XE_HP_FEATURES \
2021-10-19 17:23:51 -07:00
. graphics . ver = 12 , \
. graphics . rel = 50 , \
2021-07-21 15:30:26 -07:00
XE_HP_PAGE_SIZES , \
. dma_mask_size = 46 , \
. has_64bit_reloc = 1 , \
2022-02-19 00:17:50 +05:30
. has_flat_ccs = 1 , \
2021-07-21 15:30:26 -07:00
. has_global_mocs = 1 , \
. has_gt_uc = 1 , \
. has_llc = 1 , \
. has_logical_ring_contexts = 1 , \
. has_logical_ring_elsq = 1 , \
2021-07-29 09:59:51 -07:00
. has_mslices = 1 , \
2021-07-21 15:30:26 -07:00
. has_rc6 = 1 , \
. has_reset_engine = 1 , \
. has_rps = 1 , \
. has_runtime_pm = 1 , \
. ppgtt_size = 48 , \
. ppgtt_type = INTEL_PPGTT_FULL
2021-07-21 15:30:27 -07:00
# define XE_HPM_FEATURES \
2021-10-19 17:23:51 -07:00
. media . ver = 12 , \
. media . rel = 50
2021-07-21 15:30:27 -07:00
__maybe_unused
static const struct intel_device_info xehpsdv_info = {
XE_HP_FEATURES ,
XE_HPM_FEATURES ,
DGFX_FEATURES ,
PLATFORM ( INTEL_XEHPSDV ) ,
. display = { } ,
2021-12-08 19:46:10 +05:30
. has_64k_pages = 1 ,
2022-02-19 00:17:42 +05:30
. needs_compact_pt = 1 ,
2021-07-21 15:30:27 -07:00
. platform_engine_mask =
BIT ( RCS0 ) | BIT ( BCS0 ) |
2021-07-23 12:10:24 -07:00
BIT ( VECS0 ) | BIT ( VECS1 ) | BIT ( VECS2 ) | BIT ( VECS3 ) |
BIT ( VCS0 ) | BIT ( VCS1 ) | BIT ( VCS2 ) | BIT ( VCS3 ) |
BIT ( VCS4 ) | BIT ( VCS5 ) | BIT ( VCS6 ) | BIT ( VCS7 ) ,
2021-07-21 15:30:27 -07:00
. require_force_probe = 1 ,
} ;
2021-07-21 15:30:28 -07:00
__maybe_unused
static const struct intel_device_info dg2_info = {
XE_HP_FEATURES ,
XE_HPM_FEATURES ,
XE_LPD_FEATURES ,
DGFX_FEATURES ,
2021-10-19 17:23:51 -07:00
. graphics . rel = 55 ,
. media . rel = 55 ,
2021-07-21 15:30:28 -07:00
PLATFORM ( INTEL_DG2 ) ,
2022-01-20 13:29:47 -08:00
. has_guc_deprivilege = 1 ,
2021-12-08 19:46:10 +05:30
. has_64k_pages = 1 ,
2022-02-19 00:17:42 +05:30
. needs_compact_pt = 1 ,
2021-07-21 15:30:28 -07:00
. platform_engine_mask =
BIT ( RCS0 ) | BIT ( BCS0 ) |
BIT ( VECS0 ) | BIT ( VECS1 ) |
BIT ( VCS0 ) | BIT ( VCS2 ) ,
. require_force_probe = 1 ,
2021-12-10 14:27:26 +02:00
. display . cpu_transcoder_mask = BIT ( TRANSCODER_A ) | BIT ( TRANSCODER_B ) |
2021-10-19 20:44:33 +05:30
BIT ( TRANSCODER_C ) | BIT ( TRANSCODER_D ) ,
2021-07-21 15:30:28 -07:00
} ;
2018-02-15 08:19:30 +00:00
# undef PLATFORM
2018-02-15 08:19:28 +00:00
2016-06-24 14:00:26 +01:00
/*
* Make sure any device matches here are from most specific to most
* general . For example , since the Quanta match is based on the subsystem
* and subvendor IDs , we need it to come before the more general IVB
* PCI ID matches , otherwise we ' ll use the wrong info struct above .
*/
static const struct pci_device_id pciidlist [ ] = {
2019-12-24 00:40:03 -08:00
INTEL_I830_IDS ( & i830_info ) ,
INTEL_I845G_IDS ( & i845g_info ) ,
INTEL_I85X_IDS ( & i85x_info ) ,
INTEL_I865G_IDS ( & i865g_info ) ,
INTEL_I915G_IDS ( & i915g_info ) ,
INTEL_I915GM_IDS ( & i915gm_info ) ,
INTEL_I945G_IDS ( & i945g_info ) ,
INTEL_I945GM_IDS ( & i945gm_info ) ,
INTEL_I965G_IDS ( & i965g_info ) ,
INTEL_G33_IDS ( & g33_info ) ,
INTEL_I965GM_IDS ( & i965gm_info ) ,
INTEL_GM45_IDS ( & gm45_info ) ,
INTEL_G45_IDS ( & g45_info ) ,
INTEL_PINEVIEW_G_IDS ( & pnv_g_info ) ,
INTEL_PINEVIEW_M_IDS ( & pnv_m_info ) ,
INTEL_IRONLAKE_D_IDS ( & ilk_d_info ) ,
INTEL_IRONLAKE_M_IDS ( & ilk_m_info ) ,
INTEL_SNB_D_GT1_IDS ( & snb_d_gt1_info ) ,
INTEL_SNB_D_GT2_IDS ( & snb_d_gt2_info ) ,
INTEL_SNB_M_GT1_IDS ( & snb_m_gt1_info ) ,
INTEL_SNB_M_GT2_IDS ( & snb_m_gt2_info ) ,
INTEL_IVB_Q_IDS ( & ivb_q_info ) , /* must be first IVB */
INTEL_IVB_M_GT1_IDS ( & ivb_m_gt1_info ) ,
INTEL_IVB_M_GT2_IDS ( & ivb_m_gt2_info ) ,
INTEL_IVB_D_GT1_IDS ( & ivb_d_gt1_info ) ,
INTEL_IVB_D_GT2_IDS ( & ivb_d_gt2_info ) ,
INTEL_HSW_GT1_IDS ( & hsw_gt1_info ) ,
INTEL_HSW_GT2_IDS ( & hsw_gt2_info ) ,
INTEL_HSW_GT3_IDS ( & hsw_gt3_info ) ,
INTEL_VLV_IDS ( & vlv_info ) ,
INTEL_BDW_GT1_IDS ( & bdw_gt1_info ) ,
INTEL_BDW_GT2_IDS ( & bdw_gt2_info ) ,
INTEL_BDW_GT3_IDS ( & bdw_gt3_info ) ,
INTEL_BDW_RSVD_IDS ( & bdw_rsvd_info ) ,
INTEL_CHV_IDS ( & chv_info ) ,
INTEL_SKL_GT1_IDS ( & skl_gt1_info ) ,
INTEL_SKL_GT2_IDS ( & skl_gt2_info ) ,
INTEL_SKL_GT3_IDS ( & skl_gt3_info ) ,
INTEL_SKL_GT4_IDS ( & skl_gt4_info ) ,
INTEL_BXT_IDS ( & bxt_info ) ,
INTEL_GLK_IDS ( & glk_info ) ,
INTEL_KBL_GT1_IDS ( & kbl_gt1_info ) ,
INTEL_KBL_GT2_IDS ( & kbl_gt2_info ) ,
INTEL_KBL_GT3_IDS ( & kbl_gt3_info ) ,
INTEL_KBL_GT4_IDS ( & kbl_gt3_info ) ,
INTEL_AML_KBL_GT2_IDS ( & kbl_gt2_info ) ,
INTEL_CFL_S_GT1_IDS ( & cfl_gt1_info ) ,
INTEL_CFL_S_GT2_IDS ( & cfl_gt2_info ) ,
INTEL_CFL_H_GT1_IDS ( & cfl_gt1_info ) ,
INTEL_CFL_H_GT2_IDS ( & cfl_gt2_info ) ,
INTEL_CFL_U_GT2_IDS ( & cfl_gt2_info ) ,
INTEL_CFL_U_GT3_IDS ( & cfl_gt3_info ) ,
INTEL_WHL_U_GT1_IDS ( & cfl_gt1_info ) ,
INTEL_WHL_U_GT2_IDS ( & cfl_gt2_info ) ,
INTEL_AML_CFL_GT2_IDS ( & cfl_gt2_info ) ,
INTEL_WHL_U_GT3_IDS ( & cfl_gt3_info ) ,
2020-06-02 15:05:40 +01:00
INTEL_CML_GT1_IDS ( & cml_gt1_info ) ,
INTEL_CML_GT2_IDS ( & cml_gt2_info ) ,
INTEL_CML_U_GT1_IDS ( & cml_gt1_info ) ,
INTEL_CML_U_GT2_IDS ( & cml_gt2_info ) ,
2019-12-24 00:40:03 -08:00
INTEL_ICL_11_IDS ( & icl_info ) ,
INTEL_EHL_IDS ( & ehl_info ) ,
2020-10-14 00:59:48 +05:30
INTEL_JSL_IDS ( & jsl_info ) ,
2019-12-24 00:40:03 -08:00
INTEL_TGL_12_IDS ( & tgl_info ) ,
2020-05-04 15:52:06 -07:00
INTEL_RKL_IDS ( & rkl_info ) ,
2021-01-19 11:29:31 -08:00
INTEL_ADLS_IDS ( & adl_s_info ) ,
2021-05-06 19:19:23 +03:00
INTEL_ADLP_IDS ( & adl_p_info ) ,
2021-12-10 10:48:02 +05:30
INTEL_ADLN_IDS ( & adl_p_info ) ,
2021-08-12 14:44:52 +02:00
INTEL_DG1_IDS ( & dg1_info ) ,
2021-12-02 22:35:43 -08:00
INTEL_RPLS_IDS ( & adl_s_info ) ,
2016-06-24 14:00:26 +01:00
{ 0 , 0 , 0 }
} ;
MODULE_DEVICE_TABLE ( pci , pciidlist ) ;
2017-02-13 17:15:12 +00:00
static void i915_pci_remove ( struct pci_dev * pdev )
{
2019-08-06 08:42:19 +01:00
struct drm_i915_private * i915 ;
2018-07-16 09:03:31 +01:00
2019-08-06 08:42:19 +01:00
i915 = pci_get_drvdata ( pdev ) ;
if ( ! i915 ) /* driver load aborted, nothing to cleanup */
2018-07-16 09:03:31 +01:00
return ;
2017-02-13 17:15:12 +00:00
2019-08-06 08:42:19 +01:00
i915_driver_remove ( i915 ) ;
2018-07-16 09:03:31 +01:00
pci_set_drvdata ( pdev , NULL ) ;
2017-02-13 17:15:12 +00:00
}
2019-05-06 16:48:01 +03:00
/* is device_id present in comma separated list of ids */
static bool force_probe ( u16 device_id , const char * devices )
{
char * s , * p , * tok ;
bool ret ;
if ( ! devices | | ! * devices )
return false ;
/* match everything */
if ( strcmp ( devices , " * " ) = = 0 )
return true ;
s = kstrdup ( devices , GFP_KERNEL ) ;
if ( ! s )
return false ;
for ( p = s , ret = false ; ( tok = strsep ( & p , " , " ) ) ! = NULL ; ) {
u16 val ;
if ( kstrtou16 ( tok , 16 , & val ) = = 0 & & val = = device_id ) {
ret = true ;
break ;
}
}
kfree ( s ) ;
return ret ;
}
2016-06-24 14:00:26 +01:00
static int i915_pci_probe ( struct pci_dev * pdev , const struct pci_device_id * ent )
{
struct intel_device_info * intel_info =
( struct intel_device_info * ) ent - > driver_data ;
2017-02-13 17:15:12 +00:00
int err ;
2016-06-24 14:00:26 +01:00
2019-05-06 16:48:01 +03:00
if ( intel_info - > require_force_probe & &
! force_probe ( pdev - > device , i915_modparams . force_probe ) ) {
2020-02-07 13:50:48 +00:00
dev_info ( & pdev - > dev ,
2020-01-31 12:34:16 +03:00
" Your graphics device %04x is not properly supported by the driver in this \n "
2019-05-06 16:48:01 +03:00
" kernel version. To force driver probe anyway, use i915.force_probe=%04x \n "
" module parameter or CONFIG_DRM_I915_FORCE_PROBE=%04x configuration option, \n "
" or (recommended) check for kernel updates. \n " ,
pdev - > device , pdev - > device , pdev - > device ) ;
2016-06-24 14:00:26 +01:00
return - ENODEV ;
}
/* Only bind to function 0 of the device. Early generations
* used function 1 as a placeholder for multi - head . This causes
* us confusion instead , especially on the systems where both
* functions have the same PCI - ID !
*/
if ( PCI_FUNC ( pdev - > devfn ) )
return - ENODEV ;
2021-10-05 22:23:21 +02:00
/* Detect if we need to wait for other drivers early on */
if ( intel_modeset_probe_defer ( pdev ) )
2016-06-24 14:00:26 +01:00
return - EPROBE_DEFER ;
2019-07-12 13:24:26 +02:00
err = i915_driver_probe ( pdev , ent ) ;
2017-02-13 17:15:12 +00:00
if ( err )
return err ;
2016-06-24 14:00:26 +01:00
2019-08-06 08:42:19 +01:00
if ( i915_inject_probe_failure ( pci_get_drvdata ( pdev ) ) ) {
2018-07-16 09:03:31 +01:00
i915_pci_remove ( pdev ) ;
return - ENODEV ;
}
2017-02-13 17:15:12 +00:00
err = i915_live_selftests ( pdev ) ;
if ( err ) {
i915_pci_remove ( pdev ) ;
return err > 0 ? - ENOTTY : err ;
}
2016-06-24 14:00:26 +01:00
2019-11-11 17:27:16 +00:00
err = i915_perf_selftests ( pdev ) ;
if ( err ) {
i915_pci_remove ( pdev ) ;
return err > 0 ? - ENOTTY : err ;
}
2017-02-13 17:15:12 +00:00
return 0 ;
2016-06-24 14:00:26 +01:00
}
2020-10-01 18:16:35 +03:00
static void i915_pci_shutdown ( struct pci_dev * pdev )
{
struct drm_i915_private * i915 = pci_get_drvdata ( pdev ) ;
i915_driver_shutdown ( i915 ) ;
}
2016-06-24 14:00:27 +01:00
static struct pci_driver i915_pci_driver = {
2016-06-24 14:00:26 +01:00
. name = DRIVER_NAME ,
. id_table = pciidlist ,
. probe = i915_pci_probe ,
. remove = i915_pci_remove ,
2020-10-01 18:16:35 +03:00
. shutdown = i915_pci_shutdown ,
2016-06-24 14:00:26 +01:00
. driver . pm = & i915_pm_ops ,
} ;
2016-06-24 14:00:27 +01:00
2021-08-25 18:06:23 +03:00
int i915_pci_register_driver ( void )
2016-06-24 14:00:27 +01:00
{
drm/i915: Use a table for i915_init/exit (v2)
If the driver was not fully loaded, we may still have globals lying
around. If we don't tear those down in i915_exit(), we'll leak a bunch
of memory slabs. This can happen two ways: use_kms = false and if we've
run mock selftests. In either case, we have an early exit from
i915_init which happens after i915_globals_init() and we need to clean
up those globals.
The mock selftests case is especially sticky. The load isn't entirely
a no-op. We actually do quite a bit inside those selftests including
allocating a bunch of mock objects and running tests on them. Once all
those tests are complete, we exit early from i915_init(). Perviously,
i915_init() would return a non-zero error code on failure and a zero
error code on success. In the success case, we would get to i915_exit()
and check i915_pci_driver.driver.owner to detect if i915_init exited early
and do nothing. In the failure case, we would fail i915_init() but
there would be no opportunity to clean up globals.
The most annoying part is that you don't actually notice the failure as
part of the self-tests since leaking a bit of memory, while bad, doesn't
result in anything observable from userspace. Instead, the next time we
load the driver (usually for next IGT test), i915_globals_init() gets
invoked again, we go to allocate a bunch of new memory slabs, those
implicitly create debugfs entries, and debugfs warns that we're trying
to create directories and files that already exist. Since this all
happens as part of the next driver load, it shows up in the dmesg-warn
of whatever IGT test ran after the mock selftests.
While the obvious thing to do here might be to call i915_globals_exit()
after selftests, that's not actually safe. The dma-buf selftests call
i915_gem_prime_export which creates a file. We call dma_buf_put() on
the resulting dmabuf which calls fput() on the file. However, fput()
isn't immediate and gets flushed right before syscall returns. This
means that all the fput()s from the selftests don't happen until right
before the module load syscall used to fire off the selftests returns
which is after i915_init(). If we call i915_globals_exit() in
i915_init() after selftests, we end up freeing slabs out from under
objects which won't get released until fput() is flushed at the end of
the module load syscall.
The solution here is to let i915_init() return success early and detect
the early success in i915_exit() and only tear down globals and nothing
else. This way the module loads successfully, regardless of the success
or failure of the tests. Because we've not enumerated any PCI devices,
no device nodes are created and it's entirely useless from userspace.
The only thing the module does at that point is hold on to a bit of
memory until we unload it and i915_exit() is called. Importantly, this
means that everything from our selftests has the ability to properly
flush out between i915_init() and i915_exit() because there is at least
one syscall boundary in between.
In order to handle all the delicate init/exit cases, we convert the
whole thing to a table of init/exit pairs and track the init status in
the new init_progress global. This allows us to ensure that i915_exit()
always tears down exactly the things that i915_init() successfully
initialized. We also allow early-exit of i915_init() without failure by
an init function returning > 0. This is useful for nomodeset, and
selftests. For the mock selftests, we convert them to always return 1
so we get the desired behavior of the driver always succeeding to load
the driver and then properly tearing down the partially loaded driver.
v2 (Tvrtko Ursulin):
- Guard init_funcs[i].exit with GEM_BUG_ON(i >= ARRAY_SIZE(init_funcs))
v2 (Daniel Vetter):
- Update the docstring for i915.mock_selftests
Signed-off-by: Jason Ekstrand <jason@jlekstrand.net>
Reviewed-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Cc: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Link: https://patchwork.freedesktop.org/patch/msgid/20210721152358.2893314-4-jason@jlekstrand.net
2021-07-21 10:23:55 -05:00
return pci_register_driver ( & i915_pci_driver ) ;
2016-06-24 14:00:27 +01:00
}
2021-08-25 18:06:23 +03:00
void i915_pci_unregister_driver ( void )
2016-06-24 14:00:27 +01:00
{
pci_unregister_driver ( & i915_pci_driver ) ;
}