mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2025-01-09 01:29:52 +00:00
Revert "Correctly identify iOS simulator processes in debugserver."
This reverts commit 59d816d884
.
It broke TestGDBRemoteClient.
This commit is contained in:
parent
59d816d884
commit
66a6fa631e
@ -1131,20 +1131,6 @@ bool GDBRemoteCommunicationClient::GetDefaultThreadId(lldb::tid_t &tid) {
|
||||
return true;
|
||||
}
|
||||
|
||||
static void ParseOSType(llvm::StringRef value, std::string &os_name,
|
||||
std::string &environment) {
|
||||
if (value.equals("iossimulator") || value.equals("tvossimulator") ||
|
||||
value.equals("watchossimulator")) {
|
||||
environment = "simulator";
|
||||
os_name = value.drop_back(environment.size()).str();
|
||||
} else if (value.equals("maccatalyst")) {
|
||||
os_name = "ios";
|
||||
environment = "macabi";
|
||||
} else {
|
||||
os_name = value.str();
|
||||
}
|
||||
}
|
||||
|
||||
bool GDBRemoteCommunicationClient::GetHostInfo(bool force) {
|
||||
Log *log(ProcessGDBRemoteLog::GetLogIfAnyCategoryIsSet(GDBR_LOG_PROCESS));
|
||||
|
||||
@ -1203,7 +1189,11 @@ bool GDBRemoteCommunicationClient::GetHostInfo(bool force) {
|
||||
extractor.GetHexByteString(m_os_kernel);
|
||||
++num_keys_decoded;
|
||||
} else if (name.equals("ostype")) {
|
||||
ParseOSType(value, os_name, environment);
|
||||
if (value.equals("maccatalyst")) {
|
||||
os_name = "ios";
|
||||
environment = "macabi";
|
||||
} else
|
||||
os_name = std::string(value);
|
||||
++num_keys_decoded;
|
||||
} else if (name.equals("vendor")) {
|
||||
vendor_name = std::string(value);
|
||||
@ -2063,7 +2053,11 @@ bool GDBRemoteCommunicationClient::GetCurrentProcessInfo(bool allow_lazy) {
|
||||
extractor.GetHexByteString(triple);
|
||||
++num_keys_decoded;
|
||||
} else if (name.equals("ostype")) {
|
||||
ParseOSType(value, os_name, environment);
|
||||
if (value.equals("maccatalyst")) {
|
||||
os_name = "ios";
|
||||
environment = "macabi";
|
||||
} else
|
||||
os_name = std::string(value);
|
||||
++num_keys_decoded;
|
||||
} else if (name.equals("vendor")) {
|
||||
vendor_name = std::string(value);
|
||||
|
@ -1,58 +0,0 @@
|
||||
import lldb
|
||||
from lldbsuite.test.lldbtest import *
|
||||
from lldbsuite.test.decorators import *
|
||||
from gdbclientutils import *
|
||||
|
||||
class TestIOSSimulator(GDBRemoteTestBase):
|
||||
"""
|
||||
Test that an ios simulator process is recognized as such.
|
||||
"""
|
||||
|
||||
class MyResponder(MockGDBServerResponder):
|
||||
def __init__(self, host, process):
|
||||
self.host_ostype = host
|
||||
self.process_ostype = process
|
||||
MockGDBServerResponder.__init__(self)
|
||||
|
||||
def qHostInfo(self):
|
||||
return "cputype:16777223;cpusubtype:8;ostype:%s;vendor:apple;os_version:10.15.4;maccatalyst_version:13.4;endian:little;ptrsize:8;"%self.host_ostype
|
||||
def qProcessInfo(self):
|
||||
return "pid:a860;parent-pid:d2a0;real-uid:1f5;real-gid:14;effective-uid:1f5;effective-gid:14;cputype:1000007;cpusubtype:8;ptrsize:8;ostype:%s;vendor:apple;endian:little;"%self.process_ostype
|
||||
def vCont(self):
|
||||
return "vCont;"
|
||||
|
||||
def platform_test(self, host, process, expected_triple):
|
||||
self.server.responder = self.MyResponder(host, process)
|
||||
if self.TraceOn():
|
||||
self.runCmd("log enable gdb-remote packets")
|
||||
self.addTearDownHook(lambda: self.runCmd("log disable gdb-remote packets"))
|
||||
|
||||
target = self.dbg.CreateTargetWithFileAndArch(None, None)
|
||||
process = self.connect(target)
|
||||
triple = target.GetTriple()
|
||||
self.assertEqual(triple, expected_triple)
|
||||
|
||||
@skipIfRemote
|
||||
def test_macos(self):
|
||||
self.platform_test(host="macosx", process="macosx",
|
||||
expected_triple="x86_64h-apple-macosx-")
|
||||
|
||||
@skipIfRemote
|
||||
def test_ios_sim(self):
|
||||
self.platform_test(host="macosx", process="iossimulator",
|
||||
expected_triple="x86_64h-apple-ios-simulator")
|
||||
|
||||
@skipIfRemote
|
||||
def test_catalyst(self):
|
||||
self.platform_test(host="macosx", process="maccatalyst",
|
||||
expected_triple="x86_64h-apple-ios-macabi")
|
||||
|
||||
@skipIfRemote
|
||||
def test_tvos_sim(self):
|
||||
self.platform_test(host="macosx", process="tvossimulator",
|
||||
expected_triple="x86_64h-apple-tvos-simulator")
|
||||
|
||||
@skipIfRemote
|
||||
def test_tvos_sim(self):
|
||||
self.platform_test(host="macosx", process="watchossimulator",
|
||||
expected_triple="x86_64h-apple-watchos-simulator")
|
@ -31,6 +31,8 @@ class MyResponder(MockGDBServerResponder):
|
||||
MockGDBServerResponder.__init__(self)
|
||||
|
||||
def respond(self, packet):
|
||||
if packet == "qProcessInfo":
|
||||
return self.qProcessInfo()
|
||||
if packet[0:13] == "qRegisterInfo":
|
||||
return self.qRegisterInfo(packet[13:])
|
||||
return MockGDBServerResponder.respond(self, packet)
|
||||
|
@ -170,8 +170,6 @@ class MockGDBServerResponder:
|
||||
return self.qQueryGDBServer()
|
||||
if packet == "qHostInfo":
|
||||
return self.qHostInfo()
|
||||
if packet == "qProcessInfo":
|
||||
return self.qProcessInfo()
|
||||
if packet == "qGetWorkingDir":
|
||||
return self.qGetWorkingDir()
|
||||
if packet == "qOffsets":
|
||||
@ -198,9 +196,6 @@ class MockGDBServerResponder:
|
||||
def qHostInfo(self):
|
||||
return "ptrsize:8;endian:little;"
|
||||
|
||||
def qProcessInfo(self):
|
||||
return "pid:1;ptrsize:8;endian:little;"
|
||||
|
||||
def qQueryGDBServer(self):
|
||||
return "E04"
|
||||
|
||||
|
@ -598,16 +598,6 @@ nub_addr_t MachProcess::GetTSDAddressForThread(
|
||||
plo_pthread_tsd_entry_size);
|
||||
}
|
||||
|
||||
/// Determine whether this is running on macOS.
|
||||
/// Since debugserver runs on the same machine as the process, we can
|
||||
/// just look at the compilation target.
|
||||
static bool IsMacOSHost() {
|
||||
#if TARGET_OS_OSX == 1
|
||||
return true;
|
||||
#else
|
||||
return false;
|
||||
#endif
|
||||
}
|
||||
|
||||
const char *MachProcess::GetDeploymentInfo(const struct load_command& lc,
|
||||
uint64_t load_command_address,
|
||||
@ -629,17 +619,15 @@ const char *MachProcess::GetDeploymentInfo(const struct load_command& lc,
|
||||
minor_version = (vers_cmd.sdk >> 8) & 0xffu;
|
||||
patch_version = vers_cmd.sdk & 0xffu;
|
||||
|
||||
// Handle the older LC_VERSION load commands, which don't
|
||||
// distinguish between simulator and real hardware.
|
||||
switch (cmd) {
|
||||
case LC_VERSION_MIN_IPHONEOS:
|
||||
return IsMacOSHost() ? "iossimulator": "ios";
|
||||
return "ios";
|
||||
case LC_VERSION_MIN_MACOSX:
|
||||
return "macosx";
|
||||
case LC_VERSION_MIN_TVOS:
|
||||
return IsMacOSHost() ? "tvossimulator": "tvos";
|
||||
return "tvos";
|
||||
case LC_VERSION_MIN_WATCHOS:
|
||||
return IsMacOSHost() ? "watchossimulator" : "watchos";
|
||||
return "watchos";
|
||||
default:
|
||||
return nullptr;
|
||||
}
|
||||
@ -661,17 +649,14 @@ const char *MachProcess::GetDeploymentInfo(const struct load_command& lc,
|
||||
case PLATFORM_MACCATALYST:
|
||||
return "maccatalyst";
|
||||
case PLATFORM_IOS:
|
||||
return "ios";
|
||||
case PLATFORM_IOSSIMULATOR:
|
||||
return "iossimulator";
|
||||
return "ios";
|
||||
case PLATFORM_TVOS:
|
||||
return "tvos";
|
||||
case PLATFORM_TVOSSIMULATOR:
|
||||
return "tvossimulator";
|
||||
return "tvos";
|
||||
case PLATFORM_WATCHOS:
|
||||
return "watchos";
|
||||
case PLATFORM_WATCHOSSIMULATOR:
|
||||
return "watchossimulator";
|
||||
return "watchos";
|
||||
case PLATFORM_BRIDGEOS:
|
||||
return "bridgeos";
|
||||
case PLATFORM_DRIVERKIT:
|
||||
|
Loading…
Reference in New Issue
Block a user