drm/i915/tgl: Simply subplatform detection
authorJosé Roberto de Souza <jose.souza@intel.com>
Tue, 22 Feb 2022 14:14:24 +0000 (06:14 -0800)
committerJosé Roberto de Souza <jose.souza@intel.com>
Wed, 23 Feb 2022 15:41:57 +0000 (07:41 -0800)
In the past we had a need to differentiate TGL U and TGL Y, there
was a different voltage swing table for each subplatform and some PCI
ids of this subplatforms are shared but it turned out that it was a
specification mistake and the voltage swing table was indeed the same
but we went ahead with that patch because we needed to differentiate
TGL U and Y from TGL H and by that time TGL H was embargoed so that
was the perfect way to land it upstream.

Now the embargo for TGL H is long past and now we even have
INTEL_TGL_12_GT1_IDS with all TGL H ids, so we can drop this PCI root
check and only rely in the PCI ids to differentiate TGL U and Y from
TGL H that actually has code differences.

Besides the simplification this will fix issues in virtualization
environments where the PCI root is virtualized and don't have the same
id as actual hardware.

v2:
- add and set INTEL_SUBPLATFORM_UY

Cc: Fred Gao <fred.gao@intel.com>
Cc: Tvrtko Ursulin <tvrtko.ursulin@linux.intel.com>
Signed-off-by: José Roberto de Souza <jose.souza@intel.com>
Reviewed-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
Tested-by: Yu He <yu.he@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20220222141424.35165-1-jose.souza@intel.com
drivers/gpu/drm/i915/display/intel_ddi_buf_trans.c
drivers/gpu/drm/i915/i915_drv.h
drivers/gpu/drm/i915/i915_reg.h
drivers/gpu/drm/i915/intel_device_info.c
drivers/gpu/drm/i915/intel_device_info.h
drivers/gpu/drm/i915/intel_step.c

