162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-only 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Copyright © 2014 Broadcom 462306a36Sopenharmony_ci */ 562306a36Sopenharmony_ci 662306a36Sopenharmony_ci#include <drm/drm_drv.h> 762306a36Sopenharmony_ci 862306a36Sopenharmony_ci#include <linux/seq_file.h> 962306a36Sopenharmony_ci#include <linux/circ_buf.h> 1062306a36Sopenharmony_ci#include <linux/ctype.h> 1162306a36Sopenharmony_ci#include <linux/debugfs.h> 1262306a36Sopenharmony_ci#include <linux/platform_device.h> 1362306a36Sopenharmony_ci 1462306a36Sopenharmony_ci#include "vc4_drv.h" 1562306a36Sopenharmony_ci#include "vc4_regs.h" 1662306a36Sopenharmony_ci 1762306a36Sopenharmony_ci/* 1862306a36Sopenharmony_ci * Called at drm_dev_register() time on each of the minors registered 1962306a36Sopenharmony_ci * by the DRM device, to attach the debugfs files. 2062306a36Sopenharmony_ci */ 2162306a36Sopenharmony_civoid 2262306a36Sopenharmony_civc4_debugfs_init(struct drm_minor *minor) 2362306a36Sopenharmony_ci{ 2462306a36Sopenharmony_ci struct vc4_dev *vc4 = to_vc4_dev(minor->dev); 2562306a36Sopenharmony_ci struct drm_device *drm = &vc4->base; 2662306a36Sopenharmony_ci 2762306a36Sopenharmony_ci drm_WARN_ON(drm, vc4_hvs_debugfs_init(minor)); 2862306a36Sopenharmony_ci 2962306a36Sopenharmony_ci if (vc4->v3d) { 3062306a36Sopenharmony_ci drm_WARN_ON(drm, vc4_bo_debugfs_init(minor)); 3162306a36Sopenharmony_ci drm_WARN_ON(drm, vc4_v3d_debugfs_init(minor)); 3262306a36Sopenharmony_ci } 3362306a36Sopenharmony_ci} 3462306a36Sopenharmony_ci 3562306a36Sopenharmony_cistatic int vc4_debugfs_regset32(struct seq_file *m, void *unused) 3662306a36Sopenharmony_ci{ 3762306a36Sopenharmony_ci struct drm_debugfs_entry *entry = m->private; 3862306a36Sopenharmony_ci struct drm_device *drm = entry->dev; 3962306a36Sopenharmony_ci struct debugfs_regset32 *regset = entry->file.data; 4062306a36Sopenharmony_ci struct drm_printer p = drm_seq_file_printer(m); 4162306a36Sopenharmony_ci int idx; 4262306a36Sopenharmony_ci 4362306a36Sopenharmony_ci if (!drm_dev_enter(drm, &idx)) 4462306a36Sopenharmony_ci return -ENODEV; 4562306a36Sopenharmony_ci 4662306a36Sopenharmony_ci drm_print_regset32(&p, regset); 4762306a36Sopenharmony_ci 4862306a36Sopenharmony_ci drm_dev_exit(idx); 4962306a36Sopenharmony_ci 5062306a36Sopenharmony_ci return 0; 5162306a36Sopenharmony_ci} 5262306a36Sopenharmony_ci 5362306a36Sopenharmony_civoid vc4_debugfs_add_regset32(struct drm_device *drm, 5462306a36Sopenharmony_ci const char *name, 5562306a36Sopenharmony_ci struct debugfs_regset32 *regset) 5662306a36Sopenharmony_ci{ 5762306a36Sopenharmony_ci drm_debugfs_add_file(drm, name, vc4_debugfs_regset32, regset); 5862306a36Sopenharmony_ci} 59