1 /* Process record and replay target code for GNU/Linux.
3 Copyright (C) 2008-2019 Free Software Foundation, Inc.
5 This file is part of GDB.
7 This program is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 3 of the License, or
10 (at your option) any later version.
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
17 You should have received a copy of the GNU General Public License
18 along with this program. If not, see <http://www.gnu.org/licenses/>. */
25 #include "record-full.h"
26 #include "linux-record.h"
29 /* These macros are the values of the first argument of system call
30 "sys_ptrace". The values of these macros were obtained from Linux
33 #define RECORD_PTRACE_PEEKTEXT 1
34 #define RECORD_PTRACE_PEEKDATA 2
35 #define RECORD_PTRACE_PEEKUSR 3
37 /* These macros are the values of the first argument of system call
38 "sys_socketcall". The values of these macros were obtained from
39 Linux Kernel source. */
41 #define RECORD_SYS_SOCKET 1
42 #define RECORD_SYS_BIND 2
43 #define RECORD_SYS_CONNECT 3
44 #define RECORD_SYS_LISTEN 4
45 #define RECORD_SYS_ACCEPT 5
46 #define RECORD_SYS_GETSOCKNAME 6
47 #define RECORD_SYS_GETPEERNAME 7
48 #define RECORD_SYS_SOCKETPAIR 8
49 #define RECORD_SYS_SEND 9
50 #define RECORD_SYS_RECV 10
51 #define RECORD_SYS_SENDTO 11
52 #define RECORD_SYS_RECVFROM 12
53 #define RECORD_SYS_SHUTDOWN 13
54 #define RECORD_SYS_SETSOCKOPT 14
55 #define RECORD_SYS_GETSOCKOPT 15
56 #define RECORD_SYS_SENDMSG 16
57 #define RECORD_SYS_RECVMSG 17
59 /* These macros are the values of the first argument of system call
60 "sys_ipc". The values of these macros were obtained from Linux
63 #define RECORD_SEMOP 1
64 #define RECORD_SEMGET 2
65 #define RECORD_SEMCTL 3
66 #define RECORD_SEMTIMEDOP 4
67 #define RECORD_MSGSND 11
68 #define RECORD_MSGRCV 12
69 #define RECORD_MSGGET 13
70 #define RECORD_MSGCTL 14
71 #define RECORD_SHMAT 21
72 #define RECORD_SHMDT 22
73 #define RECORD_SHMGET 23
74 #define RECORD_SHMCTL 24
76 /* These macros are the values of the first argument of system call
77 "sys_quotactl". The values of these macros were obtained from Linux
80 #define RECORD_Q_GETFMT 0x800004
81 #define RECORD_Q_GETINFO 0x800005
82 #define RECORD_Q_GETQUOTA 0x800007
83 #define RECORD_Q_XGETQSTAT (('5' << 8) + 5)
84 #define RECORD_Q_XGETQUOTA (('3' << 8) + 3)
86 #define OUTPUT_REG(val, num) phex_nz ((val), \
87 TYPE_LENGTH (gdbarch_register_type (regcache->arch (), (num))))
89 /* Record a memory area of length LEN pointed to by register
93 record_mem_at_reg (struct regcache
*regcache
, int regnum
, int len
)
97 regcache_raw_read_unsigned (regcache
, regnum
, &addr
);
98 return record_full_arch_list_add_mem ((CORE_ADDR
) addr
, len
);
102 record_linux_sockaddr (struct regcache
*regcache
,
103 struct linux_record_tdep
*tdep
, ULONGEST addr
,
108 struct gdbarch
*gdbarch
= regcache
->arch ();
109 enum bfd_endian byte_order
= gdbarch_byte_order (gdbarch
);
114 a
= (gdb_byte
*) alloca (tdep
->size_int
);
116 if (record_full_arch_list_add_mem ((CORE_ADDR
) len
, tdep
->size_int
))
119 /* Get the addrlen. */
120 if (target_read_memory ((CORE_ADDR
) len
, a
, tdep
->size_int
))
123 fprintf_unfiltered (gdb_stdlog
,
124 "Process record: error reading "
125 "memory at addr = 0x%s len = %d.\n",
126 phex_nz (len
, tdep
->size_pointer
),
130 addrlen
= (int) extract_unsigned_integer (a
, tdep
->size_int
, byte_order
);
131 if (addrlen
<= 0 || addrlen
> tdep
->size_sockaddr
)
132 addrlen
= tdep
->size_sockaddr
;
134 if (record_full_arch_list_add_mem ((CORE_ADDR
) addr
, addrlen
))
141 record_linux_msghdr (struct regcache
*regcache
,
142 struct linux_record_tdep
*tdep
, ULONGEST addr
)
145 struct gdbarch
*gdbarch
= regcache
->arch ();
146 enum bfd_endian byte_order
= gdbarch_byte_order (gdbarch
);
153 if (record_full_arch_list_add_mem ((CORE_ADDR
) addr
, tdep
->size_msghdr
))
156 a
= (gdb_byte
*) alloca (tdep
->size_msghdr
);
157 if (target_read_memory ((CORE_ADDR
) addr
, a
, tdep
->size_msghdr
))
160 fprintf_unfiltered (gdb_stdlog
,
161 "Process record: error reading "
162 "memory at addr = 0x%s "
164 phex_nz (addr
, tdep
->size_pointer
),
169 /* msg_name msg_namelen */
170 addr
= extract_unsigned_integer (a
, tdep
->size_pointer
, byte_order
);
171 a
+= tdep
->size_pointer
;
172 if (record_full_arch_list_add_mem
174 (int) extract_unsigned_integer (a
,
178 /* We have read an int, but skip size_pointer bytes to account for alignment
179 of the next field on 64-bit targets. */
180 a
+= tdep
->size_pointer
;
182 /* msg_iov msg_iovlen */
183 addr
= extract_unsigned_integer (a
, tdep
->size_pointer
, byte_order
);
184 a
+= tdep
->size_pointer
;
188 ULONGEST len
= extract_unsigned_integer (a
, tdep
->size_size_t
,
190 gdb_byte
*iov
= (gdb_byte
*) alloca (tdep
->size_iovec
);
192 for (i
= 0; i
< len
; i
++)
194 if (target_read_memory ((CORE_ADDR
) addr
, iov
, tdep
->size_iovec
))
197 fprintf_unfiltered (gdb_stdlog
,
198 "Process record: error "
202 phex_nz (addr
,tdep
->size_pointer
),
206 tmpaddr
= (CORE_ADDR
) extract_unsigned_integer (iov
,
209 tmpint
= (int) extract_unsigned_integer (iov
+ tdep
->size_pointer
,
212 if (record_full_arch_list_add_mem (tmpaddr
, tmpint
))
214 addr
+= tdep
->size_iovec
;
217 a
+= tdep
->size_size_t
;
219 /* msg_control msg_controllen */
220 addr
= extract_unsigned_integer (a
, tdep
->size_pointer
, byte_order
);
221 a
+= tdep
->size_pointer
;
222 tmpint
= (int) extract_unsigned_integer (a
, tdep
->size_size_t
, byte_order
);
223 if (record_full_arch_list_add_mem ((CORE_ADDR
) addr
, tmpint
))
229 /* When the architecture process record get a Linux syscall
230 instruction, it will get a Linux syscall number of this
231 architecture and convert it to the Linux syscall number "num" which
232 is internal to GDB. Most Linux syscalls across architectures in
233 Linux would be similar and mostly differ by sizes of types and
234 structures. This sizes are put to "tdep".
236 Record the values of the registers and memory that will be changed
237 in current system call.
239 Return -1 if something wrong. */
242 record_linux_system_call (enum gdb_syscall syscall
,
243 struct regcache
*regcache
,
244 struct linux_record_tdep
*tdep
)
246 struct gdbarch
*gdbarch
= regcache
->arch ();
247 enum bfd_endian byte_order
= gdbarch_byte_order (gdbarch
);
248 ULONGEST tmpulongest
;
254 case gdb_sys_restart_syscall
:
258 if (yquery (_("The next instruction is syscall exit. "
259 "It will make the program exit. "
260 "Do you want to stop the program?")))
268 case gdb_sys_readlink
:
270 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
271 if (record_mem_at_reg (regcache
, tdep
->arg2
, (int) tmpulongest
))
280 case gdb_sys_waitpid
:
281 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
283 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
296 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
298 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
305 case gdb_sys_lchown16
:
306 case gdb_sys_ni_syscall17
:
312 if (record_mem_at_reg (regcache
, tdep
->arg2
,
313 tdep
->size__old_kernel_stat
))
320 case gdb_sys_oldumount
:
321 case gdb_sys_setuid16
:
322 case gdb_sys_getuid16
:
327 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
328 if (tmpulongest
== RECORD_PTRACE_PEEKTEXT
329 || tmpulongest
== RECORD_PTRACE_PEEKDATA
330 || tmpulongest
== RECORD_PTRACE_PEEKUSR
)
332 if (record_mem_at_reg (regcache
, tdep
->arg4
, 4))
340 case gdb_sys_ni_syscall31
:
341 case gdb_sys_ni_syscall32
:
344 case gdb_sys_ni_syscall35
:
355 if (record_mem_at_reg (regcache
, tdep
->arg1
, tdep
->size_int
* 2))
360 if (record_mem_at_reg (regcache
, tdep
->arg1
, tdep
->size_tms
))
364 case gdb_sys_ni_syscall44
:
366 case gdb_sys_setgid16
:
367 case gdb_sys_getgid16
:
369 case gdb_sys_geteuid16
:
370 case gdb_sys_getegid16
:
373 case gdb_sys_ni_syscall53
:
377 /* XXX Need to add a lot of support of other ioctl requests. */
378 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
379 if (tmpulongest
== tdep
->ioctl_FIOCLEX
380 || tmpulongest
== tdep
->ioctl_FIONCLEX
381 || tmpulongest
== tdep
->ioctl_FIONBIO
382 || tmpulongest
== tdep
->ioctl_FIOASYNC
383 || tmpulongest
== tdep
->ioctl_TCSETS
384 || tmpulongest
== tdep
->ioctl_TCSETSW
385 || tmpulongest
== tdep
->ioctl_TCSETSF
386 || tmpulongest
== tdep
->ioctl_TCSETA
387 || tmpulongest
== tdep
->ioctl_TCSETAW
388 || tmpulongest
== tdep
->ioctl_TCSETAF
389 || tmpulongest
== tdep
->ioctl_TCSBRK
390 || tmpulongest
== tdep
->ioctl_TCXONC
391 || tmpulongest
== tdep
->ioctl_TCFLSH
392 || tmpulongest
== tdep
->ioctl_TIOCEXCL
393 || tmpulongest
== tdep
->ioctl_TIOCNXCL
394 || tmpulongest
== tdep
->ioctl_TIOCSCTTY
395 || tmpulongest
== tdep
->ioctl_TIOCSPGRP
396 || tmpulongest
== tdep
->ioctl_TIOCSTI
397 || tmpulongest
== tdep
->ioctl_TIOCSWINSZ
398 || tmpulongest
== tdep
->ioctl_TIOCMBIS
399 || tmpulongest
== tdep
->ioctl_TIOCMBIC
400 || tmpulongest
== tdep
->ioctl_TIOCMSET
401 || tmpulongest
== tdep
->ioctl_TIOCSSOFTCAR
402 || tmpulongest
== tdep
->ioctl_TIOCCONS
403 || tmpulongest
== tdep
->ioctl_TIOCSSERIAL
404 || tmpulongest
== tdep
->ioctl_TIOCPKT
405 || tmpulongest
== tdep
->ioctl_TIOCNOTTY
406 || tmpulongest
== tdep
->ioctl_TIOCSETD
407 || tmpulongest
== tdep
->ioctl_TCSBRKP
408 || tmpulongest
== tdep
->ioctl_TIOCTTYGSTRUCT
409 || tmpulongest
== tdep
->ioctl_TIOCSBRK
410 || tmpulongest
== tdep
->ioctl_TIOCCBRK
411 || tmpulongest
== tdep
->ioctl_TCSETS2
412 || tmpulongest
== tdep
->ioctl_TCSETSW2
413 || tmpulongest
== tdep
->ioctl_TCSETSF2
414 || tmpulongest
== tdep
->ioctl_TIOCSPTLCK
415 || tmpulongest
== tdep
->ioctl_TIOCSERCONFIG
416 || tmpulongest
== tdep
->ioctl_TIOCSERGWILD
417 || tmpulongest
== tdep
->ioctl_TIOCSERSWILD
418 || tmpulongest
== tdep
->ioctl_TIOCSLCKTRMIOS
419 || tmpulongest
== tdep
->ioctl_TIOCSERGETMULTI
420 || tmpulongest
== tdep
->ioctl_TIOCSERSETMULTI
421 || tmpulongest
== tdep
->ioctl_TIOCMIWAIT
422 || tmpulongest
== tdep
->ioctl_TIOCSHAYESESP
)
426 else if (tmpulongest
== tdep
->ioctl_TCGETS
427 || tmpulongest
== tdep
->ioctl_TCGETA
428 || tmpulongest
== tdep
->ioctl_TIOCGLCKTRMIOS
)
430 if (record_mem_at_reg (regcache
, tdep
->arg3
,
434 else if (tmpulongest
== tdep
->ioctl_TIOCGPGRP
435 || tmpulongest
== tdep
->ioctl_TIOCGSID
)
437 if (record_mem_at_reg (regcache
, tdep
->arg3
, tdep
->size_pid_t
))
440 else if (tmpulongest
== tdep
->ioctl_TIOCOUTQ
441 || tmpulongest
== tdep
->ioctl_TIOCMGET
442 || tmpulongest
== tdep
->ioctl_TIOCGSOFTCAR
443 || tmpulongest
== tdep
->ioctl_FIONREAD
444 || tmpulongest
== tdep
->ioctl_TIOCINQ
445 || tmpulongest
== tdep
->ioctl_TIOCGETD
446 || tmpulongest
== tdep
->ioctl_TIOCGPTN
447 || tmpulongest
== tdep
->ioctl_TIOCSERGETLSR
)
449 if (record_mem_at_reg (regcache
, tdep
->arg3
, tdep
->size_int
))
452 else if (tmpulongest
== tdep
->ioctl_TIOCGWINSZ
)
454 if (record_mem_at_reg (regcache
, tdep
->arg3
,
458 else if (tmpulongest
== tdep
->ioctl_TIOCLINUX
)
460 /* This syscall affects a char-size memory. */
461 if (record_mem_at_reg (regcache
, tdep
->arg3
, 1))
464 else if (tmpulongest
== tdep
->ioctl_TIOCGSERIAL
)
466 if (record_mem_at_reg (regcache
, tdep
->arg3
,
467 tdep
->size_serial_struct
))
470 else if (tmpulongest
== tdep
->ioctl_TCGETS2
)
472 if (record_mem_at_reg (regcache
, tdep
->arg3
,
473 tdep
->size_termios2
))
476 else if (tmpulongest
== tdep
->ioctl_FIOQSIZE
)
478 if (record_mem_at_reg (regcache
, tdep
->arg3
, tdep
->size_loff_t
))
481 else if (tmpulongest
== tdep
->ioctl_TIOCGICOUNT
)
483 if (record_mem_at_reg (regcache
, tdep
->arg3
,
484 tdep
->size_serial_icounter_struct
))
487 else if (tmpulongest
== tdep
->ioctl_TIOCGHAYESESP
)
489 if (record_mem_at_reg (regcache
, tdep
->arg3
,
490 tdep
->size_hayes_esp_config
))
493 else if (tmpulongest
== tdep
->ioctl_TIOCSERGSTRUCT
)
495 printf_unfiltered (_("Process record and replay target doesn't "
496 "support ioctl request TIOCSERGSTRUCT\n"));
501 printf_unfiltered (_("Process record and replay target doesn't "
502 "support ioctl request 0x%s.\n"),
503 OUTPUT_REG (tmpulongest
, tdep
->arg2
));
510 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
512 if (tmpulongest
== tdep
->fcntl_F_GETLK
)
514 if (record_mem_at_reg (regcache
, tdep
->arg3
, tdep
->size_flock
))
519 case gdb_sys_ni_syscall56
:
520 case gdb_sys_setpgid
:
521 case gdb_sys_ni_syscall58
:
524 case gdb_sys_olduname
:
525 if (record_mem_at_reg (regcache
, tdep
->arg1
,
526 tdep
->size_oldold_utsname
))
535 if (record_mem_at_reg (regcache
, tdep
->arg2
, tdep
->size_ustat
))
540 case gdb_sys_getppid
:
541 case gdb_sys_getpgrp
:
545 case gdb_sys_sigaction
:
546 if (record_mem_at_reg (regcache
, tdep
->arg3
,
547 tdep
->size_old_sigaction
))
551 case gdb_sys_sgetmask
:
552 case gdb_sys_ssetmask
:
553 case gdb_sys_setreuid16
:
554 case gdb_sys_setregid16
:
555 case gdb_sys_sigsuspend
:
558 case gdb_sys_sigpending
:
559 if (record_mem_at_reg (regcache
, tdep
->arg1
,
560 tdep
->size_old_sigset_t
))
564 case gdb_sys_sethostname
:
565 case gdb_sys_setrlimit
:
568 case gdb_sys_old_getrlimit
:
569 if (record_mem_at_reg (regcache
, tdep
->arg2
, tdep
->size_rlimit
))
573 case gdb_sys_getrusage
:
574 if (record_mem_at_reg (regcache
, tdep
->arg2
, tdep
->size_rusage
))
578 case gdb_sys_gettimeofday
:
579 if (record_mem_at_reg (regcache
, tdep
->arg1
, tdep
->size_timeval
)
580 || record_mem_at_reg (regcache
, tdep
->arg2
, tdep
->size_timezone
))
584 case gdb_sys_settimeofday
:
587 case gdb_sys_getgroups16
:
588 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
593 regcache_raw_read_unsigned (regcache
, tdep
->arg1
,
595 tmpint
= tdep
->size_old_gid_t
* (int) gidsetsize
;
596 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
, tmpint
))
601 case gdb_sys_setgroups16
:
606 unsigned long sz_sel_arg
= tdep
->size_long
+ tdep
->size_pointer
* 4;
607 gdb_byte
*a
= (gdb_byte
*) alloca (sz_sel_arg
);
608 CORE_ADDR inp
, outp
, exp
, tvp
;
610 regcache_raw_read_unsigned (regcache
, tdep
->arg1
,
614 if (target_read_memory (tmpulongest
, a
, sz_sel_arg
))
617 fprintf_unfiltered (gdb_stdlog
,
618 "Process record: error reading memory "
619 "at addr = 0x%s len = %lu.\n",
620 OUTPUT_REG (tmpulongest
, tdep
->arg1
),
625 a
+= tdep
->size_long
;
626 inp
= extract_unsigned_integer (a
, tdep
->size_pointer
, byte_order
);
627 a
+= tdep
->size_pointer
;
628 outp
= extract_unsigned_integer (a
, tdep
->size_pointer
, byte_order
);
629 a
+= tdep
->size_pointer
;
630 exp
= extract_unsigned_integer (a
, tdep
->size_pointer
, byte_order
);
631 a
+= tdep
->size_pointer
;
632 tvp
= extract_unsigned_integer (a
, tdep
->size_pointer
, byte_order
);
634 if (record_full_arch_list_add_mem (inp
, tdep
->size_fd_set
))
637 if (record_full_arch_list_add_mem (outp
, tdep
->size_fd_set
))
640 if (record_full_arch_list_add_mem (exp
, tdep
->size_fd_set
))
643 if (record_full_arch_list_add_mem (tvp
, tdep
->size_timeval
))
649 case gdb_sys_symlink
:
657 if (yquery (_("The next instruction is syscall reboot. "
658 "It will restart the computer. "
659 "Do you want to stop the program?")))
663 case gdb_old_readdir
:
664 if (record_mem_at_reg (regcache
, tdep
->arg2
, tdep
->size_old_dirent
))
675 regcache_raw_read_unsigned (regcache
, tdep
->arg1
,
677 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &len
);
678 if (record_full_memory_query
)
681 The next instruction is syscall munmap.\n\
682 It will free the memory addr = 0x%s len = %u.\n\
683 It will make record target cannot record some memory change.\n\
684 Do you want to stop the program?"),
685 OUTPUT_REG (tmpulongest
, tdep
->arg1
), (int) len
))
691 case gdb_sys_truncate
:
692 case gdb_sys_ftruncate
:
694 case gdb_sys_fchown16
:
695 case gdb_sys_getpriority
:
696 case gdb_sys_setpriority
:
697 case gdb_sys_ni_syscall98
:
701 case gdb_sys_fstatfs
:
702 if (record_mem_at_reg (regcache
, tdep
->arg2
, tdep
->size_statfs
))
711 case gdb_sys_sendmsg
:
712 case gdb_sys_shutdown
:
714 case gdb_sys_connect
:
716 case gdb_sys_setsockopt
:
720 case gdb_sys_getsockname
:
721 case gdb_sys_getpeername
:
725 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
726 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &len
);
727 if (record_linux_sockaddr (regcache
, tdep
, tmpulongest
, len
))
732 case gdb_sys_recvfrom
:
736 regcache_raw_read_unsigned (regcache
, tdep
->arg4
, &tmpulongest
);
737 regcache_raw_read_unsigned (regcache
, tdep
->arg5
, &len
);
738 if (record_linux_sockaddr (regcache
, tdep
, tmpulongest
, len
))
743 case gdb_sys_recvmsg
:
744 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
745 if (record_linux_msghdr (regcache
, tdep
, tmpulongest
))
749 case gdb_sys_socketpair
:
750 if (record_mem_at_reg (regcache
, tdep
->arg4
, tdep
->size_int
))
754 case gdb_sys_getsockopt
:
755 regcache_raw_read_unsigned (regcache
, tdep
->arg5
, &tmpulongest
);
759 gdb_byte
*optlenp
= (gdb_byte
*) alloca (tdep
->size_int
);
761 if (target_read_memory ((CORE_ADDR
) tmpulongest
, optlenp
,
765 fprintf_unfiltered (gdb_stdlog
,
766 "Process record: error reading "
767 "memory at addr = 0x%s "
769 OUTPUT_REG (tmpulongest
, tdep
->arg5
),
773 regcache_raw_read_unsigned (regcache
, tdep
->arg4
, &optvalp
);
774 tmpint
= (int) extract_signed_integer (optlenp
, tdep
->size_int
,
776 if (record_full_arch_list_add_mem ((CORE_ADDR
) optvalp
, tmpint
))
778 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
784 case gdb_sys_socketcall
:
785 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
788 case RECORD_SYS_SOCKET
:
789 case RECORD_SYS_BIND
:
790 case RECORD_SYS_CONNECT
:
791 case RECORD_SYS_LISTEN
:
793 case RECORD_SYS_ACCEPT
:
794 case RECORD_SYS_GETSOCKNAME
:
795 case RECORD_SYS_GETPEERNAME
:
797 regcache_raw_read_unsigned (regcache
, tdep
->arg2
,
801 gdb_byte
*a
= (gdb_byte
*) alloca (tdep
->size_ulong
* 2);
804 tmpulongest
+= tdep
->size_ulong
;
805 if (target_read_memory ((CORE_ADDR
) tmpulongest
, a
,
806 tdep
->size_ulong
* 2))
809 fprintf_unfiltered (gdb_stdlog
,
810 "Process record: error reading "
811 "memory at addr = 0x%s len = %d.\n",
812 OUTPUT_REG (tmpulongest
, tdep
->arg2
),
813 tdep
->size_ulong
* 2);
816 tmpulongest
= extract_unsigned_integer (a
,
819 len
= extract_unsigned_integer (a
+ tdep
->size_ulong
,
820 tdep
->size_ulong
, byte_order
);
821 if (record_linux_sockaddr (regcache
, tdep
, tmpulongest
, len
))
827 case RECORD_SYS_SOCKETPAIR
:
829 gdb_byte
*a
= (gdb_byte
*) alloca (tdep
->size_ulong
);
831 regcache_raw_read_unsigned (regcache
, tdep
->arg2
,
835 tmpulongest
+= tdep
->size_ulong
* 3;
836 if (target_read_memory ((CORE_ADDR
) tmpulongest
, a
,
840 fprintf_unfiltered (gdb_stdlog
,
841 "Process record: error reading "
842 "memory at addr = 0x%s len = %d.\n",
843 OUTPUT_REG (tmpulongest
, tdep
->arg2
),
848 = (CORE_ADDR
) extract_unsigned_integer (a
, tdep
->size_ulong
,
850 if (record_full_arch_list_add_mem (tmpaddr
, tdep
->size_int
))
855 case RECORD_SYS_SEND
:
856 case RECORD_SYS_SENDTO
:
858 case RECORD_SYS_RECVFROM
:
859 regcache_raw_read_unsigned (regcache
, tdep
->arg2
,
863 gdb_byte
*a
= (gdb_byte
*) alloca (tdep
->size_ulong
* 2);
866 tmpulongest
+= tdep
->size_ulong
* 4;
867 if (target_read_memory ((CORE_ADDR
) tmpulongest
, a
,
868 tdep
->size_ulong
* 2))
871 fprintf_unfiltered (gdb_stdlog
,
872 "Process record: error reading "
873 "memory at addr = 0x%s len = %d.\n",
874 OUTPUT_REG (tmpulongest
, tdep
->arg2
),
875 tdep
->size_ulong
* 2);
878 tmpulongest
= extract_unsigned_integer (a
, tdep
->size_ulong
,
880 len
= extract_unsigned_integer (a
+ tdep
->size_ulong
,
881 tdep
->size_ulong
, byte_order
);
882 if (record_linux_sockaddr (regcache
, tdep
, tmpulongest
, len
))
886 case RECORD_SYS_RECV
:
887 regcache_raw_read_unsigned (regcache
, tdep
->arg2
,
891 gdb_byte
*a
= (gdb_byte
*) alloca (tdep
->size_ulong
* 2);
893 tmpulongest
+= tdep
->size_ulong
;
894 if (target_read_memory ((CORE_ADDR
) tmpulongest
, a
,
898 fprintf_unfiltered (gdb_stdlog
,
899 "Process record: error reading "
900 "memory at addr = 0x%s len = %d.\n",
901 OUTPUT_REG (tmpulongest
, tdep
->arg2
),
905 tmpulongest
= extract_unsigned_integer (a
, tdep
->size_ulong
,
909 a
+= tdep
->size_ulong
;
910 tmpint
= (int) extract_unsigned_integer (a
, tdep
->size_ulong
,
912 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
918 case RECORD_SYS_SHUTDOWN
:
919 case RECORD_SYS_SETSOCKOPT
:
921 case RECORD_SYS_GETSOCKOPT
:
923 gdb_byte
*a
= (gdb_byte
*) alloca (tdep
->size_ulong
* 2);
924 gdb_byte
*av
= (gdb_byte
*) alloca (tdep
->size_int
);
926 regcache_raw_read_unsigned (regcache
, tdep
->arg2
,
930 tmpulongest
+= tdep
->size_ulong
* 3;
931 if (target_read_memory ((CORE_ADDR
) tmpulongest
, a
,
932 tdep
->size_ulong
* 2))
935 fprintf_unfiltered (gdb_stdlog
,
936 "Process record: error reading "
937 "memory at addr = 0x%s len = %d.\n",
938 OUTPUT_REG (tmpulongest
, tdep
->arg2
),
939 tdep
->size_ulong
* 2);
942 tmpulongest
= extract_unsigned_integer (a
+ tdep
->size_ulong
,
947 if (target_read_memory ((CORE_ADDR
) tmpulongest
, av
,
951 fprintf_unfiltered (gdb_stdlog
,
952 "Process record: error reading "
953 "memory at addr = 0x%s "
955 phex_nz (tmpulongest
,
961 = (CORE_ADDR
) extract_unsigned_integer (a
,
964 tmpint
= (int) extract_unsigned_integer (av
,
967 if (record_full_arch_list_add_mem (tmpaddr
, tmpint
))
969 a
+= tdep
->size_ulong
;
971 = (CORE_ADDR
) extract_unsigned_integer (a
,
974 if (record_full_arch_list_add_mem (tmpaddr
,
981 case RECORD_SYS_SENDMSG
:
983 case RECORD_SYS_RECVMSG
:
985 gdb_byte
*a
= (gdb_byte
*) alloca (tdep
->size_ulong
);
987 regcache_raw_read_unsigned (regcache
, tdep
->arg2
,
991 tmpulongest
+= tdep
->size_ulong
;
992 if (target_read_memory ((CORE_ADDR
) tmpulongest
, a
,
996 fprintf_unfiltered (gdb_stdlog
,
997 "Process record: error reading "
998 "memory at addr = 0x%s len = %d.\n",
999 OUTPUT_REG (tmpulongest
, tdep
->arg2
),
1003 tmpulongest
= extract_unsigned_integer (a
, tdep
->size_ulong
,
1005 if (record_linux_msghdr (regcache
, tdep
, tmpulongest
))
1011 printf_unfiltered (_("Process record and replay target "
1012 "doesn't support socketcall call 0x%s\n"),
1013 OUTPUT_REG (tmpulongest
, tdep
->arg1
));
1019 case gdb_sys_syslog
:
1022 case gdb_sys_setitimer
:
1023 if (record_mem_at_reg (regcache
, tdep
->arg3
, tdep
->size_itimerval
))
1027 case gdb_sys_getitimer
:
1028 if (record_mem_at_reg (regcache
, tdep
->arg2
, tdep
->size_itimerval
))
1032 case gdb_sys_newstat
:
1033 case gdb_sys_newlstat
:
1034 case gdb_sys_newfstat
:
1035 if (record_mem_at_reg (regcache
, tdep
->arg2
, tdep
->size_stat
))
1039 case gdb_sys_newfstatat
:
1040 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
1041 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1047 if (record_mem_at_reg (regcache
, tdep
->arg1
,
1048 tdep
->size_old_utsname
))
1053 case gdb_sys_vhangup
:
1054 case gdb_sys_ni_syscall112
:
1055 case gdb_sys_vm86old
:
1059 if (record_mem_at_reg (regcache
, tdep
->arg2
, tdep
->size_int
)
1060 || record_mem_at_reg (regcache
, tdep
->arg4
, tdep
->size_rusage
))
1064 case gdb_sys_swapoff
:
1067 case gdb_sys_sysinfo
:
1068 if (record_mem_at_reg (regcache
, tdep
->arg1
, tdep
->size_sysinfo
))
1072 case gdb_sys_shmget
:
1073 case gdb_sys_semget
:
1075 case gdb_sys_msgget
:
1076 /* XXX maybe need do some record works with sys_shmdt. */
1078 case gdb_sys_msgsnd
:
1079 case gdb_sys_semtimedop
:
1083 if (record_mem_at_reg (regcache
, tdep
->arg3
, tdep
->size_ulong
))
1087 case gdb_sys_shmctl
:
1088 if (record_mem_at_reg (regcache
, tdep
->arg3
, tdep
->size_shmid_ds
))
1092 /* XXX sys_semctl 525 still not supported. */
1095 case gdb_sys_msgrcv
:
1099 regcache_raw_read_signed (regcache
, tdep
->arg3
, &l
);
1100 tmpint
= l
+ tdep
->size_long
;
1101 if (record_mem_at_reg (regcache
, tdep
->arg2
, tmpint
))
1106 case gdb_sys_msgctl
:
1107 if (record_mem_at_reg (regcache
, tdep
->arg3
, tdep
->size_msqid_ds
))
1112 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
1113 tmpulongest
&= 0xffff;
1114 switch (tmpulongest
)
1118 case RECORD_SEMTIMEDOP
:
1121 /* XXX maybe need do some record works with RECORD_SHMDT. */
1129 regcache_raw_read_signed (regcache
, tdep
->arg3
, &second
);
1130 tmpint
= (int) second
+ tdep
->size_long
;
1131 if (record_mem_at_reg (regcache
, tdep
->arg5
, tmpint
))
1136 if (record_mem_at_reg (regcache
, tdep
->arg5
,
1137 tdep
->size_msqid_ds
))
1141 if (record_mem_at_reg (regcache
, tdep
->arg4
, tdep
->size_ulong
))
1145 if (record_mem_at_reg (regcache
, tdep
->arg5
,
1146 tdep
->size_shmid_ds
))
1150 /* XXX RECORD_SEMCTL still not supported. */
1151 printf_unfiltered (_("Process record and replay target doesn't "
1152 "support ipc number %s\n"),
1153 pulongest (tmpulongest
));
1159 case gdb_sys_sigreturn
:
1161 case gdb_sys_setdomainname
:
1164 case gdb_sys_newuname
:
1165 if (record_mem_at_reg (regcache
, tdep
->arg1
,
1166 tdep
->size_new_utsname
))
1170 case gdb_sys_modify_ldt
:
1171 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
1172 if (tmpulongest
== 0 || tmpulongest
== 2)
1176 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &bytecount
);
1177 if (record_mem_at_reg (regcache
, tdep
->arg2
, (int) bytecount
))
1182 case gdb_sys_adjtimex
:
1183 if (record_mem_at_reg (regcache
, tdep
->arg1
, tdep
->size_timex
))
1187 case gdb_sys_mprotect
:
1190 case gdb_sys_sigprocmask
:
1191 if (record_mem_at_reg (regcache
, tdep
->arg3
,
1192 tdep
->size_old_sigset_t
))
1196 case gdb_sys_ni_syscall127
:
1197 case gdb_sys_init_module
:
1198 case gdb_sys_delete_module
:
1199 case gdb_sys_ni_syscall130
:
1202 case gdb_sys_quotactl
:
1203 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
1204 switch (tmpulongest
)
1206 case RECORD_Q_GETFMT
:
1208 if (record_mem_at_reg (regcache
, tdep
->arg4
, 4))
1211 case RECORD_Q_GETINFO
:
1212 if (record_mem_at_reg (regcache
, tdep
->arg4
,
1213 tdep
->size_mem_dqinfo
))
1216 case RECORD_Q_GETQUOTA
:
1217 if (record_mem_at_reg (regcache
, tdep
->arg4
,
1218 tdep
->size_if_dqblk
))
1221 case RECORD_Q_XGETQSTAT
:
1222 case RECORD_Q_XGETQUOTA
:
1223 if (record_mem_at_reg (regcache
, tdep
->arg4
,
1224 tdep
->size_fs_quota_stat
))
1230 case gdb_sys_getpgid
:
1231 case gdb_sys_fchdir
:
1232 case gdb_sys_bdflush
:
1236 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
1237 if (tmpulongest
== 2)
1239 /*XXX the size of memory is not very clear. */
1240 if (record_mem_at_reg (regcache
, tdep
->arg3
, 10))
1245 case gdb_sys_personality
:
1246 case gdb_sys_ni_syscall137
:
1247 case gdb_sys_setfsuid16
:
1248 case gdb_sys_setfsgid16
:
1251 case gdb_sys_llseek
:
1252 if (record_mem_at_reg (regcache
, tdep
->arg4
, tdep
->size_loff_t
))
1256 case gdb_sys_getdents
:
1257 case gdb_sys_getdents64
:
1258 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
1259 if (record_mem_at_reg (regcache
, tdep
->arg2
, tmpulongest
))
1263 case gdb_sys_select
:
1264 if (record_mem_at_reg (regcache
, tdep
->arg2
, tdep
->size_fd_set
)
1265 || record_mem_at_reg (regcache
, tdep
->arg3
, tdep
->size_fd_set
)
1266 || record_mem_at_reg (regcache
, tdep
->arg4
, tdep
->size_fd_set
)
1267 || record_mem_at_reg (regcache
, tdep
->arg5
, tdep
->size_timeval
))
1279 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &vec
);
1282 gdb_byte
*iov
= (gdb_byte
*) alloca (tdep
->size_iovec
);
1284 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &vlen
);
1285 for (tmpulongest
= 0; tmpulongest
< vlen
; tmpulongest
++)
1287 if (target_read_memory ((CORE_ADDR
) vec
, iov
,
1291 fprintf_unfiltered (gdb_stdlog
,
1292 "Process record: error reading "
1293 "memory at addr = 0x%s len = %d.\n",
1294 OUTPUT_REG (vec
, tdep
->arg2
),
1299 = (CORE_ADDR
) extract_unsigned_integer (iov
,
1303 = (int) extract_unsigned_integer (iov
+ tdep
->size_pointer
,
1306 if (record_full_arch_list_add_mem (tmpaddr
, tmpint
))
1308 vec
+= tdep
->size_iovec
;
1314 case gdb_sys_writev
:
1315 case gdb_sys_getsid
:
1316 case gdb_sys_fdatasync
:
1317 case gdb_sys_sysctl
:
1319 case gdb_sys_munlock
:
1320 case gdb_sys_mlockall
:
1321 case gdb_sys_munlockall
:
1322 case gdb_sys_sched_setparam
:
1325 case gdb_sys_sched_getparam
:
1326 if (record_mem_at_reg (regcache
, tdep
->arg2
, tdep
->size_int
))
1330 case gdb_sys_sched_setscheduler
:
1331 case gdb_sys_sched_getscheduler
:
1332 case gdb_sys_sched_yield
:
1333 case gdb_sys_sched_get_priority_max
:
1334 case gdb_sys_sched_get_priority_min
:
1337 case gdb_sys_sched_rr_get_interval
:
1338 case gdb_sys_nanosleep
:
1339 if (record_mem_at_reg (regcache
, tdep
->arg2
, tdep
->size_timespec
))
1343 case gdb_sys_mremap
:
1344 case gdb_sys_setresuid16
:
1347 case gdb_sys_getresuid16
:
1348 if (record_mem_at_reg (regcache
, tdep
->arg1
, tdep
->size_old_uid_t
)
1349 || record_mem_at_reg (regcache
, tdep
->arg2
,
1350 tdep
->size_old_uid_t
)
1351 || record_mem_at_reg (regcache
, tdep
->arg3
,
1352 tdep
->size_old_uid_t
))
1357 case gdb_sys_ni_syscall167
:
1361 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
1366 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &nfds
);
1367 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1368 tdep
->size_pollfd
* nfds
))
1373 case gdb_sys_nfsservctl
:
1374 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
1375 if (tmpulongest
== 7 || tmpulongest
== 8)
1379 if (tmpulongest
== 7)
1380 rsize
= tdep
->size_NFS_FHSIZE
;
1382 rsize
= tdep
->size_knfsd_fh
;
1383 if (record_mem_at_reg (regcache
, tdep
->arg3
, rsize
))
1388 case gdb_sys_setresgid16
:
1391 case gdb_sys_getresgid16
:
1392 if (record_mem_at_reg (regcache
, tdep
->arg1
, tdep
->size_old_gid_t
)
1393 || record_mem_at_reg (regcache
, tdep
->arg2
,
1394 tdep
->size_old_gid_t
)
1395 || record_mem_at_reg (regcache
, tdep
->arg3
,
1396 tdep
->size_old_gid_t
))
1401 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
1402 switch (tmpulongest
)
1405 if (record_mem_at_reg (regcache
, tdep
->arg2
, tdep
->size_int
))
1409 if (record_mem_at_reg (regcache
, tdep
->arg2
,
1410 tdep
->size_TASK_COMM_LEN
))
1416 case gdb_sys_rt_sigreturn
:
1419 case gdb_sys_rt_sigaction
:
1420 if (record_mem_at_reg (regcache
, tdep
->arg3
, tdep
->size_sigaction
))
1424 case gdb_sys_rt_sigprocmask
:
1425 if (record_mem_at_reg (regcache
, tdep
->arg3
, tdep
->size_sigset_t
))
1429 case gdb_sys_rt_sigpending
:
1430 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
1433 ULONGEST sigsetsize
;
1435 regcache_raw_read_unsigned (regcache
, tdep
->arg2
,&sigsetsize
);
1436 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1442 case gdb_sys_rt_sigtimedwait
:
1443 if (record_mem_at_reg (regcache
, tdep
->arg2
, tdep
->size_siginfo_t
))
1447 case gdb_sys_rt_sigqueueinfo
:
1448 case gdb_sys_rt_sigsuspend
:
1451 case gdb_sys_pread64
:
1452 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
1457 regcache_raw_read_unsigned (regcache
, tdep
->arg3
,&count
);
1458 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1464 case gdb_sys_pwrite64
:
1465 case gdb_sys_chown16
:
1468 case gdb_sys_getcwd
:
1469 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
1474 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &size
);
1475 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1481 case gdb_sys_capget
:
1482 if (record_mem_at_reg (regcache
, tdep
->arg2
,
1483 tdep
->size_cap_user_data_t
))
1487 case gdb_sys_capset
:
1490 case gdb_sys_sigaltstack
:
1491 if (record_mem_at_reg (regcache
, tdep
->arg2
, tdep
->size_stack_t
))
1495 case gdb_sys_sendfile
:
1496 if (record_mem_at_reg (regcache
, tdep
->arg3
, tdep
->size_off_t
))
1500 case gdb_sys_ni_syscall188
:
1501 case gdb_sys_ni_syscall189
:
1505 case gdb_sys_getrlimit
:
1506 if (record_mem_at_reg (regcache
, tdep
->arg2
, tdep
->size_rlimit
))
1513 case gdb_sys_truncate64
:
1514 case gdb_sys_ftruncate64
:
1517 case gdb_sys_stat64
:
1518 case gdb_sys_lstat64
:
1519 case gdb_sys_fstat64
:
1520 if (record_mem_at_reg (regcache
, tdep
->arg2
, tdep
->size_stat64
))
1524 case gdb_sys_lchown
:
1525 case gdb_sys_getuid
:
1526 case gdb_sys_getgid
:
1527 case gdb_sys_geteuid
:
1528 case gdb_sys_getegid
:
1529 case gdb_sys_setreuid
:
1530 case gdb_sys_setregid
:
1533 case gdb_sys_getgroups
:
1534 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
1537 ULONGEST gidsetsize
;
1539 regcache_raw_read_unsigned (regcache
, tdep
->arg1
,
1541 tmpint
= tdep
->size_gid_t
* (int) gidsetsize
;
1542 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
, tmpint
))
1547 case gdb_sys_setgroups
:
1548 case gdb_sys_fchown
:
1549 case gdb_sys_setresuid
:
1552 case gdb_sys_getresuid
:
1553 if (record_mem_at_reg (regcache
, tdep
->arg1
, tdep
->size_uid_t
)
1554 || record_mem_at_reg (regcache
, tdep
->arg2
, tdep
->size_uid_t
)
1555 || record_mem_at_reg (regcache
, tdep
->arg3
, tdep
->size_uid_t
))
1559 case gdb_sys_setresgid
:
1562 case gdb_sys_getresgid
:
1563 if (record_mem_at_reg (regcache
, tdep
->arg1
, tdep
->size_gid_t
)
1564 || record_mem_at_reg (regcache
, tdep
->arg2
, tdep
->size_gid_t
)
1565 || record_mem_at_reg (regcache
, tdep
->arg3
, tdep
->size_gid_t
))
1570 case gdb_sys_setuid
:
1571 case gdb_sys_setgid
:
1572 case gdb_sys_setfsuid
:
1573 case gdb_sys_setfsgid
:
1574 case gdb_sys_pivot_root
:
1577 case gdb_sys_mincore
:
1578 if (record_mem_at_reg (regcache
, tdep
->arg3
, tdep
->size_PAGE_SIZE
))
1582 case gdb_sys_madvise
:
1585 case gdb_sys_fcntl64
:
1586 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
1587 if (tmpulongest
== tdep
->fcntl_F_GETLK64
)
1589 if (record_mem_at_reg (regcache
, tdep
->arg3
,
1590 tdep
->size_flock64
))
1593 else if (tmpulongest
!= tdep
->fcntl_F_SETLK64
1594 && tmpulongest
!= tdep
->fcntl_F_SETLKW64
)
1600 case gdb_sys_ni_syscall222
:
1601 case gdb_sys_ni_syscall223
:
1602 case gdb_sys_gettid
:
1603 case gdb_sys_readahead
:
1604 case gdb_sys_setxattr
:
1605 case gdb_sys_lsetxattr
:
1606 case gdb_sys_fsetxattr
:
1609 case gdb_sys_getxattr
:
1610 case gdb_sys_lgetxattr
:
1611 case gdb_sys_fgetxattr
:
1612 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
1617 regcache_raw_read_unsigned (regcache
, tdep
->arg4
, &size
);
1618 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1624 case gdb_sys_listxattr
:
1625 case gdb_sys_llistxattr
:
1626 case gdb_sys_flistxattr
:
1627 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
1632 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &size
);
1633 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1639 case gdb_sys_removexattr
:
1640 case gdb_sys_lremovexattr
:
1641 case gdb_sys_fremovexattr
:
1645 case gdb_sys_sendfile64
:
1646 if (record_mem_at_reg (regcache
, tdep
->arg3
, tdep
->size_loff_t
))
1651 case gdb_sys_sched_setaffinity
:
1654 case gdb_sys_sched_getaffinity
:
1655 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
1660 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &len
);
1661 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1667 case gdb_sys_set_thread_area
:
1668 if (record_mem_at_reg (regcache
, tdep
->arg1
, tdep
->size_int
))
1672 case gdb_sys_get_thread_area
:
1673 if (record_mem_at_reg (regcache
, tdep
->arg1
, tdep
->size_user_desc
))
1677 case gdb_sys_io_setup
:
1678 if (record_mem_at_reg (regcache
, tdep
->arg2
, tdep
->size_long
))
1682 case gdb_sys_io_destroy
:
1685 case gdb_sys_io_getevents
:
1686 regcache_raw_read_unsigned (regcache
, tdep
->arg4
, &tmpulongest
);
1691 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &nr
);
1692 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1693 nr
* tdep
->size_io_event
))
1698 case gdb_sys_io_submit
:
1699 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
1705 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &nr
);
1706 iocbp
= (gdb_byte
*) alloca (nr
* tdep
->size_pointer
);
1707 if (target_read_memory ((CORE_ADDR
) tmpulongest
, iocbp
,
1708 nr
* tdep
->size_pointer
))
1711 fprintf_unfiltered (gdb_stdlog
,
1712 "Process record: error reading memory "
1713 "at addr = 0x%s len = %u.\n",
1714 OUTPUT_REG (tmpulongest
, tdep
->arg2
),
1715 (int) (nr
* tdep
->size_pointer
));
1718 for (i
= 0; i
< nr
; i
++)
1721 = (CORE_ADDR
) extract_unsigned_integer (iocbp
,
1724 if (record_full_arch_list_add_mem (tmpaddr
, tdep
->size_iocb
))
1726 iocbp
+= tdep
->size_pointer
;
1731 case gdb_sys_io_cancel
:
1732 if (record_mem_at_reg (regcache
, tdep
->arg3
, tdep
->size_io_event
))
1736 case gdb_sys_fadvise64
:
1737 case gdb_sys_ni_syscall251
:
1740 case gdb_sys_exit_group
:
1741 if (yquery (_("The next instruction is syscall exit_group. "
1742 "It will make the program exit. "
1743 "Do you want to stop the program?")))
1747 case gdb_sys_lookup_dcookie
:
1748 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
1753 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &len
);
1754 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1760 case gdb_sys_epoll_create
:
1761 case gdb_sys_epoll_ctl
:
1764 case gdb_sys_epoll_wait
:
1765 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
1770 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &maxevents
);
1771 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1773 * tdep
->size_epoll_event
)))
1778 case gdb_sys_remap_file_pages
:
1779 case gdb_sys_set_tid_address
:
1782 case gdb_sys_timer_create
:
1783 if (record_mem_at_reg (regcache
, tdep
->arg3
, tdep
->size_int
))
1787 case gdb_sys_timer_settime
:
1788 if (record_mem_at_reg (regcache
, tdep
->arg4
, tdep
->size_itimerspec
))
1792 case gdb_sys_timer_gettime
:
1793 if (record_mem_at_reg (regcache
, tdep
->arg2
, tdep
->size_itimerspec
))
1797 case gdb_sys_timer_getoverrun
:
1798 case gdb_sys_timer_delete
:
1799 case gdb_sys_clock_settime
:
1802 case gdb_sys_clock_gettime
:
1803 if (record_mem_at_reg (regcache
, tdep
->arg2
, tdep
->size_timespec
))
1807 case gdb_sys_clock_getres
:
1808 if (record_mem_at_reg (regcache
, tdep
->arg2
, tdep
->size_timespec
))
1812 case gdb_sys_clock_nanosleep
:
1813 if (record_mem_at_reg (regcache
, tdep
->arg4
, tdep
->size_timespec
))
1817 case gdb_sys_statfs64
:
1818 case gdb_sys_fstatfs64
:
1819 if (record_mem_at_reg (regcache
, tdep
->arg3
, tdep
->size_statfs64
))
1823 case gdb_sys_tgkill
:
1824 case gdb_sys_utimes
:
1825 case gdb_sys_fadvise64_64
:
1826 case gdb_sys_ni_syscall273
:
1830 case gdb_sys_get_mempolicy
:
1831 if (record_mem_at_reg (regcache
, tdep
->arg1
, tdep
->size_int
))
1833 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
1838 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &maxnode
);
1839 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1840 maxnode
* tdep
->size_long
))
1845 case gdb_sys_set_mempolicy
:
1846 case gdb_sys_mq_open
:
1847 case gdb_sys_mq_unlink
:
1848 case gdb_sys_mq_timedsend
:
1851 case gdb_sys_mq_timedreceive
:
1852 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
1857 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &msg_len
);
1858 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1862 if (record_mem_at_reg (regcache
, tdep
->arg4
, tdep
->size_int
))
1866 case gdb_sys_mq_notify
:
1869 case gdb_sys_mq_getsetattr
:
1870 if (record_mem_at_reg (regcache
, tdep
->arg3
, tdep
->size_mq_attr
))
1874 case gdb_sys_kexec_load
:
1877 case gdb_sys_waitid
:
1878 if (record_mem_at_reg (regcache
, tdep
->arg3
, tdep
->size_siginfo_t
)
1879 || record_mem_at_reg (regcache
, tdep
->arg5
, tdep
->size_rusage
))
1883 case gdb_sys_ni_syscall285
:
1884 case gdb_sys_add_key
:
1885 case gdb_sys_request_key
:
1888 case gdb_sys_keyctl
:
1889 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
1890 if (tmpulongest
== 6 || tmpulongest
== 11)
1892 regcache_raw_read_unsigned (regcache
, tdep
->arg3
,
1898 regcache_raw_read_unsigned (regcache
, tdep
->arg4
, &buflen
);
1899 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1906 case gdb_sys_ioprio_set
:
1907 case gdb_sys_ioprio_get
:
1908 case gdb_sys_inotify_init
:
1909 case gdb_sys_inotify_add_watch
:
1910 case gdb_sys_inotify_rm_watch
:
1911 case gdb_sys_migrate_pages
:
1912 case gdb_sys_openat
:
1913 case gdb_sys_mkdirat
:
1914 case gdb_sys_mknodat
:
1915 case gdb_sys_fchownat
:
1916 case gdb_sys_futimesat
:
1919 case gdb_sys_fstatat64
:
1920 if (record_mem_at_reg (regcache
, tdep
->arg3
, tdep
->size_stat64
))
1924 case gdb_sys_unlinkat
:
1925 case gdb_sys_renameat
:
1926 case gdb_sys_linkat
:
1927 case gdb_sys_symlinkat
:
1930 case gdb_sys_readlinkat
:
1931 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
1936 regcache_raw_read_unsigned (regcache
, tdep
->arg4
, &bufsiz
);
1937 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1943 case gdb_sys_fchmodat
:
1944 case gdb_sys_faccessat
:
1947 case gdb_sys_pselect6
:
1948 if (record_mem_at_reg (regcache
, tdep
->arg2
, tdep
->size_fd_set
)
1949 || record_mem_at_reg (regcache
, tdep
->arg3
, tdep
->size_fd_set
)
1950 || record_mem_at_reg (regcache
, tdep
->arg4
, tdep
->size_fd_set
)
1951 || record_mem_at_reg (regcache
, tdep
->arg5
, tdep
->size_timespec
))
1956 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
1961 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &nfds
);
1962 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1963 tdep
->size_pollfd
* nfds
))
1966 if (record_mem_at_reg (regcache
, tdep
->arg3
, tdep
->size_timespec
))
1970 case gdb_sys_unshare
:
1971 case gdb_sys_set_robust_list
:
1974 case gdb_sys_get_robust_list
:
1975 if (record_mem_at_reg (regcache
, tdep
->arg2
, tdep
->size_int
)
1976 || record_mem_at_reg (regcache
, tdep
->arg3
, tdep
->size_int
))
1980 case gdb_sys_splice
:
1981 if (record_mem_at_reg (regcache
, tdep
->arg2
, tdep
->size_loff_t
)
1982 || record_mem_at_reg (regcache
, tdep
->arg4
, tdep
->size_loff_t
))
1986 case gdb_sys_sync_file_range
:
1988 case gdb_sys_vmsplice
:
1991 case gdb_sys_move_pages
:
1992 regcache_raw_read_unsigned (regcache
, tdep
->arg5
, &tmpulongest
);
1997 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &nr_pages
);
1998 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1999 nr_pages
* tdep
->size_int
))
2004 case gdb_sys_getcpu
:
2005 if (record_mem_at_reg (regcache
, tdep
->arg1
, tdep
->size_int
)
2006 || record_mem_at_reg (regcache
, tdep
->arg2
, tdep
->size_int
)
2007 || record_mem_at_reg (regcache
, tdep
->arg3
,
2008 tdep
->size_ulong
* 2))
2012 case gdb_sys_epoll_pwait
:
2013 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
2018 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &maxevents
);
2019 tmpint
= (int) maxevents
* tdep
->size_epoll_event
;
2020 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
, tmpint
))
2025 case gdb_sys_fallocate
:
2026 case gdb_sys_eventfd2
:
2027 case gdb_sys_epoll_create1
:
2031 case gdb_sys_inotify_init1
:
2035 printf_unfiltered (_("Process record and replay target doesn't "
2036 "support syscall number %d\n"), syscall
);