Commit da6205b6 authored by Dmitry Vyukov's avatar Dmitry Vyukov

cmd/pprof/internal/profile: always subtract 1 from PCs

Go runtime never emits PCs that are not a return address
(except for cpu profiler).

Change-Id: I08d9dc5c7c71e23f34f2f0c16f8baeeb4f64fcd6
Reviewed-on: https://go-review.googlesource.com/21735Reviewed-by: default avatarIan Lance Taylor <iant@golang.org>
parent eb79f21c
...@@ -110,11 +110,8 @@ func parseGoCount(b []byte) (*Profile, error) { ...@@ -110,11 +110,8 @@ func parseGoCount(b []byte) (*Profile, error) {
if err != nil { if err != nil {
return nil, errMalformed return nil, errMalformed
} }
// Adjust all frames by -1 (except the leaf) to land on top of // Adjust all frames by -1 to land on the call instruction.
// the call instruction.
if len(locs) > 0 {
addr-- addr--
}
loc := locations[addr] loc := locations[addr]
if loc == nil { if loc == nil {
loc = &Location{ loc = &Location{
...@@ -291,11 +288,8 @@ func ParseTracebacks(b []byte) (*Profile, error) { ...@@ -291,11 +288,8 @@ func ParseTracebacks(b []byte) (*Profile, error) {
if s, addrs := extractHexAddresses(l); len(s) > 0 { if s, addrs := extractHexAddresses(l); len(s) > 0 {
for _, addr := range addrs { for _, addr := range addrs {
// Addresses from stack traces point to the next instruction after // Addresses from stack traces point to the next instruction after
// each call. Adjust by -1 to land somewhere on the actual call // each call. Adjust by -1 to land somewhere on the actual call.
// (except for the leaf, which is not a call).
if len(sloc) > 0 {
addr-- addr--
}
loc := locs[addr] loc := locs[addr]
if locs[addr] == nil { if locs[addr] == nil {
loc = &Location{ loc = &Location{
...@@ -568,13 +562,10 @@ func parseHeap(b []byte) (p *Profile, err error) { ...@@ -568,13 +562,10 @@ func parseHeap(b []byte) (p *Profile, err error) {
return nil, err return nil, err
} }
var sloc []*Location var sloc []*Location
for i, addr := range addrs { for _, addr := range addrs {
// Addresses from stack traces point to the next instruction after // Addresses from stack traces point to the next instruction after
// each call. Adjust by -1 to land somewhere on the actual call // each call. Adjust by -1 to land somewhere on the actual call.
// (except for the leaf, which is not a call).
if i > 0 {
addr-- addr--
}
loc := locs[addr] loc := locs[addr]
if locs[addr] == nil { if locs[addr] == nil {
loc = &Location{ loc = &Location{
...@@ -776,13 +767,10 @@ func parseContention(b []byte) (p *Profile, err error) { ...@@ -776,13 +767,10 @@ func parseContention(b []byte) (p *Profile, err error) {
return nil, err return nil, err
} }
var sloc []*Location var sloc []*Location
for i, addr := range addrs { for _, addr := range addrs {
// Addresses from stack traces point to the next instruction after // Addresses from stack traces point to the next instruction after
// each call. Adjust by -1 to land somewhere on the actual call // each call. Adjust by -1 to land somewhere on the actual call.
// (except for the leaf, which is not a call).
if i > 0 {
addr-- addr--
}
loc := locs[addr] loc := locs[addr]
if locs[addr] == nil { if locs[addr] == nil {
loc = &Location{ loc = &Location{
...@@ -919,13 +907,10 @@ func parseThread(b []byte) (*Profile, error) { ...@@ -919,13 +907,10 @@ func parseThread(b []byte) (*Profile, error) {
} }
var sloc []*Location var sloc []*Location
for i, addr := range addrs { for _, addr := range addrs {
// Addresses from stack traces point to the next instruction after // Addresses from stack traces point to the next instruction after
// each call. Adjust by -1 to land somewhere on the actual call // each call. Adjust by -1 to land somewhere on the actual call.
// (except for the leaf, which is not a call).
if i > 0 {
addr-- addr--
}
loc := locs[addr] loc := locs[addr]
if locs[addr] == nil { if locs[addr] == nil {
loc = &Location{ loc = &Location{
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment