• Russ Cox's avatar
    runtime: fix line number in first stack frame in printed stack trace · a22c11b9
    Russ Cox authored
    Originally traceback was only used for printing the stack
    when an unexpected signal came in. In that case, the
    initial PC is taken from the signal and should be used
    unaltered. For the callers, the PC is the return address,
    which might be on the line after the call; we subtract 1
    to get to the CALL instruction.
    
    Traceback is now used for a variety of things, and for
    almost all of those the initial PC is a return address,
    whether from getcallerpc, or gp->sched.pc, or gp->syscallpc.
    In those cases, we need to subtract 1 from this initial PC,
    but the traceback code had a hard rule "never subtract 1
    from the initial PC", left over from the signal handling days.
    
    Change gentraceback to take a flag that specifies whether
    we are tracing a trap.
    
    Change traceback to default to "starting with a return PC",
    which is the overwhelmingly common case.
    
    Add tracebacktrap, like traceback but starting with a trap PC.
    
    Use tracebacktrap in signal handlers.
    
    Fixes #7690.
    
    LGTM=iant, r
    R=r, iant
    CC=golang-codereviews
    https://golang.org/cl/167810044
    a22c11b9
Name
Last commit
Last update
..
archive Loading commit data...
bufio Loading commit data...
builtin Loading commit data...
bytes Loading commit data...
cmd Loading commit data...
compress Loading commit data...
container Loading commit data...
crypto Loading commit data...
database/sql Loading commit data...
debug Loading commit data...
encoding Loading commit data...
errors Loading commit data...
expvar Loading commit data...
flag Loading commit data...
fmt Loading commit data...
go Loading commit data...
hash Loading commit data...
html Loading commit data...
image Loading commit data...
index/suffixarray Loading commit data...
internal/syscall Loading commit data...
io Loading commit data...
lib9 Loading commit data...
libbio Loading commit data...
liblink Loading commit data...
log Loading commit data...
math Loading commit data...
mime Loading commit data...
net Loading commit data...
os Loading commit data...
path Loading commit data...
reflect Loading commit data...
regexp Loading commit data...
runtime Loading commit data...
sort Loading commit data...
strconv Loading commit data...
strings Loading commit data...
sync Loading commit data...
syscall Loading commit data...
testing Loading commit data...
text Loading commit data...
time Loading commit data...
unicode Loading commit data...
unsafe Loading commit data...
Make.dist Loading commit data...
all.bash Loading commit data...
all.bat Loading commit data...
all.rc Loading commit data...
androidtest.bash Loading commit data...
clean.bash Loading commit data...
clean.bat Loading commit data...
clean.rc Loading commit data...
make.bash Loading commit data...
make.bat Loading commit data...
make.rc Loading commit data...
nacltest.bash Loading commit data...
race.bash Loading commit data...
race.bat Loading commit data...
run.bash Loading commit data...
run.bat Loading commit data...
run.rc Loading commit data...
sudo.bash Loading commit data...