mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-13 16:31:09 +00:00
90 lines
2.4 KiB
Diff
90 lines
2.4 KiB
Diff
|
From 4d219b15a7a01a14c1be1eeee9a939732130d30a Mon Sep 17 00:00:00 2001
|
||
|
From: Naushir Patuck <naush@raspberrypi.com>
|
||
|
Date: Tue, 13 Aug 2024 13:45:54 +0100
|
||
|
Subject: [PATCH 1242/1350] spi: rp2040-gpio-bridge: Add debugfs progress
|
||
|
indicator
|
||
|
|
||
|
Useful for tracking upload progress via userspace.
|
||
|
|
||
|
Signed-off-by: Naushir Patuck <naush@raspberrypi.com>
|
||
|
---
|
||
|
drivers/spi/spi-rp2040-gpio-bridge.c | 24 ++++++++++++++++++++++++
|
||
|
1 file changed, 24 insertions(+)
|
||
|
|
||
|
--- a/drivers/spi/spi-rp2040-gpio-bridge.c
|
||
|
+++ b/drivers/spi/spi-rp2040-gpio-bridge.c
|
||
|
@@ -6,6 +6,7 @@
|
||
|
*/
|
||
|
|
||
|
#include <crypto/hash.h>
|
||
|
+#include <linux/debugfs.h>
|
||
|
#include <linux/crypto.h>
|
||
|
#include <linux/delay.h>
|
||
|
#include <linux/firmware.h>
|
||
|
@@ -91,6 +92,9 @@ enum rp2040_gbdg_fixed_size_commands {
|
||
|
struct rp2040_gbdg {
|
||
|
struct spi_controller *controller;
|
||
|
|
||
|
+ struct dentry *debugfs;
|
||
|
+ size_t transfer_progress;
|
||
|
+
|
||
|
struct i2c_client *client;
|
||
|
struct crypto_shash *shash;
|
||
|
struct shash_desc *shash_desc;
|
||
|
@@ -702,6 +706,7 @@ static int rp2040_gbdg_transfer_cached(s
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
+ priv_data->transfer_progress = 0;
|
||
|
while (length) {
|
||
|
unsigned int xfer = min(length, RP2040_GBDG_BLOCK_SIZE);
|
||
|
|
||
|
@@ -710,7 +715,9 @@ static int rp2040_gbdg_transfer_cached(s
|
||
|
return ret;
|
||
|
length -= xfer;
|
||
|
data += xfer;
|
||
|
+ priv_data->transfer_progress += xfer;
|
||
|
}
|
||
|
+ priv_data->transfer_progress = 0;
|
||
|
|
||
|
return 0;
|
||
|
}
|
||
|
@@ -1016,6 +1023,16 @@ static int rp2040_gbdg_power_on(struct r
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
+static int transfer_progress_show(struct seq_file *s, void *data)
|
||
|
+{
|
||
|
+ struct rp2040_gbdg *rp2040_gbdg = s->private;
|
||
|
+
|
||
|
+ seq_printf(s, "%zu\n", rp2040_gbdg->transfer_progress);
|
||
|
+ return 0;
|
||
|
+}
|
||
|
+
|
||
|
+DEFINE_SHOW_ATTRIBUTE(transfer_progress);
|
||
|
+
|
||
|
static int rp2040_gbdg_probe(struct i2c_client *client)
|
||
|
{
|
||
|
struct rp2040_gbdg_device_info info;
|
||
|
@@ -1023,6 +1040,7 @@ static int rp2040_gbdg_probe(struct i2c_
|
||
|
struct device *dev = &client->dev;
|
||
|
struct rp2040_gbdg *rp2040_gbdg;
|
||
|
struct device_node *np;
|
||
|
+ char debugfs_name[128];
|
||
|
int ret;
|
||
|
|
||
|
np = dev->of_node;
|
||
|
@@ -1136,6 +1154,12 @@ static int rp2040_gbdg_probe(struct i2c_
|
||
|
|
||
|
rp2040_gbdg_parse_dt(rp2040_gbdg);
|
||
|
|
||
|
+ snprintf(debugfs_name, sizeof(debugfs_name), "rp2040-spi:%s",
|
||
|
+ dev_name(dev));
|
||
|
+ rp2040_gbdg->debugfs = debugfs_create_dir(debugfs_name, NULL);
|
||
|
+ debugfs_create_file("transfer_progress", 0444, rp2040_gbdg->debugfs,
|
||
|
+ rp2040_gbdg, &transfer_progress_fops);
|
||
|
+
|
||
|
pm_runtime_mark_last_busy(dev);
|
||
|
pm_runtime_put_autosuspend(dev);
|
||
|
|