t_ptrace_wait.c revision 1.192
11.192Sriastrad/*	$NetBSD: t_ptrace_wait.c,v 1.192 2024/04/01 18:33:23 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.192Sriastrad__RCSID("$NetBSD: t_ptrace_wait.c,v 1.192 2024/04/01 18:33:23 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.152Skamilstatic int debug = 0;
1121.13Schristos
1131.13Schristos#define DPRINTF(a, ...)	do  \
1141.123Skamil	if (debug) \
1151.142Skamil	printf("%s() %d.%d %s:%d " a, \
1161.142Skamil	__func__, getpid(), _lwp_self(), __FILE__, __LINE__,  ##__VA_ARGS__); \
1171.13Schristos    while (/*CONSTCOND*/0)
1181.1Skamil
1191.34Skamil/// ----------------------------------------------------------------------------
1201.34Skamil
1211.174Skamil#include "t_ptrace_register_wait.h"
1221.175Skamil#include "t_ptrace_syscall_wait.h"
1231.176Skamil#include "t_ptrace_step_wait.h"
1241.177Skamil#include "t_ptrace_kill_wait.h"
1251.178Skamil#include "t_ptrace_bytetransfer_wait.h"
1261.179Skamil#include "t_ptrace_clone_wait.h"
1271.180Skamil#include "t_ptrace_fork_wait.h"
1281.181Skamil#include "t_ptrace_signal_wait.h"
1291.183Skamil#include "t_ptrace_eventmask_wait.h"
1301.185Skamil#include "t_ptrace_lwp_wait.h"
1311.186Skamil#include "t_ptrace_exec_wait.h"
1321.187Skamil#include "t_ptrace_topology_wait.h"
1331.188Skamil#include "t_ptrace_threads_wait.h"
1341.189Skamil#include "t_ptrace_siginfo_wait.h"
1351.190Skamil#include "t_ptrace_core_wait.h"
1361.191Skamil#include "t_ptrace_misc_wait.h"
1371.174Skamil
1381.174Skamil/// ----------------------------------------------------------------------------
1391.174Skamil
1401.1Skamil#include "t_ptrace_amd64_wait.h"
1411.1Skamil#include "t_ptrace_i386_wait.h"
1421.1Skamil#include "t_ptrace_x86_wait.h"
1431.1Skamil
1441.165Skamil/// ----------------------------------------------------------------------------
1451.165Skamil
1461.165Skamil#else
1471.165SkamilATF_TC(dummy);
1481.165SkamilATF_TC_HEAD(dummy, tc)
1491.165Skamil{
1501.165Skamil	atf_tc_set_md_var(tc, "descr", "A dummy test");
1511.165Skamil}
1521.165Skamil
1531.165SkamilATF_TC_BODY(dummy, tc)
1541.165Skamil{
1551.165Skamil
1561.165Skamil	// Dummy, skipped
1571.165Skamil	// The ATF framework requires at least a single defined test.
1581.165Skamil}
1591.165Skamil#endif
1601.165Skamil
1611.1SkamilATF_TP_ADD_TCS(tp)
1621.1Skamil{
1631.1Skamil	setvbuf(stdout, NULL, _IONBF, 0);
1641.1Skamil	setvbuf(stderr, NULL, _IONBF, 0);
1651.33Skamil
1661.165Skamil#ifdef ENABLE_TESTS
1671.174Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_REGISTER();
1681.175Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_SYSCALL();
1691.176Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_STEP();
1701.177Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_KILL();
1711.178Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_BYTETRANSFER();
1721.179Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_CLONE();
1731.180Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_FORK();
1741.181Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_SIGNAL();
1751.183Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_EVENTMASK();
1761.185Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_LWP();
1771.186Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_EXEC();
1781.187Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_TOPOLOGY();
1791.188Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_THREADS();
1801.189Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_SIGINFO();
1811.190Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_CORE();
1821.191Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_MISC();
1831.174Skamil
1841.1Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_AMD64();
1851.1Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_I386();
1861.1Skamil	ATF_TP_ADD_TCS_PTRACE_WAIT_X86();
1871.1Skamil
1881.165Skamil#else
1891.165Skamil	ATF_TP_ADD_TC(tp, dummy);
1901.165Skamil#endif
1911.165Skamil
1921.1Skamil	return atf_no_error();
1931.1Skamil}
194