* [PATCH rtw-next] wifi: rtl8xxxu: expose efuse via debugfs
@ 2025-08-26 9:00 Martin Kaistra
2025-08-27 0:25 ` Ping-Ke Shih
0 siblings, 1 reply; 2+ messages in thread
From: Martin Kaistra @ 2025-08-26 9:00 UTC (permalink / raw)
To: linux-wireless; +Cc: Jes Sorensen, Ping-Ke Shih, Bitterblue Smith
The efuse contains the mac address and calibration data. During
manufacturing and testing it can be necessary to read and check this
data.
Add a debugfs interface to make it available to userspace.
Signed-off-by: Martin Kaistra <martin.kaistra@linutronix.de>
---
drivers/net/wireless/realtek/rtl8xxxu/core.c | 24 ++++++++++++++++++++
1 file changed, 24 insertions(+)
diff --git a/drivers/net/wireless/realtek/rtl8xxxu/core.c b/drivers/net/wireless/realtek/rtl8xxxu/core.c
index 831b5025c6349..b45010c93ad72 100644
--- a/drivers/net/wireless/realtek/rtl8xxxu/core.c
+++ b/drivers/net/wireless/realtek/rtl8xxxu/core.c
@@ -1901,6 +1901,29 @@ static void rtl8xxxu_dump_efuse(struct rtl8xxxu_priv *priv)
priv->efuse_wifi.raw, EFUSE_MAP_LEN, true);
}
+/* debugfs: efuse */
+static ssize_t read_file_efuse(struct file *file, char __user *user_buf,
+ size_t count, loff_t *ppos)
+{
+ struct rtl8xxxu_priv *priv = file_inode(file)->i_private;
+
+ return simple_read_from_buffer(user_buf, count, ppos,
+ priv->efuse_wifi.raw, EFUSE_MAP_LEN);
+}
+
+static const struct file_operations fops_efuse = {
+ .read = read_file_efuse,
+ .owner = THIS_MODULE,
+};
+
+static void rtl8xxxu_debugfs_init(struct rtl8xxxu_priv *priv)
+{
+ struct dentry *phydir;
+
+ phydir = debugfs_create_dir("rtl8xxxu", priv->hw->wiphy->debugfsdir);
+ debugfs_create_file("efuse", 0400, phydir, priv, &fops_efuse);
+}
+
void rtl8xxxu_reset_8051(struct rtl8xxxu_priv *priv)
{
u8 val8;
@@ -7974,6 +7997,7 @@ static int rtl8xxxu_probe(struct usb_interface *interface,
}
rtl8xxxu_init_led(priv);
+ rtl8xxxu_debugfs_init(priv);
return 0;
--
2.39.5
^ permalink raw reply related [flat|nested] 2+ messages in thread
* RE: [PATCH rtw-next] wifi: rtl8xxxu: expose efuse via debugfs
2025-08-26 9:00 [PATCH rtw-next] wifi: rtl8xxxu: expose efuse via debugfs Martin Kaistra
@ 2025-08-27 0:25 ` Ping-Ke Shih
0 siblings, 0 replies; 2+ messages in thread
From: Ping-Ke Shih @ 2025-08-27 0:25 UTC (permalink / raw)
To: Martin Kaistra, linux-wireless@vger.kernel.org
Cc: Jes Sorensen, Bitterblue Smith
Martin Kaistra <martin.kaistra@linutronix.de> wrote:
> The efuse contains the mac address and calibration data. During
> manufacturing and testing it can be necessary to read and check this
> data.
>
> Add a debugfs interface to make it available to userspace.
>
> Signed-off-by: Martin Kaistra <martin.kaistra@linutronix.de>
> ---
> drivers/net/wireless/realtek/rtl8xxxu/core.c | 24 ++++++++++++++++++++
> 1 file changed, 24 insertions(+)
>
> diff --git a/drivers/net/wireless/realtek/rtl8xxxu/core.c
> b/drivers/net/wireless/realtek/rtl8xxxu/core.c
> index 831b5025c6349..b45010c93ad72 100644
> --- a/drivers/net/wireless/realtek/rtl8xxxu/core.c
> +++ b/drivers/net/wireless/realtek/rtl8xxxu/core.c
> @@ -1901,6 +1901,29 @@ static void rtl8xxxu_dump_efuse(struct rtl8xxxu_priv *priv)
> priv->efuse_wifi.raw, EFUSE_MAP_LEN, true);
> }
>
> +/* debugfs: efuse */
Not sure if this comment is worth? If you want to emphasize 'debugfs', just
add it to function name.
> +static ssize_t read_file_efuse(struct file *file, char __user *user_buf,
> + size_t count, loff_t *ppos)
> +{
> + struct rtl8xxxu_priv *priv = file_inode(file)->i_private;
> +
> + return simple_read_from_buffer(user_buf, count, ppos,
> + priv->efuse_wifi.raw, EFUSE_MAP_LEN);
> +}
> +
> +static const struct file_operations fops_efuse = {
Use debugfs_short_fops to save spaces.
> + .read = read_file_efuse,
> + .owner = THIS_MODULE,
> +};
> +
> +static void rtl8xxxu_debugfs_init(struct rtl8xxxu_priv *priv)
> +{
> + struct dentry *phydir;
> +
> + phydir = debugfs_create_dir("rtl8xxxu", priv->hw->wiphy->debugfsdir);
> + debugfs_create_file("efuse", 0400, phydir, priv, &fops_efuse);
> +}
> +
> void rtl8xxxu_reset_8051(struct rtl8xxxu_priv *priv)
> {
> u8 val8;
> @@ -7974,6 +7997,7 @@ static int rtl8xxxu_probe(struct usb_interface *interface,
> }
>
> rtl8xxxu_init_led(priv);
> + rtl8xxxu_debugfs_init(priv);
>
> return 0;
>
> --
> 2.39.5
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2025-08-27 0:25 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-08-26 9:00 [PATCH rtw-next] wifi: rtl8xxxu: expose efuse via debugfs Martin Kaistra
2025-08-27 0:25 ` Ping-Ke Shih
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).