Commit 132d03ea authored by Viresh Kumar's avatar Viresh Kumar Committed by Greg Kroah-Hartman

greybus: sysfs: generalize gb_module_attr() to capture more cases

Most of the attribute routines are created with gb_module_attr() and few are
left out because they weren't printing 32 bit hexadecimal values.

Extend gb_module_attr() to cover more cases.
Signed-off-by: default avatarViresh Kumar <viresh.kumar@linaro.org>
Reviewed-by: default avatarAlex Elder <elder@linaro.org>
Signed-off-by: default avatarGreg Kroah-Hartman <greg@kroah.com>
parent 37d8afc4
...@@ -20,55 +20,28 @@ ...@@ -20,55 +20,28 @@
#include "kernel_ver.h" #include "kernel_ver.h"
/* Module fields */ /* Module fields */
#define gb_module_attr(field) \ #define gb_module_attr(field, type) \
static ssize_t module_##field##_show(struct device *dev, \ static ssize_t module_##field##_show(struct device *dev, \
struct device_attribute *attr, \ struct device_attribute *attr, \
char *buf) \ char *buf) \
{ \ { \
struct gb_module *gmod = to_gb_module(dev); \ struct gb_module *gmod = to_gb_module(dev); \
return sprintf(buf, "%x\n", gmod->field); \ return sprintf(buf, "%"#type"\n", gmod->field); \
} \ } \
static DEVICE_ATTR_RO(module_##field) static DEVICE_ATTR_RO(module_##field)
gb_module_attr(vendor); gb_module_attr(vendor, x);
gb_module_attr(product); gb_module_attr(product, x);
gb_module_attr(version); gb_module_attr(version, x);
gb_module_attr(unique_id, llX);
static ssize_t module_serial_number_show(struct device *dev, gb_module_attr(vendor_string, s);
struct device_attribute *attr, gb_module_attr(product_string, s);
char *buf)
{
struct gb_module *gmod = to_gb_module(dev);
return sprintf(buf, "%llX\n", (unsigned long long)gmod->unique_id);
}
static DEVICE_ATTR_RO(module_serial_number);
static ssize_t module_vendor_string_show(struct device *dev,
struct device_attribute *attr,
char *buf)
{
struct gb_module *gmod = to_gb_module(dev);
return sprintf(buf, "%s", gmod->vendor_string);
}
static DEVICE_ATTR_RO(module_vendor_string);
static ssize_t module_product_string_show(struct device *dev,
struct device_attribute *attr,
char *buf)
{
struct gb_module *gmod = to_gb_module(dev);
return sprintf(buf, "%s", gmod->product_string);
}
static DEVICE_ATTR_RO(module_product_string);
static struct attribute *module_attrs[] = { static struct attribute *module_attrs[] = {
&dev_attr_module_vendor.attr, &dev_attr_module_vendor.attr,
&dev_attr_module_product.attr, &dev_attr_module_product.attr,
&dev_attr_module_version.attr, &dev_attr_module_version.attr,
&dev_attr_module_serial_number.attr, &dev_attr_module_unique_id.attr,
&dev_attr_module_vendor_string.attr, &dev_attr_module_vendor_string.attr,
&dev_attr_module_product_string.attr, &dev_attr_module_product_string.attr,
NULL, NULL,
......
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