[PATCH v13 00/13] Add GuC Error Capture Support

Tvrtko Ursulin tvrtko.ursulin at linux.intel.com
Wed Mar 23 13:19:53 UTC 2022


Hi,

On 21/03/2022 16:45, Alan Previn wrote:
> This series:
>    1. Enables support of GuC to report error-state-capture
>       using a list of MMIO registers the driver registers
>       and GuC will dump, log and notify right before a GuC
>       triggered engine-reset event.
>    2. Updates the ADS blob creation to register said lists
>       of global, engine class and engine instance registers
>       with GuC.
>    3. Defines tables of register lists that are global or
>       engine class or engine instance in scope.
>    4. Updates usage and buffer-state data for the regions
>       of the shared GuC log-buffer to accomdate both
>       the existing relay logging of general debug logs
>       along with the new error state capture usage.
>    5. Using a pool of preallocated memory, provide ability
>       to extract and format the GuC reported register-capture
>       data into chunks consistent with existing i915 error-
>       state collection flows and structures.
>    6. Connects the i915_gpu_coredump reporting function
>       to the GuC error capture module to print all GuC
>       error state capture dumps that is reported.

Story is finished with this series and we have everything on feature 
parity? Intel_error_decode handles it fine?

Would you have an example error capture at hand, I am curious how it looks?

Regards,

Tvrtko

