[PULL] drm-intel-gt-next
Joonas Lahtinen
joonas.lahtinen at linux.intel.com
Wed Aug 24 12:01:14 UTC 2022
Hi Dave & Daniel,
Here goes the first drm-intel-gt-next PR towards 6.1. Quite a small one.
As primary things, there's the parallel support of GuC v69 and v70
which already went in via -fixes, improvements to the TLB invalidation
performance regressions, further DG2 enabling and improved debugging
for GuC errors.
On top of that, locking simplification for freeing objects to avoid
potential system freeze, addition of gt/gtN/.defaults (including freq
to start), silencing some messages that are not errors.
Regards, Joonas
PS. I left a few commits out from top of drm-intel-gt-next as there is fixup
needed for at least one. I will include those in the next PR.
***
drm-intel-gt-next-2022-08-24:
UAPI Changes:
- Create gt/gtN/.defaults/ for per gt sysfs defaults
Create a gt/gtN/.defaults/ directory (similar to
engine/<engine-name>/.defaults/) to expose default parameter values for
each gt in sysfs. This allows userspace to restore default parameter values
after they have changed.
Driver Changes:
- Support GuC v69 in parallel to v70 (Daniele)
- Improve TLB invalidation to limit performance regression (Chris, Mauro)
- Expose per-gt RPS defaults in sysfs (Ashutosh)
- Suppress OOM warning for shmemfs object allocation failure (Chris, Nirmoy)
- Disable PCI resize on 32-bit machines (Nirmoy)
- Update DG2 to GuC v70.4.1 (John)
- Fix CCS data copying on DG2 during swapping (Matt A)
- Add DG2 performance tuning setting recommended by spec (Matt R)
- Add GuC <-> kernel time stamp translation information to error logs (John)
- Record GuC CTB info in error logs (John)
- Route semaphores to GuC for Gen12+ when enabled (Michal Wi, John)
- Improve resilency to bug #3575: Handle reset timeouts under unrelated kernel hangs (Chris, Ashutosh)
- Avoid system freeze by removing shared locking on freeing objects (Chris, Nirmoy)
- Demote GuC error "No response for request" into debug when expected (Zhanjun)
- Fix GuC capture size warning and bump the size (John)
- Use streaming loads to speed up dumping the GuC log (Chris, John)
- Don't abort on CTB_UNUSED status from GuC (John)
- Don't send spurious policy update for GuC child contexts (Daniele)
- Don't leak the CCS state (Matt A)
- Prefer drm_err over pr_err (John)
- Eliminate unused calc_ctrl_surf_instr_size (Matt A)
- Add dedicated function for non-ctx register tuning settings (Matt R)
- Style and typo fixes, documentation improvements (Jason Wang, Mauro)
- Selftest improvements (Matt B, Rahul, John)
The following changes since commit 17cd10a44a8962860ff4ba351b2a290e752dbbde:
drm/i915: Add lmem_bar_size modparam (2022-07-13 17:47:51 +0100)
are available in the Git repository at:
git://anongit.freedesktop.org/drm/drm-intel tags/drm-intel-gt-next-2022-08-24
for you to fetch changes up to 5ece208ab05e4042c80ed1e6fe6d7ce236eee89b:
drm/i915/guc: Use streaming loads to speed up dumping the guc log (2022-08-17 10:07:03 -0700)
----------------------------------------------------------------
UAPI Changes:
- Create gt/gtN/.defaults/ for per gt sysfs defaults
Create a gt/gtN/.defaults/ directory (similar to
engine/<engine-name>/.defaults/) to expose default parameter values for
each gt in sysfs. This allows userspace to restore default parameter values
after they have changed.
Driver Changes:
- Support GuC v69 in parallel to v70 (Daniele)
- Improve TLB invalidation to limit performance regression (Chris, Mauro)
- Expose per-gt RPS defaults in sysfs (Ashutosh)
- Suppress OOM warning for shmemfs object allocation failure (Chris, Nirmoy)
- Disable PCI resize on 32-bit machines (Nirmoy)
- Update DG2 to GuC v70.4.1 (John)
- Fix CCS data copying on DG2 during swapping (Matt A)
- Add DG2 performance tuning setting recommended by spec (Matt R)
- Add GuC <-> kernel time stamp translation information to error logs (John)
- Record GuC CTB info in error logs (John)
- Route semaphores to GuC for Gen12+ when enabled (Michal Wi, John)
- Improve resilency to bug #3575: Handle reset timeouts under unrelated kernel hangs (Chris, Ashutosh)
- Avoid system freeze by removing shared locking on freeing objects (Chris, Nirmoy)
- Demote GuC error "No response for request" into debug when expected (Zhanjun)
- Fix GuC capture size warning and bump the size (John)
- Use streaming loads to speed up dumping the GuC log (Chris, John)
- Don't abort on CTB_UNUSED status from GuC (John)
- Don't send spurious policy update for GuC child contexts (Daniele)
- Don't leak the CCS state (Matt A)
- Prefer drm_err over pr_err (John)
- Eliminate unused calc_ctrl_surf_instr_size (Matt A)
- Add dedicated function for non-ctx register tuning settings (Matt R)
- Style and typo fixes, documentation improvements (Jason Wang, Mauro)
- Selftest improvements (Matt B, Rahul, John)
----------------------------------------------------------------
Alan Previn (1):
drm/i915/guc: Add a helper for log buffer size
Ashutosh Dixit (2):
drm/i915/gt: Create gt/gtN/.defaults/ for per gt sysfs defaults
drm/i915/gt: Expose per-gt RPS defaults in sysfs
Chris Wilson (8):
drm/i915/reset: Handle reset timeouts under unrelated kernel hangs
drm/i915: Suppress oom warning for shmemfs object allocation failure
drm/i915/gt: Ignore TLB invalidations on idle engines
drm/i915/gt: Invalidate TLB of the OA unit at TLB invalidations
drm/i915/gt: Skip TLB invalidations once wedged
drm/i915/gt: Batch TLB invalidations
drm/i915/gem: Remove shared locking on freeing objects
drm/i915/guc: Use streaming loads to speed up dumping the guc log
Daniele Ceraolo Spurio (2):
drm/i915/guc: support v69 in parallel to v70
drm/i915/guc: Don't send policy update for child contexts.
Harish Chegondi (1):
drm/i915/dg2: Add Wa_1509727124
Jason Wang (2):
drm/i915/gt: Remove unneeded semicolon
drm/i915/selftests: Fix comment typo
John Harrison (7):
drm/i915/guc: Don't use pr_err when not necessary
drm/i915/selftest: Cope with not having an RCS engine
drm/i915/guc: Don't abort on CTB_UNUSED status
drm/i915/dg2: Update DG2 to GuC v70.4.1
drm/i915/guc: Fix capture size warning and bump the size
drm/i915/guc: Add GuC <-> kernel time stamp translation information
drm/i915/guc: Record CTB info in error logs
Matt Roper (2):
drm/i915/gt: Add dedicated function for non-ctx register tuning settings
drm/i915/dg2: Add additional tuning settings
Matthew Auld (3):
drm/i915/ttm: don't leak the ccs state
drm/i915/ttm: remove calc_ctrl_surf_instr_size
drm/i915/ttm: fix CCS handling
Matthew Brost (2):
drm/i915/guc: Fix issues with live_preempt_cancel
drm/i915/guc: Support larger contexts on newer hardware
Mauro Carvalho Chehab (3):
drm/i915/gt: document with_intel_gt_pm_if_awake()
drm/i915/gt: describe the new tlb parameter at i915_vma_resource
drm/i915: pass a pointer for tlb seqno at vma_invalidate_tlb()
Michał Winiarski (1):
drm/i915/guc: Route semaphores to GuC for Gen12+
Nirmoy Das (1):
drm/i915: disable pci resize on 32-bit machine
Rahul Kumar Singh (1):
drm/i915/guc: Add selftest for a hung GuC
Zhanjun Dong (1):
drm/i915/guc: Check for ct enabled while waiting for response
drivers/gpu/drm/i915/gem/i915_gem_object.c | 16 +-
drivers/gpu/drm/i915/gem/i915_gem_object_types.h | 3 +-
drivers/gpu/drm/i915/gem/i915_gem_pages.c | 25 +-
drivers/gpu/drm/i915/gem/i915_gem_shmem.c | 6 +-
drivers/gpu/drm/i915/gt/intel_context_types.h | 11 +-
drivers/gpu/drm/i915/gt/intel_gt.c | 77 +++-
drivers/gpu/drm/i915/gt/intel_gt.h | 12 +-
drivers/gpu/drm/i915/gt/intel_gt_pm.h | 11 +
drivers/gpu/drm/i915/gt/intel_gt_regs.h | 11 +
drivers/gpu/drm/i915/gt/intel_gt_sysfs.c | 10 +-
drivers/gpu/drm/i915/gt/intel_gt_sysfs.h | 6 +
drivers/gpu/drm/i915/gt/intel_gt_sysfs_pm.c | 34 ++
drivers/gpu/drm/i915/gt/intel_gt_types.h | 27 +-
drivers/gpu/drm/i915/gt/intel_migrate.c | 104 +++---
drivers/gpu/drm/i915/gt/intel_ppgtt.c | 8 +-
drivers/gpu/drm/i915/gt/intel_region_lmem.c | 4 +
drivers/gpu/drm/i915/gt/intel_reset.c | 6 +-
drivers/gpu/drm/i915/gt/intel_rps.c | 2 +
drivers/gpu/drm/i915/gt/intel_workarounds.c | 76 ++--
drivers/gpu/drm/i915/gt/selftest_execlists.c | 16 +-
drivers/gpu/drm/i915/gt/selftest_hangcheck.c | 12 +-
drivers/gpu/drm/i915/gt/uc/abi/guc_actions_abi.h | 3 +
.../drm/i915/gt/uc/abi/guc_communication_ctb_abi.h | 8 +-
drivers/gpu/drm/i915/gt/uc/intel_guc.c | 19 +
drivers/gpu/drm/i915/gt/uc/intel_guc.h | 7 +
drivers/gpu/drm/i915/gt/uc/intel_guc_ads.c | 10 +-
drivers/gpu/drm/i915/gt/uc/intel_guc_capture.c | 40 ++-
drivers/gpu/drm/i915/gt/uc/intel_guc_capture.h | 1 -
drivers/gpu/drm/i915/gt/uc/intel_guc_ct.c | 45 ++-
drivers/gpu/drm/i915/gt/uc/intel_guc_fwif.h | 45 +++
drivers/gpu/drm/i915/gt/uc/intel_guc_log.c | 79 +++--
drivers/gpu/drm/i915/gt/uc/intel_guc_log.h | 4 +-
drivers/gpu/drm/i915/gt/uc/intel_guc_reg.h | 4 +
drivers/gpu/drm/i915/gt/uc/intel_guc_slpc.c | 12 +-
drivers/gpu/drm/i915/gt/uc/intel_guc_submission.c | 393 ++++++++++++++++-----
drivers/gpu/drm/i915/gt/uc/intel_uc_fw.c | 68 +++-
drivers/gpu/drm/i915/gt/uc/intel_uc_fw.h | 7 +
drivers/gpu/drm/i915/gt/uc/selftest_guc.c | 37 +-
.../gpu/drm/i915/gt/uc/selftest_guc_hangcheck.c | 159 +++++++++
.../gpu/drm/i915/gt/uc/selftest_guc_multi_lrc.c | 10 +-
drivers/gpu/drm/i915/i915_drv.h | 4 +-
drivers/gpu/drm/i915/i915_gpu_error.c | 67 +++-
drivers/gpu/drm/i915/i915_gpu_error.h | 21 +-
drivers/gpu/drm/i915/i915_vma.c | 33 +-
drivers/gpu/drm/i915/i915_vma.h | 1 +
drivers/gpu/drm/i915/i915_vma_resource.c | 9 +-
drivers/gpu/drm/i915/i915_vma_resource.h | 6 +-
.../gpu/drm/i915/selftests/i915_live_selftests.h | 1 +
drivers/gpu/drm/i915/selftests/i915_request.c | 2 +-
49 files changed, 1227 insertions(+), 345 deletions(-)
create mode 100644 drivers/gpu/drm/i915/gt/uc/selftest_guc_hangcheck.c
More information about the dri-devel
mailing list