aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/ide/ide-sysfs.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/ide/ide-sysfs.c')
-rw-r--r--drivers/ide/ide-sysfs.c35
1 files changed, 26 insertions, 9 deletions
diff --git a/drivers/ide/ide-sysfs.c b/drivers/ide/ide-sysfs.c
index 883ffacaf45a..84a6a9e08d64 100644
--- a/drivers/ide/ide-sysfs.c
+++ b/drivers/ide/ide-sysfs.c
@@ -25,6 +25,7 @@ static ssize_t media_show(struct device *dev, struct device_attribute *attr,
25 ide_drive_t *drive = to_ide_device(dev); 25 ide_drive_t *drive = to_ide_device(dev);
26 return sprintf(buf, "%s\n", ide_media_string(drive)); 26 return sprintf(buf, "%s\n", ide_media_string(drive));
27} 27}
28static DEVICE_ATTR_RO(media);
28 29
29static ssize_t drivename_show(struct device *dev, struct device_attribute *attr, 30static ssize_t drivename_show(struct device *dev, struct device_attribute *attr,
30 char *buf) 31 char *buf)
@@ -32,6 +33,7 @@ static ssize_t drivename_show(struct device *dev, struct device_attribute *attr,
32 ide_drive_t *drive = to_ide_device(dev); 33 ide_drive_t *drive = to_ide_device(dev);
33 return sprintf(buf, "%s\n", drive->name); 34 return sprintf(buf, "%s\n", drive->name);
34} 35}
36static DEVICE_ATTR_RO(drivename);
35 37
36static ssize_t modalias_show(struct device *dev, struct device_attribute *attr, 38static ssize_t modalias_show(struct device *dev, struct device_attribute *attr,
37 char *buf) 39 char *buf)
@@ -39,6 +41,7 @@ static ssize_t modalias_show(struct device *dev, struct device_attribute *attr,
39 ide_drive_t *drive = to_ide_device(dev); 41 ide_drive_t *drive = to_ide_device(dev);
40 return sprintf(buf, "ide:m-%s\n", ide_media_string(drive)); 42 return sprintf(buf, "ide:m-%s\n", ide_media_string(drive));
41} 43}
44static DEVICE_ATTR_RO(modalias);
42 45
43static ssize_t model_show(struct device *dev, struct device_attribute *attr, 46static ssize_t model_show(struct device *dev, struct device_attribute *attr,
44 char *buf) 47 char *buf)
@@ -46,6 +49,7 @@ static ssize_t model_show(struct device *dev, struct device_attribute *attr,
46 ide_drive_t *drive = to_ide_device(dev); 49 ide_drive_t *drive = to_ide_device(dev);
47 return sprintf(buf, "%s\n", (char *)&drive->id[ATA_ID_PROD]); 50 return sprintf(buf, "%s\n", (char *)&drive->id[ATA_ID_PROD]);
48} 51}
52static DEVICE_ATTR_RO(model);
49 53
50static ssize_t firmware_show(struct device *dev, struct device_attribute *attr, 54static ssize_t firmware_show(struct device *dev, struct device_attribute *attr,
51 char *buf) 55 char *buf)
@@ -53,6 +57,7 @@ static ssize_t firmware_show(struct device *dev, struct device_attribute *attr,
53 ide_drive_t *drive = to_ide_device(dev); 57 ide_drive_t *drive = to_ide_device(dev);
54 return sprintf(buf, "%s\n", (char *)&drive->id[ATA_ID_FW_REV]); 58 return sprintf(buf, "%s\n", (char *)&drive->id[ATA_ID_FW_REV]);
55} 59}
60static DEVICE_ATTR_RO(firmware);
56 61
57static ssize_t serial_show(struct device *dev, struct device_attribute *attr, 62static ssize_t serial_show(struct device *dev, struct device_attribute *attr,
58 char *buf) 63 char *buf)
@@ -60,16 +65,28 @@ static ssize_t serial_show(struct device *dev, struct device_attribute *attr,
60 ide_drive_t *drive = to_ide_device(dev); 65 ide_drive_t *drive = to_ide_device(dev);
61 return sprintf(buf, "%s\n", (char *)&drive->id[ATA_ID_SERNO]); 66 return sprintf(buf, "%s\n", (char *)&drive->id[ATA_ID_SERNO]);
62} 67}
68static DEVICE_ATTR(serial, 0400, serial_show, NULL);
69
70static DEVICE_ATTR(unload_heads, 0644, ide_park_show, ide_park_store);
71
72static struct attribute *ide_attrs[] = {
73 &dev_attr_media.attr,
74 &dev_attr_drivename.attr,
75 &dev_attr_modalias.attr,
76 &dev_attr_model.attr,
77 &dev_attr_firmware.attr,
78 &dev_attr_serial.attr,
79 &dev_attr_unload_heads.attr,
80 NULL,
81};
82
83static const struct attribute_group ide_attr_group = {
84 .attrs = ide_attrs,
85};
63 86
64struct device_attribute ide_dev_attrs[] = { 87const struct attribute_group *ide_dev_groups[] = {
65 __ATTR_RO(media), 88 &ide_attr_group,
66 __ATTR_RO(drivename), 89 NULL,
67 __ATTR_RO(modalias),
68 __ATTR_RO(model),
69 __ATTR_RO(firmware),
70 __ATTR(serial, 0400, serial_show, NULL),
71 __ATTR(unload_heads, 0644, ide_park_show, ide_park_store),
72 __ATTR_NULL
73}; 90};
74 91
75static ssize_t store_delete_devices(struct device *portdev, 92static ssize_t store_delete_devices(struct device *portdev,