""" Test lldb's ability to read and write the AArch64 FPMR register. """ import lldb from lldbsuite.test.decorators import * from lldbsuite.test.lldbtest import * from lldbsuite.test import lldbutil class AArch64LinuxFPMR(TestBase): NO_DEBUG_INFO_TESTCASE = True # The value set by the inferior. EXPECTED_FPMR = (0b101010 << 32) | 0b101 EXPECTED_FPMR_FIELDS = ["LSCALE2 = 42", "F8S1 = FP8_E4M3 | 0x4"] @skipUnlessArch("aarch64") @skipUnlessPlatform(["linux"]) def test_fpmr_register_live(self): if not self.isAArch64FPMR(): self.skipTest("FPMR must be present.") self.build() self.runCmd("file " + self.getBuildArtifact("a.out"), CURRENT_EXECUTABLE_SET) lldbutil.run_break_set_by_file_and_line( self, "main.c", line_number("main.c", "// Set break point at this line."), num_expected_locations=1, ) self.runCmd("run", RUN_SUCCEEDED) if self.process().GetState() == lldb.eStateExited: self.fail("Test program failed to run.") self.expect( "thread list", STOPPED_DUE_TO_BREAKPOINT, substrs=["stopped", "stop reason = breakpoint"], ) # This has been set by the program. self.expect( "register read --all", substrs=[ "Floating Point Mode Register", f"fpmr = {self.EXPECTED_FPMR:#018x}", ], ) if self.hasXMLSupport(): self.expect("register read fpmr", substrs=self.EXPECTED_FPMR_FIELDS) # Write a value for the program to find. Same fields but with bit values # inverted. new_fpmr = (0b010101 << 32) | 0b010 self.runCmd(f"register write fpmr {new_fpmr:#x}") # This value should be saved and restored after expressions. self.runCmd("p expr_func()") self.expect("register read fpmr", substrs=[f"fpmr = {new_fpmr:#018x}"]) # 0 means the program found the new value in the sysreg as expected. self.expect("continue", substrs=["exited with status = 0"]) @skipIfLLVMTargetMissing("AArch64") def test_fpmr_register_core(self): if not self.isAArch64FPMR(): self.skipTest("FPMR must be present.") self.runCmd("target create --core corefile") self.expect( "register read --all", substrs=[ "Floating Point Mode Register", f"fpmr = {self.EXPECTED_FPMR:#018x}", ], ) self.expect("register read fpmr", substrs=self.EXPECTED_FPMR_FIELDS)