* configure.tgt (sparc64-*-solaris2*): New configuration.
[deliverable/binutils-gdb.git] / gdb / NEWS
CommitLineData
95618211
SS
1 What has changed in GDB?
2 (Organized release by release)
3
bf4e0fe7
FF
4*** Changes since GDB-4.15:
5
6* New native configurations
7
972821a3 8Windows 95, Windows NT i[345]86-*-win32
bf4e0fe7 9
972821a3 10* New targets
bf4e0fe7
FF
11
12ARM via RDP protocol arm-*-*
3ae51936
MM
13PowerPC via PPCBUG monitor powerpc{,le}-*-eabi*
14PowerPC simulator powerpc{,le}-*-eabi if building with GCC
bf4e0fe7 15
b3fd4c06
SS
16* Send break instead of ^C
17
18The standard remote protocol now includes an option to send a break
19rather than a ^C to the target in order to interrupt it. By default,
20GDB will send ^C; to send a break, set the variable `remotebreak' to 1.
21
87273c71
JL
22* Automatic tracking of dynamic object loading (HPUX only at the moment).
23
24By default GDB will automatically keep track of objects as they are
25loaded and unloaded by the dynamic linker. By using the command
26"set stop-on-solib-events 1" you can arrange for GDB to stop the
27inferior when shared library events occur, thus allowing you to
28set breakpoints in shared libraries which are explicitly loaded by
29the inferior.
30
31Note this feature does not work on hpux8. On hpux9 you must link
32/usr/lib/end.o into your program. This feature should work automatically
33on hpux10.
34
e8f1ad9a
FF
35* Recording and replaying remote debug sessions
36
37If you set "remotelogfile" gdb will use that filename to make a
38"recording" of a remote debug session which can be replayed back to
39gdb using "gdbreplay". See gdbserver/README for details. This is
40useful when you have a problem with gdb while doing remote debugging.
41By making a recording of the session and sending it to the gdb
42maintainers, it is possible to recreate your problem without access to
43the remote hardware you are using.
44
0764fb04
FF
45*** Changes in GDB-4.15:
46
bf4e0fe7
FF
47* Psymtabs for XCOFF
48
49The symbol reader for AIX GDB now uses partial symbol tables. This
50can greatly improve startup time, especially for large executables.
51
0764fb04
FF
52* Remote targets use caching
53
54Remote targets now use a data cache to speed up communication with the
bf4e0fe7
FF
55remote side. The data cache could lead to incorrect results because
56it doesn't know about volatile variables, thus making it impossible to
57debug targets which use memory mapped I/O devices. `set remotecache
58off' turns the the data cache off.
0764fb04 59
bf4e0fe7 60* Remote targets may have threads
24e60978 61
bf4e0fe7
FF
62The standard remote protocol now includes support for multiple threads
63in the target system, using new protocol commands 'H' and 'T'. See
64gdb/remote.c for details.
24e60978 65
bf4e0fe7 66* NetROM support
24e60978 67
bf4e0fe7
FF
68If GDB is configured with `--enable-netrom', then it will include
69support for the NetROM ROM emulator from XLNT Designs. The NetROM
70acts as though it is a bank of ROM on the target board, but you can
71write into it over the network. GDB's support consists only of
72support for fast loading into the emulated ROM; to debug, you must use
73another protocol, such as standard remote protocol. The usual
74sequence is something like
75
76 target nrom <netrom-hostname>
77 load <prog>
78 target remote <netrom-hostname>:1235
79
80* Macintosh host
81
82GDB now includes support for the Apple Macintosh, as a host only. It
83may be run as either an MPW tool or as a standalone application, and
84it can debug through the serial port. All the usual GDB commands are
85available, but to the target command, you must supply "serial" as the
86device type instead of "/dev/ttyXX". See mpw-README in the main
87directory for more information on how to build. The MPW configuration
88scripts */mpw-config.in support only a few targets, and only the
89mips-idt-ecoff target has been tested.
90
91* Autoconf
92
93GDB configuration now uses autoconf. This is not user-visible,
94but does simplify configuration and building.
95
96* hpux10
97
cd857a2d 98GDB now supports hpux10.
24e60978 99
95618211
SS
100*** Changes in GDB-4.14:
101
102* New native configurations
103
104x86 FreeBSD i[345]86-*-freebsd
105x86 NetBSD i[345]86-*-netbsd
106NS32k NetBSD ns32k-*-netbsd
107Sparc NetBSD sparc-*-netbsd
108
109* New targets
110
111A29K VxWorks a29k-*-vxworks
112HP PA PRO embedded (WinBond W89K & Oki OP50N) hppa*-*-pro*
113CPU32 EST-300 emulator m68*-*-est*
114PowerPC ELF powerpc-*-elf
115WDC 65816 w65-*-*
3ddcdc59 116
2592eef8
PS
117* Alpha OSF/1 support for procfs
118
119GDB now supports procfs under OSF/1-2.x and higher, which makes it
120possible to attach to running processes. As the mounting of the /proc
121filesystem is optional on the Alpha, GDB automatically determines
122the availability of /proc during startup. This can lead to problems
123if /proc is unmounted after GDB has been started.
124
95618211
SS
125* Arguments to user-defined commands
126
127User commands may accept up to 10 arguments separated by whitespace.
128Arguments are accessed within the user command via $arg0..$arg9. A
129trivial example:
0f8cdd9b
JL
130define adder
131 print $arg0 + $arg1 + $arg2
132
133To execute the command use:
134adder 1 2 3
135
136Defines the command "adder" which prints the sum of its three arguments.
137Note the arguments are text substitutions, so they may reference variables,
138use complex expressions, or even perform inferior function calls.
139
95618211
SS
140* New `if' and `while' commands
141
142This makes it possible to write more sophisticated user-defined
143commands. Both commands take a single argument, which is the
144expression to evaluate, and must be followed by the commands to
145execute, one per line, if the expression is nonzero, the list being
146terminated by the word `end'. The `if' command list may include an
147`else' word, which causes the following commands to be executed only
148if the expression is zero.
149
150* Fortran source language mode
151
152GDB now includes partial support for Fortran 77. It will recognize
153Fortran programs and can evaluate a subset of Fortran expressions, but
154variables and functions may not be handled correctly. GDB will work
155with G77, but does not yet know much about symbols emitted by other
156Fortran compilers.
157
158* Better HPUX support
159
160Most debugging facilities now work on dynamic executables for HPPAs
161running hpux9 or later. You can attach to running dynamically linked
162processes, but by default the dynamic libraries will be read-only, so
163for instance you won't be able to put breakpoints in them. To change
164that behavior do the following before running the program:
165
166 adb -w a.out
167 __dld_flags?W 0x5
168 control-d
169
170This will cause the libraries to be mapped private and read-write.
171To revert to the normal behavior, do this:
172
173 adb -w a.out
174 __dld_flags?W 0x4
175 control-d
176
177You cannot set breakpoints or examine data in the library until after
178the library is loaded if the function/data symbols do not have
179external linkage.
180
181GDB can now also read debug symbols produced by the HP C compiler on
182HPPAs (sorry, no C++, Fortran or 68k support).
183
184* Target byte order now dynamically selectable
185
186You can choose which byte order to use with a target system, via the
187commands "set endian big" and "set endian little", and you can see the
188current setting by using "show endian". You can also give the command
189"set endian auto", in which case GDB will use the byte order
190associated with the executable. Currently, only embedded MIPS
191configurations support dynamic selection of target byte order.
7de5c5e2 192
95618211 193* New DOS host serial code
e3581971 194
95618211
SS
195This version uses DPMI interrupts to handle buffered I/O, so you
196no longer need to run asynctsr when debugging boards connected to
197a PC's serial port.
2848f793 198
72e35288
JK
199*** Changes in GDB-4.13:
200
7de5c5e2
FF
201* New "complete" command
202
203This lists all the possible completions for the rest of the line, if it
204were to be given as a command itself. This is intended for use by emacs.
72e35288 205
7de5c5e2
FF
206* Trailing space optional in prompt
207
208"set prompt" no longer adds a space for you after the prompt you set. This
72e35288
JK
209allows you to set a prompt which ends in a space or one that does not.
210
7de5c5e2
FF
211* Breakpoint hit counts
212
213"info break" now displays a count of the number of times the breakpoint
214has been hit. This is especially useful in conjunction with "ignore"; you
215can ignore a large number of breakpoint hits, look at the breakpoint info
216to see how many times the breakpoint was hit, then run again, ignoring one
217less than that number, and this will get you quickly to the last hit of
218that breakpoint.
219
220* Ability to stop printing at NULL character
221
222"set print null-stop" will cause GDB to stop printing the characters of
223an array when the first NULL is encountered. This is useful when large
224arrays actually contain only short strings.
225
226* Shared library breakpoints
227
228In SunOS 4.x, SVR4, and Alpha OSF/1 configurations, you can now set
229breakpoints in shared libraries before the executable is run.
230
231* Hardware watchpoints
232
233There is a new hardware breakpoint for the watch command for sparclite
234targets. See gdb/sparclite/hw_breakpoint.note.
235
236Hardware watchpoints are also now supported under Linux.
237
238* Annotations
239
240Annotations have been added. These are for use with graphical interfaces,
241and are still experimental. Currently only gdba.el uses these.
242
243* Improved Irix 5 support
244
245GDB now works properly with Irix 5.2.
246
247* Improved HPPA support
248
249GDB now works properly with the latest GCC and GAS.
250
251* New native configurations
252
253Sequent PTX4 i[34]86-sequent-ptx4
254HPPA running OSF/1 hppa*-*-osf*
255Atari TT running SVR4 m68*-*-sysv4*
256RS/6000 LynxOS rs6000-*-lynxos*
257
258* New targets
259
260OS/9000 i[34]86-*-os9k
261MIPS R4000 mips64*{,el}-*-{ecoff,elf}
262Sparc64 sparc64-*-*
263
264* Hitachi SH7000 and E7000-PC ICE support
265
266There is now support for communicating with the Hitachi E7000-PC ICE.
267This is available automatically when GDB is configured for the SH.
268
269* Fixes
270
271As usual, a variety of small fixes and improvements, both generic
272and configuration-specific. See the ChangeLog for more detail.
273
4901e77d
FF
274*** Changes in GDB-4.12:
275
276* Irix 5 is now supported
277
278* HPPA support
279
280GDB-4.12 on the HPPA has a number of changes which make it unable
281to debug the output from the currently released versions of GCC and
282GAS (GCC 2.5.8 and GAS-2.2 or PAGAS-1.36). Until the next major release
283of GCC and GAS, versions of these tools designed to work with GDB-4.12
284can be retrieved via anonymous ftp from jaguar.cs.utah.edu:/dist.
285
286
617b4ae8
FF
287*** Changes in GDB-4.11:
288
289* User visible changes:
290
291* Remote Debugging
803f7af5 292
41a6194d 293The "set remotedebug" option is now consistent between the mips remote
803f7af5
JK
294target, remote targets using the gdb-specific protocol, UDI (AMD's
295debug protocol for the 29k) and the 88k bug monitor. It is now an
296integer specifying a debug level (normally 0 or 1, but 2 means more
297debugging info for the mips target).
41a6194d 298
617b4ae8
FF
299* DEC Alpha native support
300
301GDB now works on the DEC Alpha. GCC 2.4.5 does not produce usable
302debug info, but GDB works fairly well with the DEC compiler and should
303work with a future GCC release. See the README file for a few
304Alpha-specific notes.
305
306* Preliminary thread implementation
307
308GDB now has preliminary thread support for both SGI/Irix and LynxOS.
309
310* LynxOS native and target support for 386
311
312This release has been hosted on LynxOS 2.2, and also can be configured
313to remotely debug programs running under LynxOS (see gdb/gdbserver/README
314for details).
315
316* Improvements in C++ mangling/demangling.
317
318This release has much better g++ debugging, specifically in name
319mangling/demangling, virtual function calls, print virtual table,
320call methods, ...etc.
321
41a6194d 322*** Changes in GDB-4.10:
21cc14d8
RP
323
324 * User visible changes:
325
5b336d29 326Remote debugging using the GDB-specific (`target remote') protocol now
be9af13c
JK
327supports the `load' command. This is only useful if you have some
328other way of getting the stub to the target system, and you can put it
329somewhere in memory where it won't get clobbered by the download.
5b336d29 330
a32ebcfd
JK
331Filename completion now works.
332
333When run under emacs mode, the "info line" command now causes the
334arrow to point to the line specified. Also, "info line" prints
be9af13c 335addresses in symbolic form (as well as hex).
a32ebcfd 336
21cc14d8
RP
337All vxworks based targets now support a user settable option, called
338vxworks-timeout. This option represents the number of seconds gdb
339should wait for responses to rpc's. You might want to use this if
340your vxworks target is, perhaps, a slow software simulator or happens
341to be on the far side of a thin network line.
342
ebb962cd
FF
343 * DEC alpha support
344
345This release contains support for using a DEC alpha as a GDB host for
346cross debugging. Native alpha debugging is not supported yet.
347
348
cb46c402
JG
349*** Changes in GDB-4.9:
350
c787ca55
FF
351 * Testsuite
352
353This is the first GDB release which is accompanied by a matching testsuite.
354The testsuite requires installation of dejagnu, which should be available
355via ftp from most sites that carry GNU software.
356
357 * C++ demangling
358
45364c8a 359'Cfront' style demangling has had its name changed to 'ARM' style, to
0a4a0f09
FF
360emphasize that it was written from the specifications in the C++ Annotated
361Reference Manual, not necessarily to be compatible with AT&T cfront. Despite
362disclaimers, it still generated too much confusion with users attempting to
363use gdb with AT&T cfront.
45364c8a 364
c787ca55 365 * Simulators
8ae56378
SC
366
367GDB now uses a standard remote interface to a simulator library.
368So far, the library contains simulators for the Zilog Z8001/2, the
369Hitachi H8/300, H8/500 and Super-H.
370
371 * New targets supported
372
373H8/300 simulator h8300-hitachi-hms or h8300hms
374H8/500 simulator h8500-hitachi-hms or h8500hms
375SH simulator sh-hitachi-hms or sh
376Z8000 simulator z8k-zilog-none or z8ksim
8b946797 377IDT MIPS board over serial line mips-idt-ecoff
8ae56378 378
cb46c402
JG
379Cross-debugging to GO32 targets is supported. It requires a custom
380version of the i386-stub.c module which is integrated with the
0a4a0f09 381GO32 memory extender.
cb46c402 382
0a4a0f09 383 * New remote protocols
cb46c402 384
0a4a0f09 385MIPS remote debugging protocol.
cb46c402 386
0a4a0f09 387 * New source languages supported
cb46c402 388
0a4a0f09
FF
389This version includes preliminary support for Chill, a Pascal like language
390used by telecommunications companies. Chill support is also being integrated
391into the GNU compiler, but we don't know when it will be publically available.
cb46c402 392
cb46c402 393
c5cc95b1
SG
394*** Changes in GDB-4.8:
395
3421ec35 396 * HP Precision Architecture supported
c5cc95b1 397
3421ec35
JG
398GDB now supports HP PA-RISC machines running HPUX. A preliminary
399version of this support was available as a set of patches from the
400University of Utah. GDB does not support debugging of programs
401compiled with the HP compiler, because HP will not document their file
6d0380ee 402format. Instead, you must use GCC (version 2.3.2 or later) and PA-GAS
3421ec35 403(as available from jaguar.cs.utah.edu:/dist/pa-gas.u4.tar.Z).
c5cc95b1 404
3421ec35 405Many problems in the preliminary version have been fixed.
c5cc95b1
SG
406
407 * Faster and better demangling
408
409We have improved template demangling and fixed numerous bugs in the GNU style
410demangler. It can now handle type modifiers such as `static' or `const'. Wide
411character types (wchar_t) are now supported. Demangling of each symbol is now
412only done once, and is cached when the symbol table for a file is read in.
3421ec35
JG
413This results in a small increase in memory usage for C programs, a moderate
414increase in memory usage for C++ programs, and a fantastic speedup in
c5cc95b1
SG
415symbol lookups.
416
417`Cfront' style demangling still doesn't work with AT&T cfront. It was written
418from the specifications in the Annotated Reference Manual, which AT&T's
419compiler does not actually implement.
420
6d0380ee
JG
421 * G++ multiple inheritance compiler problem
422
423In the 2.3.2 release of gcc/g++, how the compiler resolves multiple
424inheritance lattices was reworked to properly discover ambiguities. We
425recently found an example which causes this new algorithm to fail in a
426very subtle way, producing bad debug information for those classes.
427The file 'gcc.patch' (in this directory) can be applied to gcc to
428circumvent the problem. A future GCC release will contain a complete
429fix.
430
431The previous G++ debug info problem (mentioned below for the gdb-4.7
432release) is fixed in gcc version 2.3.2.
433
c5cc95b1
SG
434 * Improved configure script
435
3421ec35
JG
436The `configure' script will now attempt to guess your system type if
437you don't supply a host system type. The old scheme of supplying a
438host system triplet is preferable over using this. All the magic is
439done in the new `config.guess' script. Examine it for details.
c5cc95b1
SG
440
441We have also brought our configure script much more in line with the FSF's
442version. It now supports the --with-xxx options. In particular,
3421ec35
JG
443`--with-minimal-bfd' can be used to make the GDB binary image smaller.
444The resulting GDB will not be able to read arbitrary object file formats --
445only the format ``expected'' to be used on the configured target system.
446We hope to make this the default in a future release.
447
448 * Documentation improvements
449
450There's new internal documentation on how to modify GDB, and how to
451produce clean changes to the code. We implore people to read it
452before submitting changes.
453
454The GDB manual uses new, sexy Texinfo conditionals, rather than arcane
455M4 macros. The new texinfo.tex is provided in this release. Pre-built
456`info' files are also provided. To build `info' files from scratch,
457you will need the latest `makeinfo' release, which will be available in
458a future texinfo-X.Y release.
459
460*NOTE* The new texinfo.tex can cause old versions of TeX to hang.
461We're not sure exactly which versions have this problem, but it has
462been seen in 3.0. We highly recommend upgrading to TeX version 3.141
463or better. If that isn't possible, there is a patch in
464`texinfo/tex3patch' that will modify `texinfo/texinfo.tex' to work
465around this problem.
c5cc95b1 466
3421ec35 467 * New features
c5cc95b1 468
3421ec35
JG
469GDB now supports array constants that can be used in expressions typed in by
470the user. The syntax is `{element, element, ...}'. Ie: you can now type
471`print {1, 2, 3}', and it will build up an array in memory malloc'd in
472the target program.
c5cc95b1 473
3421ec35
JG
474The new directory `gdb/sparclite' contains a program that demonstrates
475how the sparc-stub.c remote stub runs on a Fujitsu SPARClite processor.
c5cc95b1
SG
476
477 * New native hosts supported
478
479HP/PA-RISC under HPUX using GNU tools hppa1.1-hp-hpux
c5cc95b1
SG
480386 CPUs running SCO Unix 3.2v4 i386-unknown-sco3.2v4
481
482 * New targets supported
483
484AMD 29k family via UDI a29k-amd-udi or udi29k
485
486 * New file formats supported
487
3421ec35
JG
488BFD now supports reading HP/PA-RISC executables (SOM file format?),
489HPUX core files, and SCO 3.2v2 core files.
490
491 * Major bug fixes
492
493Attaching to processes now works again; thanks for the many bug reports.
494
495We have also stomped on a bunch of core dumps caused by
496printf_filtered("%s") problems.
497
498We eliminated a copyright problem on the rpc and ptrace header files
499for VxWorks, which was discovered at the last minute during the 4.7
500release. You should now be able to build a VxWorks GDB.
501
502You can now interrupt gdb while an attached process is running. This
503will cause the attached process to stop, and give control back to GDB.
504
505We fixed problems caused by using too many file descriptors
506for reading symbols from object files and libraries. This was
507especially a problem for programs that used many (~100) shared
508libraries.
c5cc95b1 509
3421ec35
JG
510The `step' command now only enters a subroutine if there is line number
511information for the subroutine. Otherwise it acts like the `next'
512command. Previously, `step' would enter subroutines if there was
513any debugging information about the routine. This avoids problems
514when using `cc -g1' on MIPS machines.
515
516 * Internal improvements
517
518GDB's internal interfaces have been improved to make it easier to support
519debugging of multiple languages in the future.
520
521GDB now uses a common structure for symbol information internally.
522Minimal symbols (derived from linkage symbols in object files), partial
523symbols (from a quick scan of debug information), and full symbols
524contain a common subset of information, making it easier to write
525shared code that handles any of them.
526
527 * New command line options
c5cc95b1
SG
528
529We now accept --silent as an alias for --quiet.
530
3421ec35 531 * Mmalloc licensing
c5cc95b1 532
3421ec35
JG
533The memory-mapped-malloc library is now licensed under the GNU Library
534General Public License.
c5cc95b1 535
76ba9b5b
SG
536*** Changes in GDB-4.7:
537
c00d8242
JG
538 * Host/native/target split
539
540GDB has had some major internal surgery to untangle the support for
541hosts and remote targets. Now, when you configure GDB for a remote
542target, it will no longer load in all of the support for debugging
543local programs on the host. When fully completed and tested, this will
544ensure that arbitrary host/target combinations are possible.
545
546The primary conceptual shift is to separate the non-portable code in
547GDB into three categories. Host specific code is required any time GDB
548is compiled on that host, regardless of the target. Target specific
549code relates to the peculiarities of the target, but can be compiled on
550any host. Native specific code is everything else: it can only be
551built when the host and target are the same system. Child process
552handling and core file support are two common `native' examples.
553
554GDB's use of /proc for controlling Unix child processes is now cleaner.
555It has been split out into a single module under the `target_ops' vector,
556plus two native-dependent functions for each system that uses /proc.
557
558 * New hosts supported
559
560HP/Apollo 68k (under the BSD domain) m68k-apollo-bsd or apollo68bsd
561386 CPUs running various BSD ports i386-unknown-bsd or 386bsd
562386 CPUs running SCO Unix i386-unknown-scosysv322 or i386sco
563
564 * New targets supported
76ba9b5b 565
c00d8242
JG
566Fujitsu SPARClite sparclite-fujitsu-none or sparclite
56768030 and CPU32 m68030-*-*, m68332-*-*
5f5be54c 568
c00d8242 569 * New native hosts supported
5f5be54c 570
c00d8242
JG
571386 CPUs running various BSD ports i386-unknown-bsd or 386bsd
572 (386bsd is not well tested yet)
573386 CPUs running SCO Unix i386-unknown-scosysv322 or sco
5f5be54c 574
c00d8242 575 * New file formats supported
5f5be54c 576
c00d8242
JG
577BFD now supports COFF files for the Zilog Z8000 microprocessor. It
578supports reading of `a.out.adobe' object files, which are an a.out
579format extended with minimal information about multiple sections.
5f5be54c 580
c00d8242 581 * New commands
5f5be54c 582
c00d8242
JG
583`show copying' is the same as the old `info copying'.
584`show warranty' is the same as `info warrantee'.
585These were renamed for consistency. The old commands continue to work.
5f5be54c 586
c00d8242 587`info handle' is a new alias for `info signals'.
5f5be54c 588
c00d8242
JG
589You can now define pre-command hooks, which attach arbitrary command
590scripts to any command. The commands in the hook will be executed
591prior to the user's command. You can also create a hook which will be
592executed whenever the program stops. See gdb.texinfo.
593
594 * C++ improvements
595
596We now deal with Cfront style name mangling, and can even extract type
597info from mangled symbols. GDB can automatically figure out which
598symbol mangling style your C++ compiler uses.
599
600Calling of methods and virtual functions has been improved as well.
5f5be54c
SG
601
602 * Major bug fixes
603
c00d8242
JG
604The crash that occured when debugging Sun Ansi-C compiled binaries is
605fixed. This was due to mishandling of the extra N_SO stabs output
606by the compiler.
5f5be54c 607
c00d8242
JG
608We also finally got Ultrix 4.2 running in house, and fixed core file
609support, with help from a dozen people on the net.
610
611John M. Farrell discovered that the reason that single-stepping was so
612slow on all of the Mips based platforms (primarily SGI and DEC) was
613that we were trying to demangle and lookup a symbol used for internal
614purposes on every instruction that was being stepped through. Changing
615the name of that symbol so that it couldn't be mistaken for a C++
616mangled symbol sped things up a great deal.
617
618Rich Pixley sped up symbol lookups in general by getting much smarter
619about when C++ symbol mangling is necessary. This should make symbol
620completion (TAB on the command line) much faster. It's not as fast as
621we'd like, but it's significantly faster than gdb-4.6.
622
623 * AMD 29k support
5f5be54c 624
c00d8242
JG
625A new user controllable variable 'call_scratch_address' can
626specify the location of a scratch area to be used when GDB
627calls a function in the target. This is necessary because the
628usual method of putting the scratch area on the stack does not work
629in systems that have separate instruction and data spaces.
630
631We integrated changes to support the 29k UDI (Universal Debugger
632Interface), but discovered at the last minute that we didn't have all
633of the appropriate copyright paperwork. We are working with AMD to
634resolve this, and hope to have it available soon.
635
636 * Remote interfaces
637
638We have sped up the remote serial line protocol, especially for targets
639with lots of registers. It now supports a new `expedited status' ('T')
640message which can be used in place of the existing 'S' status message.
641This allows the remote stub to send only the registers that GDB
642needs to make a quick decision about single-stepping or conditional
643breakpoints, eliminating the need to fetch the entire register set for
644each instruction being stepped through.
645
646The GDB remote serial protocol now implements a write-through cache for
647registers, only re-reading the registers if the target has run.
648
649There is also a new remote serial stub for SPARC processors. You can
650find it in gdb-4.7/gdb/sparc-stub.c. This was written to support the
651Fujitsu SPARClite processor, but will run on any stand-alone SPARC
652processor with a serial port.
653
654 * Configuration
655
656Configure.in files have become much easier to read and modify. A new
657`table driven' format makes it more obvious what configurations are
658supported, and what files each one uses.
659
660 * Library changes
661
662There is a new opcodes library which will eventually contain all of the
663disassembly routines and opcode tables. At present, it only contains
664Sparc and Z8000 routines. This will allow the assembler, debugger, and
665disassembler (binutils/objdump) to share these routines.
666
667The libiberty library is now copylefted under the GNU Library General
668Public License. This allows more liberal use, and was done so libg++
669can use it. This makes no difference to GDB, since the Library License
670grants all the rights from the General Public License.
671
672 * Documentation
673
674The file gdb-4.7/gdb/doc/stabs.texinfo is a (relatively) complete
675reference to the stabs symbol info used by the debugger. It is (as far
676as we know) the only published document on this fascinating topic. We
677encourage you to read it, compare it to the stabs information on your
678system, and send improvements on the document in general (to
679bug-gdb@prep.ai.mit.edu).
5f5be54c
SG
680
681And, of course, many bugs have been fixed.
76ba9b5b 682
c00d8242 683
3ddcdc59
SG
684*** Changes in GDB-4.6:
685
686 * Better support for C++ function names
687
688GDB now accepts as input the "demangled form" of C++ overloaded function
689names and member function names, and can do command completion on such names
690(using TAB, TAB-TAB, and ESC-?). The names have to be quoted with a pair of
691single quotes. Examples are 'func (int, long)' and 'obj::operator==(obj&)'.
692Make use of command completion, it is your friend.
693
694GDB also now accepts a variety of C++ mangled symbol formats. They are
695the GNU g++ style, the Cfront (ARM) style, and the Lucid (lcc) style.
696You can tell GDB which format to use by doing a 'set demangle-style {gnu,
697lucid, cfront, auto}'. 'gnu' is the default. Do a 'set demangle-style foo'
698for the list of formats.
699
700 * G++ symbol mangling problem
701
702Recent versions of gcc have a bug in how they emit debugging information for
703C++ methods (when using dbx-style stabs). The file 'gcc.patch' (in this
704directory) can be applied to gcc to fix the problem. Alternatively, if you
705can't fix gcc, you can #define GCC_MANGLE_BUG when compling gdb/symtab.c. The
706usual symptom is difficulty with setting breakpoints on methods. GDB complains
707about the method being non-existent. (We believe that version 2.2.2 of GCC has
708this problem.)
709
710 * New 'maintenance' command
711
712All of the commands related to hacking GDB internals have been moved out of
713the main command set, and now live behind the 'maintenance' command. This
714can also be abbreviated as 'mt'. The following changes were made:
715
716 dump-me -> maintenance dump-me
717 info all-breakpoints -> maintenance info breakpoints
718 printmsyms -> maintenance print msyms
719 printobjfiles -> maintenance print objfiles
720 printpsyms -> maintenance print psymbols
721 printsyms -> maintenance print symbols
722
723The following commands are new:
724
725 maintenance demangle Call internal GDB demangler routine to
726 demangle a C++ link name and prints the result.
727 maintenance print type Print a type chain for a given symbol
728
729 * Change to .gdbinit file processing
730
731We now read the $HOME/.gdbinit file before processing the argv arguments
732(e.g. reading symbol files or core files). This allows global parameters to
733be set, which will apply during the symbol reading. The ./.gdbinit is still
734read after argv processing.
735
736 * New hosts supported
737
738Solaris-2.0 !!! sparc-sun-solaris2 or sun4sol2
739
740Linux support i386-unknown-linux or linux
741
742We are also including code to support the HP/PA running BSD and HPUX. This
743is almost guaranteed not to work, as we didn't have time to test or build it
744for this release. We are including it so that the more adventurous (or
745masochistic) of you can play with it. We also had major problems with the
746fact that the compiler that we got from HP doesn't support the -g option.
747It costs extra.
748
749 * New targets supported
750
751Hitachi H8/300 h8300-hitachi-hms or h8300hms
752
753 * More smarts about finding #include files
754
755GDB now remembers the compilation directory for all include files, and for
756all files from which C is generated (like yacc and lex sources). This
757greatly improves GDB's ability to find yacc/lex sources, and include files,
758especially if you are debugging your program from a directory different from
759the one that contains your sources.
760
761We also fixed a bug which caused difficulty with listing and setting
762breakpoints in include files which contain C code. (In the past, you had to
763try twice in order to list an include file that you hadn't looked at before.)
764
765 * Interesting infernals change
766
767GDB now deals with arbitrary numbers of sections, where the symbols for each
768section must be relocated relative to that section's landing place in the
769target's address space. This work was needed to support ELF with embedded
770stabs used by Solaris-2.0.
771
772 * Bug fixes (of course!)
773
774There have been loads of fixes for the following things:
775 mips, rs6000, 29k/udi, m68k, g++, type handling, elf/dwarf, m88k,
776 i960, stabs, DOS(GO32), procfs, etc...
777
778See the ChangeLog for details.
779
780*** Changes in GDB-4.5:
781
782 * New machines supported (host and target)
783
784IBM RS6000 running AIX rs6000-ibm-aix or rs6000
785
786SGI Irix-4.x mips-sgi-irix4 or iris4
787
788 * New malloc package
789
790GDB now uses a new memory manager called mmalloc, based on gmalloc.
791Mmalloc is capable of handling mutiple heaps of memory. It is also
792capable of saving a heap to a file, and then mapping it back in later.
793This can be used to greatly speedup the startup of GDB by using a
794pre-parsed symbol table which lives in a mmalloc managed heap. For
795more details, please read mmalloc/mmalloc.texi.
796
797 * info proc
798
799The 'info proc' command (SVR4 only) has been enhanced quite a bit. See
800'help info proc' for details.
801
802 * MIPS ecoff symbol table format
803
804The code that reads MIPS symbol table format is now supported on all hosts.
805Thanks to MIPS for releasing the sym.h and symconst.h files to make this
806possible.
807
808 * File name changes for MS-DOS
809
810Many files in the config directories have been renamed to make it easier to
811support GDB on MS-DOSe systems (which have very restrictive file name
812conventions :-( ). MS-DOSe host support (under DJ Delorie's GO32
813environment) is close to working but has some remaining problems. Note
814that debugging of DOS programs is not supported, due to limitations
815in the ``operating system'', but it can be used to host cross-debugging.
816
817 * Cross byte order fixes
818
819Many fixes have been made to support cross debugging of Sparc and MIPS
820targets from hosts whose byte order differs.
821
822 * New -mapped and -readnow options
823
824If memory-mapped files are available on your system through the 'mmap'
825system call, you can use the -mapped option on the `file' or
826`symbol-file' commands to cause GDB to write the symbols from your
827program into a reusable file. If the program you are debugging is
828called `/path/fred', the mapped symbol file will be `./fred.syms'.
829Future GDB debugging sessions will notice the presence of this file,
830and will quickly map in symbol information from it, rather than reading
831the symbol table from the executable program. Using the '-mapped'
832option in a GDB `file' or `symbol-file' command has the same effect as
833starting GDB with the '-mapped' command-line option.
834
835You can cause GDB to read the entire symbol table immediately by using
836the '-readnow' option with any of the commands that load symbol table
837information (or on the GDB command line). This makes the command
838slower, but makes future operations faster.
839
840The -mapped and -readnow options are typically combined in order to
841build a `fred.syms' file that contains complete symbol information.
842A simple GDB invocation to do nothing but build a `.syms' file for future
843use is:
844
845 gdb -batch -nx -mapped -readnow programname
846
847The `.syms' file is specific to the host machine on which GDB is run.
848It holds an exact image of GDB's internal symbol table. It cannot be
849shared across multiple host platforms.
850
851 * longjmp() handling
852
853GDB is now capable of stepping and nexting over longjmp(), _longjmp(), and
854siglongjmp() without losing control. This feature has not yet been ported to
855all systems. It currently works on many 386 platforms, all MIPS-based
856platforms (SGI, DECstation, etc), and Sun3/4.
857
858 * Solaris 2.0
859
860Preliminary work has been put in to support the new Solaris OS from Sun. At
861this time, it can control and debug processes, but it is not capable of
862reading symbols.
863
864 * Bug fixes
865
866As always, many many bug fixes. The major areas were with g++, and mipsread.
867People using the MIPS-based platforms should experience fewer mysterious
868crashes and trashed symbol tables.
869
870*** Changes in GDB-4.4:
871
872 * New machines supported (host and target)
873
874SCO Unix on i386 IBM PC clones i386-sco-sysv or i386sco
875 (except core files)
876BSD Reno on Vax vax-dec-bsd
877Ultrix on Vax vax-dec-ultrix
878
879 * New machines supported (target)
880
881AMD 29000 embedded, using EBMON a29k-none-none
882
883 * C++ support
884
885GDB continues to improve its handling of C++. `References' work better.
886The demangler has also been improved, and now deals with symbols mangled as
887per the Annotated C++ Reference Guide.
888
889GDB also now handles `stabs' symbol information embedded in MIPS
890`ecoff' symbol tables. Since the ecoff format was not easily
891extensible to handle new languages such as C++, this appeared to be a
892good way to put C++ debugging info into MIPS binaries. This option
893will be supported in the GNU C compiler, version 2, when it is
894released.
895
896 * New features for SVR4
897
898GDB now handles SVR4 shared libraries, in the same fashion as SunOS
899shared libraries. Debugging dynamically linked programs should present
900only minor differences from debugging statically linked programs.
901
902The `info proc' command will print out information about any process
903on an SVR4 system (including the one you are debugging). At the moment,
904it prints the address mappings of the process.
905
906If you bring up GDB on another SVR4 system, please send mail to
907bug-gdb@prep.ai.mit.edu to let us know what changes were reqired (if any).
908
909 * Better dynamic linking support in SunOS
910
911Reading symbols from shared libraries which contain debugging symbols
912now works properly. However, there remain issues such as automatic
913skipping of `transfer vector' code during function calls, which
914make it harder to debug code in a shared library, than to debug the
915same code linked statically.
916
917 * New Getopt
918
919GDB is now using the latest `getopt' routines from the FSF. This
920version accepts the -- prefix for options with long names. GDB will
921continue to accept the old forms (-option and +option) as well.
922Various single letter abbreviations for options have been explicity
923added to the option table so that they won't get overshadowed in the
924future by other options that begin with the same letter.
925
926 * Bugs fixed
927
928The `cleanup_undefined_types' bug that many of you noticed has been squashed.
929Many assorted bugs have been handled. Many more remain to be handled.
930See the various ChangeLog files (primarily in gdb and bfd) for details.
931
932
933*** Changes in GDB-4.3:
934
935 * New machines supported (host and target)
936
937Amiga 3000 running Amix m68k-cbm-svr4 or amix
938NCR 3000 386 running SVR4 i386-ncr-svr4 or ncr3000
939Motorola Delta 88000 running Sys V m88k-motorola-sysv or delta88
940
941 * Almost SCO Unix support
942
943We had hoped to support:
944SCO Unix on i386 IBM PC clones i386-sco-sysv or i386sco
945(except for core file support), but we discovered very late in the release
946that it has problems with process groups that render gdb unusable. Sorry
947about that. I encourage people to fix it and post the fixes.
948
949 * Preliminary ELF and DWARF support
950
951GDB can read ELF object files on System V Release 4, and can handle
952debugging records for C, in DWARF format, in ELF files. This support
953is preliminary. If you bring up GDB on another SVR4 system, please
954send mail to bug-gdb@prep.ai.mit.edu to let us know what changes were
955reqired (if any).
956
957 * New Readline
958
959GDB now uses the latest `readline' library. One user-visible change
960is that two tabs will list possible command completions, which previously
961required typing M-? (meta-question mark, or ESC ?).
962
963 * Bugs fixed
964
965The `stepi' bug that many of you noticed has been squashed.
966Many bugs in C++ have been handled. Many more remain to be handled.
967See the various ChangeLog files (primarily in gdb and bfd) for details.
968
969 * State of the MIPS world (in case you wondered):
970
971GDB can understand the symbol tables emitted by the compilers
972supplied by most vendors of MIPS-based machines, including DEC. These
973symbol tables are in a format that essentially nobody else uses.
974
975Some versions of gcc come with an assembler post-processor called
976mips-tfile. This program is required if you want to do source-level
977debugging of gcc-compiled programs. I believe FSF does not ship
978mips-tfile with gcc version 1, but it will eventually come with gcc
979version 2.
980
981Debugging of g++ output remains a problem. g++ version 1.xx does not
982really support it at all. (If you're lucky, you should be able to get
983line numbers and stack traces to work, but no parameters or local
984variables.) With some work it should be possible to improve the
985situation somewhat.
986
987When gcc version 2 is released, you will have somewhat better luck.
988However, even then you will get confusing results for inheritance and
989methods.
990
991We will eventually provide full debugging of g++ output on
992DECstations. This will probably involve some kind of stabs-in-ecoff
993encapulation, but the details have not been worked out yet.
994
995
996*** Changes in GDB-4.2:
997
998 * Improved configuration
999
1000Only one copy of `configure' exists now, and it is not self-modifying.
1001Porting BFD is simpler.
1002
1003 * Stepping improved
1004
1005The `step' and `next' commands now only stop at the first instruction
1006of a source line. This prevents the multiple stops that used to occur
1007in switch statements, for-loops, etc. `Step' continues to stop if a
1008function that has debugging information is called within the line.
1009
1010 * Bug fixing
1011
1012Lots of small bugs fixed. More remain.
1013
1014 * New host supported (not target)
1015
1016Intel 386 PC clone running Mach i386-none-mach
1017
1018
1019*** Changes in GDB-4.1:
1020
1021 * Multiple source language support
1022
1023GDB now has internal scaffolding to handle several source languages.
1024It determines the type of each source file from its filename extension,
1025and will switch expression parsing and number formatting to match the
1026language of the function in the currently selected stack frame.
1027You can also specifically set the language to be used, with
1028`set language c' or `set language modula-2'.
1029
1030 * GDB and Modula-2
1031
1032GDB now has preliminary support for the GNU Modula-2 compiler,
1033currently under development at the State University of New York at
1034Buffalo. Development of both GDB and the GNU Modula-2 compiler will
1035continue through the fall of 1991 and into 1992.
1036
1037Other Modula-2 compilers are currently not supported, and attempting to
1038debug programs compiled with them will likely result in an error as the
1039symbol table is read. Feel free to work on it, though!
1040
1041There are hooks in GDB for strict type checking and range checking,
1042in the `Modula-2 philosophy', but they do not currently work.
1043
1044 * set write on/off
1045
1046GDB can now write to executable and core files (e.g. patch
1047a variable's value). You must turn this switch on, specify
1048the file ("exec foo" or "core foo"), *then* modify it, e.g.
1049by assigning a new value to a variable. Modifications take
1050effect immediately.
1051
1052 * Automatic SunOS shared library reading
1053
1054When you run your program, GDB automatically determines where its
1055shared libraries (if any) have been loaded, and reads their symbols.
1056The `share' command is no longer needed. This also works when
1057examining core files.
1058
1059 * set listsize
1060
1061You can specify the number of lines that the `list' command shows.
1062The default is 10.
1063
1064 * New machines supported (host and target)
1065
1066SGI Iris (MIPS) running Irix V3: mips-sgi-irix or iris
1067Sony NEWS (68K) running NEWSOS 3.x: m68k-sony-sysv or news
1068Ultracomputer (29K) running Sym1: a29k-nyu-sym1 or ultra3
1069
1070 * New hosts supported (not targets)
1071
1072IBM RT/PC: romp-ibm-aix or rtpc
1073
1074 * New targets supported (not hosts)
1075
1076AMD 29000 embedded with COFF a29k-none-coff
1077AMD 29000 embedded with a.out a29k-none-aout
1078Ultracomputer remote kernel debug a29k-nyu-kern
1079
1080 * New remote interfaces
1081
1082AMD 29000 Adapt
1083AMD 29000 Minimon
1084
1085
1086*** Changes in GDB-4.0:
1087
1088 * New Facilities
1089
1090Wide output is wrapped at good places to make the output more readable.
1091
1092Gdb now supports cross-debugging from a host machine of one type to a
1093target machine of another type. Communication with the target system
1094is over serial lines. The ``target'' command handles connecting to the
1095remote system; the ``load'' command will download a program into the
1096remote system. Serial stubs for the m68k and i386 are provided. Gdb
1097also supports debugging of realtime processes running under VxWorks,
1098using SunRPC Remote Procedure Calls over TCP/IP to talk to a debugger
1099stub on the target system.
1100
1101New CPUs supported include the AMD 29000 and Intel 960.
1102
1103GDB now reads object files and symbol tables via a ``binary file''
1104library, which allows a single copy of GDB to debug programs of multiple
1105object file types such as a.out and coff.
1106
1107There is now a GDB reference card in "doc/refcard.tex". (Make targets
1108refcard.dvi and refcard.ps are available to format it).
1109
1110
1111 * Control-Variable user interface simplified
1112
1113All variables that control the operation of the debugger can be set
1114by the ``set'' command, and displayed by the ``show'' command.
1115
1116For example, ``set prompt new-gdb=>'' will change your prompt to new-gdb=>.
1117``Show prompt'' produces the response:
1118Gdb's prompt is new-gdb=>.
1119
1120What follows are the NEW set commands. The command ``help set'' will
1121print a complete list of old and new set commands. ``help set FOO''
1122will give a longer description of the variable FOO. ``show'' will show
1123all of the variable descriptions and their current settings.
1124
1125confirm on/off: Enables warning questions for operations that are
1126 hard to recover from, e.g. rerunning the program while
1127 it is already running. Default is ON.
1128
1129editing on/off: Enables EMACS style command line editing
1130 of input. Previous lines can be recalled with
1131 control-P, the current line can be edited with control-B,
1132 you can search for commands with control-R, etc.
1133 Default is ON.
1134
1135history filename NAME: NAME is where the gdb command history
1136 will be stored. The default is .gdb_history,
1137 or the value of the environment variable
1138 GDBHISTFILE.
1139
1140history size N: The size, in commands, of the command history. The
1141 default is 256, or the value of the environment variable
1142 HISTSIZE.
1143
1144history save on/off: If this value is set to ON, the history file will
1145 be saved after exiting gdb. If set to OFF, the
1146 file will not be saved. The default is OFF.
1147
1148history expansion on/off: If this value is set to ON, then csh-like
1149 history expansion will be performed on
1150 command line input. The default is OFF.
1151
1152radix N: Sets the default radix for input and output. It can be set
1153 to 8, 10, or 16. Note that the argument to "radix" is interpreted
1154 in the current radix, so "set radix 10" is always a no-op.
1155
1156height N: This integer value is the number of lines on a page. Default
1157 is 24, the current `stty rows'' setting, or the ``li#''
1158 setting from the termcap entry matching the environment
1159 variable TERM.
1160
1161width N: This integer value is the number of characters on a line.
1162 Default is 80, the current `stty cols'' setting, or the ``co#''
1163 setting from the termcap entry matching the environment
1164 variable TERM.
1165
1166Note: ``set screensize'' is obsolete. Use ``set height'' and
1167``set width'' instead.
1168
1169print address on/off: Print memory addresses in various command displays,
1170 such as stack traces and structure values. Gdb looks
1171 more ``symbolic'' if you turn this off; it looks more
1172 ``machine level'' with it on. Default is ON.
1173
1174print array on/off: Prettyprint arrays. New convenient format! Default
1175 is OFF.
1176
1177print demangle on/off: Print C++ symbols in "source" form if on,
1178 "raw" form if off.
1179
1180print asm-demangle on/off: Same, for assembler level printouts
1181 like instructions.
1182
1183print vtbl on/off: Prettyprint C++ virtual function tables. Default is OFF.
1184
1185
1186 * Support for Epoch Environment.
1187
1188The epoch environment is a version of Emacs v18 with windowing. One
1189new command, ``inspect'', is identical to ``print'', except that if you
1190are running in the epoch environment, the value is printed in its own
1191window.
1192
1193
1194 * Support for Shared Libraries
1195
1196GDB can now debug programs and core files that use SunOS shared libraries.
1197Symbols from a shared library cannot be referenced
1198before the shared library has been linked with the program (this
1199happens after you type ``run'' and before the function main() is entered).
1200At any time after this linking (including when examining core files
1201from dynamically linked programs), gdb reads the symbols from each
1202shared library when you type the ``sharedlibrary'' command.
1203It can be abbreviated ``share''.
1204
1205sharedlibrary REGEXP: Load shared object library symbols for files
1206 matching a unix regular expression. No argument
1207 indicates to load symbols for all shared libraries.
1208
1209info sharedlibrary: Status of loaded shared libraries.
1210
1211
1212 * Watchpoints
1213
1214A watchpoint stops execution of a program whenever the value of an
1215expression changes. Checking for this slows down execution
1216tremendously whenever you are in the scope of the expression, but is
1217quite useful for catching tough ``bit-spreader'' or pointer misuse
1218problems. Some machines such as the 386 have hardware for doing this
1219more quickly, and future versions of gdb will use this hardware.
1220
1221watch EXP: Set a watchpoint (breakpoint) for an expression.
1222
1223info watchpoints: Information about your watchpoints.
1224
1225delete N: Deletes watchpoint number N (same as breakpoints).
1226disable N: Temporarily turns off watchpoint number N (same as breakpoints).
1227enable N: Re-enables watchpoint number N (same as breakpoints).
1228
1229
1230 * C++ multiple inheritance
1231
1232When used with a GCC version 2 compiler, GDB supports multiple inheritance
1233for C++ programs.
1234
1235 * C++ exception handling
1236
1237Gdb now supports limited C++ exception handling. Besides the existing
1238ability to breakpoint on an exception handler, gdb can breakpoint on
1239the raising of an exception (before the stack is peeled back to the
1240handler's context).
1241
1242catch FOO: If there is a FOO exception handler in the dynamic scope,
1243 set a breakpoint to catch exceptions which may be raised there.
1244 Multiple exceptions (``catch foo bar baz'') may be caught.
1245
1246info catch: Lists all exceptions which may be caught in the
1247 current stack frame.
1248
1249
1250 * Minor command changes
1251
1252The command ``call func (arg, arg, ...)'' now acts like the print
1253command, except it does not print or save a value if the function's result
1254is void. This is similar to dbx usage.
1255
1256The ``up'' and ``down'' commands now always print the frame they end up
1257at; ``up-silently'' and `down-silently'' can be used in scripts to change
1258frames without printing.
1259
1260 * New directory command
1261
1262'dir' now adds directories to the FRONT of the source search path.
1263The path starts off empty. Source files that contain debug information
1264about the directory in which they were compiled can be found even
1265with an empty path; Sun CC and GCC include this information. If GDB can't
1266find your source file in the current directory, type "dir .".
1267
1268 * Configuring GDB for compilation
1269
1270For normal use, type ``./configure host''. See README or gdb.texinfo
1271for more details.
1272
1273GDB now handles cross debugging. If you are remotely debugging between
1274two different machines, type ``./configure host -target=targ''.
1275Host is the machine where GDB will run; targ is the machine
1276where the program that you are debugging will run.
This page took 0.204159 seconds and 4 git commands to generate.