1*49cdfc7eSAndroid Build Coastguard Worker // SPDX-License-Identifier: GPL-2.0-or-later
2*49cdfc7eSAndroid Build Coastguard Worker /*
3*49cdfc7eSAndroid Build Coastguard Worker * Copyright (c) 2020 FUJITSU LIMITED. All rights reserved.
4*49cdfc7eSAndroid Build Coastguard Worker * Author: Yang Xu <[email protected]>
5*49cdfc7eSAndroid Build Coastguard Worker */
6*49cdfc7eSAndroid Build Coastguard Worker
7*49cdfc7eSAndroid Build Coastguard Worker /*\
8*49cdfc7eSAndroid Build Coastguard Worker * [Description]
9*49cdfc7eSAndroid Build Coastguard Worker *
10*49cdfc7eSAndroid Build Coastguard Worker * Before kernel 2.6.26 we could not trace init(1) process and ptrace() would
11*49cdfc7eSAndroid Build Coastguard Worker * fail with EPERM. This case just checks whether we can trace init(1) process
12*49cdfc7eSAndroid Build Coastguard Worker * successfully.
13*49cdfc7eSAndroid Build Coastguard Worker */
14*49cdfc7eSAndroid Build Coastguard Worker
15*49cdfc7eSAndroid Build Coastguard Worker #include <errno.h>
16*49cdfc7eSAndroid Build Coastguard Worker #include <signal.h>
17*49cdfc7eSAndroid Build Coastguard Worker #include <sys/wait.h>
18*49cdfc7eSAndroid Build Coastguard Worker #include <pwd.h>
19*49cdfc7eSAndroid Build Coastguard Worker #include <stdlib.h>
20*49cdfc7eSAndroid Build Coastguard Worker #include <sys/ptrace.h>
21*49cdfc7eSAndroid Build Coastguard Worker #include "tst_test.h"
22*49cdfc7eSAndroid Build Coastguard Worker
verify_ptrace(void)23*49cdfc7eSAndroid Build Coastguard Worker static void verify_ptrace(void)
24*49cdfc7eSAndroid Build Coastguard Worker {
25*49cdfc7eSAndroid Build Coastguard Worker TEST(ptrace(PTRACE_ATTACH, 1, NULL, NULL));
26*49cdfc7eSAndroid Build Coastguard Worker if (TST_RET == 0)
27*49cdfc7eSAndroid Build Coastguard Worker tst_res(TPASS, "ptrace() traces init process successfully");
28*49cdfc7eSAndroid Build Coastguard Worker else
29*49cdfc7eSAndroid Build Coastguard Worker tst_res(TFAIL | TTERRNO,
30*49cdfc7eSAndroid Build Coastguard Worker "ptrace() returns %ld, failed unexpectedly", TST_RET);
31*49cdfc7eSAndroid Build Coastguard Worker
32*49cdfc7eSAndroid Build Coastguard Worker /*
33*49cdfc7eSAndroid Build Coastguard Worker * Wait until tracee is stopped by SIGSTOP otherwise detach will fail
34*49cdfc7eSAndroid Build Coastguard Worker * with ESRCH.
35*49cdfc7eSAndroid Build Coastguard Worker */
36*49cdfc7eSAndroid Build Coastguard Worker SAFE_WAITPID(1, NULL, 0);
37*49cdfc7eSAndroid Build Coastguard Worker
38*49cdfc7eSAndroid Build Coastguard Worker SAFE_PTRACE(PTRACE_DETACH, 1, NULL, NULL);
39*49cdfc7eSAndroid Build Coastguard Worker }
40*49cdfc7eSAndroid Build Coastguard Worker
41*49cdfc7eSAndroid Build Coastguard Worker static struct tst_test test = {
42*49cdfc7eSAndroid Build Coastguard Worker .test_all = verify_ptrace,
43*49cdfc7eSAndroid Build Coastguard Worker .needs_root = 1,
44*49cdfc7eSAndroid Build Coastguard Worker };
45