aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTom de Vries <tdevries@suse.de>2024-11-13 22:41:35 +0100
committerTom de Vries <tdevries@suse.de>2024-11-13 22:41:35 +0100
commit580f291cb804c65d9bcbdd0e618233f8bee0c2ff (patch)
tree8e9e08e682f6022ff5ccc08289b700a3cac4be54
parent5cb0406bb64da200520ab3a9ee8f2a3c58ea6be0 (diff)
downloadbinutils-580f291cb804c65d9bcbdd0e618233f8bee0c2ff.zip
binutils-580f291cb804c65d9bcbdd0e618233f8bee0c2ff.tar.gz
binutils-580f291cb804c65d9bcbdd0e618233f8bee0c2ff.tar.bz2
[gdb/tdep] Handle syscall clock_gettime64 for arm-linux
When running test-case gdb.reverse/time-reverse.exp on arm-linux, I run into: ... (gdb) continue^M Continuing.^M Process record and replay target doesn't support syscall number 403^M Process record does not support instruction 0xdf00 at address 0xf7ebf774.^M Process record: failed to record execution log.^M ^M Program stopped.^M 0xf7ebf774 in ?? () from /lib/arm-linux-gnueabihf/libc.so.6^M (gdb) FAIL: $exp: mode=c: continue to breakpoint: marker2 ... Syscall number 403 stands for clock_gettime64 on arm-linux. Fix this by handling 403 in arm_canonicalize_syscall, and handling gdb_sys_clock_gettime64 elsewhere. Since i386_canonicalize_syscall is the identity function, enum value gdb_sys_clock_gettime64 gets a value to match i386, which also happens to be 403. Tested on arm-linux. Approved-By: Guinevere Larsen <guinevere@redhat.com> (record-full)
-rw-r--r--gdb/arm-linux-tdep.c1
-rw-r--r--gdb/linux-record.c6
-rw-r--r--gdb/linux-record.h1
3 files changed, 8 insertions, 0 deletions
diff --git a/gdb/arm-linux-tdep.c b/gdb/arm-linux-tdep.c
index dddd577..0e49f9f 100644
--- a/gdb/arm-linux-tdep.c
+++ b/gdb/arm-linux-tdep.c
@@ -1646,6 +1646,7 @@ arm_canonicalize_syscall (int syscall)
*/
case 384: return gdb_sys_getrandom;
case 397: return gdb_sys_statx;
+ case 403: return gdb_sys_clock_gettime64;
case 983041: /* ARM_breakpoint */ return gdb_sys_no_syscall;
case 983042: /* ARM_cacheflush */ return gdb_sys_no_syscall;
case 983043: /* ARM_usr26 */ return gdb_sys_no_syscall;
diff --git a/gdb/linux-record.c b/gdb/linux-record.c
index 549ea1b..33efa02 100644
--- a/gdb/linux-record.c
+++ b/gdb/linux-record.c
@@ -1820,6 +1820,12 @@ Do you want to stop the program?"),
return -1;
break;
+ case gdb_sys_clock_gettime64:
+ /* Size of struct __timespec64 is 16. */
+ if (record_mem_at_reg (regcache, tdep->arg2, 16))
+ return -1;
+ break;
+
case gdb_sys_clock_getres:
if (record_mem_at_reg (regcache, tdep->arg2, tdep->size_timespec))
return -1;
diff --git a/gdb/linux-record.h b/gdb/linux-record.h
index 962cedc..5469612 100644
--- a/gdb/linux-record.h
+++ b/gdb/linux-record.h
@@ -512,6 +512,7 @@ enum gdb_syscall {
gdb_sys_inotify_init1 = 332,
gdb_sys_getrandom = 355,
gdb_sys_statx = 383,
+ gdb_sys_clock_gettime64 = 403,
gdb_sys_socket = 500,
gdb_sys_connect = 501,
gdb_sys_accept = 502,