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