From mboxrd@z Thu Jan 1 00:00:00 1970 From: Jim Blandy To: Andrew Cagney Cc: Stephane Carrez , gdb-patches@sourceware.cygnus.com, Jim Blandy Subject: Re: path for gdb/dwarf2read.c, support 16-bit targets in dwarf-2 Date: Tue, 28 Mar 2000 08:24:00 -0000 Message-id: References: <38B2F3D3.54CF0AF0@worldnet.fr> <38BB5463.D6E5B75C@cygnus.com> <38C0D9D9.70987863@worldnet.fr> <38C225F3.9E236A55@cygnus.com> X-SW-Source: 2000-03/msg00644.html > > elf16 is not a good idea. I think we must not mix the size of cpu > > address with the format of ELF files. The ELF file can be larger than > > 64K and we might need indexes larger than 16-bit. > > When I say ``elf16'', I was thinking of an elf object file that has 16 > bit addresses. I'm not sure what other consequences such a move would > have. > > Is there any reason why s->arch_size isn't 16 in your case? s->arch_size is not an especially meaningful field. It exists only to indicate whether you've got an ELF32 or ELF64 format file. I think inventing a new ELF16 file format is a bad idea. There are a zillion things to take into account. It's much simpler to just use ELF32, and only link things into the lower 64k, which is what we've done with other 16-bit processors in the past. If you want to know the actual processor address size, there's a different BFD field whose job is to provide that information. That's bfd_arch_bits_per_address, which Stephane suggested we use instead. In general, the change that has dwarf2read checking the ELF backend data has just been a pain from day one. I remember fixing related dependency problems, people on the binutils list saying "This looks really wrong," and so on. GDB shouldn't be using internal BFD headers, and consulting internal ELF BFD data structures. I also buy Jim Kingdon's argument that it shouldn't be necessary to mask off the upper bits. The data in the ELF file should be correct. I'm going to revert the change which introduced address_significant_size in the first place. If this causes problems, then we'll fix the bug correctly. >From jimb@zwingli.cygnus.com Tue Mar 28 08:24:00 2000 From: Jim Blandy To: gdb-patches@sourceware.cygnus.com Subject: [PATCH] Don't trim addresses in Dwarf debug info Date: Tue, 28 Mar 2000 08:24:00 -0000 Message-id: <200003281624.LAA23161@zwingli.cygnus.com> X-SW-Source: 2000-03/msg00645.html Content-length: 4499 I've committed this: 2000-03-27 Jim Blandy * dwarf2read.c: Revert Andrew Cagney's change of Dec 15, 1997. Don't include "bfd-elf.h". (address_significant_size): Delete variable. (dwarf2_build_psymtabs_hard): Don't set it, or check for consistency between it and the Dwarf 2 compilation unit header address size. (read_address): Don't mask off bits above address_significant_size. * Makefile.in (dwarf2read.o): Don't depend on $(elf_bfd_h). (elf_bfd_h): Remove variable; it's no longer used. Index: gdb/dwarf2read.c =================================================================== RCS file: /cvs/cvsfiles/devo/gdb/dwarf2read.c,v retrieving revision 2.37 diff -c -r2.37 dwarf2read.c *** gdb/dwarf2read.c 2000/02/29 07:14:21 2.37 --- gdb/dwarf2read.c 2000/03/27 20:50:09 *************** *** 27,33 **** #include "defs.h" #include "bfd.h" - #include "elf-bfd.h" #include "symtab.h" #include "gdbtypes.h" #include "symfile.h" --- 27,32 ---- *************** *** 546,560 **** whatever scope is currently getting read. */ static int address_size; - /* Some elf32 object file formats while linked for a 32 bit address - space contain debug information that has assumed 64 bit - addresses. Eg 64 bit MIPS target produced by GCC/GAS/LD where the - symbol table contains 32bit address values while its .debug_info - section contains 64 bit address values. - ADDRESS_SIGNIFICANT_SIZE specifies the number significant bits in - the ADDRESS_SIZE bytes read from the file */ - static int address_significant_size; - /* Externals references. */ extern int info_verbose; /* From main.c; nonzero => verbose */ --- 545,550 ---- *************** *** 937,945 **** int comp_unit_has_pc_info; CORE_ADDR lowpc, highpc; - /* Number of bytes of any addresses that are signficant */ - address_significant_size = get_elf_backend_data (abfd)->s->arch_size / 8; - info_ptr = dwarf_info_buffer; abbrev_ptr = dwarf_abbrev_buffer; --- 927,932 ---- *************** *** 980,992 **** (long) (beg_of_comp_unit - dwarf_info_buffer)); return; } - if (address_size < address_significant_size) - { - error ("Dwarf Error: bad address size (%ld) in compilation unit header (offset 0x%lx + 11).", - (long) cu_header.addr_size, - (long) (beg_of_comp_unit - dwarf_info_buffer)); - } - /* Read the abbrevs for this compilation unit into a table */ dwarf2_read_abbrevs (abfd, cu_header.abbrev_offset); make_cleanup (dwarf2_empty_abbrev_table, NULL); --- 967,972 ---- *************** *** 3499,3516 **** default: /* *THE* alternative is 8, right? */ abort (); - } - /* If the address being read is larger than the address that is - applicable for the object file format then mask it down to the - correct size. Take care to avoid unnecessary shift or shift - overflow */ - if (address_size > address_significant_size - && address_significant_size < sizeof (CORE_ADDR)) - { - CORE_ADDR mask = ((CORE_ADDR) 0) - 1; - retval &= ~(mask << (address_significant_size * 8)); } ! return retval; } static char * --- 3479,3487 ---- default: /* *THE* alternative is 8, right? */ abort (); } ! ! return retval; } static char * Index: gdb/Makefile.in =================================================================== RCS file: /cvs/cvsfiles/devo/gdb/Makefile.in,v retrieving revision 1.760 diff -c -r1.760 Makefile.in *** gdb/Makefile.in 2000/03/20 04:36:02 1.760 --- gdb/Makefile.in 2000/03/27 20:50:10 *************** *** 507,513 **** getopt_h = $(INCLUDE_DIR)/getopt.h floatformat_h = $(INCLUDE_DIR)/floatformat.h bfd_h = $(BFD_DIR)/bfd.h - elf_bfd_h = $(BFD_SRC)/elf-bfd.h dis-asm_h = $(INCLUDE_DIR)/dis-asm.h remote-sim_h = $(INCLUDE_DIR)/remote-sim.h --- 507,512 ---- *************** *** 1251,1257 **** $(expression_h) $(gdbtypes_h) language.h objfiles.h symfile.h \ $(symtab_h) gdb_string.h ! dwarf2read.o: dwarf2read.c $(bfd_h) $(elf_bfd_h) buildsym.h $(defs_h) \ $(expression_h) $(gdbtypes_h) language.h objfiles.h symfile.h \ $(symtab_h) gdb_string.h --- 1250,1256 ---- $(expression_h) $(gdbtypes_h) language.h objfiles.h symfile.h \ $(symtab_h) gdb_string.h ! dwarf2read.o: dwarf2read.c $(bfd_h) buildsym.h $(defs_h) \ $(expression_h) $(gdbtypes_h) language.h objfiles.h symfile.h \ $(symtab_h) gdb_string.h >From jimb@zwingli.cygnus.com Tue Mar 28 08:26:00 2000 From: Jim Blandy To: Andrew Cagney Cc: Jim Kingdon , Stephane Carrez , gdb-patches@sourceware.cygnus.com, Jim Blandy Subject: Re: path for gdb/dwarf2read.c, support 16-bit targets in dwarf-2 Date: Tue, 28 Mar 2000 08:26:00 -0000 Message-id: References: <38B2F3D3.54CF0AF0@worldnet.fr> <38BB5463.D6E5B75C@cygnus.com> <38C0D9D9.70987863@worldnet.fr> <38C225F3.9E236A55@cygnus.com> <38C737EE.513259B9@cygnus.com> X-SW-Source: 2000-03/msg00646.html Content-length: 1204 > > The whole address_significant_size code in dwarf2read.c strikes me as > > a rather ugly kludge to work around bugs elsewhere in the tool chain. > > If someone is supplying a 32 bit pointer to GDB on a 16 bit target, > > shouldn't the rest of the tool chain be responsible for making sure > > the high bits are zero rather than expecting GDB to mask it off? > > Granted there might be complications here, like there are cases on > > MIPS where we treat an address as signed rather than unsigned, but I'm > > also pretty clear on whether that is actually design or just a bug. I > > could be wrong/persuadable, of course, and perhaps someone has a > > better idea of all this (in which case I'd suggest commenting > > arch_size at bfd/elf-bfd.h and/or expanding comments at > > bfd_arch_bits_per_address in bfd/archures.c). > > FYI, in the MIPS case it is a feature of the hardware. GDB has little > choice in the matter. Can you explain why, in the MIPS case, GCC/GAS/LD are unable to place correct information in the upper bits of the Dwarf addresses? (That sounds like a rhetorical question, but it's not. I'm having a hard time imagining why address_significant_bits was the right solution.) >From jimb@zwingli.cygnus.com Tue Mar 28 08:50:00 2000 From: Jim Blandy To: Chris Faylor Cc: gdb-patches@sourceware.cygnus.com Subject: Re: [RFA] Avoid core dumping on corrupt stabs entry Date: Tue, 28 Mar 2000 08:50:00 -0000 Message-id: References: <20000327204057.A24783@cygnus.com> X-SW-Source: 2000-03/msg00647.html Content-length: 860 Approved, thanks. > Any objections to this patch? It seems to be in the spirit of the rest > of the file. > > cgf > > 2000-03-27 Christopher Faylor > > * partial-stab.h: Add one more check against corrupted or irregular > stabs entry. > > Index: partial-stab.h > =================================================================== > RCS file: /cvs/cvsfiles/devo/gdb/partial-stab.h,v > retrieving revision 2.68 > diff -u -p -r2.68 partial-stab.h > --- partial-stab.h 1999/09/14 22:50:39 2.68 > +++ partial-stab.h 2000/03/28 01:37:53 > @@ -393,7 +393,7 @@ switch (CUR_SYMBOL_TYPE) > > #ifdef DBXREAD_ONLY > /* See if this is an end of function stab. */ > - if (CUR_SYMBOL_TYPE == N_FUN && *namestring == '\000') > + if (pst && CUR_SYMBOL_TYPE == N_FUN && *namestring == '\000') > { > unsigned long valu; > > >From shebs@shebs.cnchost.com Tue Mar 28 08:59:00 2000 From: Stan Shebs To: gdb-patches@sourceware.cygnus.com Cc: 3diff@gnu.org Subject: GDB manual changes Date: Tue, 28 Mar 2000 08:59:00 -0000 Message-id: <38E0E672.478B088F@shebs.cnchost.com> X-SW-Source: 2000-03/msg00648.html Content-length: 136933 I've just committed a pile of changes to the manual. This includes the duplication of the top-level menu for the benefit of @ifhtml, the re-removal of node links, and various formatting changes to make @smallbook come out right (as requested by Brian Youmans). I tested on 3.12, 3.12h (RH 6.1 version), and 4.0. Apparently texi2html has a problem with the top-level menu that is under @ifhtml, and it gets garbled, although 4.0 makeinfo -html works fine (but it can only make one monster html file, sigh). It's functionally no worse than before, but looks bad. I'm still planning to rewrite the introduction to use a more meaningful example program, and we still have undocumented commands that ought to be mentioned, so this isn't the end, but this should be a good base for the next round of tweaks. (I left the remote protocol section mostly untouched, since JT has a patch to apply.) Stan 2000-03-28 Stan Shebs * gdb.texinfo: Update dates, bump to Eighth Edition (note expectation of additional changes before release), update ISBN, add copy of top-level menu for @ifhtml, remove explicit node links, rephrase and/or shorten lines to fix formatting problem in both regular and @smallbook formats. * annotate.texi: Shorten lines in example, use smallexample consistently everywhere. * Makefile.in: Add comment about texinfo 4.0 html generation. (SFILES_INCLUDED): Add annotate.texi. Index: Makefile.in =================================================================== RCS file: /cvs/src/src/gdb/doc/Makefile.in,v retrieving revision 1.3 diff -p -r1.3 Makefile.in *** Makefile.in 2000/03/24 07:27:24 1.3 --- Makefile.in 2000/03/28 16:33:45 *************** TEXIDIR=${gdbdir}/../texinfo *** 40,45 **** --- 40,49 ---- # where to find makeinfo, preferably one designed for texinfo-2 MAKEINFO=makeinfo + # Note that texinfo 4.0's makeinfo --html can only generate a + # single file, which would be too large, so continue to use + # texi2html. -sts 2000-03-28 + MAKEHTML = texi2html MAKEHTMLFLAGS = -glossary -menu -split_chapter *************** TEXINDEX = texindex *** 83,89 **** DVIPS = dvips # Main GDB manual's source files ! SFILES_INCLUDED = gdb-cfg.texi SFILES_LOCAL = $(srcdir)/gdb.texinfo GDBvn.texi $(SFILES_INCLUDED) --- 87,93 ---- DVIPS = dvips # Main GDB manual's source files ! SFILES_INCLUDED = gdb-cfg.texi $(srcdir)/annotate.texi SFILES_LOCAL = $(srcdir)/gdb.texinfo GDBvn.texi $(SFILES_INCLUDED) Index: annotate.texi =================================================================== RCS file: /cvs/src/src/gdb/doc/annotate.texi,v retrieving revision 1.3 diff -p -r1.3 annotate.texi *** annotate.texi 2000/03/24 07:30:06 1.3 --- annotate.texi 2000/03/28 16:33:45 *************** *** 60,68 **** @chapter @value{GDBN} Annotations @end ifclear ! This chapter describes annotations in @value{GDBN}, the GNU symbolic debugger. ! Annotations are designed to interface @value{GDBN} to graphical user interfaces ! or other similar programs which want to interact with @value{GDBN} at a relatively high level. @ignore --- 60,68 ---- @chapter @value{GDBN} Annotations @end ifclear ! This chapter describes annotations in @value{GDBN}. Annotations are ! designed to interface @value{GDBN} to graphical user interfaces or other ! similar programs which want to interact with @value{GDBN} at a relatively high level. @ignore *************** additional information, and a newline. *** 100,109 **** cannot contain newline characters. Any output not beginning with a newline and two @samp{control-z} ! characters denotes literal output from @value{GDBN}. Currently there is no need ! for @value{GDBN} to output a newline followed by two @samp{control-z} characters, ! but if there was such a need, the annotations could be extended with an ! @samp{escape} annotation which means those three characters as output. A simple example of starting up @value{GDBN} with annotations is: --- 100,110 ---- cannot contain newline characters. Any output not beginning with a newline and two @samp{control-z} ! characters denotes literal output from @value{GDBN}. Currently there is ! no need for @value{GDBN} to output a newline followed by two ! @samp{control-z} characters, but if there was such a need, the ! annotations could be extended with an @samp{escape} annotation which ! means those three characters as output. A simple example of starting up @value{GDBN} with annotations is: *************** A simple example of starting up @value{G *** 111,120 **** $ gdb --annotate=2 GNU GDB 5.0 Copyright 2000 Free Software Foundation, Inc. ! GDB is free software, covered by the GNU General Public License, and you are ! welcome to change it and/or distribute copies of it under certain conditions. Type "show copying" to see the conditions. ! There is absolutely no warranty for GDB. Type "show warranty" for details. This GDB was configured as "sparc-sun-sunos4.1.3" ^Z^Zpre-prompt --- 112,123 ---- $ gdb --annotate=2 GNU GDB 5.0 Copyright 2000 Free Software Foundation, Inc. ! GDB is free software, covered by the GNU General Public License, ! and you are welcome to change it and/or distribute copies of it ! under certain conditions. Type "show copying" to see the conditions. ! There is absolutely no warranty for GDB. Type "show warranty" ! for details. This GDB was configured as "sparc-sun-sunos4.1.3" ^Z^Zpre-prompt *************** quit *** 126,144 **** $ @end smallexample ! Here @samp{quit} is input to @value{GDBN}; the rest is output from @value{GDBN}. The three ! lines beginning @samp{^Z^Z} (where @samp{^Z} denotes a @samp{control-z} ! character) are annotations; the rest is output from @value{GDBN}. @node Server Prefix @section The Server Prefix @cindex server prefix for annotations ! To issue a command to @value{GDBN} without affecting certain aspects of the state ! which is seen by users, prefix it with @samp{server }. This means that ! this command will not affect the command history, nor will it affect ! @value{GDBN}'s notion of which command to repeat if @key{RET} is pressed on a ! line by itself. The server prefix does not affect the recording of values into the value history; to print a value without recording it into the value history, --- 129,148 ---- $ @end smallexample ! Here @samp{quit} is input to @value{GDBN}; the rest is output from ! @value{GDBN}. The three lines beginning @samp{^Z^Z} (where @samp{^Z} ! denotes a @samp{control-z} character) are annotations; the rest is ! output from @value{GDBN}. @node Server Prefix @section The Server Prefix @cindex server prefix for annotations ! To issue a command to @value{GDBN} without affecting certain aspects of ! the state which is seen by users, prefix it with @samp{server }. This ! means that this command will not affect the command history, nor will it ! affect @value{GDBN}'s notion of which command to repeat if @key{RET} is ! pressed on a line by itself. The server prefix does not affect the recording of values into the value history; to print a value without recording it into the value history, *************** use the @code{output} command instead of *** 148,155 **** @section Values @cindex annotations for values ! When a value is printed in various contexts, @value{GDBN} uses annotations to ! delimit the value from the surrounding text. @findex value-history-begin @findex value-history-value --- 152,159 ---- @section Values @cindex annotations for values ! When a value is printed in various contexts, @value{GDBN} uses ! annotations to delimit the value from the surrounding text. @findex value-history-begin @findex value-history-value *************** delimit the value from the surrounding t *** 157,169 **** If a value is printed using @code{print} and added to the value history, the annotation looks like ! @example ^Z^Zvalue-history-begin @var{history-number} @var{value-flags} @var{history-string} ^Z^Zvalue-history-value @var{the-value} ^Z^Zvalue-history-end ! @end example where @var{history-number} is the number it is getting in the value history, @var{history-string} is a string, such as @samp{$5 = }, which --- 161,173 ---- If a value is printed using @code{print} and added to the value history, the annotation looks like ! @smallexample ^Z^Zvalue-history-begin @var{history-number} @var{value-flags} @var{history-string} ^Z^Zvalue-history-value @var{the-value} ^Z^Zvalue-history-end ! @end smallexample where @var{history-number} is the number it is getting in the value history, @var{history-string} is a string, such as @samp{$5 = }, which *************** a value which can be dereferenced and @s *** 176,186 **** If the value is not added to the value history (it is an invalid float or it is printed with the @code{output} command), the annotation is similar: ! @example ^Z^Zvalue-begin @var{value-flags} @var{the-value} ^Z^Zvalue-end ! @end example @findex arg-begin @findex arg-name-end --- 180,190 ---- If the value is not added to the value history (it is an invalid float or it is printed with the @code{output} command), the annotation is similar: ! @smallexample ^Z^Zvalue-begin @var{value-flags} @var{the-value} ^Z^Zvalue-end ! @end smallexample @findex arg-begin @findex arg-name-end *************** or it is printed with the @code{output} *** 189,195 **** When @value{GDBN} prints an argument to a function (for example, in the output from the @code{backtrace} command), it annotates it as follows: ! @example ^Z^Zarg-begin @var{argument-name} ^Z^Zarg-name-end --- 193,199 ---- When @value{GDBN} prints an argument to a function (for example, in the output from the @code{backtrace} command), it annotates it as follows: ! @smallexample ^Z^Zarg-begin @var{argument-name} ^Z^Zarg-name-end *************** from the @code{backtrace} command), it a *** 197,203 **** ^Z^Zarg-value @var{value-flags} @var{the-value} ^Z^Zarg-end ! @end example where @var{argument-name} is the name of the argument, @var{separator-string} is text which separates the name from the value --- 201,207 ---- ^Z^Zarg-value @var{value-flags} @var{the-value} ^Z^Zarg-end ! @end smallexample where @var{argument-name} is the name of the argument, @var{separator-string} is text which separates the name from the value *************** for the user's benefit (such as @samp{=} *** 211,217 **** @findex field-end When printing a structure, @value{GDBN} annotates it as follows: ! @example ^Z^Zfield-begin @var{value-flags} @var{field-name} ^Z^Zfield-name-end --- 215,221 ---- @findex field-end When printing a structure, @value{GDBN} annotates it as follows: ! @smallexample ^Z^Zfield-begin @var{value-flags} @var{field-name} ^Z^Zfield-name-end *************** When printing a structure, @value{GDBN} *** 219,225 **** ^Z^Zfield-value @var{the-value} ^Z^Zfield-end ! @end example where @var{field-name} is the name of the field, @var{separator-string} is text which separates the name from the value for the user's benefit --- 223,229 ---- ^Z^Zfield-value @var{the-value} ^Z^Zfield-end ! @end smallexample where @var{field-name} is the name of the field, @var{separator-string} is text which separates the name from the value for the user's benefit *************** same meanings as in a @code{value-histor *** 228,236 **** When printing an array, @value{GDBN} annotates it as follows: ! @example ^Z^Zarray-section-begin @var{array-index} @var{value-flags} ! @end example where @var{array-index} is the index of the first element being annotated and @var{value-flags} has the same meaning as in a --- 232,240 ---- When printing an array, @value{GDBN} annotates it as follows: ! @smallexample ^Z^Zarray-section-begin @var{array-index} @var{value-flags} ! @end smallexample where @var{array-index} is the index of the first element being annotated and @var{value-flags} has the same meaning as in a *************** annotated and @var{value-flags} has the *** 238,260 **** of elements, where is element can be either a single element: @findex elt ! @example @samp{,} @var{whitespace} ; @r{omitted for the first element} @var{the-value} ^Z^Zelt ! @end example or a repeated element @findex elt-rep @findex elt-rep-end ! @example @samp{,} @var{whitespace} ; @r{omitted for the first element} @var{the-value} ^Z^Zelt-rep @var{number-of-repititions} @var{repetition-string} ^Z^Zelt-rep-end ! @end example In both cases, @var{the-value} is the output for the value of the element and @var{whitespace} can contain spaces, tabs, and newlines. In --- 242,264 ---- of elements, where is element can be either a single element: @findex elt ! @smallexample @samp{,} @var{whitespace} ; @r{omitted for the first element} @var{the-value} ^Z^Zelt ! @end smallexample or a repeated element @findex elt-rep @findex elt-rep-end ! @smallexample @samp{,} @var{whitespace} ; @r{omitted for the first element} @var{the-value} ^Z^Zelt-rep @var{number-of-repititions} @var{repetition-string} ^Z^Zelt-rep-end ! @end smallexample In both cases, @var{the-value} is the output for the value of the element and @var{whitespace} can contain spaces, tabs, and newlines. In *************** user that repitition is being depicted. *** 267,275 **** Once all the array elements have been output, the array annotation is ended with ! @example ^Z^Zarray-section-end ! @end example @node Frame Annotations @section Frames --- 271,279 ---- Once all the array elements have been output, the array annotation is ended with ! @smallexample ^Z^Zarray-section-end ! @end smallexample @node Frame Annotations @section Frames *************** to frames printed when @value{GDBN} stop *** 282,291 **** @findex frame-begin The frame annotation begins with ! @example ^Z^Zframe-begin @var{level} @var{address} @var{level-string} ! @end example where @var{level} is the number of the frame (0 is the innermost frame, and other frames have positive numbers), @var{address} is the address of --- 286,295 ---- @findex frame-begin The frame annotation begins with ! @smallexample ^Z^Zframe-begin @var{level} @var{address} @var{level-string} ! @end smallexample where @var{level} is the number of the frame (0 is the innermost frame, and other frames have positive numbers), @var{address} is the address of *************** designed to convey the level to the user *** 295,303 **** does not depend on the language). The frame ends with @findex frame-end ! @example ^Z^Zframe-end ! @end example Between these annotations is the main body of the frame, which can consist of --- 299,307 ---- does not depend on the language). The frame ends with @findex frame-end ! @smallexample ^Z^Zframe-end ! @end smallexample Between these annotations is the main body of the frame, which can consist of *************** consist of *** 305,314 **** @itemize @bullet @item @findex function-call ! @example ^Z^Zfunction-call @var{function-call-string} ! @end example where @var{function-call-string} is text designed to convey to the user that this frame is associated with a function call made by @value{GDBN} to a --- 309,318 ---- @itemize @bullet @item @findex function-call ! @smallexample ^Z^Zfunction-call @var{function-call-string} ! @end smallexample where @var{function-call-string} is text designed to convey to the user that this frame is associated with a function call made by @value{GDBN} to a *************** function in the program being debugged. *** 316,325 **** @item @findex signal-handler-caller ! @example ^Z^Zsignal-handler-caller @var{signal-handler-caller-string} ! @end example where @var{signal-handler-caller-string} is text designed to convey to the user that this frame is associated with whatever mechanism is used --- 320,329 ---- @item @findex signal-handler-caller ! @smallexample ^Z^Zsignal-handler-caller @var{signal-handler-caller-string} ! @end smallexample where @var{signal-handler-caller-string} is text designed to convey to the user that this frame is associated with whatever mechanism is used *************** A normal frame. *** 334,345 **** This can optionally (depending on whether this is thought of as interesting information for the user to see) begin with ! @example ^Z^Zframe-address @var{address} ^Z^Zframe-address-end @var{separator-string} ! @end example where @var{address} is the address executing in the frame (the same address as in the @code{frame-begin} annotation, but printed in a form --- 338,349 ---- This can optionally (depending on whether this is thought of as interesting information for the user to see) begin with ! @smallexample ^Z^Zframe-address @var{address} ^Z^Zframe-address-end @var{separator-string} ! @end smallexample where @var{address} is the address executing in the frame (the same address as in the @code{frame-begin} annotation, but printed in a form *************** benefit. *** 352,363 **** @findex frame-args Then comes ! @example ^Z^Zframe-function-name @var{function-name} ^Z^Zframe-args @var{arguments} ! @end example where @var{function-name} is the name of the function executing in the frame, or @samp{??} if not known, and @var{arguments} are the arguments --- 356,367 ---- @findex frame-args Then comes ! @smallexample ^Z^Zframe-function-name @var{function-name} ^Z^Zframe-args @var{arguments} ! @end smallexample where @var{function-name} is the name of the function executing in the frame, or @samp{??} if not known, and @var{arguments} are the arguments *************** individually as well, @pxref{Value Annot *** 371,377 **** @findex frame-source-end If source information is available, a reference to it is then printed: ! @example ^Z^Zframe-source-begin @var{source-intro-string} ^Z^Zframe-source-file --- 375,381 ---- @findex frame-source-end If source information is available, a reference to it is then printed: ! @smallexample ^Z^Zframe-source-begin @var{source-intro-string} ^Z^Zframe-source-file *************** If source information is available, a re *** 381,387 **** ^Z^Zframe-source-line @var{line-number} ^Z^Zframe-source-end ! @end example where @var{source-intro-string} separates for the user's benefit the reference from the text which precedes it, @var{filename} is the name of --- 385,391 ---- ^Z^Zframe-source-line @var{line-number} ^Z^Zframe-source-end ! @end smallexample where @var{source-intro-string} separates for the user's benefit the reference from the text which precedes it, @var{filename} is the name of *************** If @value{GDBN} prints some information *** 393,402 **** library, which load segment, etc.; currently only done on the RS/6000), it is annotated with ! @example ^Z^Zframe-where @var{information} ! @end example Then, if source is to actually be displayed for this frame (for example, this is not true for output from the @code{backtrace} command), then a --- 397,406 ---- library, which load segment, etc.; currently only done on the RS/6000), it is annotated with ! @smallexample ^Z^Zframe-where @var{information} ! @end smallexample Then, if source is to actually be displayed for this frame (for example, this is not true for output from the @code{backtrace} command), then a *************** output, not in addition. *** 419,425 **** When @value{GDBN} is told to display something using the @code{display} command, the results of the display are annotated: ! @example ^Z^Zdisplay-begin @var{number} ^Z^Zdisplay-number-end --- 423,429 ---- When @value{GDBN} is told to display something using the @code{display} command, the results of the display are annotated: ! @smallexample ^Z^Zdisplay-begin @var{number} ^Z^Zdisplay-number-end *************** the results of the display are annotated *** 433,439 **** ^Z^Zdisplay-value @var{value} ^Z^Zdisplay-end ! @end example where @var{number} is the number of the display, @var{number-separator} is intended to separate the number from what follows for the user, --- 437,443 ---- ^Z^Zdisplay-value @var{value} ^Z^Zdisplay-end ! @end smallexample where @var{number} is the number of the display, @var{number-separator} is intended to separate the number from what follows for the user, *************** annotation which denotes the end of any *** 459,469 **** associated with the input. For example, the @code{prompt} input type features the following annotations: ! @example ^Z^Zpre-prompt ^Z^Zprompt ^Z^Zpost-prompt ! @end example The input types are --- 463,473 ---- associated with the input. For example, the @code{prompt} input type features the following annotations: ! @smallexample ^Z^Zpre-prompt ^Z^Zprompt ^Z^Zpost-prompt ! @end smallexample The input types are *************** presence of annotations. *** 508,523 **** @cindex annotations for errors, warnings and interrupts @findex quit ! @example ^Z^Zquit ! @end example This annotation occurs right before @value{GDBN} responds to an interrupt. @findex error ! @example ^Z^Zerror ! @end example This annotation occurs right before @value{GDBN} responds to an error. --- 512,527 ---- @cindex annotations for errors, warnings and interrupts @findex quit ! @smallexample ^Z^Zquit ! @end smallexample This annotation occurs right before @value{GDBN} responds to an interrupt. @findex error ! @smallexample ^Z^Zerror ! @end smallexample This annotation occurs right before @value{GDBN} responds to an error. *************** to the top level. *** 532,540 **** @findex error-begin A quit or error annotation may be preceded by ! @example ^Z^Zerror-begin ! @end example Any output between that and the quit or error annotation is the error message. --- 536,544 ---- @findex error-begin A quit or error annotation may be preceded by ! @smallexample ^Z^Zerror-begin ! @end smallexample Any output between that and the quit or error annotation is the error message. *************** The output from the @code{info breakpoin *** 551,561 **** @findex breakpoints-headers @findex breakpoints-table ! @example ^Z^Zbreakpoints-headers @var{header-entry} ^Z^Zbreakpoints-table ! @end example where @var{header-entry} has the same syntax as an entry (see below) but instead of containing data, it contains strings which are intended to --- 555,565 ---- @findex breakpoints-headers @findex breakpoints-table ! @smallexample ^Z^Zbreakpoints-headers @var{header-entry} ^Z^Zbreakpoints-table ! @end smallexample where @var{header-entry} has the same syntax as an entry (see below) but instead of containing data, it contains strings which are intended to *************** of: *** 566,572 **** @findex record @findex field ! @example ^Z^Zrecord ^Z^Zfield 0 @var{number} --- 570,576 ---- @findex record @findex field ! @smallexample ^Z^Zrecord ^Z^Zfield 0 @var{number} *************** of: *** 588,594 **** @var{ignore-count} ^Z^Zfield 9 @var{commands} ! @end example Note that @var{address} is intended for user consumption---the syntax varies depending on the language. --- 592,598 ---- @var{ignore-count} ^Z^Zfield 9 @var{commands} ! @end smallexample Note that @var{address} is intended for user consumption---the syntax varies depending on the language. *************** varies depending on the language. *** 596,604 **** The output ends with @findex breakpoints-table-end ! @example ^Z^Zbreakpoints-table-end ! @end example @node Invalidation @section Invalidation Notices --- 600,608 ---- The output ends with @findex breakpoints-table-end ! @smallexample ^Z^Zbreakpoints-table-end ! @end smallexample @node Invalidation @section Invalidation Notices *************** deleted a breakpoint. *** 630,644 **** When the program starts executing due to a @value{GDBN} command such as @code{step} or @code{continue}, ! @example ^Z^Zstarting ! @end example is output. When the program stops, ! @example ^Z^Zstopped ! @end example is output. Before the @code{stopped} annotation, a variety of annotations describe how the program stopped. --- 634,648 ---- When the program starts executing due to a @value{GDBN} command such as @code{step} or @code{continue}, ! @smallexample ^Z^Zstarting ! @end smallexample is output. When the program stops, ! @smallexample ^Z^Zstopped ! @end smallexample is output. Before the @code{stopped} annotation, a variety of annotations describe how the program stopped. *************** successful exit, otherwise nonzero). *** 658,664 **** The program exited with a signal. After the @code{^Z^Zsignalled}, the annotation continues: ! @example @var{intro-text} ^Z^Zsignal-name @var{name} --- 662,668 ---- The program exited with a signal. After the @code{^Z^Zsignalled}, the annotation continues: ! @smallexample @var{intro-text} ^Z^Zsignal-name @var{name} *************** annotation continues: *** 668,674 **** @var{string} ^Z^Zsignal-string-end @var{end-text} ! @end example where @var{name} is the name of the signal, such as @code{SIGILL} or @code{SIGSEGV}, and @var{string} is the explanation of the signal, such --- 672,678 ---- @var{string} ^Z^Zsignal-string-end @var{end-text} ! @end smallexample where @var{name} is the name of the signal, such as @code{SIGILL} or @code{SIGSEGV}, and @var{string} is the explanation of the signal, such *************** The program hit watchpoint number @var{n *** 698,706 **** @findex source The following annotation is used instead of displaying source code: ! @example ^Z^Zsource @var{filename}:@var{line}:@var{character}:@var{middle}:@var{addr} ! @end example where @var{filename} is an absolute file name indicating which source file, @var{line} is the line number within that file (where 1 is the --- 702,710 ---- @findex source The following annotation is used instead of displaying source code: ! @smallexample ^Z^Zsource @var{filename}:@var{line}:@var{character}:@var{middle}:@var{addr} ! @end smallexample where @var{filename} is an absolute file name indicating which source file, @var{line} is the line number within that file (where 1 is the Index: gdb.texinfo =================================================================== RCS file: /cvs/src/src/gdb/doc/gdb.texinfo,v retrieving revision 1.8 diff -p -r1.8 gdb.texinfo *** gdb.texinfo 2000/03/28 02:25:13 1.8 --- gdb.texinfo 2000/03/28 16:33:52 *************** *** 1,5 **** \input texinfo @c -*-texinfo-*- ! @c Copyright 1988-1999 @c Free Software Foundation, Inc. @c @c %**start of header --- 1,5 ---- \input texinfo @c -*-texinfo-*- ! @c Copyright 1988-2000 @c Free Software Foundation, Inc. @c @c %**start of header *************** *** 25,39 **** @syncodeindex vr cp @c !!set GDB manual's edition---not the same as GDB version! ! @set EDITION Seventh @c !!set GDB manual's revision date ! @set DATE February 1999 ! @c THIS MANUAL REQUIRES TEXINFO-2 macros and info-makers to format properly. @c This is a dir.info fragment to support semi-automated addition of ! @c manuals to an info tree. zoo@cygnus.com is developing this facility. @dircategory Programming & development tools. @direntry * Gdb: (gdb). The @sc{gnu} debugger. --- 25,39 ---- @syncodeindex vr cp @c !!set GDB manual's edition---not the same as GDB version! ! @set EDITION Eighth @c !!set GDB manual's revision date ! @set DATE March 2000 ! @c THIS MANUAL REQUIRES TEXINFO 3.12 OR LATER. @c This is a dir.info fragment to support semi-automated addition of ! @c manuals to an info tree. @dircategory Programming & development tools. @direntry * Gdb: (gdb). The @sc{gnu} debugger. *************** This is the @value{EDITION} Edition, @va *** 47,53 **** of @cite{Debugging with @value{GDBN}: the @sc{gnu} Source-Level Debugger} for @value{GDBN} Version @value{GDBVN}. ! Copyright (C) 1988-1999 Free Software Foundation, Inc. Permission is granted to make and distribute verbatim copies of this manual provided the copyright notice and this permission notice --- 47,53 ---- of @cite{Debugging with @value{GDBN}: the @sc{gnu} Source-Level Debugger} for @value{GDBN} Version @value{GDBVN}. ! Copyright (C) 1988-2000 Free Software Foundation, Inc. Permission is granted to make and distribute verbatim copies of this manual provided the copyright notice and this permission notice *************** into another language, under the above c *** 85,101 **** } @end tex - @c ISBN seems to be wrong... - @vskip 0pt plus 1filll ! Copyright @copyright{} 1988-1999 Free Software Foundation, Inc. @sp 2 Published by the Free Software Foundation @* 59 Temple Place - Suite 330, @* Boston, MA 02111-1307 USA @* ! Printed copies are available for $20 each. @* ! ISBN 1-882114-11-6 @* ! Permission is granted to make and distribute verbatim copies of this manual provided the copyright notice and this permission notice are preserved on all copies. --- 85,98 ---- } @end tex @vskip 0pt plus 1filll ! Copyright @copyright{} 1988-2000 Free Software Foundation, Inc. @sp 2 Published by the Free Software Foundation @* 59 Temple Place - Suite 330, @* Boston, MA 02111-1307 USA @* ! ISBN 1-882114-77-9 @* ! Permission is granted to make and distribute verbatim copies of this manual provided the copyright notice and this permission notice are preserved on all copies. *************** into another language, under the above c *** 110,127 **** @end titlepage @page - - @node Top, Summary, (dir), (dir) @ifinfo @top Debugging with @value{GDBN} This file describes @value{GDBN}, the @sc{gnu} symbolic debugger. This is the @value{EDITION} Edition, @value{DATE}, for @value{GDBN} Version @value{GDBVN}. ! Copyright (C) 1988-1999 Free Software Foundation, Inc. @end ifinfo @menu * Summary:: Summary of @value{GDBN} * Sample Session:: A sample @value{GDBN} session --- 107,173 ---- @end titlepage @page @ifinfo + @node Top, Summary, (dir), (dir) + @top Debugging with @value{GDBN} This file describes @value{GDBN}, the @sc{gnu} symbolic debugger. This is the @value{EDITION} Edition, @value{DATE}, for @value{GDBN} Version @value{GDBVN}. + + Copyright (C) 1988-2000 Free Software Foundation, Inc. + + @menu + * Summary:: Summary of @value{GDBN} + * Sample Session:: A sample @value{GDBN} session + + * Invocation:: Getting in and out of @value{GDBN} + * Commands:: @value{GDBN} commands + * Running:: Running programs under @value{GDBN} + * Stopping:: Stopping and continuing + * Stack:: Examining the stack + * Source:: Examining source files + * Data:: Examining data ! * Languages:: Using @value{GDBN} with different languages ! ! * Symbols:: Examining the symbol table ! * Altering:: Altering execution ! * GDB Files:: @value{GDBN} files ! * Targets:: Specifying a debugging target ! * Configurations:: Configuration-specific information ! * Controlling GDB:: Controlling @value{GDBN} ! * Sequences:: Canned sequences of commands ! * Emacs:: Using @value{GDBN} under @sc{gnu} Emacs ! * Annotations:: @value{GDBN}'s annotation interface. ! ! * GDB Bugs:: Reporting bugs in @value{GDBN} ! * Formatting Documentation:: How to format and print @value{GDBN} documentation ! ! * Command Line Editing:: Command Line Editing ! * Using History Interactively:: Using History Interactively ! * Installing GDB:: Installing GDB ! * Index:: Index ! @end menu ! @end ifinfo + + @c the replication sucks, but this avoids a texinfo 3.12 lameness + + @ifhtml + @node Top + + @top Debugging with @value{GDBN} + + This file describes @value{GDBN}, the @sc{gnu} symbolic debugger. + + This is the @value{EDITION} Edition, @value{DATE}, for @value{GDBN} Version + @value{GDBVN}. + + Copyright (C) 1988-2000 Free Software Foundation, Inc. + @menu * Summary:: Summary of @value{GDBN} * Sample Session:: A sample @value{GDBN} session *************** Copyright (C) 1988-1999 Free Software Fo *** 144,150 **** * Controlling GDB:: Controlling @value{GDBN} * Sequences:: Canned sequences of commands * Emacs:: Using @value{GDBN} under @sc{gnu} Emacs ! * Annotations:: @value{GDBN}'s annotations interface. * GDB Bugs:: Reporting bugs in @value{GDBN} * Formatting Documentation:: How to format and print @value{GDBN} documentation --- 190,196 ---- * Controlling GDB:: Controlling @value{GDBN} * Sequences:: Canned sequences of commands * Emacs:: Using @value{GDBN} under @sc{gnu} Emacs ! * Annotations:: @value{GDBN}'s annotation interface. * GDB Bugs:: Reporting bugs in @value{GDBN} * Formatting Documentation:: How to format and print @value{GDBN} documentation *************** Copyright (C) 1988-1999 Free Software Fo *** 155,161 **** * Index:: Index @end menu ! @node Summary, Sample Session, Top, Top @unnumbered Summary of @value{GDBN} The purpose of a debugger such as @value{GDBN} is to allow you to see what is --- 201,209 ---- * Index:: Index @end menu ! @end ifhtml ! ! @node Summary @unnumbered Summary of @value{GDBN} The purpose of a debugger such as @value{GDBN} is to allow you to see what is *************** underscore. *** 205,211 **** * Contributors:: Contributors to GDB @end menu ! @node Free Software, Contributors, Summary, Summary @unnumberedsec Free software @value{GDBN} is @dfn{free software}, protected by the @sc{gnu} --- 253,259 ---- * Contributors:: Contributors to GDB @end menu ! @node Free Software @unnumberedsec Free software @value{GDBN} is @dfn{free software}, protected by the @sc{gnu} *************** Fundamentally, the General Public Licens *** 221,227 **** you have these freedoms and that you cannot take these freedoms away from anyone else. ! @node Contributors, , Free Software, Summary @unnumberedsec Contributors to @value{GDBN} Richard Stallman was the original author of @value{GDBN}, and of many --- 269,275 ---- you have these freedoms and that you cannot take these freedoms away from anyone else. ! @node Contributors @unnumberedsec Contributors to @value{GDBN} Richard Stallman was the original author of @value{GDBN}, and of many *************** Thomas, Michael Tiemann, Tom Tromey, Ron *** 360,366 **** Zuhn have made contributions both large and small. ! @node Sample Session, Invocation, Summary, Top @chapter A Sample @value{GDBN} Session You can use this manual at your leisure to read all about @value{GDBN}. --- 408,414 ---- Zuhn have made contributions both large and small. ! @node Sample Session @chapter A Sample @value{GDBN} Session You can use this manual at your leisure to read all about @value{GDBN}. *************** session with the @value{GDBN} @code{quit *** 630,636 **** (@value{GDBP}) @b{quit} @end smallexample ! @node Invocation, Commands, Sample Session, Top @chapter Getting In and Out of @value{GDBN} This chapter discusses how to start @value{GDBN}, and how to get out of it. --- 678,684 ---- (@value{GDBP}) @b{quit} @end smallexample ! @node Invocation @chapter Getting In and Out of @value{GDBN} This chapter discusses how to start @value{GDBN}, and how to get out of it. *************** type @kbd{quit} or @kbd{C-d} to exit. *** 648,654 **** * Shell Commands:: How to use shell commands inside @value{GDBN} @end menu ! @node Invoking GDB, Quitting GDB, Invocation, Invocation @section Invoking @value{GDBN} Invoke @value{GDBN} by running the program @code{@value{GDBP}}. Once started, --- 696,702 ---- * Shell Commands:: How to use shell commands inside @value{GDBN} @end menu ! @node Invoking GDB @section Invoking @value{GDBN} Invoke @value{GDBN} by running the program @code{@value{GDBP}}. Once started, *************** in sequential order. The order makes a *** 725,731 **** * Mode Options:: Choosing modes @end menu ! @node File Options, Mode Options, Invoking GDB, Invoking GDB @subsection Choosing files When @value{GDBN} starts, it reads any arguments other than options as --- 773,779 ---- * Mode Options:: Choosing modes @end menu ! @node File Options @subsection Choosing files When @value{GDBN} starts, it reads any arguments other than options as *************** but build a @file{.syms} file for future *** 833,839 **** gdb -batch -nx -mapped -readnow programname @end example ! @node Mode Options, , File Options, Invoking GDB @subsection Choosing modes You can run @value{GDBN} in various alternative modes---for example, in --- 881,887 ---- gdb -batch -nx -mapped -readnow programname @end example ! @node Mode Options @subsection Choosing modes You can run @value{GDBN} in various alternative modes---for example, in *************** no-warranty blurb, and exit. *** 1014,1020 **** @end table ! @node Quitting GDB, Shell Commands, Invoking GDB, Invocation @section Quitting @value{GDBN} @cindex exiting @value{GDBN} @cindex leaving @value{GDBN} --- 1062,1068 ---- @end table ! @node Quitting GDB @section Quitting @value{GDBN} @cindex exiting @value{GDBN} @cindex leaving @value{GDBN} *************** If you have been using @value{GDBN} to c *** 1042,1048 **** device, you can release it with the @code{detach} command (@pxref{Attach, ,Debugging an already-running process}). ! @node Shell Commands, , Quitting GDB, Invocation @section Shell commands If you need to execute occasional shell commands during your --- 1090,1096 ---- device, you can release it with the @code{detach} command (@pxref{Attach, ,Debugging an already-running process}). ! @node Shell Commands @section Shell commands If you need to execute occasional shell commands during your *************** Execute the @code{make} program with the *** 1071,1077 **** arguments. This is equivalent to @samp{shell make @var{make-args}}. @end table ! @node Commands, Running, Invocation, Top @chapter @value{GDBN} Commands You can abbreviate a @value{GDBN} command to the first few letters of the command --- 1119,1125 ---- arguments. This is equivalent to @samp{shell make @var{make-args}}. @end table ! @node Commands @chapter @value{GDBN} Commands You can abbreviate a @value{GDBN} command to the first few letters of the command *************** show you the alternatives available, if *** 1086,1092 **** * Help:: How to ask @value{GDBN} for help @end menu ! @node Command Syntax, Completion, Commands, Commands @section Command syntax A @value{GDBN} command is a single line of input. There is no limit on --- 1134,1140 ---- * Help:: How to ask @value{GDBN} for help @end menu ! @node Command Syntax @section Command syntax A @value{GDBN} command is a single line of input. There is no limit on *************** Any text from a @kbd{#} to the end of th *** 1129,1135 **** nothing. This is useful mainly in command files (@pxref{Command Files,,Command files}). ! @node Completion, Help, Command Syntax, Commands @section Command completion @cindex completion --- 1177,1183 ---- nothing. This is useful mainly in command files (@pxref{Command Files,,Command files}). ! @node Completion @section Command completion @cindex completion *************** overload-resolution off} to disable over *** 1248,1254 **** see @ref{Debugging C plus plus, ,@value{GDBN} features for C++}. ! @node Help, , Completion, Commands @section Getting help @cindex online documentation @kindex help --- 1296,1302 ---- see @ref{Debugging C plus plus, ,@value{GDBN} features for C++}. ! @node Help @section Getting help @cindex online documentation @kindex help *************** apropos reload *** 1331,1340 **** @noindent results in: @smallexample ! @group ! set symbol-reloading -- Set dynamic symbol table reloading multiple times in one run ! show symbol-reloading -- Show dynamic symbol table reloading multiple times in one run ! @end group @end smallexample @kindex complete --- 1379,1390 ---- @noindent results in: @smallexample ! @c @group ! set symbol-reloading -- Set dynamic symbol table reloading ! multiple times in one run ! show symbol-reloading -- Show dynamic symbol table reloading ! multiple times in one run ! @c @end group @end smallexample @kindex complete *************** if your version of @value{GDBN} comes wi *** 1433,1439 **** @end table ! @node Running, Stopping, Commands, Top @chapter Running Programs Under @value{GDBN} When you run a program under @value{GDBN}, you must first generate --- 1483,1489 ---- @end table ! @node Running @chapter Running Programs Under @value{GDBN} When you run a program under @value{GDBN}, you must first generate *************** kill a child process. *** 1459,1465 **** * Processes:: Debugging programs with multiple processes @end menu ! @node Compilation, Starting, Running, Running @section Compiling for debugging In order to debug a program effectively, you need to generate --- 1509,1515 ---- * Processes:: Debugging programs with multiple processes @end menu ! @node Compilation @section Compiling for debugging In order to debug a program effectively, you need to generate *************** Older versions of the @sc{gnu} C compile *** 1500,1506 **** format; if your @sc{gnu} C compiler has this option, do not use it. @need 2000 ! @node Starting, Arguments, Compilation, Running @section Starting your program @cindex starting @cindex running --- 1550,1556 ---- format; if your @sc{gnu} C compiler has this option, do not use it. @need 2000 ! @node Starting @section Starting your program @cindex starting @cindex running *************** time @value{GDBN} read its symbols, @val *** 1576,1582 **** table, and reads it again. When it does this, @value{GDBN} tries to retain your current breakpoints. ! @node Arguments, Environment, Starting, Running @section Your program's arguments @cindex arguments (to your program) --- 1626,1632 ---- table, and reads it again. When it does this, @value{GDBN} tries to retain your current breakpoints. ! @node Arguments @section Your program's arguments @cindex arguments (to your program) *************** it again without arguments. *** 1610,1616 **** Show the arguments to give your program when it is started. @end table ! @node Environment, Working Directory, Arguments, Running @section Your program's environment @cindex environment (of your program) --- 1660,1666 ---- Show the arguments to give your program when it is started. @end table ! @node Environment @section Your program's environment @cindex environment (of your program) *************** your program. You may wish to move sett *** 1693,1699 **** files that are only run when you sign on, such as @file{.login} or @file{.profile}. ! @node Working Directory, Input/Output, Environment, Running @section Your program's working directory @cindex working directory (of your program) --- 1743,1749 ---- files that are only run when you sign on, such as @file{.login} or @file{.profile}. ! @node Working Directory @section Your program's working directory @cindex working directory (of your program) *************** Set the @value{GDBN} working directory t *** 1717,1723 **** Print the @value{GDBN} working directory. @end table ! @node Input/Output, Attach, Working Directory, Running @section Your program's input and output @cindex redirection --- 1767,1773 ---- Print the @value{GDBN} working directory. @end table ! @node Input/Output @section Your program's input and output @cindex redirection *************** When you use the @code{tty} command or r *** 1771,1777 **** command, only the input @emph{for your program} is affected. The input for @value{GDBN} still comes from your terminal. ! @node Attach, Kill Process, Input/Output, Running @section Debugging an already-running process @kindex attach @cindex attach --- 1821,1827 ---- command, only the input @emph{for your program} is affected. The input for @value{GDBN} still comes from your terminal. ! @node Attach @section Debugging an already-running process @kindex attach @cindex attach *************** control whether or not you need to confi *** 1827,1833 **** confirm} command (@pxref{Messages/Warnings, ,Optional warnings and messages}). ! @node Kill Process, Threads, Attach, Running @section Killing the child process @table @code --- 1877,1883 ---- confirm} command (@pxref{Messages/Warnings, ,Optional warnings and messages}). ! @node Kill Process @section Killing the child process @table @code *************** next type @code{run}, @value{GDBN} notic *** 1852,1858 **** reads the symbol table again (while trying to preserve your current breakpoint settings). ! @node Threads, Processes, Kill Process, Running @section Debugging programs with multiple threads @cindex threads of execution --- 1902,1908 ---- reads the symbol table again (while trying to preserve your current breakpoint settings). ! @node Threads @section Debugging programs with multiple threads @cindex threads of execution *************** For example, *** 2017,2025 **** @example (@value{GDBP}) info threads ! * 3 system thread 26607 worker (wptr=0x7b09c318 "@@") at quicksort.c:137 ! 2 system thread 26606 0x7b0030d8 in __ksleep () from /usr/lib/libc.2 ! 1 system thread 27905 0x7b003498 in _brk () from /usr/lib/libc.2 @end example @table @code --- 2067,2078 ---- @example (@value{GDBP}) info threads ! * 3 system thread 26607 worker (wptr=0x7b09c318 "@@") \@* ! at quicksort.c:137 ! 2 system thread 26606 0x7b0030d8 in __ksleep () \@* ! from /usr/lib/libc.2 ! 1 system thread 27905 0x7b003498 in _brk () \@* ! from /usr/lib/libc.2 @end example @table @code *************** programs with multiple threads. *** 2069,2075 **** @xref{Set Watchpoints,,Setting watchpoints}, for information about watchpoints in programs with multiple threads. ! @node Processes, , Threads, Running @section Debugging programs with multiple processes @cindex fork, debugging programs which call --- 2122,2128 ---- @xref{Set Watchpoints,,Setting watchpoints}, for information about watchpoints in programs with multiple threads. ! @node Processes @section Debugging programs with multiple processes @cindex fork, debugging programs which call *************** You can use the @code{catch} command to *** 2146,2152 **** a @code{fork}, @code{vfork}, or @code{exec} call is made. @xref{Set Catchpoints, ,Setting catchpoints}. ! @node Stopping, Stack, Running, Top @chapter Stopping and Continuing The principal purposes of using a debugger are so that you can stop your --- 2199,2205 ---- a @code{fork}, @code{vfork}, or @code{exec} call is made. @xref{Set Catchpoints, ,Setting catchpoints}. ! @node Stopping @chapter Stopping and Continuing The principal purposes of using a debugger are so that you can stop your *************** running or not, what process it is, and *** 2175,2181 **** * Thread Stops:: Stopping and starting multi-thread programs @end menu ! @node Breakpoints, Continuing and Stepping, Stopping, Stopping @section Breakpoints, watchpoints, and catchpoints @cindex breakpoints --- 2228,2234 ---- * Thread Stops:: Stopping and starting multi-thread programs @end menu ! @node Breakpoints @section Breakpoints, watchpoints, and catchpoints @cindex breakpoints *************** all breakpoint in that range are operate *** 2249,2255 **** * Error in Breakpoints:: ``Cannot insert breakpoints'' @end menu ! @node Set Breaks, Set Watchpoints, Breakpoints, Breakpoints @subsection Setting breakpoints @c FIXME LMB what does GDB do if no code on line of breakpt? --- 2302,2308 ---- * Error in Breakpoints:: ``Cannot insert breakpoints'' @end menu ! @node Set Breaks @subsection Setting breakpoints @c FIXME LMB what does GDB do if no code on line of breakpt? *************** Shared library events. *** 2481,2487 **** @end table ! @node Set Watchpoints, Set Catchpoints, Set Breaks, Breakpoints @subsection Setting watchpoints @cindex setting watchpoints --- 2534,2540 ---- @end table ! @node Set Watchpoints @subsection Setting watchpoints @cindex setting watchpoints *************** when a non-current thread's activity cha *** 2624,2630 **** watchpoints, in contrast, watch an expression in all threads.) @end quotation ! @node Set Catchpoints, Delete Breaks, Set Watchpoints, Breakpoints @subsection Setting catchpoints @cindex catchpoints, setting @cindex exception handlers --- 2677,2683 ---- watchpoints, in contrast, watch an expression in all threads.) @end quotation ! @node Set Catchpoints @subsection Setting catchpoints @cindex catchpoints, setting @cindex exception handlers *************** breakpoints to stop your program when an *** 2732,2738 **** raised. ! @node Delete Breaks, Disabling, Set Catchpoints, Breakpoints @subsection Deleting breakpoints @cindex clearing breakpoints, watchpoints, catchpoints --- 2785,2791 ---- raised. ! @node Delete Breaks @subsection Deleting breakpoints @cindex clearing breakpoints, watchpoints, catchpoints *************** breakpoints (@value{GDBN} asks confirmat *** 2777,2783 **** confirm off}). You can abbreviate this command as @code{d}. @end table ! @node Disabling, Conditions, Delete Breaks, Breakpoints @subsection Disabling breakpoints @kindex disable breakpoints --- 2830,2836 ---- confirm off}). You can abbreviate this command as @code{d}. @end table ! @node Disabling @subsection Disabling breakpoints @kindex disable breakpoints *************** breakpoint of its own, but it does not c *** 2850,2856 **** breakpoints; see @ref{Continuing and Stepping, ,Continuing and stepping}.) ! @node Conditions, Break Commands, Disabling, Breakpoints @subsection Break conditions @cindex conditional breakpoints @cindex breakpoint conditions --- 2903,2909 ---- breakpoints; see @ref{Continuing and Stepping, ,Continuing and stepping}.) ! @node Conditions @subsection Break conditions @cindex conditional breakpoints @cindex breakpoint conditions *************** variables}. *** 2967,2973 **** Ignore counts apply to breakpoints, watchpoints, and catchpoints. ! @node Break Commands, Breakpoint Menus, Conditions, Breakpoints @subsection Breakpoint command lists @cindex breakpoint commands --- 3020,3026 ---- Ignore counts apply to breakpoints, watchpoints, and catchpoints. ! @node Break Commands @subsection Breakpoint command lists @cindex breakpoint commands *************** cont *** 3048,3054 **** end @end example ! @node Breakpoint Menus, Error in Breakpoints, Break Commands, Breakpoints @subsection Breakpoint menus @cindex overloading @cindex symbol overloading --- 3101,3107 ---- end @end example ! @node Breakpoint Menus @subsection Breakpoint menus @cindex overloading @cindex symbol overloading *************** Use the "delete" command to delete unwan *** 3095,3101 **** @end smallexample @c @ifclear BARETARGET ! @node Error in Breakpoints, , Breakpoint Menus, Breakpoints @subsection ``Cannot insert breakpoints'' @c @c FIXME!! 14/6/95 Is there a real example of this? Let's use it. --- 3148,3154 ---- @end smallexample @c @ifclear BARETARGET ! @node Error in Breakpoints @subsection ``Cannot insert breakpoints'' @c @c FIXME!! 14/6/95 Is there a real example of this? Let's use it. *************** When this message is printed, you need t *** 3148,3154 **** hardware-assisted breakpoints and watchpoints, and then continue. ! @node Continuing and Stepping, Signals, Breakpoints, Stopping @section Continuing and stepping @cindex stepping --- 3201,3207 ---- hardware-assisted breakpoints and watchpoints, and then continue. ! @node Continuing and Stepping @section Continuing and stepping @cindex stepping *************** proceed until the function returns. *** 3350,3356 **** An argument is a repeat count, as in @code{next}. @end table ! @node Signals, Thread Stops, Continuing and Stepping, Stopping @section Signals @cindex signals --- 3403,3409 ---- An argument is a repeat count, as in @code{next}. @end table ! @node Signals @section Signals @cindex signals *************** a result of the fatal signal once it saw *** 3446,3452 **** you can continue with @samp{signal 0}. @xref{Signaling, ,Giving your program a signal}. ! @node Thread Stops, , Signals, Stopping @section Stopping and starting multi-thread programs When your program has multiple threads (@pxref{Threads,, Debugging --- 3499,3505 ---- you can continue with @samp{signal 0}. @xref{Signaling, ,Giving your program a signal}. ! @node Thread Stops @section Stopping and starting multi-thread programs When your program has multiple threads (@pxref{Threads,, Debugging *************** Display the current scheduler locking mo *** 3531,3537 **** @end table ! @node Stack, Source, Stopping, Top @chapter Examining the Stack When your program has stopped, the first thing you need to know is where it --- 3584,3590 ---- @end table ! @node Stack @chapter Examining the Stack When your program has stopped, the first thing you need to know is where it *************** currently executing frame and describes *** 3570,3576 **** @end menu ! @node Frames, Backtrace, Stack, Stack @section Stack frames @cindex frame, definition --- 3623,3629 ---- @end menu ! @node Frames @section Stack frames @cindex frame, definition *************** and so on upward. These numbers do not *** 3608,3618 **** they are assigned by @value{GDBN} to give you a way of designating stack frames in @value{GDBN} commands. ! @c below produces an acceptable overful hbox. --mew 13aug1993 @cindex frameless execution Some compilers provide a way to compile functions so that they operate ! without stack frames. (For example, the @code{@value{GCC}} option ! @samp{-fomit-frame-pointer} generates functions without a frame.) This is occasionally done with heavily used library functions to save the frame setup time. @value{GDBN} has limited facilities for dealing with these function invocations. If the innermost function invocation --- 3661,3675 ---- they are assigned by @value{GDBN} to give you a way of designating stack frames in @value{GDBN} commands. ! @c The -fomit-frame-pointer below perennially causes hbox overflow ! @c underflow problems. @cindex frameless execution Some compilers provide a way to compile functions so that they operate ! without stack frames. (For example, the @value{GCC} option ! @example ! @samp{-fomit-frame-pointer} ! @end example ! generates functions without a frame.) This is occasionally done with heavily used library functions to save the frame setup time. @value{GDBN} has limited facilities for dealing with these function invocations. If the innermost function invocation *************** to another without printing the frame. *** 3636,3642 **** @code{frame}. @end table ! @node Backtrace, Selection, Frames, Stack @section Backtraces @cindex backtraces --- 3693,3699 ---- @code{frame}. @end table ! @node Backtrace @section Backtraces @cindex backtraces *************** The display for frame zero does not begi *** 3699,3705 **** value, indicating that your program has stopped at the beginning of the code for line @code{993} of @code{builtin.c}. ! @node Selection, Frame Info, Backtrace, Stack @section Selecting a frame Most commands for examining the stack and other data in your program work on --- 3756,3762 ---- value, indicating that your program has stopped at the beginning of the code for line @code{993} of @code{builtin.c}. ! @node Selection @section Selecting a frame Most commands for examining the stack and other data in your program work on *************** in @value{GDBN} command scripts, where t *** 3785,3791 **** distracting. @end table ! @node Frame Info, , Selection, Stack @section Information about a frame There are several other commands to print information about the selected --- 3842,3848 ---- distracting. @end table ! @node Frame Info @section Information about a frame There are several other commands to print information about the selected *************** exception handlers, visit the associated *** 3861,3867 **** @end table ! @node Source, Data, Stack, Top @chapter Examining Source Files @value{GDBN} can print parts of your program's source, since the debugging --- 3918,3924 ---- @end table ! @node Source @chapter Examining Source Files @value{GDBN} can print parts of your program's source, since the debugging *************** prefer to use Emacs facilities to view s *** 3883,3889 **** * Machine Code:: Source and machine code @end menu ! @node List, Search, Source, Source @section Printing source lines @kindex list --- 3940,3946 ---- * Machine Code:: Source and machine code @end menu ! @node List @section Printing source lines @kindex list *************** Specifies the line containing the progra *** 4000,4006 **** @var{address} may be any expression. @end table ! @node Search, Source Path, List, Source @section Searching source files @cindex searching @kindex reverse-search --- 4057,4063 ---- @var{address} may be any expression. @end table ! @node Search @section Searching source files @cindex searching @kindex reverse-search *************** for @var{regexp}. It lists the line tha *** 4026,4032 **** this command as @code{rev}. @end table ! @node Source Path, Machine Code, Search, Source @section Specifying source directories @cindex source path --- 4083,4089 ---- this command as @code{rev}. @end table ! @node Source Path @section Specifying source directories @cindex source path *************** directories you want in the source path. *** 4109,4115 **** directories in one command. @end enumerate ! @node Machine Code, , Source Path, Source @section Source and machine code You can use the command @code{info line} to map source lines to program --- 4166,4172 ---- directories in one command. @end enumerate ! @node Machine Code @section Source and machine code You can use the command @code{info line} to map source lines to program *************** assemblers for x86-based targets. *** 4210,4216 **** @end table ! @node Data, Languages, Source, Top @chapter Examining Data @cindex printing data --- 4267,4273 ---- @end table ! @node Data @chapter Examining Data @cindex printing data *************** Table}. *** 4265,4271 **** * Floating Point Hardware:: Floating point hardware @end menu ! @node Expressions, Variables, Data, Data @section Expressions @cindex expressions --- 4322,4328 ---- * Floating Point Hardware:: Floating point hardware @end menu ! @node Expressions @section Expressions @cindex expressions *************** a cast). This construct is allowed rega *** 4318,4324 **** normally supposed to reside at @var{addr}. @end table ! @node Variables, Arrays, Expressions, Data @section Program variables The most common kind of expression to use is the name of a variable --- 4375,4381 ---- normally supposed to reside at @var{addr}. @end table ! @node Variables @section Program variables The most common kind of expression to use is the name of a variable *************** Program or @sc{gnu} CC, gcc.info, Using *** 4439,4445 **** information. ! @node Arrays, Output Formats, Variables, Data @section Artificial arrays @cindex artificial array --- 4496,4502 ---- information. ! @node Arrays @section Artificial arrays @cindex artificial array *************** p dtab[$i++]->fv *** 4511,4517 **** @dots{} @end example ! @node Output Formats, Memory, Arrays, Data @section Output formats @cindex formatted output --- 4568,4574 ---- @dots{} @end example ! @node Output Formats @section Output formats @cindex formatted output *************** To reprint the last value in the value h *** 4580,4586 **** you can use the @code{print} command with just a format and no expression. For example, @samp{p/x} reprints the last value in hex. ! @node Memory, Auto Display, Output Formats, Data @section Examining memory You can use the command @code{x} (for ``examine'') to examine memory in --- 4637,4643 ---- you can use the @code{print} command with just a format and no expression. For example, @samp{p/x} reprints the last value in hex. ! @node Memory @section Examining memory You can use the command @code{x} (for ``examine'') to examine memory in *************** If the @code{x} command has a repeat cou *** 4685,4691 **** are from the last memory unit printed; this is not the same as the last address printed if several units were printed on the last line of output. ! @node Auto Display, Print Settings, Memory, Data @section Automatic display @cindex automatic display @cindex display of expressions --- 4742,4748 ---- are from the last memory unit printed; this is not the same as the last address printed if several units were printed on the last line of output. ! @node Auto Display @section Automatic display @cindex automatic display @cindex display of expressions *************** there is no variable @code{last_char}--- *** 4781,4787 **** automatically. The next time your program stops where @code{last_char} is meaningful, you can enable the display expression once again. ! @node Print Settings, Value History, Auto Display, Data @section Print settings @cindex format options --- 4838,4844 ---- automatically. The next time your program stops where @code{last_char} is meaningful, you can enable the display expression once again. ! @node Print Settings @section Print settings @cindex format options *************** Do not pretty print C++ virtual function *** 5142,5148 **** Show whether C++ virtual function tables are pretty printed, or not. @end table ! @node Value History, Convenience Vars, Print Settings, Data @section Value history @cindex value history --- 5199,5205 ---- Show whether C++ virtual function tables are pretty printed, or not. @end table ! @node Value History @section Value history @cindex value history *************** values are available, @code{show values *** 5219,5225 **** Pressing @key{RET} to repeat @code{show values @var{n}} has exactly the same effect as @samp{show values +}. ! @node Convenience Vars, Registers, Value History, Data @section Convenience variables @cindex convenience variables --- 5276,5282 ---- Pressing @key{RET} to repeat @code{show values @var{n}} has exactly the same effect as @samp{show values +}. ! @node Convenience Vars @section Convenience variables @cindex convenience variables *************** On HP-UX systems, if you refer to a func *** 5305,5311 **** begins with a dollar sign, @value{GDBN} searches for a user or system name first, before it searches for a convenience variable. ! @node Registers, Floating Point Hardware, Convenience Vars, Data @section Registers @cindex registers --- 5362,5368 ---- begins with a dollar sign, @value{GDBN} searches for a user or system name first, before it searches for a convenience variable. ! @node Registers @section Registers @cindex registers *************** code generated by your compiler. If som *** 5404,5410 **** @value{GDBN} is unable to locate the saved registers, the selected stack frame makes no difference. ! @node Floating Point Hardware, , Registers, Data @section Floating point hardware @cindex floating point --- 5461,5467 ---- @value{GDBN} is unable to locate the saved registers, the selected stack frame makes no difference. ! @node Floating Point Hardware @section Floating point hardware @cindex floating point *************** floating point chip. Currently, @samp{i *** 5420,5426 **** the ARM and x86 machines. @end table ! @node Languages, Symbols, Data, Top @chapter Using @value{GDBN} with Different Languages @cindex languages --- 5477,5483 ---- the ARM and x86 machines. @end table ! @node Languages @chapter Using @value{GDBN} with Different Languages @cindex languages *************** language}. *** 5446,5452 **** * Support:: Supported languages @end menu ! @node Setting, Show, Languages, Languages @section Switching between source languages There are two ways to control the working language---either have @value{GDBN} --- 5503,5509 ---- * Support:: Supported languages @end menu ! @node Setting @section Switching between source languages There are two ways to control the working language---either have @value{GDBN} *************** program, and will display that source co *** 5480,5486 **** * Automatically:: Having @value{GDBN} infer the source language @end menu ! @node Filenames, Manually, Setting, Setting @subsection List of filename extensions and languages If a source file name ends in one of the following extensions, then --- 5537,5543 ---- * Automatically:: Having @value{GDBN} infer the source language @end menu ! @node Filenames @subsection List of filename extensions and languages If a source file name ends in one of the following extensions, then *************** Assembler source file. This actually be *** 5520,5526 **** In addition, you may set the language associated with a filename extension. @xref{Show, , Displaying the language}. ! @node Manually, Automatically, Filenames, Setting @subsection Setting the working language If you allow @value{GDBN} to set the language automatically, --- 5577,5583 ---- In addition, you may set the language associated with a filename extension. @xref{Show, , Displaying the language}. ! @node Manually @subsection Setting the working language If you allow @value{GDBN} to set the language automatically, *************** might not have the effect you intended. *** 5552,5558 **** printed would be the value of @code{a}. In Modula-2, this means to compare @code{a} to the result of @code{b+c}, yielding a @code{BOOLEAN} value. ! @node Automatically, , Manually, Setting @subsection Having @value{GDBN} infer the source language To have @value{GDBN} set the working language automatically, use --- 5609,5615 ---- printed would be the value of @code{a}. In Modula-2, this means to compare @code{a} to the result of @code{b+c}, yielding a @code{BOOLEAN} value. ! @node Automatically @subsection Having @value{GDBN} infer the source language To have @value{GDBN} set the working language automatically, use *************** written in one source language can be us *** 5571,5577 **** a different source language. Using @samp{set language auto} in this case frees you from having to set the working language manually. ! @node Show, Checks, Setting, Languages @section Displaying the language The following commands help you find out which language is the --- 5628,5634 ---- a different source language. Using @samp{set language auto} in this case frees you from having to set the working language manually. ! @node Show @section Displaying the language The following commands help you find out which language is the *************** the source language @var{language}. *** 5613,5619 **** List all the filename extensions and the associated languages. @end table ! @node Checks, Support, Show, Languages @section Type and range checking @quotation --- 5670,5676 ---- List all the filename extensions and the associated languages. @end table ! @node Checks @section Type and range checking @quotation *************** for the default settings of supported la *** 5646,5652 **** @cindex type checking @cindex checks, type ! @node Type Checking, Range Checking, Checks, Checks @subsection An overview of type checking Some languages, such as Modula-2, are strongly typed, meaning that the --- 5703,5709 ---- @cindex type checking @cindex checks, type ! @node Type Checking @subsection An overview of type checking Some languages, such as Modula-2, are strongly typed, meaning that the *************** is setting it automatically. *** 5717,5723 **** @cindex range checking @cindex checks, range ! @node Range Checking, , Type Checking, Checks @subsection An overview of range checking In some languages (such as Modula-2), it is an error to exceed the --- 5774,5780 ---- @cindex range checking @cindex checks, range ! @node Range Checking @subsection An overview of range checking In some languages (such as Modula-2), it is an error to exceed the *************** Show the current setting of the range ch *** 5776,5782 **** being set automatically by @value{GDBN}. @end table ! @node Support, , Checks, Languages @section Supported languages @value{GDBN} supports C, C++, Fortran, Java, Chill, assembly, and Modula-2. --- 5833,5839 ---- being set automatically by @value{GDBN}. @end table ! @node Support @section Supported languages @value{GDBN} supports C, C++, Fortran, Java, Chill, assembly, and Modula-2. *************** language reference or tutorial. *** 5801,5807 **** * Chill:: Chill @end menu ! @node C, Modula-2, Support, Support @subsection C and C++ @cindex C and C++ --- 5858,5864 ---- * Chill:: Chill @end menu ! @node C @subsection C and C++ @cindex C and C++ *************** CC, gcc.info, Using @sc{gnu} CC}, for mo *** 5836,5842 **** * Debugging C plus plus:: @value{GDBN} features for C++ @end menu ! @node C Operators, C Constants, C, C @subsubsection C and C++ operators @cindex C and C++ operators --- 5893,5899 ---- * Debugging C plus plus:: @value{GDBN} features for C++ @end menu ! @node C Operators @subsubsection C and C++ operators @cindex C and C++ operators *************** predefined meaning. *** 5996,6002 **** * C Constants:: @end menu ! @node C Constants, C plus plus expressions, C Operators, C @subsubsection C and C++ constants @cindex C and C++ constants --- 6053,6059 ---- * C Constants:: @end menu ! @node C Constants @subsubsection C and C++ constants @cindex C and C++ constants *************** and @samp{@{&"hi", &"there", &"fred"@}} *** 6064,6070 **** * Debugging C:: @end menu ! @node C plus plus expressions, C Defaults, C Constants, C @subsubsection C++ expressions @cindex expressions in C++ --- 6121,6127 ---- * Debugging C:: @end menu ! @node C plus plus expressions @subsubsection C++ expressions @cindex expressions in C++ *************** calling virtual functions correctly, pri *** 6169,6175 **** objects, calling functions in a base subobject, casting objects, and invoking user-defined operators. ! @node C Defaults, C Checks, C plus plus expressions, C @subsubsection C and C++ defaults @cindex C and C++ defaults --- 6226,6232 ---- objects, calling functions in a base subobject, casting objects, and invoking user-defined operators. ! @node C Defaults @subsubsection C and C++ defaults @cindex C and C++ defaults *************** for further details. *** 6190,6196 **** @c unimplemented. If (b) changes, it might make sense to let this node @c appear even if Mod-2 does not, but meanwhile ignore it. roland 16jul93. ! @node C Checks, Debugging C, C Defaults, C @subsubsection C and C++ type and range checks @cindex C and C++ checks --- 6247,6253 ---- @c unimplemented. If (b) changes, it might make sense to let this node @c appear even if Mod-2 does not, but meanwhile ignore it. roland 16jul93. ! @node C Checks @subsubsection C and C++ type and range checks @cindex C and C++ checks *************** Range checking, if turned on, is done on *** 6222,6228 **** indices are not checked, since they are often used to index a pointer that is not itself an array. ! @node Debugging C, Debugging C plus plus, C Checks, C @subsubsection @value{GDBN} and C The @code{set print union} and @code{show print union} commands apply to --- 6279,6285 ---- indices are not checked, since they are often used to index a pointer that is not itself an array. ! @node Debugging C @subsubsection @value{GDBN} and C The @code{set print union} and @code{show print union} commands apply to *************** with pointers and a memory allocation fu *** 6238,6244 **** * Debugging C plus plus:: @end menu ! @node Debugging C plus plus, , Debugging C, C @subsubsection @value{GDBN} features for C++ @cindex commands for C++ --- 6295,6301 ---- * Debugging C plus plus:: @end menu ! @node Debugging C plus plus @subsubsection @value{GDBN} features for C++ @cindex commands for C++ *************** available choices, or to finish the type *** 6321,6327 **** @xref{Completion,, Command completion}, for details on how to do this. @end table ! @node Modula-2, Chill, C, Support @subsection Modula-2 @cindex Modula-2, @value{GDBN} support --- 6378,6384 ---- @xref{Completion,, Command completion}, for details on how to do this. @end table ! @node Modula-2 @subsection Modula-2 @cindex Modula-2, @value{GDBN} support *************** table. *** 6345,6351 **** * GDB/M2:: @value{GDBN} and Modula-2 @end menu ! @node M2 Operators, Built-In Func/Proc, Modula-2, Modula-2 @subsubsection Operators @cindex Modula-2 operators --- 6402,6408 ---- * GDB/M2:: @value{GDBN} and Modula-2 @end menu ! @node M2 Operators @subsubsection Operators @cindex Modula-2 operators *************** treats the use of the operator @code{IN} *** 6469,6475 **** @end quotation @cindex Modula-2 built-ins ! @node Built-In Func/Proc, M2 Constants, M2 Operators, Modula-2 @subsubsection Built-in functions and procedures Modula-2 also makes available several built-in procedures and functions. --- 6526,6532 ---- @end quotation @cindex Modula-2 built-ins ! @node Built-In Func/Proc @subsubsection Built-in functions and procedures Modula-2 also makes available several built-in procedures and functions. *************** an error. *** 6581,6587 **** @end quotation @cindex Modula-2 constants ! @node M2 Constants, M2 Defaults, Built-In Func/Proc, Modula-2 @subsubsection Constants @value{GDBN} allows you to express the constants of Modula-2 in the following --- 6638,6644 ---- @end quotation @cindex Modula-2 constants ! @node M2 Constants @subsubsection Constants @value{GDBN} allows you to express the constants of Modula-2 in the following *************** Pointer constants consist of integral va *** 6630,6636 **** Set constants are not yet supported. @end itemize ! @node M2 Defaults, Deviations, M2 Constants, Modula-2 @subsubsection Modula-2 defaults @cindex Modula-2 defaults --- 6687,6693 ---- Set constants are not yet supported. @end itemize ! @node M2 Defaults @subsubsection Modula-2 defaults @cindex Modula-2 defaults *************** code compiled from a file whose name end *** 6644,6650 **** working language to Modula-2. @xref{Automatically, ,Having @value{GDBN} set the language automatically}, for further details. ! @node Deviations, M2 Checks, M2 Defaults, Modula-2 @subsubsection Deviations from standard Modula-2 @cindex Modula-2, deviations from --- 6701,6707 ---- working language to Modula-2. @xref{Automatically, ,Having @value{GDBN} set the language automatically}, for further details. ! @node Deviations @subsubsection Deviations from standard Modula-2 @cindex Modula-2, deviations from *************** argument. *** 6674,6680 **** All built-in procedures both modify @emph{and} return their argument. @end itemize ! @node M2 Checks, M2 Scope, Deviations, Modula-2 @subsubsection Modula-2 type and range checks @cindex Modula-2 checks --- 6731,6737 ---- All built-in procedures both modify @emph{and} return their argument. @end itemize ! @node M2 Checks @subsubsection Modula-2 type and range checks @cindex Modula-2 checks *************** whose types are not equivalent is an err *** 6702,6708 **** Range checking is done on all mathematical operations, assignment, array index bounds, and all built-in functions and procedures. ! @node M2 Scope, GDB/M2, M2 Checks, Modula-2 @subsubsection The scope operators @code{::} and @code{.} @cindex scope @kindex . --- 6759,6765 ---- Range checking is done on all mathematical operations, assignment, array index bounds, and all built-in functions and procedures. ! @node M2 Scope @subsubsection The scope operators @code{::} and @code{.} @cindex scope @kindex . *************** an error if the identifier @var{id} was *** 6742,6748 **** module @var{module}, or if @var{id} is not an identifier in @var{module}. ! @node GDB/M2, , M2 Scope, Modula-2 @subsubsection @value{GDBN} and Modula-2 Some @value{GDBN} commands have little use when debugging Modula-2 programs. --- 6799,6805 ---- module @var{module}, or if @var{id} is not an identifier in @var{module}. ! @node GDB/M2 @subsubsection @value{GDBN} and Modula-2 Some @value{GDBN} commands have little use when debugging Modula-2 programs. *************** address can be specified by an integral *** 6763,6769 **** In @value{GDBN} scripts, the Modula-2 inequality operator @code{#} is interpreted as the beginning of a comment. Use @code{<>} instead. ! @node Chill, , Modula-2, Support @subsection Chill The extensions made to @value{GDBN} to support Chill only support output --- 6820,6826 ---- In @value{GDBN} scripts, the Modula-2 inequality operator @code{#} is interpreted as the beginning of a comment. Use @code{<>} instead. ! @node Chill @subsection Chill The extensions made to @value{GDBN} to support Chill only support output *************** of @value{GDBN} which support these topi *** 6785,6791 **** * Chill defaults:: @end menu ! @node How modes are displayed, Locations, Chill, Chill @subsubsection How modes are displayed The Chill Datatype- (Mode) support of @value{GDBN} is directly related --- 6842,6848 ---- * Chill defaults:: @end menu ! @node How modes are displayed @subsubsection How modes are displayed The Chill Datatype- (Mode) support of @value{GDBN} is directly related *************** type = SET (karli = 10, susi = 20, fritz *** 6813,6822 **** @end smallexample If the type is an unnumbered set the set element values are omitted. @item ! @emph{Range Mode} which is displayed by @code{type = ! ( : )}, where @code{, } can be of any discrete literal expression (e.g. set element ! names). @end itemize @item @r{@emph{Powerset Mode:}} --- 6870,6881 ---- @end smallexample If the type is an unnumbered set the set element values are omitted. @item ! @emph{Range Mode} which is displayed by ! @smallexample ! @code{type = ( : )} ! @end smallexample ! where @code{, } can be of any discrete literal ! expression (e.g. set element names). @end itemize @item @r{@emph{Powerset Mode:}} *************** type, and is therefore not really of int *** 6852,6862 **** @item @r{@emph{Synchronization Modes:}} @itemize @bullet @item ! @emph{Event Mode} which is displayed by @code{EVENT ()}, where @code{()} is optional. @item ! @emph{Buffer Mode} which is displayed by @code{BUFFER () ! }, where @code{()} is optional. @end itemize @item @r{@emph{Timing Modes:}} --- 6911,6927 ---- @item @r{@emph{Synchronization Modes:}} @itemize @bullet @item ! @emph{Event Mode} which is displayed by ! @smallexample ! @code{EVENT ()} ! @end smallexample where @code{()} is optional. @item ! @emph{Buffer Mode} which is displayed by ! @smallexample ! @code{BUFFER ()} ! @end smallexample ! where @code{()} is optional. @end itemize @item @r{@emph{Timing Modes:}} *************** Real Modes are predefined with @code{REA *** 6873,6884 **** @item @r{@emph{String Modes:}} @itemize @bullet @item ! @emph{Character String Mode} which is displayed by @code{CHARS()}, followed by the keyword @code{VARYING} if the String Mode is ! a varying mode @item ! @emph{Bit String Mode} which is displayed by @code{BOOLS()}. @end itemize @item @r{@emph{Array Mode:}} --- 6938,6955 ---- @item @r{@emph{String Modes:}} @itemize @bullet @item ! @emph{Character String Mode} which is displayed by ! @smallexample ! @code{CHARS()} ! @end smallexample ! followed by the keyword @code{VARYING} if the String Mode is a varying ! mode @item ! @emph{Bit String Mode} which is displayed by ! @smallexample ! @code{BOOLS()} ! @end smallexample @end itemize @item @r{@emph{Array Mode:}} *************** type = STRUCT ( *** 6914,6920 **** @end smallexample @end table ! @node Locations, Values and their Operations, How modes are displayed, Chill @subsubsection Locations and their accesses A location in Chill is an object which can contain values. --- 6985,6991 ---- @end smallexample @end table ! @node Locations @subsubsection Locations and their accesses A location in Chill is an object which can contain values. *************** represents the address where the referen *** 6942,6952 **** value of the location referenced by the pointer, use the dereference operator @samp{->}. ! Values of procedure mode locations are displayed by @code{@{ PROC ( ) @}
}. @code{} is a list of modes according to the ! parameter specification of the procedure and @code{
} shows the ! address of the entry point. @ignore Locations of instance modes are displayed just like a structure with two --- 7013,7027 ---- value of the location referenced by the pointer, use the dereference operator @samp{->}. ! Values of procedure mode locations are displayed by ! @smallexample ! @code{@{ PROC ( ) @}
} ! @end smallexample ! @code{} is a list of modes according to the parameter ! specification of the procedure and @code{
} shows the address of ! the entry point. @ignore Locations of instance modes are displayed just like a structure with two *************** therefore the result can be quite confus *** 6995,7001 **** (@value{GDBP}) print int (s(3 up 4)) XXX TO be filled in !! XXX @end smallexample ! @node Values and their Operations, Chill type and range checks, Locations, Chill @subsubsection Values and their Operations Values are used to alter locations, to investigate complex structures in --- 7070,7076 ---- (@value{GDBP}) print int (s(3 up 4)) XXX TO be filled in !! XXX @end smallexample ! @node Values and their Operations @subsubsection Values and their Operations Values are used to alter locations, to investigate complex structures in *************** same manner as in Chill programs refer t *** 7065,7071 **** @end itemize @item String Element Value ! A string element value is specified by @code{()}, where @code{} is a integer expression. It delivers a character value which is equivalent to the character indexed by @code{} in the string. --- 7140,7149 ---- @end itemize @item String Element Value ! A string element value is specified by ! @smallexample ! @code{()} ! @end smallexample where @code{} is a integer expression. It delivers a character value which is equivalent to the character indexed by @code{} in the string. *************** expression, then this procedure is calle *** 7102,7109 **** effects. This can lead to confusing results if used carelessly.}. Values of duration mode locations are represented by @code{ULONG} literals. - Values of time mode locations are represented by @code{TIME(:)}. @ignore This is not implemented yet: --- 7180,7191 ---- effects. This can lead to confusing results if used carelessly.}. Values of duration mode locations are represented by @code{ULONG} literals. + + Values of time mode locations appear as + @smallexample + @code{TIME(:)} + @end smallexample @ignore This is not implemented yet: *************** Membership operator. *** 7198,7204 **** @end table @end table ! @node Chill type and range checks, Chill defaults, Values and their Operations, Chill @subsubsection Chill type and range checks @value{GDBN} considers two Chill variables mode equivalent if the sizes --- 7280,7286 ---- @end table @end table ! @node Chill type and range checks @subsubsection Chill type and range checks @value{GDBN} considers two Chill variables mode equivalent if the sizes *************** off}. *** 7224,7230 **** see last paragraph ? @end ignore ! @node Chill defaults, , Chill type and range checks, Chill @subsubsection Chill defaults If type and range checking are set automatically by @value{GDBN}, they --- 7306,7312 ---- see last paragraph ? @end ignore ! @node Chill defaults @subsubsection Chill defaults If type and range checking are set automatically by @value{GDBN}, they *************** code compiled from a file whose name end *** 7237,7243 **** working language to Chill. @xref{Automatically, ,Having @value{GDBN} set the language automatically}, for further details. ! @node Symbols, Altering, Languages, Top @chapter Examining the Symbol Table The commands described in this chapter allow you to inquire about the --- 7319,7325 ---- working language to Chill. @xref{Automatically, ,Having @value{GDBN} set the language automatically}, for further details. ! @node Symbols @chapter Examining the Symbol Table The commands described in this chapter allow you to inquire about the *************** Replace symbol definitions for the corre *** 7402,7413 **** object file with a particular name is seen again. @item set symbol-reloading off ! Do not replace symbol definitions when re-encountering object files of ! the same name. This is the default state; if you are not running on a ! system that permits automatically relinking modules, you should leave ! @code{symbol-reloading} off, since otherwise @value{GDBN} may discard symbols ! when linking large programs, that may contain several modules (from ! different directories or libraries) with the same name. @kindex show symbol-reloading @item show symbol-reloading --- 7484,7496 ---- object file with a particular name is seen again. @item set symbol-reloading off ! Do not replace symbol definitions when encountering object files of the ! same name more than once. This is the default state; if you are not ! running on a system that permits automatic relinking of modules, you ! should leave @code{symbol-reloading} off, since otherwise @value{GDBN} ! may discard symbols when linking large programs, that may contain ! several modules (from different directories or libraries) with the same ! name. @kindex show symbol-reloading @item show symbol-reloading *************** required for each object file from which *** 7459,7465 **** @value{GDBN} reads symbols (in the description of @code{symbol-file}). @end table ! @node Altering, GDB Files, Symbols, Top @chapter Altering Execution Once you think you have found an error in your program, you might want to --- 7542,7548 ---- @value{GDBN} reads symbols (in the description of @code{symbol-file}). @end table ! @node Altering @chapter Altering Execution Once you think you have found an error in your program, you might want to *************** address, or even return prematurely from *** 7481,7487 **** * Patching:: Patching your program @end menu ! @node Assignment, Jumping, Altering, Altering @section Assignment to variables @cindex assignment --- 7564,7570 ---- * Patching:: Patching your program @end menu ! @node Assignment @section Assignment to variables @cindex assignment *************** $2 = 1 *** 7552,7558 **** The program being debugged has been started already. Start it from the beginning? (y or n) y Starting program: /home/smith/cc_progs/a.out ! "/home/smith/cc_progs/a.out": can't open to read symbols: Invalid bfd target. (@value{GDBP}) show g The current BFD target is "=4". @end group --- 7635,7642 ---- The program being debugged has been started already. Start it from the beginning? (y or n) y Starting program: /home/smith/cc_progs/a.out ! "/home/smith/cc_progs/a.out": can't open to read symbols: ! Invalid bfd target. (@value{GDBP}) show g The current BFD target is "=4". @end group *************** set @{int@}0x83040 = 4 *** 7587,7593 **** @noindent stores the value 4 into that memory location. ! @node Jumping, Signaling, Assignment, Altering @section Continuing at a different address Ordinarily, when you continue your program, you do so at the place where --- 7671,7677 ---- @noindent stores the value 4 into that memory location. ! @node Jumping @section Continuing at a different address Ordinarily, when you continue your program, you do so at the place where *************** that has already executed, in order to e *** 7640,7646 **** detail. @c @group ! @node Signaling, Returning, Jumping, Altering @section Giving your program a signal @table @code --- 7724,7730 ---- detail. @c @group ! @node Signaling @section Giving your program a signal @table @code *************** the signal handling tables (@pxref{Signa *** 7669,7675 **** passes the signal directly to your program. ! @node Returning, Calling, Signaling, Altering @section Returning from a function @table @code --- 7753,7759 ---- passes the signal directly to your program. ! @node Returning @section Returning from a function @table @code *************** returned. In contrast, the @code{finish *** 7700,7706 **** and Stepping, ,Continuing and stepping}) resumes execution until the selected stack frame returns naturally. ! @node Calling, Patching, Returning, Altering @section Calling program functions @cindex calling functions --- 7784,7790 ---- and Stepping, ,Continuing and stepping}) resumes execution until the selected stack frame returns naturally. ! @node Calling @section Calling program functions @cindex calling functions *************** calls a function in the target. This is *** 7722,7728 **** method of putting the scratch area on the stack does not work in systems that have separate instruction and data spaces. ! @node Patching, , Calling, Altering @section Patching programs @cindex patching binaries --- 7806,7812 ---- method of putting the scratch area on the stack does not work in systems that have separate instruction and data spaces. ! @node Patching @section Patching programs @cindex patching binaries *************** Display whether executable files and cor *** 7757,7763 **** as well as reading. @end table ! @node GDB Files, Targets, Altering, Top @chapter @value{GDBN} Files @value{GDBN} needs to know the file name of the program to be debugged, --- 7841,7847 ---- as well as reading. @end table ! @node GDB Files @chapter @value{GDBN} Files @value{GDBN} needs to know the file name of the program to be debugged, *************** program. To debug a core dump of a prev *** 7770,7776 **** * Symbol Errors:: Errors reading symbol files @end menu ! @node Files, Symbol Errors, GDB Files, GDB Files @section Commands to specify files @cindex symbol table --- 7854,7860 ---- * Symbol Errors:: Errors reading symbol files @end menu ! @node Files @section Commands to specify files @cindex symbol table *************** directories to search, just as the shell *** 7799,7805 **** to run. You can change the value of this variable, for both @value{GDBN} and your program, using the @code{path} command. ! On systems with memory-mapped files, an auxiliary file @file{@var{filename}.syms} may hold symbol table information for @var{filename}. If so, @value{GDBN} maps in the symbol table from @file{@var{filename}.syms}, starting up more quickly. See the --- 7883,7889 ---- to run. You can change the value of this variable, for both @value{GDBN} and your program, using the @code{path} command. ! On systems with memory-mapped files, an auxiliary file named @file{@var{filename}.syms} may hold symbol table information for @var{filename}. If so, @value{GDBN} maps in the symbol table from @file{@var{filename}.syms}, starting up more quickly. See the *************** Otherwise, symbols must be loaded manual *** 8050,8056 **** Display the current autoloading size threshold, in megabytes. @end table ! @node Symbol Errors, , Files, GDB Files @section Errors reading symbol files While reading a symbol file, @value{GDBN} occasionally encounters problems, --- 8134,8140 ---- Display the current autoloading size threshold, in megabytes. @end table ! @node Symbol Errors @section Errors reading symbol files While reading a symbol file, @value{GDBN} occasionally encounters problems, *************** it. *** 8139,8145 **** @end table ! @node Targets, Configurations, GDB Files, Top @chapter Specifying a Debugging Target @cindex debugging target --- 8223,8229 ---- @end table ! @node Targets @chapter Specifying a Debugging Target @cindex debugging target *************** command to specify one of the target typ *** 8165,8171 **** @end menu ! @node Active Targets, Target Commands, Targets, Targets @section Active targets @cindex stacking targets --- 8249,8255 ---- @end menu ! @node Active Targets @section Active targets @cindex stacking targets *************** files}). To specify as a target a proce *** 8200,8206 **** the @code{attach} command (@pxref{Attach, ,Debugging an already-running process}). ! @node Target Commands, Byte Order, Active Targets, Targets @section Commands for managing targets @table @code --- 8284,8290 ---- the @code{attach} command (@pxref{Attach, ,Debugging an already-running process}). ! @node Target Commands @section Commands for managing targets @table @code *************** specifies a fixed address. *** 8332,8338 **** @code{load} does not repeat if you press @key{RET} again after using it. @end table ! @node Byte Order, Remote, Target Commands, Targets @section Choosing target byte order @cindex choosing target byte order --- 8416,8422 ---- @code{load} does not repeat if you press @key{RET} again after using it. @end table ! @node Byte Order @section Choosing target byte order @cindex choosing target byte order *************** Note that these commands merely adjust i *** 8372,8378 **** data on the host, and that they have absolutely no effect on the target system. ! @node Remote, KOD, Byte Order, Targets @section Remote debugging @cindex remote debugging --- 8456,8462 ---- data on the host, and that they have absolutely no effect on the target system. ! @node Remote @section Remote debugging @cindex remote debugging *************** configuration of @value{GDBN}; use @code *** 8396,8402 **** * Remote Serial:: @value{GDBN} remote serial protocol @end menu ! @node Remote Serial, , Remote, Remote @subsection The @value{GDBN} remote serial protocol @cindex remote serial debugging, overview --- 8480,8486 ---- * Remote Serial:: @value{GDBN} remote serial protocol @end menu ! @node Remote Serial @subsection The @value{GDBN} remote serial protocol @cindex remote serial debugging, overview *************** recently added stubs. *** 8494,8500 **** * NetWare:: Using the `gdbserve.nlm' program @end menu ! @node Stub Contents, Bootstrapping, Remote Serial, Remote Serial @subsubsection What the stub can do for you @cindex remote serial stub --- 8578,8584 ---- * NetWare:: Using the `gdbserve.nlm' program @end menu ! @node Stub Contents @subsubsection What the stub can do for you @cindex remote serial stub *************** to make certain your program stops at a *** 8545,8551 **** start of your debugging session. @end table ! @node Bootstrapping, Debug Session, Stub Contents, Remote Serial @subsubsection What you must do for the stub @cindex remote stub, support routines --- 8629,8635 ---- start of your debugging session. @end table ! @node Bootstrapping @subsubsection What you must do for the stub @cindex remote stub, support routines *************** but in general the stubs are likely to u *** 8636,8642 **** subroutines which @code{@value{GCC}} generates as inline code. ! @node Debug Session, Protocol, Bootstrapping, Remote Serial @subsubsection Putting it all together @cindex remote serial debugging summary --- 8720,8726 ---- subroutines which @code{@value{GCC}} generates as inline code. ! @node Debug Session @subsubsection Putting it all together @cindex remote serial debugging summary *************** steps. *** 8645,8651 **** @enumerate @item ! Make sure you have the supporting low-level routines (@pxref{Bootstrapping,,What you must do for the stub}): @display @code{getDebugChar}, @code{putDebugChar}, --- 8729,8735 ---- @enumerate @item ! Make sure you have defined the supporting low-level routines (@pxref{Bootstrapping,,What you must do for the stub}): @display @code{getDebugChar}, @code{putDebugChar}, *************** If you type @kbd{y}, @value{GDBN} abando *** 8742,8748 **** remote} again to connect once more.) If you type @kbd{n}, @value{GDBN} goes back to waiting. ! @node Protocol, Server, Debug Session, Remote Serial @subsubsection Communication protocol @cindex debugging stub, example --- 8826,8832 ---- remote} again to connect once more.) If you type @kbd{n}, @value{GDBN} goes back to waiting. ! @node Protocol @subsubsection Communication protocol @cindex debugging stub, example *************** bytes. For a software breakpoint, @var{ *** 9264,9270 **** the instruction to be patched. For hardware breakpoints and watchpoints @var{length} specifies the memory region to be monitored. To avoid potential problems with duplicate packets, the operations should be ! implemented in an ident-potentent way. @item @tab reply @code{E}@var{NN} @tab for an error --- 9348,9354 ---- the instruction to be patched. For hardware breakpoints and watchpoints @var{length} specifies the memory region to be monitored. To avoid potential problems with duplicate packets, the operations should be ! implemented in an idempotent way. @item @tab reply @code{E}@var{NN} @tab for an error *************** applicable for certains sorts of targets *** 9312,9325 **** @tab The process terminated with signal @var{AA}. ! @item @code{N}@var{AA}@code{;}@var{tttttttt}@code{;}@var{dddddddd}@code{;}@var{bbbbbbbb} @strong{(obsolete)} @tab ! @var{AA} = signal number; @var{tttttttt} = address of symbol "_start"; ! @var{dddddddd} = base of data section; @var{bbbbbbbb} = base of bss ! section. @emph{Note: only used by Cisco Systems targets. The difference ! between this reply and the "qOffsets" query is that the 'N' packet may ! arrive spontaneously whereas the 'qOffsets' is a query initiated by the ! host debugger.} @item @code{O}@var{XX...} @tab --- 9396,9409 ---- @tab The process terminated with signal @var{AA}. ! @item @code{N}@var{AA}@code{;}@var{t...}@code{;}@var{d...}@code{;}@var{b...} @strong{(obsolete)} @tab ! @var{AA} = signal number; @var{t...} = address of symbol "_start"; ! @var{d...} = base of data section; @var{b...} = base of bss section. ! @emph{Note: only used by Cisco Systems targets. The difference between ! this reply and the "qOffsets" query is that the 'N' packet may arrive ! spontaneously whereas the 'qOffsets' is a query initiated by the host ! debugger.} @item @code{O}@var{XX...} @tab *************** Example sequence of a target being stepp *** 9536,9542 **** <- @code{+} @end example ! @node Server, NetWare, Protocol, Remote Serial @subsubsection Using the @code{gdbserver} program @kindex gdbserver --- 9620,9626 ---- <- @code{+} @end example ! @node Server @subsubsection Using the @code{gdbserver} program @kindex gdbserver *************** text depends on the host system, but whi *** 9638,9644 **** @samp{Connection refused}. @end table ! @node NetWare, , Server, Remote Serial @subsubsection Using the @code{gdbserve.nlm} program @kindex gdbserve.nlm --- 9722,9728 ---- @samp{Connection refused}. @end table ! @node NetWare @subsubsection Using the @code{gdbserve.nlm} program @kindex gdbserve.nlm *************** argument is a device name (usually a ser *** 9695,9701 **** communications with the server via serial line @file{/dev/ttyb}. @end table ! @node KOD, , Remote, Targets @section Kernel Object Display @cindex kernel object display --- 9779,9785 ---- communications with the server via serial line @file{/dev/ttyb}. @end table ! @node KOD @section Kernel Object Display @cindex kernel object display *************** There is currently no way to determine w *** 9734,9740 **** is supported other than to try it. ! @node Configurations, Controlling GDB, Targets, Top @chapter Configuration-Specific Information While nearly all @value{GDBN} commands are available for all native and --- 9818,9824 ---- is supported other than to try it. ! @node Configurations @chapter Configuration-Specific Information While nearly all @value{GDBN} commands are available for all native and *************** are quite different from each other. *** 9754,9760 **** * Architectures:: @end menu ! @node Native, Embedded OS, Configurations, Configurations @section Native This section describes details specific to particular native --- 9838,9844 ---- * Architectures:: @end menu ! @node Native @section Native This section describes details specific to particular native *************** configurations. *** 9765,9778 **** * SVR4 Process Information:: SVR4 process information @end menu ! @node HP-UX, SVR4 Process Information, Native, Native @subsection HP-UX On HP-UX systems, if you refer to a function or variable name that begins with a dollar sign, @value{GDBN} searches for a user or system name first, before it searches for a convenience variable. ! @node SVR4 Process Information, , HP-UX, Native @subsection SVR4 process information @kindex /proc --- 9849,9862 ---- * SVR4 Process Information:: SVR4 process information @end menu ! @node HP-UX @subsection HP-UX On HP-UX systems, if you refer to a function or variable name that begins with a dollar sign, @value{GDBN} searches for a user or system name first, before it searches for a convenience variable. ! @node SVR4 Process Information @subsection SVR4 process information @kindex /proc *************** received. *** 9817,9823 **** Show all the above information about the process. @end table ! @node Embedded OS, Embedded Processors, Native, Configurations @section Embedded Operating Systems This section describes configurations involving the debugging of --- 9901,9907 ---- Show all the above information about the process. @end table ! @node Embedded OS @section Embedded Operating Systems This section describes configurations involving the debugging of *************** architectures. *** 9831,9837 **** @value{GDBN} includes the ability to debug programs running on various real-time operating systems. ! @node VxWorks, , Embedded OS, Embedded OS @subsection Using @value{GDBN} with VxWorks @cindex VxWorks --- 9915,9921 ---- @value{GDBN} includes the ability to debug programs running on various real-time operating systems. ! @node VxWorks @subsection Using @value{GDBN} with VxWorks @cindex VxWorks *************** run @value{GDBN}. From your Unix host, *** 9898,9904 **** * VxWorks Attach:: Running tasks @end menu ! @node VxWorks Connection, VxWorks Download, VxWorks, VxWorks @subsubsection Connecting to VxWorks The @value{GDBN} command @code{target} lets you connect to a VxWorks target on the --- 9982,9988 ---- * VxWorks Attach:: Running tasks @end menu ! @node VxWorks Connection @subsubsection Connecting to VxWorks The @value{GDBN} command @code{target} lets you connect to a VxWorks target on the *************** When this happens, add the appropriate d *** 9931,9937 **** the @value{GDBN} command @code{path}, and execute the @code{target} command again. ! @node VxWorks Download, VxWorks Attach, VxWorks Connection, VxWorks @subsubsection VxWorks download @cindex download to VxWorks --- 10015,10021 ---- the @value{GDBN} command @code{path}, and execute the @code{target} command again. ! @node VxWorks Download @subsubsection VxWorks download @cindex download to VxWorks *************** history. (This is necessary in order to *** 9977,9983 **** debugger's data structures that reference the target system's symbol table.) ! @node VxWorks Attach, , VxWorks Download, VxWorks @subsubsection Running tasks @cindex running VxWorks tasks --- 10061,10067 ---- debugger's data structures that reference the target system's symbol table.) ! @node VxWorks Attach @subsubsection Running tasks @cindex running VxWorks tasks *************** where @var{task} is the VxWorks hexadeci *** 9993,9999 **** or suspended when you attach to it. Running tasks are suspended at the time of attachment. ! @node Embedded Processors, Architectures, Embedded OS, Configurations @section Embedded Processors This section goes into details specific to particular embedded --- 10077,10083 ---- or suspended when you attach to it. Running tasks are suspended at the time of attachment. ! @node Embedded Processors @section Embedded Processors This section goes into details specific to particular embedded *************** configurations. *** 10018,10024 **** * Z8000:: Zilog Z8000 @end menu ! @node A29K Embedded, ARM, Embedded Processors, Embedded Processors @subsection AMD A29K Embedded @menu --- 10102,10108 ---- * Z8000:: Zilog Z8000 @end menu ! @node A29K Embedded @subsection AMD A29K Embedded @menu *************** name of the program to be debugged, as i *** 10046,10052 **** @end table ! @node A29K UDI, A29K EB29K, A29K Embedded, A29K Embedded @subsubsection A29K UDI @cindex UDI --- 10130,10136 ---- @end table ! @node A29K UDI @subsubsection A29K UDI @cindex UDI *************** working directory, you must set the envi *** 10070,10076 **** to its pathname. @end table ! @node A29K EB29K, Comms (EB29K), A29K UDI, A29K Embedded @subsubsection EBMON protocol for AMD29K @cindex EB29K board --- 10154,10160 ---- to its pathname. @end table ! @node A29K EB29K @subsubsection EBMON protocol for AMD29K @cindex EB29K board *************** board) and a serial port on the Unix sys *** 10085,10091 **** assume you've hooked the cable between the PC's @file{COM1} port and @file{/dev/ttya} on the Unix system. ! @node Comms (EB29K), gdb-EB29K, A29K EB29K, A29K Embedded @subsubsection Communications setup The next step is to set up the PC's port, by doing something like this --- 10169,10175 ---- assume you've hooked the cable between the PC's @file{COM1} port and @file{/dev/ttya} on the Unix system. ! @node Comms (EB29K) @subsubsection Communications setup The next step is to set up the PC's port, by doing something like this *************** other way---perhaps floppy-disk transfer *** 10207,10213 **** from the Unix system to the PC; @value{GDBN} does @emph{not} download it over the serial line. ! @node gdb-EB29K, Remote Log, Comms (EB29K), A29K Embedded @subsubsection EB29K cross-debugging Finally, @code{cd} to the directory containing an image of your 29K --- 10291,10297 ---- from the Unix system to the PC; @value{GDBN} does @emph{not} download it over the serial line. ! @node gdb-EB29K @subsubsection EB29K cross-debugging Finally, @code{cd} to the directory containing an image of your 29K *************** once again, after your @value{GDBN} sess *** 10251,10257 **** Type @kbd{CTTY con} to return command input to the main DOS console, and type @kbd{~.} to leave @code{tip} or @code{cu}. ! @node Remote Log, , gdb-EB29K, A29K Embedded @subsubsection Remote log @kindex eb.log @cindex log file for EB29K --- 10335,10341 ---- Type @kbd{CTTY con} to return command input to the main DOS console, and type @kbd{~.} to leave @code{tip} or @code{cu}. ! @node Remote Log @subsubsection Remote log @kindex eb.log @cindex log file for EB29K *************** of the commands sent to it. Running @sa *** 10263,10269 **** another window often helps to understand trouble with @code{EBMON}, or unexpected events on the PC side of the connection. ! @node ARM, H8/300, A29K Embedded, Embedded Processors @subsection ARM @table @code --- 10347,10353 ---- another window often helps to understand trouble with @code{EBMON}, or unexpected events on the PC side of the connection. ! @node ARM @subsection ARM @table @code *************** ARM Demon monitor. *** 10280,10286 **** @end table ! @node H8/300, H8/500, ARM, Embedded Processors @subsection Hitachi H8/300 @table @code --- 10364,10370 ---- @end table ! @node H8/300 @subsection Hitachi H8/300 @table @code *************** what speed to use over the serial device *** 10337,10343 **** * Hitachi Special:: Special @value{GDBN} commands for Hitachi micros. @end menu ! @node Hitachi Boards, Hitachi ICE, H8/300, H8/300 @subsubsection Connecting to Hitachi boards @c only for Unix hosts --- 10421,10427 ---- * Hitachi Special:: Special @value{GDBN} commands for Hitachi micros. @end menu ! @node Hitachi Boards @subsubsection Connecting to Hitachi boards @c only for Unix hosts *************** to detect program completion. *** 10450,10456 **** In either case, @value{GDBN} sees the effect of a @sc{reset} on the development board as a ``normal exit'' of your program. ! @node Hitachi ICE, Hitachi Special, Hitachi Boards, H8/300 @subsubsection Using the E7000 in-circuit emulator @kindex target e7000@r{, with Hitachi ICE} --- 10534,10540 ---- In either case, @value{GDBN} sees the effect of a @sc{reset} on the development board as a ``normal exit'' of your program. ! @node Hitachi ICE @subsubsection Using the E7000 in-circuit emulator @kindex target e7000@r{, with Hitachi ICE} *************** If your E7000 is installed as a host on *** 10470,10476 **** specify its hostname; @value{GDBN} uses @code{telnet} to connect. @end table ! @node Hitachi Special, , Hitachi ICE, H8/300 @subsubsection Special @value{GDBN} commands for Hitachi micros Some @value{GDBN} commands are available only for the H8/300: --- 10554,10560 ---- specify its hostname; @value{GDBN} uses @code{telnet} to connect. @end table ! @node Hitachi Special @subsubsection Special @value{GDBN} commands for Hitachi micros Some @value{GDBN} commands are available only for the H8/300: *************** to check which variant is currently in e *** 10487,10493 **** @end table ! @node H8/500, i960, H8/300, Embedded Processors @subsection H8/500 @table @code --- 10571,10577 ---- @end table ! @node H8/500 @subsection H8/500 @table @code *************** memory}. The accepted values for @var{m *** 10503,10509 **** @end table ! @node i960, M32R/D, H8/500, Embedded Processors @subsection Intel i960 @table @code --- 10587,10593 ---- @end table ! @node i960 @subsection Intel i960 @table @code *************** downloads @var{filename} to the 960 as w *** 10556,10562 **** * Nindy Reset:: Nindy reset command @end menu ! @node Nindy Startup, Nindy Options, i960, i960 @subsubsection Startup with Nindy If you simply start @code{@value{GDBP}} without using any command-line --- 10640,10646 ---- * Nindy Reset:: Nindy reset command @end menu ! @node Nindy Startup @subsubsection Startup with Nindy If you simply start @code{@value{GDBP}} without using any command-line *************** simply start up with no Nindy connection *** 10574,10580 **** with an empty line. If you do this and later wish to attach to Nindy, use @code{target} (@pxref{Target Commands, ,Commands for managing targets}). ! @node Nindy Options, Nindy Reset, Nindy Startup, i960 @subsubsection Options for Nindy These are the startup options for beginning your @value{GDBN} session with a --- 10658,10664 ---- with an empty line. If you do this and later wish to attach to Nindy, use @code{target} (@pxref{Target Commands, ,Commands for managing targets}). ! @node Nindy Options @subsubsection Options for Nindy These are the startup options for beginning your @value{GDBN} session with a *************** The standard @samp{-b} option controls t *** 10617,10623 **** port. @c @group ! @node Nindy Reset, , Nindy Options, i960 @subsubsection Nindy reset command @table @code --- 10701,10707 ---- port. @c @group ! @node Nindy Reset @subsubsection Nindy reset command @table @code *************** a break is detected. *** 10630,10636 **** @end table @c @end group ! @node M32R/D, M68K, i960, Embedded Processors @subsection Mitsubishi M32R/D @table @code --- 10714,10720 ---- @end table @c @end group ! @node M32R/D @subsection Mitsubishi M32R/D @table @code *************** Mitsubishi M32R/D ROM monitor. *** 10641,10647 **** @end table ! @node M68K, M88K, M32R/D, Embedded Processors @subsection M68k The Motorola m68k configuration includes ColdFire support, and --- 10725,10731 ---- @end table ! @node M68K @subsection M68k The Motorola m68k configuration includes ColdFire support, and *************** ROMBUG ROM monitor for OS/9000. *** 10692,10698 **** @end table ! @node M88K, MIPS Embedded, M68K, Embedded Processors @subsection M88K @table @code --- 10776,10782 ---- @end table ! @node M88K @subsection M88K @table @code *************** BUG monitor, running on a MVME187 (m88k) *** 10703,10709 **** @end table ! @node MIPS Embedded, PowerPC, M88K, Embedded Processors @subsection MIPS Embedded @cindex MIPS boards --- 10787,10793 ---- @end table ! @node MIPS Embedded @subsection MIPS Embedded @cindex MIPS boards *************** forever because it has no way of knowing *** 10847,10853 **** to run before stopping. @end table ! @node PowerPC, PA, MIPS Embedded, Embedded Processors @subsection PowerPC @table @code --- 10931,10937 ---- to run before stopping. @end table ! @node PowerPC @subsection PowerPC @table @code *************** SDS monitor, running on a PowerPC board *** 10868,10874 **** @end table ! @node PA, SH, PowerPC, Embedded Processors @subsection HP PA Embedded @table @code --- 10952,10958 ---- @end table ! @node PA @subsection HP PA Embedded @table @code *************** W89K monitor, running on a Winbond HPPA *** 10883,10889 **** @end table ! @node SH, Sparclet, PA, Embedded Processors @subsection Hitachi SH @table @code --- 10967,10973 ---- @end table ! @node SH @subsection Hitachi SH @table @code *************** Hitachi SH-3 and SH-3E target systems. *** 10906,10912 **** @end table ! @node Sparclet, Sparclite, SH, Embedded Processors @subsection Tsqware Sparclet @cindex Sparclet --- 10990,10996 ---- @end table ! @node Sparclet @subsection Tsqware Sparclet @cindex Sparclet *************** run @value{GDBN}. From your Unix host, *** 10960,10966 **** * Sparclet Execution:: Running and debugging @end menu ! @node Sparclet File, Sparclet Connection, Sparclet, Sparclet @subsubsection Setting file to debug The @value{GDBN} command @code{file} lets you choose with program to debug. --- 11044,11050 ---- * Sparclet Execution:: Running and debugging @end menu ! @node Sparclet File @subsubsection Setting file to debug The @value{GDBN} command @code{file} lets you choose with program to debug. *************** When this happens, add the appropriate d *** 10990,10996 **** the @value{GDBN} commands @code{path} and @code{dir}, and execute the @code{target} command again. ! @node Sparclet Connection, Sparclet Download, Sparclet File, Sparclet @subsubsection Connecting to Sparclet The @value{GDBN} command @code{target} lets you connect to a Sparclet target. --- 11074,11080 ---- the @value{GDBN} commands @code{path} and @code{dir}, and execute the @code{target} command again. ! @node Sparclet Connection @subsubsection Connecting to Sparclet The @value{GDBN} command @code{target} lets you connect to a Sparclet target. *************** main () at ../prog.c:3 *** 11009,11015 **** Connected to ttya. @end example ! @node Sparclet Download, Sparclet Execution, Sparclet Connection, Sparclet @subsubsection Sparclet download @cindex download to Sparclet --- 11093,11099 ---- Connected to ttya. @end example ! @node Sparclet Download @subsubsection Sparclet download @cindex download to Sparclet *************** If the code is loaded at a different add *** 11035,11041 **** to, you may need to use the @code{section} and @code{add-symbol-file} commands to tell @value{GDBN} where to map the symbol table. ! @node Sparclet Execution, , Sparclet Download, Sparclet @subsubsection Running and debugging @cindex running and debugging Sparclet programs --- 11119,11125 ---- to, you may need to use the @code{section} and @code{add-symbol-file} commands to tell @value{GDBN} where to map the symbol table. ! @node Sparclet Execution @subsubsection Running and debugging @cindex running and debugging Sparclet programs *************** Breakpoint 1, main (argc=1, argv=0xeffff *** 11055,11061 **** (gdbslet) @end example ! @node Sparclite, ST2000, Sparclet, Embedded Processors @subsection Fujitsu Sparclite @table @code --- 11139,11145 ---- (gdbslet) @end example ! @node Sparclite @subsection Fujitsu Sparclite @table @code *************** remote protocol. *** 11069,11075 **** @end table ! @node ST2000, Z8000, Sparclite, Embedded Processors @subsection Tandem ST2000 @value{GDBN} may be used with a Tandem ST2000 phone switch, running Tandem's --- 11153,11159 ---- @end table ! @node ST2000 @subsection Tandem ST2000 @value{GDBN} may be used with a Tandem ST2000 phone switch, running Tandem's *************** sequences gets you back to the @value{GD *** 11118,11124 **** @kbd{@key{RET}~@key{C-d}} (Return, followed by tilde and control-D). @end table ! @node Z8000, , ST2000, Embedded Processors @subsection Zilog Z8000 @cindex Z8000 --- 11202,11208 ---- @kbd{@key{RET}~@key{C-d}} (Return, followed by tilde and control-D). @end table ! @node Z8000 @subsection Zilog Z8000 @cindex Z8000 *************** conventions; for example, @w{@samp{b fpu *** 11169,11175 **** conditional breakpoint that suspends only after at least 5000 simulated clock ticks. ! @node Architectures, , Embedded Processors, Configurations @section Architectures This section describes characteristics of architectures that affect --- 11253,11259 ---- conditional breakpoint that suspends only after at least 5000 simulated clock ticks. ! @node Architectures @section Architectures This section describes characteristics of architectures that affect *************** all uses of @value{GDBN} with the archit *** 11181,11187 **** * MIPS:: @end menu ! @node A29K, Alpha, Architectures, Architectures @subsection A29K @table @code --- 11265,11271 ---- * MIPS:: @end menu ! @node A29K @subsection A29K @table @code *************** processors. *** 11207,11218 **** @end table ! @node Alpha, MIPS, A29K, Architectures @subsection Alpha See the following section. ! @node MIPS, , Alpha, Architectures @subsection MIPS @cindex stack on Alpha --- 11291,11302 ---- @end table ! @node Alpha @subsection Alpha See the following section. ! @node MIPS @subsection MIPS @cindex stack on Alpha *************** These commands are available @emph{only} *** 11247,11253 **** for debugging programs on Alpha or MIPS processors. ! @node Controlling GDB, Sequences, Configurations, Top @chapter Controlling @value{GDBN} You can alter the way @value{GDBN} interacts with you by using the --- 11331,11337 ---- for debugging programs on Alpha or MIPS processors. ! @node Controlling GDB @chapter Controlling @value{GDBN} You can alter the way @value{GDBN} interacts with you by using the *************** described here. *** 11265,11271 **** * Debugging Output:: Optional messages about internal happenings @end menu ! @node Prompt, Editing, Controlling GDB, Controlling GDB @section Prompt @cindex prompt --- 11349,11355 ---- * Debugging Output:: Optional messages about internal happenings @end menu ! @node Prompt @section Prompt @cindex prompt *************** Directs @value{GDBN} to use @var{newprom *** 11291,11297 **** Prints a line of the form: @samp{Gdb's prompt is: @var{your-prompt}} @end table ! @node Editing, History, Prompt, Controlling GDB @section Command editing @cindex readline @cindex command line editing --- 11375,11381 ---- Prints a line of the form: @samp{Gdb's prompt is: @var{your-prompt}} @end table ! @node Editing @section Command editing @cindex readline @cindex command line editing *************** Disable command line editing. *** 11321,11327 **** Show whether command line editing is enabled. @end table ! @node History, Screen Size, Editing, Controlling GDB @section Command history @value{GDBN} can keep track of the commands you type during your --- 11405,11411 ---- Show whether command line editing is enabled. @end table ! @node History @section Command history @value{GDBN} can keep track of the commands you type during your *************** Print ten commands centered on command n *** 11418,11424 **** Print ten commands just after the commands last printed. @end table ! @node Screen Size, Numbers, History, Controlling GDB @section Screen size @cindex size of screen @cindex pauses in output --- 11502,11508 ---- Print ten commands just after the commands last printed. @end table ! @node Screen Size @section Screen size @cindex size of screen @cindex pauses in output *************** Likewise, you can specify @samp{set widt *** 11460,11466 **** from wrapping its output. @end table ! @node Numbers, Messages/Warnings, Screen Size, Controlling GDB @section Numbers @cindex number representation @cindex entering numbers --- 11544,11550 ---- from wrapping its output. @end table ! @node Numbers @section Numbers @cindex number representation @cindex entering numbers *************** Display the current default base for num *** 11507,11513 **** Display the current default base for numeric display. @end table ! @node Messages/Warnings, Debugging Output , Numbers, Controlling GDB @section Optional warnings and messages By default, @value{GDBN} is silent about its inner workings. If you are --- 11591,11597 ---- Display the current default base for numeric display. @end table ! @node Messages/Warnings @section Optional warnings and messages By default, @value{GDBN} is silent about its inner workings. If you are *************** Displays state of confirmation requests. *** 11583,11589 **** @end table ! @node Debugging Output, ,Messages/Warnings, Controlling GDB @section Optional messages about internal happenings @table @code @kindex set debug arch --- 11667,11673 ---- @end table ! @node Debugging Output @section Optional messages about internal happenings @table @code @kindex set debug arch *************** Displays the current state of displaying *** 11654,11660 **** debugging info. @end table ! @node Sequences, Emacs, Controlling GDB, Top @chapter Canned Sequences of Commands Aside from breakpoint commands (@pxref{Break Commands, ,Breakpoint --- 11738,11744 ---- debugging info. @end table ! @node Sequences @chapter Canned Sequences of Commands Aside from breakpoint commands (@pxref{Break Commands, ,Breakpoint *************** files. *** 11669,11675 **** * Output:: Commands for controlled output @end menu ! @node Define, Hooks, Sequences, Sequences @section User-defined commands @cindex user-defined command --- 11753,11759 ---- * Output:: Commands for controlled output @end menu ! @node Define @section User-defined commands @cindex user-defined command *************** without asking when used inside a user-d *** 11762,11768 **** commands that normally print messages to say what they are doing omit the messages when used in a user-defined command. ! @node Hooks, Command Files, Define, Sequences @section User-defined command hooks @cindex command hooks @cindex hooks, for commands --- 11846,11852 ---- commands that normally print messages to say what they are doing omit the messages when used in a user-defined command. ! @node Hooks @section User-defined command hooks @cindex command hooks @cindex hooks, for commands *************** If an error occurs during the execution *** 11808,11814 **** If you try to define a hook which does not match any known command, you get a warning from the @code{define} command. ! @node Command Files, Output, Hooks, Sequences @section Command files @cindex command files --- 11892,11898 ---- If you try to define a hook which does not match any known command, you get a warning from the @code{define} command. ! @node Command Files @section Command files @cindex command files *************** without asking when used in a command fi *** 11871,11877 **** normally print messages to say what they are doing omit the messages when called from command files. ! @node Output, , Command Files, Sequences @section Commands for controlled output During the execution of a command file or a user-defined command, normal --- 11955,11961 ---- normally print messages to say what they are doing omit the messages when called from command files. ! @node Output @section Commands for controlled output During the execution of a command file or a user-defined command, normal *************** string are the simple ones that consist *** 11951,11957 **** letter. @end table ! @node Emacs, Annotations, Sequences, Top @chapter Using @value{GDBN} under @sc{gnu} Emacs @cindex Emacs --- 12035,12041 ---- letter. @end table ! @node Emacs @chapter Using @value{GDBN} under @sc{gnu} Emacs @cindex Emacs *************** environment. Users of this environment *** 12125,12135 **** each value is printed in its own window. @end ignore ! @node Annotations, GDB Bugs, Emacs, Top @chapter @value{GDBN} Annotations @include annotate.texi ! @node GDB Bugs, Command Line Editing, Annotations, Top @chapter Reporting Bugs in @value{GDBN} @cindex bugs in @value{GDBN} @cindex reporting bugs in @value{GDBN} --- 12209,12219 ---- each value is printed in its own window. @end ignore ! @node Annotations @chapter @value{GDBN} Annotations @include annotate.texi ! @node GDB Bugs @chapter Reporting Bugs in @value{GDBN} @cindex bugs in @value{GDBN} @cindex reporting bugs in @value{GDBN} *************** information that enables us to fix the b *** 12149,12155 **** * Bug Reporting:: How to report bugs @end menu ! @node Bug Criteria, Bug Reporting, GDB Bugs, GDB Bugs @section Have you found a bug? @cindex bug criteria --- 12233,12239 ---- * Bug Reporting:: How to report bugs @end menu ! @node Bug Criteria @section Have you found a bug? @cindex bug criteria *************** If you are an experienced user of debugg *** 12181,12187 **** for improvement of @value{GDBN} are welcome in any case. @end itemize ! @node Bug Reporting, , Bug Criteria, GDB Bugs @section How to report bugs @cindex bug reports @cindex @value{GDBN} bugs, reporting --- 12265,12271 ---- for improvement of @value{GDBN} are welcome in any case. @end itemize ! @node Bug Reporting @section How to report bugs @cindex bug reports @cindex @value{GDBN} bugs, reporting *************** things without first using the debugger *** 12371,12387 **** @c Use -I with makeinfo to point to the appropriate directory, @c environment var TEXINPUTS with TeX. ! @node Command Line Editing, Using History Interactively, GDB Bugs, Top @chapter Command Line Editing @include rluser.texinfo ! @node Using History Interactively, Formatting Documentation, Command Line Editing, Top @chapter Using History Interactively @include inc-hist.texinfo ! @node Formatting Documentation, Installing GDB, Using History Interactively, Top @appendix Formatting Documentation @cindex @value{GDBN} reference card --- 12455,12471 ---- @c Use -I with makeinfo to point to the appropriate directory, @c environment var TEXINPUTS with TeX. ! @node Command Line Editing @chapter Command Line Editing @include rluser.texinfo ! @node Using History Interactively @chapter Using History Interactively @include inc-hist.texinfo ! @node Formatting Documentation @appendix Formatting Documentation @cindex @value{GDBN} reference card *************** make gdb.dvi *** 12467,12473 **** Then give @file{gdb.dvi} to your @sc{dvi} printing program. ! @node Installing GDB, Index, Formatting Documentation, Top @appendix Installing @value{GDBN} @cindex configuring @value{GDBN} @cindex installation --- 12551,12557 ---- Then give @file{gdb.dvi} to your @sc{dvi} printing program. ! @node Installing GDB @appendix Installing @value{GDBN} @cindex configuring @value{GDBN} @cindex installation *************** let @value{GDBN} debug child processes w *** 12587,12593 **** * Configure Options:: Summary of options for configure @end menu ! @node Separate Objdir, Config Names, Installing GDB, Installing GDB @section Compiling @value{GDBN} in another directory If you want to run @value{GDBN} versions for several host or target machines, --- 12671,12677 ---- * Configure Options:: Summary of options for configure @end menu ! @node Separate Objdir @section Compiling @value{GDBN} in another directory If you want to run @value{GDBN} versions for several host or target machines, *************** directories, you can run @code{make} on *** 12648,12654 **** if they are NFS-mounted on each of the hosts); they will not interfere with each other. ! @node Config Names, Configure Options, Separate Objdir, Installing GDB @section Specifying names for hosts and targets The specifications used for hosts and targets in the @code{configure} --- 12732,12738 ---- if they are NFS-mounted on each of the hosts); they will not interfere with each other. ! @node Config Names @section Specifying names for hosts and targets The specifications used for hosts and targets in the @code{configure} *************** Invalid configuration `i986v': machine ` *** 12690,12696 **** @code{config.sub} is also distributed in the @value{GDBN} source directory (@file{gdb-@value{GDBVN}}, for version @value{GDBVN}). ! @node Configure Options, , Config Names, Installing GDB @section @code{configure} options Here is a summary of the @code{configure} options and arguments that --- 12774,12780 ---- @code{config.sub} is also distributed in the @value{GDBN} source directory (@file{gdb-@value{GDBVN}}, for version @value{GDBVN}). ! @node Configure Options @section @code{configure} options Here is a summary of the @code{configure} options and arguments that *************** There is no convenient way to generate a *** 12759,12765 **** There are many other options available as well, but they are generally needed for special purposes only. ! @node Index, , Installing GDB, Top @unnumbered Index @printindex cp --- 12843,12849 ---- There are many other options available as well, but they are generally needed for special purposes only. ! @node Index @unnumbered Index @printindex cp >From msnyder@cygnus.com Tue Mar 28 10:32:00 2000 From: Michael Snyder To: Chris Faylor Cc: gdb-patches@sourceware.cygnus.com Subject: Re: [RFA] Avoid core dumping on corrupt stabs entry Date: Tue, 28 Mar 2000 10:32:00 -0000 Message-id: <38E0FAD3.60B7@cygnus.com> References: <20000327204057.A24783@cygnus.com> X-SW-Source: 2000-03/msg00649.html Content-length: 907 Chris Faylor wrote: > > Any objections to this patch? It seems to be in the spirit of the rest > of the file. Looks good to me. JimB? > 2000-03-27 Christopher Faylor > > * partial-stab.h: Add one more check against corrupted or irregular > stabs entry. > > Index: partial-stab.h > =================================================================== > RCS file: /cvs/cvsfiles/devo/gdb/partial-stab.h,v > retrieving revision 2.68 > diff -u -p -r2.68 partial-stab.h > --- partial-stab.h 1999/09/14 22:50:39 2.68 > +++ partial-stab.h 2000/03/28 01:37:53 > @@ -393,7 +393,7 @@ switch (CUR_SYMBOL_TYPE) > > #ifdef DBXREAD_ONLY > /* See if this is an end of function stab. */ > - if (CUR_SYMBOL_TYPE == N_FUN && *namestring == '\000') > + if (pst && CUR_SYMBOL_TYPE == N_FUN && *namestring == '\000') > { > unsigned long valu; > >From msnyder@cygnus.com Tue Mar 28 11:15:00 2000 From: Michael Snyder To: gdb-patches@sourceware.cygnus.com Subject: Re: RFA: procfs.c:proc_set_watchpoint bug fix Date: Tue, 28 Mar 2000 11:15:00 -0000 Message-id: <38E1023A.7A8E@cygnus.com> References: <200003072114.WAA26143@reisser.regent.e-technik.tu-muenchen.de> X-SW-Source: 2000-03/msg00650.html Content-length: 1093 Peter.Schauer wrote: > > procfs.c:proc_set_watchpoint currently declares its addr parameter as > void *, but it is called from procfs_set_watchpoint with a CORE_ADDR addr. > This causes problems if sizeof(CORE_ADDR) > sizeof(void *), e.g on > Solaris 2.7 sparc. Approved and committed. > 2000-03-07 Peter Schauer > > * procfs.c (proc_set_watchpoint): Declare addr parameter as > CORE_ADDR, to match call from procfs_set_watchpoint. > > *** gdb/procfs.c.orig Wed Mar 1 21:54:05 2000 > --- gdb/procfs.c Sun Mar 5 12:05:33 2000 > *************** > *** 2580,2586 **** > int > proc_set_watchpoint (pi, addr, len, wflags) > procinfo *pi; > ! void *addr; > int len; > int wflags; > { > --- 2580,2586 ---- > int > proc_set_watchpoint (pi, addr, len, wflags) > procinfo *pi; > ! CORE_ADDR addr; > int len; > int wflags; > { > > -- > Peter Schauer pes@regent.e-technik.tu-muenchen.de >From msnyder@cygnus.com Tue Mar 28 11:30:00 2000 From: Michael Snyder To: gdb-patches@sourceware.cygnus.com Subject: Re: RFA: breakpoint.c: Minor output fixes for hardware watchpoints Date: Tue, 28 Mar 2000 11:30:00 -0000 Message-id: <38E1067A.119C@cygnus.com> References: <200003072114.WAA26280@reisser.regent.e-technik.tu-muenchen.de> X-SW-Source: 2000-03/msg00651.html Content-length: 5447 Peter.Schauer wrote: > > During implementation of hardware watchpoints on Solaris, I noticed the > following inconsistencies in breakpoint.c output between software and > hardware breakpoints. > > 1) insert_breakpoints and do_enable_breakpoint now use select_and_print_frame > to reselect frames after frame selection for watchpoint evaluation. > Up to gdb-4.18 GDB used select_frame to reselect frames. > I have no idea why this was done (I am unable to find a ChangeLog entry, > perhaps this was a side effect of the HP merge), and it causes the following > confusing output from the recurse.exp testcase: This change did indeed come in with the HP merge, which was so massive that we did not get justifications for every little change. I'm going to approve backing this change out. If the folks at HP really need it, let's get a justification and a change that doesn't have unpleasant side effects. Checking in this patch. > continue > Continuing. > #0 recurse (a=10) at /users/pes/gdbnd/devo/gdb/testsuite/gdb.base/recurse.c:15 > 15 if (a == 1) > Hardware watchpoint 2: b > > Old value = 0 > New value = 10 > recurse (a=10) at /users/pes/gdbnd/devo/gdb/testsuite/gdb.base/recurse.c:19 > 19 b *= recurse (a - 1); > (gdb) PASS: gdb.base/recurse.exp: continue to first instance watchpoint, first time > > Note the extra frame output before the watchpoint trigger. This is still > worse in other cases, where we have even more frame output (see below). > > 2) insert_breakpoints tries to reinsert watchpoints even if they are already > marked for deletion at next stop, causing the following redundant output, > again from the recurse.exp testcase: > > continue > Continuing. > #0 recurse (a=5) at /users/pes/gdbnd/devo/gdb/testsuite/gdb.base/recurse.c:20 > 20 return b; > #0 recurse (a=5) at /users/pes/gdbnd/devo/gdb/testsuite/gdb.base/recurse.c:20 > 20 return b; > Watchpoint 4 deleted because the program has left the block in > which its expression is valid. > #0 0x8048a71 in recurse (a=6) at /users/pes/gdbnd/devo/gdb/testsuite/gdb.base/recurse.c:19 > 19 b *= recurse (a - 1); > Hardware watchpoint 4 deletedbecause the program has left the block > in which its expression is valid. > 0x8048a70 in recurse (a=6) at /users/pes/gdbnd/devo/gdb/testsuite/gdb.base/recurse.c:19 > 19 b *= recurse (a - 1); > (gdb) PASS: gdb.base/recurse.exp: second instance watchpoint deleted when leaving scope > > Here is a patch for both problems: > > 2000-03-07 Peter Schauer > > * breakpoint.c (insert_breakpoints, do_enable_breakpoint): Reselect > the saved frame silently after frame selection for watchpoint > evaluation. > (insert_breakpoints): Add missing space in `Hardware watchpoint > deleted' message. Do not reinsert hardware watchpoint if it is > already marked for deletion at next stop. > > *** gdb/breakpoint.c.orig Thu Feb 24 13:41:33 2000 > --- gdb/breakpoint.c Sat Mar 4 11:42:48 2000 > *************** > *** 918,923 **** > --- 918,924 ---- > b->type == bp_read_watchpoint || > b->type == bp_access_watchpoint) > && b->enable == enabled > + && b->disposition != del_at_next_stop > && !b->inserted > && !b->duplicate) > { > *************** > *** 1005,1011 **** > } > else > { > ! printf_filtered ("Hardware watchpoint %d deleted", b->number); > printf_filtered ("because the program has left the block \n"); > printf_filtered ("in which its expression is valid.\n"); > if (b->related_breakpoint) > --- 1006,1012 ---- > } > else > { > ! printf_filtered ("Hardware watchpoint %d deleted ", b->number); > printf_filtered ("because the program has left the block \n"); > printf_filtered ("in which its expression is valid.\n"); > if (b->related_breakpoint) > *************** > *** 1016,1022 **** > /* Restore the frame and level. */ > if ((saved_frame != selected_frame) || > (saved_level != selected_frame_level)) > ! select_and_print_frame (saved_frame, saved_level); > > if (val) > return_val = val; /* remember failure */ > --- 1017,1023 ---- > /* Restore the frame and level. */ > if ((saved_frame != selected_frame) || > (saved_level != selected_frame_level)) > ! select_frame (saved_frame, saved_level); > > if (val) > return_val = val; /* remember failure */ > *************** > *** 7536,7543 **** > } > > if (save_selected_frame_level >= 0) > ! select_and_print_frame (save_selected_frame, > ! save_selected_frame_level); > value_free_to_mark (mark); > } > if (modify_breakpoint_hook) > --- 7558,7564 ---- > } > > if (save_selected_frame_level >= 0) > ! select_frame (save_selected_frame, save_selected_frame_level); > value_free_to_mark (mark); > } > if (modify_breakpoint_hook) > > -- > Peter Schauer pes@regent.e-technik.tu-muenchen.de >From shebs@apple.com Tue Mar 28 12:33:00 2000 From: Stan Shebs To: Andrew Cagney Cc: Eli Zaretskii , gdb-patches@sourceware.cygnus.com Subject: Re: [PATCH] Fix texinfo problems... Date: Tue, 28 Mar 2000 12:33:00 -0000 Message-id: <38E1171F.7651C329@apple.com> References: <38DB1875.4B504618@cygnus.com> <38DBB937.126C95E@apple.com> <38DC6763.563424A2@cygnus.com> <200003260443.XAA26499@mescaline.gnu.org> <38E05161.9707ED26@cygnus.com> X-SW-Source: 2000-03/msg00652.html Content-length: 462 Andrew Cagney wrote: > The attatched converts my botch into your patch. > I've also dropped a copy of texinfo-3.12 into the snapshots directory. > > sorry, > Andrew > > Stan, ok? I didn't see your message before doing my big commit this morning, so some of the changes are redundant. I would suggest updating from cvs over your patched file and seeing what's left over after the merge - the remainder should be much smaller... Stan >From msnyder@cygnus.com Tue Mar 28 13:18:00 2000 From: Michael Snyder To: gdb-patches@sourceware.cygnus.com Subject: [PATCH]: minor Makefile.in tweak Date: Tue, 28 Mar 2000 13:18:00 -0000 Message-id: <200003282118.NAA29340@cleaver.cygnus.com> X-SW-Source: 2000-03/msg00653.html Content-length: 1671 Sun's 'make' on Solaris-x86 seems to work better if this dependency is made explicitly relative to $(srcdir). I don't know if that is a bug in VPATH handling, or what... 2000-03-28 Michael Snyder * Makefile.in: anchor tui-file.h dependency to $srcdir. Index: ChangeLog =================================================================== RCS file: /cvs/src/src/gdb/ChangeLog,v retrieving revision 1.199 diff -c -r1.199 ChangeLog *** ChangeLog 2000/03/28 19:29:56 1.199 --- ChangeLog 2000/03/28 21:15:16 *************** *** 1,3 **** --- 1,7 ---- + 2000-03-28 Michael Snyder + + * Makefile.in: anchor tui-file.h dependency to $srcdir. + 2000-03-28 Peter Schauer * procfs.c (proc_set_watchpoint): Declare addr parameter as Index: Makefile.in =================================================================== RCS file: /cvs/src/src/gdb/Makefile.in,v retrieving revision 1.16 diff -c -r1.16 Makefile.in *** Makefile.in 2000/03/27 06:51:30 1.16 --- Makefile.in 2000/03/28 21:15:17 *************** *** 1492,1498 **** mac-nat.o: mac-nat.c $(defs_h) gdb_string.h ! main.o: main.c top.h $(defs_h) gdb_string.h $(event_loop_h) tui/tui-file.h maint.o: maint.c $(defs_h) $(gdbcmd_h) $(gdbtypes_h) $(symtab_h) language.h \ $(expression_h) objfiles.h symfile.h --- 1492,1498 ---- mac-nat.o: mac-nat.c $(defs_h) gdb_string.h ! main.o: main.c top.h $(defs_h) gdb_string.h $(event_loop_h) $(srcdir)/tui/tui-file.h maint.o: maint.c $(defs_h) $(gdbcmd_h) $(gdbtypes_h) $(symtab_h) language.h \ $(expression_h) objfiles.h symfile.h >From tromey@cygnus.com Tue Mar 28 13:30:00 2000 From: Tom Tromey To: gdb-patches@sourceware.cygnus.com Subject: Re: [PATCH]: minor Makefile.in tweak Date: Tue, 28 Mar 2000 13:30:00 -0000 Message-id: <87snxaok7a.fsf@cygnus.com> References: <200003282118.NAA29340@cleaver.cygnus.com> X-SW-Source: 2000-03/msg00654.html Content-length: 637 Michael> Sun's 'make' on Solaris-x86 seems to work better if this Michael> dependency is made explicitly relative to $(srcdir). I don't Michael> know if that is a bug in VPATH handling, or what... FYI, generally speaking vendor makes do not implement VPATH correctly. For automake we decided to only support this feature with GNU make. Some makes are almost good enough to use, if you add tweaks of one sort or another. Sun's make is one of these, but I forget what tweaks are required. Anyway, I don't think gdb is required (i.e., per GNU coding standards) to support VPATH for non-GNU makes. In case you care. Tom >From ac131313@cygnus.com Tue Mar 28 14:03:00 2000 From: Andrew Cagney To: Jim Blandy Cc: gdb-patches@sourceware.cygnus.com Subject: Re: [PATCH] Don't trim addresses in Dwarf debug info Date: Tue, 28 Mar 2000 14:03:00 -0000 Message-id: <38E12BD6.E6E357A4@cygnus.com> References: <200003281624.LAA23161@zwingli.cygnus.com> X-SW-Source: 2000-03/msg00655.html Content-length: 712 Jim Blandy wrote: > > I've committed this: > > 2000-03-27 Jim Blandy > > * dwarf2read.c: Revert Andrew Cagney's change of Dec 15, 1997. > Don't include "bfd-elf.h". > (address_significant_size): Delete variable. > (dwarf2_build_psymtabs_hard): Don't set it, or check for > consistency between it and the Dwarf 2 compilation unit header > address size. > (read_address): Don't mask off bits above > address_significant_size. > * Makefile.in (dwarf2read.o): Don't depend on $(elf_bfd_h). > (elf_bfd_h): Remove variable; it's no longer used. Jim, have you confirmed this doesn't cause any regressions? Andrew >From ac131313@cygnus.com Tue Mar 28 14:17:00 2000 From: Andrew Cagney To: Jim Blandy Cc: Jim Kingdon , Stephane Carrez , gdb-patches@sourceware.cygnus.com Subject: Re: path for gdb/dwarf2read.c, support 16-bit targets in dwarf-2 Date: Tue, 28 Mar 2000 14:17:00 -0000 Message-id: <38E12EDA.386F148A@cygnus.com> References: <38B2F3D3.54CF0AF0@worldnet.fr> <38BB5463.D6E5B75C@cygnus.com> <38C0D9D9.70987863@worldnet.fr> <38C225F3.9E236A55@cygnus.com> <38C737EE.513259B9@cygnus.com> X-SW-Source: 2000-03/msg00656.html Content-length: 1556 Jim Blandy wrote: > > > > The whole address_significant_size code in dwarf2read.c strikes me as > > > a rather ugly kludge to work around bugs elsewhere in the tool chain. > > > If someone is supplying a 32 bit pointer to GDB on a 16 bit target, > > > shouldn't the rest of the tool chain be responsible for making sure > > > the high bits are zero rather than expecting GDB to mask it off? > > > Granted there might be complications here, like there are cases on > > > MIPS where we treat an address as signed rather than unsigned, but I'm > > > also pretty clear on whether that is actually design or just a bug. I > > > could be wrong/persuadable, of course, and perhaps someone has a > > > better idea of all this (in which case I'd suggest commenting > > > arch_size at bfd/elf-bfd.h and/or expanding comments at > > > bfd_arch_bits_per_address in bfd/archures.c). > > > > FYI, in the MIPS case it is a feature of the hardware. GDB has little > > choice in the matter. > > Can you explain why, in the MIPS case, GCC/GAS/LD are unable to place > correct information in the upper bits of the Dwarf addresses? > > (That sounds like a rhetorical question, but it's not. I'm having a > hard time imagining why address_significant_bits was the right > solution.) >From memory, it isn't just the dwarf address. The information comes from two places: o the debug info o the raw symbol table the former has 64 bit information. The latter (elf32) has only 32 bit information. 64bits don't fit into a 32 bit table. GDB uses both. enjoy, Andrew >From msnyder@cygnus.com Tue Mar 28 14:45:00 2000 From: Michael Snyder To: gdb-patches@sourceware.cygnus.com Subject: Re: RFA: infrun.c, breakpoint.c: Kludge for Solaris x86 hardware watchpoint support Date: Tue, 28 Mar 2000 14:45:00 -0000 Message-id: <38E132C8.454C@cygnus.com> References: <200003130947.KAA07528@reisser.regent.e-technik.tu-muenchen.de> X-SW-Source: 2000-03/msg00657.html Content-length: 3545 Peter.Schauer wrote: > > Unfortunately I'd need the following kludge to work around a Solaris x86 > kernel problem with hardware watchpoint support. > See the comment in the patches for a description of the problem. OK, committed (although doesn't this sort of defeat the advantage of a hardware watchpoint?) BTW, next time could you also include the ChangeLog entry in the diffs? Thanks, Michael > 2000-03-12 Peter Schauer > > breakpoint.c, breakpoint.h (remove_hw_watchpoints): New function. > infrun.c (resume): Remove hardware watchpoints before stepping > when CANNOT_STEP_HW_WATCHPOINTS is nonzero. > > *** gdb/breakpoint.c.orig Thu Feb 24 13:41:33 2000 > --- gdb/breakpoint.c Sat Mar 4 11:42:48 2000 > *************** > *** 1080,1085 **** > --- 1081,1107 ---- > } > > int > + remove_hw_watchpoints () > + { > + register struct breakpoint *b; > + int val; > + > + ALL_BREAKPOINTS (b) > + { > + if (b->inserted > + && (b->type == bp_hardware_watchpoint > + || b->type == bp_read_watchpoint > + || b->type == bp_access_watchpoint)) > + { > + val = remove_breakpoint (b, mark_uninserted); > + if (val != 0) > + return val; > + } > + } > + return 0; > + } > + > + int > reattach_breakpoints (pid) > int pid; > { > *** ./gdb/breakpoint.h.orig Thu Feb 3 05:14:27 2000 > --- ./gdb/breakpoint.h Sat Mar 4 11:42:48 2000 > *************** > *** 562,567 **** > --- 562,568 ---- > extern int insert_breakpoints PARAMS ((void)); > > extern int remove_breakpoints PARAMS ((void)); > + extern int remove_hw_watchpoints PARAMS ((void)); > > /* This function can be used to physically insert eventpoints from the > specified traced inferior process, without modifying the breakpoint > *** gdb/infrun.c.orig Thu Feb 24 13:41:46 2000 > --- gdb/infrun.c Mon Mar 13 09:35:54 2000 > *************** > *** 296,301 **** > --- 296,308 ---- > #define HAVE_CONTINUABLE_WATCHPOINT 1 > #endif > > + #ifndef CANNOT_STEP_HW_WATCHPOINTS > + #define CANNOT_STEP_HW_WATCHPOINTS 0 > + #else > + #undef CANNOT_STEP_HW_WATCHPOINTS > + #define CANNOT_STEP_HW_WATCHPOINTS 1 > + #endif > + > /* Tables of how to react to signals; the user sets them. */ > > static unsigned char *signal_stop; > *************** > *** 796,801 **** > --- 803,820 ---- > if (step && breakpoints_inserted && breakpoint_here_p (read_pc ())) > step = 0; > #endif > + > + /* Some targets (e.g. Solaris x86) have a kernel bug when stepping > + over an instruction that causes a page fault without triggering > + a hardware watchpoint. The kernel properly notices that it shouldn't > + stop, because the hardware watchpoint is not triggered, but it forgets > + the step request and continues the program normally. > + Work around the problem by removing hardware watchpoints if a step is > + requested, GDB will check for a hardware watchpoint trigger after the > + step anyway. */ > + if (CANNOT_STEP_HW_WATCHPOINTS && step && breakpoints_inserted) > + remove_hw_watchpoints (); > + > > /* Normally, by the time we reach `resume', the breakpoints are either > removed or inserted, as appropriate. The exception is if we're sitting > > -- > Peter Schauer pes@regent.e-technik.tu-muenchen.de >From msnyder@cygnus.com Tue Mar 28 15:27:00 2000 From: Michael Snyder To: gdb-patches@sourceware.cygnus.com Cc: pes@regent.e-technik.tu-muenchen.de Subject: Re: RFA: infrun.c, breakpoint.c: Kludge for Solaris x86 hardware watchpoint support Date: Tue, 28 Mar 2000 15:27:00 -0000 Message-id: <38E13FD7.38E@cygnus.com> References: <200003130947.KAA07528@reisser.regent.e-technik.tu-muenchen.de> <38E132C8.454C@cygnus.com> X-SW-Source: 2000-03/msg00658.html Content-length: 215 Michael Snyder wrote: > BTW, next time could you also include the ChangeLog entry > in the diffs? Oops, I stand corrected. I guess omitting the ChangeLog from the diffs is the policy. Sorry for the confusion. >From ac131313@cygnus.com Tue Mar 28 16:53:00 2000 From: Andrew Cagney To: GDB Patches Subject: Re: [RFC] maint.c, move assignment to outside of IF expr Date: Tue, 28 Mar 2000 16:53:00 -0000 Message-id: <38E153C6.C75B057@cygnus.com> References: <38E04452.2D1EBEC5@cygnus.com> X-SW-Source: 2000-03/msg00659.html Content-length: 2628 Andrew Cagney wrote: > > OK? > > The attatched moves an assignment out of an if conditional. GCC was > complaining about it. > I'm guessing that the coder didn't intend to write ``=='' :-) Oops, the GCC warnings have been quitely breeding in a corner. I've accumulated/applied the attatched. Andrew Wed Mar 29 10:16:35 2000 Andrew Cagney + + * breakpoint.h (remove_hw_watchpoints): Add declaration. + * breakpoints.c (remove_hw_watchpoints): Update. + * maint.c (maintenance_do_deprecate): Avoid assignment within IF + condition. + Index: breakpoint.c =================================================================== RCS file: /cvs/src/src/gdb/breakpoint.c,v retrieving revision 1.6 diff -p -r1.6 breakpoint.c *** breakpoint.c 2000/03/28 22:30:19 1.6 --- breakpoint.c 2000/03/29 00:47:47 *************** remove_breakpoints () *** 1096,1102 **** } int ! remove_hw_watchpoints () { register struct breakpoint *b; int val; --- 1096,1102 ---- } int ! remove_hw_watchpoints (void) { register struct breakpoint *b; int val; Index: breakpoint.h =================================================================== RCS file: /cvs/src/src/gdb/breakpoint.h,v retrieving revision 1.1.1.11 diff -p -r1.1.1.11 breakpoint.h *** breakpoint.h 2000/02/03 04:14:27 1.1.1.11 --- breakpoint.h 2000/03/29 00:47:50 *************** extern struct breakpoint *set_breakpoint *** 693,696 **** --- 693,700 ---- deletes all breakpoints. */ extern void delete_command (char *arg, int from_tty); + /* Pull all H/W watchpoints from the target. Return non-zero if the + remove fails. */ + extern int remove_hw_watchpoints (void); + #endif /* !defined (BREAKPOINT_H) */ Index: maint.c =================================================================== RCS file: /cvs/src/src/gdb/maint.c,v retrieving revision 1.6 diff -p -r1.6 maint.c *** maint.c 2000/03/25 15:32:18 1.6 --- maint.c 2000/03/29 00:47:54 *************** maintenance_do_deprecate (char *text, in *** 425,434 **** if (deprecate) { /* look for a replacement command */ ! if (start_ptr = strchr (text, '\"')) { start_ptr++; ! if (end_ptr = strrchr (start_ptr, '\"')) { len = end_ptr - start_ptr; start_ptr[len] = '\0'; --- 425,436 ---- if (deprecate) { /* look for a replacement command */ ! start_ptr = strchr (text, '\"'); ! if (start_ptr != NULL) { start_ptr++; ! end_ptr = strrchr (start_ptr, '\"'); ! if (end_ptr != NULL) { len = end_ptr - start_ptr; start_ptr[len] = '\0'; >From ac131313@cygnus.com Tue Mar 28 17:17:00 2000 From: Andrew Cagney To: GDB Patches Subject: [RFC] qfThreadExtraInfo -> qThreadExtraInfo Date: Tue, 28 Mar 2000 17:17:00 -0000 Message-id: <38E15968.BE3BC597@cygnus.com> X-SW-Source: 2000-03/msg00660.html Content-length: 1905 This is just part one of the cleanups to the thread code. It brings this specific query into line with the spec. Given it isn't deployed in the field the change is ok. I've other fixes but they aren't as urgent. Andrew Index: gdb/ChangeLog Tue Mar 28 18:28:40 2000 Andrew Cagney * remote.c (remote_threads_extra_info): Replace qfThreadExtraInfo with qThreadInfo. Index: gdb/doc/ChangeLog Tue Mar 28 18:28:45 2000 Andrew Cagney * gdb.texinfo (Protocol): Replace ``qfThreadExtraInfo'' with qThreadInfo. Index: gdb/remote.c =================================================================== RCS file: /cvs/src/src/gdb/remote.c,v retrieving revision 1.6 diff -p -r1.6 remote.c *** remote.c 2000/03/21 01:22:05 1.6 --- remote.c 2000/03/28 23:57:53 *************** remote_threads_extra_info (struct thread *** 1654,1660 **** if (use_threadextra_query) { ! sprintf (bufp, "qfThreadExtraInfo,%x", tp->pid); putpkt (bufp); getpkt (bufp, PBUFSIZ, 0); if (bufp[0] != 0) --- 1654,1660 ---- if (use_threadextra_query) { ! sprintf (bufp, "qThreadExtraInfo,%x", tp->pid); putpkt (bufp); getpkt (bufp, PBUFSIZ, 0); if (bufp[0] != 0) Index: gdb/doc/gdb.texinfo =================================================================== RCS file: /cvs/src/src/gdb/doc/gdb.texinfo,v retrieving revision 1.9 diff -p -r1.9 gdb.texinfo *** gdb.texinfo 2000/03/28 16:46:24 1.9 --- gdb.texinfo 2000/03/28 23:58:40 *************** respond to each reply with a request for *** 9461,9467 **** (lower-case el, for @code{'last'}). @item extra thread info ! @tab @code{qfThreadExtraInfo,}@var{} @tab @item @tab --- 9461,9467 ---- (lower-case el, for @code{'last'}). @item extra thread info ! @tab @code{q}@code{ThreadExtraInfo}@code{,}@var{id} @tab @item @tab >From ac131313@cygnus.com Tue Mar 28 18:32:00 2000 From: Andrew Cagney To: shebs@apple.com Cc: Eli Zaretskii , gdb-patches@sourceware.cygnus.com Subject: Re: [PATCH] Fix texinfo problems... Date: Tue, 28 Mar 2000 18:32:00 -0000 Message-id: <38E16AB4.F6081625@cygnus.com> References: <38DB1875.4B504618@cygnus.com> <38DBB937.126C95E@apple.com> <38DC6763.563424A2@cygnus.com> <200003260443.XAA26499@mescaline.gnu.org> <38E05161.9707ED26@cygnus.com> <38E1171F.7651C329@apple.com> X-SW-Source: 2000-03/msg00661.html Content-length: 4046 Stan Shebs wrote: > > Andrew Cagney wrote: > > > The attatched converts my botch into your patch. > > I've also dropped a copy of texinfo-3.12 into the snapshots directory. > > > > sorry, > > Andrew > > > > Stan, ok? > > I didn't see your message before doing my big commit this morning, > so some of the changes are redundant. I would suggest updating > from cvs over your patched file and seeing what's left over after > the merge - the remainder should be much smaller... A patch to revert the remainder is attached. Andrew Index: gdb/doc/ChangeLog Tue Mar 28 16:06:22 2000 Andrew Cagney * gdb.texinfo: Revert remainder of Fri Mar 24 18:06:34 2000 Andrew Cagney . Move @chapter and @node entries back to annotate.texi, rluser.texinfo and inc-hist.texinfo. * annotate.texi: Update. Index: readline/doc/ChangeLog Tue Mar 28 16:06:22 2000 Andrew Cagney * inc-hist.texinfo, rluser.texinfo: Revert change Fri Mar 24 18:04:32 2000 Andrew Cagney . Unconditionally provide @chapter and @node. Index: gdb/doc/annotate.texi =================================================================== RCS file: /cvs/src/src/gdb/doc/annotate.texi,v retrieving revision 1.4 diff -p -r1.4 annotate.texi *** annotate.texi 2000/03/28 16:46:24 1.4 --- annotate.texi 2000/03/29 01:29:17 *************** *** 55,64 **** @syncodeindex fn cp - @ifclear GDBN @node Annotations @chapter @value{GDBN} Annotations - @end ifclear This chapter describes annotations in @value{GDBN}. Annotations are designed to interface @value{GDBN} to graphical user interfaces or other --- 55,62 ---- Index: gdb/doc/gdb.texinfo =================================================================== RCS file: /cvs/src/src/gdb/doc/gdb.texinfo,v retrieving revision 1.9 diff -p -r1.9 gdb.texinfo *** gdb.texinfo 2000/03/28 16:46:24 1.9 --- gdb.texinfo 2000/03/29 01:29:56 *************** environment. Users of this environment *** 12209,12216 **** each value is printed in its own window. @end ignore - @node Annotations - @chapter @value{GDBN} Annotations @include annotate.texi @node GDB Bugs --- 12209,12214 ---- *************** things without first using the debugger *** 12454,12467 **** @c inc-hist.texinfo @c Use -I with makeinfo to point to the appropriate directory, @c environment var TEXINPUTS with TeX. - - @node Command Line Editing - @chapter Command Line Editing @include rluser.texinfo - - - @node Using History Interactively - @chapter Using History Interactively @include inc-hist.texinfo --- 12452,12458 ---- Index: readline/doc/inc-hist.texinfo =================================================================== RCS file: /cvs/src/src/readline/doc/inc-hist.texinfo,v retrieving revision 1.2 diff -p -r1.2 inc-hist.texinfo *** inc-hist.texinfo 2000/03/24 07:30:07 1.2 --- inc-hist.texinfo 2000/03/29 01:30:01 *************** Permission is granted to copy and distri *** 23,32 **** into another language, under the above conditions for modified versions. @end ignore - @ifclear GDBN @node Using History Interactively @chapter Using History Interactively - @end ifclear @ifset BashFeatures This chapter describes how to use the GNU History Library interactively, --- 23,30 ---- Index: readline/doc/rluser.texinfo =================================================================== RCS file: /cvs/src/src/readline/doc/rluser.texinfo,v retrieving revision 1.2 diff -p -r1.2 rluser.texinfo *** rluser.texinfo 2000/03/24 07:30:07 1.2 --- rluser.texinfo 2000/03/29 01:30:05 *************** into another language, under the above c *** 36,45 **** @comment If you are including this manual as an appendix, then set the @comment variable readline-appendix. - @ifclear GDBN @node Command Line Editing @chapter Command Line Editing - @end ifclear This chapter describes the basic features of the @sc{GNU} command line editing interface. --- 36,43 ---- >From shebs@apple.com Tue Mar 28 19:00:00 2000 From: Stan Shebs To: Andrew Cagney Cc: Eli Zaretskii , gdb-patches@sourceware.cygnus.com Subject: Re: [PATCH] Fix texinfo problems... Date: Tue, 28 Mar 2000 19:00:00 -0000 Message-id: <38E171AC.AB1B5AD0@apple.com> References: <38DB1875.4B504618@cygnus.com> <38DBB937.126C95E@apple.com> <38DC6763.563424A2@cygnus.com> <200003260443.XAA26499@mescaline.gnu.org> <38E05161.9707ED26@cygnus.com> <38E1171F.7651C329@apple.com> <38E16AB4.F6081625@cygnus.com> X-SW-Source: 2000-03/msg00662.html Content-length: 876 Andrew Cagney wrote: > > Stan Shebs wrote: > > > > I didn't see your message before doing my big commit this morning, > > so some of the changes are redundant. I would suggest updating > > from cvs over your patched file and seeing what's left over after > > the merge - the remainder should be much smaller... > > A patch to revert the remainder is attached. If you could go ahead and commit these, that would be great. Seeing them reminds me of why I had to take out the explicit links in the first place - they didn't play nice with the inserted readline docs, and would have required changes that couldn't have been accepted into standard readline. So I slashed through the Gordian knot of cross-links :-) by taking them all out... (Clearly my next round of checkins should include a note to future hackers about why the explicit links are not in there, eh?) Stan >From ac131313@cygnus.com Tue Mar 28 19:50:00 2000 From: Andrew Cagney To: GDB Patches Subject: GDB 5 2000-03-29 Date: Tue, 28 Mar 2000 19:50:00 -0000 Message-id: <38E17D2C.F7EB65B9@cygnus.com> X-SW-Source: 2000-03/msg00663.html Content-length: 6421 Below is my updated TODO list for GDB 5. I've also attatched the patch I'm applying to TODO. You can see the gory details in the sources. Looking at it. There are four ``must haves'' left. For the watchpoint patches, if at least some have been addressed, I'd like to put the rest off. For Solaris/x86, what shape is it in? The remainder look like must fix bugs. Andrew GDB 5.0: Must have ------------------ These are things that have been identifed as must-have for this release of GDB. -- Watch point related patches (Eli Zaretskii, Michael Snyder, ???) Eli writes: This doesn't include the watchpoint-related patches I sent beginning with August or September, and mentioned them again three weeks ago. Here again are the pointers to the relevant messages: Hardware breakpoints and watchpoints: patches http://sourceware.cygnus.com/ml/gdb-patches/1999-q3/msg00173.html Re: Hardware breakpoints and watchpoints: patches http://sourceware.cygnus.com/ml/gdb-patches/1999-q3/msg00204.html Re: Hardware breakpoints and watchpoints: patches http://sourceware.cygnus.com/ml/gdb-patches/1999-q4/msg00200.html Hardware watchpoints for bitfields http://sourceware.cygnus.com/ml/gdb-patches/1999-q4/msg00201.html -- Tom's speedups to GDB (Tom Tromey, Jim Blandy) I believe that there was a late breaking fix that stopped a coredump. http://sourceware.cygnus.com/ml/gdb-patches/2000-q1/msg00869.html -- Solaris/x86 - which? (Nick Duffek, Peter Schauer, Michael Snyder?) Nick D's working through patches from Michael Snyder and Peter S. -- RFA: procfs.c: init_procfs_ops should set procfs_ops.to_has_[all]_memory (Peter Schauer, Andrew Cagney?) I am pretty sure that this is caused by some accidental deletion, but procfs.c:init_procfs_ops no longer sets procfs_ops.to_has_memory and procfs_ops.to_has_all_memory. http://sourceware.cygnus.com/ml/gdb-patches/2000-q1/msg01057.html Wed Mar 29 13:40:40 2000 Andrew Cagney * TODO: Update GDB 5 status. Index: TODO =================================================================== RCS file: /cvs/src/src/gdb/TODO,v retrieving revision 1.2 diff -u -r1.2 TODO --- TODO 2000/03/27 10:24:58 1.2 +++ TODO 2000/03/29 03:43:21 @@ -62,26 +62,18 @@ -- -Texinfo broken/builds (Andrew Cagney, Stan Shebs) -Cagney probably botched a fix to a botch. +RFA: procfs.c: init_procfs_ops should set +procfs_ops.to_has_[all]_memory (Peter Schauer, Andrew Cagney?) --- +I am pretty sure that this is caused by some accidental deletion, but +procfs.c:init_procfs_ops no longer sets procfs_ops.to_has_memory and +procfs_ops.to_has_all_memory. -x86 linux GDB and SIGALRM - http://sourceware.cygnus.com/ml/gdb/2000-q1/msg00803.html + http://sourceware.cygnus.com/ml/gdb-patches/2000-q1/msg01057.html -- -RFA: breakpoint.c: Minor output fixes for hardware watchpoints - http://sourceware.cygnus.com/ml/gdb-patches/2000-q1/msg00558.html - -During implementation of hardware watchpoints on Solaris, I noticed the -following inconsistencies in breakpoint.c output between software and -hardware breakpoints. - --- - GDB 5.0: Nice to have --------------------- @@ -126,6 +118,12 @@ The pascal support patches nave been added to the patch data base. I [cagney] strongly suspect that they are better suited for 5.1. +Indent -gnu ? + http://sourceware.cygnus.com/ml/gdb/2000-q1/msg00496.html + +2 pascal language patches inserted in database + http://sourceware.cygnus.com/ml/gdb/2000-q1/msg00521.html + -- Programs run under GDB have SIGCHLD masked. @@ -198,6 +196,39 @@ -- +x86 linux GDB and SIGALRM (???) + http://sourceware.cygnus.com/ml/gdb/2000-q1/msg00803.html + +-- + +Migrate qfThreadInfo packet -> qThreadInfo. (Andrew Cagney) + +Add support for packet enable/disable commands with these thread +packets. General cleanup. + +[PATCH] Document the ThreadInfo remote protocol queries + http://sourceware.cygnus.com/ml/gdb-patches/2000-q1/msg00832.html + +[PATCH] "info threads" queries for remote.c + http://sourceware.cygnus.com/ml/gdb-patches/2000-q1/msg00831.html + +-- + +MI documentation in GDB user guide. (Andrew Cagney, Elena Zannoni, +Stan Shebs, anyone else?) + +> (Are there plans to make gdbmi.texi be part of the manual as well?) + +I'd like to see it go in there sooner rather than later too. Otherwise +you're introducing discrepancies between the manual and the documentation, +and everybody is confused - witness the lack of doc for the tracing +commands still, some two years after they were added... + +[PATCH] GDB command-line switches and annotations docs + http://sourceware.cygnus.com/ml/gdb-patches/2000-q1/msg00639.html + +-- + GDB 5.0: Won't have ------------------- @@ -232,6 +263,33 @@ -- +Elimination of make_cleanup_func. (Andrew Cagney) + +make_cleanup_func elimination + http://sourceware.cygnus.com/ml/gdb-patches/2000-q1/msg00791.html + http://sourceware.cygnus.com/ml/gdb-patches/2000-q1/msg00814.html + +-- + +Allow GDB to use installed regex. Think about updating regex to more +recent version (Andrew Cagney). + +Re: A new patch for regex + http://sourceware.cygnus.com/ml/gdb-patches/2000-q1/msg00635.html + +A patch for gnu-regex + http://sourceware.cygnus.com/ml/gdb/2000-q1/msg00568.html + +-- + +ChangeLog.mi vs ChangeLog-mi (Andrew Cagney) +Needs further debate. + +Re: [PATCH] Add change-log variables to more MI files + http://sourceware.cygnus.com/ml/gdb-patches/2000-q1/msg00811.html + +-- + GDB 5.0: Test results --------------------- @@ -329,6 +387,30 @@ General Wish List ================= + +-- + +GDBARCH cleanup (Andrew Cagney) + +The non-generated parts of gdbarch.{sh,h,c} should be separated out +into gdbarch-utils.[hc] (Name ok). + +The ``info architecture'' command should be replaced with a fixed +``set architecture'' (implemented using the command.c enum code). + +Document that gdbarch_init_ftype could easily fail because it didn't +identify an architecture. + +-- + +Check that GDB can handle all BFD architectures (Andrew Cagney) + +There should be a test that checks that BFD/GDB are in sync with +regard to architecture changes. Something like a test that first +queries GDB for all supported architectures and then feeds each back +to GDB.. Anyone interested in learning how to write tests? :-) + +-- This list is probably not up to date, and opinions vary about the importance or even desirability of some of the items. >From dan@cgsoftware.com Tue Mar 28 20:00:00 2000 From: dan@cgsoftware.com (Daniel Berlin+list.gdb-patches) To: Andrew Cagney Cc: GDB Patches Subject: Re: GDB 5 2000-03-29 Date: Tue, 28 Mar 2000 20:00:00 -0000 Message-id: References: <38E17D2C.F7EB65B9@cygnus.com> X-SW-Source: 2000-03/msg00664.html Content-length: 446 > Below is my updated TODO list for GDB 5. I've also attatched the patch > I'm applying to TODO. You can see the gory details in the sources. > > Looking at it. There are four ``must haves'' left. > > For the watchpoint patches, if at least some have been addressed, I'd > like to put the rest off. > > For Solaris/x86, what shape is it in? > > The remainder look like must fix bugs. > > Andrew Maybe it's time to cut a branch then?