summaryrefslogtreecommitdiff
path: root/drivers/video/tegra/dc/mipi_cal.c
diff options
context:
space:
mode:
authorVineel Kumar Reddy Kovvuri <vineelkumarr@nvidia.com>2013-08-28 17:18:29 +0530
committerDan Willemsen <dwillemsen@nvidia.com>2013-09-14 13:44:58 -0700
commite1de9f8c5bb8572903de0284ad110a6cc77f78a6 (patch)
tree8883c00a0569da254dfb41719b7fee4c758fc1c8 /drivers/video/tegra/dc/mipi_cal.c
parent73090eb8ef7a2a7deb435e85133dd4d76ad213f8 (diff)
video: tegra: dsi: Create DSI MIPI debugfs nodes
Implements Debugfs node for DSI MIPI register dump Change-Id: I8965d47cb1f18fcd605eb19ff86702c4edd01877 Signed-off-by: Vineel Kumar Reddy Kovvuri <vineelkumarr@nvidia.com> Reviewed-on: http://git-master/r/267337 Reviewed-by: Automatic_Commit_Validation_User Reviewed-by: Animesh Kishore <ankishore@nvidia.com> GVS: Gerrit_Virtual_Submit Reviewed-by: Venkat Moganty <vmoganty@nvidia.com>
Diffstat (limited to 'drivers/video/tegra/dc/mipi_cal.c')
-rw-r--r--drivers/video/tegra/dc/mipi_cal.c74
1 files changed, 73 insertions, 1 deletions
diff --git a/drivers/video/tegra/dc/mipi_cal.c b/drivers/video/tegra/dc/mipi_cal.c
index bcfe21fdfa3f..2f0fc05acb56 100644
--- a/drivers/video/tegra/dc/mipi_cal.c
+++ b/drivers/video/tegra/dc/mipi_cal.c
@@ -14,6 +14,7 @@
*
*/
+#include <linux/debugfs.h>
#include <linux/ioport.h>
#include <linux/gfp.h>
#include <linux/export.h>
@@ -22,6 +23,74 @@
#include "mipi_cal_regs.h"
#include "dsi.h"
+#include "../../../../arch/arm/mach-tegra/iomap.h"
+
+#ifdef CONFIG_DEBUG_FS
+static int dbg_dsi_mipi_show(struct seq_file *s, void *unused)
+{
+ struct tegra_mipi_cal *mipi_cal = s->private;
+ unsigned long i = 0;
+ u32 col = 0;
+
+ BUG_ON(IS_ERR_OR_NULL(mipi_cal));
+ mutex_lock(&mipi_cal->lock);
+ tegra_mipi_cal_clk_enable(mipi_cal);
+
+ /* mem dd dump */
+ for (col = 0, i = 0; i <= MIPI_VALID_REG_LIMIT ; i += 4) {
+ if (col == 0)
+ seq_printf(s, "%08lX:", TEGRA_MIPI_BASE + i);
+ seq_printf(s, "%c%08lX", col == 2 ? '-' : ' ',
+ tegra_mipi_cal_read(mipi_cal, i));
+ if (col == 3) {
+ seq_printf(s, "\n");
+ col = 0;
+ } else
+ col++;
+ }
+ seq_printf(s, "\n");
+
+ tegra_mipi_cal_clk_disable(mipi_cal);
+ mutex_unlock(&mipi_cal->lock);
+ return 0;
+}
+
+static int dbg_dsi_mipi_open(struct inode *inode, struct file *file)
+{
+ return single_open(file, dbg_dsi_mipi_show, inode->i_private);
+}
+
+static const struct file_operations dbg_fops = {
+ .open = dbg_dsi_mipi_open,
+ .read = seq_read,
+ .llseek = seq_lseek,
+ .release = single_release,
+};
+
+static struct dentry *mipidir;
+
+static void dbg_dsi_mipi_dir_create(struct tegra_mipi_cal *mipi_cal)
+{
+ struct dentry *retval;
+
+ mipidir = debugfs_create_dir("tegra_mipi_cal", NULL);
+ if (!mipidir)
+ return;
+ retval = debugfs_create_file("regs", S_IRUGO, mipidir, mipi_cal,
+ &dbg_fops);
+ if (!retval)
+ goto free_out;
+ return;
+free_out:
+ debugfs_remove_recursive(mipidir);
+ mipidir = NULL;
+ return;
+}
+#else
+static inline void dbg_dsi_mipi_dir_create(struct tegra_mipi_cal *mipi_cal)
+{ }
+#endif
+
int tegra_mipi_cal_init_hw(struct tegra_mipi_cal *mipi_cal)
{
unsigned cnt = MIPI_CAL_MIPI_CAL_CTRL_0;
@@ -110,7 +179,7 @@ struct tegra_mipi_cal *tegra_mipi_cal_init_sw(struct tegra_dc *dc)
mipi_cal->base = base;
mipi_cal->clk = clk;
mipi_cal->fixed_clk = fixed_clk;
-
+ dbg_dsi_mipi_dir_create(mipi_cal);
return mipi_cal;
fail_free_map:
@@ -145,6 +214,9 @@ void tegra_mipi_cal_destroy(struct tegra_dc *dc)
mutex_destroy(&mipi_cal->lock);
devm_kfree(&dc->ndev->dev, mipi_cal);
+#ifdef CONFIG_DEBUG_FS
+ debugfs_remove_recursive(mipidir);
+#endif
}
EXPORT_SYMBOL(tegra_mipi_cal_destroy);