t_ptrace_wait.c revision 1.195
11.195Sriastrad/*	$NetBSD: t_ptrace_wait.c,v 1.195 2025/05/02 02:37:07 riastradh 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.192Sriastrad/*
301.192Sriastrad * XXX Hack: Force the use of sys/exec_elf.h, not elfdefinitions.h.
311.192Sriastrad * Why?
321.192Sriastrad *
331.192Sriastrad * - libelf.h and gelf.h are needed for parsing core files in
341.192Sriastrad *   t_ptrace_core_wait.h.
351.192Sriastrad *
361.192Sriastrad * - sys/exec_elf.h is needed for struct netbsd_elfcore_procinfo also
371.192Sriastrad *   in t_ptrace_core_wait.h.
381.192Sriastrad *
391.192Sriastrad * libelf.h and gelf.h pull in elfdefinitions.h, but that conflicts
401.192Sriastrad * with sys/exec_elf.h on most basic ELF definitions.
411.192Sriastrad */
421.192Sriastrad#define	_SYS_ELFDEFINITIONS_H_
431.192Sriastrad
441.1Skamil#include <sys/cdefs.h>
451.195Sriastrad__RCSID("$NetBSD: t_ptrace_wait.c,v 1.195 2025/05/02 02:37:07 riastradh Exp $");
461.143Skamil
471.143Skamil#define __LEGACY_PT_LWPINFO
481.1Skamil
491.1Skamil#include <sys/param.h>
501.1Skamil#include <sys/types.h>
511.130Smgorny#include <sys/exec_elf.h>
521.39Skamil#include <sys/mman.h>
531.1Skamil#include <sys/ptrace.h>
541.1Skamil#include <sys/resource.h>
551.1Skamil#include <sys/stat.h>
561.1Skamil#include <sys/syscall.h>
571.1Skamil#include <sys/sysctl.h>
581.129Smgorny#include <sys/uio.h>
591.1Skamil#include <sys/wait.h>
601.1Skamil#include <machine/reg.h>
611.132Skamil#include <assert.h>
621.1Skamil#include <elf.h>
631.1Skamil#include <err.h>
641.1Skamil#include <errno.h>
651.130Smgorny#include <fcntl.h>
661.1Skamil#include <lwp.h>
671.77Skamil#include <pthread.h>
681.1Skamil#include <sched.h>
691.1Skamil#include <signal.h>
701.124Skamil#include <spawn.h>
711.1Skamil#include <stdint.h>
721.1Skamil#include <stdio.h>
731.1Skamil#include <stdlib.h>
741.1Skamil#include <strings.h>
751.26Skamil#include <time.h>
761.1Skamil#include <unistd.h>
771.1Skamil
781.121Smgorny#if defined(__i386__) || defined(__x86_64__)
791.121Smgorny#include <cpuid.h>
801.121Smgorny#include <x86/cpu_extended_state.h>
811.129Smgorny#include <x86/specialreg.h>
821.121Smgorny#endif
831.121Smgorny
841.130Smgorny#include <libelf.h>
851.130Smgorny#include <gelf.h>
861.130Smgorny
871.1Skamil#include <atf-c.h>
881.1Skamil
891.165Skamil#ifdef ENABLE_TESTS
901.165Skamil
911.132Skamil/* Assumptions in the kernel code that must be kept. */
921.171Skamil__CTASSERT(sizeof(((struct ptrace_state *)0)->pe_report_event) ==
931.171Skamil    sizeof(((siginfo_t *)0)->si_pe_report_event));
941.171Skamil__CTASSERT(sizeof(((struct ptrace_state *)0)->pe_other_pid) ==
951.171Skamil    sizeof(((siginfo_t *)0)->si_pe_other_pid));
961.171Skamil__CTASSERT(sizeof(((struct ptrace_state *)0)->pe_lwp) ==
971.171Skamil    sizeof(((siginfo_t *)0)->si_pe_lwp));
981.171Skamil__CTASSERT(sizeof(((struct ptrace_state *)0)->pe_other_pid) ==
991.171Skamil    sizeof(((struct ptrace_state *)0)->pe_lwp));
1001.132Skamil
1011.1Skamil#include "h_macros.h"
1021.1Skamil
1031.1Skamil#include "t_ptrace_wait.h"
1041.1Skamil#include "msg.h"
1051.1Skamil
1061.13Schristos#define SYSCALL_REQUIRE(expr) ATF_REQUIRE_MSG(expr, "%s: %s", # expr, \
1071.13Schristos    strerror(errno))
1081.18Schristos#define SYSCALL_REQUIRE_ERRNO(res, exp) ATF_REQUIRE_MSG(res == exp, \
1091.18Schristos    "%d(%s) != %d", res, strerror(res), exp)
1101.13Schristos
1111.195Sriastradstatic int debug = 0;
1121.13Schristos
1131.13Schristos#define DPRINTF(a, ...)	do  \
1141.194Sriastrad	if (debug) { \
1151.194Sriastrad		const char *file = __FILE__, *slash = strrchr(file, '/'); \
1161.194Sriastrad		if (slash) \
1171.194Sriastrad			file = slash + 1; \
1181.194Sriastrad		printf("%s() %d.%d %s:%d " a, \
1191.194Sriastrad       		    __func__, getpid(), _lwp_self(), file, __LINE__, \
1201.194Sriastrad		    ##__VA_ARGS__); \
1211.194Sriastrad	} \
1221.13Schristos    while (/*CONSTCOND*/0)
1231.1Skamil
1241.34Skamil/// ----------------------------------------------------------------------------
1251.34Skamil
1261.174Skamil#include "t_ptrace_register_wait.h"
1271.175Skamil#include "t_ptrace_syscall_wait.h"
1281.176Skamil#include "t_ptrace_step_wait.h"
1291.177Skamil#include "t_ptrace_kill_wait.h"
1301.178Skamil#include "t_ptrace_bytetransfer_wait.h"
1311.179Skamil#include "t_ptrace_clone_wait.h"
1321.180Skamil#include "t_ptrace_fork_wait.h"
1331.181Skamil#include "t_ptrace_signal_wait.h"
1341.183Skamil#include "t_ptrace_eventmask_wait.h"
1351.185Skamil#include "t_ptrace_lwp_wait.h"
1361.186Skamil#include "t_ptrace_exec_wait.h"
1371.187Skamil#include "t_ptrace_topology_wait.h"
1381.188Skamil#include "t_ptrace_threads_wait.h"
1391.189Skamil#include "t_ptrace_siginfo_wait.h"
1401.190Skamil#include "t_ptrace_core_wait.h"
1411.191Skamil#include "t_ptrace_misc_wait.h"
1421.174Skamil
1431.174Skamil/// ----------------------------------------------------------------------------
1441.174Skamil
1451.1Skamil#include "t_ptrace_amd64_wait.h"
1461.1Skamil#include "t_ptrace_i386_wait.h"
1471.1Skamil#include "t_ptrace_x86_wait.h"
1481.1Skamil
1491.165Skamil/// ----------------------------------------------------------------------------
1501.165Skamil
1511.165Skamil#else
1521.165SkamilATF_TC(dummy);
1531.165SkamilATF_TC_HEAD(dummy, tc)
1541.165Skamil{
1551.165Skamil	atf_tc_set_md_var(tc, "descr", "A dummy test");
1561.165Skamil}
1571.165Skamil
1581.165SkamilATF_TC_BODY(dummy, tc)
1591.165Skamil{
1601.165Skamil
1611.165Skamil	// Dummy, skipped
1621.165Skamil	// The ATF framework requires at least a single defined test.
1631.165Skamil}
1641.165Skamil#endif
1651.165Skamil
1661.1SkamilATF_TP_ADD_TCS(tp)
1671.1Skamil{
1681.1Skamil	setvbuf(stdout, NULL, _IONBF, 0);
1691.1Skamil	setvbuf(stderr, NULL, _IONBF, 0);
1701.33Skamil
1711.165Skamil#ifdef ENABLE_TESTS
1721.174Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_REGISTER();
1731.175Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_SYSCALL();
1741.176Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_STEP();
1751.177Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_KILL();
1761.178Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_BYTETRANSFER();
1771.179Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_CLONE();
1781.180Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_FORK();
1791.181Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_SIGNAL();
1801.183Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_EVENTMASK();
1811.185Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_LWP();
1821.186Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_EXEC();
1831.187Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_TOPOLOGY();
1841.188Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_THREADS();
1851.189Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_SIGINFO();
1861.190Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_CORE();
1871.191Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_MISC();
1881.174Skamil
1891.1Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_AMD64();
1901.1Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_I386();
1911.1Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_X86();
1921.1Skamil
1931.165Skamil#else
1941.165Skamil	ATF_TP_ADD_TC(tp, dummy);
1951.165Skamil#endif
1961.165Skamil
1971.1Skamil	return atf_no_error();
1981.1Skamil}
199