diff options
Diffstat (limited to 'gdb')
-rw-r--r-- | gdb/ChangeLog | 41 | ||||
-rw-r--r-- | gdb/dbxread.c | 100 | ||||
-rw-r--r-- | gdb/mipsread.c | 296 | ||||
-rw-r--r-- | gdb/putenv.c | 8 |
4 files changed, 290 insertions, 155 deletions
diff --git a/gdb/ChangeLog b/gdb/ChangeLog index bc5cfb1..fa9c923 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,15 +1,36 @@ -Mon Jan 27 15:46:21 1992 Stu Grossman (grossman at cygnus.com) +Mon Jan 27 18:51:03 1992 John Gilmore (gnu at cygnus.com) - * dbxread.c (process_one_symbol): Make a first cut at handling - symbol tables generated by Suns acc. + Handle debug symbols in dynamically loaded (relocated) code: - * symtab.c (find_pc_line): Fix stepping into and out of #included - files. + * dbxread.c (read_ofile_symtab): Fix up N_CATCH better. Pass + offset to process_one_symbol. + (process_one_symbol): Take new offset parameter. Add it into + appropriate symbol types to relocate symbols to loaded addresses. + Handle all possible symbol types, and complain() about types that + we don't expect to see. + * mipsread.c (psymtab_to_symtab_1): Pass offset of zero to + process_one_symbol (FIXME, should pass real offset). -Mon Jan 27 13:43:26 1992 John Gilmore (gnu at cygnus.com) + Misc bugfixes: + + * breakpoint.c (resolve_sal_pc): Split out code to resolve a + sal's PC value. + (set_breakpoint, break_command_1, until_break_command, + catch_command_1, breakpoint_re_set_one): Use it. + (breakpoint_re_set_one): Disable bkpts that don't re-set cleanly. + (breakpoint_re_set): Mention breakpoint number in error messages. + * symtab.h (resolve_sal_pc): Declare. + * infcmd.c (jump_command): Use resolve_sal_pc. + + * source.c (find_source_lines): Avoid "Source file is more + recent than executable" when bfd_get_mtime gives 0. + (list_command): Shorten "FILE, line N" to "FILE:N". + + * putenv.c (putenv): Avoid unportably casting pointers to unsigneds. * buildsym.c (read_struct_type): Circumvent sun3 sunos "--" compiler bug. + * c-exp.y (yylex): `this' and `template' are only tokens in C++. * target.c (target_xfer_memory): Return errno in preference to EIO. @@ -18,6 +39,14 @@ Mon Jan 27 13:43:26 1992 John Gilmore (gnu at cygnus.com) xm-np1.h, xm-pn.h, xm-pyr.h, xm-rtbsd.h, xm-symmetry.h, xm-umax.h: Remove MISSING_VPRINTF declaration, and superfluous "kgdb" defines. +Mon Jan 27 15:46:21 1992 Stu Grossman (grossman at cygnus.com) + + * dbxread.c (process_one_symbol): Make a first cut at handling + symbol tables generated by Sun's acc. (#ifdef'd out, FIXME.) + + * symtab.c (find_pc_line): Fix stepping into and out of #included + files. + Mon Jan 27 13:00:55 1992 Stu Grossman (grossman at cygnus.com) * Makefile.in (OPCODES): Remove OPCODES defs and refs. There is diff --git a/gdb/dbxread.c b/gdb/dbxread.c index d2992ba..cc89708 100644 --- a/gdb/dbxread.c +++ b/gdb/dbxread.c @@ -1,5 +1,5 @@ /* Read dbx symbol tables and convert to internal format, for GDB. - Copyright (C) 1986-1991 Free Software Foundation, Inc. + Copyright 1986, 1987, 1988, 1989, 1990, 1991 Free Software Foundation, Inc. This file is part of GDB. @@ -1251,21 +1251,15 @@ read_ofile_symtab (objfile, stringtab, stringtab_size, sym_offset, { /* N_CATCH is not fixed up by the linker, and unfortunately, there's no other place to put it in the .stab map. */ - bufp->n_value += text_offset + offset; + bufp->n_value += text_offset - offset; } - else { - type &= ~N_EXT; /* Ignore external-bit */ - if (type == N_TEXT || type == N_DATA || type == N_BSS) - bufp->n_value += offset; - type = bufp->n_type; - } SET_NAMESTRING (); if (type & N_STAB) { - process_one_symbol (type, bufp->n_desc, bufp->n_value, namestring); - /* our_objfile is an implicit parameter. */ - + process_one_symbol (type, bufp->n_desc, bufp->n_value, + namestring, offset); + /* our_objfile is an implicit parameter. */ } /* We skip checking for a new .o or -l file; that should never happen in this routine. */ @@ -1319,13 +1313,28 @@ hashname (name) if (total < 0) total += (1000 << 6); return total % HASHSIZE; } - +/* This handles a single symbol from the symbol-file, building symbols + into a GDB symtab. It takes these arguments and an implicit argument. + + TYPE is the type field of the ".stab" symbol entry. + DESC is the desc field of the ".stab" entry. + VALU is the value field of the ".stab" entry. + NAME is the symbol name, in our address space. + OFFSET is the amount by which this object file was relocated + when it was loaded into memory. All symbols that refer + to memory locations need to be offset by this amount. + + The implicit argument is: + OUR_OBJFILE is the object file from which we are reading symbols. + It is used in end_symtab. */ + void -process_one_symbol (type, desc, valu, name) +process_one_symbol (type, desc, valu, name, offset) int type, desc; CORE_ADDR valu; char *name; + int offset; { #ifndef SUN_FIXED_LBRAC_BUG /* This records the last pc address we've seen. We depend on there being @@ -1364,6 +1373,8 @@ process_one_symbol (type, desc, valu, name) case N_STSYM: #endif /* 0 */ + valu += offset; /* Relocate for dynamic loading */ + /* Either of these types of symbols indicates the start of a new function. We must process its "name" normally for dbx, but also record the start of a new lexical context, and possibly @@ -1401,19 +1412,16 @@ process_one_symbol (type, desc, valu, name) case N_CATCH: /* Record the address at which this catch takes place. */ - define_symbol (valu, name, desc, type); - break; - - case N_EHDECL: - /* Don't know what to do with these yet. */ - error ("action uncertain for eh extensions"); + define_symbol (valu+offset, name, desc, type); break; case N_LBRAC: /* This "symbol" just indicates the start of an inner lexical context within a function. */ -#if !defined (BLOCK_ADDRESS_ABSOLUTE) +#if defined (BLOCK_ADDRESS_ABSOLUTE) + valu += offset; /* Relocate for dynamic loading */ +#else /* On most machines, the block addresses are relative to the N_SO, the linker did not relocate them (sigh). */ valu += last_source_start_addr; @@ -1433,7 +1441,9 @@ process_one_symbol (type, desc, valu, name) /* This "symbol" just indicates the end of an inner lexical context that was started with N_LBRAC. */ -#if !defined (BLOCK_ADDRESS_ABSOLUTE) +#if defined (BLOCK_ADDRESS_ABSOLUTE) + valu += offset; /* Relocate for dynamic loading */ +#else /* On most machines, the block addresses are relative to the N_SO, the linker did not relocate them (sigh). */ valu += last_source_start_addr; @@ -1492,6 +1502,7 @@ process_one_symbol (type, desc, valu, name) case N_FN: case N_FN_SEQ: /* This kind of symbol indicates the start of an object file. */ + valu += offset; /* Relocate for dynamic loading */ break; case N_SO: @@ -1499,6 +1510,8 @@ process_one_symbol (type, desc, valu, name) for one source file. Finish the symbol table of the previous source file (if any) and start accumulating a new symbol table. */ + valu += offset; /* Relocate for dynamic loading */ + #ifndef SUN_FIXED_LBRAC_BUG last_pc_address = valu; /* Save for SunOS bug circumcision */ #endif @@ -1531,11 +1544,13 @@ process_one_symbol (type, desc, valu, name) start_symtab (name, NULL, valu); break; + case N_SOL: /* This type of symbol indicates the start of data for a sub-source-file, one whose contents were copied or included in the compilation of the main source file (whose name was given in the N_SO symbol.) */ + valu += offset; /* Relocate for dynamic loading */ start_subfile (name, NULL); break; @@ -1557,6 +1572,7 @@ process_one_symbol (type, desc, valu, name) /* This type of "symbol" really just records one line-number -- core-address correspondence. Enter it in the line list for this symbol table. */ + valu += offset; /* Relocate for dynamic loading */ #ifndef SUN_FIXED_LBRAC_BUG last_pc_address = valu; /* Save for SunOS bug circumcision */ #endif @@ -1593,12 +1609,48 @@ process_one_symbol (type, desc, valu, name) break; } - case N_ECOML: - case N_LENG: - case N_DEFD: /* GNU Modula-2 symbol */ + /* The following symbol types need to have the offset added to their + value; then we process symbol definitions in the name. */ + case N_STSYM: /* Global symbol */ + case N_LCSYM: /* Local symbol */ + case N_DSLINE: /* Source line number, data seg */ + case N_BSLINE: /* Source line number, bss seg */ + /* N_BROWS: overlaps with N_BSLINE */ + case N_ENTRY: /* Alternate entry point */ + valu += offset; /* Relocate for dynamic loading */ + /* FALL THROUGH */ + + /* The following symbol types don't need the address field relocated, + since it is either unused, or is absolute. */ + case N_GSYM: /* Global variable */ + case N_NSYMS: /* Number of symbols (ultrix) */ + case N_NOMAP: /* No map? (ultrix) */ + case N_RSYM: /* Register variable */ + case N_DEFD: /* Modula-2 GNU module dependency */ + case N_SSYM: /* Struct or union element */ + case N_LSYM: /* Local symbol in stack */ + case N_PSYM: /* Parameter variable */ + case N_LENG: /* Length of preceding symbol type */ + if (name) + define_symbol (valu, name, desc, type); break; + /* The following symbol types we don't know how to process. Handle + them in a "default" way, but complain to people who care. */ default: + case N_EHDECL: /* Exception handler name */ + case N_MAIN: /* Name of main routine (not used in C) */ + case N_PC: /* Global symbol in Pascal */ + case N_M2C: /* Modula-2 compilation unit */ + /* N_MOD2: overlaps with N_EHDECL */ + case N_SCOPE: /* Modula-2 scope information */ + case N_ECOML: /* End common (local name) */ + case N_NBTEXT: /* Gould Non-Base-Register symbols??? */ + case N_NBDATA: + case N_NBBSS: + case N_NBSTS: + case N_NBLCS: + complain (&unknown_symtype_complaint, local_hex_string(type)); if (name) define_symbol (valu, name, desc, type); } diff --git a/gdb/mipsread.c b/gdb/mipsread.c index b98c9cb..4bd8786 100644 --- a/gdb/mipsread.c +++ b/gdb/mipsread.c @@ -60,12 +60,15 @@ struct coff_exec { struct external_aouthdr a; }; -/* These must match the corresponding definition in mips-tfile.c. */ +/* These must match the corresponding definition in mips-tfile.c. + At some point, these should probably go into an include file, + but currently gcc does use/need the ../include directory. */ #define CODE_MASK 0x8F300 #define MIPS_IS_STAB(sym) (((sym)->index & 0xFFF00) == CODE_MASK) #define MIPS_MARK_STAB(code) ((code)+CODE_MASK) #define MIPS_UNMARK_STAB(code) ((code)-CODE_MASK) +#define STABS_SYMBOL "@stabs" /* Each partial symbol table entry contains a pointer to private data for the read_symtab() function to use when expanding a partial symbol table entry @@ -115,6 +118,9 @@ struct complaint array_bitsize_complaint = struct complaint array_parse_complaint = {"array type with strange relative symbol", 0, 0}; +struct complaint bad_tag_guess_complaint = + {"guessed tag type incorrectly", 0, 0}; + /* Macros and extra defs */ /* Already-parsed symbols are marked specially */ @@ -166,7 +172,7 @@ static int n_undef_symbols, n_undef_labels, n_undef_vars, n_undef_procs; /* Pseudo symbol to use when putting stabs into the symbol table. */ -static char stabs_symbol[] = "@stabs"; +static char stabs_symbol[] = STABS_SYMBOL; /* Extra builtin types */ @@ -204,6 +210,8 @@ static void add_block(); static void add_symbol(); static int add_line(); static struct linetable *shrink_linetable(); +static char* mips_next_symbol_text (); + /* Things we export to other modules */ @@ -302,6 +310,8 @@ mipscoff_psymtab_to_symtab(pst) /* Restore the header and list of pending typedefs */ cur_hdr = CUR_HDR(pst); + next_symbol_text_func = mips_next_symbol_text; + psymtab_to_symtab_1(pst, pst->filename); /* Match with global symbols. This only needs to be done once, @@ -928,11 +938,37 @@ data: /* Common code for symbols describing data */ sh->value = (long) SYMBOL_TYPE(s); break; + +#ifndef btVoid /* btVoid was added late. */ +#define btVoid 26 +#endif +/* These new symbol types have been recently added to SGI machines. */ +#ifndef stStruct +#define stStruct 26 +#endif +#ifndef stUnion +#define stUnion 27 +#endif +#ifndef stEnum +#define stEnum 28 +#endif + case stStruct: + case stUnion: + case stEnum: + case stBlock: /* Either a lexical block, or some type */ push_parse_stack(); top_stack->blocktype = stBlock; if (sh->sc == scInfo) { /* structure/union/enum def */ - int type_code = TYPE_CODE_UNDEF; + int type_code = + sh->st == stStruct ? TYPE_CODE_STRUCT + : sh->st == stUnion ? TYPE_CODE_UNION + : sh->st == stEnum ? TYPE_CODE_ENUM + : TYPE_CODE_UNDEF; + int nfields = 0; + SYMR *tsym; + long max_value = 0; + struct field *f; s = new_symbol(sh->iss); SYMBOL_NAMESPACE(s) = STRUCT_NAMESPACE; @@ -940,74 +976,101 @@ data: /* Common code for symbols describing data */ SYMBOL_VALUE(s) = 0; add_symbol(s, top_stack->cur_block); /* If this type was expected, use its partial definition */ - if (pend) { + if (pend) t = is_pending_symbol(cur_fdr, sh)->t; - } else { - int nfields = 0; - SYMR *tsym; - long max_value = 0; - struct field *f; - - /* First count the number of fields. */ - for (tsym = sh+1; tsym->st != stEnd; tsym++) - if (tsym->st == stMember) { - if (nfields == 0) - if (tsym->index == indexNil - || ax[tsym->index].ti.bt==26)/*btVoid*/ - type_code = TYPE_CODE_ENUM; - nfields++; - if (tsym->value > max_value) - max_value = tsym->value; - } - else if (tsym->st == stBlock - || tsym->st == stParsed) { - if (tsym->sc == scVariant) ; /*UNIMPLEMENTED*/ - if (tsym->index != 0) - tsym = ((SYMR*)cur_fdr->isymBase) - + tsym->index-1; - } - + else t = new_type(sh->iss); - /* Guess the type code. */ - if (type_code == TYPE_CODE_UNDEF) - if (max_value == 0) type_code = TYPE_CODE_UNION; - else type_code = TYPE_CODE_STRUCT; - - TYPE_CODE(t) = type_code; - TYPE_NFIELDS(t) = nfields; - TYPE_FIELDS(t) = f = (struct field*) - obstack_alloc (symbol_obstack, - nfields * sizeof (struct field)); - - if (type_code == TYPE_CODE_ENUM) { - /* This is a non-empty enum. */ - while (sh[1].st == stMember) { - struct symbol *enum_sym; - sh++; - f->bitpos = sh->value; - f->type = t; - f->name = (char*)sh->iss; - f->bitsize = 0; - - enum_sym = (struct symbol *) - obstack_alloc (symbol_obstack, - sizeof (struct symbol)); - memset (enum_sym, 0, sizeof (struct symbol)); - SYMBOL_NAME (enum_sym) = f->name; - SYMBOL_CLASS (enum_sym) = LOC_CONST; - SYMBOL_TYPE (enum_sym) = t; - SYMBOL_NAMESPACE (enum_sym) = VAR_NAMESPACE; - SYMBOL_VALUE (enum_sym) = sh->value; - add_symbol(enum_sym, top_stack->cur_block); - - count++; - f++; - } + /* First count the number of fields. */ + for (tsym = sh+1; tsym->st != stEnd; tsym++) + if (tsym->st == stMember) { + if (nfields == 0 && type_code == TYPE_CODE_UNDEF) + /* If the type of the member is Void, + assume the tag is an enumeration. */ + if (tsym->index == indexNil + || ax[tsym->index].ti.bt == btVoid) + type_code = TYPE_CODE_ENUM; + nfields++; + if (tsym->value > max_value) + max_value = tsym->value; } - else { - /* Uhmm, can`t decide yet. Guess. */ - add_pending(cur_fdr, sh, t); + else if (tsym->st == stBlock + || tsym->st == stParsed) { + if (tsym->sc == scVariant) ; /*UNIMPLEMENTED*/ + if (tsym->index != 0) + tsym = ((SYMR*)cur_fdr->isymBase) + + tsym->index-1; + } + + + /* There is no guaranteed way to distinguish struct, + unions, and enums at this point. This is a bug in the + original design (that has been fixed with the + recent addition of the stStruct, stUnion, and stEnum + symbol types.) The way you can tell is if/when you + see a variable or field of that type: In that case + the variable's type (in the AUX table) says if the + type is struct, union, or enum, + and points back to the stBlock here. + So you can patch the tag kind up later - but only + if there actually is a variable or field of that type. + + So until we know for sure, we will guess at this point. + The heuristic is: + If the first member has index==indexNil or a void type, + assume we have an enumeration. + Otherwise, if all the members have offset 0, + assume we have a union. + Otherwise, assume we have a struct. + + The heuristic could guess wrong in the case of + of an enumeration with no members or a union + with one (or zero) members, or when all except the + last field of a struct have width zero. + These are uncommon and/or illegal situations, and + in any case guessing wrong probably doesn't matter much. + + But if we later do find out we were wrong, + we fixup the tag kind. Members of an enumeration + must be handled differently from struct/union fields, + and that is harder to patch up, but luckily we + shouldn't need to. (If there are any enumeration + members, we can tell for sure it's an enum here.) */ + + if (type_code == TYPE_CODE_UNDEF) + if (max_value == 0) type_code = TYPE_CODE_UNION; + else type_code = TYPE_CODE_STRUCT; + + TYPE_CODE(t) = type_code; + TYPE_NFIELDS(t) = nfields; + TYPE_FIELDS(t) = f = (struct field*) + obstack_alloc (symbol_obstack, + nfields * sizeof (struct field)); + + if (type_code == TYPE_CODE_ENUM) { + /* This is a non-empty enum. */ + while (sh[1].st == stMember) { + struct symbol *enum_sym; + sh++; + f->bitpos = sh->value; + f->type = t; + f->name = (char*)sh->iss; + f->bitsize = 0; + + enum_sym = (struct symbol *) + obstack_alloc (symbol_obstack, + sizeof (struct symbol)); + memset (enum_sym, 0, sizeof (struct symbol)); + SYMBOL_NAME (enum_sym) = f->name; + SYMBOL_CLASS (enum_sym) = LOC_CONST; + SYMBOL_TYPE (enum_sym) = t; + SYMBOL_NAMESPACE (enum_sym) = VAR_NAMESPACE; + SYMBOL_VALUE (enum_sym) = sh->value; + add_symbol(enum_sym, top_stack->cur_block); + + /* Skip the stMembers that we've handled. */ + count++; + f++; } } SYMBOL_TYPE(s) = t; @@ -1056,11 +1119,6 @@ data: /* Common code for symbols describing data */ BLOCK_END(b_bad) = BLOCK_END(b); } } - if (entry_point < BLOCK_END(b) - && entry_point >= BLOCK_START(b)) { - startup_file_start = BLOCK_START(b); - startup_file_end = BLOCK_END(b); - } } else if (sh->sc == scText && top_stack->blocktype == stBlock) { /* End of (code) block. The value of the symbol is the displacement from the procedure`s start @@ -1243,7 +1301,10 @@ static struct type *parse_type(ax, sh, bs) /* Usually, TYPE_CODE(tp) is already type_code. The main exception is if we guessed wrong re struct/union/enum. */ - TYPE_CODE(tp) = type_code; + if (TYPE_CODE(tp) != type_code) { + complain (&bad_tag_guess_complaint, 0); + TYPE_CODE(tp) = type_code; + } TYPE_NAME(tp) = obsavestring(pn, strlen(pn)); } @@ -1629,6 +1690,7 @@ parse_partial_symbols(end_of_text_seg, objfile) includes_used = 0; psymtab_include_list = (char **) alloca (includes_allocated * sizeof (char *)); + next_symbol_text_func = mips_next_symbol_text; dependencies_allocated = 30; dependencies_used = 0; @@ -1692,7 +1754,8 @@ parse_partial_symbols(end_of_text_seg, objfile) for (f_idx = 0; f_idx < hdr->ifdMax; f_idx++) { struct partial_symtab *save_pst; - fh = f_idx + (FDR *)(cur_hdr->cbFdOffset); + cur_fdr = fh = f_idx + (FDR *)(cur_hdr->cbFdOffset); + if (fh->csym == 0) { fdr_to_pst[f_idx].pst = NULL; continue; @@ -1721,17 +1784,19 @@ parse_partial_symbols(end_of_text_seg, objfile) pst->n_global_syms = 0; pst->n_static_syms = 0; - - /* The second symbol must be @stab. */ + /* The second symbol must be @stab. + This symbol is emitted by mips-tfile to signal + that the current object file uses encapsulated stabs + instead of mips ecoff for local symbols. + (It is the second symbol because the first symbol is + the stFile used to signal the start of a file). */ if (fh->csym >= 2 && strcmp(((SYMR *)fh->isymBase)[1].iss, stabs_symbol) == 0) { - for (s_idx = 2; s_idx < fh->csym; s_idx++) { + for (cur_sdx = 2; cur_sdx < fh->csym; cur_sdx++) { int type_code; char *namestring; - sh = s_idx + (SYMR *) fh->isymBase; + sh = cur_sdx + (SYMR *) fh->isymBase; type_code = MIPS_UNMARK_STAB(sh->index); - /* TEMPORARY: */ - if (type_code == 0x84 && s_idx == 2) continue; if (!MIPS_IS_STAB(sh)) { if (sh->st == stProc || sh->st == stStaticProc) { long procaddr = sh->value; @@ -1748,44 +1813,32 @@ parse_partial_symbols(end_of_text_seg, objfile) #define SET_NAMESTRING() namestring = (char*)sh->iss #define CUR_SYMBOL_TYPE type_code #define CUR_SYMBOL_VALUE sh->value -#define CHECK_SECOND_N_SO() \ - if (s_idx < fh->csym \ - && MIPS_UNMARK_STAB(((SYMR *)fh->isymBase)[s_idx+1].index) == (unsigned char)N_SO)\ - {\ - s_idx++;\ - sh = s_idx + (SYMR *) fh->isymBase;\ - SET_NAMESTRING ();\ - valu = CUR_SYMBOL_VALUE;\ - s_idx++;\ - } #define START_PSYMTAB(ofile,addr,fname,low,symoff,global_syms,static_syms)\ pst = save_pst #define END_PSYMTAB(pst,ilist,ninc,c_off,c_text,dep_list,n_deps) (void)0 -#define addr 0 +#define addr 0 /* FIXME, should be offset of addresses */ #define HANDLE_RBRAC(val) \ if ((val) > save_pst->texthigh) save_pst->texthigh = (val); -/* FIXME: Handle start_file_start and _end */ -/* FIXME: Handle enums - but must deal with next_symbol_text. */ #include "partial-stab.h" #undef addr } } else { - for (s_idx = 0; s_idx < fh->csym; ) { + for (cur_sdx = 0; cur_sdx < fh->csym; ) { register struct partial_symbol *p; char *name; int class; - sh = s_idx + (SYMR *) fh->isymBase; + sh = cur_sdx + (SYMR *) fh->isymBase; if (MIPS_IS_STAB(sh)) { - s_idx++; + cur_sdx++; continue; } if (sh->sc == scUndefined || sh->sc == scNil || sh->index == 0xfffff) { /* FIXME, premature? */ - s_idx++; + cur_sdx++; continue; } @@ -1800,10 +1853,10 @@ parse_partial_symbols(end_of_text_seg, objfile) VAR_NAMESPACE, LOC_BLOCK, static_psymbols, sh->value); /* Skip over procedure to next one. */ - s_idx = (sh->index + (AUXU *)fh->iauxBase)->isym; + cur_sdx = (sh->index + (AUXU *)fh->iauxBase)->isym; procaddr = sh->value; - sh = s_idx + (SYMR *) fh->isymBase - 1; + sh = cur_sdx + (SYMR *) fh->isymBase - 1; if (sh->st != stEnd) continue; high = procaddr + sh->value; @@ -1826,7 +1879,7 @@ parse_partial_symbols(end_of_text_seg, objfile) static_psymbols, sh->value); } /* Skip over the block */ - s_idx = sh->index; + cur_sdx = sh->index; continue; case stFile: /* File headers */ case stLabel: /* Labels */ @@ -1835,7 +1888,7 @@ parse_partial_symbols(end_of_text_seg, objfile) default: complain (&unknown_sym_complaint, SYMBOL_NAME(p)); complain (&unknown_st_complaint, sh->st); - s_idx++; + cur_sdx++; continue; } /* Use this gdb symbol */ @@ -1843,13 +1896,18 @@ parse_partial_symbols(end_of_text_seg, objfile) VAR_NAMESPACE, class, static_psymbols, sh->value); skip: - s_idx++; /* Go to next file symbol */ + cur_sdx++; /* Go to next file symbol */ } } end_psymtab (save_pst, psymtab_include_list, includes_used, -1, save_pst->texthigh, dependency_list, dependencies_used, global_psymbols.next, static_psymbols.next); + if (entry_point < save_pst->texthigh + && entry_point >= save_pst->textlow) { + startup_file_start = save_pst->textlow; + startup_file_end = save_pst->texthigh; + } } /* Mark the last code address, and remember it for later */ @@ -1929,16 +1987,12 @@ parse_fdr(f_idx, lev, objfile) return pst; } -#ifdef READ_MIPS_FORMAT -static int s_idx; - -char* -next_symbol_text () +static char* +mips_next_symbol_text () { - s_idx++; - return (char*)((SYMR *)cur_fdr->isymBase)[s_idx].iss; + cur_sdx++; + return (char*)((SYMR *)cur_fdr->isymBase)[cur_sdx].iss; } -#endif /* Ancillary function to psymtab_to_symtab(). Does all the work for turning the partial symtab PST into a symtab, recurring @@ -1974,6 +2028,7 @@ psymtab_to_symtab_1(pst, filename) maxlines = 2 * fh->cline; } + /* See comment in parse_partial_symbols about the @stabs sentinel. */ have_stabs = fh && fh->csym >= 2 && strcmp(((SYMR *)fh->isymBase)[1].iss, stabs_symbol) == 0; @@ -2051,15 +2106,13 @@ psymtab_to_symtab_1(pst, filename) if (have_stabs) { if (fh->csym <= 2) return; - for (s_idx = 2; s_idx < fh->csym; s_idx++) { - register SYMR *sh = s_idx + (SYMR *) fh->isymBase; + for (cur_sdx = 2; cur_sdx < fh->csym; cur_sdx++) { + register SYMR *sh = cur_sdx + (SYMR *) fh->isymBase; char *name = (char*)sh->iss; CORE_ADDR valu = sh->value; if (MIPS_IS_STAB(sh)) { int type_code = MIPS_UNMARK_STAB(sh->index); - /* TEMPORARY: */ - if (type_code == 0x84 && s_idx == 2) continue; - process_one_symbol (type_code, 0, valu, name); + process_one_symbol (type_code, 0, valu, name, /*FIXME*/ 0); } else if (sh->st == stLabel && sh->index != indexNil) { /* Handle encoded stab line number. */ @@ -2072,21 +2125,20 @@ psymtab_to_symtab_1(pst, filename) /* BOUND is the highest core address of this file's procedures */ int bound = cur_fd == cur_hdr->ifdMax - 1 ? cur_hdr->cbDnOffset : fh[1].adr; - for (s_idx = 0; s_idx < fh->csym; ) { - sh = (SYMR *) (fh->isymBase) + s_idx; - cur_sdx = s_idx; - s_idx += parse_symbol(sh, fh->iauxBase); + for (cur_sdx = 0; cur_sdx < fh->csym; ) { + sh = (SYMR *) (fh->isymBase) + cur_sdx; + cur_sdx += parse_symbol(sh, fh->iauxBase); } /* Procedures next, note we need to look-ahead to find out where the procedure's code ends */ - for (s_idx = 0; s_idx < fh->cpd-1; s_idx++) { - pr = (PDR *) (IPDFIRST(cur_hdr, fh)) + s_idx; + for (i = 0; i < fh->cpd-1; i++) { + pr = (PDR *) (IPDFIRST(cur_hdr, fh)) + i; parse_procedure(pr, pr[1].adr); /* next proc up */ } if (fh->cpd) { - pr = (PDR *) (IPDFIRST(cur_hdr, fh)) + s_idx; + pr = (PDR *) (IPDFIRST(cur_hdr, fh)) + i; parse_procedure(pr, bound); /* next file up */ } /* Linenumbers. At the end, check if we can save memory */ diff --git a/gdb/putenv.c b/gdb/putenv.c index b9de9f0..15689e3 100644 --- a/gdb/putenv.c +++ b/gdb/putenv.c @@ -68,15 +68,17 @@ putenv( entry ) { unsigned length; unsigned size; + char *temp; char **p; char **new_environ; /* Find the length of the "NAME=" */ - if ( (length=(unsigned) index(entry,'=')) == 0 ) + temp = index(entry,'='); + if ( temp == 0 ) return( -1 ); - length = length - (unsigned) entry + 1; + length = (unsigned) (temp - entry + 1); /* Scan through the environment looking for "NAME=" */ @@ -95,7 +97,7 @@ putenv( entry ) new_environ = (char **) malloc( (size+2)*PSIZE ); - if ( new_environ == NULL ) + if ( new_environ == (char **) NULL ) return( -1 ); bcopy( (char *) environ, (char *) new_environ, size*PSIZE ); |