aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/iio
diff options
context:
space:
mode:
authorLars-Peter Clausen <lars@metafoo.de>2012-10-22 07:15:00 -0400
committerJonathan Cameron <jic23@kernel.org>2012-11-02 05:43:48 -0400
commit02330acda7ef88865e62e2763df2cdd735607cb4 (patch)
tree7ecf6e71011b4eb8578a1f56f40987dd74e0f12d /drivers/iio
parent8f1b7eb11422d28fbc7432f0dee2f97aead09417 (diff)
iio: Reject trailing garbage when parsing fixed point numbers
When parsing a fixed point number IIO stops parsing the string once it has reached the last requested decimal place. This means that the remainder of the string is silently accepted regardless, of whether it is part of a valid number or not. This patch modifies the code to scan the whole string and only accept valid numbers. Since fract_mult is 0 after the last decimal place any digit that may follows won't affect the result. Signed-off-by: Lars-Peter Clausen <lars@metafoo.de> Signed-off-by: Jonathan Cameron <jic23@kernel.org>
Diffstat (limited to 'drivers/iio')
-rw-r--r--drivers/iio/industrialio-core.c2
1 files changed, 0 insertions, 2 deletions
diff --git a/drivers/iio/industrialio-core.c b/drivers/iio/industrialio-core.c
index 0994239361ba..7bb570b7a4af 100644
--- a/drivers/iio/industrialio-core.c
+++ b/drivers/iio/industrialio-core.c
@@ -445,8 +445,6 @@ static ssize_t iio_write_channel_info(struct device *dev,
445 integer = integer*10 + *buf - '0'; 445 integer = integer*10 + *buf - '0';
446 else { 446 else {
447 fract += fract_mult*(*buf - '0'); 447 fract += fract_mult*(*buf - '0');
448 if (fract_mult == 1)
449 break;
450 fract_mult /= 10; 448 fract_mult /= 10;
451 } 449 }
452 } else if (*buf == '\n') { 450 } else if (*buf == '\n') {