Add some more casts (2/2)
[external/binutils.git] / gdb / record-full.c
1 /* Process record and replay target for GDB, the GNU debugger.
2
3    Copyright (C) 2013-2015 Free Software Foundation, Inc.
4
5    This file is part of GDB.
6
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.
11
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.
16
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/>.  */
19
20 #include "defs.h"
21 #include "gdbcmd.h"
22 #include "regcache.h"
23 #include "gdbthread.h"
24 #include "event-top.h"
25 #include "completer.h"
26 #include "arch-utils.h"
27 #include "gdbcore.h"
28 #include "exec.h"
29 #include "record.h"
30 #include "record-full.h"
31 #include "elf-bfd.h"
32 #include "gcore.h"
33 #include "event-loop.h"
34 #include "inf-loop.h"
35 #include "gdb_bfd.h"
36 #include "observer.h"
37 #include "infrun.h"
38
39 #include <signal.h>
40
41 /* This module implements "target record-full", also known as "process
42    record and replay".  This target sits on top of a "normal" target
43    (a target that "has execution"), and provides a record and replay
44    functionality, including reverse debugging.
45
46    Target record has two modes: recording, and replaying.
47
48    In record mode, we intercept the to_resume and to_wait methods.
49    Whenever gdb resumes the target, we run the target in single step
50    mode, and we build up an execution log in which, for each executed
51    instruction, we record all changes in memory and register state.
52    This is invisible to the user, to whom it just looks like an
53    ordinary debugging session (except for performance degredation).
54
55    In replay mode, instead of actually letting the inferior run as a
56    process, we simulate its execution by playing back the recorded
57    execution log.  For each instruction in the log, we simulate the
58    instruction's side effects by duplicating the changes that it would
59    have made on memory and registers.  */
60
61 #define DEFAULT_RECORD_FULL_INSN_MAX_NUM        200000
62
63 #define RECORD_FULL_IS_REPLAY \
64      (record_full_list->next || execution_direction == EXEC_REVERSE)
65
66 #define RECORD_FULL_FILE_MAGIC  netorder32(0x20091016)
67
68 /* These are the core structs of the process record functionality.
69
70    A record_full_entry is a record of the value change of a register
71    ("record_full_reg") or a part of memory ("record_full_mem").  And each
72    instruction must have a struct record_full_entry ("record_full_end")
73    that indicates that this is the last struct record_full_entry of this
74    instruction.
75
76    Each struct record_full_entry is linked to "record_full_list" by "prev"
77    and "next" pointers.  */
78
79 struct record_full_mem_entry
80 {
81   CORE_ADDR addr;
82   int len;
83   /* Set this flag if target memory for this entry
84      can no longer be accessed.  */
85   int mem_entry_not_accessible;
86   union
87   {
88     gdb_byte *ptr;
89     gdb_byte buf[sizeof (gdb_byte *)];
90   } u;
91 };
92
93 struct record_full_reg_entry
94 {
95   unsigned short num;
96   unsigned short len;
97   union 
98   {
99     gdb_byte *ptr;
100     gdb_byte buf[2 * sizeof (gdb_byte *)];
101   } u;
102 };
103
104 struct record_full_end_entry
105 {
106   enum gdb_signal sigval;
107   ULONGEST insn_num;
108 };
109
110 enum record_full_type
111 {
112   record_full_end = 0,
113   record_full_reg,
114   record_full_mem
115 };
116
117 /* This is the data structure that makes up the execution log.
118
119    The execution log consists of a single linked list of entries
120    of type "struct record_full_entry".  It is doubly linked so that it
121    can be traversed in either direction.
122
123    The start of the list is anchored by a struct called
124    "record_full_first".  The pointer "record_full_list" either points
125    to the last entry that was added to the list (in record mode), or to
126    the next entry in the list that will be executed (in replay mode).
127
128    Each list element (struct record_full_entry), in addition to next
129    and prev pointers, consists of a union of three entry types: mem,
130    reg, and end.  A field called "type" determines which entry type is
131    represented by a given list element.
132
133    Each instruction that is added to the execution log is represented
134    by a variable number of list elements ('entries').  The instruction
135    will have one "reg" entry for each register that is changed by 
136    executing the instruction (including the PC in every case).  It 
137    will also have one "mem" entry for each memory change.  Finally,
138    each instruction will have an "end" entry that separates it from
139    the changes associated with the next instruction.  */
140
141 struct record_full_entry
142 {
143   struct record_full_entry *prev;
144   struct record_full_entry *next;
145   enum record_full_type type;
146   union
147   {
148     /* reg */
149     struct record_full_reg_entry reg;
150     /* mem */
151     struct record_full_mem_entry mem;
152     /* end */
153     struct record_full_end_entry end;
154   } u;
155 };
156
157 /* If true, query if PREC cannot record memory
158    change of next instruction.  */
159 int record_full_memory_query = 0;
160
161 struct record_full_core_buf_entry
162 {
163   struct record_full_core_buf_entry *prev;
164   struct target_section *p;
165   bfd_byte *buf;
166 };
167
168 /* Record buf with core target.  */
169 static gdb_byte *record_full_core_regbuf = NULL;
170 static struct target_section *record_full_core_start;
171 static struct target_section *record_full_core_end;
172 static struct record_full_core_buf_entry *record_full_core_buf_list = NULL;
173
174 /* The following variables are used for managing the linked list that
175    represents the execution log.
176
177    record_full_first is the anchor that holds down the beginning of
178    the list.
179
180    record_full_list serves two functions:
181      1) In record mode, it anchors the end of the list.
182      2) In replay mode, it traverses the list and points to
183         the next instruction that must be emulated.
184
185    record_full_arch_list_head and record_full_arch_list_tail are used
186    to manage a separate list, which is used to build up the change
187    elements of the currently executing instruction during record mode.
188    When this instruction has been completely annotated in the "arch
189    list", it will be appended to the main execution log.  */
190
191 static struct record_full_entry record_full_first;
192 static struct record_full_entry *record_full_list = &record_full_first;
193 static struct record_full_entry *record_full_arch_list_head = NULL;
194 static struct record_full_entry *record_full_arch_list_tail = NULL;
195
196 /* 1 ask user. 0 auto delete the last struct record_full_entry.  */
197 static int record_full_stop_at_limit = 1;
198 /* Maximum allowed number of insns in execution log.  */
199 static unsigned int record_full_insn_max_num
200         = DEFAULT_RECORD_FULL_INSN_MAX_NUM;
201 /* Actual count of insns presently in execution log.  */
202 static unsigned int record_full_insn_num = 0;
203 /* Count of insns logged so far (may be larger
204    than count of insns presently in execution log).  */
205 static ULONGEST record_full_insn_count;
206
207 /* The target_ops of process record.  */
208 static struct target_ops record_full_ops;
209 static struct target_ops record_full_core_ops;
210
211 /* See record-full.h.  */
212
213 int
214 record_full_is_used (void)
215 {
216   struct target_ops *t;
217
218   t = find_record_target ();
219   return (t == &record_full_ops
220           || t == &record_full_core_ops);
221 }
222
223
224 /* Command lists for "set/show record full".  */
225 static struct cmd_list_element *set_record_full_cmdlist;
226 static struct cmd_list_element *show_record_full_cmdlist;
227
228 /* Command list for "record full".  */
229 static struct cmd_list_element *record_full_cmdlist;
230
231 static void record_full_goto_insn (struct record_full_entry *entry,
232                                    enum exec_direction_kind dir);
233 static void record_full_save (struct target_ops *self,
234                               const char *recfilename);
235
236 /* Alloc and free functions for record_full_reg, record_full_mem, and
237    record_full_end entries.  */
238
239 /* Alloc a record_full_reg record entry.  */
240
241 static inline struct record_full_entry *
242 record_full_reg_alloc (struct regcache *regcache, int regnum)
243 {
244   struct record_full_entry *rec;
245   struct gdbarch *gdbarch = get_regcache_arch (regcache);
246
247   rec = XCNEW (struct record_full_entry);
248   rec->type = record_full_reg;
249   rec->u.reg.num = regnum;
250   rec->u.reg.len = register_size (gdbarch, regnum);
251   if (rec->u.reg.len > sizeof (rec->u.reg.u.buf))
252     rec->u.reg.u.ptr = (gdb_byte *) xmalloc (rec->u.reg.len);
253
254   return rec;
255 }
256
257 /* Free a record_full_reg record entry.  */
258
259 static inline void
260 record_full_reg_release (struct record_full_entry *rec)
261 {
262   gdb_assert (rec->type == record_full_reg);
263   if (rec->u.reg.len > sizeof (rec->u.reg.u.buf))
264     xfree (rec->u.reg.u.ptr);
265   xfree (rec);
266 }
267
268 /* Alloc a record_full_mem record entry.  */
269
270 static inline struct record_full_entry *
271 record_full_mem_alloc (CORE_ADDR addr, int len)
272 {
273   struct record_full_entry *rec;
274
275   rec = XCNEW (struct record_full_entry);
276   rec->type = record_full_mem;
277   rec->u.mem.addr = addr;
278   rec->u.mem.len = len;
279   if (rec->u.mem.len > sizeof (rec->u.mem.u.buf))
280     rec->u.mem.u.ptr = (gdb_byte *) xmalloc (len);
281
282   return rec;
283 }
284
285 /* Free a record_full_mem record entry.  */
286
287 static inline void
288 record_full_mem_release (struct record_full_entry *rec)
289 {
290   gdb_assert (rec->type == record_full_mem);
291   if (rec->u.mem.len > sizeof (rec->u.mem.u.buf))
292     xfree (rec->u.mem.u.ptr);
293   xfree (rec);
294 }
295
296 /* Alloc a record_full_end record entry.  */
297
298 static inline struct record_full_entry *
299 record_full_end_alloc (void)
300 {
301   struct record_full_entry *rec;
302
303   rec = XCNEW (struct record_full_entry);
304   rec->type = record_full_end;
305
306   return rec;
307 }
308
309 /* Free a record_full_end record entry.  */
310
311 static inline void
312 record_full_end_release (struct record_full_entry *rec)
313 {
314   xfree (rec);
315 }
316
317 /* Free one record entry, any type.
318    Return entry->type, in case caller wants to know.  */
319
320 static inline enum record_full_type
321 record_full_entry_release (struct record_full_entry *rec)
322 {
323   enum record_full_type type = rec->type;
324
325   switch (type) {
326   case record_full_reg:
327     record_full_reg_release (rec);
328     break;
329   case record_full_mem:
330     record_full_mem_release (rec);
331     break;
332   case record_full_end:
333     record_full_end_release (rec);
334     break;
335   }
336   return type;
337 }
338
339 /* Free all record entries in list pointed to by REC.  */
340
341 static void
342 record_full_list_release (struct record_full_entry *rec)
343 {
344   if (!rec)
345     return;
346
347   while (rec->next)
348     rec = rec->next;
349
350   while (rec->prev)
351     {
352       rec = rec->prev;
353       record_full_entry_release (rec->next);
354     }
355
356   if (rec == &record_full_first)
357     {
358       record_full_insn_num = 0;
359       record_full_first.next = NULL;
360     }
361   else
362     record_full_entry_release (rec);
363 }
364
365 /* Free all record entries forward of the given list position.  */
366
367 static void
368 record_full_list_release_following (struct record_full_entry *rec)
369 {
370   struct record_full_entry *tmp = rec->next;
371
372   rec->next = NULL;
373   while (tmp)
374     {
375       rec = tmp->next;
376       if (record_full_entry_release (tmp) == record_full_end)
377         {
378           record_full_insn_num--;
379           record_full_insn_count--;
380         }
381       tmp = rec;
382     }
383 }
384
385 /* Delete the first instruction from the beginning of the log, to make
386    room for adding a new instruction at the end of the log.
387
388    Note -- this function does not modify record_full_insn_num.  */
389
390 static void
391 record_full_list_release_first (void)
392 {
393   struct record_full_entry *tmp;
394
395   if (!record_full_first.next)
396     return;
397
398   /* Loop until a record_full_end.  */
399   while (1)
400     {
401       /* Cut record_full_first.next out of the linked list.  */
402       tmp = record_full_first.next;
403       record_full_first.next = tmp->next;
404       tmp->next->prev = &record_full_first;
405
406       /* tmp is now isolated, and can be deleted.  */
407       if (record_full_entry_release (tmp) == record_full_end)
408         break;  /* End loop at first record_full_end.  */
409
410       if (!record_full_first.next)
411         {
412           gdb_assert (record_full_insn_num == 1);
413           break;        /* End loop when list is empty.  */
414         }
415     }
416 }
417
418 /* Add a struct record_full_entry to record_full_arch_list.  */
419
420 static void
421 record_full_arch_list_add (struct record_full_entry *rec)
422 {
423   if (record_debug > 1)
424     fprintf_unfiltered (gdb_stdlog,
425                         "Process record: record_full_arch_list_add %s.\n",
426                         host_address_to_string (rec));
427
428   if (record_full_arch_list_tail)
429     {
430       record_full_arch_list_tail->next = rec;
431       rec->prev = record_full_arch_list_tail;
432       record_full_arch_list_tail = rec;
433     }
434   else
435     {
436       record_full_arch_list_head = rec;
437       record_full_arch_list_tail = rec;
438     }
439 }
440
441 /* Return the value storage location of a record entry.  */
442 static inline gdb_byte *
443 record_full_get_loc (struct record_full_entry *rec)
444 {
445   switch (rec->type) {
446   case record_full_mem:
447     if (rec->u.mem.len > sizeof (rec->u.mem.u.buf))
448       return rec->u.mem.u.ptr;
449     else
450       return rec->u.mem.u.buf;
451   case record_full_reg:
452     if (rec->u.reg.len > sizeof (rec->u.reg.u.buf))
453       return rec->u.reg.u.ptr;
454     else
455       return rec->u.reg.u.buf;
456   case record_full_end:
457   default:
458     gdb_assert_not_reached ("unexpected record_full_entry type");
459     return NULL;
460   }
461 }
462
463 /* Record the value of a register NUM to record_full_arch_list.  */
464
465 int
466 record_full_arch_list_add_reg (struct regcache *regcache, int regnum)
467 {
468   struct record_full_entry *rec;
469
470   if (record_debug > 1)
471     fprintf_unfiltered (gdb_stdlog,
472                         "Process record: add register num = %d to "
473                         "record list.\n",
474                         regnum);
475
476   rec = record_full_reg_alloc (regcache, regnum);
477
478   regcache_raw_read (regcache, regnum, record_full_get_loc (rec));
479
480   record_full_arch_list_add (rec);
481
482   return 0;
483 }
484
485 /* Record the value of a region of memory whose address is ADDR and
486    length is LEN to record_full_arch_list.  */
487
488 int
489 record_full_arch_list_add_mem (CORE_ADDR addr, int len)
490 {
491   struct record_full_entry *rec;
492
493   if (record_debug > 1)
494     fprintf_unfiltered (gdb_stdlog,
495                         "Process record: add mem addr = %s len = %d to "
496                         "record list.\n",
497                         paddress (target_gdbarch (), addr), len);
498
499   if (!addr)    /* FIXME: Why?  Some arch must permit it...  */
500     return 0;
501
502   rec = record_full_mem_alloc (addr, len);
503
504   if (record_read_memory (target_gdbarch (), addr,
505                           record_full_get_loc (rec), len))
506     {
507       record_full_mem_release (rec);
508       return -1;
509     }
510
511   record_full_arch_list_add (rec);
512
513   return 0;
514 }
515
516 /* Add a record_full_end type struct record_full_entry to
517    record_full_arch_list.  */
518
519 int
520 record_full_arch_list_add_end (void)
521 {
522   struct record_full_entry *rec;
523
524   if (record_debug > 1)
525     fprintf_unfiltered (gdb_stdlog,
526                         "Process record: add end to arch list.\n");
527
528   rec = record_full_end_alloc ();
529   rec->u.end.sigval = GDB_SIGNAL_0;
530   rec->u.end.insn_num = ++record_full_insn_count;
531
532   record_full_arch_list_add (rec);
533
534   return 0;
535 }
536
537 static void
538 record_full_check_insn_num (int set_terminal)
539 {
540   if (record_full_insn_num == record_full_insn_max_num)
541     {
542       /* Ask user what to do.  */
543       if (record_full_stop_at_limit)
544         {
545           int q;
546
547           if (set_terminal)
548             target_terminal_ours ();
549           q = yquery (_("Do you want to auto delete previous execution "
550                         "log entries when record/replay buffer becomes "
551                         "full (record full stop-at-limit)?"));
552           if (set_terminal)
553             target_terminal_inferior ();
554           if (q)
555             record_full_stop_at_limit = 0;
556           else
557             error (_("Process record: stopped by user."));
558         }
559     }
560 }
561
562 static void
563 record_full_arch_list_cleanups (void *ignore)
564 {
565   record_full_list_release (record_full_arch_list_tail);
566 }
567
568 /* Before inferior step (when GDB record the running message, inferior
569    only can step), GDB will call this function to record the values to
570    record_full_list.  This function will call gdbarch_process_record to
571    record the running message of inferior and set them to
572    record_full_arch_list, and add it to record_full_list.  */
573
574 static int
575 record_full_message (struct regcache *regcache, enum gdb_signal signal)
576 {
577   int ret;
578   struct gdbarch *gdbarch = get_regcache_arch (regcache);
579   struct cleanup *old_cleanups
580     = make_cleanup (record_full_arch_list_cleanups, 0);
581
582   record_full_arch_list_head = NULL;
583   record_full_arch_list_tail = NULL;
584
585   /* Check record_full_insn_num.  */
586   record_full_check_insn_num (1);
587
588   /* If gdb sends a signal value to target_resume,
589      save it in the 'end' field of the previous instruction.
590
591      Maybe process record should record what really happened,
592      rather than what gdb pretends has happened.
593
594      So if Linux delivered the signal to the child process during
595      the record mode, we will record it and deliver it again in
596      the replay mode.
597
598      If user says "ignore this signal" during the record mode, then
599      it will be ignored again during the replay mode (no matter if
600      the user says something different, like "deliver this signal"
601      during the replay mode).
602
603      User should understand that nothing he does during the replay
604      mode will change the behavior of the child.  If he tries,
605      then that is a user error.
606
607      But we should still deliver the signal to gdb during the replay,
608      if we delivered it during the recording.  Therefore we should
609      record the signal during record_full_wait, not
610      record_full_resume.  */
611   if (record_full_list != &record_full_first)  /* FIXME better way to check */
612     {
613       gdb_assert (record_full_list->type == record_full_end);
614       record_full_list->u.end.sigval = signal;
615     }
616
617   if (signal == GDB_SIGNAL_0
618       || !gdbarch_process_record_signal_p (gdbarch))
619     ret = gdbarch_process_record (gdbarch,
620                                   regcache,
621                                   regcache_read_pc (regcache));
622   else
623     ret = gdbarch_process_record_signal (gdbarch,
624                                          regcache,
625                                          signal);
626
627   if (ret > 0)
628     error (_("Process record: inferior program stopped."));
629   if (ret < 0)
630     error (_("Process record: failed to record execution log."));
631
632   discard_cleanups (old_cleanups);
633
634   record_full_list->next = record_full_arch_list_head;
635   record_full_arch_list_head->prev = record_full_list;
636   record_full_list = record_full_arch_list_tail;
637
638   if (record_full_insn_num == record_full_insn_max_num)
639     record_full_list_release_first ();
640   else
641     record_full_insn_num++;
642
643   return 1;
644 }
645
646 struct record_full_message_args {
647   struct regcache *regcache;
648   enum gdb_signal signal;
649 };
650
651 static int
652 record_full_message_wrapper (void *args)
653 {
654   struct record_full_message_args *record_full_args
655     = (struct record_full_message_args *) args;
656
657   return record_full_message (record_full_args->regcache,
658                               record_full_args->signal);
659 }
660
661 static int
662 record_full_message_wrapper_safe (struct regcache *regcache,
663                                   enum gdb_signal signal)
664 {
665   struct record_full_message_args args;
666
667   args.regcache = regcache;
668   args.signal = signal;
669
670   return catch_errors (record_full_message_wrapper, &args, NULL,
671                        RETURN_MASK_ALL);
672 }
673
674 /* Set to 1 if record_full_store_registers and record_full_xfer_partial
675    doesn't need record.  */
676
677 static int record_full_gdb_operation_disable = 0;
678
679 struct cleanup *
680 record_full_gdb_operation_disable_set (void)
681 {
682   struct cleanup *old_cleanups = NULL;
683
684   old_cleanups =
685     make_cleanup_restore_integer (&record_full_gdb_operation_disable);
686   record_full_gdb_operation_disable = 1;
687
688   return old_cleanups;
689 }
690
691 /* Flag set to TRUE for target_stopped_by_watchpoint.  */
692 static enum target_stop_reason record_full_stop_reason
693   = TARGET_STOPPED_BY_NO_REASON;
694
695 /* Execute one instruction from the record log.  Each instruction in
696    the log will be represented by an arbitrary sequence of register
697    entries and memory entries, followed by an 'end' entry.  */
698
699 static inline void
700 record_full_exec_insn (struct regcache *regcache,
701                        struct gdbarch *gdbarch,
702                        struct record_full_entry *entry)
703 {
704   switch (entry->type)
705     {
706     case record_full_reg: /* reg */
707       {
708         gdb_byte reg[MAX_REGISTER_SIZE];
709
710         if (record_debug > 1)
711           fprintf_unfiltered (gdb_stdlog,
712                               "Process record: record_full_reg %s to "
713                               "inferior num = %d.\n",
714                               host_address_to_string (entry),
715                               entry->u.reg.num);
716
717         regcache_cooked_read (regcache, entry->u.reg.num, reg);
718         regcache_cooked_write (regcache, entry->u.reg.num, 
719                                record_full_get_loc (entry));
720         memcpy (record_full_get_loc (entry), reg, entry->u.reg.len);
721       }
722       break;
723
724     case record_full_mem: /* mem */
725       {
726         /* Nothing to do if the entry is flagged not_accessible.  */
727         if (!entry->u.mem.mem_entry_not_accessible)
728           {
729             gdb_byte *mem = (gdb_byte *) alloca (entry->u.mem.len);
730
731             if (record_debug > 1)
732               fprintf_unfiltered (gdb_stdlog,
733                                   "Process record: record_full_mem %s to "
734                                   "inferior addr = %s len = %d.\n",
735                                   host_address_to_string (entry),
736                                   paddress (gdbarch, entry->u.mem.addr),
737                                   entry->u.mem.len);
738
739             if (record_read_memory (gdbarch,
740                                     entry->u.mem.addr, mem, entry->u.mem.len))
741               entry->u.mem.mem_entry_not_accessible = 1;
742             else
743               {
744                 if (target_write_memory (entry->u.mem.addr, 
745                                          record_full_get_loc (entry),
746                                          entry->u.mem.len))
747                   {
748                     entry->u.mem.mem_entry_not_accessible = 1;
749                     if (record_debug)
750                       warning (_("Process record: error writing memory at "
751                                  "addr = %s len = %d."),
752                                paddress (gdbarch, entry->u.mem.addr),
753                                entry->u.mem.len);
754                   }
755                 else
756                   {
757                     memcpy (record_full_get_loc (entry), mem,
758                             entry->u.mem.len);
759
760                     /* We've changed memory --- check if a hardware
761                        watchpoint should trap.  Note that this
762                        presently assumes the target beneath supports
763                        continuable watchpoints.  On non-continuable
764                        watchpoints target, we'll want to check this
765                        _before_ actually doing the memory change, and
766                        not doing the change at all if the watchpoint
767                        traps.  */
768                     if (hardware_watchpoint_inserted_in_range
769                         (get_regcache_aspace (regcache),
770                          entry->u.mem.addr, entry->u.mem.len))
771                       record_full_stop_reason = TARGET_STOPPED_BY_WATCHPOINT;
772                   }
773               }
774           }
775       }
776       break;
777     }
778 }
779
780 static void record_full_restore (void);
781
782 /* Asynchronous signal handle registered as event loop source for when
783    we have pending events ready to be passed to the core.  */
784
785 static struct async_event_handler *record_full_async_inferior_event_token;
786
787 static void
788 record_full_async_inferior_event_handler (gdb_client_data data)
789 {
790   inferior_event_handler (INF_REG_EVENT, NULL);
791 }
792
793 /* Open the process record target.  */
794
795 static void
796 record_full_core_open_1 (const char *name, int from_tty)
797 {
798   struct regcache *regcache = get_current_regcache ();
799   int regnum = gdbarch_num_regs (get_regcache_arch (regcache));
800   int i;
801
802   /* Get record_full_core_regbuf.  */
803   target_fetch_registers (regcache, -1);
804   record_full_core_regbuf = (gdb_byte *) xmalloc (MAX_REGISTER_SIZE * regnum);
805   for (i = 0; i < regnum; i ++)
806     regcache_raw_collect (regcache, i,
807                           record_full_core_regbuf + MAX_REGISTER_SIZE * i);
808
809   /* Get record_full_core_start and record_full_core_end.  */
810   if (build_section_table (core_bfd, &record_full_core_start,
811                            &record_full_core_end))
812     {
813       xfree (record_full_core_regbuf);
814       record_full_core_regbuf = NULL;
815       error (_("\"%s\": Can't find sections: %s"),
816              bfd_get_filename (core_bfd), bfd_errmsg (bfd_get_error ()));
817     }
818
819   push_target (&record_full_core_ops);
820   record_full_restore ();
821 }
822
823 /* "to_open" target method for 'live' processes.  */
824
825 static void
826 record_full_open_1 (const char *name, int from_tty)
827 {
828   if (record_debug)
829     fprintf_unfiltered (gdb_stdlog, "Process record: record_full_open\n");
830
831   /* check exec */
832   if (!target_has_execution)
833     error (_("Process record: the program is not being run."));
834   if (non_stop)
835     error (_("Process record target can't debug inferior in non-stop mode "
836              "(non-stop)."));
837
838   if (!gdbarch_process_record_p (target_gdbarch ()))
839     error (_("Process record: the current architecture doesn't support "
840              "record function."));
841
842   push_target (&record_full_ops);
843 }
844
845 static void record_full_init_record_breakpoints (void);
846
847 /* "to_open" target method.  Open the process record target.  */
848
849 static void
850 record_full_open (const char *name, int from_tty)
851 {
852   struct target_ops *t;
853
854   if (record_debug)
855     fprintf_unfiltered (gdb_stdlog, "Process record: record_full_open\n");
856
857   record_preopen ();
858
859   /* Reset */
860   record_full_insn_num = 0;
861   record_full_insn_count = 0;
862   record_full_list = &record_full_first;
863   record_full_list->next = NULL;
864
865   if (core_bfd)
866     record_full_core_open_1 (name, from_tty);
867   else
868     record_full_open_1 (name, from_tty);
869
870   /* Register extra event sources in the event loop.  */
871   record_full_async_inferior_event_token
872     = create_async_event_handler (record_full_async_inferior_event_handler,
873                                   NULL);
874
875   record_full_init_record_breakpoints ();
876
877   observer_notify_record_changed (current_inferior (),  1);
878 }
879
880 /* "to_close" target method.  Close the process record target.  */
881
882 static void
883 record_full_close (struct target_ops *self)
884 {
885   struct record_full_core_buf_entry *entry;
886
887   if (record_debug)
888     fprintf_unfiltered (gdb_stdlog, "Process record: record_full_close\n");
889
890   record_full_list_release (record_full_list);
891
892   /* Release record_full_core_regbuf.  */
893   if (record_full_core_regbuf)
894     {
895       xfree (record_full_core_regbuf);
896       record_full_core_regbuf = NULL;
897     }
898
899   /* Release record_full_core_buf_list.  */
900   if (record_full_core_buf_list)
901     {
902       for (entry = record_full_core_buf_list->prev; entry;
903            entry = entry->prev)
904         {
905           xfree (record_full_core_buf_list);
906           record_full_core_buf_list = entry;
907         }
908       record_full_core_buf_list = NULL;
909     }
910
911   if (record_full_async_inferior_event_token)
912     delete_async_event_handler (&record_full_async_inferior_event_token);
913 }
914
915 /* "to_async" target method.  */
916
917 static void
918 record_full_async (struct target_ops *ops, int enable)
919 {
920   if (enable)
921     mark_async_event_handler (record_full_async_inferior_event_token);
922   else
923     clear_async_event_handler (record_full_async_inferior_event_token);
924
925   ops->beneath->to_async (ops->beneath, enable);
926 }
927
928 static int record_full_resume_step = 0;
929
930 /* True if we've been resumed, and so each record_full_wait call should
931    advance execution.  If this is false, record_full_wait will return a
932    TARGET_WAITKIND_IGNORE.  */
933 static int record_full_resumed = 0;
934
935 /* The execution direction of the last resume we got.  This is
936    necessary for async mode.  Vis (order is not strictly accurate):
937
938    1. user has the global execution direction set to forward
939    2. user does a reverse-step command
940    3. record_full_resume is called with global execution direction
941       temporarily switched to reverse
942    4. GDB's execution direction is reverted back to forward
943    5. target record notifies event loop there's an event to handle
944    6. infrun asks the target which direction was it going, and switches
945       the global execution direction accordingly (to reverse)
946    7. infrun polls an event out of the record target, and handles it
947    8. GDB goes back to the event loop, and goto #4.
948 */
949 static enum exec_direction_kind record_full_execution_dir = EXEC_FORWARD;
950
951 /* "to_resume" target method.  Resume the process record target.  */
952
953 static void
954 record_full_resume (struct target_ops *ops, ptid_t ptid, int step,
955                     enum gdb_signal signal)
956 {
957   record_full_resume_step = step;
958   record_full_resumed = 1;
959   record_full_execution_dir = execution_direction;
960
961   if (!RECORD_FULL_IS_REPLAY)
962     {
963       struct gdbarch *gdbarch = target_thread_architecture (ptid);
964
965       record_full_message (get_current_regcache (), signal);
966
967       if (!step)
968         {
969           /* This is not hard single step.  */
970           if (!gdbarch_software_single_step_p (gdbarch))
971             {
972               /* This is a normal continue.  */
973               step = 1;
974             }
975           else
976             {
977               /* This arch support soft sigle step.  */
978               if (thread_has_single_step_breakpoints_set (inferior_thread ()))
979                 {
980                   /* This is a soft single step.  */
981                   record_full_resume_step = 1;
982                 }
983               else
984                 {
985                   /* This is a continue.
986                      Try to insert a soft single step breakpoint.  */
987                   if (!gdbarch_software_single_step (gdbarch,
988                                                      get_current_frame ()))
989                     {
990                       /* This system don't want use soft single step.
991                          Use hard sigle step.  */
992                       step = 1;
993                     }
994                 }
995             }
996         }
997
998       /* Make sure the target beneath reports all signals.  */
999       target_pass_signals (0, NULL);
1000
1001       ops->beneath->to_resume (ops->beneath, ptid, step, signal);
1002     }
1003
1004   /* We are about to start executing the inferior (or simulate it),
1005      let's register it with the event loop.  */
1006   if (target_can_async_p ())
1007     target_async (1);
1008 }
1009
1010 static int record_full_get_sig = 0;
1011
1012 /* SIGINT signal handler, registered by "to_wait" method.  */
1013
1014 static void
1015 record_full_sig_handler (int signo)
1016 {
1017   if (record_debug)
1018     fprintf_unfiltered (gdb_stdlog, "Process record: get a signal\n");
1019
1020   /* It will break the running inferior in replay mode.  */
1021   record_full_resume_step = 1;
1022
1023   /* It will let record_full_wait set inferior status to get the signal
1024      SIGINT.  */
1025   record_full_get_sig = 1;
1026 }
1027
1028 static void
1029 record_full_wait_cleanups (void *ignore)
1030 {
1031   if (execution_direction == EXEC_REVERSE)
1032     {
1033       if (record_full_list->next)
1034         record_full_list = record_full_list->next;
1035     }
1036   else
1037     record_full_list = record_full_list->prev;
1038 }
1039
1040 /* "to_wait" target method for process record target.
1041
1042    In record mode, the target is always run in singlestep mode
1043    (even when gdb says to continue).  The to_wait method intercepts
1044    the stop events and determines which ones are to be passed on to
1045    gdb.  Most stop events are just singlestep events that gdb is not
1046    to know about, so the to_wait method just records them and keeps
1047    singlestepping.
1048
1049    In replay mode, this function emulates the recorded execution log, 
1050    one instruction at a time (forward or backward), and determines 
1051    where to stop.  */
1052
1053 static ptid_t
1054 record_full_wait_1 (struct target_ops *ops,
1055                     ptid_t ptid, struct target_waitstatus *status,
1056                     int options)
1057 {
1058   struct cleanup *set_cleanups = record_full_gdb_operation_disable_set ();
1059
1060   if (record_debug)
1061     fprintf_unfiltered (gdb_stdlog,
1062                         "Process record: record_full_wait "
1063                         "record_full_resume_step = %d, "
1064                         "record_full_resumed = %d, direction=%s\n",
1065                         record_full_resume_step, record_full_resumed,
1066                         record_full_execution_dir == EXEC_FORWARD
1067                         ? "forward" : "reverse");
1068
1069   if (!record_full_resumed)
1070     {
1071       gdb_assert ((options & TARGET_WNOHANG) != 0);
1072
1073       /* No interesting event.  */
1074       status->kind = TARGET_WAITKIND_IGNORE;
1075       return minus_one_ptid;
1076     }
1077
1078   record_full_get_sig = 0;
1079   signal (SIGINT, record_full_sig_handler);
1080
1081   record_full_stop_reason = TARGET_STOPPED_BY_NO_REASON;
1082
1083   if (!RECORD_FULL_IS_REPLAY && ops != &record_full_core_ops)
1084     {
1085       if (record_full_resume_step)
1086         {
1087           /* This is a single step.  */
1088           return ops->beneath->to_wait (ops->beneath, ptid, status, options);
1089         }
1090       else
1091         {
1092           /* This is not a single step.  */
1093           ptid_t ret;
1094           CORE_ADDR tmp_pc;
1095           struct gdbarch *gdbarch = target_thread_architecture (inferior_ptid);
1096
1097           while (1)
1098             {
1099               struct thread_info *tp;
1100
1101               ret = ops->beneath->to_wait (ops->beneath, ptid, status, options);
1102               if (status->kind == TARGET_WAITKIND_IGNORE)
1103                 {
1104                   if (record_debug)
1105                     fprintf_unfiltered (gdb_stdlog,
1106                                         "Process record: record_full_wait "
1107                                         "target beneath not done yet\n");
1108                   return ret;
1109                 }
1110
1111               ALL_NON_EXITED_THREADS (tp)
1112                 delete_single_step_breakpoints (tp);
1113
1114               if (record_full_resume_step)
1115                 return ret;
1116
1117               /* Is this a SIGTRAP?  */
1118               if (status->kind == TARGET_WAITKIND_STOPPED
1119                   && status->value.sig == GDB_SIGNAL_TRAP)
1120                 {
1121                   struct regcache *regcache;
1122                   struct address_space *aspace;
1123                   enum target_stop_reason *stop_reason_p
1124                     = &record_full_stop_reason;
1125
1126                   /* Yes -- this is likely our single-step finishing,
1127                      but check if there's any reason the core would be
1128                      interested in the event.  */
1129
1130                   registers_changed ();
1131                   regcache = get_current_regcache ();
1132                   tmp_pc = regcache_read_pc (regcache);
1133                   aspace = get_regcache_aspace (regcache);
1134
1135                   if (target_stopped_by_watchpoint ())
1136                     {
1137                       /* Always interested in watchpoints.  */
1138                     }
1139                   else if (record_check_stopped_by_breakpoint (aspace, tmp_pc,
1140                                                                stop_reason_p))
1141                     {
1142                       /* There is a breakpoint here.  Let the core
1143                          handle it.  */
1144                     }
1145                   else
1146                     {
1147                       /* This is a single-step trap.  Record the
1148                          insn and issue another step.
1149                          FIXME: this part can be a random SIGTRAP too.
1150                          But GDB cannot handle it.  */
1151                       int step = 1;
1152
1153                       if (!record_full_message_wrapper_safe (regcache,
1154                                                              GDB_SIGNAL_0))
1155                         {
1156                            status->kind = TARGET_WAITKIND_STOPPED;
1157                            status->value.sig = GDB_SIGNAL_0;
1158                            break;
1159                         }
1160
1161                       if (gdbarch_software_single_step_p (gdbarch))
1162                         {
1163                           /* Try to insert the software single step breakpoint.
1164                              If insert success, set step to 0.  */
1165                           set_executing (inferior_ptid, 0);
1166                           reinit_frame_cache ();
1167                           if (gdbarch_software_single_step (gdbarch,
1168                                                             get_current_frame ()))
1169                             step = 0;
1170                           set_executing (inferior_ptid, 1);
1171                         }
1172
1173                       if (record_debug)
1174                         fprintf_unfiltered (gdb_stdlog,
1175                                             "Process record: record_full_wait "
1176                                             "issuing one more step in the "
1177                                             "target beneath\n");
1178                       ops->beneath->to_resume (ops->beneath, ptid, step,
1179                                                GDB_SIGNAL_0);
1180                       continue;
1181                     }
1182                 }
1183
1184               /* The inferior is broken by a breakpoint or a signal.  */
1185               break;
1186             }
1187
1188           return ret;
1189         }
1190     }
1191   else
1192     {
1193       struct regcache *regcache = get_current_regcache ();
1194       struct gdbarch *gdbarch = get_regcache_arch (regcache);
1195       struct address_space *aspace = get_regcache_aspace (regcache);
1196       int continue_flag = 1;
1197       int first_record_full_end = 1;
1198       struct cleanup *old_cleanups
1199         = make_cleanup (record_full_wait_cleanups, 0);
1200       CORE_ADDR tmp_pc;
1201
1202       record_full_stop_reason = TARGET_STOPPED_BY_NO_REASON;
1203       status->kind = TARGET_WAITKIND_STOPPED;
1204
1205       /* Check breakpoint when forward execute.  */
1206       if (execution_direction == EXEC_FORWARD)
1207         {
1208           tmp_pc = regcache_read_pc (regcache);
1209           if (record_check_stopped_by_breakpoint (aspace, tmp_pc,
1210                                                   &record_full_stop_reason))
1211             {
1212               if (record_debug)
1213                 fprintf_unfiltered (gdb_stdlog,
1214                                     "Process record: break at %s.\n",
1215                                     paddress (gdbarch, tmp_pc));
1216               goto replay_out;
1217             }
1218         }
1219
1220       /* If GDB is in terminal_inferior mode, it will not get the signal.
1221          And in GDB replay mode, GDB doesn't need to be in terminal_inferior
1222          mode, because inferior will not executed.
1223          Then set it to terminal_ours to make GDB get the signal.  */
1224       target_terminal_ours ();
1225
1226       /* In EXEC_FORWARD mode, record_full_list points to the tail of prev
1227          instruction.  */
1228       if (execution_direction == EXEC_FORWARD && record_full_list->next)
1229         record_full_list = record_full_list->next;
1230
1231       /* Loop over the record_full_list, looking for the next place to
1232          stop.  */
1233       do
1234         {
1235           /* Check for beginning and end of log.  */
1236           if (execution_direction == EXEC_REVERSE
1237               && record_full_list == &record_full_first)
1238             {
1239               /* Hit beginning of record log in reverse.  */
1240               status->kind = TARGET_WAITKIND_NO_HISTORY;
1241               break;
1242             }
1243           if (execution_direction != EXEC_REVERSE && !record_full_list->next)
1244             {
1245               /* Hit end of record log going forward.  */
1246               status->kind = TARGET_WAITKIND_NO_HISTORY;
1247               break;
1248             }
1249
1250           record_full_exec_insn (regcache, gdbarch, record_full_list);
1251
1252           if (record_full_list->type == record_full_end)
1253             {
1254               if (record_debug > 1)
1255                 fprintf_unfiltered (gdb_stdlog,
1256                                     "Process record: record_full_end %s to "
1257                                     "inferior.\n",
1258                                     host_address_to_string (record_full_list));
1259
1260               if (first_record_full_end && execution_direction == EXEC_REVERSE)
1261                 {
1262                   /* When reverse excute, the first record_full_end is the
1263                      part of current instruction.  */
1264                   first_record_full_end = 0;
1265                 }
1266               else
1267                 {
1268                   /* In EXEC_REVERSE mode, this is the record_full_end of prev
1269                      instruction.
1270                      In EXEC_FORWARD mode, this is the record_full_end of
1271                      current instruction.  */
1272                   /* step */
1273                   if (record_full_resume_step)
1274                     {
1275                       if (record_debug > 1)
1276                         fprintf_unfiltered (gdb_stdlog,
1277                                             "Process record: step.\n");
1278                       continue_flag = 0;
1279                     }
1280
1281                   /* check breakpoint */
1282                   tmp_pc = regcache_read_pc (regcache);
1283                   if (record_check_stopped_by_breakpoint (aspace, tmp_pc,
1284                                                           &record_full_stop_reason))
1285                     {
1286                       if (record_debug)
1287                         fprintf_unfiltered (gdb_stdlog,
1288                                             "Process record: break "
1289                                             "at %s.\n",
1290                                             paddress (gdbarch, tmp_pc));
1291
1292                       continue_flag = 0;
1293                     }
1294
1295                   if (record_full_stop_reason == TARGET_STOPPED_BY_WATCHPOINT)
1296                     {
1297                       if (record_debug)
1298                         fprintf_unfiltered (gdb_stdlog,
1299                                             "Process record: hit hw "
1300                                             "watchpoint.\n");
1301                       continue_flag = 0;
1302                     }
1303                   /* Check target signal */
1304                   if (record_full_list->u.end.sigval != GDB_SIGNAL_0)
1305                     /* FIXME: better way to check */
1306                     continue_flag = 0;
1307                 }
1308             }
1309
1310           if (continue_flag)
1311             {
1312               if (execution_direction == EXEC_REVERSE)
1313                 {
1314                   if (record_full_list->prev)
1315                     record_full_list = record_full_list->prev;
1316                 }
1317               else
1318                 {
1319                   if (record_full_list->next)
1320                     record_full_list = record_full_list->next;
1321                 }
1322             }
1323         }
1324       while (continue_flag);
1325
1326 replay_out:
1327       if (record_full_get_sig)
1328         status->value.sig = GDB_SIGNAL_INT;
1329       else if (record_full_list->u.end.sigval != GDB_SIGNAL_0)
1330         /* FIXME: better way to check */
1331         status->value.sig = record_full_list->u.end.sigval;
1332       else
1333         status->value.sig = GDB_SIGNAL_TRAP;
1334
1335       discard_cleanups (old_cleanups);
1336     }
1337
1338   signal (SIGINT, handle_sigint);
1339
1340   do_cleanups (set_cleanups);
1341   return inferior_ptid;
1342 }
1343
1344 static ptid_t
1345 record_full_wait (struct target_ops *ops,
1346                   ptid_t ptid, struct target_waitstatus *status,
1347                   int options)
1348 {
1349   ptid_t return_ptid;
1350
1351   return_ptid = record_full_wait_1 (ops, ptid, status, options);
1352   if (status->kind != TARGET_WAITKIND_IGNORE)
1353     {
1354       /* We're reporting a stop.  Make sure any spurious
1355          target_wait(WNOHANG) doesn't advance the target until the
1356          core wants us resumed again.  */
1357       record_full_resumed = 0;
1358     }
1359   return return_ptid;
1360 }
1361
1362 static int
1363 record_full_stopped_by_watchpoint (struct target_ops *ops)
1364 {
1365   if (RECORD_FULL_IS_REPLAY)
1366     return record_full_stop_reason == TARGET_STOPPED_BY_WATCHPOINT;
1367   else
1368     return ops->beneath->to_stopped_by_watchpoint (ops->beneath);
1369 }
1370
1371 static int
1372 record_full_stopped_data_address (struct target_ops *ops, CORE_ADDR *addr_p)
1373 {
1374   if (RECORD_FULL_IS_REPLAY)
1375     return 0;
1376   else
1377     return ops->beneath->to_stopped_data_address (ops->beneath, addr_p);
1378 }
1379
1380 /* The to_stopped_by_sw_breakpoint method of target record-full.  */
1381
1382 static int
1383 record_full_stopped_by_sw_breakpoint (struct target_ops *ops)
1384 {
1385   return record_full_stop_reason == TARGET_STOPPED_BY_SW_BREAKPOINT;
1386 }
1387
1388 /* The to_supports_stopped_by_sw_breakpoint method of target
1389    record-full.  */
1390
1391 static int
1392 record_full_supports_stopped_by_sw_breakpoint (struct target_ops *ops)
1393 {
1394   return 1;
1395 }
1396
1397 /* The to_stopped_by_hw_breakpoint method of target record-full.  */
1398
1399 static int
1400 record_full_stopped_by_hw_breakpoint (struct target_ops *ops)
1401 {
1402   return record_full_stop_reason == TARGET_STOPPED_BY_HW_BREAKPOINT;
1403 }
1404
1405 /* The to_supports_stopped_by_sw_breakpoint method of target
1406    record-full.  */
1407
1408 static int
1409 record_full_supports_stopped_by_hw_breakpoint (struct target_ops *ops)
1410 {
1411   return 1;
1412 }
1413
1414 /* Record registers change (by user or by GDB) to list as an instruction.  */
1415
1416 static void
1417 record_full_registers_change (struct regcache *regcache, int regnum)
1418 {
1419   /* Check record_full_insn_num.  */
1420   record_full_check_insn_num (0);
1421
1422   record_full_arch_list_head = NULL;
1423   record_full_arch_list_tail = NULL;
1424
1425   if (regnum < 0)
1426     {
1427       int i;
1428
1429       for (i = 0; i < gdbarch_num_regs (get_regcache_arch (regcache)); i++)
1430         {
1431           if (record_full_arch_list_add_reg (regcache, i))
1432             {
1433               record_full_list_release (record_full_arch_list_tail);
1434               error (_("Process record: failed to record execution log."));
1435             }
1436         }
1437     }
1438   else
1439     {
1440       if (record_full_arch_list_add_reg (regcache, regnum))
1441         {
1442           record_full_list_release (record_full_arch_list_tail);
1443           error (_("Process record: failed to record execution log."));
1444         }
1445     }
1446   if (record_full_arch_list_add_end ())
1447     {
1448       record_full_list_release (record_full_arch_list_tail);
1449       error (_("Process record: failed to record execution log."));
1450     }
1451   record_full_list->next = record_full_arch_list_head;
1452   record_full_arch_list_head->prev = record_full_list;
1453   record_full_list = record_full_arch_list_tail;
1454
1455   if (record_full_insn_num == record_full_insn_max_num)
1456     record_full_list_release_first ();
1457   else
1458     record_full_insn_num++;
1459 }
1460
1461 /* "to_store_registers" method for process record target.  */
1462
1463 static void
1464 record_full_store_registers (struct target_ops *ops,
1465                              struct regcache *regcache,
1466                              int regno)
1467 {
1468   if (!record_full_gdb_operation_disable)
1469     {
1470       if (RECORD_FULL_IS_REPLAY)
1471         {
1472           int n;
1473
1474           /* Let user choose if he wants to write register or not.  */
1475           if (regno < 0)
1476             n =
1477               query (_("Because GDB is in replay mode, changing the "
1478                        "value of a register will make the execution "
1479                        "log unusable from this point onward.  "
1480                        "Change all registers?"));
1481           else
1482             n =
1483               query (_("Because GDB is in replay mode, changing the value "
1484                        "of a register will make the execution log unusable "
1485                        "from this point onward.  Change register %s?"),
1486                       gdbarch_register_name (get_regcache_arch (regcache),
1487                                                regno));
1488
1489           if (!n)
1490             {
1491               /* Invalidate the value of regcache that was set in function
1492                  "regcache_raw_write".  */
1493               if (regno < 0)
1494                 {
1495                   int i;
1496
1497                   for (i = 0;
1498                        i < gdbarch_num_regs (get_regcache_arch (regcache));
1499                        i++)
1500                     regcache_invalidate (regcache, i);
1501                 }
1502               else
1503                 regcache_invalidate (regcache, regno);
1504
1505               error (_("Process record canceled the operation."));
1506             }
1507
1508           /* Destroy the record from here forward.  */
1509           record_full_list_release_following (record_full_list);
1510         }
1511
1512       record_full_registers_change (regcache, regno);
1513     }
1514   ops->beneath->to_store_registers (ops->beneath, regcache, regno);
1515 }
1516
1517 /* "to_xfer_partial" method.  Behavior is conditional on
1518    RECORD_FULL_IS_REPLAY.
1519    In replay mode, we cannot write memory unles we are willing to
1520    invalidate the record/replay log from this point forward.  */
1521
1522 static enum target_xfer_status
1523 record_full_xfer_partial (struct target_ops *ops, enum target_object object,
1524                           const char *annex, gdb_byte *readbuf,
1525                           const gdb_byte *writebuf, ULONGEST offset,
1526                           ULONGEST len, ULONGEST *xfered_len)
1527 {
1528   if (!record_full_gdb_operation_disable
1529       && (object == TARGET_OBJECT_MEMORY
1530           || object == TARGET_OBJECT_RAW_MEMORY) && writebuf)
1531     {
1532       if (RECORD_FULL_IS_REPLAY)
1533         {
1534           /* Let user choose if he wants to write memory or not.  */
1535           if (!query (_("Because GDB is in replay mode, writing to memory "
1536                         "will make the execution log unusable from this "
1537                         "point onward.  Write memory at address %s?"),
1538                        paddress (target_gdbarch (), offset)))
1539             error (_("Process record canceled the operation."));
1540
1541           /* Destroy the record from here forward.  */
1542           record_full_list_release_following (record_full_list);
1543         }
1544
1545       /* Check record_full_insn_num */
1546       record_full_check_insn_num (0);
1547
1548       /* Record registers change to list as an instruction.  */
1549       record_full_arch_list_head = NULL;
1550       record_full_arch_list_tail = NULL;
1551       if (record_full_arch_list_add_mem (offset, len))
1552         {
1553           record_full_list_release (record_full_arch_list_tail);
1554           if (record_debug)
1555             fprintf_unfiltered (gdb_stdlog,
1556                                 "Process record: failed to record "
1557                                 "execution log.");
1558           return TARGET_XFER_E_IO;
1559         }
1560       if (record_full_arch_list_add_end ())
1561         {
1562           record_full_list_release (record_full_arch_list_tail);
1563           if (record_debug)
1564             fprintf_unfiltered (gdb_stdlog,
1565                                 "Process record: failed to record "
1566                                 "execution log.");
1567           return TARGET_XFER_E_IO;
1568         }
1569       record_full_list->next = record_full_arch_list_head;
1570       record_full_arch_list_head->prev = record_full_list;
1571       record_full_list = record_full_arch_list_tail;
1572
1573       if (record_full_insn_num == record_full_insn_max_num)
1574         record_full_list_release_first ();
1575       else
1576         record_full_insn_num++;
1577     }
1578
1579   return ops->beneath->to_xfer_partial (ops->beneath, object, annex,
1580                                         readbuf, writebuf, offset,
1581                                         len, xfered_len);
1582 }
1583
1584 /* This structure represents a breakpoint inserted while the record
1585    target is active.  We use this to know when to install/remove
1586    breakpoints in/from the target beneath.  For example, a breakpoint
1587    may be inserted while recording, but removed when not replaying nor
1588    recording.  In that case, the breakpoint had not been inserted on
1589    the target beneath, so we should not try to remove it there.  */
1590
1591 struct record_full_breakpoint
1592 {
1593   /* The address and address space the breakpoint was set at.  */
1594   struct address_space *address_space;
1595   CORE_ADDR addr;
1596
1597   /* True when the breakpoint has been also installed in the target
1598      beneath.  This will be false for breakpoints set during replay or
1599      when recording.  */
1600   int in_target_beneath;
1601 };
1602
1603 typedef struct record_full_breakpoint *record_full_breakpoint_p;
1604 DEF_VEC_P(record_full_breakpoint_p);
1605
1606 /* The list of breakpoints inserted while the record target is
1607    active.  */
1608 VEC(record_full_breakpoint_p) *record_full_breakpoints = NULL;
1609
1610 static void
1611 record_full_sync_record_breakpoints (struct bp_location *loc, void *data)
1612 {
1613   if (loc->loc_type != bp_loc_software_breakpoint)
1614       return;
1615
1616   if (loc->inserted)
1617     {
1618       struct record_full_breakpoint *bp = XNEW (struct record_full_breakpoint);
1619
1620       bp->addr = loc->target_info.placed_address;
1621       bp->address_space = loc->target_info.placed_address_space;
1622
1623       bp->in_target_beneath = 1;
1624
1625       VEC_safe_push (record_full_breakpoint_p, record_full_breakpoints, bp);
1626     }
1627 }
1628
1629 /* Sync existing breakpoints to record_full_breakpoints.  */
1630
1631 static void
1632 record_full_init_record_breakpoints (void)
1633 {
1634   VEC_free (record_full_breakpoint_p, record_full_breakpoints);
1635
1636   iterate_over_bp_locations (record_full_sync_record_breakpoints);
1637 }
1638
1639 /* Behavior is conditional on RECORD_FULL_IS_REPLAY.  We will not actually
1640    insert or remove breakpoints in the real target when replaying, nor
1641    when recording.  */
1642
1643 static int
1644 record_full_insert_breakpoint (struct target_ops *ops,
1645                                struct gdbarch *gdbarch,
1646                                struct bp_target_info *bp_tgt)
1647 {
1648   struct record_full_breakpoint *bp;
1649   int in_target_beneath = 0;
1650
1651   if (!RECORD_FULL_IS_REPLAY)
1652     {
1653       /* When recording, we currently always single-step, so we don't
1654          really need to install regular breakpoints in the inferior.
1655          However, we do have to insert software single-step
1656          breakpoints, in case the target can't hardware step.  To keep
1657          things single, we always insert.  */
1658       struct cleanup *old_cleanups;
1659       int ret;
1660
1661       old_cleanups = record_full_gdb_operation_disable_set ();
1662       ret = ops->beneath->to_insert_breakpoint (ops->beneath, gdbarch, bp_tgt);
1663       do_cleanups (old_cleanups);
1664
1665       if (ret != 0)
1666         return ret;
1667
1668       in_target_beneath = 1;
1669     }
1670
1671   bp = XNEW (struct record_full_breakpoint);
1672   bp->addr = bp_tgt->placed_address;
1673   bp->address_space = bp_tgt->placed_address_space;
1674   bp->in_target_beneath = in_target_beneath;
1675   VEC_safe_push (record_full_breakpoint_p, record_full_breakpoints, bp);
1676   return 0;
1677 }
1678
1679 /* "to_remove_breakpoint" method for process record target.  */
1680
1681 static int
1682 record_full_remove_breakpoint (struct target_ops *ops,
1683                                struct gdbarch *gdbarch,
1684                                struct bp_target_info *bp_tgt)
1685 {
1686   struct record_full_breakpoint *bp;
1687   int ix;
1688
1689   for (ix = 0;
1690        VEC_iterate (record_full_breakpoint_p,
1691                     record_full_breakpoints, ix, bp);
1692        ++ix)
1693     {
1694       if (bp->addr == bp_tgt->placed_address
1695           && bp->address_space == bp_tgt->placed_address_space)
1696         {
1697           if (bp->in_target_beneath)
1698             {
1699               struct cleanup *old_cleanups;
1700               int ret;
1701
1702               old_cleanups = record_full_gdb_operation_disable_set ();
1703               ret = ops->beneath->to_remove_breakpoint (ops->beneath, gdbarch,
1704                                                         bp_tgt);
1705               do_cleanups (old_cleanups);
1706
1707               if (ret != 0)
1708                 return ret;
1709             }
1710
1711           VEC_unordered_remove (record_full_breakpoint_p,
1712                                 record_full_breakpoints, ix);
1713           return 0;
1714         }
1715     }
1716
1717   gdb_assert_not_reached ("removing unknown breakpoint");
1718 }
1719
1720 /* "to_can_execute_reverse" method for process record target.  */
1721
1722 static int
1723 record_full_can_execute_reverse (struct target_ops *self)
1724 {
1725   return 1;
1726 }
1727
1728 /* "to_get_bookmark" method for process record and prec over core.  */
1729
1730 static gdb_byte *
1731 record_full_get_bookmark (struct target_ops *self, const char *args,
1732                           int from_tty)
1733 {
1734   char *ret = NULL;
1735
1736   /* Return stringified form of instruction count.  */
1737   if (record_full_list && record_full_list->type == record_full_end)
1738     ret = xstrdup (pulongest (record_full_list->u.end.insn_num));
1739
1740   if (record_debug)
1741     {
1742       if (ret)
1743         fprintf_unfiltered (gdb_stdlog,
1744                             "record_full_get_bookmark returns %s\n", ret);
1745       else
1746         fprintf_unfiltered (gdb_stdlog,
1747                             "record_full_get_bookmark returns NULL\n");
1748     }
1749   return (gdb_byte *) ret;
1750 }
1751
1752 /* "to_goto_bookmark" method for process record and prec over core.  */
1753
1754 static void
1755 record_full_goto_bookmark (struct target_ops *self,
1756                            const gdb_byte *raw_bookmark, int from_tty)
1757 {
1758   const char *bookmark = (const char *) raw_bookmark;
1759   struct cleanup *cleanup = make_cleanup (null_cleanup, NULL);
1760
1761   if (record_debug)
1762     fprintf_unfiltered (gdb_stdlog,
1763                         "record_full_goto_bookmark receives %s\n", bookmark);
1764
1765   if (bookmark[0] == '\'' || bookmark[0] == '\"')
1766     {
1767       char *copy;
1768
1769       if (bookmark[strlen (bookmark) - 1] != bookmark[0])
1770         error (_("Unbalanced quotes: %s"), bookmark);
1771
1772
1773       copy = savestring (bookmark + 1, strlen (bookmark) - 2);
1774       make_cleanup (xfree, copy);
1775       bookmark = copy;
1776     }
1777
1778   record_goto (bookmark);
1779
1780   do_cleanups (cleanup);
1781 }
1782
1783 static enum exec_direction_kind
1784 record_full_execution_direction (struct target_ops *self)
1785 {
1786   return record_full_execution_dir;
1787 }
1788
1789 static void
1790 record_full_info (struct target_ops *self)
1791 {
1792   struct record_full_entry *p;
1793
1794   if (RECORD_FULL_IS_REPLAY)
1795     printf_filtered (_("Replay mode:\n"));
1796   else
1797     printf_filtered (_("Record mode:\n"));
1798
1799   /* Find entry for first actual instruction in the log.  */
1800   for (p = record_full_first.next;
1801        p != NULL && p->type != record_full_end;
1802        p = p->next)
1803     ;
1804
1805   /* Do we have a log at all?  */
1806   if (p != NULL && p->type == record_full_end)
1807     {
1808       /* Display instruction number for first instruction in the log.  */
1809       printf_filtered (_("Lowest recorded instruction number is %s.\n"),
1810                        pulongest (p->u.end.insn_num));
1811
1812       /* If in replay mode, display where we are in the log.  */
1813       if (RECORD_FULL_IS_REPLAY)
1814         printf_filtered (_("Current instruction number is %s.\n"),
1815                          pulongest (record_full_list->u.end.insn_num));
1816
1817       /* Display instruction number for last instruction in the log.  */
1818       printf_filtered (_("Highest recorded instruction number is %s.\n"),
1819                        pulongest (record_full_insn_count));
1820
1821       /* Display log count.  */
1822       printf_filtered (_("Log contains %u instructions.\n"),
1823                        record_full_insn_num);
1824     }
1825   else
1826     printf_filtered (_("No instructions have been logged.\n"));
1827
1828   /* Display max log size.  */
1829   printf_filtered (_("Max logged instructions is %u.\n"),
1830                    record_full_insn_max_num);
1831 }
1832
1833 /* The "to_record_delete" target method.  */
1834
1835 static void
1836 record_full_delete (struct target_ops *self)
1837 {
1838   record_full_list_release_following (record_full_list);
1839 }
1840
1841 /* The "to_record_is_replaying" target method.  */
1842
1843 static int
1844 record_full_is_replaying (struct target_ops *self, ptid_t ptid)
1845 {
1846   return RECORD_FULL_IS_REPLAY;
1847 }
1848
1849 /* The "to_record_will_replay" target method.  */
1850
1851 static int
1852 record_full_will_replay (struct target_ops *self, ptid_t ptid, int dir)
1853 {
1854   /* We can currently only record when executing forwards.  Should we be able
1855      to record when executing backwards on targets that support reverse
1856      execution, this needs to be changed.  */
1857
1858   return RECORD_FULL_IS_REPLAY || dir == EXEC_REVERSE;
1859 }
1860
1861 /* Go to a specific entry.  */
1862
1863 static void
1864 record_full_goto_entry (struct record_full_entry *p)
1865 {
1866   if (p == NULL)
1867     error (_("Target insn not found."));
1868   else if (p == record_full_list)
1869     error (_("Already at target insn."));
1870   else if (p->u.end.insn_num > record_full_list->u.end.insn_num)
1871     {
1872       printf_filtered (_("Go forward to insn number %s\n"),
1873                        pulongest (p->u.end.insn_num));
1874       record_full_goto_insn (p, EXEC_FORWARD);
1875     }
1876   else
1877     {
1878       printf_filtered (_("Go backward to insn number %s\n"),
1879                        pulongest (p->u.end.insn_num));
1880       record_full_goto_insn (p, EXEC_REVERSE);
1881     }
1882
1883   registers_changed ();
1884   reinit_frame_cache ();
1885   stop_pc = regcache_read_pc (get_current_regcache ());
1886   print_stack_frame (get_selected_frame (NULL), 1, SRC_AND_LOC, 1);
1887 }
1888
1889 /* The "to_goto_record_begin" target method.  */
1890
1891 static void
1892 record_full_goto_begin (struct target_ops *self)
1893 {
1894   struct record_full_entry *p = NULL;
1895
1896   for (p = &record_full_first; p != NULL; p = p->next)
1897     if (p->type == record_full_end)
1898       break;
1899
1900   record_full_goto_entry (p);
1901 }
1902
1903 /* The "to_goto_record_end" target method.  */
1904
1905 static void
1906 record_full_goto_end (struct target_ops *self)
1907 {
1908   struct record_full_entry *p = NULL;
1909
1910   for (p = record_full_list; p->next != NULL; p = p->next)
1911     ;
1912   for (; p!= NULL; p = p->prev)
1913     if (p->type == record_full_end)
1914       break;
1915
1916   record_full_goto_entry (p);
1917 }
1918
1919 /* The "to_goto_record" target method.  */
1920
1921 static void
1922 record_full_goto (struct target_ops *self, ULONGEST target_insn)
1923 {
1924   struct record_full_entry *p = NULL;
1925
1926   for (p = &record_full_first; p != NULL; p = p->next)
1927     if (p->type == record_full_end && p->u.end.insn_num == target_insn)
1928       break;
1929
1930   record_full_goto_entry (p);
1931 }
1932
1933 /* The "to_record_stop_replaying" target method.  */
1934
1935 static void
1936 record_full_stop_replaying (struct target_ops *self)
1937 {
1938   record_full_goto_end (self);
1939 }
1940
1941 static void
1942 init_record_full_ops (void)
1943 {
1944   record_full_ops.to_shortname = "record-full";
1945   record_full_ops.to_longname = "Process record and replay target";
1946   record_full_ops.to_doc =
1947     "Log program while executing and replay execution from log.";
1948   record_full_ops.to_open = record_full_open;
1949   record_full_ops.to_close = record_full_close;
1950   record_full_ops.to_async = record_full_async;
1951   record_full_ops.to_resume = record_full_resume;
1952   record_full_ops.to_wait = record_full_wait;
1953   record_full_ops.to_disconnect = record_disconnect;
1954   record_full_ops.to_detach = record_detach;
1955   record_full_ops.to_mourn_inferior = record_mourn_inferior;
1956   record_full_ops.to_kill = record_kill;
1957   record_full_ops.to_store_registers = record_full_store_registers;
1958   record_full_ops.to_xfer_partial = record_full_xfer_partial;
1959   record_full_ops.to_insert_breakpoint = record_full_insert_breakpoint;
1960   record_full_ops.to_remove_breakpoint = record_full_remove_breakpoint;
1961   record_full_ops.to_stopped_by_watchpoint = record_full_stopped_by_watchpoint;
1962   record_full_ops.to_stopped_data_address = record_full_stopped_data_address;
1963   record_full_ops.to_stopped_by_sw_breakpoint
1964     = record_full_stopped_by_sw_breakpoint;
1965   record_full_ops.to_supports_stopped_by_sw_breakpoint
1966     = record_full_supports_stopped_by_sw_breakpoint;
1967   record_full_ops.to_stopped_by_hw_breakpoint
1968     = record_full_stopped_by_hw_breakpoint;
1969   record_full_ops.to_supports_stopped_by_hw_breakpoint
1970     = record_full_supports_stopped_by_hw_breakpoint;
1971   record_full_ops.to_can_execute_reverse = record_full_can_execute_reverse;
1972   record_full_ops.to_stratum = record_stratum;
1973   /* Add bookmark target methods.  */
1974   record_full_ops.to_get_bookmark = record_full_get_bookmark;
1975   record_full_ops.to_goto_bookmark = record_full_goto_bookmark;
1976   record_full_ops.to_execution_direction = record_full_execution_direction;
1977   record_full_ops.to_info_record = record_full_info;
1978   record_full_ops.to_save_record = record_full_save;
1979   record_full_ops.to_delete_record = record_full_delete;
1980   record_full_ops.to_record_is_replaying = record_full_is_replaying;
1981   record_full_ops.to_record_will_replay = record_full_will_replay;
1982   record_full_ops.to_record_stop_replaying = record_full_stop_replaying;
1983   record_full_ops.to_goto_record_begin = record_full_goto_begin;
1984   record_full_ops.to_goto_record_end = record_full_goto_end;
1985   record_full_ops.to_goto_record = record_full_goto;
1986   record_full_ops.to_magic = OPS_MAGIC;
1987 }
1988
1989 /* "to_resume" method for prec over corefile.  */
1990
1991 static void
1992 record_full_core_resume (struct target_ops *ops, ptid_t ptid, int step,
1993                          enum gdb_signal signal)
1994 {
1995   record_full_resume_step = step;
1996   record_full_resumed = 1;
1997   record_full_execution_dir = execution_direction;
1998
1999   /* We are about to start executing the inferior (or simulate it),
2000      let's register it with the event loop.  */
2001   if (target_can_async_p ())
2002     target_async (1);
2003 }
2004
2005 /* "to_kill" method for prec over corefile.  */
2006
2007 static void
2008 record_full_core_kill (struct target_ops *ops)
2009 {
2010   if (record_debug)
2011     fprintf_unfiltered (gdb_stdlog, "Process record: record_full_core_kill\n");
2012
2013   unpush_target (&record_full_core_ops);
2014 }
2015
2016 /* "to_fetch_registers" method for prec over corefile.  */
2017
2018 static void
2019 record_full_core_fetch_registers (struct target_ops *ops,
2020                                   struct regcache *regcache,
2021                                   int regno)
2022 {
2023   if (regno < 0)
2024     {
2025       int num = gdbarch_num_regs (get_regcache_arch (regcache));
2026       int i;
2027
2028       for (i = 0; i < num; i ++)
2029         regcache_raw_supply (regcache, i,
2030                              record_full_core_regbuf + MAX_REGISTER_SIZE * i);
2031     }
2032   else
2033     regcache_raw_supply (regcache, regno,
2034                          record_full_core_regbuf + MAX_REGISTER_SIZE * regno);
2035 }
2036
2037 /* "to_prepare_to_store" method for prec over corefile.  */
2038
2039 static void
2040 record_full_core_prepare_to_store (struct target_ops *self,
2041                                    struct regcache *regcache)
2042 {
2043 }
2044
2045 /* "to_store_registers" method for prec over corefile.  */
2046
2047 static void
2048 record_full_core_store_registers (struct target_ops *ops,
2049                              struct regcache *regcache,
2050                              int regno)
2051 {
2052   if (record_full_gdb_operation_disable)
2053     regcache_raw_collect (regcache, regno,
2054                           record_full_core_regbuf + MAX_REGISTER_SIZE * regno);
2055   else
2056     error (_("You can't do that without a process to debug."));
2057 }
2058
2059 /* "to_xfer_partial" method for prec over corefile.  */
2060
2061 static enum target_xfer_status
2062 record_full_core_xfer_partial (struct target_ops *ops,
2063                                enum target_object object,
2064                                const char *annex, gdb_byte *readbuf,
2065                                const gdb_byte *writebuf, ULONGEST offset,
2066                                ULONGEST len, ULONGEST *xfered_len)
2067 {
2068   if (object == TARGET_OBJECT_MEMORY)
2069     {
2070       if (record_full_gdb_operation_disable || !writebuf)
2071         {
2072           struct target_section *p;
2073
2074           for (p = record_full_core_start; p < record_full_core_end; p++)
2075             {
2076               if (offset >= p->addr)
2077                 {
2078                   struct record_full_core_buf_entry *entry;
2079                   ULONGEST sec_offset;
2080
2081                   if (offset >= p->endaddr)
2082                     continue;
2083
2084                   if (offset + len > p->endaddr)
2085                     len = p->endaddr - offset;
2086
2087                   sec_offset = offset - p->addr;
2088
2089                   /* Read readbuf or write writebuf p, offset, len.  */
2090                   /* Check flags.  */
2091                   if (p->the_bfd_section->flags & SEC_CONSTRUCTOR
2092                       || (p->the_bfd_section->flags & SEC_HAS_CONTENTS) == 0)
2093                     {
2094                       if (readbuf)
2095                         memset (readbuf, 0, len);
2096
2097                       *xfered_len = len;
2098                       return TARGET_XFER_OK;
2099                     }
2100                   /* Get record_full_core_buf_entry.  */
2101                   for (entry = record_full_core_buf_list; entry;
2102                        entry = entry->prev)
2103                     if (entry->p == p)
2104                       break;
2105                   if (writebuf)
2106                     {
2107                       if (!entry)
2108                         {
2109                           /* Add a new entry.  */
2110                           entry = XNEW (struct record_full_core_buf_entry);
2111                           entry->p = p;
2112                           if (!bfd_malloc_and_get_section
2113                                 (p->the_bfd_section->owner,
2114                                  p->the_bfd_section,
2115                                  &entry->buf))
2116                             {
2117                               xfree (entry);
2118                               return TARGET_XFER_EOF;
2119                             }
2120                           entry->prev = record_full_core_buf_list;
2121                           record_full_core_buf_list = entry;
2122                         }
2123
2124                       memcpy (entry->buf + sec_offset, writebuf,
2125                               (size_t) len);
2126                     }
2127                   else
2128                     {
2129                       if (!entry)
2130                         return ops->beneath->to_xfer_partial (ops->beneath,
2131                                                               object, annex,
2132                                                               readbuf, writebuf,
2133                                                               offset, len,
2134                                                               xfered_len);
2135
2136                       memcpy (readbuf, entry->buf + sec_offset,
2137                               (size_t) len);
2138                     }
2139
2140                   *xfered_len = len;
2141                   return TARGET_XFER_OK;
2142                 }
2143             }
2144
2145           return TARGET_XFER_E_IO;
2146         }
2147       else
2148         error (_("You can't do that without a process to debug."));
2149     }
2150
2151   return ops->beneath->to_xfer_partial (ops->beneath, object, annex,
2152                                         readbuf, writebuf, offset, len,
2153                                         xfered_len);
2154 }
2155
2156 /* "to_insert_breakpoint" method for prec over corefile.  */
2157
2158 static int
2159 record_full_core_insert_breakpoint (struct target_ops *ops,
2160                                     struct gdbarch *gdbarch,
2161                                     struct bp_target_info *bp_tgt)
2162 {
2163   return 0;
2164 }
2165
2166 /* "to_remove_breakpoint" method for prec over corefile.  */
2167
2168 static int
2169 record_full_core_remove_breakpoint (struct target_ops *ops,
2170                                     struct gdbarch *gdbarch,
2171                                     struct bp_target_info *bp_tgt)
2172 {
2173   return 0;
2174 }
2175
2176 /* "to_has_execution" method for prec over corefile.  */
2177
2178 static int
2179 record_full_core_has_execution (struct target_ops *ops, ptid_t the_ptid)
2180 {
2181   return 1;
2182 }
2183
2184 static void
2185 init_record_full_core_ops (void)
2186 {
2187   record_full_core_ops.to_shortname = "record-core";
2188   record_full_core_ops.to_longname = "Process record and replay target";
2189   record_full_core_ops.to_doc =
2190     "Log program while executing and replay execution from log.";
2191   record_full_core_ops.to_open = record_full_open;
2192   record_full_core_ops.to_close = record_full_close;
2193   record_full_core_ops.to_async = record_full_async;
2194   record_full_core_ops.to_resume = record_full_core_resume;
2195   record_full_core_ops.to_wait = record_full_wait;
2196   record_full_core_ops.to_kill = record_full_core_kill;
2197   record_full_core_ops.to_fetch_registers = record_full_core_fetch_registers;
2198   record_full_core_ops.to_prepare_to_store = record_full_core_prepare_to_store;
2199   record_full_core_ops.to_store_registers = record_full_core_store_registers;
2200   record_full_core_ops.to_xfer_partial = record_full_core_xfer_partial;
2201   record_full_core_ops.to_insert_breakpoint
2202     = record_full_core_insert_breakpoint;
2203   record_full_core_ops.to_remove_breakpoint
2204     = record_full_core_remove_breakpoint;
2205   record_full_core_ops.to_stopped_by_watchpoint
2206     = record_full_stopped_by_watchpoint;
2207   record_full_core_ops.to_stopped_data_address
2208     = record_full_stopped_data_address;
2209   record_full_core_ops.to_stopped_by_sw_breakpoint
2210     = record_full_stopped_by_sw_breakpoint;
2211   record_full_core_ops.to_supports_stopped_by_sw_breakpoint
2212     = record_full_supports_stopped_by_sw_breakpoint;
2213   record_full_core_ops.to_stopped_by_hw_breakpoint
2214     = record_full_stopped_by_hw_breakpoint;
2215   record_full_core_ops.to_supports_stopped_by_hw_breakpoint
2216     = record_full_supports_stopped_by_hw_breakpoint;
2217   record_full_core_ops.to_can_execute_reverse
2218     = record_full_can_execute_reverse;
2219   record_full_core_ops.to_has_execution = record_full_core_has_execution;
2220   record_full_core_ops.to_stratum = record_stratum;
2221   /* Add bookmark target methods.  */
2222   record_full_core_ops.to_get_bookmark = record_full_get_bookmark;
2223   record_full_core_ops.to_goto_bookmark = record_full_goto_bookmark;
2224   record_full_core_ops.to_execution_direction
2225     = record_full_execution_direction;
2226   record_full_core_ops.to_info_record = record_full_info;
2227   record_full_core_ops.to_delete_record = record_full_delete;
2228   record_full_core_ops.to_record_is_replaying = record_full_is_replaying;
2229   record_full_core_ops.to_record_will_replay = record_full_will_replay;
2230   record_full_core_ops.to_goto_record_begin = record_full_goto_begin;
2231   record_full_core_ops.to_goto_record_end = record_full_goto_end;
2232   record_full_core_ops.to_goto_record = record_full_goto;
2233   record_full_core_ops.to_magic = OPS_MAGIC;
2234 }
2235
2236 /* Record log save-file format
2237    Version 1 (never released)
2238
2239    Header:
2240      4 bytes: magic number htonl(0x20090829).
2241        NOTE: be sure to change whenever this file format changes!
2242
2243    Records:
2244      record_full_end:
2245        1 byte:  record type (record_full_end, see enum record_full_type).
2246      record_full_reg:
2247        1 byte:  record type (record_full_reg, see enum record_full_type).
2248        8 bytes: register id (network byte order).
2249        MAX_REGISTER_SIZE bytes: register value.
2250      record_full_mem:
2251        1 byte:  record type (record_full_mem, see enum record_full_type).
2252        8 bytes: memory length (network byte order).
2253        8 bytes: memory address (network byte order).
2254        n bytes: memory value (n == memory length).
2255
2256    Version 2
2257      4 bytes: magic number netorder32(0x20091016).
2258        NOTE: be sure to change whenever this file format changes!
2259
2260    Records:
2261      record_full_end:
2262        1 byte:  record type (record_full_end, see enum record_full_type).
2263        4 bytes: signal
2264        4 bytes: instruction count
2265      record_full_reg:
2266        1 byte:  record type (record_full_reg, see enum record_full_type).
2267        4 bytes: register id (network byte order).
2268        n bytes: register value (n == actual register size).
2269                 (eg. 4 bytes for x86 general registers).
2270      record_full_mem:
2271        1 byte:  record type (record_full_mem, see enum record_full_type).
2272        4 bytes: memory length (network byte order).
2273        8 bytes: memory address (network byte order).
2274        n bytes: memory value (n == memory length).
2275
2276 */
2277
2278 /* bfdcore_read -- read bytes from a core file section.  */
2279
2280 static inline void
2281 bfdcore_read (bfd *obfd, asection *osec, void *buf, int len, int *offset)
2282 {
2283   int ret = bfd_get_section_contents (obfd, osec, buf, *offset, len);
2284
2285   if (ret)
2286     *offset += len;
2287   else
2288     error (_("Failed to read %d bytes from core file %s ('%s')."),
2289            len, bfd_get_filename (obfd),
2290            bfd_errmsg (bfd_get_error ()));
2291 }
2292
2293 static inline uint64_t
2294 netorder64 (uint64_t input)
2295 {
2296   uint64_t ret;
2297
2298   store_unsigned_integer ((gdb_byte *) &ret, sizeof (ret), 
2299                           BFD_ENDIAN_BIG, input);
2300   return ret;
2301 }
2302
2303 static inline uint32_t
2304 netorder32 (uint32_t input)
2305 {
2306   uint32_t ret;
2307
2308   store_unsigned_integer ((gdb_byte *) &ret, sizeof (ret), 
2309                           BFD_ENDIAN_BIG, input);
2310   return ret;
2311 }
2312
2313 static inline uint16_t
2314 netorder16 (uint16_t input)
2315 {
2316   uint16_t ret;
2317
2318   store_unsigned_integer ((gdb_byte *) &ret, sizeof (ret), 
2319                           BFD_ENDIAN_BIG, input);
2320   return ret;
2321 }
2322
2323 /* Restore the execution log from a core_bfd file.  */
2324 static void
2325 record_full_restore (void)
2326 {
2327   uint32_t magic;
2328   struct cleanup *old_cleanups;
2329   struct record_full_entry *rec;
2330   asection *osec;
2331   uint32_t osec_size;
2332   int bfd_offset = 0;
2333   struct regcache *regcache;
2334
2335   /* We restore the execution log from the open core bfd,
2336      if there is one.  */
2337   if (core_bfd == NULL)
2338     return;
2339
2340   /* "record_full_restore" can only be called when record list is empty.  */
2341   gdb_assert (record_full_first.next == NULL);
2342  
2343   if (record_debug)
2344     fprintf_unfiltered (gdb_stdlog, "Restoring recording from core file.\n");
2345
2346   /* Now need to find our special note section.  */
2347   osec = bfd_get_section_by_name (core_bfd, "null0");
2348   if (record_debug)
2349     fprintf_unfiltered (gdb_stdlog, "Find precord section %s.\n",
2350                         osec ? "succeeded" : "failed");
2351   if (osec == NULL)
2352     return;
2353   osec_size = bfd_section_size (core_bfd, osec);
2354   if (record_debug)
2355     fprintf_unfiltered (gdb_stdlog, "%s", bfd_section_name (core_bfd, osec));
2356
2357   /* Check the magic code.  */
2358   bfdcore_read (core_bfd, osec, &magic, sizeof (magic), &bfd_offset);
2359   if (magic != RECORD_FULL_FILE_MAGIC)
2360     error (_("Version mis-match or file format error in core file %s."),
2361            bfd_get_filename (core_bfd));
2362   if (record_debug)
2363     fprintf_unfiltered (gdb_stdlog,
2364                         "  Reading 4-byte magic cookie "
2365                         "RECORD_FULL_FILE_MAGIC (0x%s)\n",
2366                         phex_nz (netorder32 (magic), 4));
2367
2368   /* Restore the entries in recfd into record_full_arch_list_head and
2369      record_full_arch_list_tail.  */
2370   record_full_arch_list_head = NULL;
2371   record_full_arch_list_tail = NULL;
2372   record_full_insn_num = 0;
2373   old_cleanups = make_cleanup (record_full_arch_list_cleanups, 0);
2374   regcache = get_current_regcache ();
2375
2376   while (1)
2377     {
2378       uint8_t rectype;
2379       uint32_t regnum, len, signal, count;
2380       uint64_t addr;
2381
2382       /* We are finished when offset reaches osec_size.  */
2383       if (bfd_offset >= osec_size)
2384         break;
2385       bfdcore_read (core_bfd, osec, &rectype, sizeof (rectype), &bfd_offset);
2386
2387       switch (rectype)
2388         {
2389         case record_full_reg: /* reg */
2390           /* Get register number to regnum.  */
2391           bfdcore_read (core_bfd, osec, &regnum,
2392                         sizeof (regnum), &bfd_offset);
2393           regnum = netorder32 (regnum);
2394
2395           rec = record_full_reg_alloc (regcache, regnum);
2396
2397           /* Get val.  */
2398           bfdcore_read (core_bfd, osec, record_full_get_loc (rec),
2399                         rec->u.reg.len, &bfd_offset);
2400
2401           if (record_debug)
2402             fprintf_unfiltered (gdb_stdlog,
2403                                 "  Reading register %d (1 "
2404                                 "plus %lu plus %d bytes)\n",
2405                                 rec->u.reg.num,
2406                                 (unsigned long) sizeof (regnum),
2407                                 rec->u.reg.len);
2408           break;
2409
2410         case record_full_mem: /* mem */
2411           /* Get len.  */
2412           bfdcore_read (core_bfd, osec, &len, 
2413                         sizeof (len), &bfd_offset);
2414           len = netorder32 (len);
2415
2416           /* Get addr.  */
2417           bfdcore_read (core_bfd, osec, &addr,
2418                         sizeof (addr), &bfd_offset);
2419           addr = netorder64 (addr);
2420
2421           rec = record_full_mem_alloc (addr, len);
2422
2423           /* Get val.  */
2424           bfdcore_read (core_bfd, osec, record_full_get_loc (rec),
2425                         rec->u.mem.len, &bfd_offset);
2426
2427           if (record_debug)
2428             fprintf_unfiltered (gdb_stdlog,
2429                                 "  Reading memory %s (1 plus "
2430                                 "%lu plus %lu plus %d bytes)\n",
2431                                 paddress (get_current_arch (),
2432                                           rec->u.mem.addr),
2433                                 (unsigned long) sizeof (addr),
2434                                 (unsigned long) sizeof (len),
2435                                 rec->u.mem.len);
2436           break;
2437
2438         case record_full_end: /* end */
2439           rec = record_full_end_alloc ();
2440           record_full_insn_num ++;
2441
2442           /* Get signal value.  */
2443           bfdcore_read (core_bfd, osec, &signal, 
2444                         sizeof (signal), &bfd_offset);
2445           signal = netorder32 (signal);
2446           rec->u.end.sigval = (enum gdb_signal) signal;
2447
2448           /* Get insn count.  */
2449           bfdcore_read (core_bfd, osec, &count, 
2450                         sizeof (count), &bfd_offset);
2451           count = netorder32 (count);
2452           rec->u.end.insn_num = count;
2453           record_full_insn_count = count + 1;
2454           if (record_debug)
2455             fprintf_unfiltered (gdb_stdlog,
2456                                 "  Reading record_full_end (1 + "
2457                                 "%lu + %lu bytes), offset == %s\n",
2458                                 (unsigned long) sizeof (signal),
2459                                 (unsigned long) sizeof (count),
2460                                 paddress (get_current_arch (),
2461                                           bfd_offset));
2462           break;
2463
2464         default:
2465           error (_("Bad entry type in core file %s."),
2466                  bfd_get_filename (core_bfd));
2467           break;
2468         }
2469
2470       /* Add rec to record arch list.  */
2471       record_full_arch_list_add (rec);
2472     }
2473
2474   discard_cleanups (old_cleanups);
2475
2476   /* Add record_full_arch_list_head to the end of record list.  */
2477   record_full_first.next = record_full_arch_list_head;
2478   record_full_arch_list_head->prev = &record_full_first;
2479   record_full_arch_list_tail->next = NULL;
2480   record_full_list = &record_full_first;
2481
2482   /* Update record_full_insn_max_num.  */
2483   if (record_full_insn_num > record_full_insn_max_num)
2484     {
2485       record_full_insn_max_num = record_full_insn_num;
2486       warning (_("Auto increase record/replay buffer limit to %u."),
2487                record_full_insn_max_num);
2488     }
2489
2490   /* Succeeded.  */
2491   printf_filtered (_("Restored records from core file %s.\n"),
2492                    bfd_get_filename (core_bfd));
2493
2494   print_stack_frame (get_selected_frame (NULL), 1, SRC_AND_LOC, 1);
2495 }
2496
2497 /* bfdcore_write -- write bytes into a core file section.  */
2498
2499 static inline void
2500 bfdcore_write (bfd *obfd, asection *osec, void *buf, int len, int *offset)
2501 {
2502   int ret = bfd_set_section_contents (obfd, osec, buf, *offset, len);
2503
2504   if (ret)
2505     *offset += len;
2506   else
2507     error (_("Failed to write %d bytes to core file %s ('%s')."),
2508            len, bfd_get_filename (obfd),
2509            bfd_errmsg (bfd_get_error ()));
2510 }
2511
2512 /* Restore the execution log from a file.  We use a modified elf
2513    corefile format, with an extra section for our data.  */
2514
2515 static void
2516 cmd_record_full_restore (char *args, int from_tty)
2517 {
2518   core_file_command (args, from_tty);
2519   record_full_open (args, from_tty);
2520 }
2521
2522 static void
2523 record_full_save_cleanups (void *data)
2524 {
2525   bfd *obfd = (bfd *) data;
2526   char *pathname = xstrdup (bfd_get_filename (obfd));
2527
2528   gdb_bfd_unref (obfd);
2529   unlink (pathname);
2530   xfree (pathname);
2531 }
2532
2533 /* Save the execution log to a file.  We use a modified elf corefile
2534    format, with an extra section for our data.  */
2535
2536 static void
2537 record_full_save (struct target_ops *self, const char *recfilename)
2538 {
2539   struct record_full_entry *cur_record_full_list;
2540   uint32_t magic;
2541   struct regcache *regcache;
2542   struct gdbarch *gdbarch;
2543   struct cleanup *old_cleanups;
2544   struct cleanup *set_cleanups;
2545   bfd *obfd;
2546   int save_size = 0;
2547   asection *osec = NULL;
2548   int bfd_offset = 0;
2549
2550   /* Open the save file.  */
2551   if (record_debug)
2552     fprintf_unfiltered (gdb_stdlog, "Saving execution log to core file '%s'\n",
2553                         recfilename);
2554
2555   /* Open the output file.  */
2556   obfd = create_gcore_bfd (recfilename);
2557   old_cleanups = make_cleanup (record_full_save_cleanups, obfd);
2558
2559   /* Save the current record entry to "cur_record_full_list".  */
2560   cur_record_full_list = record_full_list;
2561
2562   /* Get the values of regcache and gdbarch.  */
2563   regcache = get_current_regcache ();
2564   gdbarch = get_regcache_arch (regcache);
2565
2566   /* Disable the GDB operation record.  */
2567   set_cleanups = record_full_gdb_operation_disable_set ();
2568
2569   /* Reverse execute to the begin of record list.  */
2570   while (1)
2571     {
2572       /* Check for beginning and end of log.  */
2573       if (record_full_list == &record_full_first)
2574         break;
2575
2576       record_full_exec_insn (regcache, gdbarch, record_full_list);
2577
2578       if (record_full_list->prev)
2579         record_full_list = record_full_list->prev;
2580     }
2581
2582   /* Compute the size needed for the extra bfd section.  */
2583   save_size = 4;        /* magic cookie */
2584   for (record_full_list = record_full_first.next; record_full_list;
2585        record_full_list = record_full_list->next)
2586     switch (record_full_list->type)
2587       {
2588       case record_full_end:
2589         save_size += 1 + 4 + 4;
2590         break;
2591       case record_full_reg:
2592         save_size += 1 + 4 + record_full_list->u.reg.len;
2593         break;
2594       case record_full_mem:
2595         save_size += 1 + 4 + 8 + record_full_list->u.mem.len;
2596         break;
2597       }
2598
2599   /* Make the new bfd section.  */
2600   osec = bfd_make_section_anyway_with_flags (obfd, "precord",
2601                                              SEC_HAS_CONTENTS
2602                                              | SEC_READONLY);
2603   if (osec == NULL)
2604     error (_("Failed to create 'precord' section for corefile %s: %s"),
2605            recfilename,
2606            bfd_errmsg (bfd_get_error ()));
2607   bfd_set_section_size (obfd, osec, save_size);
2608   bfd_set_section_vma (obfd, osec, 0);
2609   bfd_set_section_alignment (obfd, osec, 0);
2610   bfd_section_lma (obfd, osec) = 0;
2611
2612   /* Save corefile state.  */
2613   write_gcore_file (obfd);
2614
2615   /* Write out the record log.  */
2616   /* Write the magic code.  */
2617   magic = RECORD_FULL_FILE_MAGIC;
2618   if (record_debug)
2619     fprintf_unfiltered (gdb_stdlog,
2620                         "  Writing 4-byte magic cookie "
2621                         "RECORD_FULL_FILE_MAGIC (0x%s)\n",
2622                       phex_nz (magic, 4));
2623   bfdcore_write (obfd, osec, &magic, sizeof (magic), &bfd_offset);
2624
2625   /* Save the entries to recfd and forward execute to the end of
2626      record list.  */
2627   record_full_list = &record_full_first;
2628   while (1)
2629     {
2630       /* Save entry.  */
2631       if (record_full_list != &record_full_first)
2632         {
2633           uint8_t type;
2634           uint32_t regnum, len, signal, count;
2635           uint64_t addr;
2636
2637           type = record_full_list->type;
2638           bfdcore_write (obfd, osec, &type, sizeof (type), &bfd_offset);
2639
2640           switch (record_full_list->type)
2641             {
2642             case record_full_reg: /* reg */
2643               if (record_debug)
2644                 fprintf_unfiltered (gdb_stdlog,
2645                                     "  Writing register %d (1 "
2646                                     "plus %lu plus %d bytes)\n",
2647                                     record_full_list->u.reg.num,
2648                                     (unsigned long) sizeof (regnum),
2649                                     record_full_list->u.reg.len);
2650
2651               /* Write regnum.  */
2652               regnum = netorder32 (record_full_list->u.reg.num);
2653               bfdcore_write (obfd, osec, &regnum,
2654                              sizeof (regnum), &bfd_offset);
2655
2656               /* Write regval.  */
2657               bfdcore_write (obfd, osec,
2658                              record_full_get_loc (record_full_list),
2659                              record_full_list->u.reg.len, &bfd_offset);
2660               break;
2661
2662             case record_full_mem: /* mem */
2663               if (record_debug)
2664                 fprintf_unfiltered (gdb_stdlog,
2665                                     "  Writing memory %s (1 plus "
2666                                     "%lu plus %lu plus %d bytes)\n",
2667                                     paddress (gdbarch,
2668                                               record_full_list->u.mem.addr),
2669                                     (unsigned long) sizeof (addr),
2670                                     (unsigned long) sizeof (len),
2671                                     record_full_list->u.mem.len);
2672
2673               /* Write memlen.  */
2674               len = netorder32 (record_full_list->u.mem.len);
2675               bfdcore_write (obfd, osec, &len, sizeof (len), &bfd_offset);
2676
2677               /* Write memaddr.  */
2678               addr = netorder64 (record_full_list->u.mem.addr);
2679               bfdcore_write (obfd, osec, &addr, 
2680                              sizeof (addr), &bfd_offset);
2681
2682               /* Write memval.  */
2683               bfdcore_write (obfd, osec,
2684                              record_full_get_loc (record_full_list),
2685                              record_full_list->u.mem.len, &bfd_offset);
2686               break;
2687
2688               case record_full_end:
2689                 if (record_debug)
2690                   fprintf_unfiltered (gdb_stdlog,
2691                                       "  Writing record_full_end (1 + "
2692                                       "%lu + %lu bytes)\n", 
2693                                       (unsigned long) sizeof (signal),
2694                                       (unsigned long) sizeof (count));
2695                 /* Write signal value.  */
2696                 signal = netorder32 (record_full_list->u.end.sigval);
2697                 bfdcore_write (obfd, osec, &signal,
2698                                sizeof (signal), &bfd_offset);
2699
2700                 /* Write insn count.  */
2701                 count = netorder32 (record_full_list->u.end.insn_num);
2702                 bfdcore_write (obfd, osec, &count,
2703                                sizeof (count), &bfd_offset);
2704                 break;
2705             }
2706         }
2707
2708       /* Execute entry.  */
2709       record_full_exec_insn (regcache, gdbarch, record_full_list);
2710
2711       if (record_full_list->next)
2712         record_full_list = record_full_list->next;
2713       else
2714         break;
2715     }
2716
2717   /* Reverse execute to cur_record_full_list.  */
2718   while (1)
2719     {
2720       /* Check for beginning and end of log.  */
2721       if (record_full_list == cur_record_full_list)
2722         break;
2723
2724       record_full_exec_insn (regcache, gdbarch, record_full_list);
2725
2726       if (record_full_list->prev)
2727         record_full_list = record_full_list->prev;
2728     }
2729
2730   do_cleanups (set_cleanups);
2731   gdb_bfd_unref (obfd);
2732   discard_cleanups (old_cleanups);
2733
2734   /* Succeeded.  */
2735   printf_filtered (_("Saved core file %s with execution log.\n"),
2736                    recfilename);
2737 }
2738
2739 /* record_full_goto_insn -- rewind the record log (forward or backward,
2740    depending on DIR) to the given entry, changing the program state
2741    correspondingly.  */
2742
2743 static void
2744 record_full_goto_insn (struct record_full_entry *entry,
2745                        enum exec_direction_kind dir)
2746 {
2747   struct cleanup *set_cleanups = record_full_gdb_operation_disable_set ();
2748   struct regcache *regcache = get_current_regcache ();
2749   struct gdbarch *gdbarch = get_regcache_arch (regcache);
2750
2751   /* Assume everything is valid: we will hit the entry,
2752      and we will not hit the end of the recording.  */
2753
2754   if (dir == EXEC_FORWARD)
2755     record_full_list = record_full_list->next;
2756
2757   do
2758     {
2759       record_full_exec_insn (regcache, gdbarch, record_full_list);
2760       if (dir == EXEC_REVERSE)
2761         record_full_list = record_full_list->prev;
2762       else
2763         record_full_list = record_full_list->next;
2764     } while (record_full_list != entry);
2765   do_cleanups (set_cleanups);
2766 }
2767
2768 /* Alias for "target record-full".  */
2769
2770 static void
2771 cmd_record_full_start (char *args, int from_tty)
2772 {
2773   execute_command ("target record-full", from_tty);
2774 }
2775
2776 static void
2777 set_record_full_insn_max_num (char *args, int from_tty,
2778                               struct cmd_list_element *c)
2779 {
2780   if (record_full_insn_num > record_full_insn_max_num)
2781     {
2782       /* Count down record_full_insn_num while releasing records from list.  */
2783       while (record_full_insn_num > record_full_insn_max_num)
2784        {
2785          record_full_list_release_first ();
2786          record_full_insn_num--;
2787        }
2788     }
2789 }
2790
2791 /* The "set record full" command.  */
2792
2793 static void
2794 set_record_full_command (char *args, int from_tty)
2795 {
2796   printf_unfiltered (_("\"set record full\" must be followed "
2797                        "by an apporpriate subcommand.\n"));
2798   help_list (set_record_full_cmdlist, "set record full ", all_commands,
2799              gdb_stdout);
2800 }
2801
2802 /* The "show record full" command.  */
2803
2804 static void
2805 show_record_full_command (char *args, int from_tty)
2806 {
2807   cmd_show_list (show_record_full_cmdlist, from_tty, "");
2808 }
2809
2810 /* Provide a prototype to silence -Wmissing-prototypes.  */
2811 extern initialize_file_ftype _initialize_record_full;
2812
2813 void
2814 _initialize_record_full (void)
2815 {
2816   struct cmd_list_element *c;
2817
2818   /* Init record_full_first.  */
2819   record_full_first.prev = NULL;
2820   record_full_first.next = NULL;
2821   record_full_first.type = record_full_end;
2822
2823   init_record_full_ops ();
2824   add_target (&record_full_ops);
2825   add_deprecated_target_alias (&record_full_ops, "record");
2826   init_record_full_core_ops ();
2827   add_target (&record_full_core_ops);
2828
2829   add_prefix_cmd ("full", class_obscure, cmd_record_full_start,
2830                   _("Start full execution recording."), &record_full_cmdlist,
2831                   "record full ", 0, &record_cmdlist);
2832
2833   c = add_cmd ("restore", class_obscure, cmd_record_full_restore,
2834                _("Restore the execution log from a file.\n\
2835 Argument is filename.  File must be created with 'record save'."),
2836                &record_full_cmdlist);
2837   set_cmd_completer (c, filename_completer);
2838
2839   /* Deprecate the old version without "full" prefix.  */
2840   c = add_alias_cmd ("restore", "full restore", class_obscure, 1,
2841                      &record_cmdlist);
2842   set_cmd_completer (c, filename_completer);
2843   deprecate_cmd (c, "record full restore");
2844
2845   add_prefix_cmd ("full", class_support, set_record_full_command,
2846                   _("Set record options"), &set_record_full_cmdlist,
2847                   "set record full ", 0, &set_record_cmdlist);
2848
2849   add_prefix_cmd ("full", class_support, show_record_full_command,
2850                   _("Show record options"), &show_record_full_cmdlist,
2851                   "show record full ", 0, &show_record_cmdlist);
2852
2853   /* Record instructions number limit command.  */
2854   add_setshow_boolean_cmd ("stop-at-limit", no_class,
2855                            &record_full_stop_at_limit, _("\
2856 Set whether record/replay stops when record/replay buffer becomes full."), _("\
2857 Show whether record/replay stops when record/replay buffer becomes full."),
2858                            _("Default is ON.\n\
2859 When ON, if the record/replay buffer becomes full, ask user what to do.\n\
2860 When OFF, if the record/replay buffer becomes full,\n\
2861 delete the oldest recorded instruction to make room for each new one."),
2862                            NULL, NULL,
2863                            &set_record_full_cmdlist, &show_record_full_cmdlist);
2864
2865   c = add_alias_cmd ("stop-at-limit", "full stop-at-limit", no_class, 1,
2866                      &set_record_cmdlist);
2867   deprecate_cmd (c, "set record full stop-at-limit");
2868
2869   c = add_alias_cmd ("stop-at-limit", "full stop-at-limit", no_class, 1,
2870                      &show_record_cmdlist);
2871   deprecate_cmd (c, "show record full stop-at-limit");
2872
2873   add_setshow_uinteger_cmd ("insn-number-max", no_class,
2874                             &record_full_insn_max_num,
2875                             _("Set record/replay buffer limit."),
2876                             _("Show record/replay buffer limit."), _("\
2877 Set the maximum number of instructions to be stored in the\n\
2878 record/replay buffer.  A value of either \"unlimited\" or zero means no\n\
2879 limit.  Default is 200000."),
2880                             set_record_full_insn_max_num,
2881                             NULL, &set_record_full_cmdlist,
2882                             &show_record_full_cmdlist);
2883
2884   c = add_alias_cmd ("insn-number-max", "full insn-number-max", no_class, 1,
2885                      &set_record_cmdlist);
2886   deprecate_cmd (c, "set record full insn-number-max");
2887
2888   c = add_alias_cmd ("insn-number-max", "full insn-number-max", no_class, 1,
2889                      &show_record_cmdlist);
2890   deprecate_cmd (c, "show record full insn-number-max");
2891
2892   add_setshow_boolean_cmd ("memory-query", no_class,
2893                            &record_full_memory_query, _("\
2894 Set whether query if PREC cannot record memory change of next instruction."),
2895                            _("\
2896 Show whether query if PREC cannot record memory change of next instruction."),
2897                            _("\
2898 Default is OFF.\n\
2899 When ON, query if PREC cannot record memory change of next instruction."),
2900                            NULL, NULL,
2901                            &set_record_full_cmdlist,
2902                            &show_record_full_cmdlist);
2903
2904   c = add_alias_cmd ("memory-query", "full memory-query", no_class, 1,
2905                      &set_record_cmdlist);
2906   deprecate_cmd (c, "set record full memory-query");
2907
2908   c = add_alias_cmd ("memory-query", "full memory-query", no_class, 1,
2909                      &show_record_cmdlist);
2910   deprecate_cmd (c, "show record full memory-query");
2911 }