1 /* Process record and replay target code for GNU/Linux.
3 Copyright (C) 2008-2015 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"
28 /* These macros are the values of the first argument of system call
29 "sys_ptrace". The values of these macros were obtained from Linux
32 #define RECORD_PTRACE_PEEKTEXT 1
33 #define RECORD_PTRACE_PEEKDATA 2
34 #define RECORD_PTRACE_PEEKUSR 3
36 /* These macros are the values of the first argument of system call
37 "sys_socketcall". The values of these macros were obtained from
38 Linux Kernel source. */
40 #define RECORD_SYS_SOCKET 1
41 #define RECORD_SYS_BIND 2
42 #define RECORD_SYS_CONNECT 3
43 #define RECORD_SYS_LISTEN 4
44 #define RECORD_SYS_ACCEPT 5
45 #define RECORD_SYS_GETSOCKNAME 6
46 #define RECORD_SYS_GETPEERNAME 7
47 #define RECORD_SYS_SOCKETPAIR 8
48 #define RECORD_SYS_SEND 9
49 #define RECORD_SYS_RECV 10
50 #define RECORD_SYS_SENDTO 11
51 #define RECORD_SYS_RECVFROM 12
52 #define RECORD_SYS_SHUTDOWN 13
53 #define RECORD_SYS_SETSOCKOPT 14
54 #define RECORD_SYS_GETSOCKOPT 15
55 #define RECORD_SYS_SENDMSG 16
56 #define RECORD_SYS_RECVMSG 17
58 /* These macros are the values of the first argument of system call
59 "sys_ipc". The values of these macros were obtained from Linux
62 #define RECORD_SEMOP 1
63 #define RECORD_SEMGET 2
64 #define RECORD_SEMCTL 3
65 #define RECORD_SEMTIMEDOP 4
66 #define RECORD_MSGSND 11
67 #define RECORD_MSGRCV 12
68 #define RECORD_MSGGET 13
69 #define RECORD_MSGCTL 14
70 #define RECORD_SHMAT 21
71 #define RECORD_SHMDT 22
72 #define RECORD_SHMGET 23
73 #define RECORD_SHMCTL 24
75 /* These macros are the values of the first argument of system call
76 "sys_quotactl". The values of these macros were obtained from Linux
79 #define RECORD_Q_GETFMT 0x800004
80 #define RECORD_Q_GETINFO 0x800005
81 #define RECORD_Q_GETQUOTA 0x800007
82 #define RECORD_Q_XGETQSTAT (('5' << 8) + 5)
83 #define RECORD_Q_XGETQUOTA (('3' << 8) + 3)
85 #define OUTPUT_REG(val, num) phex_nz ((val), \
86 TYPE_LENGTH (gdbarch_register_type (get_regcache_arch (regcache), (num))))
89 record_linux_sockaddr (struct regcache
*regcache
,
90 struct linux_record_tdep
*tdep
, ULONGEST addr
,
95 struct gdbarch
*gdbarch
= get_regcache_arch (regcache
);
96 enum bfd_endian byte_order
= gdbarch_byte_order (gdbarch
);
101 a
= (gdb_byte
*) alloca (tdep
->size_int
);
103 if (record_full_arch_list_add_mem ((CORE_ADDR
) len
, tdep
->size_int
))
106 /* Get the addrlen. */
107 if (target_read_memory ((CORE_ADDR
) len
, a
, tdep
->size_int
))
110 fprintf_unfiltered (gdb_stdlog
,
111 "Process record: error reading "
112 "memory at addr = 0x%s len = %d.\n",
113 phex_nz (len
, tdep
->size_pointer
),
117 addrlen
= (int) extract_unsigned_integer (a
, tdep
->size_int
, byte_order
);
118 if (addrlen
<= 0 || addrlen
> tdep
->size_sockaddr
)
119 addrlen
= tdep
->size_sockaddr
;
121 if (record_full_arch_list_add_mem ((CORE_ADDR
) addr
, addrlen
))
128 record_linux_msghdr (struct regcache
*regcache
,
129 struct linux_record_tdep
*tdep
, ULONGEST addr
)
132 struct gdbarch
*gdbarch
= get_regcache_arch (regcache
);
133 enum bfd_endian byte_order
= gdbarch_byte_order (gdbarch
);
140 if (record_full_arch_list_add_mem ((CORE_ADDR
) addr
, tdep
->size_msghdr
))
143 a
= (gdb_byte
*) alloca (tdep
->size_msghdr
);
144 if (target_read_memory ((CORE_ADDR
) addr
, a
, tdep
->size_msghdr
))
147 fprintf_unfiltered (gdb_stdlog
,
148 "Process record: error reading "
149 "memory at addr = 0x%s "
151 phex_nz (addr
, tdep
->size_pointer
),
156 /* msg_name msg_namelen */
157 addr
= extract_unsigned_integer (a
, tdep
->size_pointer
, byte_order
);
158 a
+= tdep
->size_pointer
;
159 if (record_full_arch_list_add_mem
161 (int) extract_unsigned_integer (a
,
165 /* We have read an int, but skip size_pointer bytes to account for alignment
166 of the next field on 64-bit targets. */
167 a
+= tdep
->size_pointer
;
169 /* msg_iov msg_iovlen */
170 addr
= extract_unsigned_integer (a
, tdep
->size_pointer
, byte_order
);
171 a
+= tdep
->size_pointer
;
175 ULONGEST len
= extract_unsigned_integer (a
, tdep
->size_size_t
,
177 gdb_byte
*iov
= (gdb_byte
*) alloca (tdep
->size_iovec
);
179 for (i
= 0; i
< len
; i
++)
181 if (target_read_memory ((CORE_ADDR
) addr
, iov
, tdep
->size_iovec
))
184 fprintf_unfiltered (gdb_stdlog
,
185 "Process record: error "
189 phex_nz (addr
,tdep
->size_pointer
),
193 tmpaddr
= (CORE_ADDR
) extract_unsigned_integer (iov
,
196 tmpint
= (int) extract_unsigned_integer (iov
+ tdep
->size_pointer
,
199 if (record_full_arch_list_add_mem (tmpaddr
, tmpint
))
201 addr
+= tdep
->size_iovec
;
204 a
+= tdep
->size_size_t
;
206 /* msg_control msg_controllen */
207 addr
= extract_unsigned_integer (a
, tdep
->size_pointer
, byte_order
);
208 a
+= tdep
->size_pointer
;
209 tmpint
= (int) extract_unsigned_integer (a
, tdep
->size_size_t
, byte_order
);
210 if (record_full_arch_list_add_mem ((CORE_ADDR
) addr
, tmpint
))
216 /* When the architecture process record get a Linux syscall
217 instruction, it will get a Linux syscall number of this
218 architecture and convert it to the Linux syscall number "num" which
219 is internal to GDB. Most Linux syscalls across architectures in
220 Linux would be similar and mostly differ by sizes of types and
221 structures. This sizes are put to "tdep".
223 Record the values of the registers and memory that will be changed
224 in current system call.
226 Return -1 if something wrong. */
229 record_linux_system_call (enum gdb_syscall syscall
,
230 struct regcache
*regcache
,
231 struct linux_record_tdep
*tdep
)
233 struct gdbarch
*gdbarch
= get_regcache_arch (regcache
);
234 enum bfd_endian byte_order
= gdbarch_byte_order (gdbarch
);
235 ULONGEST tmpulongest
;
241 case gdb_sys_restart_syscall
:
248 target_terminal_ours ();
249 q
= yquery (_("The next instruction is syscall exit. "
250 "It will make the program exit. "
251 "Do you want to stop the program?"));
252 target_terminal_inferior ();
263 ULONGEST addr
, count
;
265 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &addr
);
266 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &count
);
267 if (record_full_arch_list_add_mem ((CORE_ADDR
) addr
, (int) count
))
277 case gdb_sys_waitpid
:
278 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
280 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
293 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
295 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
302 case gdb_sys_lchown16
:
303 case gdb_sys_ni_syscall17
:
309 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
310 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
311 tdep
->size__old_kernel_stat
))
318 case gdb_sys_oldumount
:
319 case gdb_sys_setuid16
:
320 case gdb_sys_getuid16
:
325 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
326 if (tmpulongest
== RECORD_PTRACE_PEEKTEXT
327 || tmpulongest
== RECORD_PTRACE_PEEKDATA
328 || tmpulongest
== RECORD_PTRACE_PEEKUSR
)
330 regcache_raw_read_unsigned (regcache
, tdep
->arg4
,
332 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
, 4))
340 case gdb_sys_ni_syscall31
:
341 case gdb_sys_ni_syscall32
:
344 case gdb_sys_ni_syscall35
:
354 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
355 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
360 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
361 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
366 case gdb_sys_ni_syscall44
:
368 case gdb_sys_setgid16
:
369 case gdb_sys_getgid16
:
371 case gdb_sys_geteuid16
:
372 case gdb_sys_getegid16
:
375 case gdb_sys_ni_syscall53
:
379 /* XXX Need to add a lot of support of other ioctl requests. */
380 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
381 if (tmpulongest
== tdep
->ioctl_FIOCLEX
382 || tmpulongest
== tdep
->ioctl_FIONCLEX
383 || tmpulongest
== tdep
->ioctl_FIONBIO
384 || tmpulongest
== tdep
->ioctl_FIOASYNC
385 || tmpulongest
== tdep
->ioctl_TCSETS
386 || tmpulongest
== tdep
->ioctl_TCSETSW
387 || tmpulongest
== tdep
->ioctl_TCSETSF
388 || tmpulongest
== tdep
->ioctl_TCSETA
389 || tmpulongest
== tdep
->ioctl_TCSETAW
390 || tmpulongest
== tdep
->ioctl_TCSETAF
391 || tmpulongest
== tdep
->ioctl_TCSBRK
392 || tmpulongest
== tdep
->ioctl_TCXONC
393 || tmpulongest
== tdep
->ioctl_TCFLSH
394 || tmpulongest
== tdep
->ioctl_TIOCEXCL
395 || tmpulongest
== tdep
->ioctl_TIOCNXCL
396 || tmpulongest
== tdep
->ioctl_TIOCSCTTY
397 || tmpulongest
== tdep
->ioctl_TIOCSPGRP
398 || tmpulongest
== tdep
->ioctl_TIOCSTI
399 || tmpulongest
== tdep
->ioctl_TIOCSWINSZ
400 || tmpulongest
== tdep
->ioctl_TIOCMBIS
401 || tmpulongest
== tdep
->ioctl_TIOCMBIC
402 || tmpulongest
== tdep
->ioctl_TIOCMSET
403 || tmpulongest
== tdep
->ioctl_TIOCSSOFTCAR
404 || tmpulongest
== tdep
->ioctl_TIOCCONS
405 || tmpulongest
== tdep
->ioctl_TIOCSSERIAL
406 || tmpulongest
== tdep
->ioctl_TIOCPKT
407 || tmpulongest
== tdep
->ioctl_TIOCNOTTY
408 || tmpulongest
== tdep
->ioctl_TIOCSETD
409 || tmpulongest
== tdep
->ioctl_TCSBRKP
410 || tmpulongest
== tdep
->ioctl_TIOCTTYGSTRUCT
411 || tmpulongest
== tdep
->ioctl_TIOCSBRK
412 || tmpulongest
== tdep
->ioctl_TIOCCBRK
413 || tmpulongest
== tdep
->ioctl_TCSETS2
414 || tmpulongest
== tdep
->ioctl_TCSETSW2
415 || tmpulongest
== tdep
->ioctl_TCSETSF2
416 || tmpulongest
== tdep
->ioctl_TIOCSPTLCK
417 || tmpulongest
== tdep
->ioctl_TIOCSERCONFIG
418 || tmpulongest
== tdep
->ioctl_TIOCSERGWILD
419 || tmpulongest
== tdep
->ioctl_TIOCSERSWILD
420 || tmpulongest
== tdep
->ioctl_TIOCSLCKTRMIOS
421 || tmpulongest
== tdep
->ioctl_TIOCSERGETMULTI
422 || tmpulongest
== tdep
->ioctl_TIOCSERSETMULTI
423 || tmpulongest
== tdep
->ioctl_TIOCMIWAIT
424 || tmpulongest
== tdep
->ioctl_TIOCSHAYESESP
)
428 else if (tmpulongest
== tdep
->ioctl_TCGETS
429 || tmpulongest
== tdep
->ioctl_TCGETA
430 || tmpulongest
== tdep
->ioctl_TIOCGLCKTRMIOS
)
432 regcache_raw_read_unsigned (regcache
, tdep
->arg3
,
434 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
438 else if (tmpulongest
== tdep
->ioctl_TIOCGPGRP
439 || tmpulongest
== tdep
->ioctl_TIOCGSID
)
441 regcache_raw_read_unsigned (regcache
, tdep
->arg3
,
443 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
447 else if (tmpulongest
== tdep
->ioctl_TIOCOUTQ
448 || tmpulongest
== tdep
->ioctl_TIOCMGET
449 || tmpulongest
== tdep
->ioctl_TIOCGSOFTCAR
450 || tmpulongest
== tdep
->ioctl_FIONREAD
451 || tmpulongest
== tdep
->ioctl_TIOCINQ
452 || tmpulongest
== tdep
->ioctl_TIOCGETD
453 || tmpulongest
== tdep
->ioctl_TIOCGPTN
454 || tmpulongest
== tdep
->ioctl_TIOCSERGETLSR
)
456 regcache_raw_read_unsigned (regcache
, tdep
->arg3
,
458 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
462 else if (tmpulongest
== tdep
->ioctl_TIOCGWINSZ
)
464 regcache_raw_read_unsigned (regcache
, tdep
->arg3
,
466 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
470 else if (tmpulongest
== tdep
->ioctl_TIOCLINUX
)
472 regcache_raw_read_unsigned (regcache
, tdep
->arg3
,
474 /* This syscall affects a char-size memory. */
475 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
, 1))
478 else if (tmpulongest
== tdep
->ioctl_TIOCGSERIAL
)
480 regcache_raw_read_unsigned (regcache
, tdep
->arg3
,
482 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
483 tdep
->size_serial_struct
))
486 else if (tmpulongest
== tdep
->ioctl_TCGETS2
)
488 regcache_raw_read_unsigned (regcache
, tdep
->arg3
,
490 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
491 tdep
->size_termios2
))
494 else if (tmpulongest
== tdep
->ioctl_FIOQSIZE
)
496 regcache_raw_read_unsigned (regcache
, tdep
->arg3
,
498 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
502 else if (tmpulongest
== tdep
->ioctl_TIOCGICOUNT
)
504 regcache_raw_read_unsigned (regcache
, tdep
->arg3
,
506 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
507 tdep
->size_serial_icounter_struct
))
510 else if (tmpulongest
== tdep
->ioctl_TIOCGHAYESESP
)
512 regcache_raw_read_unsigned (regcache
, tdep
->arg3
,
514 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
515 tdep
->size_hayes_esp_config
))
518 else if (tmpulongest
== tdep
->ioctl_TIOCSERGSTRUCT
)
520 printf_unfiltered (_("Process record and replay target doesn't "
521 "support ioctl request TIOCSERGSTRUCT\n"));
526 printf_unfiltered (_("Process record and replay target doesn't "
527 "support ioctl request 0x%s.\n"),
528 OUTPUT_REG (tmpulongest
, tdep
->arg2
));
535 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
537 if (tmpulongest
== tdep
->fcntl_F_GETLK
)
539 regcache_raw_read_unsigned (regcache
, tdep
->arg3
,
541 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
547 case gdb_sys_ni_syscall56
:
548 case gdb_sys_setpgid
:
549 case gdb_sys_ni_syscall58
:
552 case gdb_sys_olduname
:
553 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
554 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
555 tdep
->size_oldold_utsname
))
564 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
565 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
571 case gdb_sys_getppid
:
572 case gdb_sys_getpgrp
:
576 case gdb_sys_sigaction
:
577 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
578 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
579 tdep
->size_old_sigaction
))
583 case gdb_sys_sgetmask
:
584 case gdb_sys_ssetmask
:
585 case gdb_sys_setreuid16
:
586 case gdb_sys_setregid16
:
587 case gdb_sys_sigsuspend
:
590 case gdb_sys_sigpending
:
591 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
592 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
593 tdep
->size_old_sigset_t
))
597 case gdb_sys_sethostname
:
598 case gdb_sys_setrlimit
:
601 case gdb_sys_old_getrlimit
:
602 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
603 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
608 case gdb_sys_getrusage
:
609 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
610 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
615 case gdb_sys_gettimeofday
:
616 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
617 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
620 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
621 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
622 tdep
->size_timezone
))
626 case gdb_sys_settimeofday
:
629 case gdb_sys_getgroups16
:
630 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
631 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
632 tdep
->size_old_gid_t
))
636 case gdb_sys_setgroups16
:
637 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
638 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
639 tdep
->size_old_gid_t
))
645 struct sel_arg_struct
654 regcache_raw_read_unsigned (regcache
, tdep
->arg1
,
658 if (target_read_memory (tmpulongest
, (gdb_byte
*) &sel
,
662 fprintf_unfiltered (gdb_stdlog
,
663 "Process record: error reading memory "
664 "at addr = 0x%s len = %lu.\n",
665 OUTPUT_REG (tmpulongest
, tdep
->arg1
),
666 (unsigned long) sizeof (sel
));
669 if (record_full_arch_list_add_mem (sel
.inp
, tdep
->size_fd_set
))
671 if (record_full_arch_list_add_mem (sel
.outp
, tdep
->size_fd_set
))
673 if (record_full_arch_list_add_mem (sel
.exp
, tdep
->size_fd_set
))
675 if (record_full_arch_list_add_mem (sel
.tvp
, tdep
->size_timeval
))
681 case gdb_sys_symlink
:
684 case gdb_sys_readlink
:
688 regcache_raw_read_unsigned (regcache
, tdep
->arg2
,
690 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &len
);
691 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
, (int) len
))
704 target_terminal_ours ();
705 q
= yquery (_("The next instruction is syscall reboot. "
706 "It will restart the computer. "
707 "Do you want to stop the program?"));
708 target_terminal_inferior ();
714 case gdb_old_readdir
:
715 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
716 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
717 tdep
->size_old_dirent
))
728 regcache_raw_read_unsigned (regcache
, tdep
->arg1
,
730 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &len
);
731 if (record_full_memory_query
)
735 target_terminal_ours ();
737 The next instruction is syscall munmap.\n\
738 It will free the memory addr = 0x%s len = %u.\n\
739 It will make record target cannot record some memory change.\n\
740 Do you want to stop the program?"),
741 OUTPUT_REG (tmpulongest
, tdep
->arg1
), (int) len
);
742 target_terminal_inferior ();
749 case gdb_sys_truncate
:
750 case gdb_sys_ftruncate
:
752 case gdb_sys_fchown16
:
753 case gdb_sys_getpriority
:
754 case gdb_sys_setpriority
:
755 case gdb_sys_ni_syscall98
:
759 case gdb_sys_fstatfs
:
760 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
761 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
771 case gdb_sys_sendmsg
:
772 case gdb_sys_shutdown
:
774 case gdb_sys_connect
:
776 case gdb_sys_setsockopt
:
780 case gdb_sys_getsockname
:
781 case gdb_sys_getpeername
:
785 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
786 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &len
);
787 if (record_linux_sockaddr (regcache
, tdep
, tmpulongest
, len
))
792 case gdb_sys_recvfrom
:
796 regcache_raw_read_unsigned (regcache
, tdep
->arg4
, &tmpulongest
);
797 regcache_raw_read_unsigned (regcache
, tdep
->arg5
, &len
);
798 if (record_linux_sockaddr (regcache
, tdep
, tmpulongest
, len
))
807 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
808 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &size
);
809 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
815 case gdb_sys_recvmsg
:
816 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
817 if (record_linux_msghdr (regcache
, tdep
, tmpulongest
))
821 case gdb_sys_socketpair
:
822 regcache_raw_read_unsigned (regcache
, tdep
->arg4
, &tmpulongest
);
823 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
828 case gdb_sys_getsockopt
:
829 regcache_raw_read_unsigned (regcache
, tdep
->arg5
, &tmpulongest
);
833 gdb_byte
*optlenp
= (gdb_byte
*) alloca (tdep
->size_int
);
835 if (target_read_memory ((CORE_ADDR
) tmpulongest
, optlenp
,
839 fprintf_unfiltered (gdb_stdlog
,
840 "Process record: error reading "
841 "memory at addr = 0x%s "
843 OUTPUT_REG (tmpulongest
, tdep
->arg5
),
847 regcache_raw_read_unsigned (regcache
, tdep
->arg4
, &optvalp
);
848 tmpint
= (int) extract_signed_integer (optlenp
, tdep
->size_int
,
850 if (record_full_arch_list_add_mem ((CORE_ADDR
) optvalp
, tmpint
))
852 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
858 case gdb_sys_socketcall
:
859 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
862 case RECORD_SYS_SOCKET
:
863 case RECORD_SYS_BIND
:
864 case RECORD_SYS_CONNECT
:
865 case RECORD_SYS_LISTEN
:
867 case RECORD_SYS_ACCEPT
:
868 case RECORD_SYS_GETSOCKNAME
:
869 case RECORD_SYS_GETPEERNAME
:
871 regcache_raw_read_unsigned (regcache
, tdep
->arg2
,
875 gdb_byte
*a
= (gdb_byte
*) alloca (tdep
->size_ulong
* 2);
878 tmpulongest
+= tdep
->size_ulong
;
879 if (target_read_memory ((CORE_ADDR
) tmpulongest
, a
,
880 tdep
->size_ulong
* 2))
883 fprintf_unfiltered (gdb_stdlog
,
884 "Process record: error reading "
885 "memory at addr = 0x%s len = %d.\n",
886 OUTPUT_REG (tmpulongest
, tdep
->arg2
),
887 tdep
->size_ulong
* 2);
890 tmpulongest
= extract_unsigned_integer (a
,
893 len
= extract_unsigned_integer (a
+ tdep
->size_ulong
,
894 tdep
->size_ulong
, byte_order
);
895 if (record_linux_sockaddr (regcache
, tdep
, tmpulongest
, len
))
901 case RECORD_SYS_SOCKETPAIR
:
903 gdb_byte
*a
= (gdb_byte
*) alloca (tdep
->size_ulong
);
905 regcache_raw_read_unsigned (regcache
, tdep
->arg2
,
909 tmpulongest
+= tdep
->size_ulong
* 3;
910 if (target_read_memory ((CORE_ADDR
) tmpulongest
, a
,
914 fprintf_unfiltered (gdb_stdlog
,
915 "Process record: error reading "
916 "memory at addr = 0x%s len = %d.\n",
917 OUTPUT_REG (tmpulongest
, tdep
->arg2
),
922 = (CORE_ADDR
) extract_unsigned_integer (a
, tdep
->size_ulong
,
924 if (record_full_arch_list_add_mem (tmpaddr
, tdep
->size_int
))
929 case RECORD_SYS_SEND
:
930 case RECORD_SYS_SENDTO
:
932 case RECORD_SYS_RECVFROM
:
933 regcache_raw_read_unsigned (regcache
, tdep
->arg2
,
937 gdb_byte
*a
= (gdb_byte
*) alloca (tdep
->size_ulong
* 2);
940 tmpulongest
+= tdep
->size_ulong
* 4;
941 if (target_read_memory ((CORE_ADDR
) tmpulongest
, a
,
942 tdep
->size_ulong
* 2))
945 fprintf_unfiltered (gdb_stdlog
,
946 "Process record: error reading "
947 "memory at addr = 0x%s len = %d.\n",
948 OUTPUT_REG (tmpulongest
, tdep
->arg2
),
949 tdep
->size_ulong
* 2);
952 tmpulongest
= extract_unsigned_integer (a
, tdep
->size_ulong
,
954 len
= extract_unsigned_integer (a
+ tdep
->size_ulong
,
955 tdep
->size_ulong
, byte_order
);
956 if (record_linux_sockaddr (regcache
, tdep
, tmpulongest
, len
))
959 case RECORD_SYS_RECV
:
960 regcache_raw_read_unsigned (regcache
, tdep
->arg2
,
964 gdb_byte
*a
= (gdb_byte
*) alloca (tdep
->size_ulong
* 2);
966 tmpulongest
+= tdep
->size_ulong
;
967 if (target_read_memory ((CORE_ADDR
) tmpulongest
, a
,
971 fprintf_unfiltered (gdb_stdlog
,
972 "Process record: error reading "
973 "memory at addr = 0x%s len = %d.\n",
974 OUTPUT_REG (tmpulongest
, tdep
->arg2
),
978 tmpulongest
= extract_unsigned_integer (a
, tdep
->size_ulong
,
982 a
+= tdep
->size_ulong
;
983 tmpint
= (int) extract_unsigned_integer (a
, tdep
->size_ulong
,
985 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
991 case RECORD_SYS_SHUTDOWN
:
992 case RECORD_SYS_SETSOCKOPT
:
994 case RECORD_SYS_GETSOCKOPT
:
996 gdb_byte
*a
= (gdb_byte
*) alloca (tdep
->size_ulong
* 2);
997 gdb_byte
*av
= (gdb_byte
*) alloca (tdep
->size_int
);
999 regcache_raw_read_unsigned (regcache
, tdep
->arg2
,
1003 tmpulongest
+= tdep
->size_ulong
* 3;
1004 if (target_read_memory ((CORE_ADDR
) tmpulongest
, a
,
1005 tdep
->size_ulong
* 2))
1008 fprintf_unfiltered (gdb_stdlog
,
1009 "Process record: error reading "
1010 "memory at addr = 0x%s len = %d.\n",
1011 OUTPUT_REG (tmpulongest
, tdep
->arg2
),
1012 tdep
->size_ulong
* 2);
1015 tmpulongest
= extract_unsigned_integer (a
+ tdep
->size_ulong
,
1020 if (target_read_memory ((CORE_ADDR
) tmpulongest
, av
,
1024 fprintf_unfiltered (gdb_stdlog
,
1025 "Process record: error reading "
1026 "memory at addr = 0x%s "
1028 phex_nz (tmpulongest
,
1034 = (CORE_ADDR
) extract_unsigned_integer (a
,
1037 tmpint
= (int) extract_unsigned_integer (av
,
1040 if (record_full_arch_list_add_mem (tmpaddr
, tmpint
))
1042 a
+= tdep
->size_ulong
;
1044 = (CORE_ADDR
) extract_unsigned_integer (a
,
1047 if (record_full_arch_list_add_mem (tmpaddr
,
1054 case RECORD_SYS_SENDMSG
:
1056 case RECORD_SYS_RECVMSG
:
1058 gdb_byte
*a
= (gdb_byte
*) alloca (tdep
->size_ulong
);
1060 regcache_raw_read_unsigned (regcache
, tdep
->arg2
,
1064 tmpulongest
+= tdep
->size_ulong
;
1065 if (target_read_memory ((CORE_ADDR
) tmpulongest
, a
,
1069 fprintf_unfiltered (gdb_stdlog
,
1070 "Process record: error reading "
1071 "memory at addr = 0x%s len = %d.\n",
1072 OUTPUT_REG (tmpulongest
, tdep
->arg2
),
1076 tmpulongest
= extract_unsigned_integer (a
, tdep
->size_ulong
,
1078 if (record_linux_msghdr (regcache
, tdep
, tmpulongest
))
1084 printf_unfiltered (_("Process record and replay target "
1085 "doesn't support socketcall call 0x%s\n"),
1086 OUTPUT_REG (tmpulongest
, tdep
->arg1
));
1092 case gdb_sys_syslog
:
1095 case gdb_sys_setitimer
:
1096 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
1097 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1098 tdep
->size_itimerval
))
1102 case gdb_sys_getitimer
:
1103 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
1104 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1105 tdep
->size_itimerval
))
1109 case gdb_sys_newstat
:
1110 case gdb_sys_newlstat
:
1111 case gdb_sys_newfstat
:
1112 case gdb_sys_newfstatat
:
1113 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
1114 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1120 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
1121 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1122 tdep
->size_old_utsname
))
1127 case gdb_sys_vhangup
:
1128 case gdb_sys_ni_syscall112
:
1129 case gdb_sys_vm86old
:
1133 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
1134 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1137 regcache_raw_read_unsigned (regcache
, tdep
->arg4
, &tmpulongest
);
1138 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1143 case gdb_sys_swapoff
:
1146 case gdb_sys_sysinfo
:
1147 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
1148 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1149 tdep
->size_sysinfo
))
1153 case gdb_sys_shmget
:
1154 case gdb_sys_semget
:
1156 case gdb_sys_msgget
:
1157 /* XXX maybe need do some record works with sys_shmdt. */
1159 case gdb_sys_msgsnd
:
1160 case gdb_sys_semtimedop
:
1164 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
1165 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1170 case gdb_sys_shmctl
:
1171 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
1172 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1173 tdep
->size_shmid_ds
))
1177 /* XXX sys_semctl 525 still not supported. */
1180 case gdb_sys_msgrcv
:
1185 regcache_raw_read_signed (regcache
, tdep
->arg3
, &l
);
1186 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &msgp
);
1187 tmpint
= l
+ tdep
->size_long
;
1188 if (record_full_arch_list_add_mem ((CORE_ADDR
) msgp
, tmpint
))
1193 case gdb_sys_msgctl
:
1194 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
1195 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1196 tdep
->size_msqid_ds
))
1201 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
1202 tmpulongest
&= 0xffff;
1203 switch (tmpulongest
)
1207 case RECORD_SEMTIMEDOP
:
1210 /* XXX maybe need do some record works with RECORD_SHMDT. */
1219 regcache_raw_read_signed (regcache
, tdep
->arg3
, &second
);
1220 regcache_raw_read_unsigned (regcache
, tdep
->arg5
, &ptr
);
1221 tmpint
= (int) second
+ tdep
->size_long
;
1222 if (record_full_arch_list_add_mem ((CORE_ADDR
) ptr
, tmpint
))
1227 regcache_raw_read_unsigned (regcache
, tdep
->arg5
,
1229 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1230 tdep
->size_msqid_ds
))
1234 regcache_raw_read_unsigned (regcache
, tdep
->arg4
,
1236 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1241 regcache_raw_read_unsigned (regcache
, tdep
->arg5
,
1243 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1244 tdep
->size_shmid_ds
))
1248 /* XXX RECORD_SEMCTL still not supported. */
1249 printf_unfiltered (_("Process record and replay target doesn't "
1250 "support ipc number %s\n"),
1251 pulongest (tmpulongest
));
1257 case gdb_sys_sigreturn
:
1259 case gdb_sys_setdomainname
:
1262 case gdb_sys_newuname
:
1263 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
1264 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1265 tdep
->size_new_utsname
))
1269 case gdb_sys_modify_ldt
:
1270 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
1271 if (tmpulongest
== 0 || tmpulongest
== 2)
1273 ULONGEST ptr
, bytecount
;
1275 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &ptr
);
1276 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &bytecount
);
1277 if (record_full_arch_list_add_mem ((CORE_ADDR
) ptr
, (int) bytecount
))
1282 case gdb_sys_adjtimex
:
1283 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
1284 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1289 case gdb_sys_mprotect
:
1292 case gdb_sys_sigprocmask
:
1293 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
1294 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1295 tdep
->size_old_sigset_t
))
1299 case gdb_sys_ni_syscall127
:
1300 case gdb_sys_init_module
:
1301 case gdb_sys_delete_module
:
1302 case gdb_sys_ni_syscall130
:
1305 case gdb_sys_quotactl
:
1306 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
1307 switch (tmpulongest
)
1309 case RECORD_Q_GETFMT
:
1310 regcache_raw_read_unsigned (regcache
, tdep
->arg4
,
1313 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
, 4))
1316 case RECORD_Q_GETINFO
:
1317 regcache_raw_read_unsigned (regcache
, tdep
->arg4
,
1319 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1320 tdep
->size_mem_dqinfo
))
1323 case RECORD_Q_GETQUOTA
:
1324 regcache_raw_read_unsigned (regcache
, tdep
->arg4
,
1326 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1327 tdep
->size_if_dqblk
))
1330 case RECORD_Q_XGETQSTAT
:
1331 case RECORD_Q_XGETQUOTA
:
1332 regcache_raw_read_unsigned (regcache
, tdep
->arg4
,
1334 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1335 tdep
->size_fs_quota_stat
))
1341 case gdb_sys_getpgid
:
1342 case gdb_sys_fchdir
:
1343 case gdb_sys_bdflush
:
1347 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
1348 if (tmpulongest
== 2)
1350 regcache_raw_read_unsigned (regcache
, tdep
->arg3
,
1352 /*XXX the size of memory is not very clear. */
1353 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
, 10))
1358 case gdb_sys_personality
:
1359 case gdb_sys_ni_syscall137
:
1360 case gdb_sys_setfsuid16
:
1361 case gdb_sys_setfsgid16
:
1364 case gdb_sys_llseek
:
1365 regcache_raw_read_unsigned (regcache
, tdep
->arg4
, &tmpulongest
);
1366 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1371 case gdb_sys_getdents
:
1372 case gdb_sys_getdents64
:
1376 regcache_raw_read_unsigned (regcache
, tdep
->arg2
,
1378 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &count
);
1379 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
, count
))
1384 case gdb_sys_select
:
1385 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
1386 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1389 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
1390 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1393 regcache_raw_read_unsigned (regcache
, tdep
->arg4
, &tmpulongest
);
1394 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1397 regcache_raw_read_unsigned (regcache
, tdep
->arg5
, &tmpulongest
);
1398 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1399 tdep
->size_timeval
))
1411 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &vec
);
1414 gdb_byte
*iov
= (gdb_byte
*) alloca (tdep
->size_iovec
);
1416 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &vlen
);
1417 for (tmpulongest
= 0; tmpulongest
< vlen
; tmpulongest
++)
1419 if (target_read_memory ((CORE_ADDR
) vec
, iov
,
1423 fprintf_unfiltered (gdb_stdlog
,
1424 "Process record: error reading "
1425 "memory at addr = 0x%s len = %d.\n",
1426 OUTPUT_REG (vec
, tdep
->arg2
),
1431 = (CORE_ADDR
) extract_unsigned_integer (iov
,
1435 = (int) extract_unsigned_integer (iov
+ tdep
->size_pointer
,
1438 if (record_full_arch_list_add_mem (tmpaddr
, tmpint
))
1440 vec
+= tdep
->size_iovec
;
1446 case gdb_sys_writev
:
1447 case gdb_sys_getsid
:
1448 case gdb_sys_fdatasync
:
1449 case gdb_sys_sysctl
:
1451 case gdb_sys_munlock
:
1452 case gdb_sys_mlockall
:
1453 case gdb_sys_munlockall
:
1454 case gdb_sys_sched_setparam
:
1457 case gdb_sys_sched_getparam
:
1458 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
1459 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1464 case gdb_sys_sched_setscheduler
:
1465 case gdb_sys_sched_getscheduler
:
1466 case gdb_sys_sched_yield
:
1467 case gdb_sys_sched_get_priority_max
:
1468 case gdb_sys_sched_get_priority_min
:
1471 case gdb_sys_sched_rr_get_interval
:
1472 case gdb_sys_nanosleep
:
1473 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
1474 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1475 tdep
->size_timespec
))
1479 case gdb_sys_mremap
:
1480 case gdb_sys_setresuid16
:
1483 case gdb_sys_getresuid16
:
1484 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
1485 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1486 tdep
->size_old_uid_t
))
1488 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
1489 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1490 tdep
->size_old_uid_t
))
1492 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
1493 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1494 tdep
->size_old_uid_t
))
1499 case gdb_sys_ni_syscall167
:
1503 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
1508 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &nfds
);
1509 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1510 tdep
->size_pollfd
* nfds
))
1515 case gdb_sys_nfsservctl
:
1516 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
1517 if (tmpulongest
== 7 || tmpulongest
== 8)
1521 if (tmpulongest
== 7)
1522 rsize
= tdep
->size_NFS_FHSIZE
;
1524 rsize
= tdep
->size_knfsd_fh
;
1525 regcache_raw_read_unsigned (regcache
, tdep
->arg3
,
1527 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
, rsize
))
1532 case gdb_sys_setresgid16
:
1535 case gdb_sys_getresgid16
:
1536 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
1537 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1538 tdep
->size_old_gid_t
))
1540 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
1541 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1542 tdep
->size_old_gid_t
))
1544 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
1545 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1546 tdep
->size_old_gid_t
))
1551 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
1552 switch (tmpulongest
)
1555 regcache_raw_read_unsigned (regcache
, tdep
->arg2
,
1557 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1562 regcache_raw_read_unsigned (regcache
, tdep
->arg2
,
1564 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1565 tdep
->size_TASK_COMM_LEN
))
1571 case gdb_sys_rt_sigreturn
:
1574 case gdb_sys_rt_sigaction
:
1575 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
1576 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1577 tdep
->size_sigaction
))
1581 case gdb_sys_rt_sigprocmask
:
1582 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
1583 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1584 tdep
->size_sigset_t
))
1588 case gdb_sys_rt_sigpending
:
1589 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
1592 ULONGEST sigsetsize
;
1594 regcache_raw_read_unsigned (regcache
, tdep
->arg2
,&sigsetsize
);
1595 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1601 case gdb_sys_rt_sigtimedwait
:
1602 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
1603 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1604 tdep
->size_siginfo_t
))
1608 case gdb_sys_rt_sigqueueinfo
:
1609 case gdb_sys_rt_sigsuspend
:
1612 case gdb_sys_pread64
:
1613 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
1618 regcache_raw_read_unsigned (regcache
, tdep
->arg3
,&count
);
1619 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1625 case gdb_sys_pwrite64
:
1626 case gdb_sys_chown16
:
1629 case gdb_sys_getcwd
:
1630 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
1635 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &size
);
1636 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1642 case gdb_sys_capget
:
1643 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
1644 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1645 tdep
->size_cap_user_data_t
))
1649 case gdb_sys_capset
:
1652 case gdb_sys_sigaltstack
:
1653 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
1654 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1655 tdep
->size_stack_t
))
1659 case gdb_sys_sendfile
:
1660 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
1661 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1666 case gdb_sys_ni_syscall188
:
1667 case gdb_sys_ni_syscall189
:
1671 case gdb_sys_getrlimit
:
1672 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
1673 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1681 case gdb_sys_truncate64
:
1682 case gdb_sys_ftruncate64
:
1685 case gdb_sys_stat64
:
1686 case gdb_sys_lstat64
:
1687 case gdb_sys_fstat64
:
1688 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
1689 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1694 case gdb_sys_lchown
:
1695 case gdb_sys_getuid
:
1696 case gdb_sys_getgid
:
1697 case gdb_sys_geteuid
:
1698 case gdb_sys_getegid
:
1699 case gdb_sys_setreuid
:
1700 case gdb_sys_setregid
:
1703 case gdb_sys_getgroups
:
1704 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
1707 ULONGEST gidsetsize
;
1709 regcache_raw_read_unsigned (regcache
, tdep
->arg1
,
1711 tmpint
= tdep
->size_gid_t
* (int) gidsetsize
;
1712 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
, tmpint
))
1717 case gdb_sys_setgroups
:
1718 case gdb_sys_fchown
:
1719 case gdb_sys_setresuid
:
1722 case gdb_sys_getresuid
:
1723 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
1724 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1727 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
1728 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1731 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
1732 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1737 case gdb_sys_setresgid
:
1740 case gdb_sys_getresgid
:
1741 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
1742 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1745 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
1746 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1749 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
1750 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1756 case gdb_sys_setuid
:
1757 case gdb_sys_setgid
:
1758 case gdb_sys_setfsuid
:
1759 case gdb_sys_setfsgid
:
1760 case gdb_sys_pivot_root
:
1763 case gdb_sys_mincore
:
1764 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
1765 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1766 tdep
->size_PAGE_SIZE
))
1770 case gdb_sys_madvise
:
1773 case gdb_sys_fcntl64
:
1774 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
1775 if (tmpulongest
== tdep
->fcntl_F_GETLK64
)
1777 regcache_raw_read_unsigned (regcache
, tdep
->arg3
,
1779 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1780 tdep
->size_flock64
))
1783 else if (tmpulongest
!= tdep
->fcntl_F_SETLK64
1784 && tmpulongest
!= tdep
->fcntl_F_SETLKW64
)
1790 case gdb_sys_ni_syscall222
:
1791 case gdb_sys_ni_syscall223
:
1792 case gdb_sys_gettid
:
1793 case gdb_sys_readahead
:
1794 case gdb_sys_setxattr
:
1795 case gdb_sys_lsetxattr
:
1796 case gdb_sys_fsetxattr
:
1799 case gdb_sys_getxattr
:
1800 case gdb_sys_lgetxattr
:
1801 case gdb_sys_fgetxattr
:
1802 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
1807 regcache_raw_read_unsigned (regcache
, tdep
->arg4
, &size
);
1808 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1814 case gdb_sys_listxattr
:
1815 case gdb_sys_llistxattr
:
1816 case gdb_sys_flistxattr
:
1817 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
1822 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &size
);
1823 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1829 case gdb_sys_removexattr
:
1830 case gdb_sys_lremovexattr
:
1831 case gdb_sys_fremovexattr
:
1835 case gdb_sys_sendfile64
:
1836 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
1837 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1843 case gdb_sys_sched_setaffinity
:
1846 case gdb_sys_sched_getaffinity
:
1847 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
1852 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &len
);
1853 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1859 case gdb_sys_set_thread_area
:
1860 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
1861 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1866 case gdb_sys_get_thread_area
:
1867 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
1868 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1869 tdep
->size_user_desc
))
1873 case gdb_sys_io_setup
:
1874 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
1875 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1880 case gdb_sys_io_destroy
:
1883 case gdb_sys_io_getevents
:
1884 regcache_raw_read_unsigned (regcache
, tdep
->arg4
, &tmpulongest
);
1889 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &nr
);
1890 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1891 nr
* tdep
->size_io_event
))
1896 case gdb_sys_io_submit
:
1897 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
1903 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &nr
);
1904 iocbp
= (gdb_byte
*) alloca (nr
* tdep
->size_pointer
);
1905 if (target_read_memory ((CORE_ADDR
) tmpulongest
, iocbp
,
1906 nr
* tdep
->size_pointer
))
1909 fprintf_unfiltered (gdb_stdlog
,
1910 "Process record: error reading memory "
1911 "at addr = 0x%s len = %u.\n",
1912 OUTPUT_REG (tmpulongest
, tdep
->arg2
),
1913 (int) (nr
* tdep
->size_pointer
));
1916 for (i
= 0; i
< nr
; i
++)
1919 = (CORE_ADDR
) extract_unsigned_integer (iocbp
,
1922 if (record_full_arch_list_add_mem (tmpaddr
, tdep
->size_iocb
))
1924 iocbp
+= tdep
->size_pointer
;
1929 case gdb_sys_io_cancel
:
1930 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
1931 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1932 tdep
->size_io_event
))
1936 case gdb_sys_fadvise64
:
1937 case gdb_sys_ni_syscall251
:
1940 case gdb_sys_exit_group
:
1944 target_terminal_ours ();
1945 q
= yquery (_("The next instruction is syscall exit_group. "
1946 "It will make the program exit. "
1947 "Do you want to stop the program?"));
1948 target_terminal_inferior ();
1954 case gdb_sys_lookup_dcookie
:
1955 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
1960 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &len
);
1961 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1967 case gdb_sys_epoll_create
:
1968 case gdb_sys_epoll_ctl
:
1971 case gdb_sys_epoll_wait
:
1972 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
1977 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &maxevents
);
1978 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1980 * tdep
->size_epoll_event
)))
1985 case gdb_sys_remap_file_pages
:
1986 case gdb_sys_set_tid_address
:
1989 case gdb_sys_timer_create
:
1990 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
1991 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1996 case gdb_sys_timer_settime
:
1997 regcache_raw_read_unsigned (regcache
, tdep
->arg4
, &tmpulongest
);
1998 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
1999 tdep
->size_itimerspec
))
2003 case gdb_sys_timer_gettime
:
2004 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
2005 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
2006 tdep
->size_itimerspec
))
2010 case gdb_sys_timer_getoverrun
:
2011 case gdb_sys_timer_delete
:
2012 case gdb_sys_clock_settime
:
2015 case gdb_sys_clock_gettime
:
2016 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
2017 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
2018 tdep
->size_timespec
))
2022 case gdb_sys_clock_getres
:
2023 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
2024 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
2025 tdep
->size_timespec
))
2029 case gdb_sys_clock_nanosleep
:
2030 regcache_raw_read_unsigned (regcache
, tdep
->arg4
, &tmpulongest
);
2031 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
2032 tdep
->size_timespec
))
2036 case gdb_sys_statfs64
:
2037 case gdb_sys_fstatfs64
:
2038 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
2039 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
2040 tdep
->size_statfs64
))
2044 case gdb_sys_tgkill
:
2045 case gdb_sys_utimes
:
2046 case gdb_sys_fadvise64_64
:
2047 case gdb_sys_ni_syscall273
:
2051 case gdb_sys_get_mempolicy
:
2052 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
2053 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
2056 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
2061 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &maxnode
);
2062 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
2063 maxnode
* tdep
->size_long
))
2068 case gdb_sys_set_mempolicy
:
2069 case gdb_sys_mq_open
:
2070 case gdb_sys_mq_unlink
:
2071 case gdb_sys_mq_timedsend
:
2074 case gdb_sys_mq_timedreceive
:
2075 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
2080 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &msg_len
);
2081 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
2085 regcache_raw_read_unsigned (regcache
, tdep
->arg4
, &tmpulongest
);
2086 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
2091 case gdb_sys_mq_notify
:
2094 case gdb_sys_mq_getsetattr
:
2095 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
2096 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
2097 tdep
->size_mq_attr
))
2101 case gdb_sys_kexec_load
:
2104 case gdb_sys_waitid
:
2105 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
2106 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
2107 tdep
->size_siginfo_t
))
2109 regcache_raw_read_unsigned (regcache
, tdep
->arg5
, &tmpulongest
);
2110 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
2115 case gdb_sys_ni_syscall285
:
2116 case gdb_sys_add_key
:
2117 case gdb_sys_request_key
:
2120 case gdb_sys_keyctl
:
2121 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
2122 if (tmpulongest
== 6 || tmpulongest
== 11)
2124 regcache_raw_read_unsigned (regcache
, tdep
->arg3
,
2130 regcache_raw_read_unsigned (regcache
, tdep
->arg4
, &buflen
);
2131 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
2138 case gdb_sys_ioprio_set
:
2139 case gdb_sys_ioprio_get
:
2140 case gdb_sys_inotify_init
:
2141 case gdb_sys_inotify_add_watch
:
2142 case gdb_sys_inotify_rm_watch
:
2143 case gdb_sys_migrate_pages
:
2144 case gdb_sys_openat
:
2145 case gdb_sys_mkdirat
:
2146 case gdb_sys_mknodat
:
2147 case gdb_sys_fchownat
:
2148 case gdb_sys_futimesat
:
2151 case gdb_sys_fstatat64
:
2152 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
2153 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
2158 case gdb_sys_unlinkat
:
2159 case gdb_sys_renameat
:
2160 case gdb_sys_linkat
:
2161 case gdb_sys_symlinkat
:
2164 case gdb_sys_readlinkat
:
2165 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
2170 regcache_raw_read_unsigned (regcache
, tdep
->arg4
, &bufsiz
);
2171 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
2177 case gdb_sys_fchmodat
:
2178 case gdb_sys_faccessat
:
2181 case gdb_sys_pselect6
:
2182 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
2183 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
2186 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
2187 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
2190 regcache_raw_read_unsigned (regcache
, tdep
->arg4
, &tmpulongest
);
2191 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
2194 regcache_raw_read_unsigned (regcache
, tdep
->arg5
, &tmpulongest
);
2195 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
2196 tdep
->size_timespec
))
2201 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
2206 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &nfds
);
2207 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
2208 tdep
->size_pollfd
* nfds
))
2211 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
2212 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
2213 tdep
->size_timespec
))
2217 case gdb_sys_unshare
:
2218 case gdb_sys_set_robust_list
:
2221 case gdb_sys_get_robust_list
:
2222 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
2223 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
2226 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
2227 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
2232 case gdb_sys_splice
:
2233 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
2234 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
2237 regcache_raw_read_unsigned (regcache
, tdep
->arg4
, &tmpulongest
);
2238 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
2243 case gdb_sys_sync_file_range
:
2245 case gdb_sys_vmsplice
:
2248 case gdb_sys_move_pages
:
2249 regcache_raw_read_unsigned (regcache
, tdep
->arg5
, &tmpulongest
);
2254 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &nr_pages
);
2255 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
2256 nr_pages
* tdep
->size_int
))
2261 case gdb_sys_getcpu
:
2262 regcache_raw_read_unsigned (regcache
, tdep
->arg1
, &tmpulongest
);
2263 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
2266 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
2267 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
2270 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &tmpulongest
);
2271 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
,
2272 tdep
->size_ulong
* 2))
2276 case gdb_sys_epoll_pwait
:
2277 regcache_raw_read_unsigned (regcache
, tdep
->arg2
, &tmpulongest
);
2282 regcache_raw_read_unsigned (regcache
, tdep
->arg3
, &maxevents
);
2283 tmpint
= (int) maxevents
* tdep
->size_epoll_event
;
2284 if (record_full_arch_list_add_mem ((CORE_ADDR
) tmpulongest
, tmpint
))
2290 printf_unfiltered (_("Process record and replay target doesn't "
2291 "support syscall number %d\n"), syscall
);