aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/w1
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/w1')
-rw-r--r--drivers/w1/w1.c9
-rw-r--r--drivers/w1/w1_smem.c4
2 files changed, 7 insertions, 6 deletions
diff --git a/drivers/w1/w1.c b/drivers/w1/w1.c
index fd630cec0e79..8d7821899cc1 100644
--- a/drivers/w1/w1.c
+++ b/drivers/w1/w1.c
@@ -522,10 +522,11 @@ void w1_slave_found(unsigned long data, u64 rn)
522 slave_count++; 522 slave_count++;
523 } 523 }
524 524
525 if (slave_count == dev->slave_count && rn ) { 525 rn = cpu_to_le64(rn);
526 tmp = cpu_to_le64(rn); 526
527 if(((rn >> 56) & 0xff) == w1_calc_crc8((u8 *)&tmp, 7)) 527 if (slave_count == dev->slave_count &&
528 w1_attach_slave_device(dev, (struct w1_reg_num *) &rn); 528 rn && ((le64_to_cpu(rn) >> 56) & 0xff) == w1_calc_crc8((u8 *)&rn, 7)) {
529 w1_attach_slave_device(dev, tmp);
529 } 530 }
530 531
531 atomic_dec(&dev->refcnt); 532 atomic_dec(&dev->refcnt);
diff --git a/drivers/w1/w1_smem.c b/drivers/w1/w1_smem.c
index ab82eb7ed74f..a54e425217a0 100644
--- a/drivers/w1/w1_smem.c
+++ b/drivers/w1/w1_smem.c
@@ -60,7 +60,7 @@ static ssize_t w1_smem_read_val(struct device *dev, char *buf)
60 int i; 60 int i;
61 ssize_t count = 0; 61 ssize_t count = 0;
62 62
63 for (i = 0; i < 9; ++i) 63 for (i = 0; i < 8; ++i)
64 count += sprintf(buf + count, "%02x ", ((u8 *)&sl->reg_num)[i]); 64 count += sprintf(buf + count, "%02x ", ((u8 *)&sl->reg_num)[i]);
65 count += sprintf(buf + count, "\n"); 65 count += sprintf(buf + count, "\n");
66 66
@@ -87,7 +87,7 @@ static ssize_t w1_smem_read_bin(struct kobject *kobj, char *buf, loff_t off, siz
87 count = 0; 87 count = 0;
88 goto out; 88 goto out;
89 } 89 }
90 for (i = 0; i < 9; ++i) 90 for (i = 0; i < 8; ++i)
91 count += sprintf(buf + count, "%02x ", ((u8 *)&sl->reg_num)[i]); 91 count += sprintf(buf + count, "%02x ", ((u8 *)&sl->reg_num)[i]);
92 count += sprintf(buf + count, "\n"); 92 count += sprintf(buf + count, "\n");
93 93