mirror of
https://github.com/bminor/binutils-gdb.git
synced 2025-12-26 01:07:52 +00:00
* symtab.c (find_function_start_sal): Never return SAL pointing
before function start address, even if line info is missing.
This commit is contained in:
@@ -1,3 +1,8 @@
|
||||
2010-04-09 Ulrich Weigand <uweigand@de.ibm.com>
|
||||
|
||||
* symtab.c (find_function_start_sal): Never return SAL pointing
|
||||
before function start address, even if line info is missing.
|
||||
|
||||
2010-04-09 Pedro Alves <pedro@codesourcery.com>
|
||||
|
||||
* NEWS: Mention tracepoints support.
|
||||
|
||||
12
gdb/symtab.c
12
gdb/symtab.c
@@ -2295,6 +2295,18 @@ find_function_start_sal (struct symbol *sym, int funfirstline)
|
||||
sal = find_pc_sect_line (BLOCK_START (SYMBOL_BLOCK_VALUE (sym)),
|
||||
SYMBOL_OBJ_SECTION (sym), 0);
|
||||
|
||||
/* We always should have a line for the function start address.
|
||||
If we don't, something is odd. Create a plain SAL refering
|
||||
just the PC and hope that skip_prologue_sal (if requested)
|
||||
can find a line number for after the prologue. */
|
||||
if (sal.pc < BLOCK_START (SYMBOL_BLOCK_VALUE (sym)))
|
||||
{
|
||||
init_sal (&sal);
|
||||
sal.pspace = current_program_space;
|
||||
sal.pc = BLOCK_START (SYMBOL_BLOCK_VALUE (sym));
|
||||
sal.section = SYMBOL_OBJ_SECTION (sym);
|
||||
}
|
||||
|
||||
if (funfirstline)
|
||||
skip_prologue_sal (&sal);
|
||||
|
||||
|
||||
Reference in New Issue
Block a user