From: Djalal Harouni <tixxdz@opendz.org>
To: Sergei Zviagintsev <sergei@s15v.net>
Cc: David Herrmann <dh.herrmann@gmail.com>,
Greg Kroah-Hartman <gregkh@linuxfoundation.org>,
Daniel Mack <daniel@zonque.org>,
David Herrmann <dh.herrmann@googlemail.com>,
linux-kernel <linux-kernel@vger.kernel.org>
Subject: Re: [PATCH RFC 5/5] kdbus: improve tests on incrementing quota
Date: Thu, 2 Jul 2015 15:13:41 +0100 [thread overview]
Message-ID: <20150702141341.GA5452@dztty> (raw)
In-Reply-To: <20150702134500.GS17917@localhost.localdomain>
Hi Sergei,
On Thu, Jul 02, 2015 at 04:45:00PM +0300, Sergei Zviagintsev wrote:
> Hi David,
>
> Thank you for reviewing and providing comments on these all! I answered below.
>
> On Thu, Jul 02, 2015 at 10:50:47AM +0200, David Herrmann wrote:
> > Hi
> >
> > On Sun, Jun 28, 2015 at 3:17 PM, Sergei Zviagintsev <sergei@s15v.net> wrote:
> > > 1) Rewrite
> > >
> > > quota->memory + memory > U32_MAX
> > >
> > > as
> > > U32_MAX - quota->memory < memory
> > >
> > > and provide the comment on why we need that check.
> > >
> > > We have no overflow issue in the original expression when size_t is
> > > 32-bit because the previous one (available - quota->memory < memory)
> > > guarantees that quota->memory + memory doesn't exceed `available'
> > > which is <= U32_MAX in that case.
> > >
> > > But lets stay explicit rather than implicit, it would save us from
> > > describing HOW the code works.
> > >
> > > 2) Add WARN_ON when quota->msgs > KDBUS_CONN_MAX_MSGS
> > >
> > > This is somewhat inconsistent, so we need to properly report it.
> >
> > I don't see the purpose of this WARN_ON(). Sure, ">" should never
> > happen, but that doesn't mean we have to add a WARN_ON. I'd just keep
> > the code as it is.
>
> I agree on WARN_ON. The intention of this change was to provide
> consistency. Current code checks for 'quota->msgs > KDBUS_CONN_MAX_MSGS'
> having '>=' test. If this ever happens, it means that we have a bug, but
> silently ignore it.
>
> If we agree that '>' case should never happen, isn't it better to
> place '==' instead of '>=' in the original test?
>
> >
> > > 3) Replace
> > >
> > > quota->fds + fds < quota->fds ||
> > > quota->fds + fds > KDBUS_CONN_MAX_FDS_PER_USER
> > >
> > > with
> > >
> > > KDBUS_CONN_MAX_FDS_PER_USER - quota->fds < fds
> > >
> > > and add explicit WARN_ON in the case
> > > quota->fds > KDBUS_CONN_MAX_FDS_PER_USER.
> > >
> > > Reading the code one can assume that the first expression is
> > > there to ensure that we won't have an overflow in quota->fds after
> > > quota->fds += fds, but what it really does is testing for size_t
> > > overflow in `quota->fds + fds' to be safe in the second expression
> > > (as fds is size_t, quota->fds is converted to bigger type).
> > >
> > > Rewrite it in more obvious way. KDBUS_CONN_MAX_FDS_PER_USER is
> > > checked at compile time to fill in quota->fds type (there is
> > > BUILD_BUG_ON), so no further checks for quota->fds overflow are
> > > needed.
> > >
> > > Signed-off-by: Sergei Zviagintsev <sergei@s15v.net>
> > > ---
> > > ipc/kdbus/connection.c | 18 +++++++++++++-----
> > > 1 file changed, 13 insertions(+), 5 deletions(-)
> > >
> > > diff --git a/ipc/kdbus/connection.c b/ipc/kdbus/connection.c
> > > index 12e32de310f5..6556a0f9d44c 100644
> > > --- a/ipc/kdbus/connection.c
> > > +++ b/ipc/kdbus/connection.c
> > > @@ -701,13 +701,21 @@ int kdbus_conn_quota_inc(struct kdbus_conn *c, struct kdbus_user *u,
> > > available = (available - accounted + quota->memory) / 3;
> > >
> > > if (available < quota->memory ||
> > > - available - quota->memory < memory ||
> > > - quota->memory + memory > U32_MAX)
> > > + available - quota->memory < memory)
> > > return -ENOBUFS;
> > > - if (quota->msgs >= KDBUS_CONN_MAX_MSGS)
> > > +
> > > + /*
> > > + * available is size_t and thus it could be greater than U32_MAX.
> > > + * Ensure that quota->memory won't overflow.
> > > + */
> > > + if (U32_MAX - quota->memory < memory)
> > > + return -ENOBUFS;
> >
> > Can you drop the comment and integrate it into the condition above? I
> > mean this whole section is about overflow checks, I don't see the
> > point of explaining one of them specially.
>
> My journey with this piece of code began from spotting and immediately
> "fixing" the overflow issue :) Then I decided to dig into the
> out-of-tree repo to find the origin of this line. What I found were
> commits af8e2f750985 and ac5c385cc67a in which Djalal "fixed" it as
> well, but then reverted back to the original code.
>
> Surely we can drop this explanation, but if one of kdbus maintainers
> experienced difficulties in understanding this piece of code, wouldn't
> one who sees this code in the first time have the same issues?
Yes there was lot of work in this area to make sure that the quota
accounting is correct! the previous commits the one that tried to clean
things up and the revert were both correct :-) , there were guards
before this code path in the pool and slice allocation that prevented
the code to overflow, see the commit logs af8e2f750985 of ac5c385cc67a
;-)
But later we had to optimize pool allocation and other kdbus paths for
performance reasons, some future changes may affect this code path...
So yeh it will be safer to keep the overflow check. For the comment yeh
it is not needed since that whole section is for overflow checks.
Thank you!
--
Djalal Harouni
http://opendz.org
next prev parent reply other threads:[~2015-07-02 14:14 UTC|newest]
Thread overview: 24+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-06-28 13:17 [PATCH RFC 0/5] kdbus: minor quota code improvements Sergei Zviagintsev
2015-06-28 13:17 ` [PATCH RFC 1/5] kdbus: fix typos in kdbus_conn_quota_inc() Sergei Zviagintsev
2015-07-02 8:31 ` David Herrmann
2015-07-02 9:51 ` Sergei Zviagintsev
2015-07-02 10:26 ` David Herrmann
2015-06-28 13:17 ` [PATCH RFC 2/5] kdbus: use standard kernel types in struct kdbus_quota Sergei Zviagintsev
2015-07-02 8:32 ` David Herrmann
2015-06-28 13:17 ` [PATCH RFC 3/5] kdbus: do explicit overflow check in kdbus_conn_quota_inc() Sergei Zviagintsev
2015-07-02 8:35 ` David Herrmann
2015-07-02 14:06 ` Sergei Zviagintsev
2015-06-28 13:17 ` [PATCH RFC 4/5] kdbus: handle WARN_ON cases properly when decrementing quota Sergei Zviagintsev
2015-07-02 8:37 ` David Herrmann
2015-07-02 10:27 ` Sergei Zviagintsev
2015-06-28 13:17 ` [PATCH RFC 5/5] kdbus: improve tests on incrementing quota Sergei Zviagintsev
2015-07-02 8:50 ` David Herrmann
2015-07-02 13:45 ` Sergei Zviagintsev
2015-07-02 14:13 ` Djalal Harouni [this message]
2015-07-02 17:47 ` Sergei Zviagintsev
2015-07-04 11:48 ` David Herrmann
2015-07-04 11:42 ` David Herrmann
2015-07-04 13:32 ` Sergei Zviagintsev
2015-07-06 18:48 ` [PATCH RFC 0/5] kdbus: minor quota code improvements David Herrmann
2015-07-07 16:29 ` Sergei Zviagintsev
2015-07-07 22:21 ` Greg Kroah-Hartman
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=20150702141341.GA5452@dztty \
--to=tixxdz@opendz.org \
--cc=daniel@zonque.org \
--cc=dh.herrmann@gmail.com \
--cc=dh.herrmann@googlemail.com \
--cc=gregkh@linuxfoundation.org \
--cc=linux-kernel@vger.kernel.org \
--cc=sergei@s15v.net \
/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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox