Skip to content
Snippets Groups Projects
Commit aa06cb83 authored by Lucas De Marchi's avatar Lucas De Marchi
Browse files

drm/xe: Improve devcoredump documentation


Let the introduction be useful for both userspace and kernel. Also
improve the formatting to wire up later to the documentation build.

Reviewed-by: default avatarRaag Jadav <raag.jadav@intel.com>
Reviewed-by: default avatarRodrigo Vivi <rodrigo.vivi@intel.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20241102161254.1818604-2-lucas.demarchi@intel.com


Signed-off-by: default avatarLucas De Marchi <lucas.demarchi@intel.com>
parent db62482e
No related branches found
No related tags found
No related merge requests found
...@@ -29,30 +29,39 @@ ...@@ -29,30 +29,39 @@
/** /**
* DOC: Xe device coredump * DOC: Xe device coredump
* *
* Devices overview:
* Xe uses dev_coredump infrastructure for exposing the crash errors in a * Xe uses dev_coredump infrastructure for exposing the crash errors in a
* standardized way. * standardized way. Once a crash occurs, devcoredump exposes a temporary
* devcoredump exposes a temporary device under /sys/class/devcoredump/ * node under ``/sys/class/devcoredump/devcd<m>/``. The same node is also
* which is linked with our card device directly. * accessible in ``/sys/class/drm/card<n>/device/devcoredump/``. The
* The core dump can be accessed either from * ``failing_device`` symlink points to the device that crashed and created the
* /sys/class/drm/card<n>/device/devcoredump/ or from * coredump.
* /sys/class/devcoredump/devcd<m> where
* /sys/class/devcoredump/devcd<m>/failing_device is a link to
* /sys/class/drm/card<n>/device/.
* *
* Snapshot at hang: * The following characteristics are observed by xe when creating a device
* The 'data' file is printed with a drm_printer pointer at devcoredump read * coredump:
* time. For this reason, we need to take snapshots from when the hang has
* happened, and not only when the user is reading the file. Otherwise the
* information is outdated since the resets might have happened in between.
* *
* 'First' failure snapshot: * **Snapshot at hang**:
* In general, the first hang is the most critical one since the following hangs * The 'data' file contains a snapshot of the HW and driver states at the time
* can be a consequence of the initial hang. For this reason we only take the * the hang happened. Due to the driver recovering from resets/crashes, it may
* snapshot of the 'first' failure and ignore subsequent calls of this function, * not correspond to the state of the system when the file is read by
* at least while the coredump device is alive. Dev_coredump has a delayed work * userspace.
* queue that will eventually delete the device and free all the dump *
* information. * **Coredump release**:
* After a coredump is generated, it stays in kernel memory until released by
* userpace by writing anything to it, or after an internal timer expires. The
* exact timeout may vary and should not be relied upon. Example to release
* a coredump:
*
* .. code-block:: shell
*
* $ > /sys/class/drm/card0/device/devcoredump/data
*
* **First failure only**:
* In general, the first hang is the most critical one since the following
* hangs can be a consequence of the initial hang. For this reason a snapshot
* is taken only for the first failure. Until the devcoredump is released by
* userspace or kernel, all subsequent hangs do not override the snapshot nor
* create new ones. Devcoredump has a delayed work queue that will eventually
* delete the file node and free all the dump information.
*/ */
#ifdef CONFIG_DEV_COREDUMP #ifdef CONFIG_DEV_COREDUMP
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment