mirror of
https://github.com/llvm/llvm-project.git
synced 2025-05-09 11:26:06 +00:00

Normal customer devices won't be able to run these tests, we're hoping to get a public facing bot set up at some point. Both devices pass the testsuite without any errors or failures. I have seen some instability with the armv7 test runs, I may submit additional patches to address this. arm64 looks good. I'll be watching the bots for the rest of today; if any problems are introduced by this patch I'll revert it - if anyone sees a problem with their bot that I don't see, please do the same. I know it's a rather large patch. One change I had to make specifically for iOS devices was that debugserver can't create files. There were several tests that launch the inferior process redirecting its output to a file, then they retrieve the file. They were not trying to test file redirection in these tests, so I rewrote those to write their output to a file directly. llvm-svn: 314132
73 lines
2.2 KiB
Python
73 lines
2.2 KiB
Python
"""
|
|
Test some lldb command abbreviations.
|
|
"""
|
|
|
|
from __future__ import print_function
|
|
|
|
|
|
import os
|
|
import time
|
|
import lldb
|
|
from lldbsuite.test.decorators import *
|
|
from lldbsuite.test.lldbtest import *
|
|
from lldbsuite.test import lldbutil
|
|
|
|
|
|
class DisassemblyTestCase(TestBase):
|
|
|
|
mydir = TestBase.compute_mydir(__file__)
|
|
|
|
@expectedFailureAll(
|
|
oslist=["windows"],
|
|
bugnumber="function names print fully demangled instead of name-only")
|
|
def test(self):
|
|
self.build()
|
|
exe = os.path.join(os.getcwd(), "a.out")
|
|
self.expect("file " + exe,
|
|
patterns=["Current executable set to .*a.out.*"])
|
|
|
|
match_object = lldbutil.run_break_set_command(self, "br s -n sum")
|
|
lldbutil.check_breakpoint_result(
|
|
self,
|
|
match_object,
|
|
symbol_name='sum',
|
|
symbol_match_exact=False,
|
|
num_locations=1)
|
|
|
|
self.expect("run",
|
|
patterns=["Process .* launched: "])
|
|
|
|
self.runCmd("dis -f")
|
|
disassembly = self.res.GetOutput()
|
|
|
|
# ARCH, if not specified, defaults to x86_64.
|
|
arch = self.getArchitecture()
|
|
if arch in ["", 'x86_64', 'i386', 'i686']:
|
|
breakpoint_opcodes = ["int3"]
|
|
instructions = [' mov', ' addl ', 'ret']
|
|
elif arch in ["arm", "aarch64", "arm64", "armv7", "armv7k"]:
|
|
breakpoint_opcodes = ["brk", "udf"]
|
|
instructions = [' add ', ' ldr ', ' str ']
|
|
elif re.match("mips", arch):
|
|
breakpoint_opcodes = ["break"]
|
|
instructions = ['lw', 'sw']
|
|
elif arch in ["s390x"]:
|
|
breakpoint_opcodes = [".long"]
|
|
instructions = [' l ', ' a ', ' st ']
|
|
else:
|
|
# TODO please add your arch here
|
|
self.fail(
|
|
'unimplemented for arch = "{arch}"'.format(
|
|
arch=self.getArchitecture()))
|
|
|
|
# make sure that the software breakpoint has been removed
|
|
for op in breakpoint_opcodes:
|
|
self.assertFalse(op in disassembly)
|
|
|
|
# make sure a few reasonable assembly instructions are here
|
|
self.expect(
|
|
disassembly,
|
|
exe=False,
|
|
startstr="a.out`sum",
|
|
substrs=instructions)
|