13053e143SMichał Górny //===-- PlatformSiginfoTest.cpp -------------------------------------------===//
23053e143SMichał Górny //
33053e143SMichał Górny // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
43053e143SMichał Górny // See https://llvm.org/LICENSE.txt for license information.
53053e143SMichał Górny // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
63053e143SMichał Górny //
73053e143SMichał Górny //===----------------------------------------------------------------------===//
83053e143SMichał Górny
93053e143SMichał Górny #include "gtest/gtest.h"
103053e143SMichał Górny
113053e143SMichał Górny #include <initializer_list>
12f190ce62SKazu Hirata #include <optional>
133053e143SMichał Górny #include <tuple>
143053e143SMichał Górny
153053e143SMichał Górny #include "Plugins/Platform/FreeBSD/PlatformFreeBSD.h"
163053e143SMichał Górny #include "Plugins/Platform/Linux/PlatformLinux.h"
173053e143SMichał Górny #include "Plugins/Platform/NetBSD/PlatformNetBSD.h"
183053e143SMichał Górny #include "Plugins/TypeSystem/Clang/TypeSystemClang.h"
193053e143SMichał Górny
203053e143SMichał Górny #include "TestingSupport/SubsystemRAII.h"
213053e143SMichał Górny #include "lldb/Core/Debugger.h"
223053e143SMichał Górny #include "lldb/Host/FileSystem.h"
233053e143SMichał Górny #include "lldb/Host/HostInfo.h"
243053e143SMichał Górny #include "lldb/Utility/ArchSpec.h"
253053e143SMichał Górny
263053e143SMichał Górny using namespace lldb;
273053e143SMichał Górny using namespace lldb_private;
283053e143SMichał Górny using namespace lldb_private::repro;
293053e143SMichał Górny
303053e143SMichał Górny namespace {
313053e143SMichał Górny class PlatformSiginfoTest : public ::testing::Test {
323053e143SMichał Górny SubsystemRAII<FileSystem, HostInfo, TypeSystemClang> subsystems;
333053e143SMichał Górny PlatformSP platform_sp;
343053e143SMichał Górny DebuggerSP debugger_sp;
353053e143SMichał Górny TargetSP target_sp;
363053e143SMichał Górny
373053e143SMichał Górny public:
383053e143SMichał Górny CompilerType siginfo_type;
393053e143SMichał Górny
SetUp()403053e143SMichał Górny void SetUp() override {
413053e143SMichał Górny platform_freebsd::PlatformFreeBSD::Initialize();
423053e143SMichał Górny platform_linux::PlatformLinux::Initialize();
433053e143SMichał Górny platform_netbsd::PlatformNetBSD::Initialize();
443053e143SMichał Górny }
453053e143SMichał Górny
TearDown()463053e143SMichał Górny void TearDown() override {
473053e143SMichał Górny platform_netbsd::PlatformNetBSD::Terminate();
483053e143SMichał Górny platform_linux::PlatformLinux::Terminate();
493053e143SMichał Górny platform_freebsd::PlatformFreeBSD::Terminate();
503053e143SMichał Górny }
513053e143SMichał Górny
523053e143SMichał Górny typedef std::tuple<const char *, uint64_t, uint64_t> field_tuple;
533053e143SMichał Górny
ExpectField(const CompilerType & siginfo_type,field_tuple field)543053e143SMichał Górny void ExpectField(const CompilerType &siginfo_type, field_tuple field) {
553053e143SMichał Górny const char *path;
563053e143SMichał Górny uint64_t offset, size;
573053e143SMichał Górny std::tie(path, offset, size) = field;
583053e143SMichał Górny
593053e143SMichał Górny SCOPED_TRACE(path);
603053e143SMichał Górny CompilerType field_type = siginfo_type;
613053e143SMichał Górny uint64_t total_offset = 0;
623053e143SMichał Górny for (auto field_name : llvm::split(path, '.')) {
633053e143SMichał Górny uint64_t bit_offset;
643053e143SMichał Górny ASSERT_NE(field_type.GetIndexOfFieldWithName(field_name.str().c_str(),
653053e143SMichał Górny &field_type, &bit_offset),
663053e143SMichał Górny UINT32_MAX);
673053e143SMichał Górny total_offset += bit_offset;
683053e143SMichał Górny }
693053e143SMichał Górny
703053e143SMichał Górny EXPECT_EQ(total_offset, offset * 8);
712fe83274SKazu Hirata EXPECT_EQ(field_type.GetByteSize(nullptr), std::optional<uint64_t>(size));
723053e143SMichał Górny }
733053e143SMichał Górny
ExpectFields(const CompilerType & container,std::initializer_list<field_tuple> fields)743053e143SMichał Górny void ExpectFields(const CompilerType &container,
753053e143SMichał Górny std::initializer_list<field_tuple> fields) {
763053e143SMichał Górny for (auto x : fields)
773053e143SMichał Górny ExpectField(container, x);
783053e143SMichał Górny }
793053e143SMichał Górny
InitializeSiginfo(const std::string & triple)803053e143SMichał Górny void InitializeSiginfo(const std::string &triple) {
813053e143SMichał Górny ArchSpec arch(triple);
823053e143SMichał Górny
833053e143SMichał Górny switch (arch.GetTriple().getOS()) {
843053e143SMichał Górny case llvm::Triple::FreeBSD:
85*d6678404SMed Ismail Bennani platform_sp =
86*d6678404SMed Ismail Bennani platform_freebsd::PlatformFreeBSD::CreateInstance(true, &arch);
873053e143SMichał Górny break;
883053e143SMichał Górny case llvm::Triple::Linux:
89*d6678404SMed Ismail Bennani platform_sp = platform_linux::PlatformLinux::CreateInstance(true, &arch);
903053e143SMichał Górny break;
913053e143SMichał Górny case llvm::Triple::NetBSD:
92*d6678404SMed Ismail Bennani platform_sp =
93*d6678404SMed Ismail Bennani platform_netbsd::PlatformNetBSD::CreateInstance(true, &arch);
943053e143SMichał Górny break;
953053e143SMichał Górny default:
963053e143SMichał Górny llvm_unreachable("unknown ostype in triple");
973053e143SMichał Górny }
983053e143SMichał Górny Platform::SetHostPlatform(platform_sp);
993053e143SMichał Górny
1003053e143SMichał Górny debugger_sp = Debugger::CreateInstance();
1013053e143SMichał Górny ASSERT_TRUE(debugger_sp);
1023053e143SMichał Górny
1033053e143SMichał Górny debugger_sp->GetTargetList().CreateTarget(
1043053e143SMichał Górny *debugger_sp, "", arch, eLoadDependentsNo, platform_sp, target_sp);
1053053e143SMichał Górny ASSERT_TRUE(target_sp);
1063053e143SMichał Górny
1073053e143SMichał Górny siginfo_type = platform_sp->GetSiginfoType(arch.GetTriple());
1083053e143SMichał Górny }
1093053e143SMichał Górny };
1103053e143SMichał Górny
1113053e143SMichał Górny } // namespace
1123053e143SMichał Górny
TEST_F(PlatformSiginfoTest,TestLinux_64bit)1133053e143SMichał Górny TEST_F(PlatformSiginfoTest, TestLinux_64bit) {
1143053e143SMichał Górny for (std::string arch : {"x86_64", "aarch64", "powerpc64le"}) {
1153053e143SMichał Górny SCOPED_TRACE(arch);
1163053e143SMichał Górny InitializeSiginfo(arch + "-pc-linux-gnu");
1173053e143SMichał Górny ASSERT_TRUE(siginfo_type);
1183053e143SMichał Górny
1193053e143SMichał Górny ExpectFields(siginfo_type,
1203053e143SMichał Górny {
1213053e143SMichał Górny {"si_signo", 0, 4},
1223053e143SMichał Górny {"si_errno", 4, 4},
1233053e143SMichał Górny {"si_code", 8, 4},
1243053e143SMichał Górny {"_sifields._kill.si_pid", 16, 4},
1253053e143SMichał Górny {"_sifields._kill.si_uid", 20, 4},
1263053e143SMichał Górny {"_sifields._timer.si_tid", 16, 4},
1273053e143SMichał Górny {"_sifields._timer.si_overrun", 20, 4},
1283053e143SMichał Górny {"_sifields._timer.si_sigval", 24, 8},
1293053e143SMichał Górny {"_sifields._rt.si_pid", 16, 4},
1303053e143SMichał Górny {"_sifields._rt.si_uid", 20, 4},
1313053e143SMichał Górny {"_sifields._rt.si_sigval", 24, 8},
1323053e143SMichał Górny {"_sifields._sigchld.si_pid", 16, 4},
1333053e143SMichał Górny {"_sifields._sigchld.si_uid", 20, 4},
1343053e143SMichał Górny {"_sifields._sigchld.si_status", 24, 4},
1353053e143SMichał Górny {"_sifields._sigchld.si_utime", 32, 8},
1363053e143SMichał Górny {"_sifields._sigchld.si_stime", 40, 8},
1373053e143SMichał Górny {"_sifields._sigfault.si_addr", 16, 8},
1383053e143SMichał Górny {"_sifields._sigfault.si_addr_lsb", 24, 2},
1393053e143SMichał Górny {"_sifields._sigfault._bounds._addr_bnd._lower", 32, 8},
1403053e143SMichał Górny {"_sifields._sigfault._bounds._addr_bnd._upper", 40, 8},
1413053e143SMichał Górny {"_sifields._sigfault._bounds._pkey", 32, 4},
1423053e143SMichał Górny {"_sifields._sigpoll.si_band", 16, 8},
1433053e143SMichał Górny {"_sifields._sigpoll.si_fd", 24, 4},
1443053e143SMichał Górny {"_sifields._sigsys._call_addr", 16, 8},
1453053e143SMichał Górny {"_sifields._sigsys._syscall", 24, 4},
1463053e143SMichał Górny {"_sifields._sigsys._arch", 28, 4},
1473053e143SMichał Górny });
1483053e143SMichał Górny }
1493053e143SMichał Górny }
1503053e143SMichał Górny
TEST_F(PlatformSiginfoTest,TestLinux_32bit)1513053e143SMichał Górny TEST_F(PlatformSiginfoTest, TestLinux_32bit) {
1523053e143SMichał Górny for (std::string arch : {"i386", "armv7"}) {
1533053e143SMichał Górny SCOPED_TRACE(arch);
1543053e143SMichał Górny InitializeSiginfo(arch + "-pc-linux");
1553053e143SMichał Górny ASSERT_TRUE(siginfo_type);
1563053e143SMichał Górny
1573053e143SMichał Górny ExpectFields(siginfo_type,
1583053e143SMichał Górny {
1593053e143SMichał Górny {"si_signo", 0, 4},
1603053e143SMichał Górny {"si_errno", 4, 4},
1613053e143SMichał Górny {"si_code", 8, 4},
1623053e143SMichał Górny {"_sifields._kill.si_pid", 12, 4},
1633053e143SMichał Górny {"_sifields._kill.si_uid", 16, 4},
1643053e143SMichał Górny {"_sifields._timer.si_tid", 12, 4},
1653053e143SMichał Górny {"_sifields._timer.si_overrun", 16, 4},
1663053e143SMichał Górny {"_sifields._timer.si_sigval", 20, 4},
1673053e143SMichał Górny {"_sifields._rt.si_pid", 12, 4},
1683053e143SMichał Górny {"_sifields._rt.si_uid", 16, 4},
1693053e143SMichał Górny {"_sifields._rt.si_sigval", 20, 4},
1703053e143SMichał Górny {"_sifields._sigchld.si_pid", 12, 4},
1713053e143SMichał Górny {"_sifields._sigchld.si_uid", 16, 4},
1723053e143SMichał Górny {"_sifields._sigchld.si_status", 20, 4},
1733053e143SMichał Górny {"_sifields._sigchld.si_utime", 24, 4},
1743053e143SMichał Górny {"_sifields._sigchld.si_stime", 28, 4},
1753053e143SMichał Górny {"_sifields._sigfault.si_addr", 12, 4},
1763053e143SMichał Górny {"_sifields._sigfault.si_addr_lsb", 16, 2},
1773053e143SMichał Górny {"_sifields._sigfault._bounds._addr_bnd._lower", 20, 4},
1783053e143SMichał Górny {"_sifields._sigfault._bounds._addr_bnd._upper", 24, 4},
1793053e143SMichał Górny {"_sifields._sigfault._bounds._pkey", 20, 4},
1803053e143SMichał Górny {"_sifields._sigpoll.si_band", 12, 4},
1813053e143SMichał Górny {"_sifields._sigpoll.si_fd", 16, 4},
1823053e143SMichał Górny {"_sifields._sigsys._call_addr", 12, 4},
1833053e143SMichał Górny {"_sifields._sigsys._syscall", 16, 4},
1843053e143SMichał Górny {"_sifields._sigsys._arch", 20, 4},
1853053e143SMichał Górny });
1863053e143SMichał Górny }
1873053e143SMichał Górny }
1883053e143SMichał Górny
TEST_F(PlatformSiginfoTest,TestFreeBSD_64bit)1893053e143SMichał Górny TEST_F(PlatformSiginfoTest, TestFreeBSD_64bit) {
1903053e143SMichał Górny for (std::string arch : {"x86_64", "aarch64"}) {
1913053e143SMichał Górny SCOPED_TRACE(arch);
1923053e143SMichał Górny InitializeSiginfo("x86_64-unknown-freebsd13.0");
1933053e143SMichał Górny ASSERT_TRUE(siginfo_type);
1943053e143SMichał Górny
1953053e143SMichał Górny ExpectFields(siginfo_type, {
1963053e143SMichał Górny {"si_signo", 0, 4},
1973053e143SMichał Górny {"si_errno", 4, 4},
1983053e143SMichał Górny {"si_code", 8, 4},
1993053e143SMichał Górny {"si_pid", 12, 4},
2003053e143SMichał Górny {"si_uid", 16, 4},
2013053e143SMichał Górny {"si_status", 20, 4},
2023053e143SMichał Górny {"si_addr", 24, 8},
2033053e143SMichał Górny {"si_value", 32, 8},
2043053e143SMichał Górny {"_reason._fault._trapno", 40, 4},
2053053e143SMichał Górny {"_reason._timer._timerid", 40, 4},
2063053e143SMichał Górny {"_reason._timer._overrun", 44, 4},
2073053e143SMichał Górny {"_reason._mesgq._mqd", 40, 4},
2083053e143SMichał Górny {"_reason._poll._band", 40, 8},
2093053e143SMichał Górny });
2103053e143SMichał Górny }
2113053e143SMichał Górny }
2123053e143SMichał Górny
TEST_F(PlatformSiginfoTest,TestFreeBSD_32bit)2133053e143SMichał Górny TEST_F(PlatformSiginfoTest, TestFreeBSD_32bit) {
2143053e143SMichał Górny for (std::string arch : {"i386"}) {
2153053e143SMichał Górny SCOPED_TRACE(arch);
2163053e143SMichał Górny InitializeSiginfo(arch + "-unknown-freebsd13.0");
2173053e143SMichał Górny ASSERT_TRUE(siginfo_type);
2183053e143SMichał Górny
2193053e143SMichał Górny ExpectFields(siginfo_type, {
2203053e143SMichał Górny {"si_signo", 0, 4},
2213053e143SMichał Górny {"si_errno", 4, 4},
2223053e143SMichał Górny {"si_code", 8, 4},
2233053e143SMichał Górny {"si_pid", 12, 4},
2243053e143SMichał Górny {"si_uid", 16, 4},
2253053e143SMichał Górny {"si_status", 20, 4},
2263053e143SMichał Górny {"si_addr", 24, 4},
2273053e143SMichał Górny {"si_value", 28, 4},
2283053e143SMichał Górny {"_reason._fault._trapno", 32, 4},
2293053e143SMichał Górny {"_reason._timer._timerid", 32, 4},
2303053e143SMichał Górny {"_reason._timer._overrun", 36, 4},
2313053e143SMichał Górny {"_reason._mesgq._mqd", 32, 4},
2323053e143SMichał Górny {"_reason._poll._band", 32, 4},
2333053e143SMichał Górny });
2343053e143SMichał Górny }
2353053e143SMichał Górny }
2363053e143SMichał Górny
TEST_F(PlatformSiginfoTest,TestNetBSD_64bit)2373053e143SMichał Górny TEST_F(PlatformSiginfoTest, TestNetBSD_64bit) {
2383053e143SMichał Górny for (std::string arch : {"x86_64"}) {
2393053e143SMichał Górny SCOPED_TRACE(arch);
2403053e143SMichał Górny InitializeSiginfo(arch + "-unknown-netbsd9.0");
2413053e143SMichał Górny ASSERT_TRUE(siginfo_type);
2423053e143SMichał Górny
2433053e143SMichał Górny ExpectFields(
2443053e143SMichał Górny siginfo_type,
2453053e143SMichał Górny {
2463053e143SMichał Górny {"_info._signo", 0, 4},
2473053e143SMichał Górny {"_info._code", 4, 4},
2483053e143SMichał Górny {"_info._errno", 8, 4},
2493053e143SMichał Górny {"_info._reason._rt._pid", 16, 4},
2503053e143SMichał Górny {"_info._reason._rt._uid", 20, 4},
2513053e143SMichał Górny {"_info._reason._rt._value", 24, 8},
2523053e143SMichał Górny {"_info._reason._child._pid", 16, 4},
2533053e143SMichał Górny {"_info._reason._child._uid", 20, 4},
2543053e143SMichał Górny {"_info._reason._child._status", 24, 4},
2553053e143SMichał Górny {"_info._reason._child._utime", 28, 4},
2563053e143SMichał Górny {"_info._reason._child._stime", 32, 4},
2573053e143SMichał Górny {"_info._reason._fault._addr", 16, 8},
2583053e143SMichał Górny {"_info._reason._fault._trap", 24, 4},
2593053e143SMichał Górny {"_info._reason._fault._trap2", 28, 4},
2603053e143SMichał Górny {"_info._reason._fault._trap3", 32, 4},
2613053e143SMichał Górny {"_info._reason._poll._band", 16, 8},
2623053e143SMichał Górny {"_info._reason._poll._fd", 24, 4},
2633053e143SMichał Górny {"_info._reason._syscall._sysnum", 16, 4},
2643053e143SMichał Górny {"_info._reason._syscall._retval", 20, 8},
2653053e143SMichał Górny {"_info._reason._syscall._error", 28, 4},
2663053e143SMichał Górny {"_info._reason._syscall._args", 32, 64},
2673053e143SMichał Górny {"_info._reason._ptrace_state._pe_report_event", 16, 4},
2683053e143SMichał Górny {"_info._reason._ptrace_state._option._pe_other_pid", 20, 4},
2693053e143SMichał Górny {"_info._reason._ptrace_state._option._pe_lwp", 20, 4},
2703053e143SMichał Górny });
2713053e143SMichał Górny }
2723053e143SMichał Górny }
2733053e143SMichał Górny
TEST_F(PlatformSiginfoTest,TestNetBSD_32bit)2743053e143SMichał Górny TEST_F(PlatformSiginfoTest, TestNetBSD_32bit) {
2753053e143SMichał Górny for (std::string arch : {"i386"}) {
2763053e143SMichał Górny SCOPED_TRACE(arch);
2773053e143SMichał Górny InitializeSiginfo(arch + "-unknown-netbsd9.0");
2783053e143SMichał Górny ASSERT_TRUE(siginfo_type);
2793053e143SMichał Górny
2803053e143SMichał Górny ExpectFields(
2813053e143SMichał Górny siginfo_type,
2823053e143SMichał Górny {
2833053e143SMichał Górny {"_info._signo", 0, 4},
2843053e143SMichał Górny {"_info._code", 4, 4},
2853053e143SMichał Górny {"_info._errno", 8, 4},
2863053e143SMichał Górny {"_info._reason._rt._pid", 12, 4},
2873053e143SMichał Górny {"_info._reason._rt._uid", 16, 4},
2883053e143SMichał Górny {"_info._reason._rt._value", 20, 4},
2893053e143SMichał Górny {"_info._reason._child._pid", 12, 4},
2903053e143SMichał Górny {"_info._reason._child._uid", 16, 4},
2913053e143SMichał Górny {"_info._reason._child._status", 20, 4},
2923053e143SMichał Górny {"_info._reason._child._utime", 24, 4},
2933053e143SMichał Górny {"_info._reason._child._stime", 28, 4},
2943053e143SMichał Górny {"_info._reason._fault._addr", 12, 4},
2953053e143SMichał Górny {"_info._reason._fault._trap", 16, 4},
2963053e143SMichał Górny {"_info._reason._fault._trap2", 20, 4},
2973053e143SMichał Górny {"_info._reason._fault._trap3", 24, 4},
2983053e143SMichał Górny {"_info._reason._poll._band", 12, 4},
2993053e143SMichał Górny {"_info._reason._poll._fd", 16, 4},
3003053e143SMichał Górny {"_info._reason._syscall._sysnum", 12, 4},
3013053e143SMichał Górny {"_info._reason._syscall._retval", 16, 8},
3023053e143SMichał Górny {"_info._reason._syscall._error", 24, 4},
3033053e143SMichał Górny {"_info._reason._syscall._args", 28, 64},
3043053e143SMichał Górny {"_info._reason._ptrace_state._pe_report_event", 12, 4},
3053053e143SMichał Górny {"_info._reason._ptrace_state._option._pe_other_pid", 16, 4},
3063053e143SMichał Górny {"_info._reason._ptrace_state._option._pe_lwp", 16, 4},
3073053e143SMichał Górny });
3083053e143SMichał Górny }
3093053e143SMichał Górny }
310