]> git.ipfire.org Git - thirdparty/qemu.git/commit
Hexagon: lldb read/write predicate registers p0/p1/p2/p3
authorTaylor Simpson <ltaylorsimpson@gmail.com>
Thu, 13 Jun 2024 18:22:09 +0000 (12:22 -0600)
committerBrian Cain <bcain@quicinc.com>
Thu, 8 Aug 2024 03:34:41 +0000 (20:34 -0700)
commit523e45ac5b881237bd03934751d44767e5716620
tree4a2fd23e6544509a2f58d520df19ab50ccd8c1d9
parent6146060a6891848f854b0ed1e46e020a6fdc77c2
Hexagon: lldb read/write predicate registers p0/p1/p2/p3

hexagon-core.xml only exposes register p3_0 which is an alias that
aggregates the predicate registers.  It is more convenient for users
to interact directly with the predicate registers.

Tested with lldb downloaded from this location
https://github.com/llvm/llvm-project/releases/download/llvmorg-18.1.4/clang+llvm-18.1.4-x86_64-linux-gnu-ubuntu-18.04.tar.xz

BEFORE:
(lldb) reg read p3_0
    p3_0 = 0x00000000
(lldb) reg read p0
error: Invalid register name 'p0'.
(lldb) reg write p1 0xf
error: Register not found for 'p1'.

AFTER:
(lldb) reg read p3_0
    p3_0 = 0x00000000
(lldb) reg read p0
      p0 = 0x00
(lldb) reg read -s 1
Predicate Registers:
        p0 = 0x00
        p1 = 0x00
        p2 = 0x00
        p3 = 0x00

(lldb) reg write p1 0xf
(lldb) reg read p3_0
    p3_0 = 0x00000f00
(lldb) reg write p3_0 0xff00ff00
(lldb) reg read -s 1
Predicate Registers:
        p0 = 0x00
        p1 = 0xff
        p2 = 0x00
        p3 = 0xff

Signed-off-by: Taylor Simpson <ltaylorsimpson@gmail.com>
Reviewed-by: Brian Cain <bcain@quicinc.com>
Reviewed-by: Matheus Tavares Bernardino <quic_mathbern@quicinc.com>
Message-Id: <20240613182209.140082-1-ltaylorsimpson@gmail.com>
Signed-off-by: Brian Cain <bcain@quicinc.com>
gdb-xml/hexagon-core.xml
target/hexagon/gdbstub.c