Commit ad8bc199 authored by Thomas Weißschuh's avatar Thomas Weißschuh Committed by Wim Van Sebroeck

watchdog: report options in sysfs

This synchronizes the information reported by ioctl and sysfs.
The mismatch is confusing because "wdctl" from util-linux uses the ioctl
when used with root privileges and sysfs without.
Signed-off-by: default avatarThomas Weißschuh <linux@weissschuh.net>
Reviewed-by: default avatarGuenter Roeck <linux@roeck-us.net>
Link: https://lore.kernel.org/r/20221216-watchdog-sysfs-v2-2-6189311103a9@weissschuh.net
[groeck: Fixed continuation line alignment]
Signed-off-by: default avatarGuenter Roeck <linux@roeck-us.net>
Signed-off-by: default avatarWim Van Sebroeck <wim@linux-watchdog.org>
parent b852e7a4
...@@ -6,6 +6,12 @@ Description: ...@@ -6,6 +6,12 @@ Description:
device at boot. It is equivalent to WDIOC_GETBOOTSTATUS of device at boot. It is equivalent to WDIOC_GETBOOTSTATUS of
ioctl interface. ioctl interface.
What: /sys/class/watchdog/watchdogn/options
Date: April 2023
Contact: Thomas Weißschuh
Description:
It is a read only file. It contains options of watchdog device.
What: /sys/class/watchdog/watchdogn/fw_version What: /sys/class/watchdog/watchdogn/fw_version
Date: April 2023 Date: April 2023
Contact: Thomas Weißschuh Contact: Thomas Weißschuh
......
...@@ -547,6 +547,15 @@ static ssize_t pretimeout_show(struct device *dev, ...@@ -547,6 +547,15 @@ static ssize_t pretimeout_show(struct device *dev,
} }
static DEVICE_ATTR_RO(pretimeout); static DEVICE_ATTR_RO(pretimeout);
static ssize_t options_show(struct device *dev, struct device_attribute *attr,
char *buf)
{
struct watchdog_device *wdd = dev_get_drvdata(dev);
return sysfs_emit(buf, "0x%x\n", wdd->info->options);
}
static DEVICE_ATTR_RO(options);
static ssize_t fw_version_show(struct device *dev, struct device_attribute *attr, static ssize_t fw_version_show(struct device *dev, struct device_attribute *attr,
char *buf) char *buf)
{ {
...@@ -627,6 +636,7 @@ static umode_t wdt_is_visible(struct kobject *kobj, struct attribute *attr, ...@@ -627,6 +636,7 @@ static umode_t wdt_is_visible(struct kobject *kobj, struct attribute *attr,
} }
static struct attribute *wdt_attrs[] = { static struct attribute *wdt_attrs[] = {
&dev_attr_state.attr, &dev_attr_state.attr,
&dev_attr_options.attr,
&dev_attr_fw_version.attr, &dev_attr_fw_version.attr,
&dev_attr_identity.attr, &dev_attr_identity.attr,
&dev_attr_timeout.attr, &dev_attr_timeout.attr,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment