armbian_build/patch/kernel/archive/sunxi-5.17/patches.megous/input-touchscreen-goodix-Add-config-debugfs-file.patch
The-going 0f7200c793
Sunxi 5.17 (#3613)
* The initial state of a series of patches for sunxi-5.17

tag orange-pi-5.17-20220323-1423

* DEBUG for sunxi-5.17

* Add Armbian patches to 5.17

* Fix duplicate nodes for sun50i-h5-orangepi-pc2

* Fix reg_ahci_5v to status okay for bananapro board

* Remove an unused patch for an unsupported sun50i-h6-tanix-tx6 board
2022-03-31 20:32:04 +03:00

76 lines
2.2 KiB
Diff

From 1b556234a950eea427aba910016558c0b960a864 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Ond=C5=99ej=20Jirman?= <megi@xff.cz>
Date: Mon, 22 Jun 2020 17:17:09 +0200
Subject: [PATCH 091/456] input: touchscreen: goodix: Add config debugfs file
Signed-off-by: Ondrej Jirman <megi@xff.cz>
---
drivers/input/touchscreen/goodix.c | 17 +++++++++++++++++
drivers/input/touchscreen/goodix.h | 1 +
2 files changed, 18 insertions(+)
diff --git a/drivers/input/touchscreen/goodix.c b/drivers/input/touchscreen/goodix.c
index 752e8ba4fecb..00556749ef8b 100644
--- a/drivers/input/touchscreen/goodix.c
+++ b/drivers/input/touchscreen/goodix.c
@@ -22,6 +22,7 @@
#include <linux/slab.h>
#include <linux/acpi.h>
#include <linux/of.h>
+#include <linux/debugfs.h>
#include <asm/unaligned.h>
#include "goodix.h"
@@ -1028,6 +1029,16 @@ static int goodix_get_gpio_config(struct goodix_ts_data *ts)
return 0;
}
+static int ts_config_bin_show(struct seq_file *s, void *data)
+{
+ struct goodix_ts_data *ts = s->private;
+
+ seq_write(s, ts->config, ts->chip->config_len);
+
+ return 0;
+}
+DEFINE_SHOW_ATTRIBUTE(ts_config_bin);
+
/**
* goodix_read_config - Read the embedded configuration of the panel
*
@@ -1066,6 +1077,10 @@ static void goodix_read_config(struct goodix_ts_data *ts)
}
ts->chip->calc_config_checksum(ts);
+
+ ts->debug_root = debugfs_create_dir("goodix", NULL);
+ debugfs_create_file("config.bin", 0444, ts->debug_root, ts,
+ &ts_config_bin_fops);
}
/**
@@ -1389,6 +1404,8 @@ static int goodix_ts_remove(struct i2c_client *client)
if (ts->load_cfg_from_disk)
wait_for_completion(&ts->firmware_loading_complete);
+ debugfs_remove(ts->debug_root);
+
return 0;
}
diff --git a/drivers/input/touchscreen/goodix.h b/drivers/input/touchscreen/goodix.h
index fa8602e78a64..74cddff6e9e5 100644
--- a/drivers/input/touchscreen/goodix.h
+++ b/drivers/input/touchscreen/goodix.h
@@ -103,6 +103,7 @@ struct goodix_ts_data {
u8 main_clk[GOODIX_MAIN_CLK_LEN];
int bak_ref_len;
u8 *bak_ref;
+ struct dentry *debug_root;
};
int goodix_i2c_read(struct i2c_client *client, u16 reg, u8 *buf, int len);
--
2.34.1