2010-04-24 06:54:17 +00:00
|
|
|
--- a/drivers/ssb/main.c
|
|
|
|
+++ b/drivers/ssb/main.c
|
|
|
|
@@ -385,6 +385,34 @@ static int ssb_device_uevent(struct devi
|
|
|
|
ssb_dev->id.revision);
|
|
|
|
}
|
|
|
|
|
|
|
|
+#define ssb_config_attr(attrib, field, format_string) \
|
|
|
|
+static ssize_t \
|
|
|
|
+attrib##_show(struct device *dev, struct device_attribute *attr, char *buf) \
|
|
|
|
+{ \
|
2010-07-31 10:06:05 +00:00
|
|
|
+ return sprintf(buf, format_string, dev_to_ssb_dev(dev)->field); \
|
2010-04-24 06:54:17 +00:00
|
|
|
+}
|
|
|
|
+
|
|
|
|
+ssb_config_attr(core_num, core_index, "%u\n")
|
|
|
|
+ssb_config_attr(coreid, id.coreid, "0x%04x\n")
|
|
|
|
+ssb_config_attr(vendor, id.vendor, "0x%04x\n")
|
|
|
|
+ssb_config_attr(revision, id.revision, "%u\n")
|
|
|
|
+ssb_config_attr(irq, irq, "%u\n")
|
|
|
|
+static ssize_t
|
|
|
|
+name_show(struct device *dev, struct device_attribute *attr, char *buf)
|
|
|
|
+{
|
2010-07-31 10:06:05 +00:00
|
|
|
+ return sprintf(buf, "%s\n", ssb_core_name(dev_to_ssb_dev(dev)->id.coreid));
|
2010-04-24 06:54:17 +00:00
|
|
|
+}
|
|
|
|
+
|
|
|
|
+static struct device_attribute ssb_device_attrs[] = {
|
|
|
|
+ __ATTR_RO(name),
|
|
|
|
+ __ATTR_RO(core_num),
|
|
|
|
+ __ATTR_RO(coreid),
|
|
|
|
+ __ATTR_RO(vendor),
|
|
|
|
+ __ATTR_RO(revision),
|
|
|
|
+ __ATTR_RO(irq),
|
|
|
|
+ __ATTR_NULL,
|
|
|
|
+};
|
|
|
|
+
|
|
|
|
static struct bus_type ssb_bustype = {
|
|
|
|
.name = "ssb",
|
|
|
|
.match = ssb_bus_match,
|
|
|
|
@@ -394,6 +422,7 @@ static struct bus_type ssb_bustype = {
|
|
|
|
.suspend = ssb_device_suspend,
|
|
|
|
.resume = ssb_device_resume,
|
|
|
|
.uevent = ssb_device_uevent,
|
|
|
|
+ .dev_attrs = ssb_device_attrs,
|
|
|
|
};
|
|
|
|
|
|
|
|
static void ssb_buses_lock(void)
|