> 
> This is the 13th rev of this series where the first 3 revs
> are RFC
> 
> Prior receipts of rvb's:
>    - Patch #2, #3, #4, #5, #10, #11, #12, #13 have received
>      R-v-b's from Umesh Nerlige Ramappa <umesh.nerlige.ramappa at intel.com>
>    - Patch #1, #6, #7, #8, #9 has received an R-v-b from Matthew Brost
>      <matthew.brost at intel.com>. NOTE: some of these came in on the
>      trybot series. https://patchwork.freedesktop.org/series/100831/
> 
> Changes from prior revs:
>    v13:- Fixing register list definition styling as per Jani's request.
>    v12:- Re-sending it because previous revs only got to intel-gfx,
>          and only cover letter was in dri-devel. Also rebased again.
>    v11:- Rebase again on latest drm-tip to fix merge error.
>    v10:- Rebase on latest drm-tip again. Fix a number of checkpatch
>          warnings and an error Reported-by: kernel test robot <lkp at intel.com>.
>    v9: - Rebase on latest drm-tip to solve CI merge-build error.
>    v8: - Fix a bug found by CI in rev7: Create a cached ADS
>          capture list for null-header like the other lists.
>        - Fixed a bug on the ggtt offset calculation in the
>          ADS population loop. Thanks to Matt Brost.
>        - Change the storage uses for initial allocation and
>          caching of the ADS register lists so we only store
>          a regular pointer instead of file handle.
>        - Multiple improvements on code styling, variable names,
>          comments and code reduction from Umesh suggestions
>          across multiple patches.
> 
>    v7: - Rebased on lastest drm_tip that has the ADS now using
>          shmem based ads_blob_write utilities. Stress test
>          was performed with this patch included to fix a
>          legacy bug:
>          https://patchwork.freedesktop.org/series/100768/
> 
>    v6: - In patch #1, ADS reg-list population, we now alloc
>          regular memory to create the lists and cache them for
>          simpler and faster use by GuC ADS module at init,
>          suspend-resume and reset cycles. This was in response
>          to review comments from Lucas De Marchi that also
>          wanted to ensure the GuC ADS module owns the final
>          copying into the ADS phyical memory.
>        - Thanks to Jani Nikula for pointing out that patch #2
>          and #3 should ensure static tables as constant and
>          dynamic lists should be allocated and cached but
>          attached to the GT level for the case of multiple
>          cards with different fusings for steered registers.
>          These are addressed now along with multiple code
>          style fixups (thanks to review comment from Umesh)
>          and splitting the steered register list generation
>          as a seperate patch.
>        - The extraction functionality, Patch #10 and #11 (was
>          patch #7), has fixed all of Umesh's review comments
>          related to the code styling. Additionally, it was
>          discovered during stress tests that the extraction
>          function could be called by the ct processing thread
>          at the same time as the start of a GT reset event.
>          Thus, a redesign was done whereby the linked list of
>          processed capture-output-nodes are allocated up
>          front and reused throughout the driver's life to
>          ensure no memory locks are taken during extraction.
>        - For patch #6 (now 7, 8 and 9), updates to
>          intel_guc_log was split into smaller chunks and the
>          log_state structure was returned back to inside of
>          the intel_guc_log struct as opposed to the
>          intel_guc struct in prior rev. This is in response
>          to review comments by Matt Brost.
>        - #Patch 13 (previously #10) is mostly identical but
>          addresses all of the code styling comments reviews
>          from Umesh.
>          
>    v5: - Added Gen9->Gen11 register list for CI coverage that
>          included Gen9 with GuC submission.
>        - Redesigned the extraction of the GuC error-capture
>          dumps by grouping them into complete per-engine-reset
>          nodes. Complete here means each node includes the
>          global, engine-class and engine-instance register
>          lists in a single structure.
>        - Extraction is decoupled from the print-out. We now
>          do the extraction immediately when receiving the
>          G2H for error-capture notification. A link list of
>          nodes is maintained with a FIFO based threshold
>          while awaiting retrieval from i915_gpu_coredump's
>          capture_engine function.
>        - Added new plumbing through the i915_gpu_coredump
>          allocation and capture functions to include a flag
>          that is used indicate that GuC had triggered the
>          reset. This new plumbing guarantees an exact match
>          from i915_gpu_coredump's per-engine vma recording
>          and node-retrieval from the guc-error-capture.
>        - Broke the coredump gt_global capture and recording
>          functions into smaller subsets so we can reuse as
>          much of the existing legacy register reading + printing
>          functions and only rely on GuC error-capture for
>          the smaller subset of registers that are tied to
>          engine workload execution.
>        - Updated the register list to follow the legacy execlist
>          format of printout.
>    v4:
>        - Rebased on latest drm-tip that has been merged with the
>          support of GuC firmware version 69.0.3 that is required
>          for GuC error-state-catpure to work.
>        - Added register list for DG2 which is the same as XE_LP
>          except an additional steering register set.
>        - Fixed a bug in the end of capture parsing loop in
>          intel_guc_capture_out_print_next_group that was not
>          properly comparing the engine-instance and engine-
>          class being parsed against the one that triggered
>          the i915_gpu_coredump.
>    v3:
>        - Fixed all review comments from rev2 except the following:
>            - Michal Wajdeczko proposed adding a seperate function
>              to lookup register string nameslookup (based on offset)
>              but decided against it because of offset conflicts
>              and the current table layout is easier to maintain.
>            - Last set of checkpatch errors pertaining to "COMPLEX
>              MACROS" should be fixed on next rev.
>        - Abstracted internal-to-guc-capture information into a new
>          __guc_state_capture_priv structure that allows the exclusion
>          of intel_guc.h and intel_guc_fwif.h from intel_guc_capture.h.
>          Now, only the first 2 patches have a wider build time
>          impact because of the changes to intel_guc_fwif.h but
>          subsequent changes to guc-capture internal structures
>          or firmware interfaces used solely by guc-capture module
>          shoudn't impact the rest of the driver build.
>        - Added missing Gen12LP registers and added slice+subslice
>          indices when reporting extended steered registers.
>        - Add additional checks to ensure that the GuC reported
>          error capture information matches the i915_gpu_coredump
>          that is being printed before we print out the corresponding
>          VMA dumps such as the batch buffer.
>     v2:
>        - Ignore - failed CI retest.
> 
> Alan Previn (13):
>    drm/i915/guc: Update GuC ADS size for error capture lists
>    drm/i915/guc: Add XE_LP static registers for GuC error capture.
>    drm/i915/guc: Add XE_LP steered register lists support
>    drm/i915/guc: Add DG2 registers for GuC error state capture.
>    drm/i915/guc: Add Gen9 registers for GuC error state capture.
>    drm/i915/guc: Add GuC's error state capture output structures.
>    drm/i915/guc: Update GuC-log relay function names
>    drm/i915/guc: Add capture region into intel_guc_log
>    drm/i915/guc: Check sizing of guc_capture output
>    drm/i915/guc: Extract GuC error capture lists on G2H notification.
>    drm/i915/guc: Pre-allocate output nodes for extraction
>    drm/i915/guc: Plumb GuC-capture into gpu_coredump
>    drm/i915/guc: Print the GuC error capture output register list.
> 
>   drivers/gpu/drm/i915/Makefile                 |    1 +
>   drivers/gpu/drm/i915/gt/intel_engine_cs.c     |    4 +-
>   .../drm/i915/gt/intel_execlists_submission.c  |    4 +-
>   drivers/gpu/drm/i915/gt/intel_reset.c         |    2 +-
>   .../gpu/drm/i915/gt/uc/abi/guc_actions_abi.h  |    7 +
>   drivers/gpu/drm/i915/gt/uc/guc_capture_fwif.h |  218 +++
>   drivers/gpu/drm/i915/gt/uc/intel_guc.c        |   13 +-
>   drivers/gpu/drm/i915/gt/uc/intel_guc.h        |   12 +-
>   drivers/gpu/drm/i915/gt/uc/intel_guc_ads.c    |  127 +-
>   .../gpu/drm/i915/gt/uc/intel_guc_capture.c    | 1655 +++++++++++++++++
>   .../gpu/drm/i915/gt/uc/intel_guc_capture.h    |   33 +
>   drivers/gpu/drm/i915/gt/uc/intel_guc_fwif.h   |   14 +-
>   drivers/gpu/drm/i915/gt/uc/intel_guc_log.c    |  127 +-
>   drivers/gpu/drm/i915/gt/uc/intel_guc_log.h    |    7 +-
>   .../gpu/drm/i915/gt/uc/intel_guc_submission.c |   18 +-
>   drivers/gpu/drm/i915/i915_debugfs.c           |    3 +-
>   drivers/gpu/drm/i915/i915_gpu_error.c         |  282 ++-
>   drivers/gpu/drm/i915/i915_gpu_error.h         |   35 +-
>   18 files changed, 2379 insertions(+), 183 deletions(-)
>   create mode 100644 drivers/gpu/drm/i915/gt/uc/guc_capture_fwif.h
>   create mode 100644 drivers/gpu/drm/i915/gt/uc/intel_guc_capture.c
>   create mode 100644 drivers/gpu/drm/i915/gt/uc/intel_guc_capture.h
> 


More information about the dri-devel mailing list