aboutsummaryrefslogtreecommitdiff
path: root/gdb/configure.nat
diff options
context:
space:
mode:
authorHui Li <lihui@loongson.cn>2024-06-11 19:21:25 +0800
committerTiezhu Yang <yangtiezhu@loongson.cn>2024-06-25 05:50:08 +0800
commitc1cdee0e2c1715718c1e6224038096142ccabe40 (patch)
tree1e50ae293e34a0f0bde9f21c71fc68a956cb24ed /gdb/configure.nat
parent5ae5974d60378fa3faecff64725e00c8695bcc7d (diff)
downloadgdb-c1cdee0e2c1715718c1e6224038096142ccabe40.zip
gdb-c1cdee0e2c1715718c1e6224038096142ccabe40.tar.gz
gdb-c1cdee0e2c1715718c1e6224038096142ccabe40.tar.bz2
gdb: LoongArch: Add support for hardware watchpoint
LoongArch defines hardware watchpoint functions for load/store operations. After the software configures the watchpoints for load/store, the processor hardware will monitor the access addresses of the load/store operations and trigger watchpoint exception when the watchpoint setting conditions are met. After this patch, watch/rwatch/awatch command are supported. Refer to the following document for hardware watchpoint. https://loongson.github.io/LoongArch-Documentation/LoongArch-Vol1-EN.html#control-and-status-registers-related-to-watchpoints A simple test is as follows: lihui@bogon:~$ cat test.c #include <stdio.h> int a = 0; int main() { printf("start test\n"); a = 1; printf("a = %d\n", a); printf("end test\n"); return 0; } lihui@bogon:~$ gcc -g test.c -o test without this patch: lihui@bogon:~$ gdb test ... (gdb) start ... Temporary breakpoint 1, main () at test.c:5 5 printf("start test\n"); (gdb) awatch a Target does not support this type of hardware watchpoint. ... with this patch: lihui@bogon:~$ gdb test ... (gdb) start ... Temporary breakpoint 1, main () at test.c:5 5 printf("start test\n"); (gdb) awatch a Hardware access (read/write) watchpoint 2: a (gdb) c Continuing. start test Hardware access (read/write) watchpoint 2: a Old value = 0 New value = 1 main () at test.c:7 7 printf("a = %d\n", a); (gdb) c Continuing. Hardware access (read/write) watchpoint 2: a Value = 1 0x00000001200006e0 in main () at test.c:7 7 printf("a = %d\n", a); (gdb) c Continuing. a = 1 end test [Inferior 1 (process 22250) exited normally] Signed-off-by: Hui Li <lihui@loongson.cn> Signed-off-by: Tiezhu Yang <yangtiezhu@loongson.cn>
Diffstat (limited to 'gdb/configure.nat')
-rw-r--r--gdb/configure.nat4
1 files changed, 3 insertions, 1 deletions
diff --git a/gdb/configure.nat b/gdb/configure.nat
index 5d6669f..f88c9c2 100644
--- a/gdb/configure.nat
+++ b/gdb/configure.nat
@@ -266,7 +266,9 @@ case ${gdb_host} in
;;
loongarch)
# Host: LoongArch, running GNU/Linux.
- NATDEPFILES="${NATDEPFILES} loongarch-linux-nat.o linux-nat-trad.o"
+ NATDEPFILES="${NATDEPFILES} loongarch-linux-nat.o linux-nat-trad.o \
+ nat/loongarch-hw-point.o nat/loongarch-linux.o \
+ nat/loongarch-linux-hw-point.o"
;;
m32r)
# Host: M32R based machine running GNU/Linux