|
@@ -34,7 +34,8 @@ field##_show(struct device *dev, struct device_attribute *attr, char *buf) \
|
|
|
\
|
|
|
func = dev_to_sdio_func (dev); \
|
|
|
return sprintf (buf, format_string, func->field); \
|
|
|
-}
|
|
|
+} \
|
|
|
+static DEVICE_ATTR_RO(field)
|
|
|
|
|
|
sdio_config_attr(class, "0x%02x\n");
|
|
|
sdio_config_attr(vendor, "0x%04x\n");
|
|
@@ -47,14 +48,16 @@ static ssize_t modalias_show(struct device *dev, struct device_attribute *attr,
|
|
|
return sprintf(buf, "sdio:c%02Xv%04Xd%04X\n",
|
|
|
func->class, func->vendor, func->device);
|
|
|
}
|
|
|
-
|
|
|
-static struct device_attribute sdio_dev_attrs[] = {
|
|
|
- __ATTR_RO(class),
|
|
|
- __ATTR_RO(vendor),
|
|
|
- __ATTR_RO(device),
|
|
|
- __ATTR_RO(modalias),
|
|
|
- __ATTR_NULL,
|
|
|
+static DEVICE_ATTR_RO(modalias);
|
|
|
+
|
|
|
+static struct attribute *sdio_dev_attrs[] = {
|
|
|
+ &dev_attr_class.attr,
|
|
|
+ &dev_attr_vendor.attr,
|
|
|
+ &dev_attr_device.attr,
|
|
|
+ &dev_attr_modalias.attr,
|
|
|
+ NULL,
|
|
|
};
|
|
|
+ATTRIBUTE_GROUPS(sdio_dev);
|
|
|
|
|
|
static const struct sdio_device_id *sdio_match_one(struct sdio_func *func,
|
|
|
const struct sdio_device_id *id)
|
|
@@ -225,7 +228,7 @@ static const struct dev_pm_ops sdio_bus_pm_ops = {
|
|
|
|
|
|
static struct bus_type sdio_bus_type = {
|
|
|
.name = "sdio",
|
|
|
- .dev_attrs = sdio_dev_attrs,
|
|
|
+ .dev_groups = sdio_dev_groups,
|
|
|
.match = sdio_bus_match,
|
|
|
.uevent = sdio_bus_uevent,
|
|
|
.probe = sdio_bus_probe,
|