From: Tvrtko Ursulin <tvrtko.ursulin@xxxxxxxxx> Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@xxxxxxxxx> --- drivers/gpu/drm/i915/Kconfig.platforms | 51 ++++++++++++++++++++++++++ drivers/gpu/drm/i915/i915_drv.h | 22 ++++++----- drivers/gpu/drm/i915/i915_pci.c | 28 +++++++++++++- 3 files changed, 90 insertions(+), 11 deletions(-) diff --git a/drivers/gpu/drm/i915/Kconfig.platforms b/drivers/gpu/drm/i915/Kconfig.platforms index 23a44c8eb07b..1fa09884a290 100644 --- a/drivers/gpu/drm/i915/Kconfig.platforms +++ b/drivers/gpu/drm/i915/Kconfig.platforms @@ -32,3 +32,54 @@ config DRM_I915_PLATFORM_INTEL_I865G select DRM_I915_GEN2 help Include support for Intel i865G platform. + +config DRM_I915_GEN3 + bool + +config DRM_I915_PLATFORM_INTEL_I915G + bool "Intel i915G platform support" + default y + depends on DRM_I915 + select DRM_I915_GEN3 + help + Include support for Intel i915G platform. + +config DRM_I915_PLATFORM_INTEL_I915GM + bool "Intel i915GM platform support" + default y + depends on DRM_I915 + select DRM_I915_GEN3 + help + Include support for Intel i915GM platform. + +config DRM_I915_PLATFORM_INTEL_I945G + bool "Intel i945G platform support" + default y + depends on DRM_I915 + select DRM_I915_GEN3 + help + Include support for Intel i945G platform. + +config DRM_I915_PLATFORM_INTEL_I945GM + bool "Intel i945GM platform support" + default y + depends on DRM_I915 + select DRM_I915_GEN3 + help + Include support for Intel i945GM platform. + +config DRM_I915_PLATFORM_INTEL_G33 + bool "Intel G33 platform support" + default y + depends on DRM_I915 + select DRM_I915_GEN3 + help + Include support for Intel G33 platform. + +config DRM_I915_PLATFORM_INTEL_PINEVIEW + bool "Intel Pineview platform support" + default y + depends on DRM_I915 + select DRM_I915_GEN3 + help + Include support for Intel Pineview platform. diff --git a/drivers/gpu/drm/i915/i915_drv.h b/drivers/gpu/drm/i915/i915_drv.h index f718655294ea..949a8bf54d55 100644 --- a/drivers/gpu/drm/i915/i915_drv.h +++ b/drivers/gpu/drm/i915/i915_drv.h @@ -2582,19 +2582,21 @@ intel_info(const struct drm_i915_private *dev_priv) #define IS_I845G(dev_priv) IS_OPT_PLATFORM(dev_priv, INTEL_I845G) #define IS_I85X(dev_priv) IS_OPT_PLATFORM(dev_priv, INTEL_I85X) #define IS_I865G(dev_priv) IS_OPT_PLATFORM(dev_priv, INTEL_I865G) -#define IS_I915G(dev_priv) IS_PLATFORM(dev_priv, INTEL_I915G) -#define IS_I915GM(dev_priv) IS_PLATFORM(dev_priv, INTEL_I915GM) -#define IS_I945G(dev_priv) IS_PLATFORM(dev_priv, INTEL_I945G) -#define IS_I945GM(dev_priv) IS_PLATFORM(dev_priv, INTEL_I945GM) +#define IS_I915G(dev_priv) IS_OPT_PLATFORM(dev_priv, INTEL_I915G) +#define IS_I915GM(dev_priv) IS_OPT_PLATFORM(dev_priv, INTEL_I915GM) +#define IS_I945G(dev_priv) IS_OPT_PLATFORM(dev_priv, INTEL_I945G) +#define IS_I945GM(dev_priv) IS_OPT_PLATFORM(dev_priv, INTEL_I945GM) #define IS_I965G(dev_priv) IS_PLATFORM(dev_priv, INTEL_I965G) #define IS_I965GM(dev_priv) IS_PLATFORM(dev_priv, INTEL_I965GM) #define IS_G45(dev_priv) IS_PLATFORM(dev_priv, INTEL_G45) #define IS_GM45(dev_priv) IS_PLATFORM(dev_priv, INTEL_GM45) #define IS_G4X(dev_priv) (IS_G45(dev_priv) || IS_GM45(dev_priv)) -#define IS_PINEVIEW_G(dev_priv) (INTEL_DEVID(dev_priv) == 0xa001) -#define IS_PINEVIEW_M(dev_priv) (INTEL_DEVID(dev_priv) == 0xa011) -#define IS_PINEVIEW(dev_priv) IS_PLATFORM(dev_priv, INTEL_PINEVIEW) -#define IS_G33(dev_priv) IS_PLATFORM(dev_priv, INTEL_G33) +#define IS_PINEVIEW_G(dev_priv) (IS_OPT_PLATFORM(dev_priv, INTEL_PINEVIEW) && \ + (INTEL_DEVID(dev_priv) == 0xa001)) +#define IS_PINEVIEW_M(dev_priv) (IS_OPT_PLATFORM(dev_priv, INTEL_PINEVIEW) && \ + (INTEL_DEVID(dev_priv) == 0xa011)) +#define IS_PINEVIEW(dev_priv) IS_OPT_PLATFORM(dev_priv, INTEL_PINEVIEW) +#define IS_G33(dev_priv) IS_OPT_PLATFORM(dev_priv, INTEL_G33) #define IS_IRONLAKE_M(dev_priv) (INTEL_DEVID(dev_priv) == 0x0046) #define IS_IVYBRIDGE(dev_priv) IS_PLATFORM(dev_priv, INTEL_IVYBRIDGE) #define IS_IVB_GT1(dev_priv) (IS_IVYBRIDGE(dev_priv) && \ @@ -2717,7 +2719,9 @@ intel_info(const struct drm_i915_private *dev_priv) #define IS_GEN2(dev_priv) \ (IS_ENABLED(CONFIG_DRM_I915_GEN2) && \ ((dev_priv)->info.gen_mask & BIT(1))) -#define IS_GEN3(dev_priv) (!!((dev_priv)->info.gen_mask & BIT(2))) +#define IS_GEN3(dev_priv) \ + (IS_ENABLED(CONFIG_DRM_I915_GEN3) && \ + ((dev_priv)->info.gen_mask & BIT(2))) #define IS_GEN4(dev_priv) (!!((dev_priv)->info.gen_mask & BIT(3))) #define IS_GEN5(dev_priv) (!!((dev_priv)->info.gen_mask & BIT(4))) #define IS_GEN6(dev_priv) (!!((dev_priv)->info.gen_mask & BIT(5))) diff --git a/drivers/gpu/drm/i915/i915_pci.c b/drivers/gpu/drm/i915/i915_pci.c index 9f5054c009b6..9b47cba66d3d 100644 --- a/drivers/gpu/drm/i915/i915_pci.c +++ b/drivers/gpu/drm/i915/i915_pci.c @@ -116,6 +116,7 @@ static const struct intel_device_info intel_i865g_info = { GEN_DEFAULT_PAGE_SIZES, \ CURSOR_OFFSETS +#ifdef CONFIG_DRM_I915_PLATFORM_INTEL_I915G static const struct intel_device_info intel_i915g_info = { GEN3_FEATURES, .platform = INTEL_I915G, .cursor_needs_physical = 1, @@ -123,7 +124,9 @@ static const struct intel_device_info intel_i915g_info = { .hws_needs_physical = 1, .unfenced_needs_alignment = 1, }; +#endif +#ifdef CONFIG_DRM_I915_PLATFORM_INTEL_I915GM static const struct intel_device_info intel_i915gm_info = { GEN3_FEATURES, .platform = INTEL_I915GM, @@ -135,7 +138,9 @@ static const struct intel_device_info intel_i915gm_info = { .hws_needs_physical = 1, .unfenced_needs_alignment = 1, }; +#endif +#ifdef CONFIG_DRM_I915_PLATFORM_INTEL_I945G static const struct intel_device_info intel_i945g_info = { GEN3_FEATURES, .platform = INTEL_I945G, @@ -144,7 +149,9 @@ static const struct intel_device_info intel_i945g_info = { .hws_needs_physical = 1, .unfenced_needs_alignment = 1, }; +#endif +#ifdef CONFIG_DRM_I915_PLATFORM_INTEL_I945GM static const struct intel_device_info intel_i945gm_info = { GEN3_FEATURES, .platform = INTEL_I945GM, .is_mobile = 1, @@ -155,20 +162,25 @@ static const struct intel_device_info intel_i945gm_info = { .hws_needs_physical = 1, .unfenced_needs_alignment = 1, }; +#endif +#ifdef CONFIG_DRM_I915_PLATFORM_INTEL_G33 static const struct intel_device_info intel_g33_info = { GEN3_FEATURES, .platform = INTEL_G33, .has_hotplug = 1, .has_overlay = 1, }; +#endif +#ifdef CONFIG_DRM_I915_PLATFORM_INTEL_PINEVIEW static const struct intel_device_info intel_pineview_info = { GEN3_FEATURES, .platform = INTEL_PINEVIEW, .is_mobile = 1, .has_hotplug = 1, .has_overlay = 1, }; +#endif #define GEN4_FEATURES \ .gen = 4, .num_pipes = 2, \ @@ -619,16 +631,28 @@ static const struct pci_device_id pciidlist[] = { #ifdef CONFIG_DRM_I915_PLATFORM_INTEL_I865G INTEL_I865G_IDS(&intel_i865g_info), #endif +#ifdef CONFIG_DRM_I915_PLATFORM_INTEL_I915G INTEL_I915G_IDS(&intel_i915g_info), +#endif +#ifdef CONFIG_DRM_I915_PLATFORM_INTEL_I915GM INTEL_I915GM_IDS(&intel_i915gm_info), +#endif +#ifdef CONFIG_DRM_I915_PLATFORM_INTEL_I945G INTEL_I945G_IDS(&intel_i945g_info), +#endif +#ifdef CONFIG_DRM_I915_PLATFORM_INTEL_I945GM INTEL_I945GM_IDS(&intel_i945gm_info), - INTEL_I965G_IDS(&intel_i965g_info), +#endif +#ifdef CONFIG_DRM_I915_PLATFORM_INTEL_G33 INTEL_G33_IDS(&intel_g33_info), +#endif +#ifdef CONFIG_DRM_I915_PLATFORM_INTEL_PINEVIEW + INTEL_PINEVIEW_IDS(&intel_pineview_info), +#endif + INTEL_I965G_IDS(&intel_i965g_info), INTEL_I965GM_IDS(&intel_i965gm_info), INTEL_GM45_IDS(&intel_gm45_info), INTEL_G45_IDS(&intel_g45_info), - INTEL_PINEVIEW_IDS(&intel_pineview_info), INTEL_IRONLAKE_D_IDS(&intel_ironlake_d_info), INTEL_IRONLAKE_M_IDS(&intel_ironlake_m_info), INTEL_SNB_D_GT1_IDS(&intel_sandybridge_d_gt1_info), -- 2.27.0 _______________________________________________ Intel-gfx mailing list Intel-gfx@xxxxxxxxxxxxxxxxxxxxx https://lists.freedesktop.org/mailman/listinfo/intel-gfx