Commit ce22dece authored by Matt Roper's avatar Matt Roper Committed by Rodrigo Vivi

drm/xe: Move most platform traits to graphics IP

Most of the traits currently in the device descriptor structures are
either tied to the graphics IP or should be inferred from the graphics
IP.  This becomes important on MTL and beyond where IP versions are
supposed to be detected from the hardware's GMD_ID registers rather than
mapped from PCI devid.

Engine masks are left where they are for now; they'll be dealt with
separately in a future patch.
Reviewed-by: default avatarLucas De Marchi <lucas.demarchi@intel.com>
Link: https://lore.kernel.org/r/20230406235621.1914492-4-matthew.d.roper@intel.comSigned-off-by: default avatarMatt Roper <matthew.d.roper@intel.com>
Signed-off-by: default avatarRodrigo Vivi <rodrigo.vivi@intel.com>
parent c94f32e4
...@@ -53,24 +53,18 @@ struct xe_device_desc { ...@@ -53,24 +53,18 @@ struct xe_device_desc {
const struct xe_subplatform_desc *subplatforms; const struct xe_subplatform_desc *subplatforms;
const struct xe_gt_desc *extra_gts; const struct xe_gt_desc *extra_gts;
u8 dma_mask_size; /* available DMA address bits */
u8 gt; /* GT number, 0 if undefined */ u8 gt; /* GT number, 0 if undefined */
#define DEFINE_FLAG(name) u8 name:1 #define DEFINE_FLAG(name) u8 name:1
DEV_INFO_FOR_EACH_FLAG(DEFINE_FLAG); DEV_INFO_FOR_EACH_FLAG(DEFINE_FLAG);
#undef DEFINE_FLAG #undef DEFINE_FLAG
u8 vram_flags; /*
u8 max_tiles; * FIXME: Xe doesn't care about presence/lack of 4tile since we can
u8 vm_max_level; * already determine that from the graphics IP version. This flag
* should eventually move entirely into the display code's own logic.
bool supports_usm; */
bool has_flat_ccs;
bool has_4tile; bool has_4tile;
bool has_range_tlb_invalidation;
bool has_asid;
bool has_link_copy_engine;
}; };
#define PLATFORM(x) \ #define PLATFORM(x) \
...@@ -82,26 +76,57 @@ struct xe_device_desc { ...@@ -82,26 +76,57 @@ struct xe_device_desc {
static const struct xe_graphics_desc graphics_xelp = { static const struct xe_graphics_desc graphics_xelp = {
.ver = 12, .ver = 12,
.rel = 0, .rel = 0,
.dma_mask_size = 39,
.vm_max_level = 3,
}; };
static const struct xe_graphics_desc graphics_xelpp = { static const struct xe_graphics_desc graphics_xelpp = {
.ver = 12, .ver = 12,
.rel = 10, .rel = 10,
.dma_mask_size = 39,
.vm_max_level = 3,
}; };
#define XE_HP_FEATURES \
.has_range_tlb_invalidation = true, \
.has_flat_ccs = true, \
.dma_mask_size = 46, \
.vm_max_level = 3
static const struct xe_graphics_desc graphics_xehpg = { static const struct xe_graphics_desc graphics_xehpg = {
.ver = 12, .ver = 12,
.rel = 55, .rel = 55,
XE_HP_FEATURES,
.vram_flags = XE_VRAM_FLAGS_NEED64K,
}; };
static const struct xe_graphics_desc graphics_xehpc = { static const struct xe_graphics_desc graphics_xehpc = {
.ver = 12, .ver = 12,
.rel = 60, .rel = 60,
XE_HP_FEATURES,
.dma_mask_size = 52,
.max_tiles = 2,
.vm_max_level = 4,
.vram_flags = XE_VRAM_FLAGS_NEED64K,
.has_asid = 1,
.has_flat_ccs = 0,
.has_link_copy_engine = 1,
.supports_usm = 1,
}; };
static const struct xe_graphics_desc graphics_xelpg = { static const struct xe_graphics_desc graphics_xelpg = {
.ver = 12, .ver = 12,
.rel = 70, .rel = 70,
XE_HP_FEATURES,
.max_tiles = 2,
.has_flat_ccs = 0,
}; };
static const struct xe_media_desc media_xem = { static const struct xe_media_desc media_xem = {
...@@ -119,17 +144,9 @@ static const struct xe_media_desc media_xelpmp = { ...@@ -119,17 +144,9 @@ static const struct xe_media_desc media_xelpmp = {
.rel = 0, .rel = 0,
}; };
/* Keep in gen based order, and chronological order within a gen */
#define GEN12_FEATURES \
.dma_mask_size = 39, \
.max_tiles = 1, \
.vm_max_level = 3, \
.vram_flags = 0
static const struct xe_device_desc tgl_desc = { static const struct xe_device_desc tgl_desc = {
.graphics = &graphics_xelp, .graphics = &graphics_xelp,
.media = &media_xem, .media = &media_xem,
GEN12_FEATURES,
PLATFORM(XE_TIGERLAKE), PLATFORM(XE_TIGERLAKE),
.require_force_probe = true, .require_force_probe = true,
.platform_engine_mask = .platform_engine_mask =
...@@ -141,7 +158,6 @@ static const struct xe_device_desc tgl_desc = { ...@@ -141,7 +158,6 @@ static const struct xe_device_desc tgl_desc = {
static const struct xe_device_desc adl_s_desc = { static const struct xe_device_desc adl_s_desc = {
.graphics = &graphics_xelp, .graphics = &graphics_xelp,
.media = &media_xem, .media = &media_xem,
GEN12_FEATURES,
PLATFORM(XE_ALDERLAKE_S), PLATFORM(XE_ALDERLAKE_S),
.require_force_probe = true, .require_force_probe = true,
.platform_engine_mask = .platform_engine_mask =
...@@ -155,7 +171,6 @@ static const u16 adlp_rplu_ids[] = { XE_RPLU_IDS(NOP), 0 }; ...@@ -155,7 +171,6 @@ static const u16 adlp_rplu_ids[] = { XE_RPLU_IDS(NOP), 0 };
static const struct xe_device_desc adl_p_desc = { static const struct xe_device_desc adl_p_desc = {
.graphics = &graphics_xelp, .graphics = &graphics_xelp,
.media = &media_xem, .media = &media_xem,
GEN12_FEATURES,
PLATFORM(XE_ALDERLAKE_P), PLATFORM(XE_ALDERLAKE_P),
.require_force_probe = true, .require_force_probe = true,
.platform_engine_mask = .platform_engine_mask =
...@@ -174,7 +189,6 @@ static const struct xe_device_desc adl_p_desc = { ...@@ -174,7 +189,6 @@ static const struct xe_device_desc adl_p_desc = {
static const struct xe_device_desc dg1_desc = { static const struct xe_device_desc dg1_desc = {
.graphics = &graphics_xelpp, .graphics = &graphics_xelpp,
.media = &media_xem, .media = &media_xem,
GEN12_FEATURES,
DGFX_FEATURES, DGFX_FEATURES,
PLATFORM(XE_DG1), PLATFORM(XE_DG1),
.require_force_probe = true, .require_force_probe = true,
...@@ -184,13 +198,6 @@ static const struct xe_device_desc dg1_desc = { ...@@ -184,13 +198,6 @@ static const struct xe_device_desc dg1_desc = {
BIT(XE_HW_ENGINE_VCS2), BIT(XE_HW_ENGINE_VCS2),
}; };
#define XE_HP_FEATURES \
.has_range_tlb_invalidation = true, \
.has_flat_ccs = true, \
.dma_mask_size = 46, \
.max_tiles = 1, \
.vm_max_level = 3
static const u16 dg2_g10_ids[] = { XE_DG2_G10_IDS(NOP), XE_ATS_M150_IDS(NOP), 0 }; static const u16 dg2_g10_ids[] = { XE_DG2_G10_IDS(NOP), XE_ATS_M150_IDS(NOP), 0 };
static const u16 dg2_g11_ids[] = { XE_DG2_G11_IDS(NOP), XE_ATS_M75_IDS(NOP), 0 }; static const u16 dg2_g11_ids[] = { XE_DG2_G11_IDS(NOP), XE_ATS_M75_IDS(NOP), 0 };
static const u16 dg2_g12_ids[] = { XE_DG2_G12_IDS(NOP), 0 }; static const u16 dg2_g12_ids[] = { XE_DG2_G12_IDS(NOP), 0 };
...@@ -210,14 +217,12 @@ static const u16 dg2_g12_ids[] = { XE_DG2_G12_IDS(NOP), 0 }; ...@@ -210,14 +217,12 @@ static const u16 dg2_g12_ids[] = { XE_DG2_G12_IDS(NOP), 0 };
BIT(XE_HW_ENGINE_VCS0) | BIT(XE_HW_ENGINE_VCS2) | \ BIT(XE_HW_ENGINE_VCS0) | BIT(XE_HW_ENGINE_VCS2) | \
BIT(XE_HW_ENGINE_CCS0) | BIT(XE_HW_ENGINE_CCS1) | \ BIT(XE_HW_ENGINE_CCS0) | BIT(XE_HW_ENGINE_CCS1) | \
BIT(XE_HW_ENGINE_CCS2) | BIT(XE_HW_ENGINE_CCS3), \ BIT(XE_HW_ENGINE_CCS2) | BIT(XE_HW_ENGINE_CCS3), \
.vram_flags = XE_VRAM_FLAGS_NEED64K, \
.has_4tile = 1 .has_4tile = 1
static const struct xe_device_desc ats_m_desc = { static const struct xe_device_desc ats_m_desc = {
.graphics = &graphics_xehpg, .graphics = &graphics_xehpg,
.media = &media_xehpm, .media = &media_xehpm,
.require_force_probe = true, .require_force_probe = true,
XE_HP_FEATURES,
DG2_FEATURES, DG2_FEATURES,
}; };
...@@ -226,7 +231,6 @@ static const struct xe_device_desc dg2_desc = { ...@@ -226,7 +231,6 @@ static const struct xe_device_desc dg2_desc = {
.graphics = &graphics_xehpg, .graphics = &graphics_xehpg,
.media = &media_xehpm, .media = &media_xehpm,
.require_force_probe = true, .require_force_probe = true,
XE_HP_FEATURES,
DG2_FEATURES, DG2_FEATURES,
}; };
...@@ -254,20 +258,11 @@ static const struct xe_gt_desc pvc_gts[] = { ...@@ -254,20 +258,11 @@ static const struct xe_gt_desc pvc_gts[] = {
static const __maybe_unused struct xe_device_desc pvc_desc = { static const __maybe_unused struct xe_device_desc pvc_desc = {
.graphics = &graphics_xehpc, .graphics = &graphics_xehpc,
XE_HP_FEATURES,
DGFX_FEATURES, DGFX_FEATURES,
PLATFORM(XE_PVC), PLATFORM(XE_PVC),
.require_force_probe = true, .require_force_probe = true,
.extra_gts = pvc_gts, .extra_gts = pvc_gts,
.has_flat_ccs = 0,
.platform_engine_mask = PVC_ENGINES, .platform_engine_mask = PVC_ENGINES,
.vram_flags = XE_VRAM_FLAGS_NEED64K,
.dma_mask_size = 52,
.max_tiles = 2,
.vm_max_level = 4,
.supports_usm = true,
.has_asid = true,
.has_link_copy_engine = true,
}; };
#define MTL_MEDIA_ENGINES \ #define MTL_MEDIA_ENGINES \
...@@ -296,10 +291,6 @@ static const struct xe_device_desc mtl_desc = { ...@@ -296,10 +291,6 @@ static const struct xe_device_desc mtl_desc = {
.graphics = &graphics_xelpg, .graphics = &graphics_xelpg,
.media = &media_xelpmp, .media = &media_xelpmp,
.require_force_probe = true, .require_force_probe = true,
.dma_mask_size = 46,
.max_tiles = 2,
.vm_max_level = 3,
.has_range_tlb_invalidation = true,
PLATFORM(XE_METEORLAKE), PLATFORM(XE_METEORLAKE),
.extra_gts = xelpmp_gts, .extra_gts = xelpmp_gts,
.platform_engine_mask = MTL_MAIN_ENGINES, .platform_engine_mask = MTL_MAIN_ENGINES,
...@@ -409,16 +400,16 @@ static void xe_info_init(struct xe_device *xe, ...@@ -409,16 +400,16 @@ static void xe_info_init(struct xe_device *xe,
desc->media->rel; desc->media->rel;
xe->info.is_dgfx = desc->is_dgfx; xe->info.is_dgfx = desc->is_dgfx;
xe->info.platform = desc->platform; xe->info.platform = desc->platform;
xe->info.dma_mask_size = desc->dma_mask_size; xe->info.dma_mask_size = desc->graphics->dma_mask_size;
xe->info.vram_flags = desc->vram_flags; xe->info.vram_flags = desc->graphics->vram_flags;
xe->info.tile_count = desc->max_tiles; xe->info.tile_count = desc->graphics->max_tiles ?: 1;
xe->info.vm_max_level = desc->vm_max_level; xe->info.vm_max_level = desc->graphics->vm_max_level;
xe->info.supports_usm = desc->supports_usm; xe->info.supports_usm = desc->graphics->supports_usm;
xe->info.has_asid = desc->has_asid; xe->info.has_asid = desc->graphics->has_asid;
xe->info.has_flat_ccs = desc->has_flat_ccs; xe->info.has_flat_ccs = desc->graphics->has_flat_ccs;
xe->info.has_4tile = desc->has_4tile; xe->info.has_4tile = desc->has_4tile;
xe->info.has_range_tlb_invalidation = desc->has_range_tlb_invalidation; xe->info.has_range_tlb_invalidation = desc->graphics->has_range_tlb_invalidation;
xe->info.has_link_copy_engine = desc->has_link_copy_engine; xe->info.has_link_copy_engine = desc->graphics->has_link_copy_engine;
xe->info.subplatform = subplatform_desc ? xe->info.subplatform = subplatform_desc ?
subplatform_desc->subplatform : XE_SUBPLATFORM_NONE; subplatform_desc->subplatform : XE_SUBPLATFORM_NONE;
......
...@@ -11,6 +11,17 @@ ...@@ -11,6 +11,17 @@
struct xe_graphics_desc { struct xe_graphics_desc {
u8 ver; u8 ver;
u8 rel; u8 rel;
u8 dma_mask_size; /* available DMA address bits */
u8 max_tiles; /* defaults to 1 if unset */
u8 vm_max_level;
u8 vram_flags;
u8 has_asid:1;
u8 has_flat_ccs:1;
u8 has_link_copy_engine:1;
u8 has_range_tlb_invalidation:1;
u8 supports_usm:1;
}; };
struct xe_media_desc { struct xe_media_desc {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment