public inbox for libc-alpha@sourceware.org
 help / color / mirror / Atom feed
From: Lukasz Majewski <lukma@denx.de>
To: Adhemerval Zanella <adhemerval.zanella@linaro.org>
Cc: Joseph Myers <joseph@codesourcery.com>,
	Paul Eggert <eggert@cs.ucla.edu>,
	Alistair Francis <alistair23@gmail.com>,
	Arnd Bergmann <arnd@arndb.de>,
	Alistair Francis <alistair.francis@wdc.com>,
	GNU C Library <libc-alpha@sourceware.org>,
	Florian Weimer <fweimer@redhat.com>,
	Carlos O'Donell <carlos@redhat.com>,
	Florian Weimer <fw@deneb.enyo.de>,
	Zack Weinberg <zackw@panix.com>
Subject: Re: [PATCH v2] tst: Provide test for ppoll
Date: Thu, 4 Feb 2021 15:42:24 +0100	[thread overview]
Message-ID: <20210204154224.20f4e316@jawa> (raw)
In-Reply-To: <bb228998-f683-a478-5dde-10cc1a40b364@linaro.org>

[-- Attachment #1: Type: text/plain, Size: 5881 bytes --]

Hi Adhemerval,

> On 14/01/2021 13:32, Lukasz Majewski wrote:
> > This change adds new test to assess ppoll()'s timeout related
> > functionality (the struct pollfd does not provide valid fd to wait
> > for - just wait for timeout).
> > 
> > To be more specific - two use cases are checked:
> > - if ppoll() times out immediately when passed struct timespec has
> > zero values of tv_nsec and tv_sec.
> > - if ppoll() times out after timeout specified in passed argument
> > 
> > ---
> > Changes for v2:
> > - Remove _GNU_SOURCE definition if not already defined
> > - Replace clock_gettime with xclock_gettime
> > - Use FAIL_EXIT1 instead of plain ret value returning from the test
> > ---
> >  sysdeps/unix/sysv/linux/Makefile    |  2 +-
> >  sysdeps/unix/sysv/linux/tst-ppoll.c | 62
> > +++++++++++++++++++++++++++++ 2 files changed, 63 insertions(+), 1
> > deletion(-) create mode 100644 sysdeps/unix/sysv/linux/tst-ppoll.c
> > 
> > diff --git a/sysdeps/unix/sysv/linux/Makefile
> > b/sysdeps/unix/sysv/linux/Makefile index 7503b356c8..f4029a74ca
> > 100644 --- a/sysdeps/unix/sysv/linux/Makefile
> > +++ b/sysdeps/unix/sysv/linux/Makefile
> > @@ -108,7 +108,7 @@ tests += tst-clone tst-clone2 tst-clone3
> > tst-fanotify tst-personality \ test-errno-linux tst-memfd_create
> > tst-mlock2 tst-pkey \ tst-rlimit-infinity tst-ofdlocks tst-gettid
> > tst-gettid-kill \ tst-tgkill tst-sysvsem-linux tst-sysvmsg-linux
> > tst-sysvshm-linux \
> > -	 tst-timerfd
> > +	 tst-timerfd tst-ppoll
> >  tests-internal += tst-ofdlocks-compat tst-sigcontext-get_pc
> >  
> >  CFLAGS-tst-sigcontext-get_pc.c = -fasynchronous-unwind-tables  
> 
> Ok.
> 
> > diff --git a/sysdeps/unix/sysv/linux/tst-ppoll.c
> > b/sysdeps/unix/sysv/linux/tst-ppoll.c new file mode 100644
> > index 0000000000..eeff97f103
> > --- /dev/null
> > +++ b/sysdeps/unix/sysv/linux/tst-ppoll.c
> > @@ -0,0 +1,62 @@
> > +/* Test for ppoll timeout
> > +   Copyright (C) 2021 Free Software Foundation, Inc.
> > +   This file is part of the GNU C Library.
> > +
> > +   The GNU C Library is free software; you can redistribute it
> > and/or
> > +   modify it under the terms of the GNU Lesser General Public
> > +   License as published by the Free Software Foundation; either
> > +   version 2.1 of the License, or (at your option) any later
> > version. +
> > +   The GNU C Library is distributed in the hope that it will be
> > useful,
> > +   but WITHOUT ANY WARRANTY; without even the implied warranty of
> > +   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
> > GNU
> > +   Lesser General Public License for more details.
> > +
> > +   You should have received a copy of the GNU Lesser General Public
> > +   License along with the GNU C Library; if not, see
> > +   <https://www.gnu.org/licenses/>.  */
> > +
> > +#include <time.h>
> > +#include <poll.h>
> > +#include <support/check.h>
> > +#include <support/xtime.h>
> > +
> > +/* Timeout in seconds for PPOLL.  */
> > +#define PPOLL_TIMEOUT 2
> > +/* Timeout for test program - must be larger than PPOLL_TIMEOUT.
> > */ +#define TIMEOUT 3  
> 
> This define is unused. 

When TIMEOUT is not specified - the default time out for test is used
(2 seconds). For the ppoll test we want to wait for 2 seconds, so
without this local #define TIMEOUT 3 the test is terminated by glibc
test suite before we go out from the ppoll.

However, as we now wait for 0.5 sec, it is feasible to just remove it
and used default settings.

> 
> > +
> > +static int test_ppoll_timeout (int timeout)
> > +{
> > +  struct timespec tv0 = { 0, 0 }, tv1 = { 0, 0 }, tv = { 0, 0 };
> > +  struct pollfd fds = { -1, 0, 0 };   /* Ignore fds - just wait
> > for timeout.  */
> > +  int ret;
> > +
> > +  tv.tv_sec = timeout;
> > +
> > +  xclock_gettime (CLOCK_REALTIME, &tv0);
> > +
> > +  ret = ppoll (&fds, 1, &tv, 0);
> > +  if (ret != 0)
> > +      FAIL_EXIT1 ("*** ppoll failed: %m\n");
> > +
> > +  xclock_gettime (CLOCK_REALTIME, &tv1);
> > +  if (tv0.tv_sec + timeout != tv1.tv_sec)
> > +      FAIL_EXIT1 ("*** ppoll failed to timeout after %d [s]\n",
> > timeout); +
> > +  return 0;
> > +}
> > +
> > +static int
> > +do_test (void)
> > +{
> > +  /* Check if ppoll exits immediately.  */
> > +  test_ppoll_timeout (0);
> > +
> > +  /* Check if ppoll exits after specified timeout.  */
> > +  test_ppoll_timeout (PPOLL_TIMEOUT);
> > +
> > +  return 0;
> > +}
> > +
> > +#include <support/test-driver.c>  
> 
> The exactly timeout check is subjected to a scheduler pressure and it
> might indicate false positive depending of the system load.  It would
> be better to check only if subsequent clock_gettime returns a time
> after previously than the ppoll check.  Like:
> 
> static int test_ppoll_timeout (bool zero_tmo)
> { 
>   /* We wait for half a second.  */
>   struct timespec ts;
>   xclock_gettime (CLOCK_REALTIME, &ts);
>   struct timespec timeout = make_timespec (0, zero_tmo ? 0 :
> TIMESPEC_HZ/2); ts = timespec_add (ts, timeout);
> 
>   /* Ignore fds - just wait for timeout.  */
>   struct pollfd fds = { -1, 0, 0 };
>   TEST_COMPARE (ppoll (&fds, 1, &timeout, 0), 0);
> 
>   TEST_TIMESPEC_NOW_OR_AFTER (CLOCK_REALTIME, ts);
> 
>   return 0;
> }
> 
> static int
> do_test (void)
> { 
>   /* Check if ppoll exits immediately.  */
>   test_ppoll_timeout (true);
> 
>   /* Check if ppoll exits after specified timeout.  */
>   test_ppoll_timeout (false);
> 
>   return 0;
> }
> 
> 

Thanks for the tip. I will add this code to the test.


Best regards,

Lukasz Majewski

--

DENX Software Engineering GmbH,      Managing Director: Wolfgang Denk
HRB 165235 Munich, Office: Kirchenstr.5, D-82194 Groebenzell, Germany
Phone: (+49)-8142-66989-59 Fax: (+49)-8142-66989-80 Email: lukma@denx.de

[-- Attachment #2: OpenPGP digital signature --]
[-- Type: application/pgp-signature, Size: 488 bytes --]

      reply	other threads:[~2021-02-04 14:42 UTC|newest]

Thread overview: 5+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2021-01-14 16:32 Lukasz Majewski
2021-02-03 14:14 ` Lukasz Majewski
2021-02-03 14:49 ` [Y2038][2.34] Status and future work Lukasz Majewski
2021-02-03 21:06 ` [PATCH v2] tst: Provide test for ppoll Adhemerval Zanella
2021-02-04 14:42   ` Lukasz Majewski [this message]

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=20210204154224.20f4e316@jawa \
    --to=lukma@denx.de \
    --cc=adhemerval.zanella@linaro.org \
    --cc=alistair.francis@wdc.com \
    --cc=alistair23@gmail.com \
    --cc=arnd@arndb.de \
    --cc=carlos@redhat.com \
    --cc=eggert@cs.ucla.edu \
    --cc=fw@deneb.enyo.de \
    --cc=fweimer@redhat.com \
    --cc=joseph@codesourcery.com \
    --cc=libc-alpha@sourceware.org \
    --cc=zackw@panix.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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).