1*cf84ac9aSAndroid Build Coastguard Worker /*
2*cf84ac9aSAndroid Build Coastguard Worker * Check decoding of signal delivery.
3*cf84ac9aSAndroid Build Coastguard Worker *
4*cf84ac9aSAndroid Build Coastguard Worker * Copyright (c) 2016-2018 The strace developers.
5*cf84ac9aSAndroid Build Coastguard Worker * All rights reserved.
6*cf84ac9aSAndroid Build Coastguard Worker *
7*cf84ac9aSAndroid Build Coastguard Worker * Redistribution and use in source and binary forms, with or without
8*cf84ac9aSAndroid Build Coastguard Worker * modification, are permitted provided that the following conditions
9*cf84ac9aSAndroid Build Coastguard Worker * are met:
10*cf84ac9aSAndroid Build Coastguard Worker * 1. Redistributions of source code must retain the above copyright
11*cf84ac9aSAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer.
12*cf84ac9aSAndroid Build Coastguard Worker * 2. Redistributions in binary form must reproduce the above copyright
13*cf84ac9aSAndroid Build Coastguard Worker * notice, this list of conditions and the following disclaimer in the
14*cf84ac9aSAndroid Build Coastguard Worker * documentation and/or other materials provided with the distribution.
15*cf84ac9aSAndroid Build Coastguard Worker * 3. The name of the author may not be used to endorse or promote products
16*cf84ac9aSAndroid Build Coastguard Worker * derived from this software without specific prior written permission.
17*cf84ac9aSAndroid Build Coastguard Worker *
18*cf84ac9aSAndroid Build Coastguard Worker * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
19*cf84ac9aSAndroid Build Coastguard Worker * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
20*cf84ac9aSAndroid Build Coastguard Worker * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
21*cf84ac9aSAndroid Build Coastguard Worker * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
22*cf84ac9aSAndroid Build Coastguard Worker * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
23*cf84ac9aSAndroid Build Coastguard Worker * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24*cf84ac9aSAndroid Build Coastguard Worker * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25*cf84ac9aSAndroid Build Coastguard Worker * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26*cf84ac9aSAndroid Build Coastguard Worker * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
27*cf84ac9aSAndroid Build Coastguard Worker * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28*cf84ac9aSAndroid Build Coastguard Worker */
29*cf84ac9aSAndroid Build Coastguard Worker
30*cf84ac9aSAndroid Build Coastguard Worker #include "tests.h"
31*cf84ac9aSAndroid Build Coastguard Worker #include <signal.h>
32*cf84ac9aSAndroid Build Coastguard Worker #include <stdio.h>
33*cf84ac9aSAndroid Build Coastguard Worker #include <unistd.h>
34*cf84ac9aSAndroid Build Coastguard Worker
35*cf84ac9aSAndroid Build Coastguard Worker static volatile int s_sig, s_code, s_pid, s_uid;
36*cf84ac9aSAndroid Build Coastguard Worker
37*cf84ac9aSAndroid Build Coastguard Worker static void
handler(int sig,siginfo_t * info,void * ucontext)38*cf84ac9aSAndroid Build Coastguard Worker handler(int sig, siginfo_t *info, void *ucontext)
39*cf84ac9aSAndroid Build Coastguard Worker {
40*cf84ac9aSAndroid Build Coastguard Worker s_sig = info->si_signo;
41*cf84ac9aSAndroid Build Coastguard Worker s_code = info->si_code;
42*cf84ac9aSAndroid Build Coastguard Worker s_pid = info->si_pid;
43*cf84ac9aSAndroid Build Coastguard Worker s_uid = info->si_uid;
44*cf84ac9aSAndroid Build Coastguard Worker }
45*cf84ac9aSAndroid Build Coastguard Worker
46*cf84ac9aSAndroid Build Coastguard Worker int
main(void)47*cf84ac9aSAndroid Build Coastguard Worker main(void)
48*cf84ac9aSAndroid Build Coastguard Worker {
49*cf84ac9aSAndroid Build Coastguard Worker static const char prefix[] = "KERNEL BUG";
50*cf84ac9aSAndroid Build Coastguard Worker int printed = 0;
51*cf84ac9aSAndroid Build Coastguard Worker
52*cf84ac9aSAndroid Build Coastguard Worker const int pid = getpid();
53*cf84ac9aSAndroid Build Coastguard Worker const int uid = geteuid();
54*cf84ac9aSAndroid Build Coastguard Worker
55*cf84ac9aSAndroid Build Coastguard Worker for (int sig = 1; sig <= 31; ++sig) {
56*cf84ac9aSAndroid Build Coastguard Worker if (sig == SIGKILL || sig == SIGSTOP)
57*cf84ac9aSAndroid Build Coastguard Worker continue;
58*cf84ac9aSAndroid Build Coastguard Worker
59*cf84ac9aSAndroid Build Coastguard Worker sigset_t mask;
60*cf84ac9aSAndroid Build Coastguard Worker sigemptyset(&mask);
61*cf84ac9aSAndroid Build Coastguard Worker sigaddset(&mask, sig);
62*cf84ac9aSAndroid Build Coastguard Worker if (sigprocmask(SIG_UNBLOCK, &mask, NULL))
63*cf84ac9aSAndroid Build Coastguard Worker perror_msg_and_fail("sigprocmask");
64*cf84ac9aSAndroid Build Coastguard Worker
65*cf84ac9aSAndroid Build Coastguard Worker static const struct sigaction act = {
66*cf84ac9aSAndroid Build Coastguard Worker .sa_sigaction = handler,
67*cf84ac9aSAndroid Build Coastguard Worker .sa_flags = SA_SIGINFO
68*cf84ac9aSAndroid Build Coastguard Worker };
69*cf84ac9aSAndroid Build Coastguard Worker if (sigaction(sig, &act, NULL))
70*cf84ac9aSAndroid Build Coastguard Worker perror_msg_and_fail("sigaction: %d", sig);
71*cf84ac9aSAndroid Build Coastguard Worker
72*cf84ac9aSAndroid Build Coastguard Worker if (kill(pid, sig) != 0)
73*cf84ac9aSAndroid Build Coastguard Worker perror_msg_and_fail("kill: %d", sig);
74*cf84ac9aSAndroid Build Coastguard Worker
75*cf84ac9aSAndroid Build Coastguard Worker #ifdef MPERS_IS_m32
76*cf84ac9aSAndroid Build Coastguard Worker /*
77*cf84ac9aSAndroid Build Coastguard Worker * The tracee has received a compat siginfo_t but
78*cf84ac9aSAndroid Build Coastguard Worker * the tracer has received a native siginfo_t.
79*cf84ac9aSAndroid Build Coastguard Worker */
80*cf84ac9aSAndroid Build Coastguard Worker const int e_sig = sig;
81*cf84ac9aSAndroid Build Coastguard Worker const int e_pid = pid;
82*cf84ac9aSAndroid Build Coastguard Worker const int e_uid = uid;
83*cf84ac9aSAndroid Build Coastguard Worker #else
84*cf84ac9aSAndroid Build Coastguard Worker /*
85*cf84ac9aSAndroid Build Coastguard Worker * If the tracee is a native process,
86*cf84ac9aSAndroid Build Coastguard Worker * then the tracer is also native.
87*cf84ac9aSAndroid Build Coastguard Worker * If the tracee is a compat process,
88*cf84ac9aSAndroid Build Coastguard Worker * then the tracer is also compat.
89*cf84ac9aSAndroid Build Coastguard Worker * Anyway, both the tracee and the tracer
90*cf84ac9aSAndroid Build Coastguard Worker * have received the same siginfo_t.
91*cf84ac9aSAndroid Build Coastguard Worker */
92*cf84ac9aSAndroid Build Coastguard Worker const int e_sig = s_sig;
93*cf84ac9aSAndroid Build Coastguard Worker const int e_pid = s_pid;
94*cf84ac9aSAndroid Build Coastguard Worker const int e_uid = s_uid;
95*cf84ac9aSAndroid Build Coastguard Worker #endif
96*cf84ac9aSAndroid Build Coastguard Worker printf("kill(%d, %s) = 0\n", pid, signal2name(sig));
97*cf84ac9aSAndroid Build Coastguard Worker printf("--- %s {si_signo=%s, si_code=SI_USER, si_pid=%d"
98*cf84ac9aSAndroid Build Coastguard Worker ", si_uid=%d} ---\n",
99*cf84ac9aSAndroid Build Coastguard Worker signal2name(sig), signal2name(e_sig), e_pid, e_uid);
100*cf84ac9aSAndroid Build Coastguard Worker
101*cf84ac9aSAndroid Build Coastguard Worker if (s_code || sig != s_sig || pid != s_pid || uid != s_uid) {
102*cf84ac9aSAndroid Build Coastguard Worker /*
103*cf84ac9aSAndroid Build Coastguard Worker * The kernel has failed to initialize siginfo_t
104*cf84ac9aSAndroid Build Coastguard Worker * properly. There is nothing that could be done
105*cf84ac9aSAndroid Build Coastguard Worker * on the strace side to workaround the kernel bug,
106*cf84ac9aSAndroid Build Coastguard Worker * so just print some useful diagnostics.
107*cf84ac9aSAndroid Build Coastguard Worker */
108*cf84ac9aSAndroid Build Coastguard Worker if (!printed) {
109*cf84ac9aSAndroid Build Coastguard Worker printed = 1;
110*cf84ac9aSAndroid Build Coastguard Worker fprintf(stderr, "%s: siginfo_t\n", prefix);
111*cf84ac9aSAndroid Build Coastguard Worker }
112*cf84ac9aSAndroid Build Coastguard Worker fprintf(stderr,
113*cf84ac9aSAndroid Build Coastguard Worker "%s: expected: si_signo=%d, si_code=%d"
114*cf84ac9aSAndroid Build Coastguard Worker ", si_pid=%d, si_uid=%d\n"
115*cf84ac9aSAndroid Build Coastguard Worker "%s: received: si_signo=%d, si_code=%d"
116*cf84ac9aSAndroid Build Coastguard Worker ", si_pid=%d, si_uid=%d\n",
117*cf84ac9aSAndroid Build Coastguard Worker prefix, sig, SI_USER, pid, uid,
118*cf84ac9aSAndroid Build Coastguard Worker prefix, sig, s_code, s_pid, s_uid);
119*cf84ac9aSAndroid Build Coastguard Worker }
120*cf84ac9aSAndroid Build Coastguard Worker }
121*cf84ac9aSAndroid Build Coastguard Worker
122*cf84ac9aSAndroid Build Coastguard Worker if (printed) {
123*cf84ac9aSAndroid Build Coastguard Worker fprintf(stderr, "%s: end of diagnostics\n"
124*cf84ac9aSAndroid Build Coastguard Worker "*** PLEASE FIX THE KERNEL ***\n", prefix);
125*cf84ac9aSAndroid Build Coastguard Worker }
126*cf84ac9aSAndroid Build Coastguard Worker
127*cf84ac9aSAndroid Build Coastguard Worker puts("+++ exited with 0 +++");
128*cf84ac9aSAndroid Build Coastguard Worker return 0;
129*cf84ac9aSAndroid Build Coastguard Worker }
130