index e2dfb93a82bd9a6bb1818ecf8903c4416b0cb173..ed62c35e151800e45f8d5f7c6a5dd0a51020cf84 100644 (file)
@@ -1321,7 +1321,7 @@ tgl_get_combo_buf_trans_dp(struct intel_encoder *encoder,
        struct drm_i915_private *dev_priv = to_i915(encoder->base.dev);
 
        if (crtc_state->port_clock > 270000) {
-               if (IS_TGL_U(dev_priv) || IS_TGL_Y(dev_priv)) {
+               if (IS_TGL_UY(dev_priv)) {
                        return intel_get_buf_trans(&tgl_uy_combo_phy_trans_dp_hbr2,
                                                   n_entries);
                } else {
index 6ffadf4b3f1ab2589ea8ebc1a134c0fe53548bbe..71d946b0249ce9d10b598dbe26094bcbf65b9840 100644 (file)
@@ -1342,11 +1342,8 @@ IS_SUBPLATFORM(const struct drm_i915_private *i915,
 #define IS_ICL_WITH_PORT_F(dev_priv) \
        IS_SUBPLATFORM(dev_priv, INTEL_ICELAKE, INTEL_SUBPLATFORM_PORTF)
 
-#define IS_TGL_U(dev_priv) \
-       IS_SUBPLATFORM(dev_priv, INTEL_TIGERLAKE, INTEL_SUBPLATFORM_ULT)
-
-#define IS_TGL_Y(dev_priv) \
-       IS_SUBPLATFORM(dev_priv, INTEL_TIGERLAKE, INTEL_SUBPLATFORM_ULX)
+#define IS_TGL_UY(dev_priv) \
+       IS_SUBPLATFORM(dev_priv, INTEL_TIGERLAKE, INTEL_SUBPLATFORM_UY)
 
 #define IS_SKL_GRAPHICS_STEP(p, since, until) (IS_SKYLAKE(p) && IS_GRAPHICS_STEP(p, since, until))
 
@@ -1365,11 +1362,11 @@ IS_SUBPLATFORM(const struct drm_i915_private *i915,
         IS_DISPLAY_STEP(__i915, since, until))
 
 #define IS_TGL_UY_GRAPHICS_STEP(__i915, since, until) \
-       ((IS_TGL_U(__i915) || IS_TGL_Y(__i915)) && \
+       (IS_TGL_UY(__i915) && \
         IS_GRAPHICS_STEP(__i915, since, until))
 
 #define IS_TGL_GRAPHICS_STEP(__i915, since, until) \
-       (IS_TIGERLAKE(__i915) && !(IS_TGL_U(__i915) || IS_TGL_Y(__i915)) && \
+       (IS_TIGERLAKE(__i915) && !IS_TGL_UY(__i915)) && \
         IS_GRAPHICS_STEP(__i915, since, until))
 
 #define IS_RKL_DISPLAY_STEP(p, since, until) \
index 4b95c94084d98bbe2bf4afc89771dc59b35ffe8d..8d28d1e29aaf184982e5502fb8e5a09ec3f70b9d 100644 (file)
@@ -13012,12 +13012,6 @@ enum skl_power_gate {
 #define   DSB_ENABLE                   (1 << 31)
 #define   DSB_STATUS                   (1 << 0)
 
-#define TGL_ROOT_DEVICE_ID             0x9A00
-#define TGL_ROOT_DEVICE_MASK           0xFF00
-#define TGL_ROOT_DEVICE_SKU_MASK       0xF
-#define TGL_ROOT_DEVICE_SKU_ULX                0x2
-#define TGL_ROOT_DEVICE_SKU_ULT                0x4
-
 #define CLKREQ_POLICY                  _MMIO(0x101038)
 #define  CLKREQ_POLICY_MEM_UP_OVRD     REG_BIT(1)
 
index 04fd266d70e264e01cadb32b55d393bad0a766c0..3a713b46b573a3e87ae281e45a9af6c83e42c2ed 100644 (file)
@@ -170,6 +170,10 @@ static const u16 subplatform_portf_ids[] = {
        INTEL_ICL_PORT_F_IDS(0),
 };
 
+static const u16 subplatform_uy_ids[] = {
+       INTEL_TGL_12_GT2_IDS(0),
+};
+
 static const u16 subplatform_rpls_ids[] = {
        INTEL_RPLS_IDS(0),
 };
@@ -210,30 +214,14 @@ void intel_device_info_subplatform_init(struct drm_i915_private *i915)
        } else if (find_devid(devid, subplatform_portf_ids,
                              ARRAY_SIZE(subplatform_portf_ids))) {
                mask = BIT(INTEL_SUBPLATFORM_PORTF);
+       } else if (find_devid(devid, subplatform_uy_ids,
+                          ARRAY_SIZE(subplatform_uy_ids))) {
+               mask = BIT(INTEL_SUBPLATFORM_UY);
        } else if (find_devid(devid, subplatform_rpls_ids,
                              ARRAY_SIZE(subplatform_rpls_ids))) {
                mask = BIT(INTEL_SUBPLATFORM_RPL_S);
        }
 
-       if (IS_TIGERLAKE(i915)) {
-               struct pci_dev *root, *pdev = to_pci_dev(i915->drm.dev);
-
-               root = list_first_entry(&pdev->bus->devices, typeof(*root), bus_list);
-
-               drm_WARN_ON(&i915->drm, mask);
-               drm_WARN_ON(&i915->drm, (root->device & TGL_ROOT_DEVICE_MASK) !=
-                           TGL_ROOT_DEVICE_ID);
-
-               switch (root->device & TGL_ROOT_DEVICE_SKU_MASK) {
-               case TGL_ROOT_DEVICE_SKU_ULX:
-                       mask = BIT(INTEL_SUBPLATFORM_ULX);
-                       break;
-               case TGL_ROOT_DEVICE_SKU_ULT:
-                       mask = BIT(INTEL_SUBPLATFORM_ULT);
-                       break;
-               }
-       }
-
        GEM_BUG_ON(mask & ~INTEL_SUBPLATFORM_MASK);
 
        RUNTIME_INFO(i915)->platform_mask[pi] |= mask;
index d3cce0220018c22abc5a4dc45bd6b56d77bcd296..63bab7431f60679d277e9b8f1a32221338c4294e 100644 (file)
@@ -106,6 +106,9 @@ enum intel_platform {
 /* ICL */
 #define INTEL_SUBPLATFORM_PORTF        (0)
 
+/* TGL */
+#define INTEL_SUBPLATFORM_UY   (0)
+
 /* DG2 */
 #define INTEL_SUBPLATFORM_G10  0
 #define INTEL_SUBPLATFORM_G11  1
index ac1a796b280846fabe5c112b8d3af201af938e8f..4fd69ecd148112c51350b9f6d5e5673f19b68cd1 100644 (file)
@@ -165,7 +165,7 @@ void intel_step_init(struct drm_i915_private *i915)
        } else if (IS_ROCKETLAKE(i915)) {
                revids = rkl_revids;
                size = ARRAY_SIZE(rkl_revids);
-       } else if (IS_TGL_U(i915) || IS_TGL_Y(i915)) {
+       } else if (IS_TGL_UY(i915)) {
                revids = tgl_uy_revids;
                size = ARRAY_SIZE(tgl_uy_revids);
        } else if (IS_TIGERLAKE(i915)) {