t_ptrace_wait.c revision 1.191
11.191Skamil/*	$NetBSD: t_ptrace_wait.c,v 1.191 2020/05/05 02:06:08 kamil Exp $	*/
21.1Skamil
31.1Skamil/*-
41.181Skamil * Copyright (c) 2016, 2017, 2018, 2019, 2020 The NetBSD Foundation, Inc.
51.1Skamil * All rights reserved.
61.1Skamil *
71.1Skamil * Redistribution and use in source and binary forms, with or without
81.1Skamil * modification, are permitted provided that the following conditions
91.1Skamil * are met:
101.1Skamil * 1. Redistributions of source code must retain the above copyright
111.1Skamil *    notice, this list of conditions and the following disclaimer.
121.1Skamil * 2. Redistributions in binary form must reproduce the above copyright
131.1Skamil *    notice, this list of conditions and the following disclaimer in the
141.1Skamil *    documentation and/or other materials provided with the distribution.
151.1Skamil *
161.1Skamil * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
171.1Skamil * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
181.1Skamil * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
191.1Skamil * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
201.1Skamil * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
211.1Skamil * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
221.1Skamil * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
231.1Skamil * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
241.1Skamil * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
251.1Skamil * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
261.1Skamil * POSSIBILITY OF SUCH DAMAGE.
271.1Skamil */
281.1Skamil
291.1Skamil#include <sys/cdefs.h>
301.191Skamil__RCSID("$NetBSD: t_ptrace_wait.c,v 1.191 2020/05/05 02:06:08 kamil Exp $");
311.143Skamil
321.143Skamil#define __LEGACY_PT_LWPINFO
331.1Skamil
341.1Skamil#include <sys/param.h>
351.1Skamil#include <sys/types.h>
361.130Smgorny#include <sys/exec_elf.h>
371.39Skamil#include <sys/mman.h>
381.1Skamil#include <sys/ptrace.h>
391.1Skamil#include <sys/resource.h>
401.1Skamil#include <sys/stat.h>
411.1Skamil#include <sys/syscall.h>
421.1Skamil#include <sys/sysctl.h>
431.129Smgorny#include <sys/uio.h>
441.1Skamil#include <sys/wait.h>
451.1Skamil#include <machine/reg.h>
461.132Skamil#include <assert.h>
471.1Skamil#include <elf.h>
481.1Skamil#include <err.h>
491.1Skamil#include <errno.h>
501.130Smgorny#include <fcntl.h>
511.1Skamil#include <lwp.h>
521.77Skamil#include <pthread.h>
531.1Skamil#include <sched.h>
541.1Skamil#include <signal.h>
551.124Skamil#include <spawn.h>
561.1Skamil#include <stdint.h>
571.1Skamil#include <stdio.h>
581.1Skamil#include <stdlib.h>
591.1Skamil#include <strings.h>
601.26Skamil#include <time.h>
611.1Skamil#include <unistd.h>
621.1Skamil
631.121Smgorny#if defined(__i386__) || defined(__x86_64__)
641.121Smgorny#include <cpuid.h>
651.121Smgorny#include <x86/cpu_extended_state.h>
661.129Smgorny#include <x86/specialreg.h>
671.121Smgorny#endif
681.121Smgorny
691.130Smgorny#include <libelf.h>
701.130Smgorny#include <gelf.h>
711.130Smgorny
721.1Skamil#include <atf-c.h>
731.1Skamil
741.165Skamil#ifdef ENABLE_TESTS
751.165Skamil
761.132Skamil/* Assumptions in the kernel code that must be kept. */
771.171Skamil__CTASSERT(sizeof(((struct ptrace_state *)0)->pe_report_event) ==
781.171Skamil    sizeof(((siginfo_t *)0)->si_pe_report_event));
791.171Skamil__CTASSERT(sizeof(((struct ptrace_state *)0)->pe_other_pid) ==
801.171Skamil    sizeof(((siginfo_t *)0)->si_pe_other_pid));
811.171Skamil__CTASSERT(sizeof(((struct ptrace_state *)0)->pe_lwp) ==
821.171Skamil    sizeof(((siginfo_t *)0)->si_pe_lwp));
831.171Skamil__CTASSERT(sizeof(((struct ptrace_state *)0)->pe_other_pid) ==
841.171Skamil    sizeof(((struct ptrace_state *)0)->pe_lwp));
851.132Skamil
861.1Skamil#include "h_macros.h"
871.1Skamil
881.1Skamil#include "t_ptrace_wait.h"
891.1Skamil#include "msg.h"
901.1Skamil
911.13Schristos#define SYSCALL_REQUIRE(expr) ATF_REQUIRE_MSG(expr, "%s: %s", # expr, \
921.13Schristos    strerror(errno))
931.18Schristos#define SYSCALL_REQUIRE_ERRNO(res, exp) ATF_REQUIRE_MSG(res == exp, \
941.18Schristos    "%d(%s) != %d", res, strerror(res), exp)
951.13Schristos
961.152Skamilstatic int debug = 0;
971.13Schristos
981.13Schristos#define DPRINTF(a, ...)	do  \
991.123Skamil	if (debug) \
1001.142Skamil	printf("%s() %d.%d %s:%d " a, \
1011.142Skamil	__func__, getpid(), _lwp_self(), __FILE__, __LINE__,  ##__VA_ARGS__); \
1021.13Schristos    while (/*CONSTCOND*/0)
1031.1Skamil
1041.34Skamil/// ----------------------------------------------------------------------------
1051.34Skamil
1061.174Skamil#include "t_ptrace_register_wait.h"
1071.175Skamil#include "t_ptrace_syscall_wait.h"
1081.176Skamil#include "t_ptrace_step_wait.h"
1091.177Skamil#include "t_ptrace_kill_wait.h"
1101.178Skamil#include "t_ptrace_bytetransfer_wait.h"
1111.179Skamil#include "t_ptrace_clone_wait.h"
1121.180Skamil#include "t_ptrace_fork_wait.h"
1131.181Skamil#include "t_ptrace_signal_wait.h"
1141.183Skamil#include "t_ptrace_eventmask_wait.h"
1151.185Skamil#include "t_ptrace_lwp_wait.h"
1161.186Skamil#include "t_ptrace_exec_wait.h"
1171.187Skamil#include "t_ptrace_topology_wait.h"
1181.188Skamil#include "t_ptrace_threads_wait.h"
1191.189Skamil#include "t_ptrace_siginfo_wait.h"
1201.190Skamil#include "t_ptrace_core_wait.h"
1211.191Skamil#include "t_ptrace_misc_wait.h"
1221.174Skamil
1231.174Skamil/// ----------------------------------------------------------------------------
1241.174Skamil
1251.1Skamil#include "t_ptrace_amd64_wait.h"
1261.1Skamil#include "t_ptrace_i386_wait.h"
1271.1Skamil#include "t_ptrace_x86_wait.h"
1281.1Skamil
1291.165Skamil/// ----------------------------------------------------------------------------
1301.165Skamil
1311.165Skamil#else
1321.165SkamilATF_TC(dummy);
1331.165SkamilATF_TC_HEAD(dummy, tc)
1341.165Skamil{
1351.165Skamil	atf_tc_set_md_var(tc, "descr", "A dummy test");
1361.165Skamil}
1371.165Skamil
1381.165SkamilATF_TC_BODY(dummy, tc)
1391.165Skamil{
1401.165Skamil
1411.165Skamil	// Dummy, skipped
1421.165Skamil	// The ATF framework requires at least a single defined test.
1431.165Skamil}
1441.165Skamil#endif
1451.165Skamil
1461.1SkamilATF_TP_ADD_TCS(tp)
1471.1Skamil{
1481.1Skamil	setvbuf(stdout, NULL, _IONBF, 0);
1491.1Skamil	setvbuf(stderr, NULL, _IONBF, 0);
1501.33Skamil
1511.165Skamil#ifdef ENABLE_TESTS
1521.174Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_REGISTER();
1531.175Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_SYSCALL();
1541.176Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_STEP();
1551.177Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_KILL();
1561.178Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_BYTETRANSFER();
1571.179Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_CLONE();
1581.180Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_FORK();
1591.181Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_SIGNAL();
1601.183Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_EVENTMASK();
1611.185Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_LWP();
1621.186Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_EXEC();
1631.187Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_TOPOLOGY();
1641.188Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_THREADS();
1651.189Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_SIGINFO();
1661.190Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_CORE();
1671.191Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_MISC();
1681.174Skamil
1691.1Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_AMD64();
1701.1Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_I386();
1711.1Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_X86();
1721.1Skamil
1731.165Skamil#else
1741.165Skamil	ATF_TP_ADD_TC(tp, dummy);
1751.165Skamil#endif
1761.165Skamil
1771.1Skamil	return atf_no_error();
1781.1Skamil}
179