* backlight: catch invalid input
@ 2008-11-21 11:14 Pavel Machek
2008-11-21 23:54 ` Andrew Morton
0 siblings, 1 reply; 4+ messages in thread
From: Pavel Machek @ 2008-11-21 11:14 UTC (permalink / raw)
To: rpurdie, kernel list, Andrew Morton
Currently, echo > brightness turns brightness to zero due to
insufficient checking. Add a test to catch that.
Signed-off-by: Pavel Machek <pavel@suse.cz>
diff --git a/drivers/video/backlight/backlight.c b/drivers/video/backlight/backlight.c
index fab0bc8..5c2e23d 100644
--- a/drivers/video/backlight/backlight.c
+++ b/drivers/video/backlight/backlight.c
@@ -86,6 +86,8 @@ static ssize_t backlight_store_power(str
int power = simple_strtoul(buf, &endp, 0);
size_t size = endp - buf;
+ if (!size)
+ return -EINVAL;
if (*endp && isspace(*endp))
size++;
if (size != count)
--
(english) http://www.livejournal.com/~pavelmachek
(cesky, pictures) http://atrey.karlin.mff.cuni.cz/~pavel/picture/horses/blog.html
^ permalink raw reply related [flat|nested] 4+ messages in thread
* Re: backlight: catch invalid input
2008-11-21 11:14 backlight: catch invalid input Pavel Machek
@ 2008-11-21 23:54 ` Andrew Morton
2008-11-22 10:37 ` Pavel Machek
2008-11-22 20:31 ` Pavel Machek
0 siblings, 2 replies; 4+ messages in thread
From: Andrew Morton @ 2008-11-21 23:54 UTC (permalink / raw)
To: Pavel Machek; +Cc: rpurdie, linux-kernel
On Fri, 21 Nov 2008 12:14:14 +0100
Pavel Machek <pavel@suse.cz> wrote:
>
> Currently, echo > brightness turns brightness to zero due to
> insufficient checking. Add a test to catch that.
>
OK. And what happens if you do
echo wibble > brightness
?
>
> diff --git a/drivers/video/backlight/backlight.c b/drivers/video/backlight/backlight.c
> index fab0bc8..5c2e23d 100644
> --- a/drivers/video/backlight/backlight.c
> +++ b/drivers/video/backlight/backlight.c
> @@ -86,6 +86,8 @@ static ssize_t backlight_store_power(str
> int power = simple_strtoul(buf, &endp, 0);
> size_t size = endp - buf;
>
> + if (!size)
> + return -EINVAL;
> if (*endp && isspace(*endp))
> size++;
> if (size != count)
A better fix would be to use strict_strtoul() and check its return value.
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: backlight: catch invalid input
2008-11-21 23:54 ` Andrew Morton
@ 2008-11-22 10:37 ` Pavel Machek
2008-11-22 20:31 ` Pavel Machek
1 sibling, 0 replies; 4+ messages in thread
From: Pavel Machek @ 2008-11-22 10:37 UTC (permalink / raw)
To: Andrew Morton; +Cc: rpurdie, linux-kernel
On Fri 2008-11-21 15:54:21, Andrew Morton wrote:
> On Fri, 21 Nov 2008 12:14:14 +0100
> Pavel Machek <pavel@suse.cz> wrote:
>
> >
> > Currently, echo > brightness turns brightness to zero due to
> > insufficient checking. Add a test to catch that.
> >
>
> OK. And what happens if you do
>
> echo wibble > brightness
>
> ?
That's okay, that is catched by tests already existing in there. size
is the size we decoded, count is how many bytes user wrote. If (size
!= count), we return failure.
But there's an exception for whitespace, and missing check for nothing
at all being written.
> > diff --git a/drivers/video/backlight/backlight.c b/drivers/video/backlight/backlight.c
> > index fab0bc8..5c2e23d 100644
> > --- a/drivers/video/backlight/backlight.c
> > +++ b/drivers/video/backlight/backlight.c
> > @@ -86,6 +86,8 @@ static ssize_t backlight_store_power(str
> > int power = simple_strtoul(buf, &endp, 0);
> > size_t size = endp - buf;
> >
> > + if (!size)
> > + return -EINVAL;
> > if (*endp && isspace(*endp))
> > size++;
> > if (size != count)
>
> A better fix would be to use strict_strtoul() and check its return
> value.
Aha, here's the hint :-). Ok, will do.
Pavel
--
(english) http://www.livejournal.com/~pavelmachek
(cesky, pictures) http://atrey.karlin.mff.cuni.cz/~pavel/picture/horses/blog.html
^ permalink raw reply [flat|nested] 4+ messages in thread
* Re: backlight: catch invalid input
2008-11-21 23:54 ` Andrew Morton
2008-11-22 10:37 ` Pavel Machek
@ 2008-11-22 20:31 ` Pavel Machek
1 sibling, 0 replies; 4+ messages in thread
From: Pavel Machek @ 2008-11-22 20:31 UTC (permalink / raw)
To: Andrew Morton; +Cc: rpurdie, linux-kernel
Andrew hinted that strict_strtoul is right fix. Check input properly
in backlight, echo > brightness should not turn off the backlight.
Signed-off-by: Pavel Machek <pavel@suse.cz>
diff --git a/drivers/video/backlight/backlight.c b/drivers/video/backlight/backlight.c
index 5c2e23d..e4c93fc 100644
--- a/drivers/video/backlight/backlight.c
+++ b/drivers/video/backlight/backlight.c
@@ -80,22 +80,18 @@ static ssize_t backlight_show_power(stru
static ssize_t backlight_store_power(struct device *dev,
struct device_attribute *attr, const char *buf, size_t count)
{
- int rc = -ENXIO;
- char *endp;
+ int rc;
struct backlight_device *bd = to_backlight_device(dev);
- int power = simple_strtoul(buf, &endp, 0);
- size_t size = endp - buf;
+ unsigned long power;
- if (!size)
- return -EINVAL;
- if (*endp && isspace(*endp))
- size++;
- if (size != count)
- return -EINVAL;
+ rc = strict_strtoul(buf, 0, &power);
+ if (rc)
+ return rc;
+ rc = -ENXIO;
mutex_lock(&bd->ops_lock);
if (bd->ops) {
- pr_debug("backlight: set power to %d\n", power);
+ pr_debug("backlight: set power to %lu\n", power);
if (bd->props.power != power) {
bd->props.power = power;
backlight_update_status(bd);
@@ -118,23 +114,22 @@ static ssize_t backlight_show_brightness
static ssize_t backlight_store_brightness(struct device *dev,
struct device_attribute *attr, const char *buf, size_t count)
{
- int rc = -ENXIO;
- char *endp;
+ int rc;
struct backlight_device *bd = to_backlight_device(dev);
- int brightness = simple_strtoul(buf, &endp, 0);
- size_t size = endp - buf;
+ unsigned long brightness;
+
+ rc = strict_strtoul(buf, 0, &brightness);
+ if (rc)
+ return rc;
- if (*endp && isspace(*endp))
- size++;
- if (size != count)
- return -EINVAL;
+ rc = -ENXIO;
mutex_lock(&bd->ops_lock);
if (bd->ops) {
if (brightness > bd->props.max_brightness)
rc = -EINVAL;
else {
- pr_debug("backlight: set brightness to %d\n",
+ pr_debug("backlight: set brightness to %lu\n",
brightness);
if (bd->props.brightness != brightness) {
bd->props.brightness = brightness;
--
(english) http://www.livejournal.com/~pavelmachek
(cesky, pictures) http://atrey.karlin.mff.cuni.cz/~pavel/picture/horses/blog.html
^ permalink raw reply related [flat|nested] 4+ messages in thread
end of thread, other threads:[~2008-11-22 20:30 UTC | newest]
Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-11-21 11:14 backlight: catch invalid input Pavel Machek
2008-11-21 23:54 ` Andrew Morton
2008-11-22 10:37 ` Pavel Machek
2008-11-22 20:31 ` Pavel Machek
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.