When the flag is set, bo data is captured for devcoredump.

Signed-off-by: Chia-I Wu <olva...@gmail.com>
---
 drivers/gpu/drm/panthor/panthor_coredump.c | 36 ++++++++++++++++++++++
 drivers/gpu/drm/panthor/panthor_drv.c      |  3 +-
 drivers/gpu/drm/panthor/panthor_mmu.c      |  7 +++--
 include/uapi/drm/panthor_drm.h             |  7 +++++
 4 files changed, 49 insertions(+), 4 deletions(-)

diff --git a/drivers/gpu/drm/panthor/panthor_coredump.c 
b/drivers/gpu/drm/panthor/panthor_coredump.c
index 5502452a5baa..db5695b38c2d 100644
--- a/drivers/gpu/drm/panthor/panthor_coredump.c
+++ b/drivers/gpu/drm/panthor/panthor_coredump.c
@@ -5,6 +5,7 @@
 #include <drm/drm_print.h>
 #include <drm/drm_managed.h>
 #include <generated/utsrelease.h>
+#include <linux/ascii85.h>
 #include <linux/devcoredump.h>
 #include <linux/err.h>
 #include <linux/pm_runtime.h>
@@ -99,6 +100,26 @@ static const char *reason_str(enum panthor_coredump_reason 
reason)
        }
 }
 
+static void print_bo(struct drm_printer *p, struct panthor_gem_object *bo,
+                    u64 offset, u64 size)
+{
+       struct iosys_map map;
+       const u32 *vals;
+       u64 count;
+       char buf[ASCII85_BUFSZ];
+
+       if (drm_gem_vmap(&bo->base.base, &map))
+               return;
+
+       /* offset and size are aligned to panthor_vm_page_size, which is SZ_4K 
*/
+       vals = map.vaddr + offset;
+       count = size / sizeof(u32);
+       for (u64 i = 0; i < count; i++)
+               drm_puts(p, ascii85_encode(vals[i], buf));
+
+       drm_gem_vunmap(&bo->base.base, &map);
+}
+
 static void print_vma(struct drm_printer *p,
                      const struct panthor_coredump_vma_state *vma, u32 vma_id,
                      size_t *max_dyn_size)
@@ -129,6 +150,21 @@ static void print_vma(struct drm_printer *p,
                        }
                }
        }
+
+       if (vma->flags & DRM_PANTHOR_VM_BIND_OP_MAP_DUMPABLE) {
+               drm_puts(p, "    data: |\n");
+               drm_puts(p, "      ");
+
+               /* bo data is dynamic */
+               if (max_dyn_size) {
+                       *max_dyn_size +=
+                               vma->size / sizeof(u32) * (ASCII85_BUFSZ - 1);
+               } else {
+                       print_bo(p, bo, vma->bo_offset, vma->size);
+               }
+
+               drm_puts(p, "\n");
+       }
 }
 
 static void print_as(struct drm_printer *p,
diff --git a/drivers/gpu/drm/panthor/panthor_drv.c 
b/drivers/gpu/drm/panthor/panthor_drv.c
index 1116f2d2826e..6c4de1e73cd1 100644
--- a/drivers/gpu/drm/panthor/panthor_drv.c
+++ b/drivers/gpu/drm/panthor/panthor_drv.c
@@ -1608,6 +1608,7 @@ static void panthor_debugfs_init(struct drm_minor *minor)
  * - 1.3 - adds DRM_PANTHOR_GROUP_STATE_INNOCENT flag
  * - 1.4 - adds DRM_IOCTL_PANTHOR_BO_SET_LABEL ioctl
  * - 1.5 - adds DRM_PANTHOR_SET_USER_MMIO_OFFSET ioctl
+ * - 1.6 - adds DRM_PANTHOR_VM_BIND_OP_MAP_DUMPABLE flag
  */
 static const struct drm_driver panthor_drm_driver = {
        .driver_features = DRIVER_RENDER | DRIVER_GEM | DRIVER_SYNCOBJ |
@@ -1621,7 +1622,7 @@ static const struct drm_driver panthor_drm_driver = {
        .name = "panthor",
        .desc = "Panthor DRM driver",
        .major = 1,
-       .minor = 5,
+       .minor = 6,
 
        .gem_create_object = panthor_gem_create_object,
        .gem_prime_import_sg_table = drm_gem_shmem_prime_import_sg_table,
diff --git a/drivers/gpu/drm/panthor/panthor_mmu.c 
b/drivers/gpu/drm/panthor/panthor_mmu.c
index 7862c99984b6..72b1b2799b65 100644
--- a/drivers/gpu/drm/panthor/panthor_mmu.c
+++ b/drivers/gpu/drm/panthor/panthor_mmu.c
@@ -2045,10 +2045,11 @@ static void panthor_vma_init(struct panthor_vma *vma, 
u32 flags)
        vma->flags = flags;
 }
 
-#define PANTHOR_VM_MAP_FLAGS \
+#define PANTHOR_VM_MAP_FLAGS                   \
        (DRM_PANTHOR_VM_BIND_OP_MAP_READONLY | \
-        DRM_PANTHOR_VM_BIND_OP_MAP_NOEXEC | \
-        DRM_PANTHOR_VM_BIND_OP_MAP_UNCACHED)
+        DRM_PANTHOR_VM_BIND_OP_MAP_NOEXEC |   \
+        DRM_PANTHOR_VM_BIND_OP_MAP_UNCACHED | \
+        DRM_PANTHOR_VM_BIND_OP_MAP_DUMPABLE)
 
 static int panthor_gpuva_sm_step_map(struct drm_gpuva_op *op, void *priv)
 {
diff --git a/include/uapi/drm/panthor_drm.h b/include/uapi/drm/panthor_drm.h
index e1f43deb7eca..c4c5e38365e9 100644
--- a/include/uapi/drm/panthor_drm.h
+++ b/include/uapi/drm/panthor_drm.h
@@ -496,6 +496,13 @@ enum drm_panthor_vm_bind_op_flags {
         */
        DRM_PANTHOR_VM_BIND_OP_MAP_UNCACHED = 1 << 2,
 
+       /**
+        * @DRM_PANTHOR_VM_BIND_OP_MAP_DUMPABLE: Dump the VMA for devcoredump.
+        *
+        * Only valid with DRM_PANTHOR_VM_BIND_OP_TYPE_MAP.
+        */
+       DRM_PANTHOR_VM_BIND_OP_MAP_DUMPABLE = 1 << 3,
+
        /**
         * @DRM_PANTHOR_VM_BIND_OP_TYPE_MASK: Mask used to determine the type 
of operation.
         */
-- 
2.50.0.727.gbf7dc18ff4-goog

Reply via email to