97 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			97 lines
		
	
	
		
			2.3 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| // SPDX-License-Identifier: GPL-2.0
 | |
| //
 | |
| // // Renesas R-Car debugfs support
 | |
| //
 | |
| // Copyright (c) 2021 Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>
 | |
| //
 | |
| //	> mount -t debugfs none /sys/kernel/debug
 | |
| //	> cd /sys/kernel/debug/asoc/rcar-sound/ec500000.sound/rdai{N}/
 | |
| //	> cat playback/xxx
 | |
| //	> cat capture/xxx
 | |
| //
 | |
| #ifdef CONFIG_DEBUG_FS
 | |
| 
 | |
| #include <linux/debugfs.h>
 | |
| #include "rsnd.h"
 | |
| 
 | |
| static int rsnd_debugfs_show(struct seq_file *m, void *v)
 | |
| {
 | |
| 	struct rsnd_dai_stream *io = m->private;
 | |
| 	struct rsnd_mod *mod = rsnd_io_to_mod_ssi(io);
 | |
| 	struct rsnd_priv *priv = rsnd_mod_to_priv(mod);
 | |
| 	int i;
 | |
| 
 | |
| 	/* adg is out of mods */
 | |
| 	rsnd_adg_clk_dbg_info(priv, m);
 | |
| 
 | |
| 	for_each_rsnd_mod(i, mod, io) {
 | |
| 		u32 *status = mod->ops->get_status(mod, io, mod->type);
 | |
| 
 | |
| 		seq_printf(m, "name: %s\n", rsnd_mod_name(mod));
 | |
| 		seq_printf(m, "status: %08x\n", *status);
 | |
| 
 | |
| 		if (mod->ops->debug_info)
 | |
| 			mod->ops->debug_info(m, io, mod);
 | |
| 	}
 | |
| 
 | |
| 	return 0;
 | |
| }
 | |
| DEFINE_SHOW_ATTRIBUTE(rsnd_debugfs);
 | |
| 
 | |
| void rsnd_debugfs_reg_show(struct seq_file *m, phys_addr_t _addr,
 | |
| 			   void __iomem *base, int offset, int size)
 | |
| {
 | |
| 	int i, j;
 | |
| 
 | |
| 	for (i = 0; i < size; i += 0x10) {
 | |
| 		phys_addr_t addr = _addr + offset + i;
 | |
| 
 | |
| 		seq_printf(m, "%pa:", &addr);
 | |
| 		for (j = 0; j < 0x10; j += 0x4)
 | |
| 			seq_printf(m, " %08x", __raw_readl(base + offset + i + j));
 | |
| 		seq_puts(m, "\n");
 | |
| 	}
 | |
| }
 | |
| 
 | |
| void rsnd_debugfs_mod_reg_show(struct seq_file *m, struct rsnd_mod *mod,
 | |
| 			       int reg_id, int offset, int size)
 | |
| {
 | |
| 	struct rsnd_priv *priv = rsnd_mod_to_priv(mod);
 | |
| 
 | |
| 	rsnd_debugfs_reg_show(m,
 | |
| 			      rsnd_gen_get_phy_addr(priv, reg_id),
 | |
| 			      rsnd_gen_get_base_addr(priv, reg_id),
 | |
| 			      offset, size);
 | |
| }
 | |
| 
 | |
| int rsnd_debugfs_probe(struct snd_soc_component *component)
 | |
| {
 | |
| 	struct rsnd_priv *priv = dev_get_drvdata(component->dev);
 | |
| 	struct rsnd_dai *rdai;
 | |
| 	struct dentry *dir;
 | |
| 	char name[64];
 | |
| 	int i;
 | |
| 
 | |
| 	/* Gen1 is not supported */
 | |
| 	if (rsnd_is_gen1(priv))
 | |
| 		return 0;
 | |
| 
 | |
| 	for_each_rsnd_dai(rdai, priv, i) {
 | |
| 		/*
 | |
| 		 * created debugfs will be automatically
 | |
| 		 * removed, nothing to do for _remove.
 | |
| 		 * see
 | |
| 		 *	soc_cleanup_component_debugfs()
 | |
| 		 */
 | |
| 		snprintf(name, sizeof(name), "rdai%d", i);
 | |
| 		dir = debugfs_create_dir(name, component->debugfs_root);
 | |
| 
 | |
| 		debugfs_create_file("playback", 0444, dir, &rdai->playback, &rsnd_debugfs_fops);
 | |
| 		debugfs_create_file("capture",  0444, dir, &rdai->capture,  &rsnd_debugfs_fops);
 | |
| 	}
 | |
| 
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| #endif /* CONFIG_DEBUG_FS */
 |