• Matt Roper's avatar
    drm/i915: Only hook up uncore->debug for primary uncore · 639e30ee
    Matt Roper authored
    The original intent of intel_uncore_mmio_debug as described in commit
    0a9b2630 ("drm/i915: split out uncore_mmio_debug") was to be a
    singleton structure that could be shared between multiple GTs' uncore
    objects in a multi-tile system.  Somehow we went off track and
    started allocating separate instances of this structure for each GT,
    which defeats that original goal.
    
    But in reality, there isn't even a need to share the mmio_debug between
    multiple GTs; on all modern platforms (i.e., everything after gen7)
    unclaimed register accesses are something that can only be detected for
    display registers.  There's no point in grabbing the debug spinlock and
    checking for unclaimed accesses on an uncore used by an xehpsdv or pvc
    remote tile GT, or the uncore used by a mtl standalone media GT since
    all of the display accesses go through the primary intel_uncore.
    
    The simplest solution is to simply leave uncore->debug NULL on all
    intel_uncore instances except for the primary one.  This will allow us
    to avoid the pointless debug spinlock acquisition we've been doing on
    MMIO accesses coming in through these intel_uncores.
    Signed-off-by: default avatarMatt Roper <matthew.d.roper@intel.com>
    Reviewed-by: default avatarRadhakrishna Sripada <radhakrishna.sripada@intel.com>
    Link: https://patchwork.freedesktop.org/patch/msgid/20220906234934.3655440-3-matthew.d.roper@intel.comSigned-off-by: default avatarJoonas Lahtinen <joonas.lahtinen@linux.intel.com>
    639e30ee
intel_uncore.c 81.6 KB