From: Walter Harms <wharms@bfs.de>
To: David Laight <David.Laight@ACULAB.COM>,
'Sergey Organov' <sorganov@gmail.com>
Cc: 'Dan Carpenter' <dan.carpenter@oracle.com>,
Joel Stanley <joel@jms.id.au>, Andrew Jeffery <andrew@aj.id.au>,
"Chia-Wei, Wang" <chiawei_wang@aspeedtech.com>,
Jae Hyun Yoo <jae.hyun.yoo@intel.com>,
"John Wang" <wangzhiqiang.bj@bytedance.com>,
Brad Bishop <bradleyb@fuzziesquirrel.com>,
Patrick Venture <venture@google.com>,
"Benjamin Fair" <benjaminfair@google.com>,
Greg Kroah-Hartman <gregkh@linuxfoundation.org>,
Robert Lippert <rlippert@google.com>,
"linux-aspeed@lists.ozlabs.org" <linux-aspeed@lists.ozlabs.org>,
"linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>,
"kernel-janitors@vger.kernel.org"
<kernel-janitors@vger.kernel.org>
Subject: AW: [PATCH] soc: aspeed: fix a ternary sign expansion bug
Date: Fri, 23 Apr 2021 11:03:30 +0000 [thread overview]
Message-ID: <ebe4a1a6dd0748e28e6ca19aec20223e@bfs.de> (raw)
In-Reply-To: <265e2d3accc74c89b5bab22eadb43808@AcuMS.aculab.com>
as indepentent observer,
i would go for Dans solution:
ret = kfifo_to_user();
/* if an error occurs just return */
if (ret)
return ret;
/* otherwise return the copied number of bytes */
return copied;
there is no need for any deeper language knowledge,
jm2c
re,
wh
________________________________________
Von: David Laight <David.Laight@ACULAB.COM>
Gesendet: Freitag, 23. April 2021 12:54:59
An: 'Sergey Organov'
Cc: 'Dan Carpenter'; Joel Stanley; Andrew Jeffery; Chia-Wei, Wang; Jae Hyun Yoo; John Wang; Brad Bishop; Patrick Venture; Benjamin Fair; Greg Kroah-Hartman; Robert Lippert; linux-aspeed@lists.ozlabs.org; linux-kernel@vger.kernel.org; kernel-janitors@vger.kernel.org
Betreff: RE: [PATCH] soc: aspeed: fix a ternary sign expansion bug
WARNUNG: Diese E-Mail kam von außerhalb der Organisation. Klicken Sie nicht auf Links oder öffnen Sie keine Anhänge, es sei denn, Sie kennen den/die Absender*in und wissen, dass der Inhalt sicher ist.
From: Sergey Organov
> Sent: 23 April 2021 11:46
>
> David Laight <David.Laight@ACULAB.COM> writes:
>
> > From: Dan Carpenter
> >> Sent: 22 April 2021 10:12
> >>
> >> The intent here was to return negative error codes but it actually
> >> returns positive values. The problem is that type promotion with
> >> ternary operations is quite complicated.
> >>
> >> "ret" is an int. "copied" is a u32. And the snoop_file_read() function
> >> returns long. What happens is that "ret" is cast to u32 and becomes
> >> positive then it's cast to long and it's still positive.
> >>
> >> Fix this by removing the ternary so that "ret" is type promoted directly
> >> to long.
> >>
> >> Fixes: 3772e5da4454 ("drivers/misc: Aspeed LPC snoop output using misc chardev")
> >> Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
> >> ---
> >> drivers/soc/aspeed/aspeed-lpc-snoop.c | 4 +++-
> >> 1 file changed, 3 insertions(+), 1 deletion(-)
> >>
> >> diff --git a/drivers/soc/aspeed/aspeed-lpc-snoop.c b/drivers/soc/aspeed/aspeed-lpc-snoop.c
> >> index 210455efb321..eceeaf8dfbeb 100644
> >> --- a/drivers/soc/aspeed/aspeed-lpc-snoop.c
> >> +++ b/drivers/soc/aspeed/aspeed-lpc-snoop.c
> >> @@ -94,8 +94,10 @@ static ssize_t snoop_file_read(struct file *file, char __user *buffer,
> >> return -EINTR;
> >> }
> >> ret = kfifo_to_user(&chan->fifo, buffer, count, &copied);
> >> + if (ret)
> >> + return ret;
> >>
> >> - return ret ? ret : copied;
> >> + return copied;
> >
> > I wonder if changing it to:
> > return ret ? ret + 0L : copied;
> >
> > Might make people think in the future and not convert it back
> > as an 'optimisation'.
>
> It rather made me think: "what the heck is going on here?!"
>
> Shouldn't it better be:
>
> return ret ? ret : (long)copied;
>
> or even:
>
> return ret ?: (long)copied;
Or change the return type to int ?
The problem is that ?: doesn't behave the way most people expect.
The two possible values have to be converted to the same type.
Together with the broken decision of the original ANSI C committee
to change from K&R's 'sign preserving' to 'value preserving'
integer promotions causes grief here and elsewhere.
(Not no mention breaking existing code!)
David
-
Registered Address Lakeside, Bramley Road, Mount Farm, Milton Keynes, MK1 1PT, UK
Registration No: 1397386 (Wales)
WARNING: multiple messages have this Message-ID (diff)
From: Walter Harms <wharms@bfs.de>
To: linux-aspeed@lists.ozlabs.org
Subject: AW: [PATCH] soc: aspeed: fix a ternary sign expansion bug
Date: Fri, 23 Apr 2021 11:03:30 +0000 [thread overview]
Message-ID: <ebe4a1a6dd0748e28e6ca19aec20223e@bfs.de> (raw)
In-Reply-To: <265e2d3accc74c89b5bab22eadb43808@AcuMS.aculab.com>
as indepentent observer,
i would go for Dans solution:
ret = kfifo_to_user();
/* if an error occurs just return */
if (ret)
return ret;
/* otherwise return the copied number of bytes */
return copied;
there is no need for any deeper language knowledge,
jm2c
re,
wh
________________________________________
Von: David Laight <David.Laight@ACULAB.COM>
Gesendet: Freitag, 23. April 2021 12:54:59
An: 'Sergey Organov'
Cc: 'Dan Carpenter'; Joel Stanley; Andrew Jeffery; Chia-Wei, Wang; Jae Hyun Yoo; John Wang; Brad Bishop; Patrick Venture; Benjamin Fair; Greg Kroah-Hartman; Robert Lippert; linux-aspeed at lists.ozlabs.org; linux-kernel at vger.kernel.org; kernel-janitors at vger.kernel.org
Betreff: RE: [PATCH] soc: aspeed: fix a ternary sign expansion bug
WARNUNG: Diese E-Mail kam von au?erhalb der Organisation. Klicken Sie nicht auf Links oder ?ffnen Sie keine Anh?nge, es sei denn, Sie kennen den/die Absender*in und wissen, dass der Inhalt sicher ist.
From: Sergey Organov
> Sent: 23 April 2021 11:46
>
> David Laight <David.Laight@ACULAB.COM> writes:
>
> > From: Dan Carpenter
> >> Sent: 22 April 2021 10:12
> >>
> >> The intent here was to return negative error codes but it actually
> >> returns positive values. The problem is that type promotion with
> >> ternary operations is quite complicated.
> >>
> >> "ret" is an int. "copied" is a u32. And the snoop_file_read() function
> >> returns long. What happens is that "ret" is cast to u32 and becomes
> >> positive then it's cast to long and it's still positive.
> >>
> >> Fix this by removing the ternary so that "ret" is type promoted directly
> >> to long.
> >>
> >> Fixes: 3772e5da4454 ("drivers/misc: Aspeed LPC snoop output using misc chardev")
> >> Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
> >> ---
> >> drivers/soc/aspeed/aspeed-lpc-snoop.c | 4 +++-
> >> 1 file changed, 3 insertions(+), 1 deletion(-)
> >>
> >> diff --git a/drivers/soc/aspeed/aspeed-lpc-snoop.c b/drivers/soc/aspeed/aspeed-lpc-snoop.c
> >> index 210455efb321..eceeaf8dfbeb 100644
> >> --- a/drivers/soc/aspeed/aspeed-lpc-snoop.c
> >> +++ b/drivers/soc/aspeed/aspeed-lpc-snoop.c
> >> @@ -94,8 +94,10 @@ static ssize_t snoop_file_read(struct file *file, char __user *buffer,
> >> return -EINTR;
> >> }
> >> ret = kfifo_to_user(&chan->fifo, buffer, count, &copied);
> >> + if (ret)
> >> + return ret;
> >>
> >> - return ret ? ret : copied;
> >> + return copied;
> >
> > I wonder if changing it to:
> > return ret ? ret + 0L : copied;
> >
> > Might make people think in the future and not convert it back
> > as an 'optimisation'.
>
> It rather made me think: "what the heck is going on here?!"
>
> Shouldn't it better be:
>
> return ret ? ret : (long)copied;
>
> or even:
>
> return ret ?: (long)copied;
Or change the return type to int ?
The problem is that ?: doesn't behave the way most people expect.
The two possible values have to be converted to the same type.
Together with the broken decision of the original ANSI C committee
to change from K&R's 'sign preserving' to 'value preserving'
integer promotions causes grief here and elsewhere.
(Not no mention breaking existing code!)
David
-
Registered Address Lakeside, Bramley Road, Mount Farm, Milton Keynes, MK1 1PT, UK
Registration No: 1397386 (Wales)
next prev parent reply other threads:[~2021-04-23 11:11 UTC|newest]
Thread overview: 28+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-04-22 9:11 [PATCH] soc: aspeed: fix a ternary sign expansion bug Dan Carpenter
2021-04-22 9:11 ` Dan Carpenter
2021-04-22 9:24 ` Al Viro
2021-04-22 9:24 ` Al Viro
2021-04-22 9:26 ` Al Viro
2021-04-22 9:26 ` Al Viro
2021-04-22 14:56 ` Patrick Venture
2021-04-22 14:56 ` Patrick Venture
2021-04-22 16:21 ` David Laight
2021-04-22 16:21 ` David Laight
2021-04-23 0:07 ` Joel Stanley
2021-04-23 0:07 ` Joel Stanley
2021-04-23 7:43 ` Dan Carpenter
2021-04-23 7:43 ` Dan Carpenter
2021-04-23 10:45 ` Sergey Organov
2021-04-23 10:45 ` Sergey Organov
2021-04-23 10:54 ` David Laight
2021-04-23 10:54 ` David Laight
2021-04-23 11:03 ` Walter Harms [this message]
2021-04-23 11:03 ` AW: " Walter Harms
2021-04-23 14:40 ` Sergey Organov
2021-04-23 14:40 ` Sergey Organov
2021-04-23 14:55 ` David Laight
2021-04-23 14:55 ` David Laight
2021-04-23 15:24 ` Dan Carpenter
2021-04-23 15:24 ` Dan Carpenter
2021-04-23 11:14 ` Dan Carpenter
2021-04-23 11:14 ` Dan Carpenter
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=ebe4a1a6dd0748e28e6ca19aec20223e@bfs.de \
--to=wharms@bfs.de \
--cc=David.Laight@ACULAB.COM \
--cc=andrew@aj.id.au \
--cc=benjaminfair@google.com \
--cc=bradleyb@fuzziesquirrel.com \
--cc=chiawei_wang@aspeedtech.com \
--cc=dan.carpenter@oracle.com \
--cc=gregkh@linuxfoundation.org \
--cc=jae.hyun.yoo@intel.com \
--cc=joel@jms.id.au \
--cc=kernel-janitors@vger.kernel.org \
--cc=linux-aspeed@lists.ozlabs.org \
--cc=linux-kernel@vger.kernel.org \
--cc=rlippert@google.com \
--cc=sorganov@gmail.com \
--cc=venture@google.com \
--cc=wangzhiqiang.bj@bytedance.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
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.