diff options
author | Frederic Riss <friss@apple.com> | 2018-04-27 00:09:04 +0000 |
---|---|---|
committer | Frederic Riss <friss@apple.com> | 2018-04-27 00:09:04 +0000 |
commit | 34ec0bfb5ecee851d31d77a21dd69d49d58eb6b5 (patch) | |
tree | bb2ebbd0e9dcc0db454e18d9d7c0eddd103c0f2c /lldb/packages/Python/lldbsuite/test/tools/lldb-server/TestGdbRemoteGPacket.py | |
parent | 887fbc61d4ad17842214329dddcd8085d822081a (diff) | |
download | bcm5719-llvm-34ec0bfb5ecee851d31d77a21dd69d49d58eb6b5.tar.gz bcm5719-llvm-34ec0bfb5ecee851d31d77a21dd69d49d58eb6b5.zip |
[debugserver] Fix handling of the 'g' packet
LLDB doesn't use this packet so we never hit this, but it looks like
some other projects talk to debugserver and are hitting an assert
(https://github.com/derekparker/delve/issues/1015).
We had an off by 1 in the accounting of the FPU structure sizes.
I added a test that basically just check that 'g' doesn't return
an error (currently it assert in debug builds). I didn't make
it an lldb-server test because it looks like lldb-server doesn't
implement the g packet.
llvm-svn: 331004
Diffstat (limited to 'lldb/packages/Python/lldbsuite/test/tools/lldb-server/TestGdbRemoteGPacket.py')
-rw-r--r-- | lldb/packages/Python/lldbsuite/test/tools/lldb-server/TestGdbRemoteGPacket.py | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/lldb/packages/Python/lldbsuite/test/tools/lldb-server/TestGdbRemoteGPacket.py b/lldb/packages/Python/lldbsuite/test/tools/lldb-server/TestGdbRemoteGPacket.py new file mode 100644 index 00000000000..f2155a03786 --- /dev/null +++ b/lldb/packages/Python/lldbsuite/test/tools/lldb-server/TestGdbRemoteGPacket.py @@ -0,0 +1,30 @@ +from __future__ import print_function + + +import gdbremote_testcase +from lldbsuite.test.decorators import * +from lldbsuite.test.lldbtest import * +from lldbsuite.test import lldbutil + + +class TestGdbRemoteGPacket(gdbremote_testcase.GdbRemoteTestCaseBase): + + mydir = TestBase.compute_mydir(__file__) + + def run_test_g_packet(self): + self.build() + self.prep_debug_monitor_and_inferior() + self.test_sequence.add_log_lines( + ["read packet: $g#67", + {"direction": "send", "regex": r"^\$(.+)#[0-9a-fA-F]{2}$", + "capture": {1: "register_bank"}}], + True) + self.connect_to_debug_monitor() + context = self.expect_gdbremote_sequence() + register_bank = context.get("register_bank") + self.assertTrue(register_bank[0] != 'E') + + @debugserver_test + def test_g_packet_debugserver(self): + self.init_debugserver_test() + self.run_test_g_packet() |