1f08c3bdfSopenharmony_ci// SPDX-License-Identifier: GPL-2.0-or-later 2f08c3bdfSopenharmony_ci/* 3f08c3bdfSopenharmony_ci * Copyright (c) International Business Machines Corp., 2007 4f08c3bdfSopenharmony_ci * 13/11/08 Gowrishankar M <gowrishankar.m@in.ibm.com> 5f08c3bdfSopenharmony_ci * Copyright (C) 2022 SUSE LLC Andrea Cervesato <andrea.cervesato@suse.com> 6f08c3bdfSopenharmony_ci */ 7f08c3bdfSopenharmony_ci 8f08c3bdfSopenharmony_ci/*\ 9f08c3bdfSopenharmony_ci * [Description] 10f08c3bdfSopenharmony_ci * 11f08c3bdfSopenharmony_ci * Clone a process with CLONE_NEWPID flag and verifies that siginfo->si_pid is 12f08c3bdfSopenharmony_ci * set to 0 if sender (parent process) is not in the receiver's namespace. 13f08c3bdfSopenharmony_ci */ 14f08c3bdfSopenharmony_ci 15f08c3bdfSopenharmony_ci#include "tst_test_macros.h" 16f08c3bdfSopenharmony_ci#define _GNU_SOURCE 1 17f08c3bdfSopenharmony_ci#include <signal.h> 18f08c3bdfSopenharmony_ci#include "tst_test.h" 19f08c3bdfSopenharmony_ci#include "lapi/sched.h" 20f08c3bdfSopenharmony_ci 21f08c3bdfSopenharmony_cistatic volatile pid_t sig_pid = -1; 22f08c3bdfSopenharmony_ci 23f08c3bdfSopenharmony_cistatic void child_signal_handler(LTP_ATTRIBUTE_UNUSED int sig, siginfo_t *si, LTP_ATTRIBUTE_UNUSED void *unused) 24f08c3bdfSopenharmony_ci{ 25f08c3bdfSopenharmony_ci sig_pid = si->si_pid; 26f08c3bdfSopenharmony_ci} 27f08c3bdfSopenharmony_ci 28f08c3bdfSopenharmony_cistatic void child_func(void) 29f08c3bdfSopenharmony_ci{ 30f08c3bdfSopenharmony_ci struct sigaction sa; 31f08c3bdfSopenharmony_ci 32f08c3bdfSopenharmony_ci TST_EXP_EQ_LI(tst_getpid(), 1); 33f08c3bdfSopenharmony_ci TST_EXP_EQ_LI(getppid(), 0); 34f08c3bdfSopenharmony_ci 35f08c3bdfSopenharmony_ci sa.sa_flags = SA_SIGINFO; 36f08c3bdfSopenharmony_ci SAFE_SIGFILLSET(&sa.sa_mask); 37f08c3bdfSopenharmony_ci sa.sa_sigaction = child_signal_handler; 38f08c3bdfSopenharmony_ci 39f08c3bdfSopenharmony_ci SAFE_SIGACTION(SIGUSR1, &sa, NULL); 40f08c3bdfSopenharmony_ci 41f08c3bdfSopenharmony_ci TST_CHECKPOINT_WAKE_AND_WAIT(0); 42f08c3bdfSopenharmony_ci 43f08c3bdfSopenharmony_ci TST_EXP_EQ_LI(sig_pid, 0); 44f08c3bdfSopenharmony_ci} 45f08c3bdfSopenharmony_ci 46f08c3bdfSopenharmony_cistatic void run(void) 47f08c3bdfSopenharmony_ci{ 48f08c3bdfSopenharmony_ci const struct tst_clone_args args = { 49f08c3bdfSopenharmony_ci .flags = CLONE_NEWPID, 50f08c3bdfSopenharmony_ci .exit_signal = SIGCHLD, 51f08c3bdfSopenharmony_ci }; 52f08c3bdfSopenharmony_ci int pid; 53f08c3bdfSopenharmony_ci 54f08c3bdfSopenharmony_ci pid = SAFE_CLONE(&args); 55f08c3bdfSopenharmony_ci if (!pid) { 56f08c3bdfSopenharmony_ci child_func(); 57f08c3bdfSopenharmony_ci return; 58f08c3bdfSopenharmony_ci } 59f08c3bdfSopenharmony_ci 60f08c3bdfSopenharmony_ci TST_CHECKPOINT_WAIT(0); 61f08c3bdfSopenharmony_ci 62f08c3bdfSopenharmony_ci SAFE_KILL(pid, SIGUSR1); 63f08c3bdfSopenharmony_ci 64f08c3bdfSopenharmony_ci TST_CHECKPOINT_WAKE(0); 65f08c3bdfSopenharmony_ci} 66f08c3bdfSopenharmony_ci 67f08c3bdfSopenharmony_cistatic struct tst_test test = { 68f08c3bdfSopenharmony_ci .test_all = run, 69f08c3bdfSopenharmony_ci .needs_root = 1, 70f08c3bdfSopenharmony_ci .forks_child = 1, 71f08c3bdfSopenharmony_ci .needs_checkpoints = 1, 72f08c3bdfSopenharmony_ci .needs_kconfigs = (const char *[]) { 73f08c3bdfSopenharmony_ci "CONFIG_PID_NS", 74f08c3bdfSopenharmony_ci NULL, 75f08c3bdfSopenharmony_ci }, 76f08c3bdfSopenharmony_ci}; 77