From 612dbd4c05a4b067b654c2c145e395c90bca6a11 Mon Sep 17 00:00:00 2001 From: John Gilmore Date: Sun, 16 Aug 1992 08:20:01 +0000 Subject: [PATCH] * stabs.texinfo: Minor updates from running TeX over it. * Makefile.in (stabs.dvi, stabs.ps): Add. --- gdb/doc/ChangeLog | 5 ++ gdb/doc/Makefile.in | 13 ++++- gdb/doc/stabs.texinfo | 116 ++++++++++++++++++++++++++---------------- 3 files changed, 88 insertions(+), 46 deletions(-) diff --git a/gdb/doc/ChangeLog b/gdb/doc/ChangeLog index ed6459ec38e..63ba806f9ea 100644 --- a/gdb/doc/ChangeLog +++ b/gdb/doc/ChangeLog @@ -1,3 +1,8 @@ +Sun Aug 16 01:16:18 1992 John Gilmore (gnu@cygnus.com) + + * stabs.texinfo: Minor updates from running TeX over it. + * Makefile.in (stabs.dvi, stabs.ps): Add. + Sat Aug 15 20:52:24 1992 Per Bothner (bothner@rtl.cygnus.com) * stabs.texinfo: Stabs documentation, written by Julia Menapace. diff --git a/gdb/doc/Makefile.in b/gdb/doc/Makefile.in index 0f4bdd89a16..07906277d3d 100644 --- a/gdb/doc/Makefile.in +++ b/gdb/doc/Makefile.in @@ -85,7 +85,7 @@ CONFIG=all all install: -info: gdb.info gdbint.info +info: gdb.info gdbint.info stabs.info all-doc: gdb.info gdb.dvi refcard.dvi gdb-internals gdbint.dvi clean-info: -rm -f *.info* @@ -297,6 +297,17 @@ gdbint.info: gdbint.texinfo stabs.info: stabs.texinfo $(MAKEINFO) -o stabs.info $(srcdir)/stabs.texinfo +# STABS DOCUMENTATION: TeX dvi file +stabs.dvi : stabs.texinfo + TEXINPUTS=${TEXIDIR}:.:$(srcdir):$$TEXINPUTS tex stabs.texinfo + texindex stabs.?? + TEXINPUTS=${TEXIDIR}:.:$(srcdir):$$TEXINPUTS tex stabs.texinfo + rm -f stabs.?? stabs.aux stabs.cps stabs.fns stabs.kys \ + stabs.log stabs.pgs stabs.toc stabs.tps stabs.vrs + +stabs.ps: stabs.dvi + dvips -o stabs.ps stabs + force: Makefile: $(srcdir)/Makefile.in $(host_makefile_frag) $(target_makefile_frag) diff --git a/gdb/doc/stabs.texinfo b/gdb/doc/stabs.texinfo index c71f7bb7a60..b31c1b417e4 100644 --- a/gdb/doc/stabs.texinfo +++ b/gdb/doc/stabs.texinfo @@ -4,15 +4,15 @@ @ifinfo @format START-INFO-DIR-ENTRY -* Stabs. The "stabs" representation of debugging infromation. +* Stabs: (stabs). The "stabs" debugging information format. END-INFO-DIR-ENTRY @end format @end ifinfo @ifinfo -This document describes GNU stabs in a.out +This document describes GNU stabs (debugging symbol tables) in a.out files. -Copyright (C) 1992 by ???. +Copyright 1992 Free Software Foundation, Inc. Contributed by Cygnus Support. Written by Julia Menapace. Permission is granted to make and distribute verbatim copies of @@ -34,7 +34,7 @@ regarded as a program in the language TeX). @setchapternewpage off @settitle STABS @titlepage -@title{The "stabs" representation of debugging infromation.} +@title{The "stabs" representation of debugging information.} @author Julia Menapace @author Cygnus Support @page @@ -59,26 +59,28 @@ are preserved on all copies. @node Top, Overview, (dir), (dir) -This document describes GNU stabs in a.out +This document describes the GNU stabs debugging format in a.out files. @menu -* Overview:: Overview of stabs -* Program structure:: Encoding of the structure of the program +* Overview:: Overview of stabs +* Program structure:: Encoding of the structure of the program * Simple types:: -* Example:: A comprehensive example in C +* Example:: A comprehensive example in C * Variables:: * Aggregate types:: -* Symbol tables:: Symbol information in symbol tables +* Symbol tables:: Symbol information in symbol tables * GNU C++ stabs:: Appendixes: -* Example2.c:: source code for extended example -* Example2.s:: assembly code for extended example -* Quick reference:: Various refernce tables -* Expanded reference:: by stab type -* Questions:: Questions and anomolies -* xcoff-differences:: Differences between GNU stabs in a.out and GNU stabs in xcoff -* Sun-differences:: Differences between GNU stabs and Sun native stabs +* Example2.c:: Source code for extended example +* Example2.s:: Assembly code for extended example +* Quick reference:: Various refernce tables +* Expanded reference:: Reference information by stab type +* Questions:: Questions and anomolies +* xcoff-differences:: Differences between GNU stabs in a.out + and GNU stabs in xcoff +* Sun-differences:: Differences between GNU stabs and Sun + native stabs @end menu @@ -576,7 +578,9 @@ body of main. @end example Second code range for source line 23, 'for' loop increment and return + <68> N_SLINE - source line number associated with this code + .stabn, SLINE, NIL, line_number, code_address_of_line_continuation. @example @@ -883,7 +887,7 @@ for argv contains nested type_definitions. Type 21 is ptr to type 2 @node Aggregate Types, Symbol tables, Variables, Top @chapter Aggregate Types -Now lets look at some variable definitions involving complex types. +Now let's look at some variable definitions involving complex types. This involves understanding better how types are described. In the examples so far types have been described as references to previously defined types or defined in terms of subranges of or pointers to @@ -1015,6 +1019,7 @@ offset from the start of the struct, and number of bits in the element. +@example <128> N_LSYM - type definition .stabs "name:sym_desc(struct tag) Type_def(16)=type_desc(struct type) struct_bytes @@ -1026,6 +1031,7 @@ element. 30 .stabs "s_tag:T16=s20s_int:1,0,32;s_float:12,32,32; s_char_vec:17=ar1;0;7;2,64,64;s_next:18=*16,128,32;;",128,0,0,0 +@end example In this example, two of the structure elements are previously defined types. For these, the type following the name: part of the element @@ -1073,7 +1079,7 @@ debugging information. .stabs, stab type N_LSYM, symbol descriptor T, type descriptor u -Next lets look at unions. In example2 this union type is declared +Next let's look at unions. In example2 this union type is declared locally to a procedure and an instance of the union is defined. @example @@ -1251,8 +1257,8 @@ entry now holds an absolute address. 215 0000e008 D _g_foo -@node Gnu C++ stabs, , Symbol tables, Top -@chapter Gnu C++ stabs +@node GNU C++ stabs, , Symbol tables, Top +@chapter GNU C++ stabs @menu * Basic C++ types:: @@ -1283,7 +1289,7 @@ cross-reference @end table -@node Basic C++ types, , , Gnu C++ stabs +@node Basic C++ types, , , GNU C++ stabs @section Basic types for C++ << the examples that follow are based on a01.C >> @@ -1319,7 +1325,7 @@ virtual methods defined. .stabs "$vtbl_ptr_type:T17",128,0,0,0 -@node Simple classes, , , Gnu C++ stabs +@node Simple classes, , , GNU C++ stabs @section Simple class definition The stabs describing C++ language features are an extension of the @@ -1377,7 +1383,8 @@ semi-colon. The format of an overloaded operator method name differs from that of other methods. It is "op$::XXXX." where XXXX is the operator name -such as + or += +such as + or +=. The name ends with a period, and any characters except +the period can occur in the XXXX string. The next part of the method description represents the arguments to the method, preceeded by a colon and ending with a semi-colon. The @@ -1395,6 +1402,7 @@ elaborate further on these fields and describe the additional information present for virtual methods. +@example .stabs "class_name:sym_desc(type)type_def(20)=type_desc(struct)struct_bytes(4) field_name(Adat):type(int),bit_offset(0),field_bits(32); @@ -1408,8 +1416,9 @@ information present for virtual methods. .stabs "class_name:sym_desc(struct tag)",N_LSYM,NIL,NIL,NIL .stabs "baseA:T20",128,0,0,0 +@end example -@node Class instance, , , Gnu C++ stabs +@node Class instance, , , GNU C++ stabs @section Class instance As shown above, describing even a simple C++ class definition is @@ -1431,7 +1440,7 @@ different from a standard C stab describing a local variable. .stabs "AbaseA:20",128,0,0,-20 -@node Methods, , , Gnu C++ stabs +@node Methods, , , GNU C++ stabs @section Method defintion The class definition shown above declares Ameth. The C++ source below @@ -1455,10 +1464,12 @@ called. Note that the method name is mangled to encode the class name and argument types. << Name mangling is not described by this document - Is there already such a doc? >> +@example .stabs "name:symbol_desriptor(global function)return_type(int)", N_FUN, NIL, NIL, code_addr_of_method_start .stabs "Ameth__5baseAic:F1",36,0,0,_Ameth__5baseAic +@end example Here is the stab for the `this' pointer implicit argument. The name of the `this' pointer is always $t. Type 19, the `this' pointer is @@ -1467,25 +1478,29 @@ not yet been emited. Since the compiler knows it will be emited shortly, here it just outputs a cross reference to the undefined symbol, by prefixing the symbol name with xs. +@example .stabs "name:sym_desc(register param)type_def(19)= type_desc(ptr to)type_ref(baseA)= type_desc(cross-reference to)baseA:",N_RSYM,NIL,NIL,register_number .stabs "$t:P19=*20=xsbaseA:",64,0,0,8 +@end example The stab for the explicit integer argument looks just like a parameter to a C function. The last field of the stab is the offset from the argument pointer, which in most systems is the same as the frame pointer. +@example .stabs "name:sym_desc(value parameter)type_ref(int)", N_PSYM,NIL,NIL,offset_from_arg_ptr .stabs "in:p1",160,0,0,72 +@end example << The examples that follow are based on A1.C >> -@node Protections, , , Gnu C++ stabs +@node Protections, , , GNU C++ stabs @section Protections @@ -1513,6 +1528,7 @@ public: generates the following stab to describe the class type all_data. +@example .stabs "class_name:sym_desc(type)type_def(19)=type_desc(struct)struct_bytes data_name:/protection(private)type_ref(int),bit_offset,num_bits; data_name:/protection(protected)type_ref(char),bit_offset,num_bits; @@ -1521,6 +1537,7 @@ generates the following stab to describe the class type all_data. .stabs "all_data:t19=s12 priv_dat:/01,0,32;prot_dat:/12,32,8;pub_dat:12,64,32;;",128,0,0,0 +@end example Protections for member functions are signified by one digit embeded in the field part of the stab describing the method. The digit is 0 if @@ -1542,6 +1559,7 @@ It generates the following stab. The digit in question is to the left of an `A' in each case. Notice also that in this case two symbol descriptors apply to the class name struct tag and struct type. +@example .stabs "class_name:sym_desc(struct tag&type)type_def(21)= sym_desc(struct)struct_bytes(1) meth_name::type_def(22)=sym_desc(method)returning(int); @@ -1554,9 +1572,9 @@ descriptors apply to the class name struct tag and struct type. .stabs "all_methods:Tt21=s1priv_meth::22=##1;:i;0A.;protMeth::23=##2;:c;1A.; pubMeth::24=##12;:f;2A.;;",128,0,0,0 +@end example - -@node Method Modifiers, , , Gnu C++ stabs +@node Method Modifiers, , , GNU C++ stabs Method Modifiers (const, volatile, const volatile) << based on a6.C >> @@ -1579,6 +1597,7 @@ public: This class is described by the following stab: +@example .stabs "class(A):sym_desc(struct)type_def(20)=type_desc(struct)struct_bytes(1) meth_name(ConstMeth)::type_def(21)sym_desc(method) returning(int);:arg(int);protection(public)modifier(const)virtual(no); @@ -1586,14 +1605,14 @@ This class is described by the following stab: returning(char);:arg(char);protection(public)modifier(volatile)virt(no) meth_name(ConstVolMeth)::type_def(23)=sym_desc(method) returning(float);:arg(float);protection(public)modifer(const volatile) - virutal(no);;", etc... + virtual(no);;", etc... .stabs "A:T20=s1ConstMeth::21=##1;:i;2B.;VolatileMeth::22=##2;:c;2C.; ConstVolMeth::23=##12;:f;2D.;;",128,0,0,0 +@end example - -@node Virtual Methods, , , Gnu C++ stabs +@node Virtual Methods, , , GNU C++ stabs @section Virtual Methods << The following examples are based on a4.C >> @@ -1661,6 +1680,7 @@ For classes containing virtual functions the very last section of the string part of the stab holds a type reference to the first base class. This is preceeded by `~%' and followed by a final semi-colon. +@example .stabs "class_name(A):type_def(20)=sym_desc(struct)struct_bytes(8) field_name(Adat):type_ref(int),bit_offset(0),field_bits(32); field_name(A virt func ptr):type_def(21)=type_desc(ptr to)type_def(22)= @@ -1672,9 +1692,10 @@ class. This is preceeded by `~%' and followed by a final semi-colon. N_LSYM,NIL,NIL,NIL .stabs "A:t20=s8Adat:1,0,32;$vf20:21=*22=ar1;0;1;17,32;A_virt::23=##1;:i;2A*-2147483647;20;;;~%20;",128,0,0,0 +@end example -@node Inheritence, , , Gnu C++ stabs +@node Inheritence, , , GNU C++ stabs @section Inheritence Stabs describing C++ derived classes include additional sections that @@ -1737,15 +1758,18 @@ public: Class stabs similar to the ones described earlier are generated for each base class. +@example .stabs "A:T20=s8Adat:1,0,32;$vf20:21=*22=ar1;0;1;17,32;A_virt::23=##1;:i;2A*-2147483647;20;;;~%20;",128,0,0,0 .stabs "B:Tt25=s8Bdat:1,0,32;$vf25:21,32;B_virt::26=##1;:i;2A*-2147483647;25;;;~%25;",128,0,0,0 .stabs "C:Tt28=s8Cdat:1,0,32;$vf28:21,32;C_virt::29=##1;:i;2A*-2147483647;28;;;~%28;",128,0,0,0 +@end example In the stab describing derived class D below, the information about the derivation of this class is encoded as follows. +@example .stabs "derived_class_name:symbol_descriptors(struct tag&type)= type_descriptor(struct)struct_bytes(32)!num_bases(3), base_virtual(no)inheritence_public(no)base_offset(0), @@ -1756,9 +1780,9 @@ the derivation of this class is encoded as follows. base_class_type_ref(C); etc... .stabs "D:Tt31=s32!3,000,20;100,25;0264,28;$vb25:24,128;Ddat:1,160,32;A_virt::32=##1;:i;2A*-2147483647;20;;B_virt::32:i;2A*-2147483647;25;;C_virt::32:i;2A*-2147483647;28;;D_virt::32:i;2A*-2147483646;31;;;~%20;",128,0,0,0 +@end example - -@node Virtual Base Classes, , , Gnu C++ stabs +@node Virtual Base Classes, , , GNU C++ stabs @section Virtual Base Classes A derived class object consists of a concatination in memory of the @@ -1781,7 +1805,9 @@ name is $vb followed by a type reference to the virtual base class. Since the type id for B in this example is 25, the vbase pointer name is $vb25. +@example .stabs "D:Tt31=s32!3,000,20;100,25;0264,28;$vb25:24,128;Ddat:1,160,32;A_virt::32=##1;:i;2A*-2147483647;20;;B_virt::32:i;2A*-2147483647;25;;C_virt::32:i;2A*-2147483647;28;;D_virt::32:i;2A*-2147483646;31;;;~%20;",128,0,0,0 +@end example Following the name and a semicolon is a type reference describing the type of the virtual base class pointer, in this case 24. Type 24 was @@ -1798,7 +1824,7 @@ at 64, the vtable pointer for C at 96, the virtual ase pointer for B at 128, and Ddat at 160. -@node Static Members, , , Gnu C++ stabs +@node Static Members, , , GNU C++ stabs @section Static Members The data area for a class is a concatination of the space used by the @@ -2042,12 +2068,12 @@ dec hex name source program feature 72 0x48 N_BSLINE line number in bss segment 72 0x48 N_BROWS Sun source code browser, path to .cb file -74 0x4a N_DEFD Gnu Modula2 definition module dependency +74 0x4a N_DEFD GNU Modula2 definition module dependency -80 0x50 N_EHDECL Gnu C++ exception variable +80 0x50 N_EHDECL GNU C++ exception variable 80 0x50 N_MOD2 Modula2 info "for imc" (according to Ultrix V4.0) -84 0x54 N_CATCH Gnu C++ "catch" clause +84 0x54 N_CATCH GNU C++ "catch" clause 96 0x60 N_SSYM structure of union element 100 0x64 N_SO path and name of source file 128 0x80 N_LSYM automatic var in the stack (also used for type desc.) @@ -2316,7 +2342,7 @@ Note: type field value overlaps with N_BSLINE ------------------------------------------------------------------------- 74 0x4a N_DEFD -Gnu Modula2 definition module dependency +GNU Modula2 definition module dependency GNU Modula-2 definition module dependency. Value is the modification time of the definition file. Other is non-zero if it is imported with @@ -2325,7 +2351,7 @@ are enough empty fields? ------------------------------------------------------------------------- 80 0x50 N_EHDECL -Gnu C++ exception variable <> +GNU C++ exception variable <> "name is variable name" @@ -2337,7 +2363,7 @@ Note: conflicts with N_MOD2. Note: conflicts with N_EHDECL <> ------------------------------------------------------------------------- -84 0x54 N_CATCH Gnu C++ "catch" clause +84 0x54 N_CATCH GNU C++ "catch" clause GNU C++ `catch' clause. Value is its address. Desc is nonzero if this entry is immediately followed by a CAUGHT stab saying what @@ -2542,7 +2568,7 @@ var can be a variable defined in the program and gdb says `function var not defined' @item -In Gnu C stabs there seems to be no way to differentiate tag types: +In GNU C stabs there seems to be no way to differentiate tag types: structures, unions, and enums (symbol descriptor T) and typedefs (symbol descriptor t) defined at file scope from types defined locally to a procedure or other more local scope. They all use the N_LSYM @@ -2703,11 +2729,11 @@ N_LENG unknown @itemize @bullet @item -Gnu C stabs define *all* types, file or procedure scope, as +GNU C stabs define *all* types, file or procedure scope, as N_LSYM. Sun doc talks about using N_GSYM too. @item -Gnu C stabs use `ar' as type descriptor when defining arrays vs. just +GNU C stabs use `ar' as type descriptor when defining arrays vs. just `a' in Sun doc. @item @@ -2719,7 +2745,7 @@ GNU stabs always have 0 in that field. Sun C stabs use type number pairs in the format (a,b) where a is a number starting with 1 and incremented for each sub-source file in the compilation. b is a number starting with 1 and incremented for each -new type defined in the compilation. Gnu C stabs use the type number +new type defined in the compilation. GNU C stabs use the type number alone, with no source file number. @end itemize -- 2.30.2