From: Dmitry V. Levin Date: Mon, 13 Mar 2017 11:37:36 +0000 (+0000) Subject: tests: rewrite sigreturn syscall decoding check from match_grep to match_diff X-Git-Tag: v4.17~167 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=645eb6405b198497b8ee023090582410103b5c70;p=strace tests: rewrite sigreturn syscall decoding check from match_grep to match_diff Unlike the former test that was based on match_grep, the new one uses match_diff and does more rigorous testing. * tests/sigreturn.c: Rewrite. * tests/sigreturn.test: Likewise. --- diff --git a/tests/sigreturn.c b/tests/sigreturn.c index dace040a..ff9a59f7 100644 --- a/tests/sigreturn.c +++ b/tests/sigreturn.c @@ -1,5 +1,5 @@ /* - * Copyright (c) 2015-2016 Dmitry V. Levin + * Copyright (c) 2015-2017 Dmitry V. Levin * All rights reserved. * * Redistribution and use in source and binary forms, with or without @@ -26,23 +26,38 @@ */ #include "tests.h" -#include -#include +#include -#ifdef ASM_SIGRTMIN -# define RT_0 ASM_SIGRTMIN -#else -/* Linux kernel >= 3.18 defines SIGRTMIN to 32 on all architectures. */ -# define RT_0 32 +#if defined __powerpc64__ \ + || (defined __sparc__ && defined __arch64__) +/* Old sigreturn is defined but not implemented in the kernel. */ +# undef __NR_sigreturn #endif -static void handler(int sig) +#ifdef __NR_sigreturn + +# include +# include +# include + +# ifdef ASM_SIGRTMIN +# define RT_0 ASM_SIGRTMIN +# else +/* Linux kernel >= 3.18 defines SIGRTMIN to 32 on all architectures. */ +# define RT_0 32 +# endif + +static void +handler(int sig) { } -int main(void) { - sigset_t set; +int +main(void) +{ + static sigset_t set; sigemptyset(&set); + sigaddset(&set, SIGINT); sigaddset(&set, SIGUSR2); sigaddset(&set, SIGCHLD); sigaddset(&set, RT_0 + 3); @@ -50,8 +65,28 @@ int main(void) { sigaddset(&set, RT_0 + 5); sigaddset(&set, RT_0 + 26); sigaddset(&set, RT_0 + 27); - sigprocmask(SIG_SETMASK, &set, NULL); - signal(SIGUSR1, handler); - raise(SIGUSR1); + if (sigprocmask(SIG_SETMASK, &set, NULL)) + perror_msg_and_fail("sigprocmask"); + sigemptyset(&set); + + /* This should result to old sigreturn. */ + if (signal(SIGUSR1, handler) == SIG_ERR) + perror_msg_and_fail("sigaction"); + + if (raise(SIGUSR1)) + perror_msg_and_fail("raise"); + + static const char *const sigs = + (SIGUSR2 < SIGCHLD) ? "INT USR2 CHLD" : "INT CHLD USR2"; + static const char *const rt_sigs = "RT_3 RT_4 RT_5 RT_26 RT_27"; + printf("sigreturn({mask=[%s %s]}) = 0\n", sigs, rt_sigs); + + puts("+++ exited with 0 +++"); return 0; } + +#else + +SKIP_MAIN_UNDEFINED("__NR_sigreturn") + +#endif diff --git a/tests/sigreturn.test b/tests/sigreturn.test index dc9df181..17e9a2b9 100755 --- a/tests/sigreturn.test +++ b/tests/sigreturn.test @@ -1,48 +1,6 @@ #!/bin/sh -# -# Check rt_sigprocmask and sigreturn/rt_sigreturn decoding. -# -# Copyright (c) 2015-2016 Dmitry V. Levin -# All rights reserved. -# -# Redistribution and use in source and binary forms, with or without -# modification, are permitted provided that the following conditions -# are met: -# 1. Redistributions of source code must retain the above copyright -# notice, this list of conditions and the following disclaimer. -# 2. Redistributions in binary form must reproduce the above copyright -# notice, this list of conditions and the following disclaimer in the -# documentation and/or other materials provided with the distribution. -# 3. The name of the author may not be used to endorse or promote products -# derived from this software without specific prior written permission. -# -# THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR -# IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES -# OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. -# IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, -# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT -# NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY -# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT -# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF -# THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. +# Check decoding of sigreturn syscall. . "${srcdir=.}/init.sh" -run_prog -run_strace -e%signal $args - -mask='\[(USR2 CHLD|CHLD USR2) RT_3 RT_4 RT_5 RT_26 RT_27\]' -rt_sigprocmask='rt_sigprocmask\(SIG_SETMASK, '"$mask"', NULL, [[:digit:]]+\) += 0' -osf_sigprocmask='osf_sigprocmask\(SIG_SETMASK, '"$mask"'\) += 0 +\(old mask \[[^]]*\]\)' -EXPECTED="$LOG.expected" - -cat > "$EXPECTED" << __EOF__ -$rt_sigprocmask|$osf_sigprocmask -(rt_)?sigreturn\\((\\{mask=$mask\\})?\\) += 0 -__EOF__ - -match_grep "$LOG" "$EXPECTED" -rm -f "$EXPECTED" - -exit 0 +run_strace_match_diff -esignal='!USR1'