Commit 07e00341 authored by David Fries's avatar David Fries Committed by Linus Torvalds

W1: w1_slave_read_id read bug, use device_attribute

Fix bug reading the id sysfs file.  If less than the full 8 bytes were
read, the next read would start at the first byte instead of continuing.
It needed the offset added to memcpy, or the better solution was to
replace it with the device attribute instead of bin attribute.
Signed-off-by: default avatarDavid Fries <david@fries.net>
Signed-off-by: default avatarEvgeniy Polyakov <johnpol@2ka.mipt.ru>
Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
parent eba3b06d
...@@ -103,35 +103,20 @@ static ssize_t w1_slave_read_name(struct device *dev, struct device_attribute *a ...@@ -103,35 +103,20 @@ static ssize_t w1_slave_read_name(struct device *dev, struct device_attribute *a
return sprintf(buf, "%s\n", sl->name); return sprintf(buf, "%s\n", sl->name);
} }
static ssize_t w1_slave_read_id(struct kobject *kobj, static ssize_t w1_slave_read_id(struct device *dev,
struct bin_attribute *bin_attr, struct device_attribute *attr, char *buf)
char *buf, loff_t off, size_t count)
{ {
struct w1_slave *sl = kobj_to_w1_slave(kobj); struct w1_slave *sl = dev_to_w1_slave(dev);
ssize_t count = sizeof(sl->reg_num);
if (off > 8) {
count = 0;
} else {
if (off + count > 8)
count = 8 - off;
memcpy(buf, (u8 *)&sl->reg_num, count); memcpy(buf, (u8 *)&sl->reg_num, count);
}
return count; return count;
} }
static struct device_attribute w1_slave_attr_name = static struct device_attribute w1_slave_attr_name =
__ATTR(name, S_IRUGO, w1_slave_read_name, NULL); __ATTR(name, S_IRUGO, w1_slave_read_name, NULL);
static struct device_attribute w1_slave_attr_id =
static struct bin_attribute w1_slave_attr_bin_id = { __ATTR(id, S_IRUGO, w1_slave_read_id, NULL);
.attr = {
.name = "id",
.mode = S_IRUGO,
},
.size = 8,
.read = w1_slave_read_id,
};
/* Default family */ /* Default family */
...@@ -650,7 +635,7 @@ static int __w1_attach_slave_device(struct w1_slave *sl) ...@@ -650,7 +635,7 @@ static int __w1_attach_slave_device(struct w1_slave *sl)
} }
/* Create "id" entry */ /* Create "id" entry */
err = sysfs_create_bin_file(&sl->dev.kobj, &w1_slave_attr_bin_id); err = device_create_file(&sl->dev, &w1_slave_attr_id);
if (err < 0) { if (err < 0) {
dev_err(&sl->dev, dev_err(&sl->dev,
"sysfs file creation for [%s] failed. err=%d\n", "sysfs file creation for [%s] failed. err=%d\n",
...@@ -672,7 +657,7 @@ static int __w1_attach_slave_device(struct w1_slave *sl) ...@@ -672,7 +657,7 @@ static int __w1_attach_slave_device(struct w1_slave *sl)
return 0; return 0;
out_rem2: out_rem2:
sysfs_remove_bin_file(&sl->dev.kobj, &w1_slave_attr_bin_id); device_remove_file(&sl->dev, &w1_slave_attr_id);
out_rem1: out_rem1:
device_remove_file(&sl->dev, &w1_slave_attr_name); device_remove_file(&sl->dev, &w1_slave_attr_name);
out_unreg: out_unreg:
...@@ -754,7 +739,7 @@ void w1_slave_detach(struct w1_slave *sl) ...@@ -754,7 +739,7 @@ void w1_slave_detach(struct w1_slave *sl)
msg.type = W1_SLAVE_REMOVE; msg.type = W1_SLAVE_REMOVE;
w1_netlink_send(sl->master, &msg); w1_netlink_send(sl->master, &msg);
sysfs_remove_bin_file(&sl->dev.kobj, &w1_slave_attr_bin_id); device_remove_file(&sl->dev, &w1_slave_attr_id);
device_remove_file(&sl->dev, &w1_slave_attr_name); device_remove_file(&sl->dev, &w1_slave_attr_name);
device_unregister(&sl->dev); device_unregister(&sl->dev);
......
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