1 This is gdbint.info, produced by makeinfo version 4.13 from 2 /tmp/android-15472/src/build/../gdb/gdb-7.3.x/gdb/doc/gdbint.texinfo. 3 4 INFO-DIR-SECTION Software development 5 START-INFO-DIR-ENTRY 6 * Gdb-Internals: (gdbint). The GNU debugger's internals. 7 END-INFO-DIR-ENTRY 8 9 Copyright (C) 1990, 1991, 1992, 1993, 1994, 1996, 1998, 1999, 2000, 10 2001, 2002, 2003, 2004, 2005, 2006, 2008, 2009, 2010, 2011 Free 11 Software Foundation, Inc. Contributed by Cygnus Solutions. Written by 12 John Gilmore. Second Edition by Stan Shebs. 13 14 Permission is granted to copy, distribute and/or modify this document 15 under the terms of the GNU Free Documentation License, Version 1.3 or 16 any later version published by the Free Software Foundation; with no 17 Invariant Sections, with no Front-Cover Texts, and with no Back-Cover 18 Texts. A copy of the license is included in the section entitled "GNU 19 Free Documentation License". 20 21 This file documents the internals of the GNU debugger GDB. 22 23 Copyright (C) 1990, 1991, 1992, 1993, 1994, 1996, 1998, 1999, 2000, 24 2001, 2002, 2003, 2004, 2005, 2006, 2008, 2009, 2010, 2011 Free 25 Software Foundation, Inc. Contributed by Cygnus Solutions. Written by 26 John Gilmore. Second Edition by Stan Shebs. 27 28 Permission is granted to copy, distribute and/or modify this document 29 under the terms of the GNU Free Documentation License, Version 1.3 or 30 any later version published by the Free Software Foundation; with no 31 Invariant Sections, with no Front-Cover Texts, and with no Back-Cover 32 Texts. A copy of the license is included in the section entitled "GNU 33 Free Documentation License". 34 35 36 File: gdbint.info, Node: Top, Next: Summary, Up: (dir) 37 38 Scope of this Document 39 ********************** 40 41 This document documents the internals of the GNU debugger, GDB. It 42 includes description of GDB's key algorithms and operations, as well as 43 the mechanisms that adapt GDB to specific hosts and targets. 44 45 * Menu: 46 47 * Summary:: 48 * Overall Structure:: 49 * Algorithms:: 50 * User Interface:: 51 * libgdb:: 52 * Values:: 53 * Stack Frames:: 54 * Symbol Handling:: 55 * Language Support:: 56 * Host Definition:: 57 * Target Architecture Definition:: 58 * Target Descriptions:: 59 * Target Vector Definition:: 60 * Native Debugging:: 61 * Support Libraries:: 62 * Coding Standards:: 63 * Misc Guidelines:: 64 * Porting GDB:: 65 * Versions and Branches:: 66 * Start of New Year Procedure:: 67 * Releasing GDB:: 68 * Testsuite:: 69 * Hints:: 70 71 * GDB Observers:: GDB Currently available observers 72 * GNU Free Documentation License:: The license for this documentation 73 * Index:: 74 75 76 File: gdbint.info, Node: Summary, Next: Overall Structure, Prev: Top, Up: Top 77 78 1 Summary 79 ********* 80 81 * Menu: 82 83 * Requirements:: 84 * Contributors:: 85 86 87 File: gdbint.info, Node: Requirements, Next: Contributors, Up: Summary 88 89 1.1 Requirements 90 ================ 91 92 Before diving into the internals, you should understand the formal 93 requirements and other expectations for GDB. Although some of these 94 may seem obvious, there have been proposals for GDB that have run 95 counter to these requirements. 96 97 First of all, GDB is a debugger. It's not designed to be a front 98 panel for embedded systems. It's not a text editor. It's not a shell. 99 It's not a programming environment. 100 101 GDB is an interactive tool. Although a batch mode is available, 102 GDB's primary role is to interact with a human programmer. 103 104 GDB should be responsive to the user. A programmer hot on the trail 105 of a nasty bug, and operating under a looming deadline, is going to be 106 very impatient of everything, including the response time to debugger 107 commands. 108 109 GDB should be relatively permissive, such as for expressions. While 110 the compiler should be picky (or have the option to be made picky), 111 since source code lives for a long time usually, the programmer doing 112 debugging shouldn't be spending time figuring out to mollify the 113 debugger. 114 115 GDB will be called upon to deal with really large programs. 116 Executable sizes of 50 to 100 megabytes occur regularly, and we've 117 heard reports of programs approaching 1 gigabyte in size. 118 119 GDB should be able to run everywhere. No other debugger is 120 available for even half as many configurations as GDB supports. 121 122 123 File: gdbint.info, Node: Contributors, Prev: Requirements, Up: Summary 124 125 1.2 Contributors 126 ================ 127 128 The first edition of this document was written by John Gilmore of 129 Cygnus Solutions. The current second edition was written by Stan Shebs 130 of Cygnus Solutions, who continues to update the manual. 131 132 Over the years, many others have made additions and changes to this 133 document. This section attempts to record the significant contributors 134 to that effort. One of the virtues of free software is that everyone is 135 free to contribute to it; with regret, we cannot actually acknowledge 136 everyone here. 137 138 _Plea:_ This section has only been added relatively recently (four 139 years after publication of the second edition). Additions to this 140 section are particularly welcome. If you or your friends (or 141 enemies, to be evenhanded) have been unfairly omitted from this 142 list, we would like to add your names! 143 144 A document such as this relies on being kept up to date by numerous 145 small updates by contributing engineers as they make changes to the 146 code base. The file `ChangeLog' in the GDB distribution approximates a 147 blow-by-blow account. The most prolific contributors to this important, 148 but low profile task are Andrew Cagney (responsible for over half the 149 entries), Daniel Jacobowitz, Mark Kettenis, Jim Blandy and Eli 150 Zaretskii. 151 152 Eli Zaretskii and Daniel Jacobowitz wrote the sections documenting 153 watchpoints. 154 155 Jeremy Bennett updated the sections on initializing a new 156 architecture and register representation, and added the section on 157 Frame Interpretation. 158 159 160 File: gdbint.info, Node: Overall Structure, Next: Algorithms, Prev: Summary, Up: Top 161 162 2 Overall Structure 163 ******************* 164 165 GDB consists of three major subsystems: user interface, symbol handling 166 (the "symbol side"), and target system handling (the "target side"). 167 168 The user interface consists of several actual interfaces, plus 169 supporting code. 170 171 The symbol side consists of object file readers, debugging info 172 interpreters, symbol table management, source language expression 173 parsing, type and value printing. 174 175 The target side consists of execution control, stack frame analysis, 176 and physical target manipulation. 177 178 The target side/symbol side division is not formal, and there are a 179 number of exceptions. For instance, core file support involves symbolic 180 elements (the basic core file reader is in BFD) and target elements (it 181 supplies the contents of memory and the values of registers). Instead, 182 this division is useful for understanding how the minor subsystems 183 should fit together. 184 185 2.1 The Symbol Side 186 =================== 187 188 The symbolic side of GDB can be thought of as "everything you can do in 189 GDB without having a live program running". For instance, you can look 190 at the types of variables, and evaluate many kinds of expressions. 191 192 2.2 The Target Side 193 =================== 194 195 The target side of GDB is the "bits and bytes manipulator". Although 196 it may make reference to symbolic info here and there, most of the 197 target side will run with only a stripped executable available--or even 198 no executable at all, in remote debugging cases. 199 200 Operations such as disassembly, stack frame crawls, and register 201 display, are able to work with no symbolic info at all. In some cases, 202 such as disassembly, GDB will use symbolic info to present addresses 203 relative to symbols rather than as raw numbers, but it will work either 204 way. 205 206 2.3 Configurations 207 ================== 208 209 "Host" refers to attributes of the system where GDB runs. "Target" 210 refers to the system where the program being debugged executes. In 211 most cases they are the same machine, in which case a third type of 212 "Native" attributes come into play. 213 214 Defines and include files needed to build on the host are host 215 support. Examples are tty support, system defined types, host byte 216 order, host float format. These are all calculated by `autoconf' when 217 the debugger is built. 218 219 Defines and information needed to handle the target format are target 220 dependent. Examples are the stack frame format, instruction set, 221 breakpoint instruction, registers, and how to set up and tear down the 222 stack to call a function. 223 224 Information that is only needed when the host and target are the 225 same, is native dependent. One example is Unix child process support; 226 if the host and target are not the same, calling `fork' to start the 227 target process is a bad idea. The various macros needed for finding the 228 registers in the `upage', running `ptrace', and such are all in the 229 native-dependent files. 230 231 Another example of native-dependent code is support for features that 232 are really part of the target environment, but which require `#include' 233 files that are only available on the host system. Core file handling 234 and `setjmp' handling are two common cases. 235 236 When you want to make GDB work as the traditional native debugger on 237 a system, you will need to supply both target and native information. 238 239 2.4 Source Tree Structure 240 ========================= 241 242 The GDB source directory has a mostly flat structure--there are only a 243 few subdirectories. A file's name usually gives a hint as to what it 244 does; for example, `stabsread.c' reads stabs, `dwarf2read.c' reads 245 DWARF 2, etc. 246 247 Files that are related to some common task have names that share 248 common substrings. For example, `*-thread.c' files deal with debugging 249 threads on various platforms; `*read.c' files deal with reading various 250 kinds of symbol and object files; `inf*.c' files deal with direct 251 control of the "inferior program" (GDB parlance for the program being 252 debugged). 253 254 There are several dozens of files in the `*-tdep.c' family. `tdep' 255 stands for "target-dependent code"--each of these files implements 256 debug support for a specific target architecture (sparc, mips, etc). 257 Usually, only one of these will be used in a specific GDB configuration 258 (sometimes two, closely related). 259 260 Similarly, there are many `*-nat.c' files, each one for native 261 debugging on a specific system (e.g., `sparc-linux-nat.c' is for native 262 debugging of Sparc machines running the Linux kernel). 263 264 The few subdirectories of the source tree are: 265 266 `cli' 267 Code that implements "CLI", the GDB Command-Line Interpreter. 268 *Note Command Interpreter: User Interface. 269 270 `gdbserver' 271 Code for the GDB remote server. 272 273 `gdbtk' 274 Code for Insight, the GDB TK-based GUI front-end. 275 276 `mi' 277 The "GDB/MI", the GDB Machine Interface interpreter. 278 279 `signals' 280 Target signal translation code. 281 282 `tui' 283 Code for "TUI", the GDB Text-mode full-screen User Interface. 284 *Note TUI: User Interface. 285 286 287 File: gdbint.info, Node: Algorithms, Next: User Interface, Prev: Overall Structure, Up: Top 288 289 3 Algorithms 290 ************ 291 292 GDB uses a number of debugging-specific algorithms. They are often not 293 very complicated, but get lost in the thicket of special cases and 294 real-world issues. This chapter describes the basic algorithms and 295 mentions some of the specific target definitions that they use. 296 297 3.1 Prologue Analysis 298 ===================== 299 300 To produce a backtrace and allow the user to manipulate older frames' 301 variables and arguments, GDB needs to find the base addresses of older 302 frames, and discover where those frames' registers have been saved. 303 Since a frame's "callee-saves" registers get saved by younger frames if 304 and when they're reused, a frame's registers may be scattered 305 unpredictably across younger frames. This means that changing the 306 value of a register-allocated variable in an older frame may actually 307 entail writing to a save slot in some younger frame. 308 309 Modern versions of GCC emit Dwarf call frame information ("CFI"), 310 which describes how to find frame base addresses and saved registers. 311 But CFI is not always available, so as a fallback GDB uses a technique 312 called "prologue analysis" to find frame sizes and saved registers. A 313 prologue analyzer disassembles the function's machine code starting 314 from its entry point, and looks for instructions that allocate frame 315 space, save the stack pointer in a frame pointer register, save 316 registers, and so on. Obviously, this can't be done accurately in 317 general, but it's tractable to do well enough to be very helpful. 318 Prologue analysis predates the GNU toolchain's support for CFI; at one 319 time, prologue analysis was the only mechanism GDB used for stack 320 unwinding at all, when the function calling conventions didn't specify 321 a fixed frame layout. 322 323 In the olden days, function prologues were generated by hand-written, 324 target-specific code in GCC, and treated as opaque and untouchable by 325 optimizers. Looking at this code, it was usually straightforward to 326 write a prologue analyzer for GDB that would accurately understand all 327 the prologues GCC would generate. However, over time GCC became more 328 aggressive about instruction scheduling, and began to understand more 329 about the semantics of the prologue instructions themselves; in 330 response, GDB's analyzers became more complex and fragile. Keeping the 331 prologue analyzers working as GCC (and the instruction sets themselves) 332 evolved became a substantial task. 333 334 To try to address this problem, the code in `prologue-value.h' and 335 `prologue-value.c' provides a general framework for writing prologue 336 analyzers that are simpler and more robust than ad-hoc analyzers. When 337 we analyze a prologue using the prologue-value framework, we're really 338 doing "abstract interpretation" or "pseudo-evaluation": running the 339 function's code in simulation, but using conservative approximations of 340 the values registers and memory would hold when the code actually runs. 341 For example, if our function starts with the instruction: 342 343 addi r1, 42 # add 42 to r1 344 we don't know exactly what value will be in `r1' after executing 345 this instruction, but we do know it'll be 42 greater than its original 346 value. 347 348 If we then see an instruction like: 349 350 addi r1, 22 # add 22 to r1 351 we still don't know what `r1's' value is, but again, we can say it 352 is now 64 greater than its original value. 353 354 If the next instruction were: 355 356 mov r2, r1 # set r2 to r1's value 357 then we can say that `r2's' value is now the original value of `r1' 358 plus 64. 359 360 It's common for prologues to save registers on the stack, so we'll 361 need to track the values of stack frame slots, as well as the 362 registers. So after an instruction like this: 363 364 mov (fp+4), r2 365 then we'd know that the stack slot four bytes above the frame pointer 366 holds the original value of `r1' plus 64. 367 368 And so on. 369 370 Of course, this can only go so far before it gets unreasonable. If 371 we wanted to be able to say anything about the value of `r1' after the 372 instruction: 373 374 xor r1, r3 # exclusive-or r1 and r3, place result in r1 375 then things would get pretty complex. But remember, we're just doing 376 a conservative approximation; if exclusive-or instructions aren't 377 relevant to prologues, we can just say `r1''s value is now "unknown". 378 We can ignore things that are too complex, if that loss of information 379 is acceptable for our application. 380 381 So when we say "conservative approximation" here, what we mean is an 382 approximation that is either accurate, or marked "unknown", but never 383 inaccurate. 384 385 Using this framework, a prologue analyzer is simply an interpreter 386 for machine code, but one that uses conservative approximations for the 387 contents of registers and memory instead of actual values. Starting 388 from the function's entry point, you simulate instructions up to the 389 current PC, or an instruction that you don't know how to simulate. Now 390 you can examine the state of the registers and stack slots you've kept 391 track of. 392 393 * To see how large your stack frame is, just check the value of the 394 stack pointer register; if it's the original value of the SP minus 395 a constant, then that constant is the stack frame's size. If the 396 SP's value has been marked as "unknown", then that means the 397 prologue has done something too complex for us to track, and we 398 don't know the frame size. 399 400 * To see where we've saved the previous frame's registers, we just 401 search the values we've tracked -- stack slots, usually, but 402 registers, too, if you want -- for something equal to the 403 register's original value. If the calling conventions suggest a 404 standard place to save a given register, then we can check there 405 first, but really, anything that will get us back the original 406 value will probably work. 407 408 This does take some work. But prologue analyzers aren't 409 quick-and-simple pattern patching to recognize a few fixed prologue 410 forms any more; they're big, hairy functions. Along with inferior 411 function calls, prologue analysis accounts for a substantial portion of 412 the time needed to stabilize a GDB port. So it's worthwhile to look 413 for an approach that will be easier to understand and maintain. In the 414 approach described above: 415 416 * It's easier to see that the analyzer is correct: you just see 417 whether the analyzer properly (albeit conservatively) simulates 418 the effect of each instruction. 419 420 * It's easier to extend the analyzer: you can add support for new 421 instructions, and know that you haven't broken anything that 422 wasn't already broken before. 423 424 * It's orthogonal: to gather new information, you don't need to 425 complicate the code for each instruction. As long as your domain 426 of conservative values is already detailed enough to tell you what 427 you need, then all the existing instruction simulations are 428 already gathering the right data for you. 429 430 431 The file `prologue-value.h' contains detailed comments explaining 432 the framework and how to use it. 433 434 3.2 Breakpoint Handling 435 ======================= 436 437 In general, a breakpoint is a user-designated location in the program 438 where the user wants to regain control if program execution ever reaches 439 that location. 440 441 There are two main ways to implement breakpoints; either as 442 "hardware" breakpoints or as "software" breakpoints. 443 444 Hardware breakpoints are sometimes available as a builtin debugging 445 features with some chips. Typically these work by having dedicated 446 register into which the breakpoint address may be stored. If the PC 447 (shorthand for "program counter") ever matches a value in a breakpoint 448 registers, the CPU raises an exception and reports it to GDB. 449 450 Another possibility is when an emulator is in use; many emulators 451 include circuitry that watches the address lines coming out from the 452 processor, and force it to stop if the address matches a breakpoint's 453 address. 454 455 A third possibility is that the target already has the ability to do 456 breakpoints somehow; for instance, a ROM monitor may do its own 457 software breakpoints. So although these are not literally "hardware 458 breakpoints", from GDB's point of view they work the same; GDB need not 459 do anything more than set the breakpoint and wait for something to 460 happen. 461 462 Since they depend on hardware resources, hardware breakpoints may be 463 limited in number; when the user asks for more, GDB will start trying 464 to set software breakpoints. (On some architectures, notably the 465 32-bit x86 platforms, GDB cannot always know whether there's enough 466 hardware resources to insert all the hardware breakpoints and 467 watchpoints. On those platforms, GDB prints an error message only when 468 the program being debugged is continued.) 469 470 Software breakpoints require GDB to do somewhat more work. The 471 basic theory is that GDB will replace a program instruction with a 472 trap, illegal divide, or some other instruction that will cause an 473 exception, and then when it's encountered, GDB will take the exception 474 and stop the program. When the user says to continue, GDB will restore 475 the original instruction, single-step, re-insert the trap, and continue 476 on. 477 478 Since it literally overwrites the program being tested, the program 479 area must be writable, so this technique won't work on programs in ROM. 480 It can also distort the behavior of programs that examine themselves, 481 although such a situation would be highly unusual. 482 483 Also, the software breakpoint instruction should be the smallest 484 size of instruction, so it doesn't overwrite an instruction that might 485 be a jump target, and cause disaster when the program jumps into the 486 middle of the breakpoint instruction. (Strictly speaking, the 487 breakpoint must be no larger than the smallest interval between 488 instructions that may be jump targets; perhaps there is an architecture 489 where only even-numbered instructions may jumped to.) Note that it's 490 possible for an instruction set not to have any instructions usable for 491 a software breakpoint, although in practice only the ARC has failed to 492 define such an instruction. 493 494 Basic breakpoint object handling is in `breakpoint.c'. However, 495 much of the interesting breakpoint action is in `infrun.c'. 496 497 `target_remove_breakpoint (BP_TGT)' 498 `target_insert_breakpoint (BP_TGT)' 499 Insert or remove a software breakpoint at address 500 `BP_TGT->placed_address'. Returns zero for success, non-zero for 501 failure. On input, BP_TGT contains the address of the breakpoint, 502 and is otherwise initialized to zero. The fields of the `struct 503 bp_target_info' pointed to by BP_TGT are updated to contain other 504 information about the breakpoint on output. The field 505 `placed_address' may be updated if the breakpoint was placed at a 506 related address; the field `shadow_contents' contains the real 507 contents of the bytes where the breakpoint has been inserted, if 508 reading memory would return the breakpoint instead of the 509 underlying memory; the field `shadow_len' is the length of memory 510 cached in `shadow_contents', if any; and the field `placed_size' 511 is optionally set and used by the target, if it could differ from 512 `shadow_len'. 513 514 For example, the remote target `Z0' packet does not require 515 shadowing memory, so `shadow_len' is left at zero. However, the 516 length reported by `gdbarch_breakpoint_from_pc' is cached in 517 `placed_size', so that a matching `z0' packet can be used to 518 remove the breakpoint. 519 520 `target_remove_hw_breakpoint (BP_TGT)' 521 `target_insert_hw_breakpoint (BP_TGT)' 522 Insert or remove a hardware-assisted breakpoint at address 523 `BP_TGT->placed_address'. Returns zero for success, non-zero for 524 failure. See `target_insert_breakpoint' for a description of the 525 `struct bp_target_info' pointed to by BP_TGT; the 526 `shadow_contents' and `shadow_len' members are not used for 527 hardware breakpoints, but `placed_size' may be. 528 529 3.3 Single Stepping 530 =================== 531 532 3.4 Signal Handling 533 =================== 534 535 3.5 Thread Handling 536 =================== 537 538 3.6 Inferior Function Calls 539 =========================== 540 541 3.7 Longjmp Support 542 =================== 543 544 GDB has support for figuring out that the target is doing a `longjmp' 545 and for stopping at the target of the jump, if we are stepping. This 546 is done with a few specialized internal breakpoints, which are visible 547 in the output of the `maint info breakpoint' command. 548 549 To make this work, you need to define a function called 550 `gdbarch_get_longjmp_target', which will examine the `jmp_buf' 551 structure and extract the `longjmp' target address. Since `jmp_buf' is 552 target specific and typically defined in a target header not available 553 to GDB, you will need to determine the offset of the PC manually and 554 return that; many targets define a `jb_pc_offset' field in the tdep 555 structure to save the value once calculated. 556 557 3.8 Watchpoints 558 =============== 559 560 Watchpoints are a special kind of breakpoints (*note breakpoints: 561 Algorithms.) which break when data is accessed rather than when some 562 instruction is executed. When you have data which changes without your 563 knowing what code does that, watchpoints are the silver bullet to hunt 564 down and kill such bugs. 565 566 Watchpoints can be either hardware-assisted or not; the latter type 567 is known as "software watchpoints." GDB always uses hardware-assisted 568 watchpoints if they are available, and falls back on software 569 watchpoints otherwise. Typical situations where GDB will use software 570 watchpoints are: 571 572 * The watched memory region is too large for the underlying hardware 573 watchpoint support. For example, each x86 debug register can 574 watch up to 4 bytes of memory, so trying to watch data structures 575 whose size is more than 16 bytes will cause GDB to use software 576 watchpoints. 577 578 * The value of the expression to be watched depends on data held in 579 registers (as opposed to memory). 580 581 * Too many different watchpoints requested. (On some architectures, 582 this situation is impossible to detect until the debugged program 583 is resumed.) Note that x86 debug registers are used both for 584 hardware breakpoints and for watchpoints, so setting too many 585 hardware breakpoints might cause watchpoint insertion to fail. 586 587 * No hardware-assisted watchpoints provided by the target 588 implementation. 589 590 Software watchpoints are very slow, since GDB needs to single-step 591 the program being debugged and test the value of the watched 592 expression(s) after each instruction. The rest of this section is 593 mostly irrelevant for software watchpoints. 594 595 When the inferior stops, GDB tries to establish, among other 596 possible reasons, whether it stopped due to a watchpoint being hit. It 597 first uses `STOPPED_BY_WATCHPOINT' to see if any watchpoint was hit. 598 If not, all watchpoint checking is skipped. 599 600 Then GDB calls `target_stopped_data_address' exactly once. This 601 method returns the address of the watchpoint which triggered, if the 602 target can determine it. If the triggered address is available, GDB 603 compares the address returned by this method with each watched memory 604 address in each active watchpoint. For data-read and data-access 605 watchpoints, GDB announces every watchpoint that watches the triggered 606 address as being hit. For this reason, data-read and data-access 607 watchpoints _require_ that the triggered address be available; if not, 608 read and access watchpoints will never be considered hit. For 609 data-write watchpoints, if the triggered address is available, GDB 610 considers only those watchpoints which match that address; otherwise, 611 GDB considers all data-write watchpoints. For each data-write 612 watchpoint that GDB considers, it evaluates the expression whose value 613 is being watched, and tests whether the watched value has changed. 614 Watchpoints whose watched values have changed are announced as hit. 615 616 GDB uses several macros and primitives to support hardware 617 watchpoints: 618 619 `TARGET_CAN_USE_HARDWARE_WATCHPOINT (TYPE, COUNT, OTHER)' 620 Return the number of hardware watchpoints of type TYPE that are 621 possible to be set. The value is positive if COUNT watchpoints of 622 this type can be set, zero if setting watchpoints of this type is 623 not supported, and negative if COUNT is more than the maximum 624 number of watchpoints of type TYPE that can be set. OTHER is 625 non-zero if other types of watchpoints are currently enabled (there 626 are architectures which cannot set watchpoints of different types 627 at the same time). 628 629 `TARGET_REGION_OK_FOR_HW_WATCHPOINT (ADDR, LEN)' 630 Return non-zero if hardware watchpoints can be used to watch a 631 region whose address is ADDR and whose length in bytes is LEN. 632 633 `target_insert_watchpoint (ADDR, LEN, TYPE)' 634 `target_remove_watchpoint (ADDR, LEN, TYPE)' 635 Insert or remove a hardware watchpoint starting at ADDR, for LEN 636 bytes. TYPE is the watchpoint type, one of the possible values of 637 the enumerated data type `target_hw_bp_type', defined by 638 `breakpoint.h' as follows: 639 640 enum target_hw_bp_type 641 { 642 hw_write = 0, /* Common (write) HW watchpoint */ 643 hw_read = 1, /* Read HW watchpoint */ 644 hw_access = 2, /* Access (read or write) HW watchpoint */ 645 hw_execute = 3 /* Execute HW breakpoint */ 646 }; 647 648 These two macros should return 0 for success, non-zero for failure. 649 650 `target_stopped_data_address (ADDR_P)' 651 If the inferior has some watchpoint that triggered, place the 652 address associated with the watchpoint at the location pointed to 653 by ADDR_P and return non-zero. Otherwise, return zero. This is 654 required for data-read and data-access watchpoints. It is not 655 required for data-write watchpoints, but GDB uses it to improve 656 handling of those also. 657 658 GDB will only call this method once per watchpoint stop, 659 immediately after calling `STOPPED_BY_WATCHPOINT'. If the 660 target's watchpoint indication is sticky, i.e., stays set after 661 resuming, this method should clear it. For instance, the x86 debug 662 control register has sticky triggered flags. 663 664 `target_watchpoint_addr_within_range (TARGET, ADDR, START, LENGTH)' 665 Check whether ADDR (as returned by `target_stopped_data_address') 666 lies within the hardware-defined watchpoint region described by 667 START and LENGTH. This only needs to be provided if the 668 granularity of a watchpoint is greater than one byte, i.e., if the 669 watchpoint can also trigger on nearby addresses outside of the 670 watched region. 671 672 `HAVE_STEPPABLE_WATCHPOINT' 673 If defined to a non-zero value, it is not necessary to disable a 674 watchpoint to step over it. Like 675 `gdbarch_have_nonsteppable_watchpoint', this is usually set when 676 watchpoints trigger at the instruction which will perform an 677 interesting read or write. It should be set if there is a 678 temporary disable bit which allows the processor to step over the 679 interesting instruction without raising the watchpoint exception 680 again. 681 682 `int gdbarch_have_nonsteppable_watchpoint (GDBARCH)' 683 If it returns a non-zero value, GDB should disable a watchpoint to 684 step the inferior over it. This is usually set when watchpoints 685 trigger at the instruction which will perform an interesting read 686 or write. 687 688 `HAVE_CONTINUABLE_WATCHPOINT' 689 If defined to a non-zero value, it is possible to continue the 690 inferior after a watchpoint has been hit. This is usually set 691 when watchpoints trigger at the instruction following an 692 interesting read or write. 693 694 `STOPPED_BY_WATCHPOINT (WAIT_STATUS)' 695 Return non-zero if stopped by a watchpoint. WAIT_STATUS is of the 696 type `struct target_waitstatus', defined by `target.h'. Normally, 697 this macro is defined to invoke the function pointed to by the 698 `to_stopped_by_watchpoint' member of the structure (of the type 699 `target_ops', defined on `target.h') that describes the 700 target-specific operations; `to_stopped_by_watchpoint' ignores the 701 WAIT_STATUS argument. 702 703 GDB does not require the non-zero value returned by 704 `STOPPED_BY_WATCHPOINT' to be 100% correct, so if a target cannot 705 determine for sure whether the inferior stopped due to a 706 watchpoint, it could return non-zero "just in case". 707 708 3.8.1 Watchpoints and Threads 709 ----------------------------- 710 711 GDB only supports process-wide watchpoints, which trigger in all 712 threads. GDB uses the thread ID to make watchpoints act as if they 713 were thread-specific, but it cannot set hardware watchpoints that only 714 trigger in a specific thread. Therefore, even if the target supports 715 threads, per-thread debug registers, and watchpoints which only affect 716 a single thread, it should set the per-thread debug registers for all 717 threads to the same value. On GNU/Linux native targets, this is 718 accomplished by using `ALL_LWPS' in `target_insert_watchpoint' and 719 `target_remove_watchpoint' and by using `linux_set_new_thread' to 720 register a handler for newly created threads. 721 722 GDB's GNU/Linux support only reports a single event at a time, 723 although multiple events can trigger simultaneously for multi-threaded 724 programs. When multiple events occur, `linux-nat.c' queues subsequent 725 events and returns them the next time the program is resumed. This 726 means that `STOPPED_BY_WATCHPOINT' and `target_stopped_data_address' 727 only need to consult the current thread's state--the thread indicated 728 by `inferior_ptid'. If two threads have hit watchpoints 729 simultaneously, those routines will be called a second time for the 730 second thread. 731 732 3.8.2 x86 Watchpoints 733 --------------------- 734 735 The 32-bit Intel x86 (a.k.a. ia32) processors feature special debug 736 registers designed to facilitate debugging. GDB provides a generic 737 library of functions that x86-based ports can use to implement support 738 for watchpoints and hardware-assisted breakpoints. This subsection 739 documents the x86 watchpoint facilities in GDB. 740 741 (At present, the library functions read and write debug registers 742 directly, and are thus only available for native configurations.) 743 744 To use the generic x86 watchpoint support, a port should do the 745 following: 746 747 * Define the macro `I386_USE_GENERIC_WATCHPOINTS' somewhere in the 748 target-dependent headers. 749 750 * Include the `config/i386/nm-i386.h' header file _after_ defining 751 `I386_USE_GENERIC_WATCHPOINTS'. 752 753 * Add `i386-nat.o' to the value of the Make variable `NATDEPFILES' 754 (*note NATDEPFILES: Native Debugging.). 755 756 * Provide implementations for the `I386_DR_LOW_*' macros described 757 below. Typically, each macro should call a target-specific 758 function which does the real work. 759 760 The x86 watchpoint support works by maintaining mirror images of the 761 debug registers. Values are copied between the mirror images and the 762 real debug registers via a set of macros which each target needs to 763 provide: 764 765 `I386_DR_LOW_SET_CONTROL (VAL)' 766 Set the Debug Control (DR7) register to the value VAL. 767 768 `I386_DR_LOW_SET_ADDR (IDX, ADDR)' 769 Put the address ADDR into the debug register number IDX. 770 771 `I386_DR_LOW_RESET_ADDR (IDX)' 772 Reset (i.e. zero out) the address stored in the debug register 773 number IDX. 774 775 `I386_DR_LOW_GET_STATUS' 776 Return the value of the Debug Status (DR6) register. This value is 777 used immediately after it is returned by `I386_DR_LOW_GET_STATUS', 778 so as to support per-thread status register values. 779 780 For each one of the 4 debug registers (whose indices are from 0 to 3) 781 that store addresses, a reference count is maintained by GDB, to allow 782 sharing of debug registers by several watchpoints. This allows users 783 to define several watchpoints that watch the same expression, but with 784 different conditions and/or commands, without wasting debug registers 785 which are in short supply. GDB maintains the reference counts 786 internally, targets don't have to do anything to use this feature. 787 788 The x86 debug registers can each watch a region that is 1, 2, or 4 789 bytes long. The ia32 architecture requires that each watched region be 790 appropriately aligned: 2-byte region on 2-byte boundary, 4-byte region 791 on 4-byte boundary. However, the x86 watchpoint support in GDB can 792 watch unaligned regions and regions larger than 4 bytes (up to 16 793 bytes) by allocating several debug registers to watch a single region. 794 This allocation of several registers per a watched region is also done 795 automatically without target code intervention. 796 797 The generic x86 watchpoint support provides the following API for the 798 GDB's application code: 799 800 `i386_region_ok_for_watchpoint (ADDR, LEN)' 801 The macro `TARGET_REGION_OK_FOR_HW_WATCHPOINT' is set to call this 802 function. It counts the number of debug registers required to 803 watch a given region, and returns a non-zero value if that number 804 is less than 4, the number of debug registers available to x86 805 processors. 806 807 `i386_stopped_data_address (ADDR_P)' 808 The target function `target_stopped_data_address' is set to call 809 this function. This function examines the breakpoint condition 810 bits in the DR6 Debug Status register, as returned by the 811 `I386_DR_LOW_GET_STATUS' macro, and returns the address associated 812 with the first bit that is set in DR6. 813 814 `i386_stopped_by_watchpoint (void)' 815 The macro `STOPPED_BY_WATCHPOINT' is set to call this function. 816 The argument passed to `STOPPED_BY_WATCHPOINT' is ignored. This 817 function examines the breakpoint condition bits in the DR6 Debug 818 Status register, as returned by the `I386_DR_LOW_GET_STATUS' 819 macro, and returns true if any bit is set. Otherwise, false is 820 returned. 821 822 `i386_insert_watchpoint (ADDR, LEN, TYPE)' 823 `i386_remove_watchpoint (ADDR, LEN, TYPE)' 824 Insert or remove a watchpoint. The macros 825 `target_insert_watchpoint' and `target_remove_watchpoint' are set 826 to call these functions. `i386_insert_watchpoint' first looks for 827 a debug register which is already set to watch the same region for 828 the same access types; if found, it just increments the reference 829 count of that debug register, thus implementing debug register 830 sharing between watchpoints. If no such register is found, the 831 function looks for a vacant debug register, sets its mirrored 832 value to ADDR, sets the mirrored value of DR7 Debug Control 833 register as appropriate for the LEN and TYPE parameters, and then 834 passes the new values of the debug register and DR7 to the 835 inferior by calling `I386_DR_LOW_SET_ADDR' and 836 `I386_DR_LOW_SET_CONTROL'. If more than one debug register is 837 required to cover the given region, the above process is repeated 838 for each debug register. 839 840 `i386_remove_watchpoint' does the opposite: it resets the address 841 in the mirrored value of the debug register and its read/write and 842 length bits in the mirrored value of DR7, then passes these new 843 values to the inferior via `I386_DR_LOW_RESET_ADDR' and 844 `I386_DR_LOW_SET_CONTROL'. If a register is shared by several 845 watchpoints, each time a `i386_remove_watchpoint' is called, it 846 decrements the reference count, and only calls 847 `I386_DR_LOW_RESET_ADDR' and `I386_DR_LOW_SET_CONTROL' when the 848 count goes to zero. 849 850 `i386_insert_hw_breakpoint (BP_TGT)' 851 `i386_remove_hw_breakpoint (BP_TGT)' 852 These functions insert and remove hardware-assisted breakpoints. 853 The macros `target_insert_hw_breakpoint' and 854 `target_remove_hw_breakpoint' are set to call these functions. 855 The argument is a `struct bp_target_info *', as described in the 856 documentation for `target_insert_breakpoint'. These functions 857 work like `i386_insert_watchpoint' and `i386_remove_watchpoint', 858 respectively, except that they set up the debug registers to watch 859 instruction execution, and each hardware-assisted breakpoint 860 always requires exactly one debug register. 861 862 `i386_cleanup_dregs (void)' 863 This function clears all the reference counts, addresses, and 864 control bits in the mirror images of the debug registers. It 865 doesn't affect the actual debug registers in the inferior process. 866 867 *Notes:* 868 1. x86 processors support setting watchpoints on I/O reads or writes. 869 However, since no target supports this (as of March 2001), and 870 since `enum target_hw_bp_type' doesn't even have an enumeration 871 for I/O watchpoints, this feature is not yet available to GDB 872 running on x86. 873 874 2. x86 processors can enable watchpoints locally, for the current task 875 only, or globally, for all the tasks. For each debug register, 876 there's a bit in the DR7 Debug Control register that determines 877 whether the associated address is watched locally or globally. The 878 current implementation of x86 watchpoint support in GDB always 879 sets watchpoints to be locally enabled, since global watchpoints 880 might interfere with the underlying OS and are probably 881 unavailable in many platforms. 882 883 3.9 Checkpoints 884 =============== 885 886 In the abstract, a checkpoint is a point in the execution history of 887 the program, which the user may wish to return to at some later time. 888 889 Internally, a checkpoint is a saved copy of the program state, 890 including whatever information is required in order to restore the 891 program to that state at a later time. This can be expected to include 892 the state of registers and memory, and may include external state such 893 as the state of open files and devices. 894 895 There are a number of ways in which checkpoints may be implemented 896 in gdb, e.g. as corefiles, as forked processes, and as some opaque 897 method implemented on the target side. 898 899 A corefile can be used to save an image of target memory and register 900 state, which can in principle be restored later -- but corefiles do not 901 typically include information about external entities such as open 902 files. Currently this method is not implemented in gdb. 903 904 A forked process can save the state of user memory and registers, as 905 well as some subset of external (kernel) state. This method is used to 906 implement checkpoints on Linux, and in principle might be used on other 907 systems. 908 909 Some targets, e.g. simulators, might have their own built-in method 910 for saving checkpoints, and gdb might be able to take advantage of that 911 capability without necessarily knowing any details of how it is done. 912 913 3.10 Observing changes in GDB internals 914 ======================================= 915 916 In order to function properly, several modules need to be notified when 917 some changes occur in the GDB internals. Traditionally, these modules 918 have relied on several paradigms, the most common ones being hooks and 919 gdb-events. Unfortunately, none of these paradigms was versatile 920 enough to become the standard notification mechanism in GDB. The fact 921 that they only supported one "client" was also a strong limitation. 922 923 A new paradigm, based on the Observer pattern of the `Design 924 Patterns' book, has therefore been implemented. The goal was to provide 925 a new interface overcoming the issues with the notification mechanisms 926 previously available. This new interface needed to be strongly typed, 927 easy to extend, and versatile enough to be used as the standard 928 interface when adding new notifications. 929 930 See *note GDB Observers:: for a brief description of the observers 931 currently implemented in GDB. The rationale for the current 932 implementation is also briefly discussed. 933 934 935 File: gdbint.info, Node: User Interface, Next: libgdb, Prev: Algorithms, Up: Top 936 937 4 User Interface 938 **************** 939 940 GDB has several user interfaces, of which the traditional command-line 941 interface is perhaps the most familiar. 942 943 4.1 Command Interpreter 944 ======================= 945 946 The command interpreter in GDB is fairly simple. It is designed to 947 allow for the set of commands to be augmented dynamically, and also has 948 a recursive subcommand capability, where the first argument to a 949 command may itself direct a lookup on a different command list. 950 951 For instance, the `set' command just starts a lookup on the 952 `setlist' command list, while `set thread' recurses to the 953 `set_thread_cmd_list'. 954 955 To add commands in general, use `add_cmd'. `add_com' adds to the 956 main command list, and should be used for those commands. The usual 957 place to add commands is in the `_initialize_XYZ' routines at the ends 958 of most source files. 959 960 To add paired `set' and `show' commands, use `add_setshow_cmd' or 961 `add_setshow_cmd_full'. The former is a slightly simpler interface 962 which is useful when you don't need to further modify the new command 963 structures, while the latter returns the new command structures for 964 manipulation. 965 966 Before removing commands from the command set it is a good idea to 967 deprecate them for some time. Use `deprecate_cmd' on commands or 968 aliases to set the deprecated flag. `deprecate_cmd' takes a `struct 969 cmd_list_element' as it's first argument. You can use the return value 970 from `add_com' or `add_cmd' to deprecate the command immediately after 971 it is created. 972 973 The first time a command is used the user will be warned and offered 974 a replacement (if one exists). Note that the replacement string passed 975 to `deprecate_cmd' should be the full name of the command, i.e., the 976 entire string the user should type at the command line. 977 978 4.2 UI-Independent Output--the `ui_out' Functions 979 ================================================= 980 981 The `ui_out' functions present an abstraction level for the GDB output 982 code. They hide the specifics of different user interfaces supported 983 by GDB, and thus free the programmer from the need to write several 984 versions of the same code, one each for every UI, to produce output. 985 986 4.2.1 Overview and Terminology 987 ------------------------------ 988 989 In general, execution of each GDB command produces some sort of output, 990 and can even generate an input request. 991 992 Output can be generated for the following purposes: 993 994 * to display a _result_ of an operation; 995 996 * to convey _info_ or produce side-effects of a requested operation; 997 998 * to provide a _notification_ of an asynchronous event (including 999 progress indication of a prolonged asynchronous operation); 1000 1001 * to display _error messages_ (including warnings); 1002 1003 * to show _debug data_; 1004 1005 * to _query_ or prompt a user for input (a special case). 1006 1007 This section mainly concentrates on how to build result output, 1008 although some of it also applies to other kinds of output. 1009 1010 Generation of output that displays the results of an operation 1011 involves one or more of the following: 1012 1013 * output of the actual data 1014 1015 * formatting the output as appropriate for console output, to make it 1016 easily readable by humans 1017 1018 * machine oriented formatting-a more terse formatting to allow for 1019 easy parsing by programs which read GDB's output 1020 1021 * annotation, whose purpose is to help legacy GUIs to identify 1022 interesting parts in the output 1023 1024 The `ui_out' routines take care of the first three aspects. 1025 Annotations are provided by separate annotation routines. Note that use 1026 of annotations for an interface between a GUI and GDB is deprecated. 1027 1028 Output can be in the form of a single item, which we call a "field"; 1029 a "list" consisting of identical fields; a "tuple" consisting of 1030 non-identical fields; or a "table", which is a tuple consisting of a 1031 header and a body. In a BNF-like form: 1032 1033 `<table> ==>' 1034 `<header> <body>' 1035 1036 `<header> ==>' 1037 `{ <column> }' 1038 1039 `<column> ==>' 1040 `<width> <alignment> <title>' 1041 1042 `<body> ==>' 1043 `{<row>}' 1044 1045 4.2.2 General Conventions 1046 ------------------------- 1047 1048 Most `ui_out' routines are of type `void', the exceptions are 1049 `ui_out_stream_new' (which returns a pointer to the newly created 1050 object) and the `make_cleanup' routines. 1051 1052 The first parameter is always the `ui_out' vector object, a pointer 1053 to a `struct ui_out'. 1054 1055 The FORMAT parameter is like in `printf' family of functions. When 1056 it is present, there must also be a variable list of arguments 1057 sufficient used to satisfy the `%' specifiers in the supplied format. 1058 1059 When a character string argument is not used in a `ui_out' function 1060 call, a `NULL' pointer has to be supplied instead. 1061 1062 4.2.3 Table, Tuple and List Functions 1063 ------------------------------------- 1064 1065 This section introduces `ui_out' routines for building lists, tuples 1066 and tables. The routines to output the actual data items (fields) are 1067 presented in the next section. 1068 1069 To recap: A "tuple" is a sequence of "fields", each field containing 1070 information about an object; a "list" is a sequence of fields where 1071 each field describes an identical object. 1072 1073 Use the "table" functions when your output consists of a list of 1074 rows (tuples) and the console output should include a heading. Use this 1075 even when you are listing just one object but you still want the header. 1076 1077 Tables can not be nested. Tuples and lists can be nested up to a 1078 maximum of five levels. 1079 1080 The overall structure of the table output code is something like 1081 this: 1082 1083 ui_out_table_begin 1084 ui_out_table_header 1085 ... 1086 ui_out_table_body 1087 ui_out_tuple_begin 1088 ui_out_field_* 1089 ... 1090 ui_out_tuple_end 1091 ... 1092 ui_out_table_end 1093 1094 Here is the description of table-, tuple- and list-related `ui_out' 1095 functions: 1096 1097 -- Function: void ui_out_table_begin (struct ui_out *UIOUT, int 1098 NBROFCOLS, int NR_ROWS, const char *TBLID) 1099 The function `ui_out_table_begin' marks the beginning of the output 1100 of a table. It should always be called before any other `ui_out' 1101 function for a given table. NBROFCOLS is the number of columns in 1102 the table. NR_ROWS is the number of rows in the table. TBLID is 1103 an optional string identifying the table. The string pointed to 1104 by TBLID is copied by the implementation of `ui_out_table_begin', 1105 so the application can free the string if it was `malloc'ed. 1106 1107 The companion function `ui_out_table_end', described below, marks 1108 the end of the table's output. 1109 1110 -- Function: void ui_out_table_header (struct ui_out *UIOUT, int 1111 WIDTH, enum ui_align ALIGNMENT, const char *COLHDR) 1112 `ui_out_table_header' provides the header information for a single 1113 table column. You call this function several times, one each for 1114 every column of the table, after `ui_out_table_begin', but before 1115 `ui_out_table_body'. 1116 1117 The value of WIDTH gives the column width in characters. The 1118 value of ALIGNMENT is one of `left', `center', and `right', and it 1119 specifies how to align the header: left-justify, center, or 1120 right-justify it. COLHDR points to a string that specifies the 1121 column header; the implementation copies that string, so column 1122 header strings in `malloc'ed storage can be freed after the call. 1123 1124 -- Function: void ui_out_table_body (struct ui_out *UIOUT) 1125 This function delimits the table header from the table body. 1126 1127 -- Function: void ui_out_table_end (struct ui_out *UIOUT) 1128 This function signals the end of a table's output. It should be 1129 called after the table body has been produced by the list and 1130 field output functions. 1131 1132 There should be exactly one call to `ui_out_table_end' for each 1133 call to `ui_out_table_begin', otherwise the `ui_out' functions 1134 will signal an internal error. 1135 1136 The output of the tuples that represent the table rows must follow 1137 the call to `ui_out_table_body' and precede the call to 1138 `ui_out_table_end'. You build a tuple by calling `ui_out_tuple_begin' 1139 and `ui_out_tuple_end', with suitable calls to functions which actually 1140 output fields between them. 1141 1142 -- Function: void ui_out_tuple_begin (struct ui_out *UIOUT, const char 1143 *ID) 1144 This function marks the beginning of a tuple output. ID points to 1145 an optional string that identifies the tuple; it is copied by the 1146 implementation, and so strings in `malloc'ed storage can be freed 1147 after the call. 1148 1149 -- Function: void ui_out_tuple_end (struct ui_out *UIOUT) 1150 This function signals an end of a tuple output. There should be 1151 exactly one call to `ui_out_tuple_end' for each call to 1152 `ui_out_tuple_begin', otherwise an internal GDB error will be 1153 signaled. 1154 1155 -- Function: struct cleanup * make_cleanup_ui_out_tuple_begin_end 1156 (struct ui_out *UIOUT, const char *ID) 1157 This function first opens the tuple and then establishes a cleanup 1158 (*note Cleanups: Misc Guidelines.) to close the tuple. It 1159 provides a convenient and correct implementation of the 1160 non-portable(1) code sequence: 1161 struct cleanup *old_cleanup; 1162 ui_out_tuple_begin (uiout, "..."); 1163 old_cleanup = make_cleanup ((void(*)(void *)) ui_out_tuple_end, 1164 uiout); 1165 1166 -- Function: void ui_out_list_begin (struct ui_out *UIOUT, const char 1167 *ID) 1168 This function marks the beginning of a list output. ID points to 1169 an optional string that identifies the list; it is copied by the 1170 implementation, and so strings in `malloc'ed storage can be freed 1171 after the call. 1172 1173 -- Function: void ui_out_list_end (struct ui_out *UIOUT) 1174 This function signals an end of a list output. There should be 1175 exactly one call to `ui_out_list_end' for each call to 1176 `ui_out_list_begin', otherwise an internal GDB error will be 1177 signaled. 1178 1179 -- Function: struct cleanup * make_cleanup_ui_out_list_begin_end 1180 (struct ui_out *UIOUT, const char *ID) 1181 Similar to `make_cleanup_ui_out_tuple_begin_end', this function 1182 opens a list and then establishes cleanup (*note Cleanups: Misc 1183 Guidelines.) that will close the list. 1184 1185 4.2.4 Item Output Functions 1186 --------------------------- 1187 1188 The functions described below produce output for the actual data items, 1189 or fields, which contain information about the object. 1190 1191 Choose the appropriate function accordingly to your particular needs. 1192 1193 -- Function: void ui_out_field_fmt (struct ui_out *UIOUT, char 1194 *FLDNAME, char *FORMAT, ...) 1195 This is the most general output function. It produces the 1196 representation of the data in the variable-length argument list 1197 according to formatting specifications in FORMAT, a `printf'-like 1198 format string. The optional argument FLDNAME supplies the name of 1199 the field. The data items themselves are supplied as additional 1200 arguments after FORMAT. 1201 1202 This generic function should be used only when it is not possible 1203 to use one of the specialized versions (see below). 1204 1205 -- Function: void ui_out_field_int (struct ui_out *UIOUT, const char 1206 *FLDNAME, int VALUE) 1207 This function outputs a value of an `int' variable. It uses the 1208 `"%d"' output conversion specification. FLDNAME specifies the 1209 name of the field. 1210 1211 -- Function: void ui_out_field_fmt_int (struct ui_out *UIOUT, int 1212 WIDTH, enum ui_align ALIGNMENT, const char *FLDNAME, int 1213 VALUE) 1214 This function outputs a value of an `int' variable. It differs 1215 from `ui_out_field_int' in that the caller specifies the desired 1216 WIDTH and ALIGNMENT of the output. FLDNAME specifies the name of 1217 the field. 1218 1219 -- Function: void ui_out_field_core_addr (struct ui_out *UIOUT, const 1220 char *FLDNAME, struct gdbarch *GDBARCH, CORE_ADDR ADDRESS) 1221 This function outputs an address as appropriate for GDBARCH. 1222 1223 -- Function: void ui_out_field_string (struct ui_out *UIOUT, const 1224 char *FLDNAME, const char *STRING) 1225 This function outputs a string using the `"%s"' conversion 1226 specification. 1227 1228 Sometimes, there's a need to compose your output piece by piece using 1229 functions that operate on a stream, such as `value_print' or 1230 `fprintf_symbol_filtered'. These functions accept an argument of the 1231 type `struct ui_file *', a pointer to a `ui_file' object used to store 1232 the data stream used for the output. When you use one of these 1233 functions, you need a way to pass their results stored in a `ui_file' 1234 object to the `ui_out' functions. To this end, you first create a 1235 `ui_stream' object by calling `ui_out_stream_new', pass the `stream' 1236 member of that `ui_stream' object to `value_print' and similar 1237 functions, and finally call `ui_out_field_stream' to output the field 1238 you constructed. When the `ui_stream' object is no longer needed, you 1239 should destroy it and free its memory by calling `ui_out_stream_delete'. 1240 1241 -- Function: struct ui_stream * ui_out_stream_new (struct ui_out 1242 *UIOUT) 1243 This function creates a new `ui_stream' object which uses the same 1244 output methods as the `ui_out' object whose pointer is passed in 1245 UIOUT. It returns a pointer to the newly created `ui_stream' 1246 object. 1247 1248 -- Function: void ui_out_stream_delete (struct ui_stream *STREAMBUF) 1249 This functions destroys a `ui_stream' object specified by 1250 STREAMBUF. 1251 1252 -- Function: void ui_out_field_stream (struct ui_out *UIOUT, const 1253 char *FIELDNAME, struct ui_stream *STREAMBUF) 1254 This function consumes all the data accumulated in 1255 `streambuf->stream' and outputs it like `ui_out_field_string' 1256 does. After a call to `ui_out_field_stream', the accumulated data 1257 no longer exists, but the stream is still valid and may be used 1258 for producing more fields. 1259 1260 *Important:* If there is any chance that your code could bail out 1261 before completing output generation and reaching the point where 1262 `ui_out_stream_delete' is called, it is necessary to set up a cleanup, 1263 to avoid leaking memory and other resources. Here's a skeleton code to 1264 do that: 1265 1266 struct ui_stream *mybuf = ui_out_stream_new (uiout); 1267 struct cleanup *old = make_cleanup (ui_out_stream_delete, mybuf); 1268 ... 1269 do_cleanups (old); 1270 1271 If the function already has the old cleanup chain set (for other 1272 kinds of cleanups), you just have to add your cleanup to it: 1273 1274 mybuf = ui_out_stream_new (uiout); 1275 make_cleanup (ui_out_stream_delete, mybuf); 1276 1277 Note that with cleanups in place, you should not call 1278 `ui_out_stream_delete' directly, or you would attempt to free the same 1279 buffer twice. 1280 1281 4.2.5 Utility Output Functions 1282 ------------------------------ 1283 1284 -- Function: void ui_out_field_skip (struct ui_out *UIOUT, const char 1285 *FLDNAME) 1286 This function skips a field in a table. Use it if you have to 1287 leave an empty field without disrupting the table alignment. The 1288 argument FLDNAME specifies a name for the (missing) filed. 1289 1290 -- Function: void ui_out_text (struct ui_out *UIOUT, const char 1291 *STRING) 1292 This function outputs the text in STRING in a way that makes it 1293 easy to be read by humans. For example, the console 1294 implementation of this method filters the text through a built-in 1295 pager, to prevent it from scrolling off the visible portion of the 1296 screen. 1297 1298 Use this function for printing relatively long chunks of text 1299 around the actual field data: the text it produces is not aligned 1300 according to the table's format. Use `ui_out_field_string' to 1301 output a string field, and use `ui_out_message', described below, 1302 to output short messages. 1303 1304 -- Function: void ui_out_spaces (struct ui_out *UIOUT, int NSPACES) 1305 This function outputs NSPACES spaces. It is handy to align the 1306 text produced by `ui_out_text' with the rest of the table or list. 1307 1308 -- Function: void ui_out_message (struct ui_out *UIOUT, int VERBOSITY, 1309 const char *FORMAT, ...) 1310 This function produces a formatted message, provided that the 1311 current verbosity level is at least as large as given by 1312 VERBOSITY. The current verbosity level is specified by the user 1313 with the `set verbositylevel' command.(2) 1314 1315 -- Function: void ui_out_wrap_hint (struct ui_out *UIOUT, char *INDENT) 1316 This function gives the console output filter (a paging filter) a 1317 hint of where to break lines which are too long. Ignored for all 1318 other output consumers. INDENT, if non-`NULL', is the string to 1319 be printed to indent the wrapped text on the next line; it must 1320 remain accessible until the next call to `ui_out_wrap_hint', or 1321 until an explicit newline is produced by one of the other 1322 functions. If INDENT is `NULL', the wrapped text will not be 1323 indented. 1324 1325 -- Function: void ui_out_flush (struct ui_out *UIOUT) 1326 This function flushes whatever output has been accumulated so far, 1327 if the UI buffers output. 1328 1329 4.2.6 Examples of Use of `ui_out' functions 1330 ------------------------------------------- 1331 1332 This section gives some practical examples of using the `ui_out' 1333 functions to generalize the old console-oriented code in GDB. The 1334 examples all come from functions defined on the `breakpoints.c' file. 1335 1336 This example, from the `breakpoint_1' function, shows how to produce 1337 a table. 1338 1339 The original code was: 1340 1341 if (!found_a_breakpoint++) 1342 { 1343 annotate_breakpoints_headers (); 1344 1345 annotate_field (0); 1346 printf_filtered ("Num "); 1347 annotate_field (1); 1348 printf_filtered ("Type "); 1349 annotate_field (2); 1350 printf_filtered ("Disp "); 1351 annotate_field (3); 1352 printf_filtered ("Enb "); 1353 if (addressprint) 1354 { 1355 annotate_field (4); 1356 printf_filtered ("Address "); 1357 } 1358 annotate_field (5); 1359 printf_filtered ("What\n"); 1360 1361 annotate_breakpoints_table (); 1362 } 1363 1364 Here's the new version: 1365 1366 nr_printable_breakpoints = ...; 1367 1368 if (addressprint) 1369 ui_out_table_begin (ui, 6, nr_printable_breakpoints, "BreakpointTable"); 1370 else 1371 ui_out_table_begin (ui, 5, nr_printable_breakpoints, "BreakpointTable"); 1372 1373 if (nr_printable_breakpoints > 0) 1374 annotate_breakpoints_headers (); 1375 if (nr_printable_breakpoints > 0) 1376 annotate_field (0); 1377 ui_out_table_header (uiout, 3, ui_left, "number", "Num"); /* 1 */ 1378 if (nr_printable_breakpoints > 0) 1379 annotate_field (1); 1380 ui_out_table_header (uiout, 14, ui_left, "type", "Type"); /* 2 */ 1381 if (nr_printable_breakpoints > 0) 1382 annotate_field (2); 1383 ui_out_table_header (uiout, 4, ui_left, "disp", "Disp"); /* 3 */ 1384 if (nr_printable_breakpoints > 0) 1385 annotate_field (3); 1386 ui_out_table_header (uiout, 3, ui_left, "enabled", "Enb"); /* 4 */ 1387 if (addressprint) 1388 { 1389 if (nr_printable_breakpoints > 0) 1390 annotate_field (4); 1391 if (print_address_bits <= 32) 1392 ui_out_table_header (uiout, 10, ui_left, "addr", "Address");/* 5 */ 1393 else 1394 ui_out_table_header (uiout, 18, ui_left, "addr", "Address");/* 5 */ 1395 } 1396 if (nr_printable_breakpoints > 0) 1397 annotate_field (5); 1398 ui_out_table_header (uiout, 40, ui_noalign, "what", "What"); /* 6 */ 1399 ui_out_table_body (uiout); 1400 if (nr_printable_breakpoints > 0) 1401 annotate_breakpoints_table (); 1402 1403 This example, from the `print_one_breakpoint' function, shows how to 1404 produce the actual data for the table whose structure was defined in 1405 the above example. The original code was: 1406 1407 annotate_record (); 1408 annotate_field (0); 1409 printf_filtered ("%-3d ", b->number); 1410 annotate_field (1); 1411 if ((int)b->type > (sizeof(bptypes)/sizeof(bptypes[0])) 1412 || ((int) b->type != bptypes[(int) b->type].type)) 1413 internal_error ("bptypes table does not describe type #%d.", 1414 (int)b->type); 1415 printf_filtered ("%-14s ", bptypes[(int)b->type].description); 1416 annotate_field (2); 1417 printf_filtered ("%-4s ", bpdisps[(int)b->disposition]); 1418 annotate_field (3); 1419 printf_filtered ("%-3c ", bpenables[(int)b->enable]); 1420 ... 1421 1422 This is the new version: 1423 1424 annotate_record (); 1425 ui_out_tuple_begin (uiout, "bkpt"); 1426 annotate_field (0); 1427 ui_out_field_int (uiout, "number", b->number); 1428 annotate_field (1); 1429 if (((int) b->type > (sizeof (bptypes) / sizeof (bptypes[0]))) 1430 || ((int) b->type != bptypes[(int) b->type].type)) 1431 internal_error ("bptypes table does not describe type #%d.", 1432 (int) b->type); 1433 ui_out_field_string (uiout, "type", bptypes[(int)b->type].description); 1434 annotate_field (2); 1435 ui_out_field_string (uiout, "disp", bpdisps[(int)b->disposition]); 1436 annotate_field (3); 1437 ui_out_field_fmt (uiout, "enabled", "%c", bpenables[(int)b->enable]); 1438 ... 1439 1440 This example, also from `print_one_breakpoint', shows how to produce 1441 a complicated output field using the `print_expression' functions which 1442 requires a stream to be passed. It also shows how to automate stream 1443 destruction with cleanups. The original code was: 1444 1445 annotate_field (5); 1446 print_expression (b->exp, gdb_stdout); 1447 1448 The new version is: 1449 1450 struct ui_stream *stb = ui_out_stream_new (uiout); 1451 struct cleanup *old_chain = make_cleanup_ui_out_stream_delete (stb); 1452 ... 1453 annotate_field (5); 1454 print_expression (b->exp, stb->stream); 1455 ui_out_field_stream (uiout, "what", local_stream); 1456 1457 This example, also from `print_one_breakpoint', shows how to use 1458 `ui_out_text' and `ui_out_field_string'. The original code was: 1459 1460 annotate_field (5); 1461 if (b->dll_pathname == NULL) 1462 printf_filtered ("<any library> "); 1463 else 1464 printf_filtered ("library \"%s\" ", b->dll_pathname); 1465 1466 It became: 1467 1468 annotate_field (5); 1469 if (b->dll_pathname == NULL) 1470 { 1471 ui_out_field_string (uiout, "what", "<any library>"); 1472 ui_out_spaces (uiout, 1); 1473 } 1474 else 1475 { 1476 ui_out_text (uiout, "library \""); 1477 ui_out_field_string (uiout, "what", b->dll_pathname); 1478 ui_out_text (uiout, "\" "); 1479 } 1480 1481 The following example from `print_one_breakpoint' shows how to use 1482 `ui_out_field_int' and `ui_out_spaces'. The original code was: 1483 1484 annotate_field (5); 1485 if (b->forked_inferior_pid != 0) 1486 printf_filtered ("process %d ", b->forked_inferior_pid); 1487 1488 It became: 1489 1490 annotate_field (5); 1491 if (b->forked_inferior_pid != 0) 1492 { 1493 ui_out_text (uiout, "process "); 1494 ui_out_field_int (uiout, "what", b->forked_inferior_pid); 1495 ui_out_spaces (uiout, 1); 1496 } 1497 1498 Here's an example of using `ui_out_field_string'. The original code 1499 was: 1500 1501 annotate_field (5); 1502 if (b->exec_pathname != NULL) 1503 printf_filtered ("program \"%s\" ", b->exec_pathname); 1504 1505 It became: 1506 1507 annotate_field (5); 1508 if (b->exec_pathname != NULL) 1509 { 1510 ui_out_text (uiout, "program \""); 1511 ui_out_field_string (uiout, "what", b->exec_pathname); 1512 ui_out_text (uiout, "\" "); 1513 } 1514 1515 Finally, here's an example of printing an address. The original 1516 code: 1517 1518 annotate_field (4); 1519 printf_filtered ("%s ", 1520 hex_string_custom ((unsigned long) b->address, 8)); 1521 1522 It became: 1523 1524 annotate_field (4); 1525 ui_out_field_core_addr (uiout, "Address", b->address); 1526 1527 4.3 Console Printing 1528 ==================== 1529 1530 4.4 TUI 1531 ======= 1532 1533 ---------- Footnotes ---------- 1534 1535 (1) The function cast is not portable ISO C. 1536 1537 (2) As of this writing (April 2001), setting verbosity level is not 1538 yet implemented, and is always returned as zero. So calling 1539 `ui_out_message' with a VERBOSITY argument more than zero will cause 1540 the message to never be printed. 1541 1542 1543 File: gdbint.info, Node: libgdb, Next: Values, Prev: User Interface, Up: Top 1544 1545 5 libgdb 1546 ******** 1547 1548 5.1 libgdb 1.0 1549 ============== 1550 1551 `libgdb' 1.0 was an abortive project of years ago. The theory was to 1552 provide an API to GDB's functionality. 1553 1554 5.2 libgdb 2.0 1555 ============== 1556 1557 `libgdb' 2.0 is an ongoing effort to update GDB so that is better able 1558 to support graphical and other environments. 1559 1560 Since `libgdb' development is on-going, its architecture is still 1561 evolving. The following components have so far been identified: 1562 1563 * Observer - `gdb-events.h'. 1564 1565 * Builder - `ui-out.h' 1566 1567 * Event Loop - `event-loop.h' 1568 1569 * Library - `gdb.h' 1570 1571 The model that ties these components together is described below. 1572 1573 5.3 The `libgdb' Model 1574 ====================== 1575 1576 A client of `libgdb' interacts with the library in two ways. 1577 1578 * As an observer (using `gdb-events') receiving notifications from 1579 `libgdb' of any internal state changes (break point changes, run 1580 state, etc). 1581 1582 * As a client querying `libgdb' (using the `ui-out' builder) to 1583 obtain various status values from GDB. 1584 1585 Since `libgdb' could have multiple clients (e.g., a GUI supporting 1586 the existing GDB CLI), those clients must co-operate when controlling 1587 `libgdb'. In particular, a client must ensure that `libgdb' is idle 1588 (i.e. no other client is using `libgdb') before responding to a 1589 `gdb-event' by making a query. 1590 1591 5.4 CLI support 1592 =============== 1593 1594 At present GDB's CLI is very much entangled in with the core of 1595 `libgdb'. Consequently, a client wishing to include the CLI in their 1596 interface needs to carefully co-ordinate its own and the CLI's 1597 requirements. 1598 1599 It is suggested that the client set `libgdb' up to be bi-modal 1600 (alternate between CLI and client query modes). The notes below sketch 1601 out the theory: 1602 1603 * The client registers itself as an observer of `libgdb'. 1604 1605 * The client create and install `cli-out' builder using its own 1606 versions of the `ui-file' `gdb_stderr', `gdb_stdtarg' and 1607 `gdb_stdout' streams. 1608 1609 * The client creates a separate custom `ui-out' builder that is only 1610 used while making direct queries to `libgdb'. 1611 1612 When the client receives input intended for the CLI, it simply 1613 passes it along. Since the `cli-out' builder is installed by default, 1614 all the CLI output in response to that command is routed (pronounced 1615 rooted) through to the client controlled `gdb_stdout' et. al. streams. 1616 At the same time, the client is kept abreast of internal changes by 1617 virtue of being a `libgdb' observer. 1618 1619 The only restriction on the client is that it must wait until 1620 `libgdb' becomes idle before initiating any queries (using the client's 1621 custom builder). 1622 1623 5.5 `libgdb' components 1624 ======================= 1625 1626 Observer - `gdb-events.h' 1627 ------------------------- 1628 1629 `gdb-events' provides the client with a very raw mechanism that can be 1630 used to implement an observer. At present it only allows for one 1631 observer and that observer must, internally, handle the need to delay 1632 the processing of any event notifications until after `libgdb' has 1633 finished the current command. 1634 1635 Builder - `ui-out.h' 1636 -------------------- 1637 1638 `ui-out' provides the infrastructure necessary for a client to create a 1639 builder. That builder is then passed down to `libgdb' when doing any 1640 queries. 1641 1642 Event Loop - `event-loop.h' 1643 --------------------------- 1644 1645 `event-loop', currently non-re-entrant, provides a simple event loop. 1646 A client would need to either plug its self into this loop or, 1647 implement a new event-loop that GDB would use. 1648 1649 The event-loop will eventually be made re-entrant. This is so that 1650 GDB can better handle the problem of some commands blocking instead of 1651 returning. 1652 1653 Library - `gdb.h' 1654 ----------------- 1655 1656 `libgdb' is the most obvious component of this system. It provides the 1657 query interface. Each function is parameterized by a `ui-out' builder. 1658 The result of the query is constructed using that builder before the 1659 query function returns. 1660 1661 1662 File: gdbint.info, Node: Values, Next: Stack Frames, Prev: libgdb, Up: Top 1663 1664 6 Values 1665 ******** 1666 1667 6.1 Values 1668 ========== 1669 1670 GDB uses `struct value', or "values", as an internal abstraction for 1671 the representation of a variety of inferior objects and GDB convenience 1672 objects. 1673 1674 Values have an associated `struct type', that describes a virtual 1675 view of the raw data or object stored in or accessed through the value. 1676 1677 A value is in addition discriminated by its lvalue-ness, given its 1678 `enum lval_type' enumeration type: 1679 1680 ``not_lval'' 1681 This value is not an lval. It can't be assigned to. 1682 1683 ``lval_memory'' 1684 This value represents an object in memory. 1685 1686 ``lval_register'' 1687 This value represents an object that lives in a register. 1688 1689 ``lval_internalvar'' 1690 Represents the value of an internal variable. 1691 1692 ``lval_internalvar_component'' 1693 Represents part of a GDB internal variable. E.g., a structure 1694 field. 1695 1696 ``lval_computed'' 1697 These are "computed" values. They allow creating specialized value 1698 objects for specific purposes, all abstracted away from the core 1699 value support code. The creator of such a value writes specialized 1700 functions to handle the reading and writing to/from the value's 1701 backend data, and optionally, a "copy operator" and a "destructor". 1702 1703 Pointers to these functions are stored in a `struct lval_funcs' 1704 instance (declared in `value.h'), and passed to the 1705 `allocate_computed_value' function, as in the example below. 1706 1707 static void 1708 nil_value_read (struct value *v) 1709 { 1710 /* This callback reads data from some backend, and stores it in V. 1711 In this case, we always read null data. You'll want to fill in 1712 something more interesting. */ 1713 1714 memset (value_contents_all_raw (v), 1715 value_offset (v), 1716 TYPE_LENGTH (value_type (v))); 1717 } 1718 1719 static void 1720 nil_value_write (struct value *v, struct value *fromval) 1721 { 1722 /* Takes the data from FROMVAL and stores it in the backend of V. */ 1723 1724 to_oblivion (value_contents_all_raw (fromval), 1725 value_offset (v), 1726 TYPE_LENGTH (value_type (fromval))); 1727 } 1728 1729 static struct lval_funcs nil_value_funcs = 1730 { 1731 nil_value_read, 1732 nil_value_write 1733 }; 1734 1735 struct value * 1736 make_nil_value (void) 1737 { 1738 struct type *type; 1739 struct value *v; 1740 1741 type = make_nils_type (); 1742 v = allocate_computed_value (type, &nil_value_funcs, NULL); 1743 1744 return v; 1745 } 1746 1747 See the implementation of the `$_siginfo' convenience variable in 1748 `infrun.c' as a real example use of lval_computed. 1749 1750 1751 1752 File: gdbint.info, Node: Stack Frames, Next: Symbol Handling, Prev: Values, Up: Top 1753 1754 7 Stack Frames 1755 ************** 1756 1757 A frame is a construct that GDB uses to keep track of calling and 1758 called functions. 1759 1760 GDB's frame model, a fresh design, was implemented with the need to 1761 support DWARF's Call Frame Information in mind. In fact, the term 1762 "unwind" is taken directly from that specification. Developers wishing 1763 to learn more about unwinders, are encouraged to read the DWARF 1764 specification, available from `http://www.dwarfstd.org'. 1765 1766 GDB's model is that you find a frame's registers by "unwinding" them 1767 from the next younger frame. That is, `get_frame_register' which 1768 returns the value of a register in frame #1 (the next-to-youngest 1769 frame), is implemented by calling frame #0's `frame_register_unwind' 1770 (the youngest frame). But then the obvious question is: how do you 1771 access the registers of the youngest frame itself? 1772 1773 To answer this question, GDB has the "sentinel" frame, the "-1st" 1774 frame. Unwinding registers from the sentinel frame gives you the 1775 current values of the youngest real frame's registers. If F is a 1776 sentinel frame, then `get_frame_type (F) == SENTINEL_FRAME'. 1777 1778 7.1 Selecting an Unwinder 1779 ========================= 1780 1781 The architecture registers a list of frame unwinders (`struct 1782 frame_unwind'), using the functions `frame_unwind_prepend_unwinder' and 1783 `frame_unwind_append_unwinder'. Each unwinder includes a sniffer. 1784 Whenever GDB needs to unwind a frame (to fetch the previous frame's 1785 registers or the current frame's ID), it calls registered sniffers in 1786 order to find one which recognizes the frame. The first time a sniffer 1787 returns non-zero, the corresponding unwinder is assigned to the frame. 1788 1789 7.2 Unwinding the Frame ID 1790 ========================== 1791 1792 Every frame has an associated ID, of type `struct frame_id'. The ID 1793 includes the stack base and function start address for the frame. The 1794 ID persists through the entire life of the frame, including while other 1795 called frames are running; it is used to locate an appropriate `struct 1796 frame_info' from the cache. 1797 1798 Every time the inferior stops, and at various other times, the frame 1799 cache is flushed. Because of this, parts of GDB which need to keep 1800 track of individual frames cannot use pointers to `struct frame_info'. 1801 A frame ID provides a stable reference to a frame, even when the 1802 unwinder must be run again to generate a new `struct frame_info' for 1803 the same frame. 1804 1805 The frame's unwinder's `this_id' method is called to find the ID. 1806 Note that this is different from register unwinding, where the next 1807 frame's `prev_register' is called to unwind this frame's registers. 1808 1809 Both stack base and function address are required to identify the 1810 frame, because a recursive function has the same function address for 1811 two consecutive frames and a leaf function may have the same stack 1812 address as its caller. On some platforms, a third address is part of 1813 the ID to further disambiguate frames--for instance, on IA-64 the 1814 separate register stack address is included in the ID. 1815 1816 An invalid frame ID (`outer_frame_id') returned from the `this_id' 1817 method means to stop unwinding after this frame. 1818 1819 `null_frame_id' is another invalid frame ID which should be used 1820 when there is no frame. For instance, certain breakpoints are attached 1821 to a specific frame, and that frame is identified through its frame ID 1822 (we use this to implement the "finish" command). Using `null_frame_id' 1823 as the frame ID for a given breakpoint means that the breakpoint is not 1824 specific to any frame. The `this_id' method should never return 1825 `null_frame_id'. 1826 1827 7.3 Unwinding Registers 1828 ======================= 1829 1830 Each unwinder includes a `prev_register' method. This method takes a 1831 frame, an associated cache pointer, and a register number. It returns 1832 a `struct value *' describing the requested register, as saved by this 1833 frame. This is the value of the register that is current in this 1834 frame's caller. 1835 1836 The returned value must have the same type as the register. It may 1837 have any lvalue type. In most circumstances one of these routines will 1838 generate the appropriate value: 1839 1840 `frame_unwind_got_optimized' 1841 This register was not saved. 1842 1843 `frame_unwind_got_register' 1844 This register was copied into another register in this frame. This 1845 is also used for unchanged registers; they are "copied" into the 1846 same register. 1847 1848 `frame_unwind_got_memory' 1849 This register was saved in memory. 1850 1851 `frame_unwind_got_constant' 1852 This register was not saved, but the unwinder can compute the 1853 previous value some other way. 1854 1855 `frame_unwind_got_address' 1856 Same as `frame_unwind_got_constant', except that the value is a 1857 target address. This is frequently used for the stack pointer, 1858 which is not explicitly saved but has a known offset from this 1859 frame's stack pointer. For architectures with a flat unified 1860 address space, this is generally the same as 1861 `frame_unwind_got_constant'. 1862 1863 1864 File: gdbint.info, Node: Symbol Handling, Next: Language Support, Prev: Stack Frames, Up: Top 1865 1866 8 Symbol Handling 1867 ***************** 1868 1869 Symbols are a key part of GDB's operation. Symbols include variables, 1870 functions, and types. 1871 1872 Symbol information for a large program can be truly massive, and 1873 reading of symbol information is one of the major performance 1874 bottlenecks in GDB; it can take many minutes to process it all. 1875 Studies have shown that nearly all the time spent is computational, 1876 rather than file reading. 1877 1878 One of the ways for GDB to provide a good user experience is to 1879 start up quickly, taking no more than a few seconds. It is simply not 1880 possible to process all of a program's debugging info in that time, and 1881 so we attempt to handle symbols incrementally. For instance, we create 1882 "partial symbol tables" consisting of only selected symbols, and only 1883 expand them to full symbol tables when necessary. 1884 1885 8.1 Symbol Reading 1886 ================== 1887 1888 GDB reads symbols from "symbol files". The usual symbol file is the 1889 file containing the program which GDB is debugging. GDB can be 1890 directed to use a different file for symbols (with the `symbol-file' 1891 command), and it can also read more symbols via the `add-file' and 1892 `load' commands. In addition, it may bring in more symbols while 1893 loading shared libraries. 1894 1895 Symbol files are initially opened by code in `symfile.c' using the 1896 BFD library (*note Support Libraries::). BFD identifies the type of 1897 the file by examining its header. `find_sym_fns' then uses this 1898 identification to locate a set of symbol-reading functions. 1899 1900 Symbol-reading modules identify themselves to GDB by calling 1901 `add_symtab_fns' during their module initialization. The argument to 1902 `add_symtab_fns' is a `struct sym_fns' which contains the name (or name 1903 prefix) of the symbol format, the length of the prefix, and pointers to 1904 four functions. These functions are called at various times to process 1905 symbol files whose identification matches the specified prefix. 1906 1907 The functions supplied by each module are: 1908 1909 `XYZ_symfile_init(struct sym_fns *sf)' 1910 Called from `symbol_file_add' when we are about to read a new 1911 symbol file. This function should clean up any internal state 1912 (possibly resulting from half-read previous files, for example) 1913 and prepare to read a new symbol file. Note that the symbol file 1914 which we are reading might be a new "main" symbol file, or might 1915 be a secondary symbol file whose symbols are being added to the 1916 existing symbol table. 1917 1918 The argument to `XYZ_symfile_init' is a newly allocated `struct 1919 sym_fns' whose `bfd' field contains the BFD for the new symbol 1920 file being read. Its `private' field has been zeroed, and can be 1921 modified as desired. Typically, a struct of private information 1922 will be `malloc''d, and a pointer to it will be placed in the 1923 `private' field. 1924 1925 There is no result from `XYZ_symfile_init', but it can call 1926 `error' if it detects an unavoidable problem. 1927 1928 `XYZ_new_init()' 1929 Called from `symbol_file_add' when discarding existing symbols. 1930 This function needs only handle the symbol-reading module's 1931 internal state; the symbol table data structures visible to the 1932 rest of GDB will be discarded by `symbol_file_add'. It has no 1933 arguments and no result. It may be called after 1934 `XYZ_symfile_init', if a new symbol table is being read, or may be 1935 called alone if all symbols are simply being discarded. 1936 1937 `XYZ_symfile_read(struct sym_fns *sf, CORE_ADDR addr, int mainline)' 1938 Called from `symbol_file_add' to actually read the symbols from a 1939 symbol-file into a set of psymtabs or symtabs. 1940 1941 `sf' points to the `struct sym_fns' originally passed to 1942 `XYZ_sym_init' for possible initialization. `addr' is the offset 1943 between the file's specified start address and its true address in 1944 memory. `mainline' is 1 if this is the main symbol table being 1945 read, and 0 if a secondary symbol file (e.g., shared library or 1946 dynamically loaded file) is being read. 1947 1948 In addition, if a symbol-reading module creates psymtabs when 1949 XYZ_symfile_read is called, these psymtabs will contain a pointer to a 1950 function `XYZ_psymtab_to_symtab', which can be called from any point in 1951 the GDB symbol-handling code. 1952 1953 `XYZ_psymtab_to_symtab (struct partial_symtab *pst)' 1954 Called from `psymtab_to_symtab' (or the `PSYMTAB_TO_SYMTAB' macro) 1955 if the psymtab has not already been read in and had its 1956 `pst->symtab' pointer set. The argument is the psymtab to be 1957 fleshed-out into a symtab. Upon return, `pst->readin' should have 1958 been set to 1, and `pst->symtab' should contain a pointer to the 1959 new corresponding symtab, or zero if there were no symbols in that 1960 part of the symbol file. 1961 1962 8.2 Partial Symbol Tables 1963 ========================= 1964 1965 GDB has three types of symbol tables: 1966 1967 * Full symbol tables ("symtabs"). These contain the main 1968 information about symbols and addresses. 1969 1970 * Partial symbol tables ("psymtabs"). These contain enough 1971 information to know when to read the corresponding part of the full 1972 symbol table. 1973 1974 * Minimal symbol tables ("msymtabs"). These contain information 1975 gleaned from non-debugging symbols. 1976 1977 This section describes partial symbol tables. 1978 1979 A psymtab is constructed by doing a very quick pass over an 1980 executable file's debugging information. Small amounts of information 1981 are extracted--enough to identify which parts of the symbol table will 1982 need to be re-read and fully digested later, when the user needs the 1983 information. The speed of this pass causes GDB to start up very 1984 quickly. Later, as the detailed rereading occurs, it occurs in small 1985 pieces, at various times, and the delay therefrom is mostly invisible to 1986 the user. 1987 1988 The symbols that show up in a file's psymtab should be, roughly, 1989 those visible to the debugger's user when the program is not running 1990 code from that file. These include external symbols and types, static 1991 symbols and types, and `enum' values declared at file scope. 1992 1993 The psymtab also contains the range of instruction addresses that the 1994 full symbol table would represent. 1995 1996 The idea is that there are only two ways for the user (or much of the 1997 code in the debugger) to reference a symbol: 1998 1999 * By its address (e.g., execution stops at some address which is 2000 inside a function in this file). The address will be noticed to 2001 be in the range of this psymtab, and the full symtab will be read 2002 in. `find_pc_function', `find_pc_line', and other `find_pc_...' 2003 functions handle this. 2004 2005 * By its name (e.g., the user asks to print a variable, or set a 2006 breakpoint on a function). Global names and file-scope names will 2007 be found in the psymtab, which will cause the symtab to be pulled 2008 in. Local names will have to be qualified by a global name, or a 2009 file-scope name, in which case we will have already read in the 2010 symtab as we evaluated the qualifier. Or, a local symbol can be 2011 referenced when we are "in" a local scope, in which case the first 2012 case applies. `lookup_symbol' does most of the work here. 2013 2014 The only reason that psymtabs exist is to cause a symtab to be read 2015 in at the right moment. Any symbol that can be elided from a psymtab, 2016 while still causing that to happen, should not appear in it. Since 2017 psymtabs don't have the idea of scope, you can't put local symbols in 2018 them anyway. Psymtabs don't have the idea of the type of a symbol, 2019 either, so types need not appear, unless they will be referenced by 2020 name. 2021 2022 It is a bug for GDB to behave one way when only a psymtab has been 2023 read, and another way if the corresponding symtab has been read in. 2024 Such bugs are typically caused by a psymtab that does not contain all 2025 the visible symbols, or which has the wrong instruction address ranges. 2026 2027 The psymtab for a particular section of a symbol file (objfile) 2028 could be thrown away after the symtab has been read in. The symtab 2029 should always be searched before the psymtab, so the psymtab will never 2030 be used (in a bug-free environment). Currently, psymtabs are allocated 2031 on an obstack, and all the psymbols themselves are allocated in a pair 2032 of large arrays on an obstack, so there is little to be gained by 2033 trying to free them unless you want to do a lot more work. 2034 2035 Whether or not psymtabs are created depends on the objfile's symbol 2036 reader. The core of GDB hides the details of partial symbols and 2037 partial symbol tables behind a set of function pointers known as the 2038 "quick symbol functions". These are documented in `symfile.h'. 2039 2040 8.3 Types 2041 ========= 2042 2043 Fundamental Types (e.g., `FT_VOID', `FT_BOOLEAN'). 2044 -------------------------------------------------- 2045 2046 These are the fundamental types that GDB uses internally. Fundamental 2047 types from the various debugging formats (stabs, ELF, etc) are mapped 2048 into one of these. They are basically a union of all fundamental types 2049 that GDB knows about for all the languages that GDB knows about. 2050 2051 Type Codes (e.g., `TYPE_CODE_PTR', `TYPE_CODE_ARRAY'). 2052 ------------------------------------------------------ 2053 2054 Each time GDB builds an internal type, it marks it with one of these 2055 types. The type may be a fundamental type, such as `TYPE_CODE_INT', or 2056 a derived type, such as `TYPE_CODE_PTR' which is a pointer to another 2057 type. Typically, several `FT_*' types map to one `TYPE_CODE_*' type, 2058 and are distinguished by other members of the type struct, such as 2059 whether the type is signed or unsigned, and how many bits it uses. 2060 2061 Builtin Types (e.g., `builtin_type_void', `builtin_type_char'). 2062 --------------------------------------------------------------- 2063 2064 These are instances of type structs that roughly correspond to 2065 fundamental types and are created as global types for GDB to use for 2066 various ugly historical reasons. We eventually want to eliminate 2067 these. Note for example that `builtin_type_int' initialized in 2068 `gdbtypes.c' is basically the same as a `TYPE_CODE_INT' type that is 2069 initialized in `c-lang.c' for an `FT_INTEGER' fundamental type. The 2070 difference is that the `builtin_type' is not associated with any 2071 particular objfile, and only one instance exists, while `c-lang.c' 2072 builds as many `TYPE_CODE_INT' types as needed, with each one 2073 associated with some particular objfile. 2074 2075 8.4 Object File Formats 2076 ======================= 2077 2078 8.4.1 a.out 2079 ----------- 2080 2081 The `a.out' format is the original file format for Unix. It consists 2082 of three sections: `text', `data', and `bss', which are for program 2083 code, initialized data, and uninitialized data, respectively. 2084 2085 The `a.out' format is so simple that it doesn't have any reserved 2086 place for debugging information. (Hey, the original Unix hackers used 2087 `adb', which is a machine-language debugger!) The only debugging 2088 format for `a.out' is stabs, which is encoded as a set of normal 2089 symbols with distinctive attributes. 2090 2091 The basic `a.out' reader is in `dbxread.c'. 2092 2093 8.4.2 COFF 2094 ---------- 2095 2096 The COFF format was introduced with System V Release 3 (SVR3) Unix. 2097 COFF files may have multiple sections, each prefixed by a header. The 2098 number of sections is limited. 2099 2100 The COFF specification includes support for debugging. Although this 2101 was a step forward, the debugging information was woefully limited. 2102 For instance, it was not possible to represent code that came from an 2103 included file. GNU's COFF-using configs often use stabs-type info, 2104 encapsulated in special sections. 2105 2106 The COFF reader is in `coffread.c'. 2107 2108 8.4.3 ECOFF 2109 ----------- 2110 2111 ECOFF is an extended COFF originally introduced for Mips and Alpha 2112 workstations. 2113 2114 The basic ECOFF reader is in `mipsread.c'. 2115 2116 8.4.4 XCOFF 2117 ----------- 2118 2119 The IBM RS/6000 running AIX uses an object file format called XCOFF. 2120 The COFF sections, symbols, and line numbers are used, but debugging 2121 symbols are `dbx'-style stabs whose strings are located in the `.debug' 2122 section (rather than the string table). For more information, see 2123 *note Top: (stabs)Top. 2124 2125 The shared library scheme has a clean interface for figuring out what 2126 shared libraries are in use, but the catch is that everything which 2127 refers to addresses (symbol tables and breakpoints at least) needs to be 2128 relocated for both shared libraries and the main executable. At least 2129 using the standard mechanism this can only be done once the program has 2130 been run (or the core file has been read). 2131 2132 8.4.5 PE 2133 -------- 2134 2135 Windows 95 and NT use the PE ("Portable Executable") format for their 2136 executables. PE is basically COFF with additional headers. 2137 2138 While BFD includes special PE support, GDB needs only the basic COFF 2139 reader. 2140 2141 8.4.6 ELF 2142 --------- 2143 2144 The ELF format came with System V Release 4 (SVR4) Unix. ELF is 2145 similar to COFF in being organized into a number of sections, but it 2146 removes many of COFF's limitations. Debugging info may be either stabs 2147 encapsulated in ELF sections, or more commonly these days, DWARF. 2148 2149 The basic ELF reader is in `elfread.c'. 2150 2151 8.4.7 SOM 2152 --------- 2153 2154 SOM is HP's object file and debug format (not to be confused with IBM's 2155 SOM, which is a cross-language ABI). 2156 2157 The SOM reader is in `somread.c'. 2158 2159 8.5 Debugging File Formats 2160 ========================== 2161 2162 This section describes characteristics of debugging information that 2163 are independent of the object file format. 2164 2165 8.5.1 stabs 2166 ----------- 2167 2168 `stabs' started out as special symbols within the `a.out' format. 2169 Since then, it has been encapsulated into other file formats, such as 2170 COFF and ELF. 2171 2172 While `dbxread.c' does some of the basic stab processing, including 2173 for encapsulated versions, `stabsread.c' does the real work. 2174 2175 8.5.2 COFF 2176 ---------- 2177 2178 The basic COFF definition includes debugging information. The level of 2179 support is minimal and non-extensible, and is not often used. 2180 2181 8.5.3 Mips debug (Third Eye) 2182 ---------------------------- 2183 2184 ECOFF includes a definition of a special debug format. 2185 2186 The file `mdebugread.c' implements reading for this format. 2187 2188 8.5.4 DWARF 2 2189 ------------- 2190 2191 DWARF 2 is an improved but incompatible version of DWARF 1. 2192 2193 The DWARF 2 reader is in `dwarf2read.c'. 2194 2195 8.5.5 Compressed DWARF 2 2196 ------------------------ 2197 2198 Compressed DWARF 2 is not technically a separate debugging format, but 2199 merely DWARF 2 debug information that has been compressed. In this 2200 format, every object-file section holding DWARF 2 debugging information 2201 is compressed and prepended with a header. (The section is also 2202 typically renamed, so a section called `.debug_info' in a DWARF 2 2203 binary would be called `.zdebug_info' in a compressed DWARF 2 binary.) 2204 The header is 12 bytes long: 2205 2206 * 4 bytes: the literal string "ZLIB" 2207 2208 * 8 bytes: the uncompressed size of the section, in big-endian byte 2209 order. 2210 2211 The same reader is used for both compressed an normal DWARF 2 info. 2212 Section decompression is done in `zlib_decompress_section' in 2213 `dwarf2read.c'. 2214 2215 8.5.6 DWARF 3 2216 ------------- 2217 2218 DWARF 3 is an improved version of DWARF 2. 2219 2220 8.5.7 SOM 2221 --------- 2222 2223 Like COFF, the SOM definition includes debugging information. 2224 2225 8.6 Adding a New Symbol Reader to GDB 2226 ===================================== 2227 2228 If you are using an existing object file format (`a.out', COFF, ELF, 2229 etc), there is probably little to be done. 2230 2231 If you need to add a new object file format, you must first add it to 2232 BFD. This is beyond the scope of this document. 2233 2234 You must then arrange for the BFD code to provide access to the 2235 debugging symbols. Generally GDB will have to call swapping routines 2236 from BFD and a few other BFD internal routines to locate the debugging 2237 information. As much as possible, GDB should not depend on the BFD 2238 internal data structures. 2239 2240 For some targets (e.g., COFF), there is a special transfer vector 2241 used to call swapping routines, since the external data structures on 2242 various platforms have different sizes and layouts. Specialized 2243 routines that will only ever be implemented by one object file format 2244 may be called directly. This interface should be described in a file 2245 `bfd/libXYZ.h', which is included by GDB. 2246 2247 8.7 Memory Management for Symbol Files 2248 ====================================== 2249 2250 Most memory associated with a loaded symbol file is stored on its 2251 `objfile_obstack'. This includes symbols, types, namespace data, and 2252 other information produced by the symbol readers. 2253 2254 Because this data lives on the objfile's obstack, it is automatically 2255 released when the objfile is unloaded or reloaded. Therefore one 2256 objfile must not reference symbol or type data from another objfile; 2257 they could be unloaded at different times. 2258 2259 User convenience variables, et cetera, have associated types. 2260 Normally these types live in the associated objfile. However, when the 2261 objfile is unloaded, those types are deep copied to global memory, so 2262 that the values of the user variables and history items are not lost. 2263 2264 2265 File: gdbint.info, Node: Language Support, Next: Host Definition, Prev: Symbol Handling, Up: Top 2266 2267 9 Language Support 2268 ****************** 2269 2270 GDB's language support is mainly driven by the symbol reader, although 2271 it is possible for the user to set the source language manually. 2272 2273 GDB chooses the source language by looking at the extension of the 2274 file recorded in the debug info; `.c' means C, `.f' means Fortran, etc. 2275 It may also use a special-purpose language identifier if the debug 2276 format supports it, like with DWARF. 2277 2278 9.1 Adding a Source Language to GDB 2279 =================================== 2280 2281 To add other languages to GDB's expression parser, follow the following 2282 steps: 2283 2284 _Create the expression parser._ 2285 This should reside in a file `LANG-exp.y'. Routines for building 2286 parsed expressions into a `union exp_element' list are in 2287 `parse.c'. 2288 2289 Since we can't depend upon everyone having Bison, and YACC produces 2290 parsers that define a bunch of global names, the following lines 2291 *must* be included at the top of the YACC parser, to prevent the 2292 various parsers from defining the same global names: 2293 2294 #define yyparse LANG_parse 2295 #define yylex LANG_lex 2296 #define yyerror LANG_error 2297 #define yylval LANG_lval 2298 #define yychar LANG_char 2299 #define yydebug LANG_debug 2300 #define yypact LANG_pact 2301 #define yyr1 LANG_r1 2302 #define yyr2 LANG_r2 2303 #define yydef LANG_def 2304 #define yychk LANG_chk 2305 #define yypgo LANG_pgo 2306 #define yyact LANG_act 2307 #define yyexca LANG_exca 2308 #define yyerrflag LANG_errflag 2309 #define yynerrs LANG_nerrs 2310 2311 At the bottom of your parser, define a `struct language_defn' and 2312 initialize it with the right values for your language. Define an 2313 `initialize_LANG' routine and have it call 2314 `add_language(LANG_language_defn)' to tell the rest of GDB that 2315 your language exists. You'll need some other supporting variables 2316 and functions, which will be used via pointers from your 2317 `LANG_language_defn'. See the declaration of `struct 2318 language_defn' in `language.h', and the other `*-exp.y' files, for 2319 more information. 2320 2321 _Add any evaluation routines, if necessary_ 2322 If you need new opcodes (that represent the operations of the 2323 language), add them to the enumerated type in `expression.h'. Add 2324 support code for these operations in the `evaluate_subexp' function 2325 defined in the file `eval.c'. Add cases for new opcodes in two 2326 functions from `parse.c': `prefixify_subexp' and 2327 `length_of_subexp'. These compute the number of `exp_element's 2328 that a given operation takes up. 2329 2330 _Update some existing code_ 2331 Add an enumerated identifier for your language to the enumerated 2332 type `enum language' in `defs.h'. 2333 2334 Update the routines in `language.c' so your language is included. 2335 These routines include type predicates and such, which (in some 2336 cases) are language dependent. If your language does not appear 2337 in the switch statement, an error is reported. 2338 2339 Also included in `language.c' is the code that updates the variable 2340 `current_language', and the routines that translate the 2341 `language_LANG' enumerated identifier into a printable string. 2342 2343 Update the function `_initialize_language' to include your 2344 language. This function picks the default language upon startup, 2345 so is dependent upon which languages that GDB is built for. 2346 2347 Update `allocate_symtab' in `symfile.c' and/or symbol-reading code 2348 so that the language of each symtab (source file) is set properly. 2349 This is used to determine the language to use at each stack frame 2350 level. Currently, the language is set based upon the extension of 2351 the source file. If the language can be better inferred from the 2352 symbol information, please set the language of the symtab in the 2353 symbol-reading code. 2354 2355 Add helper code to `print_subexp' (in `expprint.c') to handle any 2356 new expression opcodes you have added to `expression.h'. Also, 2357 add the printed representations of your operators to 2358 `op_print_tab'. 2359 2360 _Add a place of call_ 2361 Add a call to `LANG_parse()' and `LANG_error' in `parse_exp_1' 2362 (defined in `parse.c'). 2363 2364 _Edit `Makefile.in'_ 2365 Add dependencies in `Makefile.in'. Make sure you update the macro 2366 variables such as `HFILES' and `OBJS', otherwise your code may not 2367 get linked in, or, worse yet, it may not get `tar'red into the 2368 distribution! 2369 2370 2371 File: gdbint.info, Node: Host Definition, Next: Target Architecture Definition, Prev: Language Support, Up: Top 2372 2373 10 Host Definition 2374 ****************** 2375 2376 With the advent of Autoconf, it's rarely necessary to have host 2377 definition machinery anymore. The following information is provided, 2378 mainly, as an historical reference. 2379 2380 10.1 Adding a New Host 2381 ====================== 2382 2383 GDB's host configuration support normally happens via Autoconf. New 2384 host-specific definitions should not be needed. Older hosts GDB still 2385 use the host-specific definitions and files listed below, but these 2386 mostly exist for historical reasons, and will eventually disappear. 2387 2388 `gdb/config/ARCH/XYZ.mh' 2389 This file is a Makefile fragment that once contained both host and 2390 native configuration information (*note Native Debugging::) for the 2391 machine XYZ. The host configuration information is now handled by 2392 Autoconf. 2393 2394 Host configuration information included definitions for `CC', 2395 `SYSV_DEFINE', `XM_CFLAGS', `XM_ADD_FILES', `XM_CLIBS', 2396 `XM_CDEPS', etc.; see `Makefile.in'. 2397 2398 New host-only configurations do not need this file. 2399 2400 2401 (Files named `gdb/config/ARCH/xm-XYZ.h' were once used to define 2402 host-specific macros, but were no longer needed and have all been 2403 removed.) 2404 2405 Generic Host Support Files 2406 -------------------------- 2407 2408 There are some "generic" versions of routines that can be used by 2409 various systems. 2410 2411 `ser-unix.c' 2412 This contains serial line support for Unix systems. It is 2413 included by default on all Unix-like hosts. 2414 2415 `ser-pipe.c' 2416 This contains serial pipe support for Unix systems. It is 2417 included by default on all Unix-like hosts. 2418 2419 `ser-mingw.c' 2420 This contains serial line support for 32-bit programs running under 2421 Windows using MinGW. 2422 2423 `ser-go32.c' 2424 This contains serial line support for 32-bit programs running 2425 under DOS, using the DJGPP (a.k.a. GO32) execution environment. 2426 2427 `ser-tcp.c' 2428 This contains generic TCP support using sockets. It is included by 2429 default on all Unix-like hosts and with MinGW. 2430 2431 10.2 Host Conditionals 2432 ====================== 2433 2434 When GDB is configured and compiled, various macros are defined or left 2435 undefined, to control compilation based on the attributes of the host 2436 system. While formerly they could be set in host-specific header 2437 files, at present they can be changed only by setting `CFLAGS' when 2438 building, or by editing the source code. 2439 2440 These macros and their meanings (or if the meaning is not documented 2441 here, then one of the source files where they are used is indicated) 2442 are: 2443 2444 `GDBINIT_FILENAME' 2445 The default name of GDB's initialization file (normally 2446 `.gdbinit'). 2447 2448 `SIGWINCH_HANDLER' 2449 If your host defines `SIGWINCH', you can define this to be the name 2450 of a function to be called if `SIGWINCH' is received. 2451 2452 `SIGWINCH_HANDLER_BODY' 2453 Define this to expand into code that will define the function 2454 named by the expansion of `SIGWINCH_HANDLER'. 2455 2456 `CRLF_SOURCE_FILES' 2457 Define this if host files use `\r\n' rather than `\n' as a line 2458 terminator. This will cause source file listings to omit `\r' 2459 characters when printing and it will allow `\r\n' line endings of 2460 files which are "sourced" by gdb. It must be possible to open 2461 files in binary mode using `O_BINARY' or, for fopen, `"rb"'. 2462 2463 `DEFAULT_PROMPT' 2464 The default value of the prompt string (normally `"(gdb) "'). 2465 2466 `DEV_TTY' 2467 The name of the generic TTY device, defaults to `"/dev/tty"'. 2468 2469 `ISATTY' 2470 Substitute for isatty, if not available. 2471 2472 `FOPEN_RB' 2473 Define this if binary files are opened the same way as text files. 2474 2475 `CC_HAS_LONG_LONG' 2476 Define this if the host C compiler supports `long long'. This is 2477 set by the `configure' script. 2478 2479 `PRINTF_HAS_LONG_LONG' 2480 Define this if the host can handle printing of long long integers 2481 via the printf format conversion specifier `ll'. This is set by 2482 the `configure' script. 2483 2484 `LSEEK_NOT_LINEAR' 2485 Define this if `lseek (n)' does not necessarily move to byte number 2486 `n' in the file. This is only used when reading source files. It 2487 is normally faster to define `CRLF_SOURCE_FILES' when possible. 2488 2489 `lint' 2490 Define this to help placate `lint' in some situations. 2491 2492 `volatile' 2493 Define this to override the defaults of `__volatile__' or `/**/'. 2494 2495 2496 File: gdbint.info, Node: Target Architecture Definition, Next: Target Descriptions, Prev: Host Definition, Up: Top 2497 2498 11 Target Architecture Definition 2499 ********************************* 2500 2501 GDB's target architecture defines what sort of machine-language 2502 programs GDB can work with, and how it works with them. 2503 2504 The target architecture object is implemented as the C structure 2505 `struct gdbarch *'. The structure, and its methods, are generated 2506 using the Bourne shell script `gdbarch.sh'. 2507 2508 * Menu: 2509 2510 * OS ABI Variant Handling:: 2511 * Initialize New Architecture:: 2512 * Registers and Memory:: 2513 * Pointers and Addresses:: 2514 * Address Classes:: 2515 * Register Representation:: 2516 * Frame Interpretation:: 2517 * Inferior Call Setup:: 2518 * Adding support for debugging core files:: 2519 * Defining Other Architecture Features:: 2520 * Adding a New Target:: 2521 2522 2523 File: gdbint.info, Node: OS ABI Variant Handling, Next: Initialize New Architecture, Up: Target Architecture Definition 2524 2525 11.1 Operating System ABI Variant Handling 2526 ========================================== 2527 2528 GDB provides a mechanism for handling variations in OS ABIs. An OS ABI 2529 variant may have influence over any number of variables in the target 2530 architecture definition. There are two major components in the OS ABI 2531 mechanism: sniffers and handlers. 2532 2533 A "sniffer" examines a file matching a BFD architecture/flavour pair 2534 (the architecture may be wildcarded) in an attempt to determine the OS 2535 ABI of that file. Sniffers with a wildcarded architecture are 2536 considered to be "generic", while sniffers for a specific architecture 2537 are considered to be "specific". A match from a specific sniffer 2538 overrides a match from a generic sniffer. Multiple sniffers for an 2539 architecture/flavour may exist, in order to differentiate between two 2540 different operating systems which use the same basic file format. The 2541 OS ABI framework provides a generic sniffer for ELF-format files which 2542 examines the `EI_OSABI' field of the ELF header, as well as note 2543 sections known to be used by several operating systems. 2544 2545 A "handler" is used to fine-tune the `gdbarch' structure for the 2546 selected OS ABI. There may be only one handler for a given OS ABI for 2547 each BFD architecture. 2548 2549 The following OS ABI variants are defined in `defs.h': 2550 2551 `GDB_OSABI_UNINITIALIZED' 2552 Used for struct gdbarch_info if ABI is still uninitialized. 2553 2554 `GDB_OSABI_UNKNOWN' 2555 The ABI of the inferior is unknown. The default `gdbarch' 2556 settings for the architecture will be used. 2557 2558 `GDB_OSABI_SVR4' 2559 UNIX System V Release 4. 2560 2561 `GDB_OSABI_HURD' 2562 GNU using the Hurd kernel. 2563 2564 `GDB_OSABI_SOLARIS' 2565 Sun Solaris. 2566 2567 `GDB_OSABI_OSF1' 2568 OSF/1, including Digital UNIX and Compaq Tru64 UNIX. 2569 2570 `GDB_OSABI_LINUX' 2571 GNU using the Linux kernel. 2572 2573 `GDB_OSABI_FREEBSD_AOUT' 2574 FreeBSD using the `a.out' executable format. 2575 2576 `GDB_OSABI_FREEBSD_ELF' 2577 FreeBSD using the ELF executable format. 2578 2579 `GDB_OSABI_NETBSD_AOUT' 2580 NetBSD using the `a.out' executable format. 2581 2582 `GDB_OSABI_NETBSD_ELF' 2583 NetBSD using the ELF executable format. 2584 2585 `GDB_OSABI_OPENBSD_ELF' 2586 OpenBSD using the ELF executable format. 2587 2588 `GDB_OSABI_WINCE' 2589 Windows CE. 2590 2591 `GDB_OSABI_GO32' 2592 DJGPP. 2593 2594 `GDB_OSABI_IRIX' 2595 Irix. 2596 2597 `GDB_OSABI_INTERIX' 2598 Interix (Posix layer for MS-Windows systems). 2599 2600 `GDB_OSABI_HPUX_ELF' 2601 HP/UX using the ELF executable format. 2602 2603 `GDB_OSABI_HPUX_SOM' 2604 HP/UX using the SOM executable format. 2605 2606 `GDB_OSABI_QNXNTO' 2607 QNX Neutrino. 2608 2609 `GDB_OSABI_CYGWIN' 2610 Cygwin. 2611 2612 `GDB_OSABI_AIX' 2613 AIX. 2614 2615 2616 Here are the functions that make up the OS ABI framework: 2617 2618 -- Function: const char * gdbarch_osabi_name (enum gdb_osabi OSABI) 2619 Return the name of the OS ABI corresponding to OSABI. 2620 2621 -- Function: void gdbarch_register_osabi (enum bfd_architecture ARCH, 2622 unsigned long MACHINE, enum gdb_osabi OSABI, void 2623 (*INIT_OSABI)(struct gdbarch_info INFO, struct gdbarch 2624 *GDBARCH)) 2625 Register the OS ABI handler specified by INIT_OSABI for the 2626 architecture, machine type and OS ABI specified by ARCH, MACHINE 2627 and OSABI. In most cases, a value of zero for the machine type, 2628 which implies the architecture's default machine type, will 2629 suffice. 2630 2631 -- Function: void gdbarch_register_osabi_sniffer (enum 2632 bfd_architecture ARCH, enum bfd_flavour FLAVOUR, enum 2633 gdb_osabi (*SNIFFER)(bfd *ABFD)) 2634 Register the OS ABI file sniffer specified by SNIFFER for the BFD 2635 architecture/flavour pair specified by ARCH and FLAVOUR. If ARCH 2636 is `bfd_arch_unknown', the sniffer is considered to be generic, 2637 and is allowed to examine FLAVOUR-flavoured files for any 2638 architecture. 2639 2640 -- Function: enum gdb_osabi gdbarch_lookup_osabi (bfd *ABFD) 2641 Examine the file described by ABFD to determine its OS ABI. The 2642 value `GDB_OSABI_UNKNOWN' is returned if the OS ABI cannot be 2643 determined. 2644 2645 -- Function: void gdbarch_init_osabi (struct gdbarch info INFO, struct 2646 gdbarch *GDBARCH, enum gdb_osabi OSABI) 2647 Invoke the OS ABI handler corresponding to OSABI to fine-tune the 2648 `gdbarch' structure specified by GDBARCH. If a handler 2649 corresponding to OSABI has not been registered for GDBARCH's 2650 architecture, a warning will be issued and the debugging session 2651 will continue with the defaults already established for GDBARCH. 2652 2653 -- Function: void generic_elf_osabi_sniff_abi_tag_sections (bfd *ABFD, 2654 asection *SECT, void *OBJ) 2655 Helper routine for ELF file sniffers. Examine the file described 2656 by ABFD and look at ABI tag note sections to determine the OS ABI 2657 from the note. This function should be called via 2658 `bfd_map_over_sections'. 2659 2660 2661 File: gdbint.info, Node: Initialize New Architecture, Next: Registers and Memory, Prev: OS ABI Variant Handling, Up: Target Architecture Definition 2662 2663 11.2 Initializing a New Architecture 2664 ==================================== 2665 2666 * Menu: 2667 2668 * How an Architecture is Represented:: 2669 * Looking Up an Existing Architecture:: 2670 * Creating a New Architecture:: 2671 2672 2673 File: gdbint.info, Node: How an Architecture is Represented, Next: Looking Up an Existing Architecture, Up: Initialize New Architecture 2674 2675 11.2.1 How an Architecture is Represented 2676 ----------------------------------------- 2677 2678 Each `gdbarch' is associated with a single BFD architecture, via a 2679 `bfd_arch_ARCH' in the `bfd_architecture' enumeration. The `gdbarch' 2680 is registered by a call to `register_gdbarch_init', usually from the 2681 file's `_initialize_FILENAME' routine, which will be automatically 2682 called during GDB startup. The arguments are a BFD architecture 2683 constant and an initialization function. 2684 2685 A GDB description for a new architecture, ARCH is created by 2686 defining a global function `_initialize_ARCH_tdep', by convention in 2687 the source file `ARCH-tdep.c'. For example, in the case of the 2688 OpenRISC 1000, this function is called `_initialize_or1k_tdep' and is 2689 found in the file `or1k-tdep.c'. 2690 2691 The resulting object files containing the implementation of the 2692 `_initialize_ARCH_tdep' function are specified in the GDB 2693 `configure.tgt' file, which includes a large case statement pattern 2694 matching against the `--target' option of the `configure' script. The 2695 new `struct gdbarch' is created within the `_initialize_ARCH_tdep' 2696 function by calling `gdbarch_register': 2697 2698 void gdbarch_register (enum bfd_architecture ARCHITECTURE, 2699 gdbarch_init_ftype *INIT_FUNC, 2700 gdbarch_dump_tdep_ftype *TDEP_DUMP_FUNC); 2701 2702 The ARCHITECTURE will identify the unique BFD to be associated with 2703 this `gdbarch'. The INIT_FUNC funciton is called to create and return 2704 the new `struct gdbarch'. The TDEP_DUMP_FUNC function will dump the 2705 target specific details associated with this architecture. 2706 2707 For example the function `_initialize_or1k_tdep' creates its 2708 architecture for 32-bit OpenRISC 1000 architectures by calling: 2709 2710 gdbarch_register (bfd_arch_or32, or1k_gdbarch_init, or1k_dump_tdep); 2711 2712 2713 File: gdbint.info, Node: Looking Up an Existing Architecture, Next: Creating a New Architecture, Prev: How an Architecture is Represented, Up: Initialize New Architecture 2714 2715 11.2.2 Looking Up an Existing Architecture 2716 ------------------------------------------ 2717 2718 The initialization function has this prototype: 2719 2720 static struct gdbarch * 2721 ARCH_gdbarch_init (struct gdbarch_info INFO, 2722 struct gdbarch_list *ARCHES) 2723 2724 The INFO argument contains parameters used to select the correct 2725 architecture, and ARCHES is a list of architectures which have already 2726 been created with the same `bfd_arch_ARCH' value. 2727 2728 The initialization function should first make sure that INFO is 2729 acceptable, and return `NULL' if it is not. Then, it should search 2730 through ARCHES for an exact match to INFO, and return one if found. 2731 Lastly, if no exact match was found, it should create a new 2732 architecture based on INFO and return it. 2733 2734 The lookup is done using `gdbarch_list_lookup_by_info'. It is 2735 passed the list of existing architectures, ARCHES, and the `struct 2736 gdbarch_info', INFO, and returns the first matching architecture it 2737 finds, or `NULL' if none are found. If an architecture is found it can 2738 be returned as the result from the initialization function, otherwise a 2739 new `struct gdbach' will need to be created. 2740 2741 The struct gdbarch_info has the following components: 2742 2743 struct gdbarch_info 2744 { 2745 const struct bfd_arch_info *bfd_arch_info; 2746 int byte_order; 2747 bfd *abfd; 2748 struct gdbarch_tdep_info *tdep_info; 2749 enum gdb_osabi osabi; 2750 const struct target_desc *target_desc; 2751 }; 2752 2753 The `bfd_arch_info' member holds the key details about the 2754 architecture. The `byte_order' member is a value in an enumeration 2755 indicating the endianism. The `abfd' member is a pointer to the full 2756 BFD, the `tdep_info' member is additional custom target specific 2757 information, `osabi' identifies which (if any) of a number of operating 2758 specific ABIs are used by this architecture and the `target_desc' 2759 member is a set of name-value pairs with information about register 2760 usage in this target. 2761 2762 When the `struct gdbarch' initialization function is called, not all 2763 the fields are provided--only those which can be deduced from the BFD. 2764 The `struct gdbarch_info', INFO is used as a look-up key with the list 2765 of existing architectures, ARCHES to see if a suitable architecture 2766 already exists. The TDEP_INFO, OSABI and TARGET_DESC fields may be 2767 added before this lookup to refine the search. 2768 2769 Only information in INFO should be used to choose the new 2770 architecture. Historically, INFO could be sparse, and defaults would 2771 be collected from the first element on ARCHES. However, GDB now fills 2772 in INFO more thoroughly, so new `gdbarch' initialization functions 2773 should not take defaults from ARCHES. 2774 2775 2776 File: gdbint.info, Node: Creating a New Architecture, Prev: Looking Up an Existing Architecture, Up: Initialize New Architecture 2777 2778 11.2.3 Creating a New Architecture 2779 ---------------------------------- 2780 2781 If no architecture is found, then a new architecture must be created, 2782 by calling `gdbarch_alloc' using the supplied `struct gdbarch_info' and 2783 any additional custom target specific information in a `struct 2784 gdbarch_tdep'. The prototype for `gdbarch_alloc' is: 2785 2786 struct gdbarch *gdbarch_alloc (const struct gdbarch_info *INFO, 2787 struct gdbarch_tdep *TDEP); 2788 2789 The newly created struct gdbarch must then be populated. Although 2790 there are default values, in most cases they are not what is required. 2791 2792 For each element, X, there is are a pair of corresponding accessor 2793 functions, one to set the value of that element, `set_gdbarch_X', the 2794 second to either get the value of an element (if it is a variable) or 2795 to apply the element (if it is a function), `gdbarch_X'. Note that 2796 both accessor functions take a pointer to the `struct gdbarch' as first 2797 argument. Populating the new `gdbarch' should use the `set_gdbarch' 2798 functions. 2799 2800 The following sections identify the main elements that should be set 2801 in this way. This is not the complete list, but represents the 2802 functions and elements that must commonly be specified for a new 2803 architecture. Many of the functions and variables are described in the 2804 header file `gdbarch.h'. 2805 2806 This is the main work in defining a new architecture. Implementing 2807 the set of functions to populate the `struct gdbarch'. 2808 2809 `struct gdbarch_tdep' is not defined within GDB--it is up to the 2810 user to define this struct if it is needed to hold custom target 2811 information that is not covered by the standard `struct gdbarch'. For 2812 example with the OpenRISC 1000 architecture it is used to hold the 2813 number of matchpoints available in the target (along with other 2814 information). 2815 2816 If there is no additional target specific information, it can be set 2817 to `NULL'. 2818 2819 2820 File: gdbint.info, Node: Registers and Memory, Next: Pointers and Addresses, Prev: Initialize New Architecture, Up: Target Architecture Definition 2821 2822 11.3 Registers and Memory 2823 ========================= 2824 2825 GDB's model of the target machine is rather simple. GDB assumes the 2826 machine includes a bank of registers and a block of memory. Each 2827 register may have a different size. 2828 2829 GDB does not have a magical way to match up with the compiler's idea 2830 of which registers are which; however, it is critical that they do 2831 match up accurately. The only way to make this work is to get accurate 2832 information about the order that the compiler uses, and to reflect that 2833 in the `gdbarch_register_name' and related functions. 2834 2835 GDB can handle big-endian, little-endian, and bi-endian 2836 architectures. 2837 2838 2839 File: gdbint.info, Node: Pointers and Addresses, Next: Address Classes, Prev: Registers and Memory, Up: Target Architecture Definition 2840 2841 11.4 Pointers Are Not Always Addresses 2842 ====================================== 2843 2844 On almost all 32-bit architectures, the representation of a pointer is 2845 indistinguishable from the representation of some fixed-length number 2846 whose value is the byte address of the object pointed to. On such 2847 machines, the words "pointer" and "address" can be used interchangeably. 2848 However, architectures with smaller word sizes are often cramped for 2849 address space, so they may choose a pointer representation that breaks 2850 this identity, and allows a larger code address space. 2851 2852 For example, the Renesas D10V is a 16-bit VLIW processor whose 2853 instructions are 32 bits long(1). If the D10V used ordinary byte 2854 addresses to refer to code locations, then the processor would only be 2855 able to address 64kb of instructions. However, since instructions must 2856 be aligned on four-byte boundaries, the low two bits of any valid 2857 instruction's byte address are always zero--byte addresses waste two 2858 bits. So instead of byte addresses, the D10V uses word addresses--byte 2859 addresses shifted right two bits--to refer to code. Thus, the D10V can 2860 use 16-bit words to address 256kb of code space. 2861 2862 However, this means that code pointers and data pointers have 2863 different forms on the D10V. The 16-bit word `0xC020' refers to byte 2864 address `0xC020' when used as a data address, but refers to byte address 2865 `0x30080' when used as a code address. 2866 2867 (The D10V also uses separate code and data address spaces, which also 2868 affects the correspondence between pointers and addresses, but we're 2869 going to ignore that here; this example is already too long.) 2870 2871 To cope with architectures like this--the D10V is not the only 2872 one!--GDB tries to distinguish between "addresses", which are byte 2873 numbers, and "pointers", which are the target's representation of an 2874 address of a particular type of data. In the example above, `0xC020' 2875 is the pointer, which refers to one of the addresses `0xC020' or 2876 `0x30080', depending on the type imposed upon it. GDB provides 2877 functions for turning a pointer into an address and vice versa, in the 2878 appropriate way for the current architecture. 2879 2880 Unfortunately, since addresses and pointers are identical on almost 2881 all processors, this distinction tends to bit-rot pretty quickly. Thus, 2882 each time you port GDB to an architecture which does distinguish 2883 between pointers and addresses, you'll probably need to clean up some 2884 architecture-independent code. 2885 2886 Here are functions which convert between pointers and addresses: 2887 2888 -- Function: CORE_ADDR extract_typed_address (void *BUF, struct type 2889 *TYPE) 2890 Treat the bytes at BUF as a pointer or reference of type TYPE, and 2891 return the address it represents, in a manner appropriate for the 2892 current architecture. This yields an address GDB can use to read 2893 target memory, disassemble, etc. Note that BUF refers to a buffer 2894 in GDB's memory, not the inferior's. 2895 2896 For example, if the current architecture is the Intel x86, this 2897 function extracts a little-endian integer of the appropriate 2898 length from BUF and returns it. However, if the current 2899 architecture is the D10V, this function will return a 16-bit 2900 integer extracted from BUF, multiplied by four if TYPE is a 2901 pointer to a function. 2902 2903 If TYPE is not a pointer or reference type, then this function 2904 will signal an internal error. 2905 2906 -- Function: CORE_ADDR store_typed_address (void *BUF, struct type 2907 *TYPE, CORE_ADDR ADDR) 2908 Store the address ADDR in BUF, in the proper format for a pointer 2909 of type TYPE in the current architecture. Note that BUF refers to 2910 a buffer in GDB's memory, not the inferior's. 2911 2912 For example, if the current architecture is the Intel x86, this 2913 function stores ADDR unmodified as a little-endian integer of the 2914 appropriate length in BUF. However, if the current architecture 2915 is the D10V, this function divides ADDR by four if TYPE is a 2916 pointer to a function, and then stores it in BUF. 2917 2918 If TYPE is not a pointer or reference type, then this function 2919 will signal an internal error. 2920 2921 -- Function: CORE_ADDR value_as_address (struct value *VAL) 2922 Assuming that VAL is a pointer, return the address it represents, 2923 as appropriate for the current architecture. 2924 2925 This function actually works on integral values, as well as 2926 pointers. For pointers, it performs architecture-specific 2927 conversions as described above for `extract_typed_address'. 2928 2929 -- Function: CORE_ADDR value_from_pointer (struct type *TYPE, 2930 CORE_ADDR ADDR) 2931 Create and return a value representing a pointer of type TYPE to 2932 the address ADDR, as appropriate for the current architecture. 2933 This function performs architecture-specific conversions as 2934 described above for `store_typed_address'. 2935 2936 Here are two functions which architectures can define to indicate the 2937 relationship between pointers and addresses. These have default 2938 definitions, appropriate for architectures on which all pointers are 2939 simple unsigned byte addresses. 2940 2941 -- Function: CORE_ADDR gdbarch_pointer_to_address (struct gdbarch 2942 *GDBARCH, struct type *TYPE, char *BUF) 2943 Assume that BUF holds a pointer of type TYPE, in the appropriate 2944 format for the current architecture. Return the byte address the 2945 pointer refers to. 2946 2947 This function may safely assume that TYPE is either a pointer or a 2948 C++ reference type. 2949 2950 -- Function: void gdbarch_address_to_pointer (struct gdbarch *GDBARCH, 2951 struct type *TYPE, char *BUF, CORE_ADDR ADDR) 2952 Store in BUF a pointer of type TYPE representing the address ADDR, 2953 in the appropriate format for the current architecture. 2954 2955 This function may safely assume that TYPE is either a pointer or a 2956 C++ reference type. 2957 2958 ---------- Footnotes ---------- 2959 2960 (1) Some D10V instructions are actually pairs of 16-bit 2961 sub-instructions. However, since you can't jump into the middle of 2962 such a pair, code addresses can only refer to full 32 bit instructions, 2963 which is what matters in this explanation. 2964 2965 2966 File: gdbint.info, Node: Address Classes, Next: Register Representation, Prev: Pointers and Addresses, Up: Target Architecture Definition 2967 2968 11.5 Address Classes 2969 ==================== 2970 2971 Sometimes information about different kinds of addresses is available 2972 via the debug information. For example, some programming environments 2973 define addresses of several different sizes. If the debug information 2974 distinguishes these kinds of address classes through either the size 2975 info (e.g, `DW_AT_byte_size' in DWARF 2) or through an explicit address 2976 class attribute (e.g, `DW_AT_address_class' in DWARF 2), the following 2977 macros should be defined in order to disambiguate these types within 2978 GDB as well as provide the added information to a GDB user when 2979 printing type expressions. 2980 2981 -- Function: int gdbarch_address_class_type_flags (struct gdbarch 2982 *GDBARCH, int BYTE_SIZE, int DWARF2_ADDR_CLASS) 2983 Returns the type flags needed to construct a pointer type whose 2984 size is BYTE_SIZE and whose address class is DWARF2_ADDR_CLASS. 2985 This function is normally called from within a symbol reader. See 2986 `dwarf2read.c'. 2987 2988 -- Function: char * gdbarch_address_class_type_flags_to_name (struct 2989 gdbarch *GDBARCH, int TYPE_FLAGS) 2990 Given the type flags representing an address class qualifier, 2991 return its name. 2992 2993 -- Function: int gdbarch_address_class_name_to_type_flags (struct 2994 gdbarch *GDBARCH, int NAME, int *TYPE_FLAGS_PTR) 2995 Given an address qualifier name, set the `int' referenced by 2996 TYPE_FLAGS_PTR to the type flags for that address class qualifier. 2997 2998 Since the need for address classes is rather rare, none of the 2999 address class functions are defined by default. Predicate functions 3000 are provided to detect when they are defined. 3001 3002 Consider a hypothetical architecture in which addresses are normally 3003 32-bits wide, but 16-bit addresses are also supported. Furthermore, 3004 suppose that the DWARF 2 information for this architecture simply uses 3005 a `DW_AT_byte_size' value of 2 to indicate the use of one of these 3006 "short" pointers. The following functions could be defined to 3007 implement the address class functions: 3008 3009 somearch_address_class_type_flags (int byte_size, 3010 int dwarf2_addr_class) 3011 { 3012 if (byte_size == 2) 3013 return TYPE_FLAG_ADDRESS_CLASS_1; 3014 else 3015 return 0; 3016 } 3017 3018 static char * 3019 somearch_address_class_type_flags_to_name (int type_flags) 3020 { 3021 if (type_flags & TYPE_FLAG_ADDRESS_CLASS_1) 3022 return "short"; 3023 else 3024 return NULL; 3025 } 3026 3027 int 3028 somearch_address_class_name_to_type_flags (char *name, 3029 int *type_flags_ptr) 3030 { 3031 if (strcmp (name, "short") == 0) 3032 { 3033 *type_flags_ptr = TYPE_FLAG_ADDRESS_CLASS_1; 3034 return 1; 3035 } 3036 else 3037 return 0; 3038 } 3039 3040 The qualifier `@short' is used in GDB's type expressions to indicate 3041 the presence of one of these "short" pointers. For example if the 3042 debug information indicates that `short_ptr_var' is one of these short 3043 pointers, GDB might show the following behavior: 3044 3045 (gdb) ptype short_ptr_var 3046 type = int * @short 3047 3048 3049 File: gdbint.info, Node: Register Representation, Next: Frame Interpretation, Prev: Address Classes, Up: Target Architecture Definition 3050 3051 11.6 Register Representation 3052 ============================ 3053 3054 * Menu: 3055 3056 * Raw and Cooked Registers:: 3057 * Register Architecture Functions & Variables:: 3058 * Register Information Functions:: 3059 * Register and Memory Data:: 3060 * Register Caching:: 3061 3062 3063 File: gdbint.info, Node: Raw and Cooked Registers, Next: Register Architecture Functions & Variables, Up: Register Representation 3064 3065 11.6.1 Raw and Cooked Registers 3066 ------------------------------- 3067 3068 GDB considers registers to be a set with members numbered linearly from 3069 0 upwards. The first part of that set corresponds to real physical 3070 registers, the second part to any "pseudo-registers". Pseudo-registers 3071 have no independent physical existence, but are useful representations 3072 of information within the architecture. For example the OpenRISC 1000 3073 architecture has up to 32 general purpose registers, which are 3074 typically represented as 32-bit (or 64-bit) integers. However the GPRs 3075 are also used as operands to the floating point operations, and it 3076 could be convenient to define a set of pseudo-registers, to show the 3077 GPRs represented as floating point values. 3078 3079 For any architecture, the implementer will decide on a mapping from 3080 hardware to GDB register numbers. The registers corresponding to real 3081 hardware are referred to as "raw" registers, the remaining registers are 3082 "pseudo-registers". The total register set (raw and pseudo) is called 3083 the "cooked" register set. 3084 3085 3086 File: gdbint.info, Node: Register Architecture Functions & Variables, Next: Register Information Functions, Prev: Raw and Cooked Registers, Up: Register Representation 3087 3088 11.6.2 Functions and Variables Specifying the Register Architecture 3089 ------------------------------------------------------------------- 3090 3091 These `struct gdbarch' functions and variables specify the number and 3092 type of registers in the architecture. 3093 3094 -- Architecture Function: CORE_ADDR read_pc (struct regcache *REGCACHE) 3095 3096 -- Architecture Function: void write_pc (struct regcache *REGCACHE, 3097 CORE_ADDR VAL) 3098 Read or write the program counter. The default value of both 3099 functions is `NULL' (no function available). If the program 3100 counter is just an ordinary register, it can be specified in 3101 `struct gdbarch' instead (see `pc_regnum' below) and it will be 3102 read or written using the standard routines to access registers. 3103 This function need only be specified if the program counter is not 3104 an ordinary register. 3105 3106 Any register information can be obtained using the supplied 3107 register cache, REGCACHE. *Note Register Caching: Register 3108 Caching. 3109 3110 3111 -- Architecture Function: void pseudo_register_read (struct gdbarch 3112 *GDBARCH, struct regcache *REGCACHE, int REGNUM, const 3113 gdb_byte *BUF) 3114 3115 -- Architecture Function: void pseudo_register_write (struct gdbarch 3116 *GDBARCH, struct regcache *REGCACHE, int REGNUM, const 3117 gdb_byte *BUF) 3118 These functions should be defined if there are any 3119 pseudo-registers. The default value is `NULL'. REGNUM is the 3120 number of the register to read or write (which will be a "cooked" 3121 register number) and BUF is the buffer where the value read will be 3122 placed, or from which the value to be written will be taken. The 3123 value in the buffer may be converted to or from a signed or 3124 unsigned integral value using one of the utility functions (*note 3125 Using Different Register and Memory Data Representations: Register 3126 and Memory Data.). 3127 3128 The access should be for the specified architecture, GDBARCH. Any 3129 register information can be obtained using the supplied register 3130 cache, REGCACHE. *Note Register Caching: Register Caching. 3131 3132 3133 -- Architecture Variable: int sp_regnum 3134 This specifies the register holding the stack pointer, which may 3135 be a raw or pseudo-register. It defaults to -1 (not defined), but 3136 it is an error for it not to be defined. 3137 3138 The value of the stack pointer register can be accessed withing 3139 GDB as the variable `$sp'. 3140 3141 3142 -- Architecture Variable: int pc_regnum 3143 This specifies the register holding the program counter, which may 3144 be a raw or pseudo-register. It defaults to -1 (not defined). If 3145 `pc_regnum' is not defined, then the functions `read_pc' and 3146 `write_pc' (see above) must be defined. 3147 3148 The value of the program counter (whether defined as a register, or 3149 through `read_pc' and `write_pc') can be accessed withing GDB as 3150 the variable `$pc'. 3151 3152 3153 -- Architecture Variable: int ps_regnum 3154 This specifies the register holding the processor status (often 3155 called the status register), which may be a raw or 3156 pseudo-register. It defaults to -1 (not defined). 3157 3158 If defined, the value of this register can be accessed withing GDB 3159 as the variable `$ps'. 3160 3161 3162 -- Architecture Variable: int fp0_regnum 3163 This specifies the first floating point register. It defaults to 3164 0. `fp0_regnum' is not needed unless the target offers support 3165 for floating point. 3166 3167 3168 3169 File: gdbint.info, Node: Register Information Functions, Next: Register and Memory Data, Prev: Register Architecture Functions & Variables, Up: Register Representation 3170 3171 11.6.3 Functions Giving Register Information 3172 -------------------------------------------- 3173 3174 These functions return information about registers. 3175 3176 -- Architecture Function: const char * register_name (struct gdbarch 3177 *GDBARCH, int REGNUM) 3178 This function should convert a register number (raw or pseudo) to a 3179 register name (as a C `const char *'). This is used both to 3180 determine the name of a register for output and to work out the 3181 meaning of any register names used as input. The function may 3182 also return `NULL', to indicate that REGNUM is not a valid 3183 register. 3184 3185 For example with the OpenRISC 1000, GDB registers 0-31 are the 3186 General Purpose Registers, register 32 is the program counter and 3187 register 33 is the supervision register (i.e. the processor status 3188 register), which map to the strings `"gpr00"' through `"gpr31"', 3189 `"pc"' and `"sr"' respectively. This means that the GDB command 3190 `print $gpr5' should print the value of the OR1K general purpose 3191 register 5(1). 3192 3193 The default value for this function is `NULL', meaning undefined. 3194 It should always be defined. 3195 3196 The access should be for the specified architecture, GDBARCH. 3197 3198 3199 -- Architecture Function: struct type * register_type (struct gdbarch 3200 *GDBARCH, int REGNUM) 3201 Given a register number, this function identifies the type of data 3202 it may be holding, specified as a `struct type'. GDB allows 3203 creation of arbitrary types, but a number of built in types are 3204 provided (`builtin_type_void', `builtin_type_int32' etc), together 3205 with functions to derive types from these. 3206 3207 Typically the program counter will have a type of "pointer to 3208 function" (it points to code), the frame pointer and stack pointer 3209 will have types of "pointer to void" (they point to data on the 3210 stack) and all other integer registers will have a type of 32-bit 3211 integer or 64-bit integer. 3212 3213 This information guides the formatting when displaying register 3214 information. The default value is `NULL' meaning no information is 3215 available to guide formatting when displaying registers. 3216 3217 3218 -- Architecture Function: void print_registers_info (struct gdbarch 3219 *GDBARCH, struct ui_file *FILE, struct frame_info *FRAME, int 3220 REGNUM, int ALL) 3221 Define this function to print out one or all of the registers for 3222 the GDB `info registers' command. The default value is the 3223 function `default_print_registers_info', which uses the register 3224 type information (see `register_type' above) to determine how each 3225 register should be printed. Define a custom version of this 3226 function for fuller control over how the registers are displayed. 3227 3228 The access should be for the specified architecture, GDBARCH, with 3229 output to the the file specified by the User Interface Independent 3230 Output file handle, FILE (*note UI-Independent Output--the 3231 `ui_out' Functions: UI-Independent Output.). 3232 3233 The registers should show their values in the frame specified by 3234 FRAME. If REGNUM is -1 and ALL is zero, then all the 3235 "significant" registers should be shown (the implementer should 3236 decide which registers are "significant"). Otherwise only the 3237 value of the register specified by REGNUM should be output. If 3238 REGNUM is -1 and ALL is non-zero (true), then the value of all 3239 registers should be shown. 3240 3241 By default `default_print_registers_info' prints one register per 3242 line, and if ALL is zero omits floating-point registers. 3243 3244 3245 -- Architecture Function: void print_float_info (struct gdbarch 3246 *GDBARCH, struct ui_file *FILE, struct frame_info *FRAME, 3247 const char *ARGS) 3248 Define this function to provide output about the floating point 3249 unit and registers for the GDB `info float' command respectively. 3250 The default value is `NULL' (not defined), meaning no information 3251 will be provided. 3252 3253 The GDBARCH and FILE and FRAME arguments have the same meaning as 3254 in the `print_registers_info' function above. The string ARGS 3255 contains any supplementary arguments to the `info float' command. 3256 3257 Define this function if the target supports floating point 3258 operations. 3259 3260 3261 -- Architecture Function: void print_vector_info (struct gdbarch 3262 *GDBARCH, struct ui_file *FILE, struct frame_info *FRAME, 3263 const char *ARGS) 3264 Define this function to provide output about the vector unit and 3265 registers for the GDB `info vector' command respectively. The 3266 default value is `NULL' (not defined), meaning no information will 3267 be provided. 3268 3269 The GDBARCH, FILE and FRAME arguments have the same meaning as in 3270 the `print_registers_info' function above. The string ARGS 3271 contains any supplementary arguments to the `info vector' command. 3272 3273 Define this function if the target supports vector operations. 3274 3275 3276 -- Architecture Function: int register_reggroup_p (struct gdbarch 3277 *GDBARCH, int REGNUM, struct reggroup *GROUP) 3278 GDB groups registers into different categories (general, vector, 3279 floating point etc). This function, given a register, REGNUM, and 3280 group, GROUP, returns 1 (true) if the register is in the group and 3281 0 (false) otherwise. 3282 3283 The information should be for the specified architecture, GDBARCH 3284 3285 The default value is the function `default_register_reggroup_p' 3286 which will do a reasonable job based on the type of the register 3287 (see the function `register_type' above), with groups for general 3288 purpose registers, floating point registers, vector registers and 3289 raw (i.e not pseudo) registers. 3290 3291 3292 ---------- Footnotes ---------- 3293 3294 (1) Historically, GDB always had a concept of a frame pointer 3295 register, which could be accessed via the GDB variable, `$fp'. That 3296 concept is now deprecated, recognizing that not all architectures have 3297 a frame pointer. However if an architecture does have a frame pointer 3298 register, and defines a register or pseudo-register with the name 3299 `"fp"', then that register will be used as the value of the `$fp' 3300 variable. 3301 3302 3303 File: gdbint.info, Node: Register and Memory Data, Next: Register Caching, Prev: Register Information Functions, Up: Register Representation 3304 3305 11.6.4 Using Different Register and Memory Data Representations 3306 --------------------------------------------------------------- 3307 3308 Some architectures have different representations of data objects, 3309 depending whether the object is held in a register or memory. For 3310 example: 3311 3312 * The Alpha architecture can represent 32 bit integer values in 3313 floating-point registers. 3314 3315 * The x86 architecture supports 80-bit floating-point registers. The 3316 `long double' data type occupies 96 bits in memory but only 80 3317 bits when stored in a register. 3318 3319 3320 In general, the register representation of a data type is determined 3321 by the architecture, or GDB's interface to the architecture, while the 3322 memory representation is determined by the Application Binary Interface. 3323 3324 For almost all data types on almost all architectures, the two 3325 representations are identical, and no special handling is needed. 3326 However, they do occasionally differ. An architecture may define the 3327 following `struct gdbarch' functions to request conversions between the 3328 register and memory representations of a data type: 3329 3330 -- Architecture Function: int gdbarch_convert_register_p (struct 3331 gdbarch *GDBARCH, int REG) 3332 Return non-zero (true) if the representation of a data value 3333 stored in this register may be different to the representation of 3334 that same data value when stored in memory. The default value is 3335 `NULL' (undefined). 3336 3337 If this function is defined and returns non-zero, the `struct 3338 gdbarch' functions `gdbarch_register_to_value' and 3339 `gdbarch_value_to_register' (see below) should be used to perform 3340 any necessary conversion. 3341 3342 If defined, this function should return zero for the register's 3343 native type, when no conversion is necessary. 3344 3345 -- Architecture Function: void gdbarch_register_to_value (struct 3346 gdbarch *GDBARCH, int REG, struct type *TYPE, char *FROM, 3347 char *TO) 3348 Convert the value of register number REG to a data object of type 3349 TYPE. The buffer at FROM holds the register's value in raw 3350 format; the converted value should be placed in the buffer at TO. 3351 3352 _Note:_ `gdbarch_register_to_value' and 3353 `gdbarch_value_to_register' take their REG and TYPE arguments 3354 in different orders. 3355 3356 `gdbarch_register_to_value' should only be used with registers for 3357 which the `gdbarch_convert_register_p' function returns a non-zero 3358 value. 3359 3360 3361 -- Architecture Function: void gdbarch_value_to_register (struct 3362 gdbarch *GDBARCH, struct type *TYPE, int REG, char *FROM, 3363 char *TO) 3364 Convert a data value of type TYPE to register number REG' raw 3365 format. 3366 3367 _Note:_ `gdbarch_register_to_value' and 3368 `gdbarch_value_to_register' take their REG and TYPE arguments 3369 in different orders. 3370 3371 `gdbarch_value_to_register' should only be used with registers for 3372 which the `gdbarch_convert_register_p' function returns a non-zero 3373 value. 3374 3375 3376 3377 File: gdbint.info, Node: Register Caching, Prev: Register and Memory Data, Up: Register Representation 3378 3379 11.6.5 Register Caching 3380 ----------------------- 3381 3382 Caching of registers is used, so that the target does not need to be 3383 accessed and reanalyzed multiple times for each register in 3384 circumstances where the register value cannot have changed. 3385 3386 GDB provides `struct regcache', associated with a particular `struct 3387 gdbarch' to hold the cached values of the raw registers. A set of 3388 functions is provided to access both the raw registers (with `raw' in 3389 their name) and the full set of cooked registers (with `cooked' in 3390 their name). Functions are provided to ensure the register cache is 3391 kept synchronized with the values of the actual registers in the target. 3392 3393 Accessing registers through the `struct regcache' routines will 3394 ensure that the appropriate `struct gdbarch' functions are called when 3395 necessary to access the underlying target architecture. In general 3396 users should use the "cooked" functions, since these will map to the 3397 "raw" functions automatically as appropriate. 3398 3399 The two key functions are `regcache_cooked_read' and 3400 `regcache_cooked_write' which read or write a register from or to a 3401 byte buffer (type `gdb_byte *'). For convenience the wrapper functions 3402 `regcache_cooked_read_signed', `regcache_cooked_read_unsigned', 3403 `regcache_cooked_write_signed' and `regcache_cooked_write_unsigned' are 3404 provided, which read or write the value using the buffer and convert to 3405 or from an integral value as appropriate. 3406 3407 3408 File: gdbint.info, Node: Frame Interpretation, Next: Inferior Call Setup, Prev: Register Representation, Up: Target Architecture Definition 3409 3410 11.7 Frame Interpretation 3411 ========================= 3412 3413 * Menu: 3414 3415 * All About Stack Frames:: 3416 * Frame Handling Terminology:: 3417 * Prologue Caches:: 3418 * Functions and Variable to Analyze Frames:: 3419 * Functions to Access Frame Data:: 3420 * Analyzing Stacks---Frame Sniffers:: 3421 3422 3423 File: gdbint.info, Node: All About Stack Frames, Next: Frame Handling Terminology, Up: Frame Interpretation 3424 3425 11.7.1 All About Stack Frames 3426 ----------------------------- 3427 3428 GDB needs to understand the stack on which local (automatic) variables 3429 are stored. The area of the stack containing all the local variables 3430 for a function invocation is known as the "stack frame" for that 3431 function (or colloquially just as the "frame"). In turn the function 3432 that called the function will have its stack frame, and so on back 3433 through the chain of functions that have been called. 3434 3435 Almost all architectures have one register dedicated to point to the 3436 end of the stack (the "stack pointer"). Many have a second register 3437 which points to the start of the currently active stack frame (the 3438 "frame pointer"). The specific arrangements for an architecture are a 3439 key part of the ABI. 3440 3441 A diagram helps to explain this. Here is a simple program to compute 3442 factorials: 3443 3444 #include <stdio.h> 3445 int fact (int n) 3446 { 3447 if (0 == n) 3448 { 3449 return 1; 3450 } 3451 else 3452 { 3453 return n * fact (n - 1); 3454 } 3455 } 3456 3457 main () 3458 { 3459 int i; 3460 3461 for (i = 0; i < 10; i++) 3462 { 3463 int f = fact (i); 3464 printf ("%d! = %d\n", i, f); 3465 } 3466 } 3467 3468 Consider the state of the stack when the code reaches line 6 after 3469 the main program has called `fact (3)'. The chain of function calls 3470 will be `main ()', `fact (3)', `fact (2)', `fact (1)' and `fact (0)'. 3471 3472 In this illustration the stack is falling (as used for example by the 3473 OpenRISC 1000 ABI). The stack pointer (SP) is at the end of the stack 3474 (lowest address) and the frame pointer (FP) is at the highest address 3475 in the current stack frame. The following diagram shows how the stack 3476 looks. 3477 3478 ^ ->| | 3479 Frame | | | | 3480 Number - | | |============| int fact (int n) 3481 | | | | i = 3 | { 3482 | | | |------------| if (0 == n) { 3483 | | | | f = ? | return 1; <-------- PC 3484 #4 main() < | | |------------| } 3485 | | | | | else { 3486 | | -+->|------------| ---> return n * fact (n - 1); 3487 | -+-+--+-----o | | } 3488 = | | |============| | } 3489 | | | | n = 3 | | 3490 | | | |------------| | main () 3491 #3 fact (3) < | | | o---------+- { 3492 | -+-+->|------------| | | int i; 3493 | | | --+-----o | | | 3494 = | | |============| | | for (i = 0; i < 10; i++) { 3495 | | | | n = 2 | | -> int f = fact (i); 3496 | | | |------------| | printf ("%d! = %d\n", i , f); 3497 #2 fact (2) < | | | o------+--| } 3498 | | | ->|------------| | } 3499 | | -+--+-----o | | 3500 = | | |============| | 3501 | | | | n = 1 | | 3502 | | | |------------| | 3503 #1 fact (1) < | | | o------+--| 3504 | | | |------------| | 3505 | ---|--+-----o |<-+------- FP 3506 = | |============| | | 3507 | | | n = 0 | | | 3508 | | |------------| | | 3509 #0 fact (0) < | | o--------- | 3510 | | |------------| | 3511 | --+-----o |<--------- SP | 3512 = |============| | 3513 | | Red Zone | v 3514 | \/\/\/\/\/\/\/ Direction of 3515 #-1 < \/\/\/\/\/\/\/ stack growth 3516 | | | 3517 3518 In each stack frame, offset 0 from the stack pointer is the frame 3519 pointer of the previous frame and offset 4 (this is illustrating a 3520 32-bit architecture) from the stack pointer is the return address. 3521 Local variables are indexed from the frame pointer, with negative 3522 indexes. In the function `fact', offset -4 from the frame pointer is 3523 the argument N. In the `main' function, offset -4 from the frame 3524 pointer is the local variable I and offset -8 from the frame pointer is 3525 the local variable F(1). 3526 3527 It is very easy to get confused when examining stacks. GDB has 3528 terminology it uses rigorously throughout. The stack frame of the 3529 function currently executing, or where execution stopped is numbered 3530 zero. In this example frame #0 is the stack frame of the call to 3531 `fact (0)'. The stack frame of its calling function (`fact (1)' in 3532 this case) is numbered #1 and so on back through the chain of calls. 3533 3534 The main GDB data structure describing frames is 3535 `struct frame_info'. It is not used directly, but only via its 3536 accessor functions. `frame_info' includes information about the 3537 registers in the frame and a pointer to the code of the function with 3538 which the frame is associated. The entire stack is represented as a 3539 linked list of `frame_info' structs. 3540 3541 ---------- Footnotes ---------- 3542 3543 (1) This is a simplified example for illustrative purposes only. 3544 Good optimizing compilers would not put anything on the stack for such 3545 simple functions. Indeed they might eliminate the recursion and use of 3546 the stack entirely! 3547 3548 3549 File: gdbint.info, Node: Frame Handling Terminology, Next: Prologue Caches, Prev: All About Stack Frames, Up: Frame Interpretation 3550 3551 11.7.2 Frame Handling Terminology 3552 --------------------------------- 3553 3554 It is easy to get confused when referencing stack frames. GDB uses 3555 some precise terminology. 3556 3557 * "THIS" frame is the frame currently under consideration. 3558 3559 * The "NEXT" frame, also sometimes called the inner or newer frame 3560 is the frame of the function called by the function of THIS frame. 3561 3562 * The "PREVIOUS" frame, also sometimes called the outer or older 3563 frame is the frame of the function which called the function of 3564 THIS frame. 3565 3566 3567 So in the example in the previous section (*note All About Stack 3568 Frames: All About Stack Frames.), if THIS frame is #3 (the call to 3569 `fact (3)'), the NEXT frame is frame #2 (the call to `fact (2)') and 3570 the PREVIOUS frame is frame #4 (the call to `main ()'). 3571 3572 The "innermost" frame is the frame of the current executing 3573 function, or where the program stopped, in this example, in the middle 3574 of the call to `fact (0))'. It is always numbered frame #0. 3575 3576 The "base" of a frame is the address immediately before the start of 3577 the NEXT frame. For a stack which grows down in memory (a "falling" 3578 stack) this will be the lowest address and for a stack which grows up 3579 in memory (a "rising" stack) this will be the highest address in the 3580 frame. 3581 3582 GDB functions to analyze the stack are typically given a pointer to 3583 the NEXT frame to determine information about THIS frame. Information 3584 about THIS frame includes data on where the registers of the PREVIOUS 3585 frame are stored in this stack frame. In this example the frame 3586 pointer of the PREVIOUS frame is stored at offset 0 from the stack 3587 pointer of THIS frame. 3588 3589 The process whereby a function is given a pointer to the NEXT frame 3590 to work out information about THIS frame is referred to as "unwinding". 3591 The GDB functions involved in this typically include unwind in their 3592 name. 3593 3594 The process of analyzing a target to determine the information that 3595 should go in struct frame_info is called "sniffing". The functions 3596 that carry this out are called sniffers and typically include sniffer 3597 in their name. More than one sniffer may be required to extract all 3598 the information for a particular frame. 3599 3600 Because so many functions work using the NEXT frame, there is an 3601 issue about addressing the innermost frame--it has no NEXT frame. To 3602 solve this GDB creates a dummy frame #-1, known as the "sentinel" frame. 3603 3604 3605 File: gdbint.info, Node: Prologue Caches, Next: Functions and Variable to Analyze Frames, Prev: Frame Handling Terminology, Up: Frame Interpretation 3606 3607 11.7.3 Prologue Caches 3608 ---------------------- 3609 3610 All the frame sniffing functions typically examine the code at the 3611 start of the corresponding function, to determine the state of 3612 registers. The ABI will save old values and set new values of key 3613 registers at the start of each function in what is known as the 3614 function "prologue". 3615 3616 For any particular stack frame this data does not change, so all the 3617 standard unwinding functions, in addition to receiving a pointer to the 3618 NEXT frame as their first argument, receive a pointer to a "prologue 3619 cache" as their second argument. This can be used to store values 3620 associated with a particular frame, for reuse on subsequent calls 3621 involving the same frame. 3622 3623 It is up to the user to define the structure used (it is a `void *' 3624 pointer) and arrange allocation and deallocation of storage. However 3625 for general use, GDB provides `struct trad_frame_cache', with a set of 3626 accessor routines. This structure holds the stack and code address of 3627 THIS frame, the base address of the frame, a pointer to the struct 3628 `frame_info' for the NEXT frame and details of where the registers of 3629 the PREVIOUS frame may be found in THIS frame. 3630 3631 Typically the first time any sniffer function is called with NEXT 3632 frame, the prologue sniffer for THIS frame will be `NULL'. The sniffer 3633 will analyze the frame, allocate a prologue cache structure and 3634 populate it. Subsequent calls using the same NEXT frame will pass in 3635 this prologue cache, so the data can be returned with no additional 3636 analysis. 3637 3638 3639 File: gdbint.info, Node: Functions and Variable to Analyze Frames, Next: Functions to Access Frame Data, Prev: Prologue Caches, Up: Frame Interpretation 3640 3641 11.7.4 Functions and Variable to Analyze Frames 3642 ----------------------------------------------- 3643 3644 These struct `gdbarch' functions and variable should be defined to 3645 provide analysis of the stack frame and allow it to be adjusted as 3646 required. 3647 3648 -- Architecture Function: CORE_ADDR skip_prologue (struct gdbarch 3649 *GDBARCH, CORE_ADDR PC) 3650 The prologue of a function is the code at the beginning of the 3651 function which sets up the stack frame, saves the return address 3652 etc. The code representing the behavior of the function starts 3653 after the prologue. 3654 3655 This function skips past the prologue of a function if the program 3656 counter, PC, is within the prologue of a function. The result is 3657 the program counter immediately after the prologue. With modern 3658 optimizing compilers, this may be a far from trivial exercise. 3659 However the required information may be within the binary as 3660 DWARF2 debugging information, making the job much easier. 3661 3662 The default value is `NULL' (not defined). This function should 3663 always be provided, but can take advantage of DWARF2 debugging 3664 information, if that is available. 3665 3666 3667 -- Architecture Function: int inner_than (CORE_ADDR LHS, CORE_ADDR RHS) 3668 Given two frame or stack pointers, return non-zero (true) if the 3669 first represents the "inner" stack frame and 0 (false) otherwise. 3670 This is used to determine whether the target has a stack which 3671 grows up in memory (rising stack) or grows down in memory (falling 3672 stack). *Note All About Stack Frames: All About Stack Frames, for 3673 an explanation of "inner" frames. 3674 3675 The default value of this function is `NULL' and it should always 3676 be defined. However for almost all architectures one of the 3677 built-in functions can be used: `core_addr_lessthan' (for stacks 3678 growing down in memory) or `core_addr_greaterthan' (for stacks 3679 growing up in memory). 3680 3681 3682 -- Architecture Function: CORE_ADDR frame_align (struct gdbarch 3683 *GDBARCH, CORE_ADDR ADDRESS) 3684 The architecture may have constraints on how its frames are 3685 aligned. For example the OpenRISC 1000 ABI requires stack frames 3686 to be double-word aligned, but 32-bit versions of the architecture 3687 allocate single-word values to the stack. Thus extra padding may 3688 be needed at the end of a stack frame. 3689 3690 Given a proposed address for the stack pointer, this function 3691 returns a suitably aligned address (by expanding the stack frame). 3692 3693 The default value is `NULL' (undefined). This function should be 3694 defined for any architecture where it is possible the stack could 3695 become misaligned. The utility functions `align_down' (for falling 3696 stacks) and `align_up' (for rising stacks) will facilitate the 3697 implementation of this function. 3698 3699 3700 -- Architecture Variable: int frame_red_zone_size 3701 Some ABIs reserve space beyond the end of the stack for use by leaf 3702 functions without prologue or epilogue or by exception handlers 3703 (for example the OpenRISC 1000). 3704 3705 This is known as a "red zone" (AMD terminology). The AMD64 (nee 3706 x86-64) ABI documentation refers to the "red zone" when describing 3707 this scratch area. 3708 3709 The default value is 0. Set this field if the architecture has 3710 such a red zone. The value must be aligned as required by the ABI 3711 (see `frame_align' above for an explanation of stack frame 3712 alignment). 3713 3714 3715 3716 File: gdbint.info, Node: Functions to Access Frame Data, Next: Analyzing Stacks---Frame Sniffers, Prev: Functions and Variable to Analyze Frames, Up: Frame Interpretation 3717 3718 11.7.5 Functions to Access Frame Data 3719 ------------------------------------- 3720 3721 These functions provide access to key registers and arguments in the 3722 stack frame. 3723 3724 -- Architecture Function: CORE_ADDR unwind_pc (struct gdbarch 3725 *GDBARCH, struct frame_info *NEXT_FRAME) 3726 This function is given a pointer to the NEXT stack frame (*note 3727 All About Stack Frames: All About Stack Frames, for how frames are 3728 represented) and returns the value of the program counter in the 3729 PREVIOUS frame (i.e. the frame of the function that called THIS 3730 one). This is commonly referred to as the "return address". 3731 3732 The implementation, which must be frame agnostic (work with any 3733 frame), is typically no more than: 3734 3735 ULONGEST pc; 3736 pc = frame_unwind_register_unsigned (next_frame, ARCH_PC_REGNUM); 3737 return gdbarch_addr_bits_remove (gdbarch, pc); 3738 3739 3740 -- Architecture Function: CORE_ADDR unwind_sp (struct gdbarch 3741 *GDBARCH, struct frame_info *NEXT_FRAME) 3742 This function is given a pointer to the NEXT stack frame (*note 3743 All About Stack Frames: All About Stack Frames. for how frames are 3744 represented) and returns the value of the stack pointer in the 3745 PREVIOUS frame (i.e. the frame of the function that called THIS 3746 one). 3747 3748 The implementation, which must be frame agnostic (work with any 3749 frame), is typically no more than: 3750 3751 ULONGEST sp; 3752 sp = frame_unwind_register_unsigned (next_frame, ARCH_SP_REGNUM); 3753 return gdbarch_addr_bits_remove (gdbarch, sp); 3754 3755 3756 -- Architecture Function: int frame_num_args (struct gdbarch *GDBARCH, 3757 struct frame_info *THIS_FRAME) 3758 This function is given a pointer to THIS stack frame (*note All 3759 About Stack Frames: All About Stack Frames. for how frames are 3760 represented), and returns the number of arguments that are being 3761 passed, or -1 if not known. 3762 3763 The default value is `NULL' (undefined), in which case the number 3764 of arguments passed on any stack frame is always unknown. For many 3765 architectures this will be a suitable default. 3766 3767 3768 3769 File: gdbint.info, Node: Analyzing Stacks---Frame Sniffers, Prev: Functions to Access Frame Data, Up: Frame Interpretation 3770 3771 11.7.6 Analyzing Stacks--Frame Sniffers 3772 --------------------------------------- 3773 3774 When a program stops, GDB needs to construct the chain of struct 3775 `frame_info' representing the state of the stack using appropriate 3776 "sniffers". 3777 3778 Each architecture requires appropriate sniffers, but they do not form 3779 entries in `struct gdbarch', since more than one sniffer may be 3780 required and a sniffer may be suitable for more than one 3781 `struct gdbarch'. Instead sniffers are associated with architectures 3782 using the following functions. 3783 3784 * `frame_unwind_append_sniffer' is used to add a new sniffer to 3785 analyze THIS frame when given a pointer to the NEXT frame. 3786 3787 * `frame_base_append_sniffer' is used to add a new sniffer which can 3788 determine information about the base of a stack frame. 3789 3790 * `frame_base_set_default' is used to specify the default base 3791 sniffer. 3792 3793 3794 These functions all take a reference to `struct gdbarch', so they 3795 are associated with a specific architecture. They are usually called 3796 in the `gdbarch' initialization function, after the `gdbarch' struct 3797 has been set up. Unless a default has been set, the most recently 3798 appended sniffer will be tried first. 3799 3800 The main frame unwinding sniffer (as set by 3801 `frame_unwind_append_sniffer)' returns a structure specifying a set of 3802 sniffing functions: 3803 3804 struct frame_unwind 3805 { 3806 enum frame_type type; 3807 frame_this_id_ftype *this_id; 3808 frame_prev_register_ftype *prev_register; 3809 const struct frame_data *unwind_data; 3810 frame_sniffer_ftype *sniffer; 3811 frame_prev_pc_ftype *prev_pc; 3812 frame_dealloc_cache_ftype *dealloc_cache; 3813 }; 3814 3815 The `type' field indicates the type of frame this sniffer can 3816 handle: normal, dummy (*note Functions Creating Dummy Frames: Functions 3817 Creating Dummy Frames.), signal handler or sentinel. Signal handlers 3818 sometimes have their own simplified stack structure for efficiency, so 3819 may need their own handlers. 3820 3821 The `unwind_data' field holds additional information which may be 3822 relevant to particular types of frame. For example it may hold 3823 additional information for signal handler frames. 3824 3825 The remaining fields define functions that yield different types of 3826 information when given a pointer to the NEXT stack frame. Not all 3827 functions need be provided. If an entry is `NULL', the next sniffer 3828 will be tried instead. 3829 3830 * `this_id' determines the stack pointer and function (code entry 3831 point) for THIS stack frame. 3832 3833 * `prev_register' determines where the values of registers for the 3834 PREVIOUS stack frame are stored in THIS stack frame. 3835 3836 * `sniffer' takes a look at THIS frame's registers to determine if 3837 this is the appropriate unwinder. 3838 3839 * `prev_pc' determines the program counter for THIS frame. Only 3840 needed if the program counter is not an ordinary register (*note 3841 Functions and Variables Specifying the Register Architecture: 3842 Register Architecture Functions & Variables.). 3843 3844 * `dealloc_cache' frees any additional memory associated with the 3845 prologue cache for this frame (*note Prologue Caches: Prologue 3846 Caches.). 3847 3848 3849 In general it is only the `this_id' and `prev_register' fields that 3850 need be defined for custom sniffers. 3851 3852 The frame base sniffer is much simpler. It is a 3853 `struct frame_base', which refers to the corresponding `frame_unwind' 3854 struct and whose fields refer to functions yielding various addresses 3855 within the frame. 3856 3857 struct frame_base 3858 { 3859 const struct frame_unwind *unwind; 3860 frame_this_base_ftype *this_base; 3861 frame_this_locals_ftype *this_locals; 3862 frame_this_args_ftype *this_args; 3863 }; 3864 3865 All the functions referred to take a pointer to the NEXT frame as 3866 argument. The function referred to by `this_base' returns the base 3867 address of THIS frame, the function referred to by `this_locals' 3868 returns the base address of local variables in THIS frame and the 3869 function referred to by `this_args' returns the base address of the 3870 function arguments in this frame. 3871 3872 As described above, the base address of a frame is the address 3873 immediately before the start of the NEXT frame. For a falling stack, 3874 this is the lowest address in the frame and for a rising stack it is 3875 the highest address in the frame. For most architectures the same 3876 address is also the base address for local variables and arguments, in 3877 which case the same function can be used for all three entries(1). 3878 3879 ---------- Footnotes ---------- 3880 3881 (1) It is worth noting that if it cannot be determined in any other 3882 way (for example by there being a register with the name `"fp"'), then 3883 the result of the `this_base' function will be used as the value of the 3884 frame pointer variable `$fp' in GDB. This is very often not correct 3885 (for example with the OpenRISC 1000, this value is the stack pointer, 3886 `$sp'). In this case a register (raw or pseudo) with the name `"fp"' 3887 should be defined. It will be used in preference as the value of `$fp'. 3888 3889 3890 File: gdbint.info, Node: Inferior Call Setup, Next: Adding support for debugging core files, Prev: Frame Interpretation, Up: Target Architecture Definition 3891 3892 11.8 Inferior Call Setup 3893 ======================== 3894 3895 * Menu: 3896 3897 * About Dummy Frames:: 3898 * Functions Creating Dummy Frames:: 3899 3900 3901 File: gdbint.info, Node: About Dummy Frames, Next: Functions Creating Dummy Frames, Up: Inferior Call Setup 3902 3903 11.8.1 About Dummy Frames 3904 ------------------------- 3905 3906 GDB can call functions in the target code (for example by using the 3907 `call' or `print' commands). These functions may be breakpointed, and 3908 it is essential that if a function does hit a breakpoint, commands like 3909 `backtrace' work correctly. 3910 3911 This is achieved by making the stack look as though the function had 3912 been called from the point where GDB had previously stopped. This 3913 requires that GDB can set up stack frames appropriate for such function 3914 calls. 3915 3916 3917 File: gdbint.info, Node: Functions Creating Dummy Frames, Prev: About Dummy Frames, Up: Inferior Call Setup 3918 3919 11.8.2 Functions Creating Dummy Frames 3920 -------------------------------------- 3921 3922 The following functions provide the functionality to set up such 3923 "dummy" stack frames. 3924 3925 -- Architecture Function: CORE_ADDR push_dummy_call (struct gdbarch 3926 *GDBARCH, struct value *FUNCTION, struct regcache *REGCACHE, 3927 CORE_ADDR BP_ADDR, int NARGS, struct value **ARGS, CORE_ADDR 3928 SP, int STRUCT_RETURN, CORE_ADDR STRUCT_ADDR) 3929 This function sets up a dummy stack frame for the function about 3930 to be called. `push_dummy_call' is given the arguments to be 3931 passed and must copy them into registers or push them on to the 3932 stack as appropriate for the ABI. 3933 3934 FUNCTION is a pointer to the function that will be called and 3935 REGCACHE the register cache from which values should be obtained. 3936 BP_ADDR is the address to which the function should return (which 3937 is breakpointed, so GDB can regain control, hence the name). 3938 NARGS is the number of arguments to pass and ARGS an array 3939 containing the argument values. STRUCT_RETURN is non-zero (true) 3940 if the function returns a structure, and if so STRUCT_ADDR is the 3941 address in which the structure should be returned. 3942 3943 After calling this function, GDB will pass control to the target 3944 at the address of the function, which will find the stack and 3945 registers set up just as expected. 3946 3947 The default value of this function is `NULL' (undefined). If the 3948 function is not defined, then GDB will not allow the user to call 3949 functions within the target being debugged. 3950 3951 3952 -- Architecture Function: struct frame_id unwind_dummy_id (struct 3953 gdbarch *GDBARCH, struct frame_info *NEXT_FRAME) 3954 This is the inverse of `push_dummy_call' which restores the stack 3955 pointer and program counter after a call to evaluate a function 3956 using a dummy stack frame. The result is a `struct frame_id', 3957 which contains the value of the stack pointer and program counter 3958 to be used. 3959 3960 The NEXT frame pointer is provided as argument, NEXT_FRAME. THIS 3961 frame is the frame of the dummy function, which can be unwound, to 3962 yield the required stack pointer and program counter from the 3963 PREVIOUS frame. 3964 3965 The default value is `NULL' (undefined). If `push_dummy_call' is 3966 defined, then this function should also be defined. 3967 3968 3969 -- Architecture Function: CORE_ADDR push_dummy_code (struct gdbarch 3970 *GDBARCH, CORE_ADDR SP, CORE_ADDR FUNADDR, struct value 3971 **ARGS, int NARGS, struct type *VALUE_TYPE, CORE_ADDR 3972 *REAL_PC, CORE_ADDR *BP_ADDR, struct regcache *REGCACHE) 3973 If this function is not defined (its default value is `NULL'), a 3974 dummy call will use the entry point of the currently loaded code 3975 on the target as its return address. A temporary breakpoint will 3976 be set there, so the location must be writable and have room for a 3977 breakpoint. 3978 3979 It is possible that this default is not suitable. It might not be 3980 writable (in ROM possibly), or the ABI might require code to be 3981 executed on return from a call to unwind the stack before the 3982 breakpoint is encountered. 3983 3984 If either of these is the case, then push_dummy_code should be 3985 defined to push an instruction sequence onto the end of the stack 3986 to which the dummy call should return. 3987 3988 The arguments are essentially the same as those to 3989 `push_dummy_call'. However the function is provided with the type 3990 of the function result, VALUE_TYPE, BP_ADDR is used to return a 3991 value (the address at which the breakpoint instruction should be 3992 inserted) and REAL PC is used to specify the resume address when 3993 starting the call sequence. The function should return the 3994 updated innermost stack address. 3995 3996 _Note:_ This does require that code in the stack can be 3997 executed. Some Harvard architectures may not allow this. 3998 3999 4000 4001 File: gdbint.info, Node: Adding support for debugging core files, Next: Defining Other Architecture Features, Prev: Inferior Call Setup, Up: Target Architecture Definition 4002 4003 11.9 Adding support for debugging core files 4004 ============================================ 4005 4006 The prerequisite for adding core file support in GDB is to have core 4007 file support in BFD. 4008 4009 Once BFD support is available, writing the apropriate 4010 `regset_from_core_section' architecture function should be all that is 4011 needed in order to add support for core files in GDB. 4012 4013 4014 File: gdbint.info, Node: Defining Other Architecture Features, Next: Adding a New Target, Prev: Adding support for debugging core files, Up: Target Architecture Definition 4015 4016 11.10 Defining Other Architecture Features 4017 ========================================== 4018 4019 This section describes other functions and values in `gdbarch', 4020 together with some useful macros, that you can use to define the target 4021 architecture. 4022 4023 `CORE_ADDR gdbarch_addr_bits_remove (GDBARCH, ADDR)' 4024 If a raw machine instruction address includes any bits that are not 4025 really part of the address, then this function is used to zero 4026 those bits in ADDR. This is only used for addresses of 4027 instructions, and even then not in all contexts. 4028 4029 For example, the two low-order bits of the PC on the 4030 Hewlett-Packard PA 2.0 architecture contain the privilege level of 4031 the corresponding instruction. Since instructions must always be 4032 aligned on four-byte boundaries, the processor masks out these 4033 bits to generate the actual address of the instruction. 4034 `gdbarch_addr_bits_remove' would then for example look like that: 4035 arch_addr_bits_remove (CORE_ADDR addr) 4036 { 4037 return (addr &= ~0x3); 4038 } 4039 4040 `int address_class_name_to_type_flags (GDBARCH, NAME, TYPE_FLAGS_PTR)' 4041 If NAME is a valid address class qualifier name, set the `int' 4042 referenced by TYPE_FLAGS_PTR to the mask representing the qualifier 4043 and return 1. If NAME is not a valid address class qualifier name, 4044 return 0. 4045 4046 The value for TYPE_FLAGS_PTR should be one of 4047 `TYPE_FLAG_ADDRESS_CLASS_1', `TYPE_FLAG_ADDRESS_CLASS_2', or 4048 possibly some combination of these values or'd together. *Note 4049 Address Classes: Target Architecture Definition. 4050 4051 `int address_class_name_to_type_flags_p (GDBARCH)' 4052 Predicate which indicates whether 4053 `address_class_name_to_type_flags' has been defined. 4054 4055 `int gdbarch_address_class_type_flags (GDBARCH, BYTE_SIZE, DWARF2_ADDR_CLASS)' 4056 Given a pointers byte size (as described by the debug information) 4057 and the possible `DW_AT_address_class' value, return the type flags 4058 used by GDB to represent this address class. The value returned 4059 should be one of `TYPE_FLAG_ADDRESS_CLASS_1', 4060 `TYPE_FLAG_ADDRESS_CLASS_2', or possibly some combination of these 4061 values or'd together. *Note Address Classes: Target Architecture 4062 Definition. 4063 4064 `int gdbarch_address_class_type_flags_p (GDBARCH)' 4065 Predicate which indicates whether 4066 `gdbarch_address_class_type_flags_p' has been defined. 4067 4068 `const char *gdbarch_address_class_type_flags_to_name (GDBARCH, TYPE_FLAGS)' 4069 Return the name of the address class qualifier associated with the 4070 type flags given by TYPE_FLAGS. 4071 4072 `int gdbarch_address_class_type_flags_to_name_p (GDBARCH)' 4073 Predicate which indicates whether 4074 `gdbarch_address_class_type_flags_to_name' has been defined. 4075 *Note Address Classes: Target Architecture Definition. 4076 4077 `void gdbarch_address_to_pointer (GDBARCH, TYPE, BUF, ADDR)' 4078 Store in BUF a pointer of type TYPE representing the address ADDR, 4079 in the appropriate format for the current architecture. This 4080 function may safely assume that TYPE is either a pointer or a C++ 4081 reference type. *Note Pointers Are Not Always Addresses: Target 4082 Architecture Definition. 4083 4084 `int gdbarch_believe_pcc_promotion (GDBARCH)' 4085 Used to notify if the compiler promotes a `short' or `char' 4086 parameter to an `int', but still reports the parameter as its 4087 original type, rather than the promoted type. 4088 4089 `gdbarch_bits_big_endian (GDBARCH)' 4090 This is used if the numbering of bits in the targets does *not* 4091 match the endianism of the target byte order. A value of 1 means 4092 that the bits are numbered in a big-endian bit order, 0 means 4093 little-endian. 4094 4095 `set_gdbarch_bits_big_endian (GDBARCH, BITS_BIG_ENDIAN)' 4096 Calling set_gdbarch_bits_big_endian with a value of 1 indicates 4097 that the bits in the target are numbered in a big-endian bit 4098 order, 0 indicates little-endian. 4099 4100 `BREAKPOINT' 4101 This is the character array initializer for the bit pattern to put 4102 into memory where a breakpoint is set. Although it's common to 4103 use a trap instruction for a breakpoint, it's not required; for 4104 instance, the bit pattern could be an invalid instruction. The 4105 breakpoint must be no longer than the shortest instruction of the 4106 architecture. 4107 4108 `BREAKPOINT' has been deprecated in favor of 4109 `gdbarch_breakpoint_from_pc'. 4110 4111 `BIG_BREAKPOINT' 4112 `LITTLE_BREAKPOINT' 4113 Similar to BREAKPOINT, but used for bi-endian targets. 4114 4115 `BIG_BREAKPOINT' and `LITTLE_BREAKPOINT' have been deprecated in 4116 favor of `gdbarch_breakpoint_from_pc'. 4117 4118 `const gdb_byte *gdbarch_breakpoint_from_pc (GDBARCH, PCPTR, LENPTR)' 4119 Use the program counter to determine the contents and size of a 4120 breakpoint instruction. It returns a pointer to a static string 4121 of bytes that encode a breakpoint instruction, stores the length 4122 of the string to `*LENPTR', and adjusts the program counter (if 4123 necessary) to point to the actual memory location where the 4124 breakpoint should be inserted. May return `NULL' to indicate that 4125 software breakpoints are not supported. 4126 4127 Although it is common to use a trap instruction for a breakpoint, 4128 it's not required; for instance, the bit pattern could be an 4129 invalid instruction. The breakpoint must be no longer than the 4130 shortest instruction of the architecture. 4131 4132 Provided breakpoint bytes can be also used by 4133 `bp_loc_is_permanent' to detect permanent breakpoints. 4134 `gdbarch_breakpoint_from_pc' should return an unchanged memory 4135 copy if it was called for a location with permanent breakpoint as 4136 some architectures use breakpoint instructions containing 4137 arbitrary parameter value. 4138 4139 Replaces all the other BREAKPOINT macros. 4140 4141 `int gdbarch_memory_insert_breakpoint (GDBARCH, BP_TGT)' 4142 `gdbarch_memory_remove_breakpoint (GDBARCH, BP_TGT)' 4143 Insert or remove memory based breakpoints. Reasonable defaults 4144 (`default_memory_insert_breakpoint' and 4145 `default_memory_remove_breakpoint' respectively) have been 4146 provided so that it is not necessary to set these for most 4147 architectures. Architectures which may want to set 4148 `gdbarch_memory_insert_breakpoint' and 4149 `gdbarch_memory_remove_breakpoint' will likely have instructions 4150 that are oddly sized or are not stored in a conventional manner. 4151 4152 It may also be desirable (from an efficiency standpoint) to define 4153 custom breakpoint insertion and removal routines if 4154 `gdbarch_breakpoint_from_pc' needs to read the target's memory for 4155 some reason. 4156 4157 `CORE_ADDR gdbarch_adjust_breakpoint_address (GDBARCH, BPADDR)' 4158 Given an address at which a breakpoint is desired, return a 4159 breakpoint address adjusted to account for architectural 4160 constraints on breakpoint placement. This method is not needed by 4161 most targets. 4162 4163 The FR-V target (see `frv-tdep.c') requires this method. The FR-V 4164 is a VLIW architecture in which a number of RISC-like instructions 4165 are grouped (packed) together into an aggregate instruction or 4166 instruction bundle. When the processor executes one of these 4167 bundles, the component instructions are executed in parallel. 4168 4169 In the course of optimization, the compiler may group instructions 4170 from distinct source statements into the same bundle. The line 4171 number information associated with one of the latter statements 4172 will likely refer to some instruction other than the first one in 4173 the bundle. So, if the user attempts to place a breakpoint on one 4174 of these latter statements, GDB must be careful to _not_ place the 4175 break instruction on any instruction other than the first one in 4176 the bundle. (Remember though that the instructions within a 4177 bundle execute in parallel, so the _first_ instruction is the 4178 instruction at the lowest address and has nothing to do with 4179 execution order.) 4180 4181 The FR-V's `gdbarch_adjust_breakpoint_address' method will adjust a 4182 breakpoint's address by scanning backwards for the beginning of 4183 the bundle, returning the address of the bundle. 4184 4185 Since the adjustment of a breakpoint may significantly alter a 4186 user's expectation, GDB prints a warning when an adjusted 4187 breakpoint is initially set and each time that that breakpoint is 4188 hit. 4189 4190 `int gdbarch_call_dummy_location (GDBARCH)' 4191 See the file `inferior.h'. 4192 4193 This method has been replaced by `gdbarch_push_dummy_code' (*note 4194 gdbarch_push_dummy_code::). 4195 4196 `int gdbarch_cannot_fetch_register (GDBARCH, REGUM)' 4197 This function should return nonzero if REGNO cannot be fetched 4198 from an inferior process. 4199 4200 `int gdbarch_cannot_store_register (GDBARCH, REGNUM)' 4201 This function should return nonzero if REGNO should not be written 4202 to the target. This is often the case for program counters, 4203 status words, and other special registers. This function returns 4204 0 as default so that GDB will assume that all registers may be 4205 written. 4206 4207 `int gdbarch_convert_register_p (GDBARCH, REGNUM, struct type *TYPE)' 4208 Return non-zero if register REGNUM represents data values of type 4209 TYPE in a non-standard form. *Note Using Different Register and 4210 Memory Data Representations: Target Architecture Definition. 4211 4212 `int gdbarch_fp0_regnum (GDBARCH)' 4213 This function returns the number of the first floating point 4214 register, if the machine has such registers. Otherwise, it 4215 returns -1. 4216 4217 `CORE_ADDR gdbarch_decr_pc_after_break (GDBARCH)' 4218 This function shall return the amount by which to decrement the PC 4219 after the program encounters a breakpoint. This is often the 4220 number of bytes in `BREAKPOINT', though not always. For most 4221 targets this value will be 0. 4222 4223 `DISABLE_UNSETTABLE_BREAK (ADDR)' 4224 If defined, this should evaluate to 1 if ADDR is in a shared 4225 library in which breakpoints cannot be set and so should be 4226 disabled. 4227 4228 `int gdbarch_dwarf2_reg_to_regnum (GDBARCH, DWARF2_REGNR)' 4229 Convert DWARF2 register number DWARF2_REGNR into GDB regnum. If 4230 not defined, no conversion will be performed. 4231 4232 `int gdbarch_ecoff_reg_to_regnum (GDBARCH, ECOFF_REGNR)' 4233 Convert ECOFF register number ECOFF_REGNR into GDB regnum. If 4234 not defined, no conversion will be performed. 4235 4236 `GCC_COMPILED_FLAG_SYMBOL' 4237 `GCC2_COMPILED_FLAG_SYMBOL' 4238 If defined, these are the names of the symbols that GDB will look 4239 for to detect that GCC compiled the file. The default symbols are 4240 `gcc_compiled.' and `gcc2_compiled.', respectively. (Currently 4241 only defined for the Delta 68.) 4242 4243 `gdbarch_get_longjmp_target' 4244 This function determines the target PC address that `longjmp' will 4245 jump to, assuming that we have just stopped at a `longjmp' 4246 breakpoint. It takes a `CORE_ADDR *' as argument, and stores the 4247 target PC value through this pointer. It examines the current 4248 state of the machine as needed, typically by using a 4249 manually-determined offset into the `jmp_buf'. (While we might 4250 like to get the offset from the target's `jmpbuf.h', that header 4251 file cannot be assumed to be available when building a 4252 cross-debugger.) 4253 4254 `DEPRECATED_IBM6000_TARGET' 4255 Shows that we are configured for an IBM RS/6000 system. This 4256 conditional should be eliminated (FIXME) and replaced by 4257 feature-specific macros. It was introduced in haste and we are 4258 repenting at leisure. 4259 4260 `I386_USE_GENERIC_WATCHPOINTS' 4261 An x86-based target can define this to use the generic x86 4262 watchpoint support; see *note I386_USE_GENERIC_WATCHPOINTS: 4263 Algorithms. 4264 4265 `gdbarch_in_function_epilogue_p (GDBARCH, ADDR)' 4266 Returns non-zero if the given ADDR is in the epilogue of a 4267 function. The epilogue of a function is defined as the part of a 4268 function where the stack frame of the function already has been 4269 destroyed up to the final `return from function call' instruction. 4270 4271 `int gdbarch_in_solib_return_trampoline (GDBARCH, PC, NAME)' 4272 Define this function to return nonzero if the program is stopped 4273 in the trampoline that returns from a shared library. 4274 4275 `target_so_ops.in_dynsym_resolve_code (PC)' 4276 Define this to return nonzero if the program is stopped in the 4277 dynamic linker. 4278 4279 `SKIP_SOLIB_RESOLVER (PC)' 4280 Define this to evaluate to the (nonzero) address at which execution 4281 should continue to get past the dynamic linker's symbol resolution 4282 function. A zero value indicates that it is not important or 4283 necessary to set a breakpoint to get through the dynamic linker 4284 and that single stepping will suffice. 4285 4286 `CORE_ADDR gdbarch_integer_to_address (GDBARCH, TYPE, BUF)' 4287 Define this when the architecture needs to handle non-pointer to 4288 address conversions specially. Converts that value to an address 4289 according to the current architectures conventions. 4290 4291 _Pragmatics: When the user copies a well defined expression from 4292 their source code and passes it, as a parameter, to GDB's `print' 4293 command, they should get the same value as would have been 4294 computed by the target program. Any deviation from this rule can 4295 cause major confusion and annoyance, and needs to be justified 4296 carefully. In other words, GDB doesn't really have the freedom to 4297 do these conversions in clever and useful ways. It has, however, 4298 been pointed out that users aren't complaining about how GDB casts 4299 integers to pointers; they are complaining that they can't take an 4300 address from a disassembly listing and give it to `x/i'. Adding 4301 an architecture method like `gdbarch_integer_to_address' certainly 4302 makes it possible for GDB to "get it right" in all circumstances._ 4303 4304 *Note Pointers Are Not Always Addresses: Target Architecture 4305 Definition. 4306 4307 `CORE_ADDR gdbarch_pointer_to_address (GDBARCH, TYPE, BUF)' 4308 Assume that BUF holds a pointer of type TYPE, in the appropriate 4309 format for the current architecture. Return the byte address the 4310 pointer refers to. *Note Pointers Are Not Always Addresses: 4311 Target Architecture Definition. 4312 4313 `void gdbarch_register_to_value(GDBARCH, FRAME, REGNUM, TYPE, FUR)' 4314 Convert the raw contents of register REGNUM into a value of type 4315 TYPE. *Note Using Different Register and Memory Data 4316 Representations: Target Architecture Definition. 4317 4318 `REGISTER_CONVERT_TO_VIRTUAL(REG, TYPE, FROM, TO)' 4319 Convert the value of register REG from its raw form to its virtual 4320 form. *Note Raw and Virtual Register Representations: Target 4321 Architecture Definition. 4322 4323 `REGISTER_CONVERT_TO_RAW(TYPE, REG, FROM, TO)' 4324 Convert the value of register REG from its virtual form to its raw 4325 form. *Note Raw and Virtual Register Representations: Target 4326 Architecture Definition. 4327 4328 `const struct regset *regset_from_core_section (struct gdbarch * GDBARCH, const char * SECT_NAME, size_t SECT_SIZE)' 4329 Return the appropriate register set for a core file section with 4330 name SECT_NAME and size SECT_SIZE. 4331 4332 `SOFTWARE_SINGLE_STEP_P()' 4333 Define this as 1 if the target does not have a hardware single-step 4334 mechanism. The macro `SOFTWARE_SINGLE_STEP' must also be defined. 4335 4336 `SOFTWARE_SINGLE_STEP(SIGNAL, INSERT_BREAKPOINTS_P)' 4337 A function that inserts or removes (depending on 4338 INSERT_BREAKPOINTS_P) breakpoints at each possible destinations of 4339 the next instruction. See `sparc-tdep.c' and `rs6000-tdep.c' for 4340 examples. 4341 4342 `set_gdbarch_sofun_address_maybe_missing (GDBARCH, SET)' 4343 Somebody clever observed that, the more actual addresses you have 4344 in the debug information, the more time the linker has to spend 4345 relocating them. So whenever there's some other way the debugger 4346 could find the address it needs, you should omit it from the debug 4347 info, to make linking faster. 4348 4349 Calling `set_gdbarch_sofun_address_maybe_missing' with a non-zero 4350 argument SET indicates that a particular set of hacks of this sort 4351 are in use, affecting `N_SO' and `N_FUN' entries in stabs-format 4352 debugging information. `N_SO' stabs mark the beginning and ending 4353 addresses of compilation units in the text segment. `N_FUN' stabs 4354 mark the starts and ends of functions. 4355 4356 In this case, GDB assumes two things: 4357 4358 * `N_FUN' stabs have an address of zero. Instead of using those 4359 addresses, you should find the address where the function 4360 starts by taking the function name from the stab, and then 4361 looking that up in the minsyms (the linker/assembler symbol 4362 table). In other words, the stab has the name, and the 4363 linker/assembler symbol table is the only place that carries 4364 the address. 4365 4366 * `N_SO' stabs have an address of zero, too. You just look at 4367 the `N_FUN' stabs that appear before and after the `N_SO' 4368 stab, and guess the starting and ending addresses of the 4369 compilation unit from them. 4370 4371 `int gdbarch_stabs_argument_has_addr (GDBARCH, TYPE)' 4372 Define this function to return nonzero if a function argument of 4373 type TYPE is passed by reference instead of value. 4374 4375 `CORE_ADDR gdbarch_push_dummy_call (GDBARCH, FUNCTION, REGCACHE, BP_ADDR, NARGS, ARGS, SP, STRUCT_RETURN, STRUCT_ADDR)' 4376 Define this to push the dummy frame's call to the inferior 4377 function onto the stack. In addition to pushing NARGS, the code 4378 should push STRUCT_ADDR (when STRUCT_RETURN is non-zero), and the 4379 return address (BP_ADDR). 4380 4381 FUNCTION is a pointer to a `struct value'; on architectures that 4382 use function descriptors, this contains the function descriptor 4383 value. 4384 4385 Returns the updated top-of-stack pointer. 4386 4387 `CORE_ADDR gdbarch_push_dummy_code (GDBARCH, SP, FUNADDR, USING_GCC, ARGS, NARGS, VALUE_TYPE, REAL_PC, BP_ADDR, REGCACHE)' 4388 Given a stack based call dummy, push the instruction sequence 4389 (including space for a breakpoint) to which the called function 4390 should return. 4391 4392 Set BP_ADDR to the address at which the breakpoint instruction 4393 should be inserted, REAL_PC to the resume address when starting 4394 the call sequence, and return the updated inner-most stack address. 4395 4396 By default, the stack is grown sufficient to hold a frame-aligned 4397 (*note frame_align::) breakpoint, BP_ADDR is set to the address 4398 reserved for that breakpoint, and REAL_PC set to FUNADDR. 4399 4400 This method replaces `gdbarch_call_dummy_location (GDBARCH)'. 4401 4402 `int gdbarch_sdb_reg_to_regnum (GDBARCH, SDB_REGNR)' 4403 Use this function to convert sdb register SDB_REGNR into GDB 4404 regnum. If not defined, no conversion will be done. 4405 4406 `enum return_value_convention gdbarch_return_value (struct gdbarch *GDBARCH, struct type *VALTYPE, struct regcache *REGCACHE, void *READBUF, const void *WRITEBUF)' 4407 Given a function with a return-value of type RETTYPE, return which 4408 return-value convention that function would use. 4409 4410 GDB currently recognizes two function return-value conventions: 4411 `RETURN_VALUE_REGISTER_CONVENTION' where the return value is found 4412 in registers; and `RETURN_VALUE_STRUCT_CONVENTION' where the return 4413 value is found in memory and the address of that memory location is 4414 passed in as the function's first parameter. 4415 4416 If the register convention is being used, and WRITEBUF is 4417 non-`NULL', also copy the return-value in WRITEBUF into REGCACHE. 4418 4419 If the register convention is being used, and READBUF is 4420 non-`NULL', also copy the return value from REGCACHE into READBUF 4421 (REGCACHE contains a copy of the registers from the just returned 4422 function). 4423 4424 _Maintainer note: This method replaces separate predicate, extract, 4425 store methods. By having only one method, the logic needed to 4426 determine the return-value convention need only be implemented in 4427 one place. If GDB were written in an OO language, this method 4428 would instead return an object that knew how to perform the 4429 register return-value extract and store._ 4430 4431 _Maintainer note: This method does not take a GCC_P parameter, and 4432 such a parameter should not be added. If an architecture that 4433 requires per-compiler or per-function information be identified, 4434 then the replacement of RETTYPE with `struct value' FUNCTION 4435 should be pursued._ 4436 4437 _Maintainer note: The REGCACHE parameter limits this methods to 4438 the inner most frame. While replacing REGCACHE with a `struct 4439 frame_info' FRAME parameter would remove that limitation there has 4440 yet to be a demonstrated need for such a change._ 4441 4442 `void gdbarch_skip_permanent_breakpoint (GDBARCH, REGCACHE)' 4443 Advance the inferior's PC past a permanent breakpoint. GDB 4444 normally steps over a breakpoint by removing it, stepping one 4445 instruction, and re-inserting the breakpoint. However, permanent 4446 breakpoints are hardwired into the inferior, and can't be removed, 4447 so this strategy doesn't work. Calling 4448 `gdbarch_skip_permanent_breakpoint' adjusts the processor's state 4449 so that execution will resume just after the breakpoint. This 4450 function does the right thing even when the breakpoint is in the 4451 delay slot of a branch or jump. 4452 4453 `CORE_ADDR gdbarch_skip_trampoline_code (GDBARCH, FRAME, PC)' 4454 If the target machine has trampoline code that sits between 4455 callers and the functions being called, then define this function 4456 to return a new PC that is at the start of the real function. 4457 4458 `int gdbarch_deprecated_fp_regnum (GDBARCH)' 4459 If the frame pointer is in a register, use this function to return 4460 the number of that register. 4461 4462 `int gdbarch_stab_reg_to_regnum (GDBARCH, STAB_REGNR)' 4463 Use this function to convert stab register STAB_REGNR into GDB 4464 regnum. If not defined, no conversion will be done. 4465 4466 `SYMBOL_RELOADING_DEFAULT' 4467 The default value of the "symbol-reloading" variable. (Never 4468 defined in current sources.) 4469 4470 `TARGET_CHAR_BIT' 4471 Number of bits in a char; defaults to 8. 4472 4473 `int gdbarch_char_signed (GDBARCH)' 4474 Non-zero if `char' is normally signed on this architecture; zero if 4475 it should be unsigned. 4476 4477 The ISO C standard requires the compiler to treat `char' as 4478 equivalent to either `signed char' or `unsigned char'; any 4479 character in the standard execution set is supposed to be positive. 4480 Most compilers treat `char' as signed, but `char' is unsigned on 4481 the IBM S/390, RS6000, and PowerPC targets. 4482 4483 `int gdbarch_double_bit (GDBARCH)' 4484 Number of bits in a double float; defaults to 4485 `8 * TARGET_CHAR_BIT'. 4486 4487 `int gdbarch_float_bit (GDBARCH)' 4488 Number of bits in a float; defaults to `4 * TARGET_CHAR_BIT'. 4489 4490 `int gdbarch_int_bit (GDBARCH)' 4491 Number of bits in an integer; defaults to `4 * TARGET_CHAR_BIT'. 4492 4493 `int gdbarch_long_bit (GDBARCH)' 4494 Number of bits in a long integer; defaults to 4495 `4 * TARGET_CHAR_BIT'. 4496 4497 `int gdbarch_long_double_bit (GDBARCH)' 4498 Number of bits in a long double float; defaults to 4499 `2 * gdbarch_double_bit (GDBARCH)'. 4500 4501 `int gdbarch_long_long_bit (GDBARCH)' 4502 Number of bits in a long long integer; defaults to 4503 `2 * gdbarch_long_bit (GDBARCH)'. 4504 4505 `int gdbarch_ptr_bit (GDBARCH)' 4506 Number of bits in a pointer; defaults to 4507 `gdbarch_int_bit (GDBARCH)'. 4508 4509 `int gdbarch_short_bit (GDBARCH)' 4510 Number of bits in a short integer; defaults to 4511 `2 * TARGET_CHAR_BIT'. 4512 4513 `void gdbarch_virtual_frame_pointer (GDBARCH, PC, FRAME_REGNUM, FRAME_OFFSET)' 4514 Returns a `(REGISTER, OFFSET)' pair representing the virtual frame 4515 pointer in use at the code address PC. If virtual frame pointers 4516 are not used, a default definition simply returns 4517 `gdbarch_deprecated_fp_regnum' (or `gdbarch_sp_regnum', if no 4518 frame pointer is defined), with an offset of zero. 4519 4520 `TARGET_HAS_HARDWARE_WATCHPOINTS' 4521 If non-zero, the target has support for hardware-assisted 4522 watchpoints. *Note watchpoints: Algorithms, for more details and 4523 other related macros. 4524 4525 `int gdbarch_print_insn (GDBARCH, VMA, INFO)' 4526 This is the function used by GDB to print an assembly instruction. 4527 It prints the instruction at address VMA in debugged memory and 4528 returns the length of the instruction, in bytes. This usually 4529 points to a function in the `opcodes' library (*note Opcodes: 4530 Support Libraries.). INFO is a structure (of type 4531 `disassemble_info') defined in the header file 4532 `include/dis-asm.h', and used to pass information to the 4533 instruction decoding routine. 4534 4535 `frame_id gdbarch_dummy_id (GDBARCH, FRAME)' 4536 Given FRAME return a `struct frame_id' that uniquely identifies an 4537 inferior function call's dummy frame. The value returned must 4538 match the dummy frame stack value previously saved by 4539 `call_function_by_hand'. 4540 4541 `void gdbarch_value_to_register (GDBARCH, FRAME, TYPE, BUF)' 4542 Convert a value of type TYPE into the raw contents of a register. 4543 *Note Using Different Register and Memory Data Representations: 4544 Target Architecture Definition. 4545 4546 4547 Motorola M68K target conditionals. 4548 4549 `BPT_VECTOR' 4550 Define this to be the 4-bit location of the breakpoint trap 4551 vector. If not defined, it will default to `0xf'. 4552 4553 `REMOTE_BPT_VECTOR' 4554 Defaults to `1'. 4555 4556 4557 4558 File: gdbint.info, Node: Adding a New Target, Prev: Defining Other Architecture Features, Up: Target Architecture Definition 4559 4560 11.11 Adding a New Target 4561 ========================= 4562 4563 The following files add a target to GDB: 4564 4565 `gdb/TTT-tdep.c' 4566 Contains any miscellaneous code required for this target machine. 4567 On some machines it doesn't exist at all. 4568 4569 `gdb/ARCH-tdep.c' 4570 `gdb/ARCH-tdep.h' 4571 This is required to describe the basic layout of the target 4572 machine's processor chip (registers, stack, etc.). It can be 4573 shared among many targets that use the same processor architecture. 4574 4575 4576 (Target header files such as `gdb/config/ARCH/tm-TTT.h', 4577 `gdb/config/ARCH/tm-ARCH.h', and `config/tm-OS.h' are no longer used.) 4578 4579 A GDB description for a new architecture, arch is created by 4580 defining a global function `_initialize_ARCH_tdep', by convention in 4581 the source file `ARCH-tdep.c'. For example, in the case of the 4582 OpenRISC 1000, this function is called `_initialize_or1k_tdep' and is 4583 found in the file `or1k-tdep.c'. 4584 4585 The object file resulting from compiling this source file, which will 4586 contain the implementation of the `_initialize_ARCH_tdep' function is 4587 specified in the GDB `configure.tgt' file, which includes a large case 4588 statement pattern matching against the `--target' option of the 4589 `configure' script. 4590 4591 _Note:_ If the architecture requires multiple source files, the 4592 corresponding binaries should be included in `configure.tgt'. 4593 However if there are header files, the dependencies on these will 4594 not be picked up from the entries in `configure.tgt'. The 4595 `Makefile.in' file will need extending to show these dependencies. 4596 4597 A new struct gdbarch, defining the new architecture, is created 4598 within the `_initialize_ARCH_tdep' function by calling 4599 `gdbarch_register': 4600 4601 void gdbarch_register (enum bfd_architecture architecture, 4602 gdbarch_init_ftype *init_func, 4603 gdbarch_dump_tdep_ftype *tdep_dump_func); 4604 4605 This function has been described fully in an earlier section. *Note 4606 How an Architecture is Represented: How an Architecture is Represented. 4607 4608 The new `struct gdbarch' should contain implementations of the 4609 necessary functions (described in the previous sections) to describe 4610 the basic layout of the target machine's processor chip (registers, 4611 stack, etc.). It can be shared among many targets that use the same 4612 processor architecture. 4613 4614 4615 File: gdbint.info, Node: Target Descriptions, Next: Target Vector Definition, Prev: Target Architecture Definition, Up: Top 4616 4617 12 Target Descriptions 4618 ********************** 4619 4620 The target architecture definition (*note Target Architecture 4621 Definition::) contains GDB's hard-coded knowledge about an 4622 architecture. For some platforms, it is handy to have more flexible 4623 knowledge about a specific instance of the architecture--for instance, 4624 a processor or development board. "Target descriptions" provide a 4625 mechanism for the user to tell GDB more about what their target 4626 supports, or for the target to tell GDB directly. 4627 4628 For details on writing, automatically supplying, and manually 4629 selecting target descriptions, see *note Target Descriptions: 4630 (gdb)Target Descriptions. This section will cover some related topics 4631 about the GDB internals. 4632 4633 * Menu: 4634 4635 * Target Descriptions Implementation:: 4636 * Adding Target Described Register Support:: 4637 4638 4639 File: gdbint.info, Node: Target Descriptions Implementation, Next: Adding Target Described Register Support, Up: Target Descriptions 4640 4641 12.1 Target Descriptions Implementation 4642 ======================================= 4643 4644 Before GDB connects to a new target, or runs a new program on an 4645 existing target, it discards any existing target description and 4646 reverts to a default gdbarch. Then, after connecting, it looks for a 4647 new target description by calling `target_find_description'. 4648 4649 A description may come from a user specified file (XML), the remote 4650 `qXfer:features:read' packet (also XML), or from any custom 4651 `to_read_description' routine in the target vector. For instance, the 4652 remote target supports guessing whether a MIPS target is 32-bit or 4653 64-bit based on the size of the `g' packet. 4654 4655 If any target description is found, GDB creates a new gdbarch 4656 incorporating the description by calling `gdbarch_update_p'. Any 4657 `<architecture>' element is handled first, to determine which 4658 architecture's gdbarch initialization routine is called to create the 4659 new architecture. Then the initialization routine is called, and has a 4660 chance to adjust the constructed architecture based on the contents of 4661 the target description. For instance, it can recognize any properties 4662 set by a `to_read_description' routine. Also see *note Adding Target 4663 Described Register Support::. 4664 4665 4666 File: gdbint.info, Node: Adding Target Described Register Support, Prev: Target Descriptions Implementation, Up: Target Descriptions 4667 4668 12.2 Adding Target Described Register Support 4669 ============================================= 4670 4671 Target descriptions can report additional registers specific to an 4672 instance of the target. But it takes a little work in the architecture 4673 specific routines to support this. 4674 4675 A target description must either have no registers or a complete 4676 set--this avoids complexity in trying to merge standard registers with 4677 the target defined registers. It is the architecture's responsibility 4678 to validate that a description with registers has everything it needs. 4679 To keep architecture code simple, the same mechanism is used to assign 4680 fixed internal register numbers to standard registers. 4681 4682 If `tdesc_has_registers' returns 1, the description contains 4683 registers. The architecture's `gdbarch_init' routine should: 4684 4685 * Call `tdesc_data_alloc' to allocate storage, early, before 4686 searching for a matching gdbarch or allocating a new one. 4687 4688 * Use `tdesc_find_feature' to locate standard features by name. 4689 4690 * Use `tdesc_numbered_register' and `tdesc_numbered_register_choices' 4691 to locate the expected registers in the standard features. 4692 4693 * Return `NULL' if a required feature is missing, or if any standard 4694 feature is missing expected registers. This will produce a 4695 warning that the description was incomplete. 4696 4697 * Free the allocated data before returning, unless 4698 `tdesc_use_registers' is called. 4699 4700 * Call `set_gdbarch_num_regs' as usual, with a number higher than any 4701 fixed number passed to `tdesc_numbered_register'. 4702 4703 * Call `tdesc_use_registers' after creating a new gdbarch, before 4704 returning it. 4705 4706 4707 After `tdesc_use_registers' has been called, the architecture's 4708 `register_name', `register_type', and `register_reggroup_p' routines 4709 will not be called; that information will be taken from the target 4710 description. `num_regs' may be increased to account for any additional 4711 registers in the description. 4712 4713 Pseudo-registers require some extra care: 4714 4715 * Using `tdesc_numbered_register' allows the architecture to give 4716 constant register numbers to standard architectural registers, e.g. 4717 as an `enum' in `ARCH-tdep.h'. But because pseudo-registers are 4718 always numbered above `num_regs', which may be increased by the 4719 description, constant numbers can not be used for pseudos. They 4720 must be numbered relative to `num_regs' instead. 4721 4722 * The description will not describe pseudo-registers, so the 4723 architecture must call `set_tdesc_pseudo_register_name', 4724 `set_tdesc_pseudo_register_type', and 4725 `set_tdesc_pseudo_register_reggroup_p' to supply routines 4726 describing pseudo registers. These routines will be passed 4727 internal register numbers, so the same routines used for the 4728 gdbarch equivalents are usually suitable. 4729 4730 4731 4732 File: gdbint.info, Node: Target Vector Definition, Next: Native Debugging, Prev: Target Descriptions, Up: Top 4733 4734 13 Target Vector Definition 4735 *************************** 4736 4737 The target vector defines the interface between GDB's abstract handling 4738 of target systems, and the nitty-gritty code that actually exercises 4739 control over a process or a serial port. GDB includes some 30-40 4740 different target vectors; however, each configuration of GDB includes 4741 only a few of them. 4742 4743 * Menu: 4744 4745 * Managing Execution State:: 4746 * Existing Targets:: 4747 4748 4749 File: gdbint.info, Node: Managing Execution State, Next: Existing Targets, Up: Target Vector Definition 4750 4751 13.1 Managing Execution State 4752 ============================= 4753 4754 A target vector can be completely inactive (not pushed on the target 4755 stack), active but not running (pushed, but not connected to a fully 4756 manifested inferior), or completely active (pushed, with an accessible 4757 inferior). Most targets are only completely inactive or completely 4758 active, but some support persistent connections to a target even when 4759 the target has exited or not yet started. 4760 4761 For example, connecting to the simulator using `target sim' does not 4762 create a running program. Neither registers nor memory are accessible 4763 until `run'. Similarly, after `kill', the program can not continue 4764 executing. But in both cases GDB remains connected to the simulator, 4765 and target-specific commands are directed to the simulator. 4766 4767 A target which only supports complete activation should push itself 4768 onto the stack in its `to_open' routine (by calling `push_target'), and 4769 unpush itself from the stack in its `to_mourn_inferior' routine (by 4770 calling `unpush_target'). 4771 4772 A target which supports both partial and complete activation should 4773 still call `push_target' in `to_open', but not call `unpush_target' in 4774 `to_mourn_inferior'. Instead, it should call either 4775 `target_mark_running' or `target_mark_exited' in its `to_open', 4776 depending on whether the target is fully active after connection. It 4777 should also call `target_mark_running' any time the inferior becomes 4778 fully active (e.g. in `to_create_inferior' and `to_attach'), and 4779 `target_mark_exited' when the inferior becomes inactive (in 4780 `to_mourn_inferior'). The target should also make sure to call 4781 `target_mourn_inferior' from its `to_kill', to return the target to 4782 inactive state. 4783 4784 4785 File: gdbint.info, Node: Existing Targets, Prev: Managing Execution State, Up: Target Vector Definition 4786 4787 13.2 Existing Targets 4788 ===================== 4789 4790 13.2.1 File Targets 4791 ------------------- 4792 4793 Both executables and core files have target vectors. 4794 4795 13.2.2 Standard Protocol and Remote Stubs 4796 ----------------------------------------- 4797 4798 GDB's file `remote.c' talks a serial protocol to code that runs in the 4799 target system. GDB provides several sample "stubs" that can be 4800 integrated into target programs or operating systems for this purpose; 4801 they are named `CPU-stub.c'. Many operating systems, embedded targets, 4802 emulators, and simulators already have a GDB stub built into them, and 4803 maintenance of the remote protocol must be careful to preserve 4804 compatibility. 4805 4806 The GDB user's manual describes how to put such a stub into your 4807 target code. What follows is a discussion of integrating the SPARC 4808 stub into a complicated operating system (rather than a simple 4809 program), by Stu Grossman, the author of this stub. 4810 4811 The trap handling code in the stub assumes the following upon entry 4812 to `trap_low': 4813 4814 1. %l1 and %l2 contain pc and npc respectively at the time of the 4815 trap; 4816 4817 2. traps are disabled; 4818 4819 3. you are in the correct trap window. 4820 4821 As long as your trap handler can guarantee those conditions, then 4822 there is no reason why you shouldn't be able to "share" traps with the 4823 stub. The stub has no requirement that it be jumped to directly from 4824 the hardware trap vector. That is why it calls `exceptionHandler()', 4825 which is provided by the external environment. For instance, this could 4826 set up the hardware traps to actually execute code which calls the stub 4827 first, and then transfers to its own trap handler. 4828 4829 For the most point, there probably won't be much of an issue with 4830 "sharing" traps, as the traps we use are usually not used by the kernel, 4831 and often indicate unrecoverable error conditions. Anyway, this is all 4832 controlled by a table, and is trivial to modify. The most important 4833 trap for us is for `ta 1'. Without that, we can't single step or do 4834 breakpoints. Everything else is unnecessary for the proper operation 4835 of the debugger/stub. 4836 4837 From reading the stub, it's probably not obvious how breakpoints 4838 work. They are simply done by deposit/examine operations from GDB. 4839 4840 13.2.3 ROM Monitor Interface 4841 ---------------------------- 4842 4843 13.2.4 Custom Protocols 4844 ----------------------- 4845 4846 13.2.5 Transport Layer 4847 ---------------------- 4848 4849 13.2.6 Builtin Simulator 4850 ------------------------ 4851 4852 4853 File: gdbint.info, Node: Native Debugging, Next: Support Libraries, Prev: Target Vector Definition, Up: Top 4854 4855 14 Native Debugging 4856 ******************* 4857 4858 Several files control GDB's configuration for native support: 4859 4860 `gdb/config/ARCH/XYZ.mh' 4861 Specifies Makefile fragments needed by a _native_ configuration on 4862 machine XYZ. In particular, this lists the required 4863 native-dependent object files, by defining `NATDEPFILES=...'. 4864 Also specifies the header file which describes native support on 4865 XYZ, by defining `NAT_FILE= nm-XYZ.h'. You can also define 4866 `NAT_CFLAGS', `NAT_ADD_FILES', `NAT_CLIBS', `NAT_CDEPS', 4867 `NAT_GENERATED_FILES', etc.; see `Makefile.in'. 4868 4869 _Maintainer's note: The `.mh' suffix is because this file 4870 originally contained `Makefile' fragments for hosting GDB on 4871 machine XYZ. While the file is no longer used for this purpose, 4872 the `.mh' suffix remains. Perhaps someone will eventually rename 4873 these fragments so that they have a `.mn' suffix._ 4874 4875 `gdb/config/ARCH/nm-XYZ.h' 4876 (`nm.h' is a link to this file, created by `configure'). Contains 4877 C macro definitions describing the native system environment, such 4878 as child process control and core file support. 4879 4880 `gdb/XYZ-nat.c' 4881 Contains any miscellaneous C code required for this native support 4882 of this machine. On some machines it doesn't exist at all. 4883 4884 There are some "generic" versions of routines that can be used by 4885 various systems. These can be customized in various ways by macros 4886 defined in your `nm-XYZ.h' file. If these routines work for the XYZ 4887 host, you can just include the generic file's name (with `.o', not 4888 `.c') in `NATDEPFILES'. 4889 4890 Otherwise, if your machine needs custom support routines, you will 4891 need to write routines that perform the same functions as the generic 4892 file. Put them into `XYZ-nat.c', and put `XYZ-nat.o' into 4893 `NATDEPFILES'. 4894 4895 `inftarg.c' 4896 This contains the _target_ops vector_ that supports Unix child 4897 processes on systems which use ptrace and wait to control the 4898 child. 4899 4900 `procfs.c' 4901 This contains the _target_ops vector_ that supports Unix child 4902 processes on systems which use /proc to control the child. 4903 4904 `fork-child.c' 4905 This does the low-level grunge that uses Unix system calls to do a 4906 "fork and exec" to start up a child process. 4907 4908 `infptrace.c' 4909 This is the low level interface to inferior processes for systems 4910 using the Unix `ptrace' call in a vanilla way. 4911 4912 14.1 ptrace 4913 =========== 4914 4915 14.2 /proc 4916 ========== 4917 4918 14.3 win32 4919 ========== 4920 4921 14.4 shared libraries 4922 ===================== 4923 4924 14.5 Native Conditionals 4925 ======================== 4926 4927 When GDB is configured and compiled, various macros are defined or left 4928 undefined, to control compilation when the host and target systems are 4929 the same. These macros should be defined (or left undefined) in 4930 `nm-SYSTEM.h'. 4931 4932 `I386_USE_GENERIC_WATCHPOINTS' 4933 An x86-based machine can define this to use the generic x86 4934 watchpoint support; see *note I386_USE_GENERIC_WATCHPOINTS: 4935 Algorithms. 4936 4937 `SOLIB_ADD (FILENAME, FROM_TTY, TARG, READSYMS)' 4938 Define this to expand into an expression that will cause the 4939 symbols in FILENAME to be added to GDB's symbol table. If 4940 READSYMS is zero symbols are not read but any necessary low level 4941 processing for FILENAME is still done. 4942 4943 `SOLIB_CREATE_INFERIOR_HOOK' 4944 Define this to expand into any shared-library-relocation code that 4945 you want to be run just after the child process has been forked. 4946 4947 `START_INFERIOR_TRAPS_EXPECTED' 4948 When starting an inferior, GDB normally expects to trap twice; 4949 once when the shell execs, and once when the program itself execs. 4950 If the actual number of traps is something other than 2, then 4951 define this macro to expand into the number expected. 4952 4953 4954 4955 File: gdbint.info, Node: Support Libraries, Next: Coding Standards, Prev: Native Debugging, Up: Top 4956 4957 15 Support Libraries 4958 ******************** 4959 4960 15.1 BFD 4961 ======== 4962 4963 BFD provides support for GDB in several ways: 4964 4965 _identifying executable and core files_ 4966 BFD will identify a variety of file types, including a.out, coff, 4967 and several variants thereof, as well as several kinds of core 4968 files. 4969 4970 _access to sections of files_ 4971 BFD parses the file headers to determine the names, virtual 4972 addresses, sizes, and file locations of all the various named 4973 sections in files (such as the text section or the data section). 4974 GDB simply calls BFD to read or write section X at byte offset Y 4975 for length Z. 4976 4977 _specialized core file support_ 4978 BFD provides routines to determine the failing command name stored 4979 in a core file, the signal with which the program failed, and 4980 whether a core file matches (i.e. could be a core dump of) a 4981 particular executable file. 4982 4983 _locating the symbol information_ 4984 GDB uses an internal interface of BFD to determine where to find 4985 the symbol information in an executable file or symbol-file. GDB 4986 itself handles the reading of symbols, since BFD does not 4987 "understand" debug symbols, but GDB uses BFD's cached information 4988 to find the symbols, string table, etc. 4989 4990 15.2 opcodes 4991 ============ 4992 4993 The opcodes library provides GDB's disassembler. (It's a separate 4994 library because it's also used in binutils, for `objdump'). 4995 4996 15.3 readline 4997 ============= 4998 4999 The `readline' library provides a set of functions for use by 5000 applications that allow users to edit command lines as they are typed 5001 in. 5002 5003 15.4 libiberty 5004 ============== 5005 5006 The `libiberty' library provides a set of functions and features that 5007 integrate and improve on functionality found in modern operating 5008 systems. Broadly speaking, such features can be divided into three 5009 groups: supplemental functions (functions that may be missing in some 5010 environments and operating systems), replacement functions (providing a 5011 uniform and easier to use interface for commonly used standard 5012 functions), and extensions (which provide additional functionality 5013 beyond standard functions). 5014 5015 GDB uses various features provided by the `libiberty' library, for 5016 instance the C++ demangler, the IEEE floating format support functions, 5017 the input options parser `getopt', the `obstack' extension, and other 5018 functions. 5019 5020 15.4.1 `obstacks' in GDB 5021 ------------------------ 5022 5023 The obstack mechanism provides a convenient way to allocate and free 5024 chunks of memory. Each obstack is a pool of memory that is managed 5025 like a stack. Objects (of any nature, size and alignment) are 5026 allocated and freed in a LIFO fashion on an obstack (see `libiberty''s 5027 documentation for a more detailed explanation of `obstacks'). 5028 5029 The most noticeable use of the `obstacks' in GDB is in object files. 5030 There is an obstack associated with each internal representation of an 5031 object file. Lots of things get allocated on these `obstacks': 5032 dictionary entries, blocks, blockvectors, symbols, minimal symbols, 5033 types, vectors of fundamental types, class fields of types, object 5034 files section lists, object files section offset lists, line tables, 5035 symbol tables, partial symbol tables, string tables, symbol table 5036 private data, macros tables, debug information sections and entries, 5037 import and export lists (som), unwind information (hppa), dwarf2 5038 location expressions data. Plus various strings such as directory 5039 names strings, debug format strings, names of types. 5040 5041 An essential and convenient property of all data on `obstacks' is 5042 that memory for it gets allocated (with `obstack_alloc') at various 5043 times during a debugging session, but it is released all at once using 5044 the `obstack_free' function. The `obstack_free' function takes a 5045 pointer to where in the stack it must start the deletion from (much 5046 like the cleanup chains have a pointer to where to start the cleanups). 5047 Because of the stack like structure of the `obstacks', this allows to 5048 free only a top portion of the obstack. There are a few instances in 5049 GDB where such thing happens. Calls to `obstack_free' are done after 5050 some local data is allocated to the obstack. Only the local data is 5051 deleted from the obstack. Of course this assumes that nothing between 5052 the `obstack_alloc' and the `obstack_free' allocates anything else on 5053 the same obstack. For this reason it is best and safest to use 5054 temporary `obstacks'. 5055 5056 Releasing the whole obstack is also not safe per se. It is safe only 5057 under the condition that we know the `obstacks' memory is no longer 5058 needed. In GDB we get rid of the `obstacks' only when we get rid of 5059 the whole objfile(s), for instance upon reading a new symbol file. 5060 5061 15.5 gnu-regex 5062 ============== 5063 5064 Regex conditionals. 5065 5066 `C_ALLOCA' 5067 5068 `NFAILURES' 5069 5070 `RE_NREGS' 5071 5072 `SIGN_EXTEND_CHAR' 5073 5074 `SWITCH_ENUM_BUG' 5075 5076 `SYNTAX_TABLE' 5077 5078 `Sword' 5079 5080 `sparc' 5081 5082 15.6 Array Containers 5083 ===================== 5084 5085 Often it is necessary to manipulate a dynamic array of a set of 5086 objects. C forces some bookkeeping on this, which can get cumbersome 5087 and repetitive. The `vec.h' file contains macros for defining and 5088 using a typesafe vector type. The functions defined will be inlined 5089 when compiling, and so the abstraction cost should be zero. Domain 5090 checks are added to detect programming errors. 5091 5092 An example use would be an array of symbols or section information. 5093 The array can be grown as symbols are read in (or preallocated), and 5094 the accessor macros provided keep care of all the necessary 5095 bookkeeping. Because the arrays are type safe, there is no danger of 5096 accidentally mixing up the contents. Think of these as C++ templates, 5097 but implemented in C. 5098 5099 Because of the different behavior of structure objects, scalar 5100 objects and of pointers, there are three flavors of vector, one for 5101 each of these variants. Both the structure object and pointer variants 5102 pass pointers to objects around -- in the former case the pointers are 5103 stored into the vector and in the latter case the pointers are 5104 dereferenced and the objects copied into the vector. The scalar object 5105 variant is suitable for `int'-like objects, and the vector elements are 5106 returned by value. 5107 5108 There are both `index' and `iterate' accessors. The iterator 5109 returns a boolean iteration condition and updates the iteration 5110 variable passed by reference. Because the iterator will be inlined, 5111 the address-of can be optimized away. 5112 5113 The vectors are implemented using the trailing array idiom, thus they 5114 are not resizeable without changing the address of the vector object 5115 itself. This means you cannot have variables or fields of vector type 5116 -- always use a pointer to a vector. The one exception is the final 5117 field of a structure, which could be a vector type. You will have to 5118 use the `embedded_size' & `embedded_init' calls to create such objects, 5119 and they will probably not be resizeable (so don't use the "safe" 5120 allocation variants). The trailing array idiom is used (rather than a 5121 pointer to an array of data), because, if we allow `NULL' to also 5122 represent an empty vector, empty vectors occupy minimal space in the 5123 structure containing them. 5124 5125 Each operation that increases the number of active elements is 5126 available in "quick" and "safe" variants. The former presumes that 5127 there is sufficient allocated space for the operation to succeed (it 5128 dies if there is not). The latter will reallocate the vector, if 5129 needed. Reallocation causes an exponential increase in vector size. 5130 If you know you will be adding N elements, it would be more efficient 5131 to use the reserve operation before adding the elements with the 5132 "quick" operation. This will ensure there are at least as many 5133 elements as you ask for, it will exponentially increase if there are 5134 too few spare slots. If you want reserve a specific number of slots, 5135 but do not want the exponential increase (for instance, you know this 5136 is the last allocation), use a negative number for reservation. You 5137 can also create a vector of a specific size from the get go. 5138 5139 You should prefer the push and pop operations, as they append and 5140 remove from the end of the vector. If you need to remove several items 5141 in one go, use the truncate operation. The insert and remove 5142 operations allow you to change elements in the middle of the vector. 5143 There are two remove operations, one which preserves the element 5144 ordering `ordered_remove', and one which does not `unordered_remove'. 5145 The latter function copies the end element into the removed slot, 5146 rather than invoke a memmove operation. The `lower_bound' function 5147 will determine where to place an item in the array using insert that 5148 will maintain sorted order. 5149 5150 If you need to directly manipulate a vector, then the `address' 5151 accessor will return the address of the start of the vector. Also the 5152 `space' predicate will tell you whether there is spare capacity in the 5153 vector. You will not normally need to use these two functions. 5154 5155 Vector types are defined using a `DEF_VEC_{O,P,I}(TYPENAME)' macro. 5156 Variables of vector type are declared using a `VEC(TYPENAME)' macro. 5157 The characters `O', `P' and `I' indicate whether TYPENAME is an object 5158 (`O'), pointer (`P') or integral (`I') type. Be careful to pick the 5159 correct one, as you'll get an awkward and inefficient API if you use 5160 the wrong one. There is a check, which results in a compile-time 5161 warning, for the `P' and `I' versions, but there is no check for the 5162 `O' versions, as that is not possible in plain C. 5163 5164 An example of their use would be, 5165 5166 DEF_VEC_P(tree); // non-managed tree vector. 5167 5168 struct my_struct { 5169 VEC(tree) *v; // A (pointer to) a vector of tree pointers. 5170 }; 5171 5172 struct my_struct *s; 5173 5174 if (VEC_length(tree, s->v)) { we have some contents } 5175 VEC_safe_push(tree, s->v, decl); // append some decl onto the end 5176 for (ix = 0; VEC_iterate(tree, s->v, ix, elt); ix++) 5177 { do something with elt } 5178 5179 The `vec.h' file provides details on how to invoke the various 5180 accessors provided. They are enumerated here: 5181 5182 `VEC_length' 5183 Return the number of items in the array, 5184 5185 `VEC_empty' 5186 Return true if the array has no elements. 5187 5188 `VEC_last' 5189 `VEC_index' 5190 Return the last or arbitrary item in the array. 5191 5192 `VEC_iterate' 5193 Access an array element and indicate whether the array has been 5194 traversed. 5195 5196 `VEC_alloc' 5197 `VEC_free' 5198 Create and destroy an array. 5199 5200 `VEC_embedded_size' 5201 `VEC_embedded_init' 5202 Helpers for embedding an array as the final element of another 5203 struct. 5204 5205 `VEC_copy' 5206 Duplicate an array. 5207 5208 `VEC_space' 5209 Return the amount of free space in an array. 5210 5211 `VEC_reserve' 5212 Ensure a certain amount of free space. 5213 5214 `VEC_quick_push' 5215 `VEC_safe_push' 5216 Append to an array, either assuming the space is available, or 5217 making sure that it is. 5218 5219 `VEC_pop' 5220 Remove the last item from an array. 5221 5222 `VEC_truncate' 5223 Remove several items from the end of an array. 5224 5225 `VEC_safe_grow' 5226 Add several items to the end of an array. 5227 5228 `VEC_replace' 5229 Overwrite an item in the array. 5230 5231 `VEC_quick_insert' 5232 `VEC_safe_insert' 5233 Insert an item into the middle of the array. Either the space must 5234 already exist, or the space is created. 5235 5236 `VEC_ordered_remove' 5237 `VEC_unordered_remove' 5238 Remove an item from the array, preserving order or not. 5239 5240 `VEC_block_remove' 5241 Remove a set of items from the array. 5242 5243 `VEC_address' 5244 Provide the address of the first element. 5245 5246 `VEC_lower_bound' 5247 Binary search the array. 5248 5249 5250 15.7 include 5251 ============ 5252 5253 5254 File: gdbint.info, Node: Coding Standards, Next: Misc Guidelines, Prev: Support Libraries, Up: Top 5255 5256 16 Coding Standards 5257 ******************* 5258 5259 16.1 GDB C Coding Standards 5260 =========================== 5261 5262 GDB follows the GNU coding standards, as described in 5263 `etc/standards.texi'. This file is also available for anonymous FTP 5264 from GNU archive sites. GDB takes a strict interpretation of the 5265 standard; in general, when the GNU standard recommends a practice but 5266 does not require it, GDB requires it. 5267 5268 GDB follows an additional set of coding standards specific to GDB, 5269 as described in the following sections. 5270 5271 16.1.1 ISO C 5272 ------------ 5273 5274 GDB assumes an ISO/IEC 9899:1990 (a.k.a. ISO C90) compliant compiler. 5275 5276 GDB does not assume an ISO C or POSIX compliant C library. 5277 5278 16.1.2 Formatting 5279 ----------------- 5280 5281 The standard GNU recommendations for formatting must be followed 5282 strictly. Any GDB-specific deviation from GNU recomendations is 5283 described below. 5284 5285 A function declaration should not have its name in column zero. A 5286 function definition should have its name in column zero. 5287 5288 /* Declaration */ 5289 static void foo (void); 5290 /* Definition */ 5291 void 5292 foo (void) 5293 { 5294 } 5295 5296 _Pragmatics: This simplifies scripting. Function definitions can be 5297 found using `^function-name'._ 5298 5299 There must be a space between a function or macro name and the 5300 opening parenthesis of its argument list (except for macro definitions, 5301 as required by C). There must not be a space after an open 5302 paren/bracket or before a close paren/bracket. 5303 5304 While additional whitespace is generally helpful for reading, do not 5305 use more than one blank line to separate blocks, and avoid adding 5306 whitespace after the end of a program line (as of 1/99, some 600 lines 5307 had whitespace after the semicolon). Excess whitespace causes 5308 difficulties for `diff' and `patch' utilities. 5309 5310 Pointers are declared using the traditional K&R C style: 5311 5312 void *foo; 5313 5314 and not: 5315 5316 void * foo; 5317 void* foo; 5318 5319 In addition, whitespace around casts and unary operators should 5320 follow the following guidelines: 5321 5322 Use... ...instead of 5323 `!x' `! x' 5324 `~x' `~ x' 5325 `-x' `- x' (unary minus) 5326 `(foo) x' `(foo)x' (cast) 5327 `*x' `* x' (pointer dereference) 5328 5329 16.1.3 Comments 5330 --------------- 5331 5332 The standard GNU requirements on comments must be followed strictly. 5333 5334 Block comments must appear in the following form, with no `/*'- or 5335 `*/'-only lines, and no leading `*': 5336 5337 /* Wait for control to return from inferior to debugger. If inferior 5338 gets a signal, we may decide to start it up again instead of 5339 returning. That is why there is a loop in this function. When 5340 this function actually returns it means the inferior should be left 5341 stopped and GDB should read more commands. */ 5342 5343 (Note that this format is encouraged by Emacs; tabbing for a 5344 multi-line comment works correctly, and `M-q' fills the block 5345 consistently.) 5346 5347 Put a blank line between the block comments preceding function or 5348 variable definitions, and the definition itself. 5349 5350 In general, put function-body comments on lines by themselves, rather 5351 than trying to fit them into the 20 characters left at the end of a 5352 line, since either the comment or the code will inevitably get longer 5353 than will fit, and then somebody will have to move it anyhow. 5354 5355 16.1.4 C Usage 5356 -------------- 5357 5358 Code must not depend on the sizes of C data types, the format of the 5359 host's floating point numbers, the alignment of anything, or the order 5360 of evaluation of expressions. 5361 5362 Use functions freely. There are only a handful of compute-bound 5363 areas in GDB that might be affected by the overhead of a function call, 5364 mainly in symbol reading. Most of GDB's performance is limited by the 5365 target interface (whether serial line or system call). 5366 5367 However, use functions with moderation. A thousand one-line 5368 functions are just as hard to understand as a single thousand-line 5369 function. 5370 5371 _Macros are bad, M'kay._ (But if you have to use a macro, make sure 5372 that the macro arguments are protected with parentheses.) 5373 5374 Declarations like `struct foo *' should be used in preference to 5375 declarations like `typedef struct foo { ... } *foo_ptr'. 5376 5377 16.1.5 Function Prototypes 5378 -------------------------- 5379 5380 Prototypes must be used when both _declaring_ and _defining_ a 5381 function. Prototypes for GDB functions must include both the argument 5382 type and name, with the name matching that used in the actual function 5383 definition. 5384 5385 All external functions should have a declaration in a header file 5386 that callers include, except for `_initialize_*' functions, which must 5387 be external so that `init.c' construction works, but shouldn't be 5388 visible to random source files. 5389 5390 Where a source file needs a forward declaration of a static function, 5391 that declaration must appear in a block near the top of the source file. 5392 5393 16.1.6 File Names 5394 ----------------- 5395 5396 Any file used when building the core of GDB must be in lower case. Any 5397 file used when building the core of GDB must be 8.3 unique. These 5398 requirements apply to both source and generated files. 5399 5400 _Pragmatics: The core of GDB must be buildable on many platforms 5401 including DJGPP and MacOS/HFS. Every time an unfriendly file is 5402 introduced to the build process both `Makefile.in' and `configure.in' 5403 need to be modified accordingly. Compare the convoluted conversion 5404 process needed to transform `COPYING' into `copying.c' with the 5405 conversion needed to transform `version.in' into `version.c'._ 5406 5407 Any file non 8.3 compliant file (that is not used when building the 5408 core of GDB) must be added to `gdb/config/djgpp/fnchange.lst'. 5409 5410 _Pragmatics: This is clearly a compromise._ 5411 5412 When GDB has a local version of a system header file (ex `string.h') 5413 the file name based on the POSIX header prefixed with `gdb_' 5414 (`gdb_string.h'). These headers should be relatively independent: they 5415 should use only macros defined by `configure', the compiler, or the 5416 host; they should include only system headers; they should refer only 5417 to system types. They may be shared between multiple programs, e.g. 5418 GDB and GDBSERVER. 5419 5420 For other files `-' is used as the separator. 5421 5422 16.1.7 Include Files 5423 -------------------- 5424 5425 A `.c' file should include `defs.h' first. 5426 5427 A `.c' file should directly include the `.h' file of every 5428 declaration and/or definition it directly refers to. It cannot rely on 5429 indirect inclusion. 5430 5431 A `.h' file should directly include the `.h' file of every 5432 declaration and/or definition it directly refers to. It cannot rely on 5433 indirect inclusion. Exception: The file `defs.h' does not need to be 5434 directly included. 5435 5436 An external declaration should only appear in one include file. 5437 5438 An external declaration should never appear in a `.c' file. 5439 Exception: a declaration for the `_initialize' function that pacifies 5440 `-Wmissing-declaration'. 5441 5442 A `typedef' definition should only appear in one include file. 5443 5444 An opaque `struct' declaration can appear in multiple `.h' files. 5445 Where possible, a `.h' file should use an opaque `struct' declaration 5446 instead of an include. 5447 5448 All `.h' files should be wrapped in: 5449 5450 #ifndef INCLUDE_FILE_NAME_H 5451 #define INCLUDE_FILE_NAME_H 5452 header body 5453 #endif 5454 5455 16.2 GDB Python Coding Standards 5456 ================================ 5457 5458 GDB follows the published `Python' coding standards in `PEP008' 5459 (http://www.python.org/dev/peps/pep-0008/). 5460 5461 In addition, the guidelines in the Google Python Style Guide 5462 (http://google-styleguide.googlecode.com/svn/trunk/pyguide.html) are 5463 also followed where they do not conflict with `PEP008'. 5464 5465 16.2.1 GDB-specific exceptions 5466 ------------------------------ 5467 5468 There are a few exceptions to the published standards. They exist 5469 mainly for consistency with the `C' standards. 5470 5471 * Use `FIXME' instead of `TODO'. 5472 5473 5474 5475 File: gdbint.info, Node: Misc Guidelines, Next: Porting GDB, Prev: Coding Standards, Up: Top 5476 5477 17 Misc Guidelines 5478 ****************** 5479 5480 This chapter covers topics that are lower-level than the major 5481 algorithms of GDB. 5482 5483 17.1 Cleanups 5484 ============= 5485 5486 Cleanups are a structured way to deal with things that need to be done 5487 later. 5488 5489 When your code does something (e.g., `xmalloc' some memory, or 5490 `open' a file) that needs to be undone later (e.g., `xfree' the memory 5491 or `close' the file), it can make a cleanup. The cleanup will be done 5492 at some future point: when the command is finished and control returns 5493 to the top level; when an error occurs and the stack is unwound; or 5494 when your code decides it's time to explicitly perform cleanups. 5495 Alternatively you can elect to discard the cleanups you created. 5496 5497 Syntax: 5498 5499 `struct cleanup *OLD_CHAIN;' 5500 Declare a variable which will hold a cleanup chain handle. 5501 5502 `OLD_CHAIN = make_cleanup (FUNCTION, ARG);' 5503 Make a cleanup which will cause FUNCTION to be called with ARG (a 5504 `char *') later. The result, OLD_CHAIN, is a handle that can 5505 later be passed to `do_cleanups' or `discard_cleanups'. Unless 5506 you are going to call `do_cleanups' or `discard_cleanups', you can 5507 ignore the result from `make_cleanup'. 5508 5509 `do_cleanups (OLD_CHAIN);' 5510 Do all cleanups added to the chain since the corresponding 5511 `make_cleanup' call was made. 5512 5513 `discard_cleanups (OLD_CHAIN);' 5514 Same as `do_cleanups' except that it just removes the cleanups from 5515 the chain and does not call the specified functions. 5516 5517 Cleanups are implemented as a chain. The handle returned by 5518 `make_cleanups' includes the cleanup passed to the call and any later 5519 cleanups appended to the chain (but not yet discarded or performed). 5520 E.g.: 5521 5522 make_cleanup (a, 0); 5523 { 5524 struct cleanup *old = make_cleanup (b, 0); 5525 make_cleanup (c, 0) 5526 ... 5527 do_cleanups (old); 5528 } 5529 5530 will call `c()' and `b()' but will not call `a()'. The cleanup that 5531 calls `a()' will remain in the cleanup chain, and will be done later 5532 unless otherwise discarded. 5533 5534 Your function should explicitly do or discard the cleanups it 5535 creates. Failing to do this leads to non-deterministic behavior since 5536 the caller will arbitrarily do or discard your functions cleanups. 5537 This need leads to two common cleanup styles. 5538 5539 The first style is try/finally. Before it exits, your code-block 5540 calls `do_cleanups' with the old cleanup chain and thus ensures that 5541 your code-block's cleanups are always performed. For instance, the 5542 following code-segment avoids a memory leak problem (even when `error' 5543 is called and a forced stack unwind occurs) by ensuring that the 5544 `xfree' will always be called: 5545 5546 struct cleanup *old = make_cleanup (null_cleanup, 0); 5547 data = xmalloc (sizeof blah); 5548 make_cleanup (xfree, data); 5549 ... blah blah ... 5550 do_cleanups (old); 5551 5552 The second style is try/except. Before it exits, your code-block 5553 calls `discard_cleanups' with the old cleanup chain and thus ensures 5554 that any created cleanups are not performed. For instance, the 5555 following code segment, ensures that the file will be closed but only 5556 if there is an error: 5557 5558 FILE *file = fopen ("afile", "r"); 5559 struct cleanup *old = make_cleanup (close_file, file); 5560 ... blah blah ... 5561 discard_cleanups (old); 5562 return file; 5563 5564 Some functions, e.g., `fputs_filtered()' or `error()', specify that 5565 they "should not be called when cleanups are not in place". This means 5566 that any actions you need to reverse in the case of an error or 5567 interruption must be on the cleanup chain before you call these 5568 functions, since they might never return to your code (they `longjmp' 5569 instead). 5570 5571 17.2 Per-architecture module data 5572 ================================= 5573 5574 The multi-arch framework includes a mechanism for adding module 5575 specific per-architecture data-pointers to the `struct gdbarch' 5576 architecture object. 5577 5578 A module registers one or more per-architecture data-pointers using: 5579 5580 -- Architecture Function: struct gdbarch_data * 5581 gdbarch_data_register_pre_init (gdbarch_data_pre_init_ftype *PRE_INIT) 5582 PRE_INIT is used to, on-demand, allocate an initial value for a 5583 per-architecture data-pointer using the architecture's obstack 5584 (passed in as a parameter). Since PRE_INIT can be called during 5585 architecture creation, it is not parameterized with the 5586 architecture. and must not call modules that use per-architecture 5587 data. 5588 5589 -- Architecture Function: struct gdbarch_data * 5590 gdbarch_data_register_post_init (gdbarch_data_post_init_ftype 5591 *POST_INIT) 5592 POST_INIT is used to obtain an initial value for a 5593 per-architecture data-pointer _after_. Since POST_INIT is always 5594 called after architecture creation, it both receives the fully 5595 initialized architecture and is free to call modules that use 5596 per-architecture data (care needs to be taken to ensure that those 5597 other modules do not try to call back to this module as that will 5598 create in cycles in the initialization call graph). 5599 5600 These functions return a `struct gdbarch_data' that is used to 5601 identify the per-architecture data-pointer added for that module. 5602 5603 The per-architecture data-pointer is accessed using the function: 5604 5605 -- Architecture Function: void * gdbarch_data (struct gdbarch 5606 *GDBARCH, struct gdbarch_data *DATA_HANDLE) 5607 Given the architecture ARCH and module data handle DATA_HANDLE 5608 (returned by `gdbarch_data_register_pre_init' or 5609 `gdbarch_data_register_post_init'), this function returns the 5610 current value of the per-architecture data-pointer. If the data 5611 pointer is `NULL', it is first initialized by calling the 5612 corresponding PRE_INIT or POST_INIT method. 5613 5614 The examples below assume the following definitions: 5615 5616 struct nozel { int total; }; 5617 static struct gdbarch_data *nozel_handle; 5618 5619 A module can extend the architecture vector, adding additional 5620 per-architecture data, using the PRE_INIT method. The module's 5621 per-architecture data is then initialized during architecture creation. 5622 5623 In the below, the module's per-architecture _nozel_ is added. An 5624 architecture can specify its nozel by calling `set_gdbarch_nozel' from 5625 `gdbarch_init'. 5626 5627 static void * 5628 nozel_pre_init (struct obstack *obstack) 5629 { 5630 struct nozel *data = OBSTACK_ZALLOC (obstack, struct nozel); 5631 return data; 5632 } 5633 5634 extern void 5635 set_gdbarch_nozel (struct gdbarch *gdbarch, int total) 5636 { 5637 struct nozel *data = gdbarch_data (gdbarch, nozel_handle); 5638 data->total = nozel; 5639 } 5640 5641 A module can on-demand create architecture dependent data structures 5642 using `post_init'. 5643 5644 In the below, the nozel's total is computed on-demand by 5645 `nozel_post_init' using information obtained from the architecture. 5646 5647 static void * 5648 nozel_post_init (struct gdbarch *gdbarch) 5649 { 5650 struct nozel *data = GDBARCH_OBSTACK_ZALLOC (gdbarch, struct nozel); 5651 nozel->total = gdbarch... (gdbarch); 5652 return data; 5653 } 5654 5655 extern int 5656 nozel_total (struct gdbarch *gdbarch) 5657 { 5658 struct nozel *data = gdbarch_data (gdbarch, nozel_handle); 5659 return data->total; 5660 } 5661 5662 17.3 Wrapping Output Lines 5663 ========================== 5664 5665 Output that goes through `printf_filtered' or `fputs_filtered' or 5666 `fputs_demangled' needs only to have calls to `wrap_here' added in 5667 places that would be good breaking points. The utility routines will 5668 take care of actually wrapping if the line width is exceeded. 5669 5670 The argument to `wrap_here' is an indentation string which is 5671 printed _only_ if the line breaks there. This argument is saved away 5672 and used later. It must remain valid until the next call to 5673 `wrap_here' or until a newline has been printed through the 5674 `*_filtered' functions. Don't pass in a local variable and then return! 5675 5676 It is usually best to call `wrap_here' after printing a comma or 5677 space. If you call it before printing a space, make sure that your 5678 indentation properly accounts for the leading space that will print if 5679 the line wraps there. 5680 5681 Any function or set of functions that produce filtered output must 5682 finish by printing a newline, to flush the wrap buffer, before switching 5683 to unfiltered (`printf') output. Symbol reading routines that print 5684 warnings are a good example. 5685 5686 17.4 Memory Management 5687 ====================== 5688 5689 GDB does not use the functions `malloc', `realloc', `calloc', `free' 5690 and `asprintf'. 5691 5692 GDB uses the functions `xmalloc', `xrealloc' and `xcalloc' when 5693 allocating memory. Unlike `malloc' et.al. these functions do not 5694 return when the memory pool is empty. Instead, they unwind the stack 5695 using cleanups. These functions return `NULL' when requested to 5696 allocate a chunk of memory of size zero. 5697 5698 _Pragmatics: By using these functions, the need to check every 5699 memory allocation is removed. These functions provide portable 5700 behavior._ 5701 5702 GDB does not use the function `free'. 5703 5704 GDB uses the function `xfree' to return memory to the memory pool. 5705 Consistent with ISO-C, this function ignores a request to free a `NULL' 5706 pointer. 5707 5708 _Pragmatics: On some systems `free' fails when passed a `NULL' 5709 pointer._ 5710 5711 GDB can use the non-portable function `alloca' for the allocation of 5712 small temporary values (such as strings). 5713 5714 _Pragmatics: This function is very non-portable. Some systems 5715 restrict the memory being allocated to no more than a few kilobytes._ 5716 5717 GDB uses the string function `xstrdup' and the print function 5718 `xstrprintf'. 5719 5720 _Pragmatics: `asprintf' and `strdup' can fail. Print functions such 5721 as `sprintf' are very prone to buffer overflow errors._ 5722 5723 17.5 Compiler Warnings 5724 ====================== 5725 5726 With few exceptions, developers should avoid the configuration option 5727 `--disable-werror' when building GDB. The exceptions are listed in the 5728 file `gdb/MAINTAINERS'. The default, when building with GCC, is 5729 `--enable-werror'. 5730 5731 This option causes GDB (when built using GCC) to be compiled with a 5732 carefully selected list of compiler warning flags. Any warnings from 5733 those flags are treated as errors. 5734 5735 The current list of warning flags includes: 5736 5737 `-Wall' 5738 Recommended GCC warnings. 5739 5740 `-Wdeclaration-after-statement' 5741 GCC 3.x (and later) and C99 allow declarations mixed with code, 5742 but GCC 2.x and C89 do not. 5743 5744 `-Wpointer-arith' 5745 5746 `-Wformat-nonliteral' 5747 Non-literal format strings, with a few exceptions, are bugs - they 5748 might contain unintended user-supplied format specifiers. Since 5749 GDB uses the `format printf' attribute on all `printf' like 5750 functions this checks not just `printf' calls but also calls to 5751 functions such as `fprintf_unfiltered'. 5752 5753 `-Wno-pointer-sign' 5754 In version 4.0, GCC began warning about pointer argument passing or 5755 assignment even when the source and destination differed only in 5756 signedness. However, most GDB code doesn't distinguish carefully 5757 between `char' and `unsigned char'. In early 2006 the GDB 5758 developers decided correcting these warnings wasn't worth the time 5759 it would take. 5760 5761 `-Wno-unused-parameter' 5762 Due to the way that GDB is implemented many functions have unused 5763 parameters. Consequently this warning is avoided. The macro 5764 `ATTRIBUTE_UNUSED' is not used as it leads to false negatives -- 5765 it is not an error to have `ATTRIBUTE_UNUSED' on a parameter that 5766 is being used. 5767 5768 `-Wno-unused' 5769 `-Wno-switch' 5770 `-Wno-char-subscripts' 5771 These are warnings which might be useful for GDB, but are 5772 currently too noisy to enable with `-Werror'. 5773 5774 5775 17.6 Internal Error Recovery 5776 ============================ 5777 5778 During its execution, GDB can encounter two types of errors. User 5779 errors and internal errors. User errors include not only a user 5780 entering an incorrect command but also problems arising from corrupt 5781 object files and system errors when interacting with the target. 5782 Internal errors include situations where GDB has detected, at run time, 5783 a corrupt or erroneous situation. 5784 5785 When reporting an internal error, GDB uses `internal_error' and 5786 `gdb_assert'. 5787 5788 GDB must not call `abort' or `assert'. 5789 5790 _Pragmatics: There is no `internal_warning' function. Either the 5791 code detected a user error, recovered from it and issued a `warning' or 5792 the code failed to correctly recover from the user error and issued an 5793 `internal_error'._ 5794 5795 17.7 Command Names 5796 ================== 5797 5798 GDB U/I commands are written `foo-bar', not `foo_bar'. 5799 5800 17.8 Clean Design and Portable Implementation 5801 ============================================= 5802 5803 In addition to getting the syntax right, there's the little question of 5804 semantics. Some things are done in certain ways in GDB because long 5805 experience has shown that the more obvious ways caused various kinds of 5806 trouble. 5807 5808 You can't assume the byte order of anything that comes from a target 5809 (including VALUEs, object files, and instructions). Such things must 5810 be byte-swapped using `SWAP_TARGET_AND_HOST' in GDB, or one of the swap 5811 routines defined in `bfd.h', such as `bfd_get_32'. 5812 5813 You can't assume that you know what interface is being used to talk 5814 to the target system. All references to the target must go through the 5815 current `target_ops' vector. 5816 5817 You can't assume that the host and target machines are the same 5818 machine (except in the "native" support modules). In particular, you 5819 can't assume that the target machine's header files will be available 5820 on the host machine. Target code must bring along its own header files 5821 - written from scratch or explicitly donated by their owner, to avoid 5822 copyright problems. 5823 5824 Insertion of new `#ifdef''s will be frowned upon. It's much better 5825 to write the code portably than to conditionalize it for various 5826 systems. 5827 5828 New `#ifdef''s which test for specific compilers or manufacturers or 5829 operating systems are unacceptable. All `#ifdef''s should test for 5830 features. The information about which configurations contain which 5831 features should be segregated into the configuration files. Experience 5832 has proven far too often that a feature unique to one particular system 5833 often creeps into other systems; and that a conditional based on some 5834 predefined macro for your current system will become worthless over 5835 time, as new versions of your system come out that behave differently 5836 with regard to this feature. 5837 5838 Adding code that handles specific architectures, operating systems, 5839 target interfaces, or hosts, is not acceptable in generic code. 5840 5841 One particularly notorious area where system dependencies tend to 5842 creep in is handling of file names. The mainline GDB code assumes 5843 Posix semantics of file names: absolute file names begin with a forward 5844 slash `/', slashes are used to separate leading directories, 5845 case-sensitive file names. These assumptions are not necessarily true 5846 on non-Posix systems such as MS-Windows. To avoid system-dependent 5847 code where you need to take apart or construct a file name, use the 5848 following portable macros: 5849 5850 `HAVE_DOS_BASED_FILE_SYSTEM' 5851 This preprocessing symbol is defined to a non-zero value on hosts 5852 whose filesystems belong to the MS-DOS/MS-Windows family. Use this 5853 symbol to write conditional code which should only be compiled for 5854 such hosts. 5855 5856 `IS_DIR_SEPARATOR (C)' 5857 Evaluates to a non-zero value if C is a directory separator 5858 character. On Unix and GNU/Linux systems, only a slash `/' is 5859 such a character, but on Windows, both `/' and `\' will pass. 5860 5861 `IS_ABSOLUTE_PATH (FILE)' 5862 Evaluates to a non-zero value if FILE is an absolute file name. 5863 For Unix and GNU/Linux hosts, a name which begins with a slash `/' 5864 is absolute. On DOS and Windows, `d:/foo' and `x:\bar' are also 5865 absolute file names. 5866 5867 `FILENAME_CMP (F1, F2)' 5868 Calls a function which compares file names F1 and F2 as 5869 appropriate for the underlying host filesystem. For Posix systems, 5870 this simply calls `strcmp'; on case-insensitive filesystems it 5871 will call `strcasecmp' instead. 5872 5873 `DIRNAME_SEPARATOR' 5874 Evaluates to a character which separates directories in 5875 `PATH'-style lists, typically held in environment variables. This 5876 character is `:' on Unix, `;' on DOS and Windows. 5877 5878 `SLASH_STRING' 5879 This evaluates to a constant string you should use to produce an 5880 absolute filename from leading directories and the file's basename. 5881 `SLASH_STRING' is `"/"' on most systems, but might be `"\\"' for 5882 some Windows-based ports. 5883 5884 In addition to using these macros, be sure to use portable library 5885 functions whenever possible. For example, to extract a directory or a 5886 basename part from a file name, use the `dirname' and `basename' 5887 library functions (available in `libiberty' for platforms which don't 5888 provide them), instead of searching for a slash with `strrchr'. 5889 5890 Another way to generalize GDB along a particular interface is with an 5891 attribute struct. For example, GDB has been generalized to handle 5892 multiple kinds of remote interfaces--not by `#ifdef's everywhere, but 5893 by defining the `target_ops' structure and having a current target (as 5894 well as a stack of targets below it, for memory references). Whenever 5895 something needs to be done that depends on which remote interface we are 5896 using, a flag in the current target_ops structure is tested (e.g., 5897 `target_has_stack'), or a function is called through a pointer in the 5898 current target_ops structure. In this way, when a new remote interface 5899 is added, only one module needs to be touched--the one that actually 5900 implements the new remote interface. Other examples of 5901 attribute-structs are BFD access to multiple kinds of object file 5902 formats, or GDB's access to multiple source languages. 5903 5904 Please avoid duplicating code. For example, in GDB 3.x all the code 5905 interfacing between `ptrace' and the rest of GDB was duplicated in 5906 `*-dep.c', and so changing something was very painful. In GDB 4.x, 5907 these have all been consolidated into `infptrace.c'. `infptrace.c' can 5908 deal with variations between systems the same way any system-independent 5909 file would (hooks, `#if defined', etc.), and machines which are 5910 radically different don't need to use `infptrace.c' at all. 5911 5912 All debugging code must be controllable using the `set debug MODULE' 5913 command. Do not use `printf' to print trace messages. Use 5914 `fprintf_unfiltered(gdb_stdlog, ...'. Do not use `#ifdef DEBUG'. 5915 5916 5917 File: gdbint.info, Node: Porting GDB, Next: Versions and Branches, Prev: Misc Guidelines, Up: Top 5918 5919 18 Porting GDB 5920 ************** 5921 5922 Most of the work in making GDB compile on a new machine is in 5923 specifying the configuration of the machine. Porting a new 5924 architecture to GDB can be broken into a number of steps. 5925 5926 * Ensure a BFD exists for executables of the target architecture in 5927 the `bfd' directory. If one does not exist, create one by 5928 modifying an existing similar one. 5929 5930 * Implement a disassembler for the target architecture in the 5931 `opcodes' directory. 5932 5933 * Define the target architecture in the `gdb' directory (*note 5934 Adding a New Target: Adding a New Target.). Add the pattern for 5935 the new target to `configure.tgt' with the names of the files that 5936 contain the code. By convention the target architecture 5937 definition for an architecture ARCH is placed in `ARCH-tdep.c'. 5938 5939 Within `ARCH-tdep.c' define the function `_initialize_ARCH_tdep' 5940 which calls `gdbarch_register' to create the new `struct gdbarch' 5941 for the architecture. 5942 5943 * If a new remote target is needed, consider adding a new remote 5944 target by defining a function `_initialize_remote_ARCH'. However 5945 if at all possible use the GDB _Remote Serial Protocol_ for this 5946 and implement the server side protocol independently with the 5947 target. 5948 5949 * If desired implement a simulator in the `sim' directory. This 5950 should create the library `libsim.a' implementing the interface in 5951 `remote-sim.h' (found in the `include' directory). 5952 5953 * Build and test. If desired, lobby the GDB steering group to have 5954 the new port included in the main distribution! 5955 5956 * Add a description of the new architecture to the main GDB user 5957 guide (*note Configuration Specific Information: 5958 (gdb)Configuration Specific Information.). 5959 5960 5961 5962 File: gdbint.info, Node: Versions and Branches, Next: Start of New Year Procedure, Prev: Porting GDB, Up: Top 5963 5964 19 Versions and Branches 5965 ************************ 5966 5967 19.1 Versions 5968 ============= 5969 5970 GDB's version is determined by the file `gdb/version.in' and takes one 5971 of the following forms: 5972 5973 MAJOR.MINOR 5974 MAJOR.MINOR.PATCHLEVEL 5975 an official release (e.g., 6.2 or 6.2.1) 5976 5977 MAJOR.MINOR.PATCHLEVEL.YYYYMMDD 5978 a snapshot taken at YYYY-MM-DD-gmt (e.g., 6.1.50.20020302, 5979 6.1.90.20020304, or 6.1.0.20020308) 5980 5981 MAJOR.MINOR.PATCHLEVEL.YYYYMMDD-cvs 5982 a CVS check out drawn on YYYY-MM-DD (e.g., 6.1.50.20020302-cvs, 5983 6.1.90.20020304-cvs, or 6.1.0.20020308-cvs) 5984 5985 MAJOR.MINOR.PATCHLEVEL.YYYYMMDD (VENDOR) 5986 a vendor specific release of GDB, that while based on 5987 MAJOR.MINOR.PATCHLEVEL.YYYYMMDD, may include additional changes 5988 5989 GDB's mainline uses the MAJOR and MINOR version numbers from the 5990 most recent release branch, with a PATCHLEVEL of 50. At the time each 5991 new release branch is created, the mainline's MAJOR and MINOR version 5992 numbers are updated. 5993 5994 GDB's release branch is similar. When the branch is cut, the 5995 PATCHLEVEL is changed from 50 to 90. As draft releases are drawn from 5996 the branch, the PATCHLEVEL is incremented. Once the first release 5997 (MAJOR.MINOR) has been made, the PATCHLEVEL is set to 0 and updates 5998 have an incremented PATCHLEVEL. 5999 6000 For snapshots, and CVS check outs, it is also possible to identify 6001 the CVS origin: 6002 6003 MAJOR.MINOR.50.YYYYMMDD 6004 drawn from the HEAD of mainline CVS (e.g., 6.1.50.20020302) 6005 6006 MAJOR.MINOR.90.YYYYMMDD 6007 MAJOR.MINOR.91.YYYYMMDD ... 6008 drawn from a release branch prior to the release (e.g., 6009 6.1.90.20020304) 6010 6011 MAJOR.MINOR.0.YYYYMMDD 6012 MAJOR.MINOR.1.YYYYMMDD ... 6013 drawn from a release branch after the release (e.g., 6014 6.2.0.20020308) 6015 6016 If the previous GDB version is 6.1 and the current version is 6.2, 6017 then, substituting 6 for MAJOR and 1 or 2 for MINOR, here's an 6018 illustration of a typical sequence: 6019 6020 <HEAD> 6021 | 6022 6.1.50.20020302-cvs 6023 | 6024 +--------------------------. 6025 | <gdb_6_2-branch> 6026 | | 6027 6.2.50.20020303-cvs 6.1.90 (draft #1) 6028 | | 6029 6.2.50.20020304-cvs 6.1.90.20020304-cvs 6030 | | 6031 6.2.50.20020305-cvs 6.1.91 (draft #2) 6032 | | 6033 6.2.50.20020306-cvs 6.1.91.20020306-cvs 6034 | | 6035 6.2.50.20020307-cvs 6.2 (release) 6036 | | 6037 6.2.50.20020308-cvs 6.2.0.20020308-cvs 6038 | | 6039 6.2.50.20020309-cvs 6.2.1 (update) 6040 | | 6041 6.2.50.20020310-cvs <branch closed> 6042 | 6043 6.2.50.20020311-cvs 6044 | 6045 +--------------------------. 6046 | <gdb_6_3-branch> 6047 | | 6048 6.3.50.20020312-cvs 6.2.90 (draft #1) 6049 | | 6050 6051 19.2 Release Branches 6052 ===================== 6053 6054 GDB draws a release series (6.2, 6.2.1, ...) from a single release 6055 branch, and identifies that branch using the CVS branch tags: 6056 6057 gdb_MAJOR_MINOR-YYYYMMDD-branchpoint 6058 gdb_MAJOR_MINOR-branch 6059 gdb_MAJOR_MINOR-YYYYMMDD-release 6060 6061 _Pragmatics: To help identify the date at which a branch or release 6062 is made, both the branchpoint and release tags include the date that 6063 they are cut (YYYYMMDD) in the tag. The branch tag, denoting the head 6064 of the branch, does not need this._ 6065 6066 19.3 Vendor Branches 6067 ==================== 6068 6069 To avoid version conflicts, vendors are expected to modify the file 6070 `gdb/version.in' to include a vendor unique alphabetic identifier (an 6071 official GDB release never uses alphabetic characters in its version 6072 identifier). E.g., `6.2widgit2', or `6.2 (Widgit Inc Patch 2)'. 6073 6074 19.4 Experimental Branches 6075 ========================== 6076 6077 19.4.1 Guidelines 6078 ----------------- 6079 6080 GDB permits the creation of branches, cut from the CVS repository, for 6081 experimental development. Branches make it possible for developers to 6082 share preliminary work, and maintainers to examine significant new 6083 developments. 6084 6085 The following are a set of guidelines for creating such branches: 6086 6087 _a branch has an owner_ 6088 The owner can set further policy for a branch, but may not change 6089 the ground rules. In particular, they can set a policy for 6090 commits (be it adding more reviewers or deciding who can commit). 6091 6092 _all commits are posted_ 6093 All changes committed to a branch shall also be posted to the GDB 6094 patches mailing list <gdb-patches (a] sourceware.org>. While 6095 commentary on such changes are encouraged, people should remember 6096 that the changes only apply to a branch. 6097 6098 _all commits are covered by an assignment_ 6099 This ensures that all changes belong to the Free Software 6100 Foundation, and avoids the possibility that the branch may become 6101 contaminated. 6102 6103 _a branch is focused_ 6104 A focused branch has a single objective or goal, and does not 6105 contain unnecessary or irrelevant changes. Cleanups, where 6106 identified, being be pushed into the mainline as soon as possible. 6107 6108 _a branch tracks mainline_ 6109 This keeps the level of divergence under control. It also keeps 6110 the pressure on developers to push cleanups and other stuff into 6111 the mainline. 6112 6113 _a branch shall contain the entire GDB module_ 6114 The GDB module `gdb' should be specified when creating a branch 6115 (branches of individual files should be avoided). *Note Tags::. 6116 6117 _a branch shall be branded using `version.in'_ 6118 The file `gdb/version.in' shall be modified so that it identifies 6119 the branch OWNER and branch NAME, e.g., 6120 `6.2.50.20030303_owner_name' or `6.2 (Owner Name)'. 6121 6122 6123 19.4.2 Tags 6124 ----------- 6125 6126 To simplify the identification of GDB branches, the following branch 6127 tagging convention is strongly recommended: 6128 6129 `OWNER_NAME-YYYYMMDD-branchpoint' 6130 `OWNER_NAME-YYYYMMDD-branch' 6131 The branch point and corresponding branch tag. YYYYMMDD is the 6132 date that the branch was created. A branch is created using the 6133 sequence: 6134 cvs rtag OWNER_NAME-YYYYMMDD-branchpoint gdb 6135 cvs rtag -b -r OWNER_NAME-YYYYMMDD-branchpoint \ 6136 OWNER_NAME-YYYYMMDD-branch gdb 6137 6138 `OWNER_NAME-YYYYMMDD-mergepoint' 6139 The tagged point, on the mainline, that was used when merging the 6140 branch on YYYYMMDD. To merge in all changes since the branch was 6141 cut, use a command sequence like: 6142 cvs rtag OWNER_NAME-YYYYMMDD-mergepoint gdb 6143 cvs update \ 6144 -jOWNER_NAME-YYYYMMDD-branchpoint 6145 -jOWNER_NAME-YYYYMMDD-mergepoint 6146 Similar sequences can be used to just merge in changes since the 6147 last merge. 6148 6149 6150 For further information on CVS, see Concurrent Versions System 6151 (http://www.gnu.org/software/cvs/). 6152 6153 6154 File: gdbint.info, Node: Start of New Year Procedure, Next: Releasing GDB, Prev: Versions and Branches, Up: Top 6155 6156 20 Start of New Year Procedure 6157 ****************************** 6158 6159 At the start of each new year, the following actions should be 6160 performed: 6161 6162 * Rotate the ChangeLog file 6163 6164 The current `ChangeLog' file should be renamed into 6165 `ChangeLog-YYYY' where YYYY is the year that has just passed. A 6166 new `ChangeLog' file should be created, and its contents should 6167 contain a reference to the previous ChangeLog. The following 6168 should also be preserved at the end of the new ChangeLog, in order 6169 to provide the appropriate settings when editing this file with 6170 Emacs: 6171 Local Variables: 6172 mode: change-log 6173 left-margin: 8 6174 fill-column: 74 6175 version-control: never 6176 coding: utf-8 6177 End: 6178 6179 * Add an entry for the newly created ChangeLog file 6180 (`ChangeLog-YYYY') in `gdb/config/djgpp/fnchange.lst'. 6181 6182 * Update the copyright year in the startup message 6183 6184 Update the copyright year in: 6185 * file `top.c', function `print_gdb_version' 6186 6187 * file `gdbserver/server.c', function `gdbserver_version' 6188 6189 * file `gdbserver/gdbreplay.c', function `gdbreplay_version' 6190 6191 * Run the `copyright.sh' script to add the new year in the copyright 6192 notices of most source files. This script requires Emacs 22 or 6193 later to be installed. 6194 6195 * The new year also needs to be added manually in all other files 6196 that are not already taken care of by the `copyright.sh' script: 6197 * `*.s' 6198 6199 * `*.f' 6200 6201 * `*.f90' 6202 6203 * `*.igen' 6204 6205 * `*.ac' 6206 6207 * `*.texi' 6208 6209 * `*.texinfo' 6210 6211 * `*.tex' 6212 6213 * `*.defs' 6214 6215 * `*.1' 6216 6217 6218 6219 File: gdbint.info, Node: Releasing GDB, Next: Testsuite, Prev: Start of New Year Procedure, Up: Top 6220 6221 21 Releasing GDB 6222 **************** 6223 6224 21.1 Branch Commit Policy 6225 ========================= 6226 6227 The branch commit policy is pretty slack. GDB releases 5.0, 5.1 and 6228 5.2 all used the below: 6229 6230 * The `gdb/MAINTAINERS' file still holds. 6231 6232 * Don't fix something on the branch unless/until it is also fixed in 6233 the trunk. If this isn't possible, mentioning it in the 6234 `gdb/PROBLEMS' file is better than committing a hack. 6235 6236 * When considering a patch for the branch, suggested criteria 6237 include: Does it fix a build? Does it fix the sequence `break 6238 main; run' when debugging a static binary? 6239 6240 * The further a change is from the core of GDB, the less likely the 6241 change will worry anyone (e.g., target specific code). 6242 6243 * Only post a proposal to change the core of GDB after you've sent 6244 individual bribes to all the people listed in the `MAINTAINERS' 6245 file ;-) 6246 6247 _Pragmatics: Provided updates are restricted to non-core 6248 functionality there is little chance that a broken change will be fatal. 6249 This means that changes such as adding a new architectures or (within 6250 reason) support for a new host are considered acceptable._ 6251 6252 21.2 Obsoleting code 6253 ==================== 6254 6255 Before anything else, poke the other developers (and around the source 6256 code) to see if there is anything that can be removed from GDB (an old 6257 target, an unused file). 6258 6259 Obsolete code is identified by adding an `OBSOLETE' prefix to every 6260 line. Doing this means that it is easy to identify something that has 6261 been obsoleted when greping through the sources. 6262 6263 The process is done in stages -- this is mainly to ensure that the 6264 wider GDB community has a reasonable opportunity to respond. Remember, 6265 everything on the Internet takes a week. 6266 6267 1. Post the proposal on the GDB mailing list <gdb (a] sourceware.org> 6268 Creating a bug report to track the task's state, is also highly 6269 recommended. 6270 6271 2. Wait a week or so. 6272 6273 3. Post the proposal on the GDB Announcement mailing list 6274 <gdb-announce (a] sourceware.org>. 6275 6276 4. Wait a week or so. 6277 6278 5. Go through and edit all relevant files and lines so that they are 6279 prefixed with the word `OBSOLETE'. 6280 6281 6. Wait until the next GDB version, containing this obsolete code, 6282 has been released. 6283 6284 7. Remove the obsolete code. 6285 6286 _Maintainer note: While removing old code is regrettable it is 6287 hopefully better for GDB's long term development. Firstly it helps the 6288 developers by removing code that is either no longer relevant or simply 6289 wrong. Secondly since it removes any history associated with the file 6290 (effectively clearing the slate) the developer has a much freer hand 6291 when it comes to fixing broken files._ 6292 6293 21.3 Before the Branch 6294 ====================== 6295 6296 The most important objective at this stage is to find and fix simple 6297 changes that become a pain to track once the branch is created. For 6298 instance, configuration problems that stop GDB from even building. If 6299 you can't get the problem fixed, document it in the `gdb/PROBLEMS' file. 6300 6301 Prompt for `gdb/NEWS' 6302 --------------------- 6303 6304 People always forget. Send a post reminding them but also if you know 6305 something interesting happened add it yourself. The `schedule' script 6306 will mention this in its e-mail. 6307 6308 Review `gdb/README' 6309 ------------------- 6310 6311 Grab one of the nightly snapshots and then walk through the 6312 `gdb/README' looking for anything that can be improved. The `schedule' 6313 script will mention this in its e-mail. 6314 6315 Refresh any imported files. 6316 --------------------------- 6317 6318 A number of files are taken from external repositories. They include: 6319 6320 * `texinfo/texinfo.tex' 6321 6322 * `config.guess' et. al. (see the top-level `MAINTAINERS' file) 6323 6324 * `etc/standards.texi', `etc/make-stds.texi' 6325 6326 Check the ARI 6327 ------------- 6328 6329 A.R.I. is an `awk' script (Awk Regression Index ;-) that checks for a 6330 number of errors and coding conventions. The checks include things 6331 like using `malloc' instead of `xmalloc' and file naming problems. 6332 There shouldn't be any regressions. 6333 6334 21.3.1 Review the bug data base 6335 ------------------------------- 6336 6337 Close anything obviously fixed. 6338 6339 21.3.2 Check all cross targets build 6340 ------------------------------------ 6341 6342 The targets are listed in `gdb/MAINTAINERS'. 6343 6344 21.4 Cut the Branch 6345 =================== 6346 6347 Create the branch 6348 ----------------- 6349 6350 $ u=5.1 6351 $ v=5.2 6352 $ V=`echo $v | sed 's/\./_/g'` 6353 $ D=`date -u +%Y-%m-%d` 6354 $ echo $u $V $D 6355 5.1 5_2 2002-03-03 6356 $ echo cvs -f -d :ext:sourceware.org:/cvs/src rtag \ 6357 -D $D-gmt gdb_$V-$D-branchpoint insight 6358 cvs -f -d :ext:sourceware.org:/cvs/src rtag 6359 -D 2002-03-03-gmt gdb_5_2-2002-03-03-branchpoint insight 6360 $ ^echo ^^ 6361 ... 6362 $ echo cvs -f -d :ext:sourceware.org:/cvs/src rtag \ 6363 -b -r gdb_$V-$D-branchpoint gdb_$V-branch insight 6364 cvs -f -d :ext:sourceware.org:/cvs/src rtag \ 6365 -b -r gdb_5_2-2002-03-03-branchpoint gdb_5_2-branch insight 6366 $ ^echo ^^ 6367 ... 6368 $ 6369 6370 * By using `-D YYYY-MM-DD-gmt', the branch is forced to an exact 6371 date/time. 6372 6373 * The trunk is first tagged so that the branch point can easily be 6374 found. 6375 6376 * Insight, which includes GDB, is tagged at the same time. 6377 6378 * `version.in' gets bumped to avoid version number conflicts. 6379 6380 * The reading of `.cvsrc' is disabled using `-f'. 6381 6382 Update `version.in' 6383 ------------------- 6384 6385 $ u=5.1 6386 $ v=5.2 6387 $ V=`echo $v | sed 's/\./_/g'` 6388 $ echo $u $v$V 6389 5.1 5_2 6390 $ cd /tmp 6391 $ echo cvs -f -d :ext:sourceware.org:/cvs/src co \ 6392 -r gdb_$V-branch src/gdb/version.in 6393 cvs -f -d :ext:sourceware.org:/cvs/src co 6394 -r gdb_5_2-branch src/gdb/version.in 6395 $ ^echo ^^ 6396 U src/gdb/version.in 6397 $ cd src/gdb 6398 $ echo $u.90-0000-00-00-cvs > version.in 6399 $ cat version.in 6400 5.1.90-0000-00-00-cvs 6401 $ cvs -f commit version.in 6402 6403 * `0000-00-00' is used as a date to pump prime the version.in update 6404 mechanism. 6405 6406 * `.90' and the previous branch version are used as fairly arbitrary 6407 initial branch version number. 6408 6409 Update the web and news pages 6410 ----------------------------- 6411 6412 Something? 6413 6414 Tweak cron to track the new branch 6415 ---------------------------------- 6416 6417 The file `gdbadmin/cron/crontab' contains gdbadmin's cron table. This 6418 file needs to be updated so that: 6419 6420 * A daily timestamp is added to the file `version.in'. 6421 6422 * The new branch is included in the snapshot process. 6423 6424 See the file `gdbadmin/cron/README' for how to install the updated cron 6425 table. 6426 6427 The file `gdbadmin/ss/README' should also be reviewed to reflect any 6428 changes. That file is copied to both the branch/ and current/ snapshot 6429 directories. 6430 6431 Update the NEWS and README files 6432 -------------------------------- 6433 6434 The `NEWS' file needs to be updated so that on the branch it refers to 6435 _changes in the current release_ while on the trunk it also refers to 6436 _changes since the current release_. 6437 6438 The `README' file needs to be updated so that it refers to the 6439 current release. 6440 6441 Post the branch info 6442 -------------------- 6443 6444 Send an announcement to the mailing lists: 6445 6446 * GDB Announcement mailing list <gdb-announce (a] sourceware.org> 6447 6448 * GDB Discussion mailing list <gdb (a] sourceware.org> and GDB Testers 6449 mailing list <gdb-testers (a] sourceware.org> 6450 6451 _Pragmatics: The branch creation is sent to the announce list to 6452 ensure that people people not subscribed to the higher volume discussion 6453 list are alerted._ 6454 6455 The announcement should include: 6456 6457 * The branch tag. 6458 6459 * How to check out the branch using CVS. 6460 6461 * The date/number of weeks until the release. 6462 6463 * The branch commit policy still holds. 6464 6465 21.5 Stabilize the branch 6466 ========================= 6467 6468 Something goes here. 6469 6470 21.6 Create a Release 6471 ===================== 6472 6473 The process of creating and then making available a release is broken 6474 down into a number of stages. The first part addresses the technical 6475 process of creating a releasable tar ball. The later stages address the 6476 process of releasing that tar ball. 6477 6478 When making a release candidate just the first section is needed. 6479 6480 21.6.1 Create a release candidate 6481 --------------------------------- 6482 6483 The objective at this stage is to create a set of tar balls that can be 6484 made available as a formal release (or as a less formal release 6485 candidate). 6486 6487 Freeze the branch 6488 ................. 6489 6490 Send out an e-mail notifying everyone that the branch is frozen to 6491 <gdb-patches (a] sourceware.org>. 6492 6493 Establish a few defaults. 6494 ......................... 6495 6496 $ b=gdb_5_2-branch 6497 $ v=5.2 6498 $ t=/sourceware/snapshot-tmp/gdbadmin-tmp 6499 $ echo $t/$b/$v 6500 /sourceware/snapshot-tmp/gdbadmin-tmp/gdb_5_2-branch/5.2 6501 $ mkdir -p $t/$b/$v 6502 $ cd $t/$b/$v 6503 $ pwd 6504 /sourceware/snapshot-tmp/gdbadmin-tmp/gdb_5_2-branch/5.2 6505 $ which autoconf 6506 /home/gdbadmin/bin/autoconf 6507 $ 6508 6509 Notes: 6510 6511 * Check the `autoconf' version carefully. You want to be using the 6512 version documented in the toplevel `README-maintainer-mode' file. 6513 It is very unlikely that the version of `autoconf' installed in 6514 system directories (e.g., `/usr/bin/autoconf') is correct. 6515 6516 Check out the relevant modules: 6517 ............................... 6518 6519 $ for m in gdb insight 6520 do 6521 ( mkdir -p $m && cd $m && cvs -q -f -d /cvs/src co -P -r $b $m ) 6522 done 6523 $ 6524 6525 Note: 6526 6527 * The reading of `.cvsrc' is disabled (`-f') so that there isn't any 6528 confusion between what is written here and what your local `cvs' 6529 really does. 6530 6531 Update relevant files. 6532 ...................... 6533 6534 `gdb/NEWS' 6535 Major releases get their comments added as part of the mainline. 6536 Minor releases should probably mention any significant bugs that 6537 were fixed. 6538 6539 Don't forget to include the `ChangeLog' entry. 6540 6541 $ emacs gdb/src/gdb/NEWS 6542 ... 6543 c-x 4 a 6544 ... 6545 c-x c-s c-x c-c 6546 $ cp gdb/src/gdb/NEWS insight/src/gdb/NEWS 6547 $ cp gdb/src/gdb/ChangeLog insight/src/gdb/ChangeLog 6548 6549 `gdb/README' 6550 You'll need to update: 6551 6552 * The version. 6553 6554 * The update date. 6555 6556 * Who did it. 6557 6558 $ emacs gdb/src/gdb/README 6559 ... 6560 c-x 4 a 6561 ... 6562 c-x c-s c-x c-c 6563 $ cp gdb/src/gdb/README insight/src/gdb/README 6564 $ cp gdb/src/gdb/ChangeLog insight/src/gdb/ChangeLog 6565 6566 _Maintainer note: Hopefully the `README' file was reviewed before 6567 the initial branch was cut so just a simple substitute is needed 6568 to get it updated._ 6569 6570 _Maintainer note: Other projects generate `README' and `INSTALL' 6571 from the core documentation. This might be worth pursuing._ 6572 6573 `gdb/version.in' 6574 $ echo $v > gdb/src/gdb/version.in 6575 $ cat gdb/src/gdb/version.in 6576 5.2 6577 $ emacs gdb/src/gdb/version.in 6578 ... 6579 c-x 4 a 6580 ... Bump to version ... 6581 c-x c-s c-x c-c 6582 $ cp gdb/src/gdb/version.in insight/src/gdb/version.in 6583 $ cp gdb/src/gdb/ChangeLog insight/src/gdb/ChangeLog 6584 6585 6586 Do the dirty work 6587 ................. 6588 6589 This is identical to the process used to create the daily snapshot. 6590 6591 $ for m in gdb insight 6592 do 6593 ( cd $m/src && gmake -f src-release $m.tar ) 6594 done 6595 6596 If the top level source directory does not have `src-release' (GDB 6597 version 5.3.1 or earlier), try these commands instead: 6598 6599 $ for m in gdb insight 6600 do 6601 ( cd $m/src && gmake -f Makefile.in $m.tar ) 6602 done 6603 6604 Check the source files 6605 ...................... 6606 6607 You're looking for files that have mysteriously disappeared. 6608 `distclean' has the habit of deleting files it shouldn't. Watch out 6609 for the `version.in' update `cronjob'. 6610 6611 $ ( cd gdb/src && cvs -f -q -n update ) 6612 M djunpack.bat 6613 ? gdb-5.1.91.tar 6614 ? proto-toplev 6615 ... lots of generated files ... 6616 M gdb/ChangeLog 6617 M gdb/NEWS 6618 M gdb/README 6619 M gdb/version.in 6620 ... lots of generated files ... 6621 $ 6622 6623 _Don't worry about the `gdb.info-??' or `gdb/p-exp.tab.c'. They were 6624 generated (and yes `gdb.info-1' was also generated only something 6625 strange with CVS means that they didn't get suppressed). Fixing it 6626 would be nice though._ 6627 6628 Create compressed versions of the release 6629 ......................................... 6630 6631 $ cp */src/*.tar . 6632 $ cp */src/*.bz2 . 6633 $ ls -F 6634 gdb/ gdb-5.2.tar insight/ insight-5.2.tar 6635 $ for m in gdb insight 6636 do 6637 bzip2 -v -9 -c $m-$v.tar > $m-$v.tar.bz2 6638 gzip -v -9 -c $m-$v.tar > $m-$v.tar.gz 6639 done 6640 $ 6641 6642 Note: 6643 6644 * A pipe such as `bunzip2 < xxx.bz2 | gzip -9 > xxx.gz' is not since, 6645 in that mode, `gzip' does not know the name of the file and, hence, 6646 can not include it in the compressed file. This is also why the 6647 release process runs `tar' and `bzip2' as separate passes. 6648 6649 21.6.2 Sanity check the tar ball 6650 -------------------------------- 6651 6652 Pick a popular machine (Solaris/PPC?) and try the build on that. 6653 6654 $ bunzip2 < gdb-5.2.tar.bz2 | tar xpf - 6655 $ cd gdb-5.2 6656 $ ./configure 6657 $ make 6658 ... 6659 $ ./gdb/gdb ./gdb/gdb 6660 GNU gdb 5.2 6661 ... 6662 (gdb) b main 6663 Breakpoint 1 at 0x80732bc: file main.c, line 734. 6664 (gdb) run 6665 Starting program: /tmp/gdb-5.2/gdb/gdb 6666 6667 Breakpoint 1, main (argc=1, argv=0xbffff8b4) at main.c:734 6668 734 catch_errors (captured_main, &args, "", RETURN_MASK_ALL); 6669 (gdb) print args 6670 $1 = {argc = 136426532, argv = 0x821b7f0} 6671 (gdb) 6672 6673 21.6.3 Make a release candidate available 6674 ----------------------------------------- 6675 6676 If this is a release candidate then the only remaining steps are: 6677 6678 1. Commit `version.in' and `ChangeLog' 6679 6680 2. Tweak `version.in' (and `ChangeLog' to read L.M.N-0000-00-00-cvs 6681 so that the version update process can restart. 6682 6683 3. Make the release candidate available in 6684 `ftp://sourceware.org/pub/gdb/snapshots/branch' 6685 6686 4. Notify the relevant mailing lists ( <gdb (a] sourceware.org> and 6687 <gdb-testers (a] sourceware.org> that the candidate is available. 6688 6689 21.6.4 Make a formal release available 6690 -------------------------------------- 6691 6692 (And you thought all that was required was to post an e-mail.) 6693 6694 Install on sware 6695 ................ 6696 6697 Copy the new files to both the release and the old release directory: 6698 6699 $ cp *.bz2 *.gz ~ftp/pub/gdb/old-releases/ 6700 $ cp *.bz2 *.gz ~ftp/pub/gdb/releases 6701 6702 Clean up the releases directory so that only the most recent releases 6703 are available (e.g. keep 5.2 and 5.2.1 but remove 5.1): 6704 6705 $ cd ~ftp/pub/gdb/releases 6706 $ rm ... 6707 6708 Update the file `README' and `.message' in the releases directory: 6709 6710 $ vi README 6711 ... 6712 $ rm -f .message 6713 $ ln README .message 6714 6715 Update the web pages. 6716 ..................... 6717 6718 `htdocs/download/ANNOUNCEMENT' 6719 This file, which is posted as the official announcement, includes: 6720 * General announcement. 6721 6722 * News. If making an M.N.1 release, retain the news from 6723 earlier M.N release. 6724 6725 * Errata. 6726 6727 `htdocs/index.html' 6728 `htdocs/news/index.html' 6729 `htdocs/download/index.html' 6730 These files include: 6731 * Announcement of the most recent release. 6732 6733 * News entry (remember to update both the top level and the 6734 news directory). 6735 These pages also need to be regenerate using `index.sh'. 6736 6737 `download/onlinedocs/' 6738 You need to find the magic command that is used to generate the 6739 online docs from the `.tar.bz2'. The best way is to look in the 6740 output from one of the nightly `cron' jobs and then just edit 6741 accordingly. Something like: 6742 6743 $ ~/ss/update-web-docs \ 6744 ~ftp/pub/gdb/releases/gdb-5.2.tar.bz2 \ 6745 $PWD/www \ 6746 /www/sourceware/htdocs/gdb/download/onlinedocs \ 6747 gdb 6748 6749 `download/ari/' 6750 Just like the online documentation. Something like: 6751 6752 $ /bin/sh ~/ss/update-web-ari \ 6753 ~ftp/pub/gdb/releases/gdb-5.2.tar.bz2 \ 6754 $PWD/www \ 6755 /www/sourceware/htdocs/gdb/download/ari \ 6756 gdb 6757 6758 6759 Shadow the pages onto gnu 6760 ......................... 6761 6762 Something goes here. 6763 6764 Install the GDB tar ball on GNU 6765 ............................... 6766 6767 At the time of writing, the GNU machine was `gnudist.gnu.org' in 6768 `~ftp/gnu/gdb'. 6769 6770 Make the `ANNOUNCEMENT' 6771 ....................... 6772 6773 Post the `ANNOUNCEMENT' file you created above to: 6774 6775 * GDB Announcement mailing list <gdb-announce (a] sourceware.org> 6776 6777 * General GNU Announcement list <info-gnu (a] gnu.org> (but delay it a 6778 day or so to let things get out) 6779 6780 * GDB Bug Report mailing list <bug-gdb (a] gnu.org> 6781 6782 21.6.5 Cleanup 6783 -------------- 6784 6785 The release is out but you're still not finished. 6786 6787 Commit outstanding changes 6788 .......................... 6789 6790 In particular you'll need to commit any changes to: 6791 6792 * `gdb/ChangeLog' 6793 6794 * `gdb/version.in' 6795 6796 * `gdb/NEWS' 6797 6798 * `gdb/README' 6799 6800 Tag the release 6801 ............... 6802 6803 Something like: 6804 6805 $ d=`date -u +%Y-%m-%d` 6806 $ echo $d 6807 2002-01-24 6808 $ ( cd insight/src/gdb && cvs -f -q update ) 6809 $ ( cd insight/src && cvs -f -q tag gdb_5_2-$d-release ) 6810 6811 Insight is used since that contains more of the release than GDB. 6812 6813 Mention the release on the trunk 6814 ................................ 6815 6816 Just put something in the `ChangeLog' so that the trunk also indicates 6817 when the release was made. 6818 6819 Restart `gdb/version.in' 6820 ........................ 6821 6822 If `gdb/version.in' does not contain an ISO date such as `2002-01-24' 6823 then the daily `cronjob' won't update it. Having committed all the 6824 release changes it can be set to `5.2.0_0000-00-00-cvs' which will 6825 restart things (yes the `_' is important - it affects the snapshot 6826 process). 6827 6828 Don't forget the `ChangeLog'. 6829 6830 Merge into trunk 6831 ................ 6832 6833 The files committed to the branch may also need changes merged into the 6834 trunk. 6835 6836 Revise the release schedule 6837 ........................... 6838 6839 Post a revised release schedule to GDB Discussion List 6840 <gdb (a] sourceware.org> with an updated announcement. The schedule can be 6841 generated by running: 6842 6843 $ ~/ss/schedule `date +%s` schedule 6844 6845 The first parameter is approximate date/time in seconds (from the epoch) 6846 of the most recent release. 6847 6848 Also update the schedule `cronjob'. 6849 6850 21.7 Post release 6851 ================= 6852 6853 Remove any `OBSOLETE' code. 6854 6855 6856 File: gdbint.info, Node: Testsuite, Next: Hints, Prev: Releasing GDB, Up: Top 6857 6858 22 Testsuite 6859 ************ 6860 6861 The testsuite is an important component of the GDB package. While it 6862 is always worthwhile to encourage user testing, in practice this is 6863 rarely sufficient; users typically use only a small subset of the 6864 available commands, and it has proven all too common for a change to 6865 cause a significant regression that went unnoticed for some time. 6866 6867 The GDB testsuite uses the DejaGNU testing framework. The tests 6868 themselves are calls to various `Tcl' procs; the framework runs all the 6869 procs and summarizes the passes and fails. 6870 6871 22.1 Using the Testsuite 6872 ======================== 6873 6874 To run the testsuite, simply go to the GDB object directory (or to the 6875 testsuite's objdir) and type `make check'. This just sets up some 6876 environment variables and invokes DejaGNU's `runtest' script. While 6877 the testsuite is running, you'll get mentions of which test file is in 6878 use, and a mention of any unexpected passes or fails. When the 6879 testsuite is finished, you'll get a summary that looks like this: 6880 6881 === gdb Summary === 6882 6883 # of expected passes 6016 6884 # of unexpected failures 58 6885 # of unexpected successes 5 6886 # of expected failures 183 6887 # of unresolved testcases 3 6888 # of untested testcases 5 6889 6890 To run a specific test script, type: 6891 make check RUNTESTFLAGS='TESTS' 6892 where TESTS is a list of test script file names, separated by spaces. 6893 6894 If you use GNU make, you can use its `-j' option to run the 6895 testsuite in parallel. This can greatly reduce the amount of time it 6896 takes for the testsuite to run. In this case, if you set 6897 `RUNTESTFLAGS' then, by default, the tests will be run serially even 6898 under `-j'. You can override this and force a parallel run by setting 6899 the `make' variable `FORCE_PARALLEL' to any non-empty value. Note that 6900 the parallel `make check' assumes that you want to run the entire 6901 testsuite, so it is not compatible with some dejagnu options, like 6902 `--directory'. 6903 6904 The ideal test run consists of expected passes only; however, reality 6905 conspires to keep us from this ideal. Unexpected failures indicate 6906 real problems, whether in GDB or in the testsuite. Expected failures 6907 are still failures, but ones which have been decided are too hard to 6908 deal with at the time; for instance, a test case might work everywhere 6909 except on AIX, and there is no prospect of the AIX case being fixed in 6910 the near future. Expected failures should not be added lightly, since 6911 you may be masking serious bugs in GDB. Unexpected successes are 6912 expected fails that are passing for some reason, while unresolved and 6913 untested cases often indicate some minor catastrophe, such as the 6914 compiler being unable to deal with a test program. 6915 6916 When making any significant change to GDB, you should run the 6917 testsuite before and after the change, to confirm that there are no 6918 regressions. Note that truly complete testing would require that you 6919 run the testsuite with all supported configurations and a variety of 6920 compilers; however this is more than really necessary. In many cases 6921 testing with a single configuration is sufficient. Other useful 6922 options are to test one big-endian (Sparc) and one little-endian (x86) 6923 host, a cross config with a builtin simulator (powerpc-eabi, mips-elf), 6924 or a 64-bit host (Alpha). 6925 6926 If you add new functionality to GDB, please consider adding tests 6927 for it as well; this way future GDB hackers can detect and fix their 6928 changes that break the functionality you added. Similarly, if you fix 6929 a bug that was not previously reported as a test failure, please add a 6930 test case for it. Some cases are extremely difficult to test, such as 6931 code that handles host OS failures or bugs in particular versions of 6932 compilers, and it's OK not to try to write tests for all of those. 6933 6934 DejaGNU supports separate build, host, and target machines. However, 6935 some GDB test scripts do not work if the build machine and the host 6936 machine are not the same. In such an environment, these scripts will 6937 give a result of "UNRESOLVED", like this: 6938 6939 UNRESOLVED: gdb.base/example.exp: This test script does not work on a remote host. 6940 6941 22.2 Testsuite Parameters 6942 ========================= 6943 6944 Several variables exist to modify the behavior of the testsuite. 6945 6946 * `TRANSCRIPT' 6947 6948 Sometimes it is convenient to get a transcript of the commands 6949 which the testsuite sends to GDB. For example, if GDB crashes 6950 during testing, a transcript can be used to more easily 6951 reconstruct the failure when running GDB under GDB. 6952 6953 You can instruct the GDB testsuite to write transcripts by setting 6954 the DejaGNU variable `TRANSCRIPT' (to any value) before invoking 6955 `runtest' or `make check'. The transcripts will be written into 6956 DejaGNU's output directory. One transcript will be made for each 6957 invocation of GDB; they will be named `transcript.N', where N is 6958 an integer. The first line of the transcript file will show how 6959 GDB was invoked; each subsequent line is a command sent as input 6960 to GDB. 6961 6962 make check RUNTESTFLAGS=TRANSCRIPT=y 6963 6964 Note that the transcript is not always complete. In particular, 6965 tests of completion can yield partial command lines. 6966 6967 * `GDB' 6968 6969 Sometimes one wishes to test a different GDB than the one in the 6970 build directory. For example, one may wish to run the testsuite on 6971 `/usr/bin/gdb'. 6972 6973 make check RUNTESTFLAGS=GDB=/usr/bin/gdb 6974 6975 * `GDBSERVER' 6976 6977 When testing a different GDB, it is often useful to also test a 6978 different gdbserver. 6979 6980 make check RUNTESTFLAGS="GDB=/usr/bin/gdb GDBSERVER=/usr/bin/gdbserver" 6981 6982 * `INTERNAL_GDBFLAGS' 6983 6984 When running the testsuite normally one doesn't want whatever is in 6985 `~/.gdbinit' to interfere with the tests, therefore the test 6986 harness passes `-nx' to GDB. One also doesn't want any windowed 6987 version of GDB, e.g., `gdbtui', to run. This is achieved via 6988 `INTERNAL_GDBFLAGS'. 6989 6990 set INTERNAL_GDBFLAGS "-nw -nx" 6991 6992 This is all well and good, except when testing an installed GDB 6993 that has been configured with `--with-system-gdbinit'. Here one 6994 does not want `~/.gdbinit' loaded but one may want the system 6995 `.gdbinit' file loaded. This can be achieved by pointing `$HOME' 6996 at a directory without a `.gdbinit' and by overriding 6997 `INTERNAL_GDBFLAGS' and removing `-nx'. 6998 6999 cd testsuite 7000 HOME=`pwd` runtest \ 7001 GDB=/usr/bin/gdb \ 7002 GDBSERVER=/usr/bin/gdbserver \ 7003 INTERNAL_GDBFLAGS=-nw 7004 7005 7006 There are two ways to run the testsuite and pass additional 7007 parameters to DejaGnu. The first is with `make check' and specifying 7008 the makefile variable `RUNTESTFLAGS'. 7009 7010 make check RUNTESTFLAGS=TRANSCRIPT=y 7011 7012 The second is to cd to the `testsuite' directory and invoke the 7013 DejaGnu `runtest' command directly. 7014 7015 cd testsuite 7016 make site.exp 7017 runtest TRANSCRIPT=y 7018 7019 22.3 Testsuite Configuration 7020 ============================ 7021 7022 It is possible to adjust the behavior of the testsuite by defining the 7023 global variables listed below, either in a `site.exp' file, or in a 7024 board file. 7025 7026 * `gdb_test_timeout' 7027 7028 Defining this variable changes the default timeout duration used 7029 during communication with GDB. More specifically, the global 7030 variable used during testing is `timeout', but this variable gets 7031 reset to `gdb_test_timeout' at the beginning of each testcase, 7032 making sure that any local change to `timeout' in a testcase does 7033 not affect subsequent testcases. 7034 7035 This global variable comes in handy when the debugger is slower 7036 than normal due to the testing environment, triggering unexpected 7037 `TIMEOUT' test failures. Examples include when testing on a 7038 remote machine, or against a system where communications are slow. 7039 7040 If not specifically defined, this variable gets automatically 7041 defined to the same value as `timeout' during the testsuite 7042 initialization. The default value of the timeout is defined in 7043 the file `gdb/testsuite/config/unix.exp' that is part of the GDB 7044 test suite(1). 7045 7046 7047 22.4 Testsuite Organization 7048 =========================== 7049 7050 The testsuite is entirely contained in `gdb/testsuite'. While the 7051 testsuite includes some makefiles and configury, these are very minimal, 7052 and used for little besides cleaning up, since the tests themselves 7053 handle the compilation of the programs that GDB will run. The file 7054 `testsuite/lib/gdb.exp' contains common utility procs useful for all 7055 GDB tests, while the directory `testsuite/config' contains 7056 configuration-specific files, typically used for special-purpose 7057 definitions of procs like `gdb_load' and `gdb_start'. 7058 7059 The tests themselves are to be found in `testsuite/gdb.*' and 7060 subdirectories of those. The names of the test files must always end 7061 with `.exp'. DejaGNU collects the test files by wildcarding in the 7062 test directories, so both subdirectories and individual files get 7063 chosen and run in alphabetical order. 7064 7065 The following table lists the main types of subdirectories and what 7066 they are for. Since DejaGNU finds test files no matter where they are 7067 located, and since each test file sets up its own compilation and 7068 execution environment, this organization is simply for convenience and 7069 intelligibility. 7070 7071 `gdb.base' 7072 This is the base testsuite. The tests in it should apply to all 7073 configurations of GDB (but generic native-only tests may live 7074 here). The test programs should be in the subset of C that is 7075 valid K&R, ANSI/ISO, and C++ (`#ifdef's are allowed if necessary, 7076 for instance for prototypes). 7077 7078 `gdb.LANG' 7079 Language-specific tests for any language LANG besides C. Examples 7080 are `gdb.cp' and `gdb.java'. 7081 7082 `gdb.PLATFORM' 7083 Non-portable tests. The tests are specific to a specific 7084 configuration (host or target), such as HP-UX or eCos. Example is 7085 `gdb.hp', for HP-UX. 7086 7087 `gdb.COMPILER' 7088 Tests specific to a particular compiler. As of this writing (June 7089 1999), there aren't currently any groups of tests in this category 7090 that couldn't just as sensibly be made platform-specific, but one 7091 could imagine a `gdb.gcc', for tests of GDB's handling of GCC 7092 extensions. 7093 7094 `gdb.SUBSYSTEM' 7095 Tests that exercise a specific GDB subsystem in more depth. For 7096 instance, `gdb.disasm' exercises various disassemblers, while 7097 `gdb.stabs' tests pathways through the stabs symbol reader. 7098 7099 22.5 Writing Tests 7100 ================== 7101 7102 In many areas, the GDB tests are already quite comprehensive; you 7103 should be able to copy existing tests to handle new cases. 7104 7105 You should try to use `gdb_test' whenever possible, since it 7106 includes cases to handle all the unexpected errors that might happen. 7107 However, it doesn't cost anything to add new test procedures; for 7108 instance, `gdb.base/exprs.exp' defines a `test_expr' that calls 7109 `gdb_test' multiple times. 7110 7111 Only use `send_gdb' and `gdb_expect' when absolutely necessary. 7112 Even if GDB has several valid responses to a command, you can use 7113 `gdb_test_multiple'. Like `gdb_test', `gdb_test_multiple' recognizes 7114 internal errors and unexpected prompts. 7115 7116 Do not write tests which expect a literal tab character from GDB. 7117 On some operating systems (e.g. OpenBSD) the TTY layer expands tabs to 7118 spaces, so by the time GDB's output reaches expect the tab is gone. 7119 7120 The source language programs do _not_ need to be in a consistent 7121 style. Since GDB is used to debug programs written in many different 7122 styles, it's worth having a mix of styles in the testsuite; for 7123 instance, some GDB bugs involving the display of source lines would 7124 never manifest themselves if the programs used GNU coding style 7125 uniformly. 7126 7127 ---------- Footnotes ---------- 7128 7129 (1) If you are using a board file, it could override the test-suite 7130 default; search the board file for "timeout". 7131 7132 7133 File: gdbint.info, Node: Hints, Next: GDB Observers, Prev: Testsuite, Up: Top 7134 7135 23 Hints 7136 ******** 7137 7138 Check the `README' file, it often has useful information that does not 7139 appear anywhere else in the directory. 7140 7141 * Menu: 7142 7143 * Getting Started:: Getting started working on GDB 7144 * Debugging GDB:: Debugging GDB with itself 7145 7146 7147 File: gdbint.info, Node: Getting Started, Next: Debugging GDB, Up: Hints 7148 7149 23.1 Getting Started 7150 ==================== 7151 7152 GDB is a large and complicated program, and if you first starting to 7153 work on it, it can be hard to know where to start. Fortunately, if you 7154 know how to go about it, there are ways to figure out what is going on. 7155 7156 This manual, the GDB Internals manual, has information which applies 7157 generally to many parts of GDB. 7158 7159 Information about particular functions or data structures are 7160 located in comments with those functions or data structures. If you 7161 run across a function or a global variable which does not have a 7162 comment correctly explaining what is does, this can be thought of as a 7163 bug in GDB; feel free to submit a bug report, with a suggested comment 7164 if you can figure out what the comment should say. If you find a 7165 comment which is actually wrong, be especially sure to report that. 7166 7167 Comments explaining the function of macros defined in host, target, 7168 or native dependent files can be in several places. Sometimes they are 7169 repeated every place the macro is defined. Sometimes they are where the 7170 macro is used. Sometimes there is a header file which supplies a 7171 default definition of the macro, and the comment is there. This manual 7172 also documents all the available macros. 7173 7174 Start with the header files. Once you have some idea of how GDB's 7175 internal symbol tables are stored (see `symtab.h', `gdbtypes.h'), you 7176 will find it much easier to understand the code which uses and creates 7177 those symbol tables. 7178 7179 You may wish to process the information you are getting somehow, to 7180 enhance your understanding of it. Summarize it, translate it to another 7181 language, add some (perhaps trivial or non-useful) feature to GDB, use 7182 the code to predict what a test case would do and write the test case 7183 and verify your prediction, etc. If you are reading code and your eyes 7184 are starting to glaze over, this is a sign you need to use a more active 7185 approach. 7186 7187 Once you have a part of GDB to start with, you can find more 7188 specifically the part you are looking for by stepping through each 7189 function with the `next' command. Do not use `step' or you will 7190 quickly get distracted; when the function you are stepping through 7191 calls another function try only to get a big-picture understanding 7192 (perhaps using the comment at the beginning of the function being 7193 called) of what it does. This way you can identify which of the 7194 functions being called by the function you are stepping through is the 7195 one which you are interested in. You may need to examine the data 7196 structures generated at each stage, with reference to the comments in 7197 the header files explaining what the data structures are supposed to 7198 look like. 7199 7200 Of course, this same technique can be used if you are just reading 7201 the code, rather than actually stepping through it. The same general 7202 principle applies--when the code you are looking at calls something 7203 else, just try to understand generally what the code being called does, 7204 rather than worrying about all its details. 7205 7206 A good place to start when tracking down some particular area is with 7207 a command which invokes that feature. Suppose you want to know how 7208 single-stepping works. As a GDB user, you know that the `step' command 7209 invokes single-stepping. The command is invoked via command tables 7210 (see `command.h'); by convention the function which actually performs 7211 the command is formed by taking the name of the command and adding 7212 `_command', or in the case of an `info' subcommand, `_info'. For 7213 example, the `step' command invokes the `step_command' function and the 7214 `info display' command invokes `display_info'. When this convention is 7215 not followed, you might have to use `grep' or `M-x tags-search' in 7216 emacs, or run GDB on itself and set a breakpoint in `execute_command'. 7217 7218 If all of the above fail, it may be appropriate to ask for 7219 information on `bug-gdb'. But _never_ post a generic question like "I 7220 was wondering if anyone could give me some tips about understanding 7221 GDB"--if we had some magic secret we would put it in this manual. 7222 Suggestions for improving the manual are always welcome, of course. 7223 7224 7225 File: gdbint.info, Node: Debugging GDB, Prev: Getting Started, Up: Hints 7226 7227 23.2 Debugging GDB with itself 7228 ============================== 7229 7230 If GDB is limping on your machine, this is the preferred way to get it 7231 fully functional. Be warned that in some ancient Unix systems, like 7232 Ultrix 4.2, a program can't be running in one process while it is being 7233 debugged in another. Rather than typing the command `./gdb ./gdb', 7234 which works on Suns and such, you can copy `gdb' to `gdb2' and then 7235 type `./gdb ./gdb2'. 7236 7237 When you run GDB in the GDB source directory, it will read a 7238 `.gdbinit' file that sets up some simple things to make debugging gdb 7239 easier. The `info' command, when executed without a subcommand in a 7240 GDB being debugged by gdb, will pop you back up to the top level gdb. 7241 See `.gdbinit' for details. 7242 7243 If you use emacs, you will probably want to do a `make TAGS' after 7244 you configure your distribution; this will put the machine dependent 7245 routines for your local machine where they will be accessed first by 7246 `M-.' 7247 7248 Also, make sure that you've either compiled GDB with your local cc, 7249 or have run `fixincludes' if you are compiling with gcc. 7250 7251 23.3 Submitting Patches 7252 ======================= 7253 7254 Thanks for thinking of offering your changes back to the community of 7255 GDB users. In general we like to get well designed enhancements. 7256 Thanks also for checking in advance about the best way to transfer the 7257 changes. 7258 7259 The GDB maintainers will only install "cleanly designed" patches. 7260 This manual summarizes what we believe to be clean design for GDB. 7261 7262 If the maintainers don't have time to put the patch in when it 7263 arrives, or if there is any question about a patch, it goes into a 7264 large queue with everyone else's patches and bug reports. 7265 7266 The legal issue is that to incorporate substantial changes requires a 7267 copyright assignment from you and/or your employer, granting ownership 7268 of the changes to the Free Software Foundation. You can get the 7269 standard documents for doing this by sending mail to `gnu (a] gnu.org' and 7270 asking for it. We recommend that people write in "All programs owned 7271 by the Free Software Foundation" as "NAME OF PROGRAM", so that changes 7272 in many programs (not just GDB, but GAS, Emacs, GCC, etc) can be 7273 contributed with only one piece of legalese pushed through the 7274 bureaucracy and filed with the FSF. We can't start merging changes 7275 until this paperwork is received by the FSF (their rules, which we 7276 follow since we maintain it for them). 7277 7278 Technically, the easiest way to receive changes is to receive each 7279 feature as a small context diff or unidiff, suitable for `patch'. Each 7280 message sent to me should include the changes to C code and header 7281 files for a single feature, plus `ChangeLog' entries for each directory 7282 where files were modified, and diffs for any changes needed to the 7283 manuals (`gdb/doc/gdb.texinfo' or `gdb/doc/gdbint.texinfo'). If there 7284 are a lot of changes for a single feature, they can be split down into 7285 multiple messages. 7286 7287 In this way, if we read and like the feature, we can add it to the 7288 sources with a single patch command, do some testing, and check it in. 7289 If you leave out the `ChangeLog', we have to write one. If you leave 7290 out the doc, we have to puzzle out what needs documenting. Etc., etc. 7291 7292 The reason to send each change in a separate message is that we will 7293 not install some of the changes. They'll be returned to you with 7294 questions or comments. If we're doing our job correctly, the message 7295 back to you will say what you have to fix in order to make the change 7296 acceptable. The reason to have separate messages for separate features 7297 is so that the acceptable changes can be installed while one or more 7298 changes are being reworked. If multiple features are sent in a single 7299 message, we tend to not put in the effort to sort out the acceptable 7300 changes from the unacceptable, so none of the features get installed 7301 until all are acceptable. 7302 7303 If this sounds painful or authoritarian, well, it is. But we get a 7304 lot of bug reports and a lot of patches, and many of them don't get 7305 installed because we don't have the time to finish the job that the bug 7306 reporter or the contributor could have done. Patches that arrive 7307 complete, working, and well designed, tend to get installed on the day 7308 they arrive. The others go into a queue and get installed as time 7309 permits, which, since the maintainers have many demands to meet, may not 7310 be for quite some time. 7311 7312 Please send patches directly to the GDB maintainers 7313 <gdb-patches (a] sourceware.org>. 7314 7315 23.4 Build Script 7316 ================= 7317 7318 The script `gdb_buildall.sh' builds GDB with flag 7319 `--enable-targets=all' set. This builds GDB with all supported targets 7320 activated. This helps testing GDB when doing changes that affect more 7321 than one architecture and is much faster than using `gdb_mbuild.sh'. 7322 7323 After building GDB the script checks which architectures are 7324 supported and then switches the current architecture to each of those 7325 to get information about the architecture. The test results are stored 7326 in log files in the directory the script was called from. 7327 7328 7329 File: gdbint.info, Node: GDB Observers, Next: GNU Free Documentation License, Prev: Hints, Up: Top 7330 7331 Appendix A GDB Currently available observers 7332 ******************************************** 7333 7334 A.1 Implementation rationale 7335 ============================ 7336 7337 An "observer" is an entity which is interested in being notified when 7338 GDB reaches certain states, or certain events occur in GDB. The entity 7339 being observed is called the "subject". To receive notifications, the 7340 observer attaches a callback to the subject. One subject can have 7341 several observers. 7342 7343 `observer.c' implements an internal generic low-level event 7344 notification mechanism. This generic event notification mechanism is 7345 then re-used to implement the exported high-level notification 7346 management routines for all possible notifications. 7347 7348 The current implementation of the generic observer provides support 7349 for contextual data. This contextual data is given to the subject when 7350 attaching the callback. In return, the subject will provide this 7351 contextual data back to the observer as a parameter of the callback. 7352 7353 Note that the current support for the contextual data is only 7354 partial, as it lacks a mechanism that would deallocate this data when 7355 the callback is detached. This is not a problem so far, as this 7356 contextual data is only used internally to hold a function pointer. 7357 Later on, if a certain observer needs to provide support for user-level 7358 contextual data, then the generic notification mechanism will need to be 7359 enhanced to allow the observer to provide a routine to deallocate the 7360 data when attaching the callback. 7361 7362 The observer implementation is also currently not reentrant. In 7363 particular, it is therefore not possible to call the attach or detach 7364 routines during a notification. 7365 7366 A.2 Debugging 7367 ============= 7368 7369 Observer notifications can be traced using the command `set debug 7370 observer 1' (*note Optional messages about internal happenings: 7371 (gdb)Debugging Output.). 7372 7373 A.3 `normal_stop' Notifications 7374 =============================== 7375 7376 GDB notifies all `normal_stop' observers when the inferior execution 7377 has just stopped, the associated messages and annotations have been 7378 printed, and the control is about to be returned to the user. 7379 7380 Note that the `normal_stop' notification is not emitted when the 7381 execution stops due to a breakpoint, and this breakpoint has a 7382 condition that is not met. If the breakpoint has any associated 7383 commands list, the commands are executed after the notification is 7384 emitted. 7385 7386 The following interfaces are available to manage observers: 7387 7388 -- Function: extern struct observer *observer_attach_EVENT 7389 (observer_EVENT_ftype *F) 7390 Using the function F, create an observer that is notified when 7391 ever EVENT occurs, return the observer. 7392 7393 -- Function: extern void observer_detach_EVENT (struct observer 7394 *OBSERVER); 7395 Remove OBSERVER from the list of observers to be notified when 7396 EVENT occurs. 7397 7398 -- Function: extern void observer_notify_EVENT (void); 7399 Send a notification to all EVENT observers. 7400 7401 The following observable events are defined: 7402 7403 -- Function: void normal_stop (struct bpstats *BS, int PRINT_FRAME) 7404 The inferior has stopped for real. The BS argument describes the 7405 breakpoints were are stopped at, if any. Second argument 7406 PRINT_FRAME non-zero means display the location where the inferior 7407 has stopped. 7408 7409 -- Function: void target_changed (struct target_ops *TARGET) 7410 The target's register contents have changed. 7411 7412 -- Function: void executable_changed (void) 7413 The executable being debugged by GDB has changed: The user decided 7414 to debug a different program, or the program he was debugging has 7415 been modified since being loaded by the debugger (by being 7416 recompiled, for instance). 7417 7418 -- Function: void inferior_created (struct target_ops *OBJFILE, int 7419 FROM_TTY) 7420 GDB has just connected to an inferior. For `run', GDB calls this 7421 observer while the inferior is still stopped at the entry-point 7422 instruction. For `attach' and `core', GDB calls this observer 7423 immediately after connecting to the inferior, and before any 7424 information on the inferior has been printed. 7425 7426 -- Function: void solib_loaded (struct so_list *SOLIB) 7427 The shared library specified by SOLIB has been loaded. Note that 7428 when GDB calls this observer, the library's symbols probably 7429 haven't been loaded yet. 7430 7431 -- Function: void solib_unloaded (struct so_list *SOLIB) 7432 The shared library specified by SOLIB has been unloaded. Note 7433 that when GDB calls this observer, the library's symbols have not 7434 been unloaded yet, and thus are still available. 7435 7436 -- Function: void new_objfile (struct objfile *OBJFILE) 7437 The symbol file specified by OBJFILE has been loaded. Called with 7438 OBJFILE equal to `NULL' to indicate previously loaded symbol table 7439 data has now been invalidated. 7440 7441 -- Function: void new_thread (struct thread_info *T) 7442 The thread specified by T has been created. 7443 7444 -- Function: void thread_exit (struct thread_info *T, int SILENT) 7445 The thread specified by T has exited. The SILENT argument 7446 indicates that GDB is removing the thread from its tables without 7447 wanting to notify the user about it. 7448 7449 -- Function: void thread_stop_requested (ptid_t PTID) 7450 An explicit stop request was issued to PTID. If PTID equals 7451 MINUS_ONE_PTID, the request applied to all threads. If 7452 `ptid_is_pid(ptid)' returns true, the request applied to all 7453 threads of the process pointed at by PTID. Otherwise, the request 7454 applied to the single thread pointed at by PTID. 7455 7456 -- Function: void target_resumed (ptid_t PTID) 7457 The target was resumed. The PTID parameter specifies which thread 7458 was resume, and may be RESUME_ALL if all threads are resumed. 7459 7460 -- Function: void about_to_proceed (void) 7461 The target is about to be proceeded. 7462 7463 -- Function: void breakpoint_created (int BPNUM) 7464 A new breakpoint has been created. The argument BPNUM is the 7465 number of the newly-created breakpoint. 7466 7467 -- Function: void breakpoint_deleted (int BPNUM) 7468 A breakpoint has been destroyed. The argument BPNUM is the number 7469 of the newly-destroyed breakpoint. 7470 7471 -- Function: void breakpoint_modified (int BPNUM) 7472 A breakpoint has been modified in some way. The argument BPNUM is 7473 the number of the modified breakpoint. 7474 7475 -- Function: void tracepoint_created (int TPNUM) 7476 A new tracepoint has been created. The argument TPNUM is the 7477 number of the newly-created tracepoint. 7478 7479 -- Function: void tracepoint_deleted (int TPNUM) 7480 A tracepoint has been destroyed. The argument TPNUM is the number 7481 of the newly-destroyed tracepoint. 7482 7483 -- Function: void tracepoint_modified (int TPNUM) 7484 A tracepoint has been modified in some way. The argument TPNUM is 7485 the number of the modified tracepoint. 7486 7487 -- Function: void architecture_changed (struct gdbarch *NEWARCH) 7488 The current architecture has changed. The argument NEWARCH is a 7489 pointer to the new architecture. 7490 7491 -- Function: void thread_ptid_changed (ptid_t OLD_PTID, ptid_t 7492 NEW_PTID) 7493 The thread's ptid has changed. The OLD_PTID parameter specifies 7494 the old value, and NEW_PTID specifies the new value. 7495 7496 -- Function: void inferior_added (struct inferior *INF) 7497 The inferior INF has been added to the list of inferiors. At this 7498 point, it might not be associated with any process. 7499 7500 -- Function: void inferior_appeared (struct inferior *INF) 7501 The inferior identified by INF has been attached to a process. 7502 7503 -- Function: void inferior_exit (struct inferior *INF) 7504 Either the inferior associated with INF has been detached from the 7505 process, or the process has exited. 7506 7507 -- Function: void inferior_removed (struct inferior *INF) 7508 The inferior INF has been removed from the list of inferiors. 7509 This method is called immediately before freeing INF. 7510 7511 -- Function: void memory_changed (CORE_ADDR ADDR, int LEN, const 7512 bfd_byte *DATA) 7513 Bytes from DATA to DATA + LEN have been written to the current 7514 inferior at ADDR. 7515 7516 -- Function: void test_notification (int SOMEARG) 7517 This observer is used for internal testing. Do not use. See 7518 testsuite/gdb.gdb/observer.exp. 7519 7520 7521 File: gdbint.info, Node: GNU Free Documentation License, Next: Index, Prev: GDB Observers, Up: Top 7522 7523 Appendix B GNU Free Documentation License 7524 ***************************************** 7525 7526 Version 1.3, 3 November 2008 7527 7528 Copyright (C) 2000, 2001, 2002, 2007, 2008 Free Software Foundation, Inc. 7529 `http://fsf.org/' 7530 7531 Everyone is permitted to copy and distribute verbatim copies 7532 of this license document, but changing it is not allowed. 7533 7534 0. PREAMBLE 7535 7536 The purpose of this License is to make a manual, textbook, or other 7537 functional and useful document "free" in the sense of freedom: to 7538 assure everyone the effective freedom to copy and redistribute it, 7539 with or without modifying it, either commercially or 7540 noncommercially. Secondarily, this License preserves for the 7541 author and publisher a way to get credit for their work, while not 7542 being considered responsible for modifications made by others. 7543 7544 This License is a kind of "copyleft", which means that derivative 7545 works of the document must themselves be free in the same sense. 7546 It complements the GNU General Public License, which is a copyleft 7547 license designed for free software. 7548 7549 We have designed this License in order to use it for manuals for 7550 free software, because free software needs free documentation: a 7551 free program should come with manuals providing the same freedoms 7552 that the software does. But this License is not limited to 7553 software manuals; it can be used for any textual work, regardless 7554 of subject matter or whether it is published as a printed book. 7555 We recommend this License principally for works whose purpose is 7556 instruction or reference. 7557 7558 1. APPLICABILITY AND DEFINITIONS 7559 7560 This License applies to any manual or other work, in any medium, 7561 that contains a notice placed by the copyright holder saying it 7562 can be distributed under the terms of this License. Such a notice 7563 grants a world-wide, royalty-free license, unlimited in duration, 7564 to use that work under the conditions stated herein. The 7565 "Document", below, refers to any such manual or work. Any member 7566 of the public is a licensee, and is addressed as "you". You 7567 accept the license if you copy, modify or distribute the work in a 7568 way requiring permission under copyright law. 7569 7570 A "Modified Version" of the Document means any work containing the 7571 Document or a portion of it, either copied verbatim, or with 7572 modifications and/or translated into another language. 7573 7574 A "Secondary Section" is a named appendix or a front-matter section 7575 of the Document that deals exclusively with the relationship of the 7576 publishers or authors of the Document to the Document's overall 7577 subject (or to related matters) and contains nothing that could 7578 fall directly within that overall subject. (Thus, if the Document 7579 is in part a textbook of mathematics, a Secondary Section may not 7580 explain any mathematics.) The relationship could be a matter of 7581 historical connection with the subject or with related matters, or 7582 of legal, commercial, philosophical, ethical or political position 7583 regarding them. 7584 7585 The "Invariant Sections" are certain Secondary Sections whose 7586 titles are designated, as being those of Invariant Sections, in 7587 the notice that says that the Document is released under this 7588 License. If a section does not fit the above definition of 7589 Secondary then it is not allowed to be designated as Invariant. 7590 The Document may contain zero Invariant Sections. If the Document 7591 does not identify any Invariant Sections then there are none. 7592 7593 The "Cover Texts" are certain short passages of text that are 7594 listed, as Front-Cover Texts or Back-Cover Texts, in the notice 7595 that says that the Document is released under this License. A 7596 Front-Cover Text may be at most 5 words, and a Back-Cover Text may 7597 be at most 25 words. 7598 7599 A "Transparent" copy of the Document means a machine-readable copy, 7600 represented in a format whose specification is available to the 7601 general public, that is suitable for revising the document 7602 straightforwardly with generic text editors or (for images 7603 composed of pixels) generic paint programs or (for drawings) some 7604 widely available drawing editor, and that is suitable for input to 7605 text formatters or for automatic translation to a variety of 7606 formats suitable for input to text formatters. A copy made in an 7607 otherwise Transparent file format whose markup, or absence of 7608 markup, has been arranged to thwart or discourage subsequent 7609 modification by readers is not Transparent. An image format is 7610 not Transparent if used for any substantial amount of text. A 7611 copy that is not "Transparent" is called "Opaque". 7612 7613 Examples of suitable formats for Transparent copies include plain 7614 ASCII without markup, Texinfo input format, LaTeX input format, 7615 SGML or XML using a publicly available DTD, and 7616 standard-conforming simple HTML, PostScript or PDF designed for 7617 human modification. Examples of transparent image formats include 7618 PNG, XCF and JPG. Opaque formats include proprietary formats that 7619 can be read and edited only by proprietary word processors, SGML or 7620 XML for which the DTD and/or processing tools are not generally 7621 available, and the machine-generated HTML, PostScript or PDF 7622 produced by some word processors for output purposes only. 7623 7624 The "Title Page" means, for a printed book, the title page itself, 7625 plus such following pages as are needed to hold, legibly, the 7626 material this License requires to appear in the title page. For 7627 works in formats which do not have any title page as such, "Title 7628 Page" means the text near the most prominent appearance of the 7629 work's title, preceding the beginning of the body of the text. 7630 7631 The "publisher" means any person or entity that distributes copies 7632 of the Document to the public. 7633 7634 A section "Entitled XYZ" means a named subunit of the Document 7635 whose title either is precisely XYZ or contains XYZ in parentheses 7636 following text that translates XYZ in another language. (Here XYZ 7637 stands for a specific section name mentioned below, such as 7638 "Acknowledgements", "Dedications", "Endorsements", or "History".) 7639 To "Preserve the Title" of such a section when you modify the 7640 Document means that it remains a section "Entitled XYZ" according 7641 to this definition. 7642 7643 The Document may include Warranty Disclaimers next to the notice 7644 which states that this License applies to the Document. These 7645 Warranty Disclaimers are considered to be included by reference in 7646 this License, but only as regards disclaiming warranties: any other 7647 implication that these Warranty Disclaimers may have is void and 7648 has no effect on the meaning of this License. 7649 7650 2. VERBATIM COPYING 7651 7652 You may copy and distribute the Document in any medium, either 7653 commercially or noncommercially, provided that this License, the 7654 copyright notices, and the license notice saying this License 7655 applies to the Document are reproduced in all copies, and that you 7656 add no other conditions whatsoever to those of this License. You 7657 may not use technical measures to obstruct or control the reading 7658 or further copying of the copies you make or distribute. However, 7659 you may accept compensation in exchange for copies. If you 7660 distribute a large enough number of copies you must also follow 7661 the conditions in section 3. 7662 7663 You may also lend copies, under the same conditions stated above, 7664 and you may publicly display copies. 7665 7666 3. COPYING IN QUANTITY 7667 7668 If you publish printed copies (or copies in media that commonly 7669 have printed covers) of the Document, numbering more than 100, and 7670 the Document's license notice requires Cover Texts, you must 7671 enclose the copies in covers that carry, clearly and legibly, all 7672 these Cover Texts: Front-Cover Texts on the front cover, and 7673 Back-Cover Texts on the back cover. Both covers must also clearly 7674 and legibly identify you as the publisher of these copies. The 7675 front cover must present the full title with all words of the 7676 title equally prominent and visible. You may add other material 7677 on the covers in addition. Copying with changes limited to the 7678 covers, as long as they preserve the title of the Document and 7679 satisfy these conditions, can be treated as verbatim copying in 7680 other respects. 7681 7682 If the required texts for either cover are too voluminous to fit 7683 legibly, you should put the first ones listed (as many as fit 7684 reasonably) on the actual cover, and continue the rest onto 7685 adjacent pages. 7686 7687 If you publish or distribute Opaque copies of the Document 7688 numbering more than 100, you must either include a 7689 machine-readable Transparent copy along with each Opaque copy, or 7690 state in or with each Opaque copy a computer-network location from 7691 which the general network-using public has access to download 7692 using public-standard network protocols a complete Transparent 7693 copy of the Document, free of added material. If you use the 7694 latter option, you must take reasonably prudent steps, when you 7695 begin distribution of Opaque copies in quantity, to ensure that 7696 this Transparent copy will remain thus accessible at the stated 7697 location until at least one year after the last time you 7698 distribute an Opaque copy (directly or through your agents or 7699 retailers) of that edition to the public. 7700 7701 It is requested, but not required, that you contact the authors of 7702 the Document well before redistributing any large number of 7703 copies, to give them a chance to provide you with an updated 7704 version of the Document. 7705 7706 4. MODIFICATIONS 7707 7708 You may copy and distribute a Modified Version of the Document 7709 under the conditions of sections 2 and 3 above, provided that you 7710 release the Modified Version under precisely this License, with 7711 the Modified Version filling the role of the Document, thus 7712 licensing distribution and modification of the Modified Version to 7713 whoever possesses a copy of it. In addition, you must do these 7714 things in the Modified Version: 7715 7716 A. Use in the Title Page (and on the covers, if any) a title 7717 distinct from that of the Document, and from those of 7718 previous versions (which should, if there were any, be listed 7719 in the History section of the Document). You may use the 7720 same title as a previous version if the original publisher of 7721 that version gives permission. 7722 7723 B. List on the Title Page, as authors, one or more persons or 7724 entities responsible for authorship of the modifications in 7725 the Modified Version, together with at least five of the 7726 principal authors of the Document (all of its principal 7727 authors, if it has fewer than five), unless they release you 7728 from this requirement. 7729 7730 C. State on the Title page the name of the publisher of the 7731 Modified Version, as the publisher. 7732 7733 D. Preserve all the copyright notices of the Document. 7734 7735 E. Add an appropriate copyright notice for your modifications 7736 adjacent to the other copyright notices. 7737 7738 F. Include, immediately after the copyright notices, a license 7739 notice giving the public permission to use the Modified 7740 Version under the terms of this License, in the form shown in 7741 the Addendum below. 7742 7743 G. Preserve in that license notice the full lists of Invariant 7744 Sections and required Cover Texts given in the Document's 7745 license notice. 7746 7747 H. Include an unaltered copy of this License. 7748 7749 I. Preserve the section Entitled "History", Preserve its Title, 7750 and add to it an item stating at least the title, year, new 7751 authors, and publisher of the Modified Version as given on 7752 the Title Page. If there is no section Entitled "History" in 7753 the Document, create one stating the title, year, authors, 7754 and publisher of the Document as given on its Title Page, 7755 then add an item describing the Modified Version as stated in 7756 the previous sentence. 7757 7758 J. Preserve the network location, if any, given in the Document 7759 for public access to a Transparent copy of the Document, and 7760 likewise the network locations given in the Document for 7761 previous versions it was based on. These may be placed in 7762 the "History" section. You may omit a network location for a 7763 work that was published at least four years before the 7764 Document itself, or if the original publisher of the version 7765 it refers to gives permission. 7766 7767 K. For any section Entitled "Acknowledgements" or "Dedications", 7768 Preserve the Title of the section, and preserve in the 7769 section all the substance and tone of each of the contributor 7770 acknowledgements and/or dedications given therein. 7771 7772 L. Preserve all the Invariant Sections of the Document, 7773 unaltered in their text and in their titles. Section numbers 7774 or the equivalent are not considered part of the section 7775 titles. 7776 7777 M. Delete any section Entitled "Endorsements". Such a section 7778 may not be included in the Modified Version. 7779 7780 N. Do not retitle any existing section to be Entitled 7781 "Endorsements" or to conflict in title with any Invariant 7782 Section. 7783 7784 O. Preserve any Warranty Disclaimers. 7785 7786 If the Modified Version includes new front-matter sections or 7787 appendices that qualify as Secondary Sections and contain no 7788 material copied from the Document, you may at your option 7789 designate some or all of these sections as invariant. To do this, 7790 add their titles to the list of Invariant Sections in the Modified 7791 Version's license notice. These titles must be distinct from any 7792 other section titles. 7793 7794 You may add a section Entitled "Endorsements", provided it contains 7795 nothing but endorsements of your Modified Version by various 7796 parties--for example, statements of peer review or that the text 7797 has been approved by an organization as the authoritative 7798 definition of a standard. 7799 7800 You may add a passage of up to five words as a Front-Cover Text, 7801 and a passage of up to 25 words as a Back-Cover Text, to the end 7802 of the list of Cover Texts in the Modified Version. Only one 7803 passage of Front-Cover Text and one of Back-Cover Text may be 7804 added by (or through arrangements made by) any one entity. If the 7805 Document already includes a cover text for the same cover, 7806 previously added by you or by arrangement made by the same entity 7807 you are acting on behalf of, you may not add another; but you may 7808 replace the old one, on explicit permission from the previous 7809 publisher that added the old one. 7810 7811 The author(s) and publisher(s) of the Document do not by this 7812 License give permission to use their names for publicity for or to 7813 assert or imply endorsement of any Modified Version. 7814 7815 5. COMBINING DOCUMENTS 7816 7817 You may combine the Document with other documents released under 7818 this License, under the terms defined in section 4 above for 7819 modified versions, provided that you include in the combination 7820 all of the Invariant Sections of all of the original documents, 7821 unmodified, and list them all as Invariant Sections of your 7822 combined work in its license notice, and that you preserve all 7823 their Warranty Disclaimers. 7824 7825 The combined work need only contain one copy of this License, and 7826 multiple identical Invariant Sections may be replaced with a single 7827 copy. If there are multiple Invariant Sections with the same name 7828 but different contents, make the title of each such section unique 7829 by adding at the end of it, in parentheses, the name of the 7830 original author or publisher of that section if known, or else a 7831 unique number. Make the same adjustment to the section titles in 7832 the list of Invariant Sections in the license notice of the 7833 combined work. 7834 7835 In the combination, you must combine any sections Entitled 7836 "History" in the various original documents, forming one section 7837 Entitled "History"; likewise combine any sections Entitled 7838 "Acknowledgements", and any sections Entitled "Dedications". You 7839 must delete all sections Entitled "Endorsements." 7840 7841 6. COLLECTIONS OF DOCUMENTS 7842 7843 You may make a collection consisting of the Document and other 7844 documents released under this License, and replace the individual 7845 copies of this License in the various documents with a single copy 7846 that is included in the collection, provided that you follow the 7847 rules of this License for verbatim copying of each of the 7848 documents in all other respects. 7849 7850 You may extract a single document from such a collection, and 7851 distribute it individually under this License, provided you insert 7852 a copy of this License into the extracted document, and follow 7853 this License in all other respects regarding verbatim copying of 7854 that document. 7855 7856 7. AGGREGATION WITH INDEPENDENT WORKS 7857 7858 A compilation of the Document or its derivatives with other 7859 separate and independent documents or works, in or on a volume of 7860 a storage or distribution medium, is called an "aggregate" if the 7861 copyright resulting from the compilation is not used to limit the 7862 legal rights of the compilation's users beyond what the individual 7863 works permit. When the Document is included in an aggregate, this 7864 License does not apply to the other works in the aggregate which 7865 are not themselves derivative works of the Document. 7866 7867 If the Cover Text requirement of section 3 is applicable to these 7868 copies of the Document, then if the Document is less than one half 7869 of the entire aggregate, the Document's Cover Texts may be placed 7870 on covers that bracket the Document within the aggregate, or the 7871 electronic equivalent of covers if the Document is in electronic 7872 form. Otherwise they must appear on printed covers that bracket 7873 the whole aggregate. 7874 7875 8. TRANSLATION 7876 7877 Translation is considered a kind of modification, so you may 7878 distribute translations of the Document under the terms of section 7879 4. Replacing Invariant Sections with translations requires special 7880 permission from their copyright holders, but you may include 7881 translations of some or all Invariant Sections in addition to the 7882 original versions of these Invariant Sections. You may include a 7883 translation of this License, and all the license notices in the 7884 Document, and any Warranty Disclaimers, provided that you also 7885 include the original English version of this License and the 7886 original versions of those notices and disclaimers. In case of a 7887 disagreement between the translation and the original version of 7888 this License or a notice or disclaimer, the original version will 7889 prevail. 7890 7891 If a section in the Document is Entitled "Acknowledgements", 7892 "Dedications", or "History", the requirement (section 4) to 7893 Preserve its Title (section 1) will typically require changing the 7894 actual title. 7895 7896 9. TERMINATION 7897 7898 You may not copy, modify, sublicense, or distribute the Document 7899 except as expressly provided under this License. Any attempt 7900 otherwise to copy, modify, sublicense, or distribute it is void, 7901 and will automatically terminate your rights under this License. 7902 7903 However, if you cease all violation of this License, then your 7904 license from a particular copyright holder is reinstated (a) 7905 provisionally, unless and until the copyright holder explicitly 7906 and finally terminates your license, and (b) permanently, if the 7907 copyright holder fails to notify you of the violation by some 7908 reasonable means prior to 60 days after the cessation. 7909 7910 Moreover, your license from a particular copyright holder is 7911 reinstated permanently if the copyright holder notifies you of the 7912 violation by some reasonable means, this is the first time you have 7913 received notice of violation of this License (for any work) from 7914 that copyright holder, and you cure the violation prior to 30 days 7915 after your receipt of the notice. 7916 7917 Termination of your rights under this section does not terminate 7918 the licenses of parties who have received copies or rights from 7919 you under this License. If your rights have been terminated and 7920 not permanently reinstated, receipt of a copy of some or all of 7921 the same material does not give you any rights to use it. 7922 7923 10. FUTURE REVISIONS OF THIS LICENSE 7924 7925 The Free Software Foundation may publish new, revised versions of 7926 the GNU Free Documentation License from time to time. Such new 7927 versions will be similar in spirit to the present version, but may 7928 differ in detail to address new problems or concerns. See 7929 `http://www.gnu.org/copyleft/'. 7930 7931 Each version of the License is given a distinguishing version 7932 number. If the Document specifies that a particular numbered 7933 version of this License "or any later version" applies to it, you 7934 have the option of following the terms and conditions either of 7935 that specified version or of any later version that has been 7936 published (not as a draft) by the Free Software Foundation. If 7937 the Document does not specify a version number of this License, 7938 you may choose any version ever published (not as a draft) by the 7939 Free Software Foundation. If the Document specifies that a proxy 7940 can decide which future versions of this License can be used, that 7941 proxy's public statement of acceptance of a version permanently 7942 authorizes you to choose that version for the Document. 7943 7944 11. RELICENSING 7945 7946 "Massive Multiauthor Collaboration Site" (or "MMC Site") means any 7947 World Wide Web server that publishes copyrightable works and also 7948 provides prominent facilities for anybody to edit those works. A 7949 public wiki that anybody can edit is an example of such a server. 7950 A "Massive Multiauthor Collaboration" (or "MMC") contained in the 7951 site means any set of copyrightable works thus published on the MMC 7952 site. 7953 7954 "CC-BY-SA" means the Creative Commons Attribution-Share Alike 3.0 7955 license published by Creative Commons Corporation, a not-for-profit 7956 corporation with a principal place of business in San Francisco, 7957 California, as well as future copyleft versions of that license 7958 published by that same organization. 7959 7960 "Incorporate" means to publish or republish a Document, in whole or 7961 in part, as part of another Document. 7962 7963 An MMC is "eligible for relicensing" if it is licensed under this 7964 License, and if all works that were first published under this 7965 License somewhere other than this MMC, and subsequently 7966 incorporated in whole or in part into the MMC, (1) had no cover 7967 texts or invariant sections, and (2) were thus incorporated prior 7968 to November 1, 2008. 7969 7970 The operator of an MMC Site may republish an MMC contained in the 7971 site under CC-BY-SA on the same site at any time before August 1, 7972 2009, provided the MMC is eligible for relicensing. 7973 7974 7975 ADDENDUM: How to use this License for your documents 7976 ==================================================== 7977 7978 To use this License in a document you have written, include a copy of 7979 the License in the document and put the following copyright and license 7980 notices just after the title page: 7981 7982 Copyright (C) YEAR YOUR NAME. 7983 Permission is granted to copy, distribute and/or modify this document 7984 under the terms of the GNU Free Documentation License, Version 1.3 7985 or any later version published by the Free Software Foundation; 7986 with no Invariant Sections, no Front-Cover Texts, and no Back-Cover 7987 Texts. A copy of the license is included in the section entitled ``GNU 7988 Free Documentation License''. 7989 7990 If you have Invariant Sections, Front-Cover Texts and Back-Cover 7991 Texts, replace the "with...Texts." line with this: 7992 7993 with the Invariant Sections being LIST THEIR TITLES, with 7994 the Front-Cover Texts being LIST, and with the Back-Cover Texts 7995 being LIST. 7996 7997 If you have Invariant Sections without Cover Texts, or some other 7998 combination of the three, merge those two alternatives to suit the 7999 situation. 8000 8001 If your document contains nontrivial examples of program code, we 8002 recommend releasing these examples in parallel under your choice of 8003 free software license, such as the GNU General Public License, to 8004 permit their use in free software. 8005 8006 8007 File: gdbint.info, Node: Index, Prev: GNU Free Documentation License, Up: Top 8008 8009 Index 8010 ***** 8011 8012 [index] 8013 * Menu: 8014 8015 * $fp: Register Information Functions. 8016 (line 126) 8017 * $pc: Register Architecture Functions & Variables. 8018 (line 58) 8019 * $ps: Register Architecture Functions & Variables. 8020 (line 69) 8021 * $sp: Register Architecture Functions & Variables. 8022 (line 49) 8023 * _initialize_ARCH_tdep <1>: Adding a New Target. (line 22) 8024 * _initialize_ARCH_tdep: How an Architecture is Represented. 8025 (line 13) 8026 * _initialize_language: Language Support. (line 79) 8027 * a.out format: Symbol Handling. (line 218) 8028 * about_to_proceed: GDB Observers. (line 133) 8029 * abstract interpretation of function prologues: Algorithms. (line 48) 8030 * add_cmd: User Interface. (line 21) 8031 * add_com: User Interface. (line 21) 8032 * add_setshow_cmd: User Interface. (line 26) 8033 * add_setshow_cmd_full: User Interface. (line 26) 8034 * add_symtab_fns: Symbol Handling. (line 37) 8035 * adding a new host: Host Definition. (line 13) 8036 * adding a symbol-reading module: Symbol Handling. (line 37) 8037 * adding a target: Adding a New Target. (line 6) 8038 * adding debugging info reader: Symbol Handling. (line 365) 8039 * adding source language: Language Support. (line 17) 8040 * address classes: Address Classes. (line 6) 8041 * address representation: Pointers and Addresses. 8042 (line 6) 8043 * address spaces, separate data and code: Pointers and Addresses. 8044 (line 6) 8045 * address_class_name_to_type_flags: Defining Other Architecture Features. 8046 (line 28) 8047 * address_class_name_to_type_flags_p: Defining Other Architecture Features. 8048 (line 39) 8049 * algorithms: Algorithms. (line 6) 8050 * align_down: Functions and Variable to Analyze Frames. 8051 (line 46) 8052 * align_up: Functions and Variable to Analyze Frames. 8053 (line 46) 8054 * allocate_symtab: Language Support. (line 83) 8055 * ARCH-tdep.c: How an Architecture is Represented. 8056 (line 13) 8057 * architecture representation: How an Architecture is Represented. 8058 (line 6) 8059 * architecture_changed: GDB Observers. (line 160) 8060 * Array Containers: Support Libraries. (line 131) 8061 * assumptions about targets: Misc Guidelines. (line 334) 8062 * base of a frame: Frame Handling Terminology. 8063 (line 28) 8064 * BFD library: Support Libraries. (line 9) 8065 * bfd_arch_info: Looking Up an Existing Architecture. 8066 (line 41) 8067 * BIG_BREAKPOINT: Defining Other Architecture Features. 8068 (line 100) 8069 * BPT_VECTOR: Defining Other Architecture Features. 8070 (line 536) 8071 * BREAKPOINT: Defining Other Architecture Features. 8072 (line 88) 8073 * breakpoint address adjusted: Defining Other Architecture Features. 8074 (line 145) 8075 * breakpoint_created: GDB Observers. (line 136) 8076 * breakpoint_deleted: GDB Observers. (line 140) 8077 * breakpoint_modified: GDB Observers. (line 144) 8078 * breakpoints: Algorithms. (line 151) 8079 * bug-gdb mailing list: Getting Started. (line 72) 8080 * build script: Debugging GDB. (line 94) 8081 * C data types: Coding Standards. (line 105) 8082 * call frame information: Algorithms. (line 14) 8083 * call stack frame: Stack Frames. (line 6) 8084 * calls to the inferior: Inferior Call Setup. (line 6) 8085 * CC_HAS_LONG_LONG: Host Definition. (line 105) 8086 * CFI (call frame information): Algorithms. (line 14) 8087 * checkpoints: Algorithms. (line 600) 8088 * cleanups: Misc Guidelines. (line 12) 8089 * CLI: User Interface. (line 12) 8090 * code pointers, word-addressed: Pointers and Addresses. 8091 (line 6) 8092 * coding standards: Coding Standards. (line 6) 8093 * COFF debugging info: Symbol Handling. (line 315) 8094 * COFF format: Symbol Handling. (line 233) 8095 * command implementation: Getting Started. (line 60) 8096 * command interpreter: User Interface. (line 12) 8097 * comment formatting: Coding Standards. (line 79) 8098 * compiler warnings: Misc Guidelines. (line 252) 8099 * Compressed DWARF 2 debugging info: Symbol Handling. (line 335) 8100 * computed values: Values. (line 35) 8101 * configure.tgt: How an Architecture is Represented. 8102 (line 19) 8103 * converting between pointers and addresses: Pointers and Addresses. 8104 (line 6) 8105 * converting integers to addresses: Defining Other Architecture Features. 8106 (line 274) 8107 * cooked register representation: Raw and Cooked Registers. 8108 (line 6) 8109 * core files: Adding support for debugging core files. 8110 (line 6) 8111 * core_addr_greaterthan: Functions and Variable to Analyze Frames. 8112 (line 30) 8113 * core_addr_lessthan: Functions and Variable to Analyze Frames. 8114 (line 30) 8115 * CRLF_SOURCE_FILES: Host Definition. (line 86) 8116 * current_language: Language Support. (line 75) 8117 * D10V addresses: Pointers and Addresses. 8118 (line 6) 8119 * data output: User Interface. (line 254) 8120 * data-pointer, per-architecture/per-module: Misc Guidelines. (line 100) 8121 * debugging GDB: Debugging GDB. (line 6) 8122 * DEFAULT_PROMPT: Host Definition. (line 93) 8123 * deprecate_cmd: User Interface. (line 32) 8124 * DEPRECATED_IBM6000_TARGET: Defining Other Architecture Features. 8125 (line 242) 8126 * deprecating commands: User Interface. (line 32) 8127 * design: Misc Guidelines. (line 329) 8128 * DEV_TTY: Host Definition. (line 96) 8129 * DIRNAME_SEPARATOR: Misc Guidelines. (line 399) 8130 * DISABLE_UNSETTABLE_BREAK: Defining Other Architecture Features. 8131 (line 211) 8132 * discard_cleanups: Misc Guidelines. (line 39) 8133 * do_cleanups: Misc Guidelines. (line 35) 8134 * DOS text files: Host Definition. (line 87) 8135 * dummy frames: About Dummy Frames. (line 6) 8136 * DW_AT_address_class: Address Classes. (line 6) 8137 * DW_AT_byte_size: Address Classes. (line 6) 8138 * DWARF 2 debugging info: Symbol Handling. (line 328) 8139 * DWARF 3 debugging info: Symbol Handling. (line 355) 8140 * ECOFF debugging info: Symbol Handling. (line 321) 8141 * ECOFF format: Symbol Handling. (line 248) 8142 * ELF format: Symbol Handling. (line 281) 8143 * evaluate_subexp: Language Support. (line 58) 8144 * executable_changed: GDB Observers. (line 85) 8145 * execution state: Managing Execution State. 8146 (line 6) 8147 * experimental branches: Versions and Branches. 8148 (line 116) 8149 * expression evaluation routines: Language Support. (line 58) 8150 * expression parser: Language Support. (line 21) 8151 * extract_typed_address: Pointers and Addresses. 8152 (line 52) 8153 * field output functions: User Interface. (line 254) 8154 * file names, portability: Misc Guidelines. (line 367) 8155 * FILENAME_CMP: Misc Guidelines. (line 393) 8156 * find_pc_function: Symbol Handling. (line 136) 8157 * find_pc_line: Symbol Handling. (line 136) 8158 * find_sym_fns: Symbol Handling. (line 32) 8159 * finding a symbol: Symbol Handling. (line 133) 8160 * fine-tuning gdbarch structure: OS ABI Variant Handling. 8161 (line 23) 8162 * first floating point register: Register Architecture Functions & Variables. 8163 (line 78) 8164 * FOPEN_RB: Host Definition. (line 102) 8165 * fp0_regnum: Register Architecture Functions & Variables. 8166 (line 78) 8167 * frame: Stack Frames. (line 6) 8168 * frame ID: Stack Frames. (line 41) 8169 * frame pointer: Register Information Functions. 8170 (line 126) 8171 * frame, definition of base of a frame: Frame Handling Terminology. 8172 (line 28) 8173 * frame, definition of innermost frame: Frame Handling Terminology. 8174 (line 24) 8175 * frame, definition of NEXT frame: Frame Handling Terminology. 8176 (line 11) 8177 * frame, definition of PREVIOUS frame: Frame Handling Terminology. 8178 (line 14) 8179 * frame, definition of sentinel frame: Frame Handling Terminology. 8180 (line 52) 8181 * frame, definition of sniffing: Frame Handling Terminology. 8182 (line 46) 8183 * frame, definition of THIS frame: Frame Handling Terminology. 8184 (line 9) 8185 * frame, definition of unwinding: Frame Handling Terminology. 8186 (line 41) 8187 * frame_align: Functions and Variable to Analyze Frames. 8188 (line 46) 8189 * frame_base: Analyzing Stacks---Frame Sniffers. 8190 (line 89) 8191 * frame_base_append_sniffer: Analyzing Stacks---Frame Sniffers. 8192 (line 19) 8193 * frame_base_set_default: Analyzing Stacks---Frame Sniffers. 8194 (line 22) 8195 * frame_num_args: Functions to Access Frame Data. 8196 (line 43) 8197 * frame_red_zone_size: Functions and Variable to Analyze Frames. 8198 (line 63) 8199 * frame_register_unwind: Stack Frames. (line 15) 8200 * frame_unwind: Analyzing Stacks---Frame Sniffers. 8201 (line 36) 8202 * frame_unwind_append_sniffer: Analyzing Stacks---Frame Sniffers. 8203 (line 16) 8204 * frame_unwind_append_unwinder: Stack Frames. (line 30) 8205 * frame_unwind_got_address: Stack Frames. (line 105) 8206 * frame_unwind_got_constant: Stack Frames. (line 101) 8207 * frame_unwind_got_memory: Stack Frames. (line 98) 8208 * frame_unwind_got_optimized: Stack Frames. (line 90) 8209 * frame_unwind_got_register: Stack Frames. (line 93) 8210 * frame_unwind_prepend_unwinder: Stack Frames. (line 30) 8211 * full symbol table: Symbol Handling. (line 104) 8212 * function prologue: Prologue Caches. (line 6) 8213 * function prototypes: Coding Standards. (line 127) 8214 * function usage: Coding Standards. (line 109) 8215 * fundamental types: Symbol Handling. (line 183) 8216 * GCC2_COMPILED_FLAG_SYMBOL: Defining Other Architecture Features. 8217 (line 225) 8218 * GCC_COMPILED_FLAG_SYMBOL: Defining Other Architecture Features. 8219 (line 225) 8220 * GDB source tree structure: Overall Structure. (line 83) 8221 * gdb_byte: Register Caching. (line 23) 8222 * GDB_OSABI_AIX: OS ABI Variant Handling. 8223 (line 90) 8224 * GDB_OSABI_CYGWIN: OS ABI Variant Handling. 8225 (line 87) 8226 * GDB_OSABI_FREEBSD_AOUT: OS ABI Variant Handling. 8227 (line 51) 8228 * GDB_OSABI_FREEBSD_ELF: OS ABI Variant Handling. 8229 (line 54) 8230 * GDB_OSABI_GO32: OS ABI Variant Handling. 8231 (line 69) 8232 * GDB_OSABI_HPUX_ELF: OS ABI Variant Handling. 8233 (line 78) 8234 * GDB_OSABI_HPUX_SOM: OS ABI Variant Handling. 8235 (line 81) 8236 * GDB_OSABI_HURD: OS ABI Variant Handling. 8237 (line 39) 8238 * GDB_OSABI_INTERIX: OS ABI Variant Handling. 8239 (line 75) 8240 * GDB_OSABI_IRIX: OS ABI Variant Handling. 8241 (line 72) 8242 * GDB_OSABI_LINUX: OS ABI Variant Handling. 8243 (line 48) 8244 * GDB_OSABI_NETBSD_AOUT: OS ABI Variant Handling. 8245 (line 57) 8246 * GDB_OSABI_NETBSD_ELF: OS ABI Variant Handling. 8247 (line 60) 8248 * GDB_OSABI_OPENBSD_ELF: OS ABI Variant Handling. 8249 (line 63) 8250 * GDB_OSABI_OSF1: OS ABI Variant Handling. 8251 (line 45) 8252 * GDB_OSABI_QNXNTO: OS ABI Variant Handling. 8253 (line 84) 8254 * GDB_OSABI_SOLARIS: OS ABI Variant Handling. 8255 (line 42) 8256 * GDB_OSABI_SVR4: OS ABI Variant Handling. 8257 (line 36) 8258 * GDB_OSABI_UNINITIALIZED: OS ABI Variant Handling. 8259 (line 29) 8260 * GDB_OSABI_UNKNOWN: OS ABI Variant Handling. 8261 (line 32) 8262 * GDB_OSABI_WINCE: OS ABI Variant Handling. 8263 (line 66) 8264 * gdbarch: How an Architecture is Represented. 8265 (line 19) 8266 * gdbarch accessor functions: Creating a New Architecture. 8267 (line 14) 8268 * gdbarch lookup: Looking Up an Existing Architecture. 8269 (line 6) 8270 * gdbarch register architecture functions: Register Architecture Functions & Variables. 8271 (line 6) 8272 * gdbarch register information functions: Register Information Functions. 8273 (line 6) 8274 * gdbarch_addr_bits_remove: Defining Other Architecture Features. 8275 (line 11) 8276 * gdbarch_address_class_name_to_type_flags: Address Classes. (line 30) 8277 * gdbarch_address_class_type_flags <1>: Defining Other Architecture Features. 8278 (line 43) 8279 * gdbarch_address_class_type_flags: Address Classes. (line 18) 8280 * gdbarch_address_class_type_flags_p: Defining Other Architecture Features. 8281 (line 52) 8282 * gdbarch_address_class_type_flags_to_name <1>: Defining Other Architecture Features. 8283 (line 56) 8284 * gdbarch_address_class_type_flags_to_name: Address Classes. (line 25) 8285 * gdbarch_address_class_type_flags_to_name_p: Defining Other Architecture Features. 8286 (line 60) 8287 * gdbarch_address_to_pointer <1>: Defining Other Architecture Features. 8288 (line 65) 8289 * gdbarch_address_to_pointer: Pointers and Addresses. 8290 (line 114) 8291 * gdbarch_adjust_breakpoint_address: Defining Other Architecture Features. 8292 (line 145) 8293 * gdbarch_alloc: Creating a New Architecture. 8294 (line 6) 8295 * gdbarch_believe_pcc_promotion: Defining Other Architecture Features. 8296 (line 72) 8297 * gdbarch_bits_big_endian: Defining Other Architecture Features. 8298 (line 77) 8299 * gdbarch_breakpoint_from_pc: Defining Other Architecture Features. 8300 (line 106) 8301 * gdbarch_call_dummy_location: Defining Other Architecture Features. 8302 (line 178) 8303 * gdbarch_cannot_fetch_register: Defining Other Architecture Features. 8304 (line 184) 8305 * gdbarch_cannot_store_register: Defining Other Architecture Features. 8306 (line 188) 8307 * gdbarch_char_signed: Defining Other Architecture Features. 8308 (line 461) 8309 * gdbarch_convert_register_p <1>: Defining Other Architecture Features. 8310 (line 195) 8311 * gdbarch_convert_register_p: Register and Memory Data. 8312 (line 30) 8313 * gdbarch_data: Misc Guidelines. (line 133) 8314 * gdbarch_data_register_post_init: Misc Guidelines. (line 118) 8315 * gdbarch_data_register_pre_init: Misc Guidelines. (line 108) 8316 * gdbarch_decr_pc_after_break: Defining Other Architecture Features. 8317 (line 205) 8318 * gdbarch_deprecated_fp_regnum: Defining Other Architecture Features. 8319 (line 446) 8320 * gdbarch_double_bit: Defining Other Architecture Features. 8321 (line 471) 8322 * gdbarch_dummy_id: Defining Other Architecture Features. 8323 (line 523) 8324 * gdbarch_dwarf2_reg_to_regnum: Defining Other Architecture Features. 8325 (line 216) 8326 * gdbarch_ecoff_reg_to_regnum: Defining Other Architecture Features. 8327 (line 220) 8328 * gdbarch_float_bit: Defining Other Architecture Features. 8329 (line 475) 8330 * gdbarch_fp0_regnum: Defining Other Architecture Features. 8331 (line 200) 8332 * gdbarch_get_longjmp_target <1>: Defining Other Architecture Features. 8333 (line 231) 8334 * gdbarch_get_longjmp_target: Algorithms. (line 263) 8335 * gdbarch_have_nonsteppable_watchpoint: Algorithms. (line 396) 8336 * gdbarch_in_function_epilogue_p: Defining Other Architecture Features. 8337 (line 253) 8338 * gdbarch_in_solib_return_trampoline: Defining Other Architecture Features. 8339 (line 259) 8340 * gdbarch_info: Looking Up an Existing Architecture. 8341 (line 22) 8342 * gdbarch_init_osabi: OS ABI Variant Handling. 8343 (line 125) 8344 * gdbarch_int_bit: Defining Other Architecture Features. 8345 (line 478) 8346 * gdbarch_integer_to_address: Defining Other Architecture Features. 8347 (line 274) 8348 * gdbarch_list_lookup_by_info: Looking Up an Existing Architecture. 8349 (line 22) 8350 * gdbarch_long_bit: Defining Other Architecture Features. 8351 (line 481) 8352 * gdbarch_long_double_bit: Defining Other Architecture Features. 8353 (line 485) 8354 * gdbarch_long_long_bit: Defining Other Architecture Features. 8355 (line 489) 8356 * gdbarch_lookup_osabi: OS ABI Variant Handling. 8357 (line 119) 8358 * gdbarch_memory_insert_breakpoint: Defining Other Architecture Features. 8359 (line 130) 8360 * gdbarch_memory_remove_breakpoint: Defining Other Architecture Features. 8361 (line 130) 8362 * gdbarch_osabi_name: OS ABI Variant Handling. 8363 (line 97) 8364 * gdbarch_pointer_to_address <1>: Defining Other Architecture Features. 8365 (line 295) 8366 * gdbarch_pointer_to_address: Pointers and Addresses. 8367 (line 105) 8368 * gdbarch_print_insn: Defining Other Architecture Features. 8369 (line 513) 8370 * gdbarch_ptr_bit: Defining Other Architecture Features. 8371 (line 493) 8372 * gdbarch_push_dummy_call: Defining Other Architecture Features. 8373 (line 363) 8374 * gdbarch_push_dummy_code: Defining Other Architecture Features. 8375 (line 375) 8376 * gdbarch_register <1>: Adding a New Target. (line 40) 8377 * gdbarch_register: How an Architecture is Represented. 8378 (line 19) 8379 * gdbarch_register_osabi: OS ABI Variant Handling. 8380 (line 103) 8381 * gdbarch_register_osabi_sniffer: OS ABI Variant Handling. 8382 (line 112) 8383 * gdbarch_register_to_value <1>: Defining Other Architecture Features. 8384 (line 301) 8385 * gdbarch_register_to_value: Register and Memory Data. 8386 (line 46) 8387 * gdbarch_return_value: Defining Other Architecture Features. 8388 (line 394) 8389 * gdbarch_sdb_reg_to_regnum: Defining Other Architecture Features. 8390 (line 390) 8391 * gdbarch_short_bit: Defining Other Architecture Features. 8392 (line 497) 8393 * gdbarch_skip_permanent_breakpoint: Defining Other Architecture Features. 8394 (line 430) 8395 * gdbarch_skip_trampoline_code: Defining Other Architecture Features. 8396 (line 441) 8397 * gdbarch_stab_reg_to_regnum: Defining Other Architecture Features. 8398 (line 450) 8399 * gdbarch_stabs_argument_has_addr: Defining Other Architecture Features. 8400 (line 359) 8401 * gdbarch_tdep definition: Creating a New Architecture. 8402 (line 34) 8403 * gdbarch_tdep when allocating new gdbarch: Creating a New Architecture. 8404 (line 6) 8405 * gdbarch_value_to_register <1>: Defining Other Architecture Features. 8406 (line 529) 8407 * gdbarch_value_to_register: Register and Memory Data. 8408 (line 62) 8409 * gdbarch_virtual_frame_pointer: Defining Other Architecture Features. 8410 (line 501) 8411 * GDBINIT_FILENAME: Host Definition. (line 74) 8412 * generic host support: Host Definition. (line 38) 8413 * generic_elf_osabi_sniff_abi_tag_sections: OS ABI Variant Handling. 8414 (line 133) 8415 * get_frame_register: Stack Frames. (line 15) 8416 * get_frame_type: Stack Frames. (line 22) 8417 * hardware breakpoints: Algorithms. (line 158) 8418 * hardware watchpoints: Algorithms. (line 280) 8419 * HAVE_CONTINUABLE_WATCHPOINT: Algorithms. (line 402) 8420 * HAVE_DOS_BASED_FILE_SYSTEM: Misc Guidelines. (line 376) 8421 * HAVE_STEPPABLE_WATCHPOINT: Algorithms. (line 386) 8422 * host: Overall Structure. (line 50) 8423 * host, adding: Host Definition. (line 13) 8424 * i386_cleanup_dregs: Algorithms. (line 576) 8425 * I386_DR_LOW_GET_STATUS: Algorithms. (line 489) 8426 * I386_DR_LOW_RESET_ADDR: Algorithms. (line 485) 8427 * I386_DR_LOW_SET_ADDR: Algorithms. (line 482) 8428 * I386_DR_LOW_SET_CONTROL: Algorithms. (line 479) 8429 * i386_insert_hw_breakpoint: Algorithms. (line 564) 8430 * i386_insert_watchpoint: Algorithms. (line 536) 8431 * i386_region_ok_for_watchpoint: Algorithms. (line 514) 8432 * i386_remove_hw_breakpoint: Algorithms. (line 564) 8433 * i386_remove_watchpoint: Algorithms. (line 536) 8434 * i386_stopped_by_watchpoint: Algorithms. (line 528) 8435 * i386_stopped_data_address: Algorithms. (line 521) 8436 * I386_USE_GENERIC_WATCHPOINTS: Algorithms. (line 461) 8437 * in_dynsym_resolve_code: Defining Other Architecture Features. 8438 (line 263) 8439 * inferior_added: GDB Observers. (line 169) 8440 * inferior_appeared: GDB Observers. (line 173) 8441 * inferior_created: GDB Observers. (line 92) 8442 * inferior_exit: GDB Observers. (line 176) 8443 * inferior_removed: GDB Observers. (line 180) 8444 * inner_than: Functions and Variable to Analyze Frames. 8445 (line 30) 8446 * innermost frame: Frame Handling Terminology. 8447 (line 24) 8448 * insert or remove hardware breakpoint: Algorithms. (line 234) 8449 * insert or remove hardware watchpoint: Algorithms. (line 347) 8450 * insert or remove software breakpoint: Algorithms. (line 211) 8451 * IS_ABSOLUTE_PATH: Misc Guidelines. (line 387) 8452 * IS_DIR_SEPARATOR: Misc Guidelines. (line 382) 8453 * ISATTY: Host Definition. (line 99) 8454 * item output functions: User Interface. (line 254) 8455 * language parser: Language Support. (line 25) 8456 * language support: Language Support. (line 6) 8457 * legal papers for code contributions: Debugging GDB. (line 42) 8458 * length_of_subexp: Language Support. (line 58) 8459 * libgdb: libgdb. (line 9) 8460 * libiberty library: Support Libraries. (line 52) 8461 * line wrap in output: Misc Guidelines. (line 191) 8462 * lint: Host Definition. (line 119) 8463 * list output functions: User Interface. (line 131) 8464 * LITTLE_BREAKPOINT: Defining Other Architecture Features. 8465 (line 100) 8466 * long long data type: Host Definition. (line 106) 8467 * longjmp debugging: Algorithms. (line 258) 8468 * lookup_symbol: Symbol Handling. (line 142) 8469 * LSEEK_NOT_LINEAR: Host Definition. (line 114) 8470 * lval_type enumeration, for values.: Values. (line 19) 8471 * make_cleanup: Misc Guidelines. (line 28) 8472 * make_cleanup_ui_out_list_begin_end: User Interface. (line 247) 8473 * make_cleanup_ui_out_tuple_begin_end: User Interface. (line 223) 8474 * making a new release of gdb: Releasing GDB. (line 6) 8475 * memory representation: Register and Memory Data. 8476 (line 6) 8477 * memory_changed: GDB Observers. (line 185) 8478 * minimal symbol table: Symbol Handling. (line 111) 8479 * minsymtabs: Symbol Handling. (line 111) 8480 * multi-arch data: Misc Guidelines. (line 100) 8481 * NATDEPFILES: Native Debugging. (line 8) 8482 * native conditionals: Native Debugging. (line 75) 8483 * native debugging: Native Debugging. (line 6) 8484 * nesting level in ui_out functions: User Interface. (line 143) 8485 * new year procedure: Start of New Year Procedure. 8486 (line 6) 8487 * new_objfile: GDB Observers. (line 109) 8488 * new_thread: GDB Observers. (line 114) 8489 * NEXT frame: Frame Handling Terminology. 8490 (line 11) 8491 * normal_stop: GDB Observers. (line 76) 8492 * normal_stop observer: GDB Observers. (line 48) 8493 * notification about inferior execution stop: GDB Observers. (line 48) 8494 * notifications about changes in internals: Algorithms. (line 630) 8495 * object file formats: Symbol Handling. (line 215) 8496 * observer pattern interface: Algorithms. (line 630) 8497 * observers implementation rationale: GDB Observers. (line 9) 8498 * obstacks: Support Libraries. (line 69) 8499 * op_print_tab: Language Support. (line 91) 8500 * opcodes library: Support Libraries. (line 39) 8501 * OS ABI variants: OS ABI Variant Handling. 8502 (line 6) 8503 * parse_exp_1: Language Support. (line 97) 8504 * partial symbol table: Symbol Handling. (line 114) 8505 * pc_regnum: Register Architecture Functions & Variables. 8506 (line 58) 8507 * PE-COFF format: Symbol Handling. (line 272) 8508 * per-architecture module data: Misc Guidelines. (line 100) 8509 * pointer representation: Pointers and Addresses. 8510 (line 6) 8511 * portability: Misc Guidelines. (line 350) 8512 * portable file name handling: Misc Guidelines. (line 367) 8513 * porting to new machines: Porting GDB. (line 6) 8514 * prefixify_subexp: Language Support. (line 58) 8515 * PREVIOUS frame: Frame Handling Terminology. 8516 (line 14) 8517 * print_float_info: Register Information Functions. 8518 (line 80) 8519 * print_registers_info: Register Information Functions. 8520 (line 53) 8521 * print_subexp: Language Support. (line 91) 8522 * print_vector_info: Register Information Functions. 8523 (line 96) 8524 * PRINTF_HAS_LONG_LONG: Host Definition. (line 109) 8525 * processor status register: Register Architecture Functions & Variables. 8526 (line 69) 8527 * program counter <1>: Register Architecture Functions & Variables. 8528 (line 58) 8529 * program counter: Algorithms. (line 158) 8530 * prologue analysis: Algorithms. (line 14) 8531 * prologue cache: Prologue Caches. (line 12) 8532 * prologue of a function: Prologue Caches. (line 6) 8533 * prologue-value.c: Algorithms. (line 48) 8534 * prompt: Host Definition. (line 94) 8535 * ps_regnum: Register Architecture Functions & Variables. 8536 (line 69) 8537 * pseudo-evaluation of function prologues: Algorithms. (line 48) 8538 * pseudo_register_read: Register Architecture Functions & Variables. 8539 (line 29) 8540 * pseudo_register_write: Register Architecture Functions & Variables. 8541 (line 33) 8542 * psymtabs: Symbol Handling. (line 107) 8543 * push_dummy_call: Functions Creating Dummy Frames. 8544 (line 13) 8545 * push_dummy_code: Functions Creating Dummy Frames. 8546 (line 57) 8547 * raw register representation: Raw and Cooked Registers. 8548 (line 6) 8549 * read_pc: Register Architecture Functions & Variables. 8550 (line 10) 8551 * reading of symbols: Symbol Handling. (line 25) 8552 * readline library: Support Libraries. (line 45) 8553 * regcache_cooked_read: Register Caching. (line 23) 8554 * regcache_cooked_read_signed: Register Caching. (line 23) 8555 * regcache_cooked_read_unsigned: Register Caching. (line 23) 8556 * regcache_cooked_write: Register Caching. (line 23) 8557 * regcache_cooked_write_signed: Register Caching. (line 23) 8558 * regcache_cooked_write_unsigned: Register Caching. (line 23) 8559 * register caching: Register Caching. (line 6) 8560 * register data formats, converting: Register and Memory Data. 8561 (line 6) 8562 * register representation: Register and Memory Data. 8563 (line 6) 8564 * REGISTER_CONVERT_TO_RAW: Defining Other Architecture Features. 8565 (line 311) 8566 * REGISTER_CONVERT_TO_VIRTUAL: Defining Other Architecture Features. 8567 (line 306) 8568 * register_name: Register Information Functions. 8569 (line 10) 8570 * register_reggroup_p: Register Information Functions. 8571 (line 110) 8572 * register_type: Register Information Functions. 8573 (line 33) 8574 * regset_from_core_section: Defining Other Architecture Features. 8575 (line 316) 8576 * regular expressions library: Support Libraries. (line 110) 8577 * Release Branches: Versions and Branches. 8578 (line 93) 8579 * remote debugging support: Host Definition. (line 41) 8580 * REMOTE_BPT_VECTOR: Defining Other Architecture Features. 8581 (line 540) 8582 * representation of architecture: How an Architecture is Represented. 8583 (line 6) 8584 * representations, raw and cooked registers: Raw and Cooked Registers. 8585 (line 6) 8586 * representations, register and memory: Register and Memory Data. 8587 (line 6) 8588 * requirements for GDB: Requirements. (line 6) 8589 * restart: Algorithms. (line 600) 8590 * running the test suite: Testsuite. (line 19) 8591 * secondary symbol file: Symbol Handling. (line 47) 8592 * sentinel frame <1>: Frame Handling Terminology. 8593 (line 52) 8594 * sentinel frame: Stack Frames. (line 22) 8595 * SENTINEL_FRAME: Stack Frames. (line 22) 8596 * separate data and code address spaces: Pointers and Addresses. 8597 (line 6) 8598 * serial line support: Host Definition. (line 41) 8599 * set_gdbarch functions: Creating a New Architecture. 8600 (line 14) 8601 * set_gdbarch_bits_big_endian: Defining Other Architecture Features. 8602 (line 83) 8603 * set_gdbarch_sofun_address_maybe_missing: Defining Other Architecture Features. 8604 (line 330) 8605 * SIGWINCH_HANDLER: Host Definition. (line 78) 8606 * SIGWINCH_HANDLER_BODY: Host Definition. (line 82) 8607 * skip_prologue: Functions and Variable to Analyze Frames. 8608 (line 12) 8609 * SKIP_SOLIB_RESOLVER: Defining Other Architecture Features. 8610 (line 267) 8611 * SLASH_STRING: Misc Guidelines. (line 404) 8612 * sniffing: Frame Handling Terminology. 8613 (line 46) 8614 * software breakpoints: Algorithms. (line 184) 8615 * software watchpoints: Algorithms. (line 280) 8616 * SOFTWARE_SINGLE_STEP: Defining Other Architecture Features. 8617 (line 324) 8618 * SOFTWARE_SINGLE_STEP_P: Defining Other Architecture Features. 8619 (line 320) 8620 * SOLIB_ADD: Native Debugging. (line 86) 8621 * SOLIB_CREATE_INFERIOR_HOOK: Native Debugging. (line 92) 8622 * solib_loaded: GDB Observers. (line 99) 8623 * solib_unloaded: GDB Observers. (line 104) 8624 * SOM debugging info: Symbol Handling. (line 360) 8625 * SOM format: Symbol Handling. (line 291) 8626 * source code formatting: Coding Standards. (line 28) 8627 * sp_regnum: Register Architecture Functions & Variables. 8628 (line 49) 8629 * spaces, separate data and code address: Pointers and Addresses. 8630 (line 6) 8631 * stabs debugging info: Symbol Handling. (line 305) 8632 * stack frame, definition of base of a frame: Frame Handling Terminology. 8633 (line 28) 8634 * stack frame, definition of innermost frame: Frame Handling Terminology. 8635 (line 24) 8636 * stack frame, definition of NEXT frame: Frame Handling Terminology. 8637 (line 11) 8638 * stack frame, definition of PREVIOUS frame: Frame Handling Terminology. 8639 (line 14) 8640 * stack frame, definition of sentinel frame: Frame Handling Terminology. 8641 (line 52) 8642 * stack frame, definition of sniffing: Frame Handling Terminology. 8643 (line 46) 8644 * stack frame, definition of THIS frame: Frame Handling Terminology. 8645 (line 9) 8646 * stack frame, definition of unwinding: Frame Handling Terminology. 8647 (line 41) 8648 * stack pointer: Register Architecture Functions & Variables. 8649 (line 49) 8650 * START_INFERIOR_TRAPS_EXPECTED: Native Debugging. (line 96) 8651 * status register: Register Architecture Functions & Variables. 8652 (line 69) 8653 * STOPPED_BY_WATCHPOINT: Algorithms. (line 408) 8654 * store_typed_address: Pointers and Addresses. 8655 (line 70) 8656 * struct: GDB Observers. (line 62) 8657 * struct gdbarch creation: Creating a New Architecture. 8658 (line 6) 8659 * struct regcache: Register Caching. (line 10) 8660 * struct value, converting register contents to: Register and Memory Data. 8661 (line 6) 8662 * submitting patches: Debugging GDB. (line 30) 8663 * sym_fns structure: Symbol Handling. (line 37) 8664 * symbol files: Symbol Handling. (line 25) 8665 * symbol lookup: Symbol Handling. (line 133) 8666 * symbol reading: Symbol Handling. (line 25) 8667 * SYMBOL_RELOADING_DEFAULT: Defining Other Architecture Features. 8668 (line 454) 8669 * symtabs: Symbol Handling. (line 104) 8670 * system dependencies: Misc Guidelines. (line 354) 8671 * table output functions: User Interface. (line 131) 8672 * target: Overall Structure. (line 50) 8673 * target architecture definition: Target Architecture Definition. 8674 (line 6) 8675 * target dependent files: Adding a New Target. (line 8) 8676 * target descriptions: Target Descriptions. (line 6) 8677 * target descriptions, adding register support: Adding Target Described Register Support. 8678 (line 6) 8679 * target descriptions, implementation: Target Descriptions Implementation. 8680 (line 6) 8681 * target vector: Target Vector Definition. 8682 (line 6) 8683 * TARGET_CAN_USE_HARDWARE_WATCHPOINT: Algorithms. (line 333) 8684 * target_changed: GDB Observers. (line 82) 8685 * TARGET_CHAR_BIT: Defining Other Architecture Features. 8686 (line 458) 8687 * target_insert_breakpoint: Algorithms. (line 211) 8688 * target_insert_hw_breakpoint: Algorithms. (line 234) 8689 * target_insert_watchpoint: Algorithms. (line 347) 8690 * TARGET_REGION_OK_FOR_HW_WATCHPOINT: Algorithms. (line 343) 8691 * target_remove_breakpoint: Algorithms. (line 211) 8692 * target_remove_hw_breakpoint: Algorithms. (line 234) 8693 * target_remove_watchpoint: Algorithms. (line 347) 8694 * target_resumed: GDB Observers. (line 129) 8695 * target_stopped_data_address: Algorithms. (line 364) 8696 * target_watchpoint_addr_within_range: Algorithms. (line 378) 8697 * targets: Existing Targets. (line 6) 8698 * TCP remote support: Host Definition. (line 57) 8699 * terminal device: Host Definition. (line 97) 8700 * test suite: Testsuite. (line 6) 8701 * test suite organization: Testsuite. (line 195) 8702 * test_notification: GDB Observers. (line 189) 8703 * Testsuite Configuration: Testsuite. (line 167) 8704 * THIS frame: Frame Handling Terminology. 8705 (line 9) 8706 * thread_exit: GDB Observers. (line 117) 8707 * thread_ptid_changed: GDB Observers. (line 165) 8708 * thread_stop_requested: GDB Observers. (line 122) 8709 * tracepoint_created: GDB Observers. (line 148) 8710 * tracepoint_deleted: GDB Observers. (line 152) 8711 * tracepoint_modified: GDB Observers. (line 156) 8712 * tuple output functions: User Interface. (line 131) 8713 * type codes: Symbol Handling. (line 191) 8714 * types: Coding Standards. (line 121) 8715 * ui_out functions: User Interface. (line 47) 8716 * ui_out functions, usage examples: User Interface. (line 398) 8717 * ui_out_field_core_addr: User Interface. (line 287) 8718 * ui_out_field_fmt: User Interface. (line 261) 8719 * ui_out_field_fmt_int: User Interface. (line 280) 8720 * ui_out_field_int: User Interface. (line 273) 8721 * ui_out_field_skip: User Interface. (line 352) 8722 * ui_out_field_stream: User Interface. (line 320) 8723 * ui_out_field_string: User Interface. (line 291) 8724 * ui_out_flush: User Interface. (line 392) 8725 * ui_out_list_begin: User Interface. (line 234) 8726 * ui_out_list_end: User Interface. (line 240) 8727 * ui_out_message: User Interface. (line 376) 8728 * ui_out_spaces: User Interface. (line 371) 8729 * ui_out_stream_delete: User Interface. (line 315) 8730 * ui_out_stream_new: User Interface. (line 309) 8731 * ui_out_table_begin: User Interface. (line 165) 8732 * ui_out_table_body: User Interface. (line 191) 8733 * ui_out_table_end: User Interface. (line 194) 8734 * ui_out_table_header: User Interface. (line 178) 8735 * ui_out_text: User Interface. (line 358) 8736 * ui_out_tuple_begin: User Interface. (line 210) 8737 * ui_out_tuple_end: User Interface. (line 216) 8738 * ui_out_wrap_hint: User Interface. (line 382) 8739 * unwind frame: Stack Frames. (line 9) 8740 * unwind_dummy_id: Functions Creating Dummy Frames. 8741 (line 38) 8742 * unwind_pc: Functions to Access Frame Data. 8743 (line 11) 8744 * unwind_sp: Functions to Access Frame Data. 8745 (line 27) 8746 * unwinding: Frame Handling Terminology. 8747 (line 41) 8748 * using ui_out functions: User Interface. (line 398) 8749 * value structure: Values. (line 9) 8750 * value_as_address: Pointers and Addresses. 8751 (line 84) 8752 * value_from_pointer: Pointers and Addresses. 8753 (line 93) 8754 * values: Values. (line 9) 8755 * VEC: Support Libraries. (line 131) 8756 * vendor branches: Versions and Branches. 8757 (line 108) 8758 * void: GDB Observers. (line 67) 8759 * volatile: Host Definition. (line 122) 8760 * watchpoints: Algorithms. (line 274) 8761 * watchpoints, on x86: Algorithms. (line 449) 8762 * watchpoints, with threads: Algorithms. (line 425) 8763 * word-addressed machines: Pointers and Addresses. 8764 (line 6) 8765 * wrap_here: Misc Guidelines. (line 191) 8766 * write_pc: Register Architecture Functions & Variables. 8767 (line 13) 8768 * writing tests: Testsuite. (line 247) 8769 * x86 debug registers: Algorithms. (line 449) 8770 * XCOFF format: Symbol Handling. (line 256) 8771 8772 8773 8774 Tag Table: 8775 Node: Top1602 8776 Node: Summary2513 8777 Node: Requirements2663 8778 Node: Contributors4142 8779 Node: Overall Structure5735 8780 Node: Algorithms10758 8781 Node: User Interface42200 8782 Ref: UI-Independent Output44055 8783 Ref: User Interface-Footnote-166045 8784 Ref: User Interface-Footnote-266094 8785 Node: libgdb66329 8786 Node: Values70280 8787 Node: Stack Frames73124 8788 Node: Symbol Handling78106 8789 Node: Language Support94911 8790 Node: Host Definition99637 8791 Node: Target Architecture Definition103996 8792 Node: OS ABI Variant Handling104816 8793 Node: Initialize New Architecture109661 8794 Node: How an Architecture is Represented110012 8795 Node: Looking Up an Existing Architecture111969 8796 Node: Creating a New Architecture114888 8797 Node: Registers and Memory116926 8798 Node: Pointers and Addresses117718 8799 Ref: Pointers and Addresses-Footnote-1123719 8800 Node: Address Classes123962 8801 Node: Register Representation127207 8802 Node: Raw and Cooked Registers127581 8803 Node: Register Architecture Functions & Variables128765 8804 Node: Register Information Functions132374 8805 Ref: Register Information Functions-Footnote-1138280 8806 Node: Register and Memory Data138699 8807 Node: Register Caching141848 8808 Node: Frame Interpretation143384 8809 Node: All About Stack Frames143790 8810 Ref: All About Stack Frames-Footnote-1149082 8811 Node: Frame Handling Terminology149314 8812 Node: Prologue Caches151841 8813 Node: Functions and Variable to Analyze Frames153522 8814 Ref: frame_align155620 8815 Node: Functions to Access Frame Data157134 8816 Node: Analyzing Stacks---Frame Sniffers159425 8817 Ref: Analyzing Stacks---Frame Sniffers-Footnote-1164075 8818 Node: Inferior Call Setup164572 8819 Node: About Dummy Frames164855 8820 Node: Functions Creating Dummy Frames165481 8821 Node: Adding support for debugging core files169538 8822 Node: Defining Other Architecture Features170082 8823 Ref: gdbarch_breakpoint_from_pc174929 8824 Ref: gdbarch_stabs_argument_has_addr187323 8825 Ref: gdbarch_push_dummy_call187570 8826 Ref: gdbarch_push_dummy_code188130 8827 Ref: gdbarch_return_value189112 8828 Ref: gdbarch_dummy_id194878 8829 Node: Adding a New Target195566 8830 Node: Target Descriptions198033 8831 Node: Target Descriptions Implementation198972 8832 Node: Adding Target Described Register Support200346 8833 Node: Target Vector Definition203292 8834 Node: Managing Execution State203824 8835 Node: Existing Targets205637 8836 Node: Native Debugging208152 8837 Node: Support Libraries211980 8838 Node: Coding Standards223505 8839 Node: Misc Guidelines231385 8840 Node: Porting GDB249748 8841 Node: Versions and Branches251626 8842 Ref: Tags257582 8843 Ref: experimental branch tags257913 8844 Node: Start of New Year Procedure258645 8845 Node: Releasing GDB260451 8846 Node: Testsuite278683 8847 Ref: Testsuite-Footnote-1290548 8848 Node: Hints290666 8849 Node: Getting Started290988 8850 Node: Debugging GDB295153 8851 Node: GDB Observers300242 8852 Node: GNU Free Documentation License308550 8853 Node: Index333717 8854 8855 End Tag Table 8856