[Lldb-commits] [PATCH] D157846: [lldb][AArch64] Add SME's SVE register state to TestArm64DynamicRegsets
David Spickett via Phabricator via lldb-commits
lldb-commits at lists.llvm.org
Mon Aug 14 02:22:42 PDT 2023
DavidSpickett created this revision.
Herald added subscribers: ctetreau, kristof.beyls.
Herald added a project: All.
DavidSpickett requested review of this revision.
Herald added a project: LLDB.
Herald added a subscriber: lldb-commits.
Since we need to switch modes, this is its own test. I will be adding
ZA, SVG and SVCR checks here later.
Prior to this we didn't have any testing of writing streaming mode
SVE registers from lldb.
Repository:
rG LLVM Github Monorepo
https://reviews.llvm.org/D157846
Files:
lldb/test/API/commands/register/register/aarch64_dynamic_regset/TestArm64DynamicRegsets.py
lldb/test/API/commands/register/register/aarch64_dynamic_regset/main.c
Index: lldb/test/API/commands/register/register/aarch64_dynamic_regset/main.c
===================================================================
--- lldb/test/API/commands/register/register/aarch64_dynamic_regset/main.c
+++ lldb/test/API/commands/register/register/aarch64_dynamic_regset/main.c
@@ -1,5 +1,9 @@
#include <sys/auxv.h>
+#ifndef HWCAP2_SME
+#define HWCAP2_SME (1 << 23)
+#endif
+
void set_sve_registers() {
// AArch64 SVE extension ISA adds a new set of vector and predicate registers:
// 32 Z registers, 16 P registers, and 1 FFR register.
@@ -64,8 +68,14 @@
asm volatile("cpy z31.b, p15/z, #32\n\t");
}
-int main() {
- if (getauxval(AT_HWCAP) & HWCAP_SVE) // check if SVE is present
+int main(int argc, char *argv[]) {
+ if (argc > 1) {
+ // Enable streaming mode SVE and the ZA array storage.
+ asm volatile("msr s0_3_c4_c7_3, xzr" /*smstart*/);
+ }
+
+ // If we have SVE or SME, set the SVE registers.
+ if ((getauxval(AT_HWCAP) & HWCAP_SVE) || (getauxval(AT_HWCAP2) & HWCAP2_SME))
set_sve_registers();
return 0; // Set a break point here.
Index: lldb/test/API/commands/register/register/aarch64_dynamic_regset/TestArm64DynamicRegsets.py
===================================================================
--- lldb/test/API/commands/register/register/aarch64_dynamic_regset/TestArm64DynamicRegsets.py
+++ lldb/test/API/commands/register/register/aarch64_dynamic_regset/TestArm64DynamicRegsets.py
@@ -120,3 +120,42 @@
)
self.expect("register read data_mask", substrs=["data_mask = 0x"])
self.expect("register read code_mask", substrs=["code_mask = 0x"])
+
+ @no_debug_info_test
+ @skipIf(archs=no_match(["aarch64"]))
+ @skipIf(oslist=no_match(["linux"]))
+ def test_aarch64_dynamic_regset_config_sme(self):
+ """Test AArch64 Dynamic Register sets configuration, but only SME
+ registers."""
+ if not self.isAArch64SME():
+ self.skipTest("SME must be present.")
+
+ self.build()
+ self.line = line_number("main.c", "// Set a break point here.")
+
+ exe = self.getBuildArtifact("a.out")
+ self.runCmd("file " + exe, CURRENT_EXECUTABLE_SET)
+
+ lldbutil.run_break_set_by_file_and_line(
+ self, "main.c", self.line, num_expected_locations=1
+ )
+ self.runCmd("settings set target.run-args sme")
+ self.runCmd("run", RUN_SUCCEEDED)
+
+ self.expect(
+ "thread backtrace",
+ STOPPED_DUE_TO_BREAKPOINT,
+ substrs=["stop reason = breakpoint 1."],
+ )
+
+ target = self.dbg.GetSelectedTarget()
+ process = target.GetProcess()
+ thread = process.GetThreadAtIndex(0)
+ currentFrame = thread.GetFrameAtIndex(0)
+
+ register_sets = currentFrame.GetRegisters()
+
+ ssve_registers = register_sets.GetFirstValueByName(
+ "Scalable Vector Extension Registers")
+ self.assertTrue(ssve_registers.IsValid())
+ self.sve_regs_read_dynamic(ssve_registers)
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D157846.549838.patch
Type: text/x-patch
Size: 3067 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/lldb-commits/attachments/20230814/99da4434/attachment.bin>
More information about the lldb-commits
mailing list