* breakpoint.{c,h}: Add exp_string to struct breakpoint and use
[platform/upstream/binutils.git] / gdb / breakpoint.c
1 /* Everything about breakpoints, for GDB.
2    Copyright 1986, 1987, 1989, 1990, 1991, 1992 Free Software Foundation, Inc.
3
4 This file is part of GDB.
5
6 This program is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 2 of the License, or
9 (at your option) any later version.
10
11 This program is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14 GNU General Public License for more details.
15
16 You should have received a copy of the GNU General Public License
17 along with this program; if not, write to the Free Software
18 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.  */
19
20 #include "defs.h"
21 #include <ctype.h>
22 #include "symtab.h"
23 #include "frame.h"
24 #include "breakpoint.h"
25 #include "gdbtypes.h"
26 #include "expression.h"
27 #include "gdbcore.h"
28 #include "gdbcmd.h"
29 #include "value.h"
30 #include "ctype.h"
31 #include "command.h"
32 #include "inferior.h"
33 #include "target.h"
34 #include "language.h"
35 #include <string.h>
36 #include "demangle.h"
37
38 /* local function prototypes */
39
40 static void
41 catch_command_1 PARAMS ((char *, int, int));
42
43 static void
44 enable_delete_command PARAMS ((char *, int));
45
46 static void
47 enable_delete_breakpoint PARAMS ((struct breakpoint *));
48
49 static void
50 enable_once_command PARAMS ((char *, int));
51
52 static void
53 enable_once_breakpoint PARAMS ((struct breakpoint *));
54
55 static void
56 disable_command PARAMS ((char *, int));
57
58 static void
59 disable_breakpoint PARAMS ((struct breakpoint *));
60
61 static void
62 enable_command PARAMS ((char *, int));
63
64 static void
65 enable_breakpoint PARAMS ((struct breakpoint *));
66
67 static void
68 map_breakpoint_numbers PARAMS ((char *, void (*)(struct breakpoint *)));
69
70 static void
71 ignore_command PARAMS ((char *, int));
72
73 static int
74 breakpoint_re_set_one PARAMS ((char *));
75
76 static void
77 delete_command PARAMS ((char *, int));
78
79 static void
80 clear_command PARAMS ((char *, int));
81
82 static void
83 catch_command PARAMS ((char *, int));
84
85 static struct symtabs_and_lines
86 get_catch_sals PARAMS ((int));
87
88 static void
89 watch_command PARAMS ((char *, int));
90
91 static void
92 tbreak_command PARAMS ((char *, int));
93
94 static void
95 break_command_1 PARAMS ((char *, int, int));
96
97 static void
98 mention PARAMS ((struct breakpoint *));
99
100 static struct breakpoint *
101 set_raw_breakpoint PARAMS ((struct symtab_and_line));
102
103 static void
104 check_duplicates PARAMS ((CORE_ADDR));
105
106 static void
107 describe_other_breakpoints PARAMS ((CORE_ADDR));
108
109 static void
110 breakpoints_info PARAMS ((char *, int));
111
112 static void
113 breakpoint_1 PARAMS ((int, int));
114
115 static bpstat
116 bpstat_alloc PARAMS ((struct breakpoint *, bpstat));
117
118 static int
119 breakpoint_cond_eval PARAMS ((char *));
120
121 static void
122 cleanup_executing_breakpoints PARAMS ((int));
123
124 static void
125 commands_command PARAMS ((char *, int));
126
127 static void
128 condition_command PARAMS ((char *, int));
129
130 static int
131 get_number PARAMS ((char **));
132
133 static void
134 set_breakpoint_count PARAMS ((int));
135
136
137 extern int addressprint;                /* Print machine addresses? */
138 extern int demangle;                    /* Print de-mangled symbol names? */
139
140 /* Are we executing breakpoint commands?  */
141 static int executing_breakpoint_commands;
142
143 /* Walk the following statement or block through all breakpoints.
144    ALL_BREAKPOINTS_SAFE does so even if the statment deletes the current
145    breakpoint.  */
146
147 #define ALL_BREAKPOINTS(b)  for (b = breakpoint_chain; b; b = b->next)
148
149 #define ALL_BREAKPOINTS_SAFE(b,tmp)     \
150         for (b = breakpoint_chain;      \
151              b? (tmp=b->next, 1): 0;    \
152              b = tmp)
153
154 /* Chain of all breakpoints defined.  */
155
156 struct breakpoint *breakpoint_chain;
157
158 /* Number of last breakpoint made.  */
159
160 static int breakpoint_count;
161
162 /* Set breakpoint count to NUM.  */
163 static void
164 set_breakpoint_count (num)
165      int num;
166 {
167   breakpoint_count = num;
168   set_internalvar (lookup_internalvar ("bpnum"),
169                    value_from_longest (builtin_type_int, (LONGEST) num));
170 }
171
172 /* Default address, symtab and line to put a breakpoint at
173    for "break" command with no arg.
174    if default_breakpoint_valid is zero, the other three are
175    not valid, and "break" with no arg is an error.
176
177    This set by print_stack_frame, which calls set_default_breakpoint.  */
178
179 int default_breakpoint_valid;
180 CORE_ADDR default_breakpoint_address;
181 struct symtab *default_breakpoint_symtab;
182 int default_breakpoint_line;
183
184 /* Flag indicating extra verbosity for xgdb.  */
185 extern int xgdb_verbose;
186 \f
187 /* *PP is a string denoting a breakpoint.  Get the number of the breakpoint.
188    Advance *PP after the string and any trailing whitespace.
189
190    Currently the string can either be a number or "$" followed by the name
191    of a convenience variable.  Making it an expression wouldn't work well
192    for map_breakpoint_numbers (e.g. "4 + 5 + 6").  */
193 static int
194 get_number (pp)
195      char **pp;
196 {
197   int retval;
198   char *p = *pp;
199
200   if (p == NULL)
201     /* Empty line means refer to the last breakpoint.  */
202     return breakpoint_count;
203   else if (*p == '$')
204     {
205       /* Make a copy of the name, so we can null-terminate it
206          to pass to lookup_internalvar().  */
207       char *varname;
208       char *start = ++p;
209       value val;
210
211       while (isalnum (*p) || *p == '_')
212         p++;
213       varname = (char *) alloca (p - start + 1);
214       strncpy (varname, start, p - start);
215       varname[p - start] = '\0';
216       val = value_of_internalvar (lookup_internalvar (varname));
217       if (TYPE_CODE (VALUE_TYPE (val)) != TYPE_CODE_INT)
218         error (
219 "Convenience variables used to specify breakpoints must have integer values."
220                );
221       retval = (int) value_as_long (val);
222     }
223   else
224     {
225       if (*p == '-')
226         ++p;
227       while (*p >= '0' && *p <= '9')
228         ++p;
229       if (p == *pp)
230         /* There is no number here.  (e.g. "cond a == b").  */
231         error_no_arg ("breakpoint number");
232       retval = atoi (*pp);
233     }
234   if (!(isspace (*p) || *p == '\0'))
235     error ("breakpoint number expected");
236   while (isspace (*p))
237     p++;
238   *pp = p;
239   return retval;
240 }
241 \f
242 /* condition N EXP -- set break condition of breakpoint N to EXP.  */
243
244 static void
245 condition_command (arg, from_tty)
246      char *arg;
247      int from_tty;
248 {
249   register struct breakpoint *b;
250   char *p;
251   register int bnum;
252
253   if (arg == 0)
254     error_no_arg ("breakpoint number");
255
256   p = arg;
257   bnum = get_number (&p);
258
259   ALL_BREAKPOINTS (b)
260     if (b->number == bnum)
261       {
262         if (b->cond)
263           {
264             free ((PTR)b->cond);
265             b->cond = 0;
266           }
267         if (b->cond_string != NULL)
268           free ((PTR)b->cond_string);
269
270         if (*p == 0)
271           {
272             b->cond = 0;
273             b->cond_string = NULL;
274             if (from_tty)
275               printf_filtered ("Breakpoint %d now unconditional.\n", bnum);
276           }
277         else
278           {
279             arg = p;
280             /* I don't know if it matters whether this is the string the user
281                typed in or the decompiled expression.  */
282             b->cond_string = savestring (arg, strlen (arg));
283             b->cond = parse_exp_1 (&arg, block_for_pc (b->address), 0);
284             if (*arg)
285               error ("Junk at end of expression");
286           }
287         return;
288       }
289
290   error ("No breakpoint number %d.", bnum);
291 }
292
293 /* ARGSUSED */
294 static void
295 commands_command (arg, from_tty)
296      char *arg;
297      int from_tty;
298 {
299   register struct breakpoint *b;
300   char *p;
301   register int bnum;
302   struct command_line *l;
303
304   /* If we allowed this, we would have problems with when to
305      free the storage, if we change the commands currently
306      being read from.  */
307
308   if (executing_breakpoint_commands)
309     error ("Can't use the \"commands\" command among a breakpoint's commands.");
310
311   p = arg;
312   bnum = get_number (&p);
313   if (p && *p)
314     error ("Unexpected extra arguments following breakpoint number.");
315       
316   ALL_BREAKPOINTS (b)
317     if (b->number == bnum)
318       {
319         if (from_tty && input_from_terminal_p ())
320           printf_filtered ("Type commands for when breakpoint %d is hit, one per line.\n\
321 End with a line saying just \"end\".\n", bnum);
322         l = read_command_lines ();
323         free_command_lines (&b->commands);
324         b->commands = l;
325         return;
326       }
327   error ("No breakpoint number %d.", bnum);
328 }
329 \f
330 extern int memory_breakpoint_size; /* from mem-break.c */
331
332 /* Like target_read_memory() but if breakpoints are inserted, return
333    the shadow contents instead of the breakpoints themselves.
334
335    Read "memory data" from whatever target or inferior we have. 
336    Returns zero if successful, errno value if not.  EIO is used
337    for address out of bounds.  If breakpoints are inserted, returns
338    shadow contents, not the breakpoints themselves.  From breakpoint.c.  */
339
340 int
341 read_memory_nobpt (memaddr, myaddr, len)
342      CORE_ADDR memaddr;
343      char *myaddr;
344      unsigned len;
345 {
346   int status;
347   struct breakpoint *b;
348
349   if (memory_breakpoint_size < 0)
350     /* No breakpoints on this machine.  */
351     return target_read_memory (memaddr, myaddr, len);
352   
353   ALL_BREAKPOINTS (b)
354     {
355       if (b->type == bp_watchpoint || !b->inserted)
356         continue;
357       else if (b->address + memory_breakpoint_size <= memaddr)
358         /* The breakpoint is entirely before the chunk of memory
359            we are reading.  */
360         continue;
361       else if (b->address >= memaddr + len)
362         /* The breakpoint is entirely after the chunk of memory we
363            are reading.  */
364         continue;
365       else
366         {
367           /* Copy the breakpoint from the shadow contents, and recurse
368              for the things before and after.  */
369           
370           /* Addresses and length of the part of the breakpoint that
371              we need to copy.  */
372           CORE_ADDR membpt = b->address;
373           unsigned int bptlen = memory_breakpoint_size;
374           /* Offset within shadow_contents.  */
375           int bptoffset = 0;
376           
377           if (membpt < memaddr)
378             {
379               /* Only copy the second part of the breakpoint.  */
380               bptlen -= memaddr - membpt;
381               bptoffset = memaddr - membpt;
382               membpt = memaddr;
383             }
384
385           if (membpt + bptlen > memaddr + len)
386             {
387               /* Only copy the first part of the breakpoint.  */
388               bptlen -= (membpt + bptlen) - (memaddr + len);
389             }
390
391           memcpy (myaddr + membpt - memaddr, 
392                   b->shadow_contents + bptoffset, bptlen);
393
394           if (membpt > memaddr)
395             {
396               /* Copy the section of memory before the breakpoint.  */
397               status = read_memory_nobpt (memaddr, myaddr, membpt - memaddr);
398               if (status != 0)
399                 return status;
400             }
401
402           if (membpt + bptlen < memaddr + len)
403             {
404               /* Copy the section of memory after the breakpoint.  */
405               status = read_memory_nobpt
406                 (membpt + bptlen,
407                  myaddr + membpt + bptlen - memaddr,
408                  memaddr + len - (membpt + bptlen));
409               if (status != 0)
410                 return status;
411             }
412           return 0;
413         }
414     }
415   /* Nothing overlaps.  Just call read_memory_noerr.  */
416   return target_read_memory (memaddr, myaddr, len);
417 }
418 \f
419 /* insert_breakpoints is used when starting or continuing the program.
420    remove_breakpoints is used when the program stops.
421    Both return zero if successful,
422    or an `errno' value if could not write the inferior.  */
423
424 int
425 insert_breakpoints ()
426 {
427   register struct breakpoint *b;
428   int val = 0;
429   int disabled_breaks = 0;
430
431   ALL_BREAKPOINTS (b)
432     if (b->type != bp_watchpoint
433         && b->enable != disabled
434         && ! b->inserted
435         && ! b->duplicate)
436       {
437         val = target_insert_breakpoint(b->address, b->shadow_contents);
438         if (val)
439           {
440             /* Can't set the breakpoint.  */
441 #if defined (DISABLE_UNSETTABLE_BREAK)
442             if (DISABLE_UNSETTABLE_BREAK (b->address))
443               {
444                 val = 0;
445                 b->enable = disabled;
446                 if (!disabled_breaks)
447                   {
448                     fprintf (stderr,
449                          "Cannot insert breakpoint %d:\n", b->number);
450                     printf_filtered ("Disabling shared library breakpoints:\n");
451                   }
452                 disabled_breaks = 1;
453                 printf_filtered ("%d ", b->number);
454               }
455             else
456 #endif
457               {
458                 fprintf (stderr, "Cannot insert breakpoint %d:\n", b->number);
459 #ifdef ONE_PROCESS_WRITETEXT
460                 fprintf (stderr,
461                   "The same program may be running in another process.\n");
462 #endif
463                 memory_error (val, b->address); /* which bombs us out */
464               }
465           }
466         else
467           b->inserted = 1;
468       }
469   if (disabled_breaks)
470     printf_filtered ("\n");
471   return val;
472 }
473
474 int
475 remove_breakpoints ()
476 {
477   register struct breakpoint *b;
478   int val;
479
480 #ifdef BREAKPOINT_DEBUG
481   printf ("Removing breakpoints.\n");
482 #endif /* BREAKPOINT_DEBUG */
483
484   ALL_BREAKPOINTS (b)
485     if (b->type != bp_watchpoint && b->inserted)
486       {
487         val = target_remove_breakpoint(b->address, b->shadow_contents);
488         if (val)
489           return val;
490         b->inserted = 0;
491 #ifdef BREAKPOINT_DEBUG
492         printf ("Removed breakpoint at %s",
493                 local_hex_string(b->address));
494         printf (", shadow %s",
495                 local_hex_string(b->shadow_contents[0]));
496         printf (", %s.\n",
497                 local_hex_string(b->shadow_contents[1]));
498 #endif /* BREAKPOINT_DEBUG */
499       }
500
501   return 0;
502 }
503
504 /* Clear the "inserted" flag in all breakpoints.
505    This is done when the inferior is loaded.  */
506
507 void
508 mark_breakpoints_out ()
509 {
510   register struct breakpoint *b;
511
512   ALL_BREAKPOINTS (b)
513     b->inserted = 0;
514 }
515
516 /* breakpoint_here_p (PC) returns 1 if an enabled breakpoint exists at PC.
517    When continuing from a location with a breakpoint,
518    we actually single step once before calling insert_breakpoints.  */
519
520 int
521 breakpoint_here_p (pc)
522      CORE_ADDR pc;
523 {
524   register struct breakpoint *b;
525
526   ALL_BREAKPOINTS (b)
527     if (b->enable != disabled && b->address == pc)
528       return 1;
529
530   return 0;
531 }
532 \f
533 /* bpstat stuff.  External routines' interfaces are documented
534    in breakpoint.h.  */
535
536 /* Clear a bpstat so that it says we are not at any breakpoint.
537    Also free any storage that is part of a bpstat.  */
538
539 void
540 bpstat_clear (bsp)
541      bpstat *bsp;
542 {
543   bpstat p;
544   bpstat q;
545
546   if (bsp == 0)
547     return;
548   p = *bsp;
549   while (p != NULL)
550     {
551       q = p->next;
552       if (p->old_val != NULL)
553         value_free (p->old_val);
554       free ((PTR)p);
555       p = q;
556     }
557   *bsp = NULL;
558 }
559
560 /* Return a copy of a bpstat.  Like "bs1 = bs2" but all storage that
561    is part of the bpstat is copied as well.  */
562
563 bpstat
564 bpstat_copy (bs)
565      bpstat bs;
566 {
567   bpstat p = NULL;
568   bpstat tmp;
569   bpstat retval;
570
571   if (bs == NULL)
572     return bs;
573
574   for (; bs != NULL; bs = bs->next)
575     {
576       tmp = (bpstat) xmalloc (sizeof (*tmp));
577       memcpy (tmp, bs, sizeof (*tmp));
578       if (p == NULL)
579         /* This is the first thing in the chain.  */
580         retval = tmp;
581       else
582         p->next = tmp;
583       p = tmp;
584     }
585   p->next = NULL;
586   return retval;
587 }
588
589 /* Find the bpstat associated with this breakpoint */
590
591 bpstat
592 bpstat_find_breakpoint(bsp, breakpoint)
593      bpstat bsp;
594      struct breakpoint *breakpoint;
595 {
596   if (bsp == NULL) return NULL;
597
598   for (;bsp != NULL; bsp = bsp->next) {
599     if (bsp->breakpoint_at == breakpoint) return bsp;
600   }
601   return NULL;
602 }
603
604 /* Return the breakpoint number of the first breakpoint we are stopped
605    at.  *BSP upon return is a bpstat which points to the remaining
606    breakpoints stopped at (but which is not guaranteed to be good for
607    anything but further calls to bpstat_num).
608    Return 0 if passed a bpstat which does not indicate any breakpoints.  */
609
610 int
611 bpstat_num (bsp)
612      bpstat *bsp;
613 {
614   struct breakpoint *b;
615
616   if ((*bsp) == NULL)
617     return 0;                   /* No more breakpoint values */
618   else
619     {
620       b = (*bsp)->breakpoint_at;
621       *bsp = (*bsp)->next;
622       if (b == NULL)
623         return -1;              /* breakpoint that's been deleted since */
624       else
625         return b->number;       /* We have its number */
626     }
627 }
628
629 /* Modify BS so that the actions will not be performed.  */
630
631 void
632 bpstat_clear_actions (bs)
633      bpstat bs;
634 {
635   for (; bs != NULL; bs = bs->next)
636     {
637       bs->commands = NULL;
638       if (bs->old_val != NULL)
639         {
640           value_free (bs->old_val);
641           bs->old_val = NULL;
642         }
643     }
644 }
645
646 /* Stub for cleaning up our state if we error-out of a breakpoint command */
647 /* ARGSUSED */
648 static void
649 cleanup_executing_breakpoints (ignore)
650      int ignore;
651 {
652   executing_breakpoint_commands = 0;
653 }
654
655 /* Execute all the commands associated with all the breakpoints at this
656    location.  Any of these commands could cause the process to proceed
657    beyond this point, etc.  We look out for such changes by checking
658    the global "breakpoint_proceeded" after each command.  */
659
660 void
661 bpstat_do_actions (bsp)
662      bpstat *bsp;
663 {
664   bpstat bs;
665   struct cleanup *old_chain;
666
667   executing_breakpoint_commands = 1;
668   old_chain = make_cleanup (cleanup_executing_breakpoints, 0);
669
670 top:
671   bs = *bsp;
672
673   breakpoint_proceeded = 0;
674   for (; bs != NULL; bs = bs->next)
675     {
676       while (bs->commands)
677         {
678           char *line = bs->commands->line;
679           bs->commands = bs->commands->next;
680           execute_command (line, 0);
681           /* If the inferior is proceeded by the command, bomb out now.
682              The bpstat chain has been blown away by wait_for_inferior.
683              But since execution has stopped again, there is a new bpstat
684              to look at, so start over.  */
685           if (breakpoint_proceeded)
686             goto top;
687         }
688     }
689
690   executing_breakpoint_commands = 0;
691   discard_cleanups (old_chain);
692 }
693
694 /* Print a message indicating what happened.  Returns nonzero to
695    say that only the source line should be printed after this (zero
696    return means print the frame as well as the source line).  */
697
698 int
699 bpstat_print (bs)
700      bpstat bs;
701 {
702   /* bs->breakpoint_at can be NULL if it was a momentary breakpoint
703      which has since been deleted.  */
704   if (bs == NULL
705       || bs->breakpoint_at == NULL
706       || (bs->breakpoint_at->type != bp_breakpoint
707           && bs->breakpoint_at->type != bp_watchpoint))
708     return 0;
709   
710   /* If bpstat_stop_status says don't print, OK, we won't.  An example
711      circumstance is when we single-stepped for both a watchpoint and
712      for a "stepi" instruction.  The bpstat says that the watchpoint
713      explains the stop, but we shouldn't print because the watchpoint's
714      value didn't change -- and the real reason we are stopping here
715      rather than continuing to step (as the watchpoint would've had us do)
716      is because of the "stepi".  */
717   if (!bs->print)
718     return 0;
719
720   if (bs->breakpoint_at->type == bp_breakpoint)
721     {
722       /* I think the user probably only wants to see one breakpoint
723          number, not all of them.  */
724       printf_filtered ("\nBreakpoint %d, ", bs->breakpoint_at->number);
725       return 0;
726     }
727       
728   if (bs->old_val != NULL)
729     {
730       printf_filtered ("\nWatchpoint %d, ", bs->breakpoint_at->number);
731       print_expression (bs->breakpoint_at->exp, stdout);
732       printf_filtered ("\nOld value = ");
733       value_print (bs->old_val, stdout, 0, Val_pretty_default);
734       printf_filtered ("\nNew value = ");
735       value_print (bs->breakpoint_at->val, stdout, 0,
736                    Val_pretty_default);
737       printf_filtered ("\n");
738       value_free (bs->old_val);
739       bs->old_val = NULL;
740       return 1;
741     }
742
743   /* Maybe another breakpoint in the chain caused us to stop.
744      (Currently all watchpoints go on the bpstat whether hit or
745      not.  That probably could (should) be changed, provided care is taken
746      with respect to bpstat_explains_signal).  */
747   if (bs->next)
748     return bpstat_print (bs->next);
749
750   fprintf_filtered (stderr, "gdb internal error: in bpstat_print\n");
751   return 0;
752 }
753
754 /* Evaluate the expression EXP and return 1 if value is zero.
755    This is used inside a catch_errors to evaluate the breakpoint condition. 
756    The argument is a "struct expression *" that has been cast to char * to 
757    make it pass through catch_errors.  */
758
759 static int
760 breakpoint_cond_eval (exp)
761      char *exp;
762 {
763   return !value_true (evaluate_expression ((struct expression *)exp));
764 }
765
766 /* Allocate a new bpstat and chain it to the current one.  */
767
768 static bpstat
769 bpstat_alloc (b, cbs)
770      register struct breakpoint *b;
771      bpstat cbs;                        /* Current "bs" value */
772 {
773   bpstat bs;
774
775   bs = (bpstat) xmalloc (sizeof (*bs));
776   cbs->next = bs;
777   bs->breakpoint_at = b;
778   /* If the condition is false, etc., don't do the commands.  */
779   bs->commands = NULL;
780   bs->momentary = b->disposition == delete;
781   bs->old_val = NULL;
782   return bs;
783 }
784
785 /* Determine whether we stopped at a breakpoint, etc, or whether we
786    don't understand this stop.  Result is a chain of bpstat's such that:
787
788         if we don't understand the stop, the result is a null pointer.
789
790         if we understand why we stopped, the result is not null, and
791         the first element of the chain contains summary "stop" and
792         "print" flags for the whole chain.
793
794         Each element of the chain refers to a particular breakpoint or
795         watchpoint at which we have stopped.  (We may have stopped for
796         several reasons concurrently.)
797
798         Each element of the chain has valid next, breakpoint_at,
799         commands, FIXME??? fields.
800
801  */
802
803         
804 bpstat
805 bpstat_stop_status (pc, frame_address)
806      CORE_ADDR *pc;
807      FRAME_ADDR frame_address;
808 {
809   register struct breakpoint *b;
810   int stop = 0;
811   int print = 0;
812   CORE_ADDR bp_addr;
813 #if DECR_PC_AFTER_BREAK != 0 || defined (SHIFT_INST_REGS)
814   /* True if we've hit a breakpoint (as opposed to a watchpoint).  */
815   int real_breakpoint = 0;
816 #endif
817   /* Root of the chain of bpstat's */
818   struct bpstat root_bs[1];
819   /* Pointer to the last thing in the chain currently.  */
820   bpstat bs = root_bs;
821
822   /* Get the address where the breakpoint would have been.  */
823   bp_addr = *pc - DECR_PC_AFTER_BREAK;
824
825   ALL_BREAKPOINTS (b)
826     {
827       int this_bp_stop;
828       int this_bp_print;
829
830       if (b->enable == disabled)
831         continue;
832
833       if (b->type != bp_watchpoint && b->address != bp_addr)
834         continue;
835
836       /* Come here if it's a watchpoint, or if the break address matches */
837
838       bs = bpstat_alloc (b, bs);        /* Alloc a bpstat to explain stop */
839
840       this_bp_stop = 1;
841       this_bp_print = 1;
842
843       if (b->type == bp_watchpoint)
844         {
845           int within_current_scope;
846           if (b->exp_valid_block != NULL)
847             within_current_scope =
848               contained_in (get_selected_block (), b->exp_valid_block);
849           else
850             within_current_scope = 1;
851
852           if (within_current_scope)
853             {
854               /* We use value_{,free_to_}mark because it could be a
855                  *long* time before we return to the command level and
856                  call free_all_values.  */
857
858               value mark = value_mark ();
859               value new_val = evaluate_expression (b->exp);
860               if (!value_equal (b->val, new_val))
861                 {
862                   release_value (new_val);
863                   value_free_to_mark (mark);
864                   bs->old_val = b->val;
865                   b->val = new_val;
866                   /* We will stop here */
867                 }
868               else
869                 {
870                   /* Nothing changed, don't do anything.  */
871                   value_free_to_mark (mark);
872                   continue;
873                   /* We won't stop here */
874                 }
875             }
876           else
877             {
878               /* This seems like the only logical thing to do because
879                  if we temporarily ignored the watchpoint, then when
880                  we reenter the block in which it is valid it contains
881                  garbage (in the case of a function, it may have two
882                  garbage values, one before and one after the prologue).
883                  So we can't even detect the first assignment to it and
884                  watch after that (since the garbage may or may not equal
885                  the first value assigned).  */
886               b->enable = disabled;
887               printf_filtered ("\
888 Watchpoint %d disabled because the program has left the block in\n\
889 which its expression is valid.\n", b->number);
890               /* We won't stop here */
891               /* FIXME, maybe we should stop here!!! */
892               continue;
893             }
894         }
895 #if DECR_PC_AFTER_BREAK != 0 || defined (SHIFT_INST_REGS)
896       else
897         real_breakpoint = 1;
898 #endif
899
900       if (b->frame && b->frame != frame_address)
901         this_bp_stop = 0;
902       else
903         {
904           int value_is_zero;
905
906           if (b->cond)
907             {
908               /* Need to select the frame, with all that implies
909                  so that the conditions will have the right context.  */
910               select_frame (get_current_frame (), 0);
911               value_is_zero
912                 = catch_errors (breakpoint_cond_eval, (char *)(b->cond),
913                                 "Error in testing breakpoint condition:\n");
914                                 /* FIXME-someday, should give breakpoint # */
915               free_all_values ();
916             }
917           if (b->cond && value_is_zero)
918             {
919               this_bp_stop = 0;
920             }
921           else if (b->ignore_count > 0)
922             {
923               b->ignore_count--;
924               this_bp_stop = 0;
925             }
926           else
927             {
928               /* We will stop here */
929               if (b->disposition == disable)
930                 b->enable = disabled;
931               bs->commands = b->commands;
932               if (b->silent)
933                 this_bp_print = 0;
934               if (bs->commands && STREQ ("silent", bs->commands->line))
935                 {
936                   bs->commands = bs->commands->next;
937                   this_bp_print = 0;
938                 }
939             }
940         }
941       if (this_bp_stop)
942         stop = 1;
943       if (this_bp_print)
944         print = 1;
945     }
946
947   bs->next = NULL;              /* Terminate the chain */
948   bs = root_bs->next;           /* Re-grab the head of the chain */
949   if (bs)
950     {
951       bs->stop = stop;
952       bs->print = print;
953 #if DECR_PC_AFTER_BREAK != 0 || defined (SHIFT_INST_REGS)
954       if (real_breakpoint)
955         {
956           *pc = bp_addr;
957 #if defined (SHIFT_INST_REGS)
958           {
959             CORE_ADDR pc = read_register (PC_REGNUM);
960             CORE_ADDR npc = read_register (NPC_REGNUM);
961             if (pc != npc)
962               {
963                 write_register (NNPC_REGNUM, npc);
964                 write_register (NPC_REGNUM, pc);
965               }
966           }
967 #else /* No SHIFT_INST_REGS.  */
968           write_pc (bp_addr);
969 #endif /* No SHIFT_INST_REGS.  */
970         }
971 #endif /* DECR_PC_AFTER_BREAK != 0.  */
972     }
973   return bs;
974 }
975
976 /* Nonzero if we should step constantly (e.g. watchpoints on machines
977    without hardware support).  This isn't related to a specific bpstat,
978    just to things like whether watchpoints are set.  */
979
980 int 
981 bpstat_should_step ()
982 {
983   struct breakpoint *b;
984   ALL_BREAKPOINTS (b)
985     if (b->enable == enabled && b->type == bp_watchpoint)
986       return 1;
987   return 0;
988 }
989 \f
990 /* Print information on breakpoint number BNUM, or -1 if all.
991    If WATCHPOINTS is zero, process only breakpoints; if WATCHPOINTS
992    is nonzero, process only watchpoints.  */
993
994 static void
995 breakpoint_1 (bnum, allflag)
996      int bnum;
997      int allflag;
998 {
999   register struct breakpoint *b;
1000   register struct command_line *l;
1001   register struct symbol *sym;
1002   CORE_ADDR last_addr = (CORE_ADDR)-1;
1003   int found_a_breakpoint = 0;
1004   static char *bptypes[] = {"breakpoint", "until", "finish", "watchpoint",
1005                               "longjmp", "longjmp resume"};
1006   static char *bpdisps[] = {"del", "dis", "keep"};
1007   static char bpenables[] = "ny";
1008
1009   if (!breakpoint_chain)
1010     {
1011       printf_filtered ("No breakpoints or watchpoints.\n");
1012       return;
1013     }
1014   
1015   ALL_BREAKPOINTS (b)
1016     if (bnum == -1
1017         || bnum == b->number)
1018       {
1019 /*  We only print out user settable breakpoints unless the allflag is set. */
1020         if (!allflag
1021             && b->type != bp_breakpoint
1022             && b->type != bp_watchpoint)
1023           continue;
1024
1025         if (!found_a_breakpoint++)
1026           printf_filtered ("Num Type           Disp Enb %sWhat\n",
1027                            addressprint ? "Address    " : "");
1028
1029         printf_filtered ("%-3d %-14s %-4s %-3c ",
1030                          b->number,
1031                          bptypes[(int)b->type],
1032                          bpdisps[(int)b->disposition],
1033                          bpenables[(int)b->enable]);
1034         switch (b->type)
1035           {
1036           case bp_watchpoint:
1037             print_expression (b->exp, stdout);
1038             break;
1039           case bp_breakpoint:
1040           case bp_until:
1041           case bp_finish:
1042           case bp_longjmp:
1043           case bp_longjmp_resume:
1044             if (addressprint)
1045               printf_filtered ("%s ", local_hex_string_custom(b->address, "08"));
1046
1047             last_addr = b->address;
1048             if (b->symtab)
1049               {
1050                 sym = find_pc_function (b->address);
1051                 if (sym)
1052                   {
1053                     fputs_filtered ("in ", stdout);
1054                     fputs_filtered (SYMBOL_SOURCE_NAME (sym), stdout);
1055                     fputs_filtered (" at ", stdout);
1056                   }
1057                 fputs_filtered (b->symtab->filename, stdout);
1058                 printf_filtered (":%d", b->line_number);
1059               }
1060             else
1061               print_address_symbolic (b->address, stdout, demangle, " ");
1062           }
1063
1064         printf_filtered ("\n");
1065
1066         if (b->frame)
1067           printf_filtered ("\tstop only in stack frame at %s\n",
1068                            local_hex_string(b->frame));
1069         if (b->cond)
1070           {
1071             printf_filtered ("\tstop only if ");
1072             print_expression (b->cond, stdout);
1073             printf_filtered ("\n");
1074           }
1075         if (b->ignore_count)
1076           printf_filtered ("\tignore next %d hits\n", b->ignore_count);
1077         if ((l = b->commands))
1078           while (l)
1079             {
1080               fputs_filtered ("\t", stdout);
1081               fputs_filtered (l->line, stdout);
1082               fputs_filtered ("\n", stdout);
1083               l = l->next;
1084             }
1085       }
1086
1087   if (!found_a_breakpoint
1088       && bnum != -1)
1089     printf_filtered ("No breakpoint or watchpoint number %d.\n", bnum);
1090   else
1091     /* Compare against (CORE_ADDR)-1 in case some compiler decides
1092        that a comparison of an unsigned with -1 is always false.  */
1093     if (last_addr != (CORE_ADDR)-1)
1094       set_next_address (last_addr);
1095 }
1096
1097 /* ARGSUSED */
1098 static void
1099 breakpoints_info (bnum_exp, from_tty)
1100      char *bnum_exp;
1101      int from_tty;
1102 {
1103   int bnum = -1;
1104
1105   if (bnum_exp)
1106     bnum = parse_and_eval_address (bnum_exp);
1107
1108   breakpoint_1 (bnum, 0);
1109 }
1110
1111 #if MAINTENANCE_CMDS
1112
1113 /* ARGSUSED */
1114 static void
1115 maintenance_info_breakpoints (bnum_exp, from_tty)
1116      char *bnum_exp;
1117      int from_tty;
1118 {
1119   int bnum = -1;
1120
1121   if (bnum_exp)
1122     bnum = parse_and_eval_address (bnum_exp);
1123
1124   breakpoint_1 (bnum, 1);
1125 }
1126
1127 #endif
1128
1129 /* Print a message describing any breakpoints set at PC.  */
1130
1131 static void
1132 describe_other_breakpoints (pc)
1133      register CORE_ADDR pc;
1134 {
1135   register int others = 0;
1136   register struct breakpoint *b;
1137
1138   ALL_BREAKPOINTS (b)
1139     if (b->address == pc)
1140       others++;
1141   if (others > 0)
1142     {
1143       printf ("Note: breakpoint%s ", (others > 1) ? "s" : "");
1144       ALL_BREAKPOINTS (b)
1145         if (b->address == pc)
1146           {
1147             others--;
1148             printf ("%d%s%s ",
1149                     b->number,
1150                     (b->enable == disabled) ? " (disabled)" : "",
1151                     (others > 1) ? "," : ((others == 1) ? " and" : ""));
1152           }
1153       printf ("also set at pc %s.\n", local_hex_string(pc));
1154     }
1155 }
1156 \f
1157 /* Set the default place to put a breakpoint
1158    for the `break' command with no arguments.  */
1159
1160 void
1161 set_default_breakpoint (valid, addr, symtab, line)
1162      int valid;
1163      CORE_ADDR addr;
1164      struct symtab *symtab;
1165      int line;
1166 {
1167   default_breakpoint_valid = valid;
1168   default_breakpoint_address = addr;
1169   default_breakpoint_symtab = symtab;
1170   default_breakpoint_line = line;
1171 }
1172
1173 /* Rescan breakpoints at address ADDRESS,
1174    marking the first one as "first" and any others as "duplicates".
1175    This is so that the bpt instruction is only inserted once.  */
1176
1177 static void
1178 check_duplicates (address)
1179      CORE_ADDR address;
1180 {
1181   register struct breakpoint *b;
1182   register int count = 0;
1183
1184   if (address == 0)             /* Watchpoints are uninteresting */
1185     return;
1186
1187   ALL_BREAKPOINTS (b)
1188     if (b->enable != disabled && b->address == address)
1189       {
1190         count++;
1191         b->duplicate = count > 1;
1192       }
1193 }
1194
1195 /* Low level routine to set a breakpoint.
1196    Takes as args the three things that every breakpoint must have.
1197    Returns the breakpoint object so caller can set other things.
1198    Does not set the breakpoint number!
1199    Does not print anything.
1200
1201    ==> This routine should not be called if there is a chance of later
1202    error(); otherwise it leaves a bogus breakpoint on the chain.  Validate
1203    your arguments BEFORE calling this routine!  */
1204
1205 static struct breakpoint *
1206 set_raw_breakpoint (sal)
1207      struct symtab_and_line sal;
1208 {
1209   register struct breakpoint *b, *b1;
1210
1211   b = (struct breakpoint *) xmalloc (sizeof (struct breakpoint));
1212   memset (b, 0, sizeof (*b));
1213   b->address = sal.pc;
1214   b->symtab = sal.symtab;
1215   b->line_number = sal.line;
1216   b->enable = enabled;
1217   b->next = 0;
1218   b->silent = 0;
1219   b->ignore_count = 0;
1220   b->commands = NULL;
1221   b->frame = 0;
1222
1223   /* Add this breakpoint to the end of the chain
1224      so that a list of breakpoints will come out in order
1225      of increasing numbers.  */
1226
1227   b1 = breakpoint_chain;
1228   if (b1 == 0)
1229     breakpoint_chain = b;
1230   else
1231     {
1232       while (b1->next)
1233         b1 = b1->next;
1234       b1->next = b;
1235     }
1236
1237   check_duplicates (sal.pc);
1238
1239   return b;
1240 }
1241
1242 static void
1243 create_longjmp_breakpoint(func_name)
1244      char *func_name;
1245 {
1246   struct symtab_and_line sal;
1247   struct breakpoint *b;
1248   static int internal_breakpoint_number = -1;
1249
1250   if (func_name != NULL)
1251     {
1252       struct minimal_symbol *m;
1253
1254       m = lookup_minimal_symbol(func_name, (struct objfile *)NULL);
1255       if (m)
1256         sal.pc = SYMBOL_VALUE_ADDRESS (m);
1257       else
1258         return;
1259     }
1260   else
1261     sal.pc = 0;
1262
1263   sal.symtab = NULL;
1264   sal.line = 0;
1265
1266   b = set_raw_breakpoint(sal);
1267   if (!b) return;
1268
1269   b->type = func_name != NULL ? bp_longjmp : bp_longjmp_resume;
1270   b->disposition = donttouch;
1271   b->enable = disabled;
1272   b->silent = 1;
1273   if (func_name)
1274     b->addr_string = strsave(func_name);
1275   b->number = internal_breakpoint_number--;
1276 }
1277
1278 /* Call this routine when stepping and nexting to enable a breakpoint if we do
1279    a longjmp().  When we hit that breakpoint, call
1280    set_longjmp_resume_breakpoint() to figure out where we are going. */
1281
1282 void
1283 enable_longjmp_breakpoint()
1284 {
1285   register struct breakpoint *b;
1286
1287   ALL_BREAKPOINTS (b)
1288     if (b->type == bp_longjmp)
1289       {
1290         b->enable = enabled;
1291         check_duplicates (b->address);
1292       }
1293 }
1294
1295 void
1296 disable_longjmp_breakpoint()
1297 {
1298   register struct breakpoint *b;
1299
1300   ALL_BREAKPOINTS (b)
1301     if (   b->type == bp_longjmp
1302         || b->type == bp_longjmp_resume)
1303       {
1304         b->enable = disabled;
1305         check_duplicates (b->address);
1306       }
1307 }
1308
1309 /* Call this after hitting the longjmp() breakpoint.  Use this to set a new
1310    breakpoint at the target of the jmp_buf.
1311
1312    FIXME - This ought to be done by setting a temporary breakpoint that gets
1313    deleted automatically...
1314 */
1315
1316 void
1317 set_longjmp_resume_breakpoint(pc, frame)
1318      CORE_ADDR pc;
1319      FRAME frame;
1320 {
1321   register struct breakpoint *b;
1322
1323   ALL_BREAKPOINTS (b)
1324     if (b->type == bp_longjmp_resume)
1325       {
1326         b->address = pc;
1327         b->enable = enabled;
1328         if (frame != NULL)
1329           b->frame = FRAME_FP(frame);
1330         else
1331           b->frame = 0;
1332         check_duplicates (b->address);
1333         return;
1334       }
1335 }
1336
1337 /* Set a breakpoint that will evaporate an end of command
1338    at address specified by SAL.
1339    Restrict it to frame FRAME if FRAME is nonzero.  */
1340
1341 struct breakpoint *
1342 set_momentary_breakpoint (sal, frame, type)
1343      struct symtab_and_line sal;
1344      FRAME frame;
1345      enum bptype type;
1346 {
1347   register struct breakpoint *b;
1348   b = set_raw_breakpoint (sal);
1349   b->type = type;
1350   b->enable = enabled;
1351   b->disposition = donttouch;
1352   b->frame = (frame ? FRAME_FP (frame) : 0);
1353   return b;
1354 }
1355
1356 #if 0
1357 void
1358 clear_momentary_breakpoints ()
1359 {
1360   register struct breakpoint *b;
1361   ALL_BREAKPOINTS (b)
1362     if (b->disposition == delete)
1363       {
1364         delete_breakpoint (b);
1365         break;
1366       }
1367 }
1368 #endif
1369 \f
1370 /* Tell the user we have just set a breakpoint B.  */
1371 static void
1372 mention (b)
1373      struct breakpoint *b;
1374 {
1375   switch (b->type)
1376     {
1377     case bp_watchpoint:
1378       printf_filtered ("Watchpoint %d: ", b->number);
1379       print_expression (b->exp, stdout);
1380       break;
1381     case bp_breakpoint:
1382       printf_filtered ("Breakpoint %d at %s", b->number,
1383                        local_hex_string(b->address));
1384       if (b->symtab)
1385         printf_filtered (": file %s, line %d.",
1386                          b->symtab->filename, b->line_number);
1387       break;
1388     case bp_until:
1389     case bp_finish:
1390     case bp_longjmp:
1391     case bp_longjmp_resume:
1392       break;
1393     }
1394   printf_filtered ("\n");
1395 }
1396
1397 #if 0
1398 /* Nobody calls this currently. */
1399 /* Set a breakpoint from a symtab and line.
1400    If TEMPFLAG is nonzero, it is a temporary breakpoint.
1401    ADDR_STRING is a malloc'd string holding the name of where we are
1402    setting the breakpoint.  This is used later to re-set it after the
1403    program is relinked and symbols are reloaded.
1404    Print the same confirmation messages that the breakpoint command prints.  */
1405
1406 void
1407 set_breakpoint (s, line, tempflag, addr_string)
1408      struct symtab *s;
1409      int line;
1410      int tempflag;
1411      char *addr_string;
1412 {
1413   register struct breakpoint *b;
1414   struct symtab_and_line sal;
1415   
1416   sal.symtab = s;
1417   sal.line = line;
1418   sal.pc = 0;
1419   resolve_sal_pc (&sal);                        /* Might error out */
1420   describe_other_breakpoints (sal.pc);
1421
1422   b = set_raw_breakpoint (sal);
1423   set_breakpoint_count (breakpoint_count + 1);
1424   b->number = breakpoint_count;
1425   b->type = bp_breakpoint;
1426   b->cond = 0;
1427   b->addr_string = addr_string;
1428   b->enable = enabled;
1429   b->disposition = tempflag ? delete : donttouch;
1430
1431   mention (b);
1432 }
1433 #endif /* 0 */
1434 \f
1435 /* Set a breakpoint according to ARG (function, linenum or *address)
1436    and make it temporary if TEMPFLAG is nonzero. */
1437
1438 static void
1439 break_command_1 (arg, tempflag, from_tty)
1440      char *arg;
1441      int tempflag, from_tty;
1442 {
1443   struct symtabs_and_lines sals;
1444   struct symtab_and_line sal;
1445   register struct expression *cond = 0;
1446   register struct breakpoint *b;
1447
1448   /* Pointers in arg to the start, and one past the end, of the condition.  */
1449   char *cond_start = NULL;
1450   char *cond_end;
1451   /* Pointers in arg to the start, and one past the end,
1452      of the address part.  */
1453   char *addr_start = NULL;
1454   char *addr_end;
1455   
1456   int i;
1457
1458   sals.sals = NULL;
1459   sals.nelts = 0;
1460
1461   sal.line = sal.pc = sal.end = 0;
1462   sal.symtab = 0;
1463
1464   /* If no arg given, or if first arg is 'if ', use the default breakpoint. */
1465
1466   if (!arg || (arg[0] == 'i' && arg[1] == 'f' 
1467                && (arg[2] == ' ' || arg[2] == '\t')))
1468     {
1469       if (default_breakpoint_valid)
1470         {
1471           sals.sals = (struct symtab_and_line *) 
1472             xmalloc (sizeof (struct symtab_and_line));
1473           sal.pc = default_breakpoint_address;
1474           sal.line = default_breakpoint_line;
1475           sal.symtab = default_breakpoint_symtab;
1476           sals.sals[0] = sal;
1477           sals.nelts = 1;
1478         }
1479       else
1480         error ("No default breakpoint address now.");
1481     }
1482   else
1483     {
1484       addr_start = arg;
1485
1486       /* Force almost all breakpoints to be in terms of the
1487          current_source_symtab (which is decode_line_1's default).  This
1488          should produce the results we want almost all of the time while
1489          leaving default_breakpoint_* alone.  */
1490       if (default_breakpoint_valid
1491           && (!current_source_symtab
1492               || (arg && (*arg == '+' || *arg == '-'))))
1493         sals = decode_line_1 (&arg, 1, default_breakpoint_symtab,
1494                               default_breakpoint_line);
1495       else
1496         sals = decode_line_1 (&arg, 1, (struct symtab *)NULL, 0);
1497
1498       addr_end = arg;
1499     }
1500   
1501   if (! sals.nelts) 
1502     return;
1503
1504   /* Resolve all line numbers to PC's, and verify that conditions
1505      can be parsed, before setting any breakpoints.  */
1506   for (i = 0; i < sals.nelts; i++)
1507     {
1508       resolve_sal_pc (&sals.sals[i]);
1509       
1510       while (arg && *arg)
1511         {
1512           if (arg[0] == 'i' && arg[1] == 'f'
1513               && (arg[2] == ' ' || arg[2] == '\t'))
1514             {
1515               arg += 2;
1516               cond_start = arg;
1517               cond = parse_exp_1 (&arg, block_for_pc (sals.sals[i].pc), 0);
1518               cond_end = arg;
1519             }
1520           else
1521             error ("Junk at end of arguments.");
1522         }
1523     }
1524
1525   /* Now set all the breakpoints.  */
1526   for (i = 0; i < sals.nelts; i++)
1527     {
1528       sal = sals.sals[i];
1529
1530       if (from_tty)
1531         describe_other_breakpoints (sal.pc);
1532
1533       b = set_raw_breakpoint (sal);
1534       set_breakpoint_count (breakpoint_count + 1);
1535       b->number = breakpoint_count;
1536       b->type = bp_breakpoint;
1537       b->cond = cond;
1538       
1539       if (addr_start)
1540         b->addr_string = savestring (addr_start, addr_end - addr_start);
1541       if (cond_start)
1542         b->cond_string = savestring (cond_start, cond_end - cond_start);
1543                                      
1544       b->enable = enabled;
1545       b->disposition = tempflag ? delete : donttouch;
1546
1547       mention (b);
1548     }
1549
1550   if (sals.nelts > 1)
1551     {
1552       printf ("Multiple breakpoints were set.\n");
1553       printf ("Use the \"delete\" command to delete unwanted breakpoints.\n");
1554     }
1555   free ((PTR)sals.sals);
1556 }
1557
1558 /* Helper function for break_command_1 and disassemble_command.  */
1559
1560 void
1561 resolve_sal_pc (sal)
1562      struct symtab_and_line *sal;
1563 {
1564   CORE_ADDR pc;
1565
1566   if (sal->pc == 0 && sal->symtab != 0)
1567     {
1568       pc = find_line_pc (sal->symtab, sal->line);
1569       if (pc == 0)
1570         error ("No line %d in file \"%s\".",
1571                sal->line, sal->symtab->filename);
1572       sal->pc = pc;
1573     }
1574 }
1575
1576 void
1577 break_command (arg, from_tty)
1578      char *arg;
1579      int from_tty;
1580 {
1581   break_command_1 (arg, 0, from_tty);
1582 }
1583
1584 static void
1585 tbreak_command (arg, from_tty)
1586      char *arg;
1587      int from_tty;
1588 {
1589   break_command_1 (arg, 1, from_tty);
1590 }
1591
1592 /* ARGSUSED */
1593 static void
1594 watch_command (arg, from_tty)
1595      char *arg;
1596      int from_tty;
1597 {
1598   struct breakpoint *b;
1599   struct symtab_and_line sal;
1600   struct expression *exp;
1601   struct block *exp_valid_block;
1602   struct value *val;
1603
1604   sal.pc = 0;
1605   sal.symtab = NULL;
1606   sal.line = 0;
1607   
1608   /* Parse arguments.  */
1609   innermost_block = NULL;
1610   exp = parse_expression (arg);
1611   exp_valid_block = innermost_block;
1612   val = evaluate_expression (exp);
1613   release_value (val);
1614   if (VALUE_LAZY (val))
1615     value_fetch_lazy (val);
1616
1617   /* Now set up the breakpoint.  */
1618   b = set_raw_breakpoint (sal);
1619   set_breakpoint_count (breakpoint_count + 1);
1620   b->number = breakpoint_count;
1621   b->type = bp_watchpoint;
1622   b->disposition = donttouch;
1623   b->exp = exp;
1624   b->exp_valid_block = exp_valid_block;
1625   b->val = val;
1626   b->cond = 0;
1627   b->cond_string = NULL;
1628   b->exp_string = savestring (arg, strlen (arg));
1629   mention (b);
1630 }
1631 \f
1632 /*
1633  * Helper routine for the until_command routine in infcmd.c.  Here
1634  * because it uses the mechanisms of breakpoints.
1635  */
1636 /* ARGSUSED */
1637 void
1638 until_break_command (arg, from_tty)
1639      char *arg;
1640      int from_tty;
1641 {
1642   struct symtabs_and_lines sals;
1643   struct symtab_and_line sal;
1644   FRAME prev_frame = get_prev_frame (selected_frame);
1645   struct breakpoint *breakpoint;
1646   struct cleanup *old_chain;
1647
1648   clear_proceed_status ();
1649
1650   /* Set a breakpoint where the user wants it and at return from
1651      this function */
1652   
1653   if (default_breakpoint_valid)
1654     sals = decode_line_1 (&arg, 1, default_breakpoint_symtab,
1655                           default_breakpoint_line);
1656   else
1657     sals = decode_line_1 (&arg, 1, (struct symtab *)NULL, 0);
1658   
1659   if (sals.nelts != 1)
1660     error ("Couldn't get information on specified line.");
1661   
1662   sal = sals.sals[0];
1663   free ((PTR)sals.sals);                /* malloc'd, so freed */
1664   
1665   if (*arg)
1666     error ("Junk at end of arguments.");
1667   
1668   resolve_sal_pc (&sal);
1669   
1670   breakpoint = set_momentary_breakpoint (sal, selected_frame, bp_until);
1671   
1672   old_chain = make_cleanup(delete_breakpoint, breakpoint);
1673
1674   /* Keep within the current frame */
1675   
1676   if (prev_frame)
1677     {
1678       struct frame_info *fi;
1679       
1680       fi = get_frame_info (prev_frame);
1681       sal = find_pc_line (fi->pc, 0);
1682       sal.pc = fi->pc;
1683       breakpoint = set_momentary_breakpoint (sal, prev_frame, bp_until);
1684       make_cleanup(delete_breakpoint, breakpoint);
1685     }
1686   
1687   proceed (-1, -1, 0);
1688   do_cleanups(old_chain);
1689 }
1690 \f
1691 #if 0
1692 /* These aren't used; I don't konw what they were for.  */
1693 /* Set a breakpoint at the catch clause for NAME.  */
1694 static int
1695 catch_breakpoint (name)
1696      char *name;
1697 {
1698 }
1699
1700 static int
1701 disable_catch_breakpoint ()
1702 {
1703 }
1704
1705 static int
1706 delete_catch_breakpoint ()
1707 {
1708 }
1709
1710 static int
1711 enable_catch_breakpoint ()
1712 {
1713 }
1714 #endif /* 0 */
1715
1716 struct sal_chain
1717 {
1718   struct sal_chain *next;
1719   struct symtab_and_line sal;
1720 };
1721
1722 #if 0
1723 /* This isn't used; I don't know what it was for.  */
1724 /* For each catch clause identified in ARGS, run FUNCTION
1725    with that clause as an argument.  */
1726 static struct symtabs_and_lines
1727 map_catch_names (args, function)
1728      char *args;
1729      int (*function)();
1730 {
1731   register char *p = args;
1732   register char *p1;
1733   struct symtabs_and_lines sals;
1734 #if 0
1735   struct sal_chain *sal_chain = 0;
1736 #endif
1737
1738   if (p == 0)
1739     error_no_arg ("one or more catch names");
1740
1741   sals.nelts = 0;
1742   sals.sals = NULL;
1743
1744   while (*p)
1745     {
1746       p1 = p;
1747       /* Don't swallow conditional part.  */
1748       if (p1[0] == 'i' && p1[1] == 'f'
1749           && (p1[2] == ' ' || p1[2] == '\t'))
1750         break;
1751
1752       if (isalpha (*p1))
1753         {
1754           p1++;
1755           while (isalnum (*p1) || *p1 == '_' || *p1 == '$')
1756             p1++;
1757         }
1758
1759       if (*p1 && *p1 != ' ' && *p1 != '\t')
1760         error ("Arguments must be catch names.");
1761
1762       *p1 = 0;
1763 #if 0
1764       if (function (p))
1765         {
1766           struct sal_chain *next
1767             = (struct sal_chain *)alloca (sizeof (struct sal_chain));
1768           next->next = sal_chain;
1769           next->sal = get_catch_sal (p);
1770           sal_chain = next;
1771           goto win;
1772         }
1773 #endif
1774       printf ("No catch clause for exception %s.\n", p);
1775 #if 0
1776     win:
1777 #endif
1778       p = p1;
1779       while (*p == ' ' || *p == '\t') p++;
1780     }
1781 }
1782 #endif /* 0 */
1783
1784 /* This shares a lot of code with `print_frame_label_vars' from stack.c.  */
1785
1786 static struct symtabs_and_lines
1787 get_catch_sals (this_level_only)
1788      int this_level_only;
1789 {
1790   register struct blockvector *bl;
1791   register struct block *block;
1792   int index, have_default = 0;
1793   struct frame_info *fi;
1794   CORE_ADDR pc;
1795   struct symtabs_and_lines sals;
1796   struct sal_chain *sal_chain = 0;
1797   char *blocks_searched;
1798
1799   /* Not sure whether an error message is always the correct response,
1800      but it's better than a core dump.  */
1801   if (selected_frame == NULL)
1802     error ("No selected frame.");
1803   block = get_frame_block (selected_frame);
1804   fi = get_frame_info (selected_frame);
1805   pc = fi->pc;
1806
1807   sals.nelts = 0;
1808   sals.sals = NULL;
1809
1810   if (block == 0)
1811     error ("No symbol table info available.\n");
1812
1813   bl = blockvector_for_pc (BLOCK_END (block) - 4, &index);
1814   blocks_searched = (char *) alloca (BLOCKVECTOR_NBLOCKS (bl) * sizeof (char));
1815   memset (blocks_searched, 0, BLOCKVECTOR_NBLOCKS (bl) * sizeof (char));
1816
1817   while (block != 0)
1818     {
1819       CORE_ADDR end = BLOCK_END (block) - 4;
1820       int last_index;
1821
1822       if (bl != blockvector_for_pc (end, &index))
1823         error ("blockvector blotch");
1824       if (BLOCKVECTOR_BLOCK (bl, index) != block)
1825         error ("blockvector botch");
1826       last_index = BLOCKVECTOR_NBLOCKS (bl);
1827       index += 1;
1828
1829       /* Don't print out blocks that have gone by.  */
1830       while (index < last_index
1831              && BLOCK_END (BLOCKVECTOR_BLOCK (bl, index)) < pc)
1832         index++;
1833
1834       while (index < last_index
1835              && BLOCK_END (BLOCKVECTOR_BLOCK (bl, index)) < end)
1836         {
1837           if (blocks_searched[index] == 0)
1838             {
1839               struct block *b = BLOCKVECTOR_BLOCK (bl, index);
1840               int nsyms;
1841               register int i;
1842               register struct symbol *sym;
1843
1844               nsyms = BLOCK_NSYMS (b);
1845
1846               for (i = 0; i < nsyms; i++)
1847                 {
1848                   sym = BLOCK_SYM (b, i);
1849                   if (STREQ (SYMBOL_NAME (sym), "default"))
1850                     {
1851                       if (have_default)
1852                         continue;
1853                       have_default = 1;
1854                     }
1855                   if (SYMBOL_CLASS (sym) == LOC_LABEL)
1856                     {
1857                       struct sal_chain *next = (struct sal_chain *)
1858                         alloca (sizeof (struct sal_chain));
1859                       next->next = sal_chain;
1860                       next->sal = find_pc_line (SYMBOL_VALUE_ADDRESS (sym), 0);
1861                       sal_chain = next;
1862                     }
1863                 }
1864               blocks_searched[index] = 1;
1865             }
1866           index++;
1867         }
1868       if (have_default)
1869         break;
1870       if (sal_chain && this_level_only)
1871         break;
1872
1873       /* After handling the function's top-level block, stop.
1874          Don't continue to its superblock, the block of
1875          per-file symbols.  */
1876       if (BLOCK_FUNCTION (block))
1877         break;
1878       block = BLOCK_SUPERBLOCK (block);
1879     }
1880
1881   if (sal_chain)
1882     {
1883       struct sal_chain *tmp_chain;
1884
1885       /* Count the number of entries.  */
1886       for (index = 0, tmp_chain = sal_chain; tmp_chain;
1887            tmp_chain = tmp_chain->next)
1888         index++;
1889
1890       sals.nelts = index;
1891       sals.sals = (struct symtab_and_line *)
1892         xmalloc (index * sizeof (struct symtab_and_line));
1893       for (index = 0; sal_chain; sal_chain = sal_chain->next, index++)
1894         sals.sals[index] = sal_chain->sal;
1895     }
1896
1897   return sals;
1898 }
1899
1900 /* Commands to deal with catching exceptions.  */
1901
1902 static void
1903 catch_command_1 (arg, tempflag, from_tty)
1904      char *arg;
1905      int tempflag;
1906      int from_tty;
1907 {
1908   /* First, translate ARG into something we can deal with in terms
1909      of breakpoints.  */
1910
1911   struct symtabs_and_lines sals;
1912   struct symtab_and_line sal;
1913   register struct expression *cond = 0;
1914   register struct breakpoint *b;
1915   char *save_arg;
1916   int i;
1917
1918   sal.line = sal.pc = sal.end = 0;
1919   sal.symtab = 0;
1920
1921   /* If no arg given, or if first arg is 'if ', all active catch clauses
1922      are breakpointed. */
1923
1924   if (!arg || (arg[0] == 'i' && arg[1] == 'f' 
1925                && (arg[2] == ' ' || arg[2] == '\t')))
1926     {
1927       /* Grab all active catch clauses.  */
1928       sals = get_catch_sals (0);
1929     }
1930   else
1931     {
1932       /* Grab selected catch clauses.  */
1933       error ("catch NAME not implemeneted");
1934 #if 0
1935       /* This isn't used; I don't know what it was for.  */
1936       sals = map_catch_names (arg, catch_breakpoint);
1937 #endif
1938     }
1939
1940   if (! sals.nelts) 
1941     return;
1942
1943   save_arg = arg;
1944   for (i = 0; i < sals.nelts; i++)
1945     {
1946       resolve_sal_pc (&sals.sals[i]);
1947       
1948       while (arg && *arg)
1949         {
1950           if (arg[0] == 'i' && arg[1] == 'f'
1951               && (arg[2] == ' ' || arg[2] == '\t'))
1952             cond = parse_exp_1 ((arg += 2, &arg), 
1953                                 block_for_pc (sals.sals[i].pc), 0);
1954           else
1955             error ("Junk at end of arguments.");
1956         }
1957       arg = save_arg;
1958     }
1959
1960   for (i = 0; i < sals.nelts; i++)
1961     {
1962       sal = sals.sals[i];
1963
1964       if (from_tty)
1965         describe_other_breakpoints (sal.pc);
1966
1967       b = set_raw_breakpoint (sal);
1968       set_breakpoint_count (breakpoint_count + 1);
1969       b->number = breakpoint_count;
1970       b->type = bp_breakpoint;
1971       b->cond = cond;
1972       b->enable = enabled;
1973       b->disposition = tempflag ? delete : donttouch;
1974
1975       printf ("Breakpoint %d at %s", b->number, local_hex_string(b->address));
1976       if (b->symtab)
1977         printf (": file %s, line %d.", b->symtab->filename, b->line_number);
1978       printf ("\n");
1979     }
1980
1981   if (sals.nelts > 1)
1982     {
1983       printf ("Multiple breakpoints were set.\n");
1984       printf ("Use the \"delete\" command to delete unwanted breakpoints.\n");
1985     }
1986   free ((PTR)sals.sals);
1987 }
1988
1989 #if 0
1990 /* These aren't used; I don't know what they were for.  */
1991 /* Disable breakpoints on all catch clauses described in ARGS.  */
1992 static void
1993 disable_catch (args)
1994      char *args;
1995 {
1996   /* Map the disable command to catch clauses described in ARGS.  */
1997 }
1998
1999 /* Enable breakpoints on all catch clauses described in ARGS.  */
2000 static void
2001 enable_catch (args)
2002      char *args;
2003 {
2004   /* Map the disable command to catch clauses described in ARGS.  */
2005 }
2006
2007 /* Delete breakpoints on all catch clauses in the active scope.  */
2008 static void
2009 delete_catch (args)
2010      char *args;
2011 {
2012   /* Map the delete command to catch clauses described in ARGS.  */
2013 }
2014 #endif /* 0 */
2015
2016 static void
2017 catch_command (arg, from_tty)
2018      char *arg;
2019      int from_tty;
2020 {
2021   catch_command_1 (arg, 0, from_tty);
2022 }
2023 \f
2024 static void
2025 clear_command (arg, from_tty)
2026      char *arg;
2027      int from_tty;
2028 {
2029   register struct breakpoint *b, *b1;
2030   struct symtabs_and_lines sals;
2031   struct symtab_and_line sal;
2032   register struct breakpoint *found;
2033   int i;
2034
2035   if (arg)
2036     {
2037       sals = decode_line_spec (arg, 1);
2038     }
2039   else
2040     {
2041       sals.sals = (struct symtab_and_line *) xmalloc (sizeof (struct symtab_and_line));
2042       sal.line = default_breakpoint_line;
2043       sal.symtab = default_breakpoint_symtab;
2044       sal.pc = 0;
2045       if (sal.symtab == 0)
2046         error ("No source file specified.");
2047
2048       sals.sals[0] = sal;
2049       sals.nelts = 1;
2050     }
2051
2052   for (i = 0; i < sals.nelts; i++)
2053     {
2054       /* If exact pc given, clear bpts at that pc.
2055          But if sal.pc is zero, clear all bpts on specified line.  */
2056       sal = sals.sals[i];
2057       found = (struct breakpoint *) 0;
2058       while (breakpoint_chain
2059              && (sal.pc ? breakpoint_chain->address == sal.pc
2060                  : (breakpoint_chain->symtab == sal.symtab
2061                     && breakpoint_chain->line_number == sal.line)))
2062         {
2063           b1 = breakpoint_chain;
2064           breakpoint_chain = b1->next;
2065           b1->next = found;
2066           found = b1;
2067         }
2068
2069       ALL_BREAKPOINTS (b)
2070         while (b->next
2071                && b->next->type != bp_watchpoint
2072                && (sal.pc ? b->next->address == sal.pc
2073                    : (b->next->symtab == sal.symtab
2074                       && b->next->line_number == sal.line)))
2075           {
2076             b1 = b->next;
2077             b->next = b1->next;
2078             b1->next = found;
2079             found = b1;
2080           }
2081
2082       if (found == 0)
2083         {
2084           if (arg)
2085             error ("No breakpoint at %s.", arg);
2086           else
2087             error ("No breakpoint at this line.");
2088         }
2089
2090       if (found->next) from_tty = 1; /* Always report if deleted more than one */
2091       if (from_tty) printf ("Deleted breakpoint%s ", found->next ? "s" : "");
2092       while (found)
2093         {
2094           if (from_tty) printf ("%d ", found->number);
2095           b1 = found->next;
2096           delete_breakpoint (found);
2097           found = b1;
2098         }
2099       if (from_tty) putchar ('\n');
2100     }
2101   free ((PTR)sals.sals);
2102 }
2103 \f
2104 /* Delete breakpoint in BS if they are `delete' breakpoints.
2105    This is called after any breakpoint is hit, or after errors.  */
2106
2107 void
2108 breakpoint_auto_delete (bs)
2109      bpstat bs;
2110 {
2111   for (; bs; bs = bs->next)
2112     if (bs->breakpoint_at && bs->breakpoint_at->disposition == delete)
2113       delete_breakpoint (bs->breakpoint_at);
2114 }
2115
2116 /* Delete a breakpoint and clean up all traces of it in the data structures. */
2117
2118 void
2119 delete_breakpoint (bpt)
2120      struct breakpoint *bpt;
2121 {
2122   register struct breakpoint *b;
2123   register bpstat bs;
2124
2125   if (bpt->inserted)
2126       target_remove_breakpoint(bpt->address, bpt->shadow_contents);
2127
2128   if (breakpoint_chain == bpt)
2129     breakpoint_chain = bpt->next;
2130
2131   ALL_BREAKPOINTS (b)
2132     if (b->next == bpt)
2133       {
2134         b->next = bpt->next;
2135         break;
2136       }
2137
2138   check_duplicates (bpt->address);
2139
2140   free_command_lines (&bpt->commands);
2141   if (bpt->cond)
2142     free ((PTR)bpt->cond);
2143   if (bpt->cond_string != NULL)
2144     free ((PTR)bpt->cond_string);
2145   if (bpt->addr_string != NULL)
2146     free ((PTR)bpt->addr_string);
2147   if (bpt->exp_string != NULL)
2148     free ((PTR)bpt->exp_string);
2149
2150   if (xgdb_verbose && bpt->type == bp_breakpoint)
2151     printf ("breakpoint #%d deleted\n", bpt->number);
2152
2153   /* Be sure no bpstat's are pointing at it after it's been freed.  */
2154   /* FIXME, how can we find all bpstat's?  We just check stop_bpstat for now. */
2155   for (bs = stop_bpstat; bs; bs = bs->next)
2156     if (bs->breakpoint_at == bpt)
2157       bs->breakpoint_at = NULL;
2158   free ((PTR)bpt);
2159 }
2160
2161 static void
2162 delete_command (arg, from_tty)
2163      char *arg;
2164      int from_tty;
2165 {
2166
2167   if (arg == 0)
2168     {
2169       /* Ask user only if there are some breakpoints to delete.  */
2170       if (!from_tty
2171           || (breakpoint_chain && query ("Delete all breakpoints? ", 0, 0)))
2172         {
2173           /* No arg; clear all breakpoints.  */
2174           while (breakpoint_chain)
2175             delete_breakpoint (breakpoint_chain);
2176         }
2177     }
2178   else
2179     map_breakpoint_numbers (arg, delete_breakpoint);
2180 }
2181
2182 /* Reset a breakpoint given it's struct breakpoint * BINT.
2183    The value we return ends up being the return value from catch_errors.
2184    Unused in this case.  */
2185
2186 static int
2187 breakpoint_re_set_one (bint)
2188      char *bint;
2189 {
2190   struct breakpoint *b = (struct breakpoint *)bint;  /* get past catch_errs */
2191   int i;
2192   struct symtabs_and_lines sals;
2193   char *s;
2194   enum enable save_enable;
2195
2196   switch (b->type)
2197     {
2198     case bp_breakpoint:
2199       if (b->addr_string == NULL)
2200         {
2201           /* Anything without a string can't be re-set. */
2202           delete_breakpoint (b);
2203           return 0;
2204         }
2205       /* In case we have a problem, disable this breakpoint.  We'll restore
2206          its status if we succeed.  */
2207       save_enable = b->enable;
2208       b->enable = disabled;
2209
2210       s = b->addr_string;
2211       sals = decode_line_1 (&s, 1, (struct symtab *)NULL, 0);
2212       for (i = 0; i < sals.nelts; i++)
2213         {
2214           resolve_sal_pc (&sals.sals[i]);
2215           if (b->symtab != sals.sals[i].symtab
2216               || b->line_number != sals.sals[i].line
2217               || b->address != sals.sals[i].pc)
2218             {
2219               b->symtab = sals.sals[i].symtab;
2220               b->line_number = sals.sals[i].line;
2221               b->address = sals.sals[i].pc;
2222
2223               if (b->cond_string != NULL)
2224                 {
2225                   s = b->cond_string;
2226                   if (b->cond)
2227                     free ((PTR)b->cond);
2228                   b->cond = parse_exp_1 (&s, block_for_pc (sals.sals[i].pc), 0);
2229                 }
2230           
2231               check_duplicates (b->address);
2232
2233               mention (b);
2234             }
2235           b->enable = save_enable;      /* Restore it, this worked. */
2236         }
2237       free ((PTR)sals.sals);
2238       break;
2239
2240     case bp_watchpoint:
2241       innermost_block = NULL;
2242       b->exp = parse_expression (b->exp_string);
2243       b->exp_valid_block = innermost_block;
2244       b->val = evaluate_expression (b->exp);
2245       release_value (b->val);
2246       if (VALUE_LAZY (b->val))
2247         value_fetch_lazy (b->val);
2248
2249       if (b->cond_string != NULL)
2250         {
2251           s = b->cond_string;
2252           b->cond = parse_exp_1 (&s, (struct block *)0, 0);
2253         }
2254       mention (b);
2255       break;
2256
2257     default:
2258       printf_filtered ("Deleting unknown breakpoint type %d\n", b->type);
2259       /* fall through */
2260     case bp_until:
2261     case bp_finish:
2262     case bp_longjmp:
2263     case bp_longjmp_resume:
2264       delete_breakpoint (b);
2265       break;
2266     }
2267
2268   return 0;
2269 }
2270
2271 /* Re-set all breakpoints after symbols have been re-loaded.  */
2272 void
2273 breakpoint_re_set ()
2274 {
2275   struct breakpoint *b, *temp;
2276   static char message1[] = "Error in re-setting breakpoint %d:\n";
2277   char message[sizeof (message1) + 30 /* slop */];
2278   
2279   /* If we have no current source symtab, and we have any breakpoints,
2280      go through the work of making a source context.  */
2281   if (current_source_symtab == NULL && breakpoint_chain != 0)
2282     {
2283       select_source_symtab (NULL);
2284     }
2285
2286   ALL_BREAKPOINTS_SAFE (b, temp)
2287     {
2288       sprintf (message, message1, b->number);   /* Format possible error msg */
2289       catch_errors (breakpoint_re_set_one, (char *) b, message);
2290     }
2291
2292   create_longjmp_breakpoint("longjmp");
2293   create_longjmp_breakpoint("_longjmp");
2294   create_longjmp_breakpoint("siglongjmp");
2295   create_longjmp_breakpoint(NULL);
2296
2297 #if 0
2298   /* Took this out (temporaliy at least), since it produces an extra 
2299      blank line at startup. This messes up the gdbtests. -PB */
2300   /* Blank line to finish off all those mention() messages we just printed.  */
2301   printf_filtered ("\n");
2302 #endif
2303 }
2304 \f
2305 /* Set ignore-count of breakpoint number BPTNUM to COUNT.
2306    If from_tty is nonzero, it prints a message to that effect,
2307    which ends with a period (no newline).  */
2308
2309 void
2310 set_ignore_count (bptnum, count, from_tty)
2311      int bptnum, count, from_tty;
2312 {
2313   register struct breakpoint *b;
2314
2315   if (count < 0)
2316     count = 0;
2317
2318   ALL_BREAKPOINTS (b)
2319     if (b->number == bptnum)
2320       {
2321         b->ignore_count = count;
2322         if (!from_tty)
2323           return;
2324         else if (count == 0)
2325           printf_filtered ("Will stop next time breakpoint %d is reached.",
2326                            bptnum);
2327         else if (count == 1)
2328           printf_filtered ("Will ignore next crossing of breakpoint %d.",
2329                            bptnum);
2330         else
2331           printf_filtered ("Will ignore next %d crossings of breakpoint %d.",
2332                   count, bptnum);
2333         return;
2334       }
2335
2336   error ("No breakpoint number %d.", bptnum);
2337 }
2338
2339 /* Clear the ignore counts of all breakpoints.  */
2340 void
2341 breakpoint_clear_ignore_counts ()
2342 {
2343   struct breakpoint *b;
2344
2345   ALL_BREAKPOINTS (b)
2346     b->ignore_count = 0;
2347 }
2348
2349 /* Command to set ignore-count of breakpoint N to COUNT.  */
2350
2351 static void
2352 ignore_command (args, from_tty)
2353      char *args;
2354      int from_tty;
2355 {
2356   char *p = args;
2357   register int num;
2358
2359   if (p == 0)
2360     error_no_arg ("a breakpoint number");
2361   
2362   num = get_number (&p);
2363
2364   if (*p == 0)
2365     error ("Second argument (specified ignore-count) is missing.");
2366
2367   set_ignore_count (num,
2368                     longest_to_int (value_as_long (parse_and_eval (p))),
2369                     from_tty);
2370   printf_filtered ("\n");
2371 }
2372 \f
2373 /* Call FUNCTION on each of the breakpoints
2374    whose numbers are given in ARGS.  */
2375
2376 static void
2377 map_breakpoint_numbers (args, function)
2378      char *args;
2379      void (*function) PARAMS ((struct breakpoint *));
2380 {
2381   register char *p = args;
2382   char *p1;
2383   register int num;
2384   register struct breakpoint *b;
2385
2386   if (p == 0)
2387     error_no_arg ("one or more breakpoint numbers");
2388
2389   while (*p)
2390     {
2391       p1 = p;
2392       
2393       num = get_number (&p1);
2394
2395       ALL_BREAKPOINTS (b)
2396         if (b->number == num)
2397           {
2398             function (b);
2399             goto win;
2400           }
2401       printf ("No breakpoint number %d.\n", num);
2402     win:
2403       p = p1;
2404     }
2405 }
2406
2407 static void
2408 enable_breakpoint (bpt)
2409      struct breakpoint *bpt;
2410 {
2411   bpt->enable = enabled;
2412
2413   if (xgdb_verbose && bpt->type == bp_breakpoint)
2414     printf ("breakpoint #%d enabled\n", bpt->number);
2415
2416   check_duplicates (bpt->address);
2417   if (bpt->type == bp_watchpoint)
2418     {
2419       if (bpt->exp_valid_block != NULL
2420        && !contained_in (get_selected_block (), bpt->exp_valid_block))
2421         {
2422           printf_filtered ("\
2423 Cannot enable watchpoint %d because the block in which its expression\n\
2424 is valid is not currently in scope.\n", bpt->number);
2425           bpt->enable = disabled;
2426           return;
2427         }
2428
2429       value_free (bpt->val);
2430
2431       bpt->val = evaluate_expression (bpt->exp);
2432       release_value (bpt->val);
2433       if (VALUE_LAZY (bpt->val))
2434         value_fetch_lazy (bpt->val);
2435     }
2436 }
2437
2438 /* ARGSUSED */
2439 static void
2440 enable_command (args, from_tty)
2441      char *args;
2442      int from_tty;
2443 {
2444   struct breakpoint *bpt;
2445   if (args == 0)
2446     ALL_BREAKPOINTS (bpt)
2447       switch (bpt->type)
2448         {
2449         case bp_breakpoint:
2450         case bp_watchpoint:
2451           enable_breakpoint (bpt);
2452         default:
2453           continue;
2454         }
2455   else
2456     map_breakpoint_numbers (args, enable_breakpoint);
2457 }
2458
2459 static void
2460 disable_breakpoint (bpt)
2461      struct breakpoint *bpt;
2462 {
2463   bpt->enable = disabled;
2464
2465   if (xgdb_verbose && bpt->type == bp_breakpoint)
2466     printf_filtered ("breakpoint #%d disabled\n", bpt->number);
2467
2468   check_duplicates (bpt->address);
2469 }
2470
2471 /* ARGSUSED */
2472 static void
2473 disable_command (args, from_tty)
2474      char *args;
2475      int from_tty;
2476 {
2477   register struct breakpoint *bpt;
2478   if (args == 0)
2479     ALL_BREAKPOINTS (bpt)
2480       switch (bpt->type)
2481         {
2482         case bp_breakpoint:
2483         case bp_watchpoint:
2484           disable_breakpoint (bpt);
2485         default:
2486           continue;
2487         }
2488   else
2489     map_breakpoint_numbers (args, disable_breakpoint);
2490 }
2491
2492 static void
2493 enable_once_breakpoint (bpt)
2494      struct breakpoint *bpt;
2495 {
2496   bpt->enable = enabled;
2497   bpt->disposition = disable;
2498
2499   check_duplicates (bpt->address);
2500 }
2501
2502 /* ARGSUSED */
2503 static void
2504 enable_once_command (args, from_tty)
2505      char *args;
2506      int from_tty;
2507 {
2508   map_breakpoint_numbers (args, enable_once_breakpoint);
2509 }
2510
2511 static void
2512 enable_delete_breakpoint (bpt)
2513      struct breakpoint *bpt;
2514 {
2515   bpt->enable = enabled;
2516   bpt->disposition = delete;
2517
2518   check_duplicates (bpt->address);
2519 }
2520
2521 /* ARGSUSED */
2522 static void
2523 enable_delete_command (args, from_tty)
2524      char *args;
2525      int from_tty;
2526 {
2527   map_breakpoint_numbers (args, enable_delete_breakpoint);
2528 }
2529 \f
2530 /*
2531  * Use default_breakpoint_'s, or nothing if they aren't valid.
2532  */
2533 struct symtabs_and_lines
2534 decode_line_spec_1 (string, funfirstline)
2535      char *string;
2536      int funfirstline;
2537 {
2538   struct symtabs_and_lines sals;
2539   if (string == 0)
2540     error ("Empty line specification.");
2541   if (default_breakpoint_valid)
2542     sals = decode_line_1 (&string, funfirstline,
2543                           default_breakpoint_symtab, default_breakpoint_line);
2544   else
2545     sals = decode_line_1 (&string, funfirstline, (struct symtab *)NULL, 0);
2546   if (*string)
2547     error ("Junk at end of line specification: %s", string);
2548   return sals;
2549 }
2550 \f
2551 void
2552 _initialize_breakpoint ()
2553 {
2554   breakpoint_chain = 0;
2555   /* Don't bother to call set_breakpoint_count.  $bpnum isn't useful
2556      before a breakpoint is set.  */
2557   breakpoint_count = 0;
2558
2559   add_com ("ignore", class_breakpoint, ignore_command,
2560            "Set ignore-count of breakpoint number N to COUNT.");
2561
2562   add_com ("commands", class_breakpoint, commands_command,
2563            "Set commands to be executed when a breakpoint is hit.\n\
2564 Give breakpoint number as argument after \"commands\".\n\
2565 With no argument, the targeted breakpoint is the last one set.\n\
2566 The commands themselves follow starting on the next line.\n\
2567 Type a line containing \"end\" to indicate the end of them.\n\
2568 Give \"silent\" as the first line to make the breakpoint silent;\n\
2569 then no output is printed when it is hit, except what the commands print.");
2570
2571   add_com ("condition", class_breakpoint, condition_command,
2572            "Specify breakpoint number N to break only if COND is true.\n\
2573 N is an integer; COND is an expression to be evaluated whenever\n\
2574 breakpoint N is reached.  ");
2575
2576   add_com ("tbreak", class_breakpoint, tbreak_command,
2577            "Set a temporary breakpoint.  Args like \"break\" command.\n\
2578 Like \"break\" except the breakpoint is only enabled temporarily,\n\
2579 so it will be disabled when hit.  Equivalent to \"break\" followed\n\
2580 by using \"enable once\" on the breakpoint number.");
2581
2582   add_prefix_cmd ("enable", class_breakpoint, enable_command,
2583                   "Enable some breakpoints.\n\
2584 Give breakpoint numbers (separated by spaces) as arguments.\n\
2585 With no subcommand, breakpoints are enabled until you command otherwise.\n\
2586 This is used to cancel the effect of the \"disable\" command.\n\
2587 With a subcommand you can enable temporarily.",
2588                   &enablelist, "enable ", 1, &cmdlist);
2589
2590   add_abbrev_prefix_cmd ("breakpoints", class_breakpoint, enable_command,
2591                   "Enable some breakpoints.\n\
2592 Give breakpoint numbers (separated by spaces) as arguments.\n\
2593 This is used to cancel the effect of the \"disable\" command.\n\
2594 May be abbreviated to simply \"enable\".\n",
2595                   &enablebreaklist, "enable breakpoints ", 1, &enablelist);
2596
2597   add_cmd ("once", no_class, enable_once_command,
2598            "Enable breakpoints for one hit.  Give breakpoint numbers.\n\
2599 If a breakpoint is hit while enabled in this fashion, it becomes disabled.\n\
2600 See the \"tbreak\" command which sets a breakpoint and enables it once.",
2601            &enablebreaklist);
2602
2603   add_cmd ("delete", no_class, enable_delete_command,
2604            "Enable breakpoints and delete when hit.  Give breakpoint numbers.\n\
2605 If a breakpoint is hit while enabled in this fashion, it is deleted.",
2606            &enablebreaklist);
2607
2608   add_cmd ("delete", no_class, enable_delete_command,
2609            "Enable breakpoints and delete when hit.  Give breakpoint numbers.\n\
2610 If a breakpoint is hit while enabled in this fashion, it is deleted.",
2611            &enablelist);
2612
2613   add_cmd ("once", no_class, enable_once_command,
2614            "Enable breakpoints for one hit.  Give breakpoint numbers.\n\
2615 If a breakpoint is hit while enabled in this fashion, it becomes disabled.\n\
2616 See the \"tbreak\" command which sets a breakpoint and enables it once.",
2617            &enablelist);
2618
2619   add_prefix_cmd ("disable", class_breakpoint, disable_command,
2620            "Disable some breakpoints.\n\
2621 Arguments are breakpoint numbers with spaces in between.\n\
2622 To disable all breakpoints, give no argument.\n\
2623 A disabled breakpoint is not forgotten, but has no effect until reenabled.",
2624                   &disablelist, "disable ", 1, &cmdlist);
2625   add_com_alias ("dis", "disable", class_breakpoint, 1);
2626   add_com_alias ("disa", "disable", class_breakpoint, 1);
2627
2628   add_cmd ("breakpoints", class_alias, disable_command,
2629            "Disable some breakpoints.\n\
2630 Arguments are breakpoint numbers with spaces in between.\n\
2631 To disable all breakpoints, give no argument.\n\
2632 A disabled breakpoint is not forgotten, but has no effect until reenabled.\n\
2633 This command may be abbreviated \"disable\".",
2634            &disablelist);
2635
2636   add_prefix_cmd ("delete", class_breakpoint, delete_command,
2637            "Delete some breakpoints or auto-display expressions.\n\
2638 Arguments are breakpoint numbers with spaces in between.\n\
2639 To delete all breakpoints, give no argument.\n\
2640 \n\
2641 Also a prefix command for deletion of other GDB objects.\n\
2642 The \"unset\" command is also an alias for \"delete\".",
2643                   &deletelist, "delete ", 1, &cmdlist);
2644   add_com_alias ("d", "delete", class_breakpoint, 1);
2645
2646   add_cmd ("breakpoints", class_alias, delete_command,
2647            "Delete some breakpoints or auto-display expressions.\n\
2648 Arguments are breakpoint numbers with spaces in between.\n\
2649 To delete all breakpoints, give no argument.\n\
2650 This command may be abbreviated \"delete\".",
2651            &deletelist);
2652
2653   add_com ("clear", class_breakpoint, clear_command,
2654            "Clear breakpoint at specified line or function.\n\
2655 Argument may be line number, function name, or \"*\" and an address.\n\
2656 If line number is specified, all breakpoints in that line are cleared.\n\
2657 If function is specified, breakpoints at beginning of function are cleared.\n\
2658 If an address is specified, breakpoints at that address are cleared.\n\n\
2659 With no argument, clears all breakpoints in the line that the selected frame\n\
2660 is executing in.\n\
2661 \n\
2662 See also the \"delete\" command which clears breakpoints by number.");
2663
2664   add_com ("break", class_breakpoint, break_command,
2665            "Set breakpoint at specified line or function.\n\
2666 Argument may be line number, function name, or \"*\" and an address.\n\
2667 If line number is specified, break at start of code for that line.\n\
2668 If function is specified, break at start of code for that function.\n\
2669 If an address is specified, break at that exact address.\n\
2670 With no arg, uses current execution address of selected stack frame.\n\
2671 This is useful for breaking on return to a stack frame.\n\
2672 \n\
2673 Multiple breakpoints at one place are permitted, and useful if conditional.\n\
2674 \n\
2675 Do \"help breakpoints\" for info on other commands dealing with breakpoints.");
2676   add_com_alias ("b", "break", class_run, 1);
2677   add_com_alias ("br", "break", class_run, 1);
2678   add_com_alias ("bre", "break", class_run, 1);
2679   add_com_alias ("brea", "break", class_run, 1);
2680
2681   add_info ("breakpoints", breakpoints_info,
2682             "Status of user-settable breakpoints, or breakpoint number NUMBER.\n\
2683 The \"Type\" column indicates one of:\n\
2684 \tbreakpoint     - normal breakpoint\n\
2685 \twatchpoint     - watchpoint\n\
2686 The \"Disp\" column contains one of \"keep\", \"del\", or \"dis\" to indicate\n\
2687 the disposition of the breakpoint after it gets hit.  \"dis\" means that the\n\
2688 breakpoint will be disabled.  The \"Address\" and \"What\" columns indicate the\n\
2689 address and file/line number respectively.\n\n\
2690 Convenience variable \"$_\" and default examine address for \"x\"\n\
2691 are set to the address of the last breakpoint listed.\n\n\
2692 Convenience variable \"$bpnum\" contains the number of the last\n\
2693 breakpoint set.");
2694
2695 #if MAINTENANCE_CMDS
2696
2697   add_cmd ("breakpoints", class_maintenance, maintenance_info_breakpoints,
2698             "Status of all breakpoints, or breakpoint number NUMBER.\n\
2699 The \"Type\" column indicates one of:\n\
2700 \tbreakpoint     - normal breakpoint\n\
2701 \twatchpoint     - watchpoint\n\
2702 \tlongjmp        - internal breakpoint used to step through longjmp()\n\
2703 \tlongjmp resume - internal breakpoint at the target of longjmp()\n\
2704 \tuntil          - internal breakpoint used by the \"until\" command\n\
2705 \tfinish         - internal breakpoint used by the \"finish\" command\n\
2706 The \"Disp\" column contains one of \"keep\", \"del\", or \"dis\" to indicate\n\
2707 the disposition of the breakpoint after it gets hit.  \"dis\" means that the\n\
2708 breakpoint will be disabled.  The \"Address\" and \"What\" columns indicate the\n\
2709 address and file/line number respectively.\n\n\
2710 Convenience variable \"$_\" and default examine address for \"x\"\n\
2711 are set to the address of the last breakpoint listed.\n\n\
2712 Convenience variable \"$bpnum\" contains the number of the last\n\
2713 breakpoint set.",
2714            &maintenanceinfolist);
2715
2716 #endif  /* MAINTENANCE_CMDS */
2717
2718   add_com ("catch", class_breakpoint, catch_command,
2719          "Set breakpoints to catch exceptions that are raised.\n\
2720 Argument may be a single exception to catch, multiple exceptions\n\
2721 to catch, or the default exception \"default\".  If no arguments\n\
2722 are given, breakpoints are set at all exception handlers catch clauses\n\
2723 within the current scope.\n\
2724 \n\
2725 A condition specified for the catch applies to all breakpoints set\n\
2726 with this command\n\
2727 \n\
2728 Do \"help breakpoints\" for info on other commands dealing with breakpoints.");
2729
2730   add_com ("watch", class_breakpoint, watch_command,
2731            "Set a watchpoint for an expression.\n\
2732 A watchpoint stops execution of your program whenever the value of\n\
2733 an expression changes.");
2734
2735   add_info ("watchpoints", breakpoints_info,
2736             "Synonym for ``info breakpoints''.");
2737 }
2738
2739 /* OK, when we call objfile_relocate, we need to relocate breakpoints
2740    too.  breakpoint_re_set is not a good choice--for example, if
2741    addr_string contains just a line number without a file name the
2742    breakpoint might get set in a different file.  In general, there is
2743    no need to go all the way back to the user's string (though this might
2744    work if some effort were made to canonicalize it), since symtabs and
2745    everything except addresses are still valid.
2746
2747    Probably the best way to solve this is to have each breakpoint save
2748    the objfile and the section number that was used to set it (if set
2749    by "*addr", probably it is best to use find_pc_line to get a symtab
2750    and use the objfile and block_line_section for that symtab).  Then
2751    objfile_relocate can call fixup_breakpoints with the objfile and
2752    the new_offsets, and it can relocate only the appropriate breakpoints.  */
2753
2754 #ifdef IBM6000_TARGET
2755 /* But for now, just kludge it based on the concept that before an
2756    objfile is relocated the breakpoint is below 0x10000000, and afterwards
2757    it is higher, so that way we only relocate each breakpoint once.  */
2758
2759 void
2760 fixup_breakpoints (low, high, delta)
2761   CORE_ADDR low;
2762   CORE_ADDR high;
2763   CORE_ADDR delta;
2764 {
2765   struct breakpoint *b;
2766
2767   ALL_BREAKPOINTS (b)
2768     {
2769      if (b->address >= low && b->address <= high)
2770        b->address += delta;
2771     }
2772 }
2773 #endif