Commit 23e8c0d2 authored by David du Colombier's avatar David du Colombier

cmd/addr2line, cmd/objdump: handle Plan 9 a.out object files

Update #7947.

LGTM=iant
R=rsc, iant
CC=golang-codereviews
https://golang.org/cl/91500044
parent 1704368c
...@@ -92,9 +92,6 @@ func testAddr2Line(t *testing.T, exepath, addr string) { ...@@ -92,9 +92,6 @@ func testAddr2Line(t *testing.T, exepath, addr string) {
// This is line 93. The test depends on that. // This is line 93. The test depends on that.
func TestAddr2Line(t *testing.T) { func TestAddr2Line(t *testing.T) {
if runtime.GOOS == "plan9" {
t.Skip("skipping test; see http://golang.org/issue/7947")
}
syms := loadSyms(t) syms := loadSyms(t)
tmpDir, err := ioutil.TempDir("", "TestAddr2Line") tmpDir, err := ioutil.TempDir("", "TestAddr2Line")
......
...@@ -23,6 +23,7 @@ import ( ...@@ -23,6 +23,7 @@ import (
"debug/gosym" "debug/gosym"
"debug/macho" "debug/macho"
"debug/pe" "debug/pe"
"debug/plan9obj"
"flag" "flag"
"fmt" "fmt"
"log" "log"
...@@ -159,6 +160,21 @@ func loadTables(f *os.File) (textStart uint64, symtab, pclntab []byte, err error ...@@ -159,6 +160,21 @@ func loadTables(f *os.File) (textStart uint64, symtab, pclntab []byte, err error
return textStart, symtab, pclntab, nil return textStart, symtab, pclntab, nil
} }
if obj, err := plan9obj.NewFile(f); err == nil {
sym, err := findPlan9Symbol(obj, "text")
if err != nil {
return 0, nil, nil, err
}
textStart = sym.Value
if pclntab, err = loadPlan9Table(obj, "pclntab", "epclntab"); err != nil {
return 0, nil, nil, err
}
if symtab, err = loadPlan9Table(obj, "symtab", "esymtab"); err != nil {
return 0, nil, nil, err
}
return textStart, symtab, pclntab, nil
}
return 0, nil, nil, fmt.Errorf("unrecognized binary format") return 0, nil, nil, fmt.Errorf("unrecognized binary format")
} }
...@@ -197,3 +213,41 @@ func loadPETable(f *pe.File, sname, ename string) ([]byte, error) { ...@@ -197,3 +213,41 @@ func loadPETable(f *pe.File, sname, ename string) ([]byte, error) {
} }
return data[ssym.Value:esym.Value], nil return data[ssym.Value:esym.Value], nil
} }
func findPlan9Symbol(f *plan9obj.File, name string) (*plan9obj.Sym, error) {
syms, err := f.Symbols()
if err != nil {
return nil, err
}
for _, s := range syms {
if s.Name != name {
continue
}
return &s, nil
}
return nil, fmt.Errorf("no %s symbol found", name)
}
func loadPlan9Table(f *plan9obj.File, sname, ename string) ([]byte, error) {
ssym, err := findPlan9Symbol(f, sname)
if err != nil {
return nil, err
}
esym, err := findPlan9Symbol(f, ename)
if err != nil {
return nil, err
}
text, err := findPlan9Symbol(f, "text")
if err != nil {
return nil, err
}
sect := f.Section("text")
if sect == nil {
return nil, err
}
data, err := sect.Data()
if err != nil {
return nil, err
}
return data[ssym.Value-text.Value : esym.Value-text.Value], nil
}
...@@ -41,6 +41,7 @@ import ( ...@@ -41,6 +41,7 @@ import (
"debug/gosym" "debug/gosym"
"debug/macho" "debug/macho"
"debug/pe" "debug/pe"
"debug/plan9obj"
"flag" "flag"
"fmt" "fmt"
"io" "io"
...@@ -340,6 +341,24 @@ func loadTables(f *os.File) (textStart uint64, textData, symtab, pclntab []byte, ...@@ -340,6 +341,24 @@ func loadTables(f *os.File) (textStart uint64, textData, symtab, pclntab []byte,
return textStart, textData, symtab, pclntab, nil return textStart, textData, symtab, pclntab, nil
} }
if obj, err := plan9obj.NewFile(f); err == nil {
sym, err := findPlan9Symbol(obj, "text")
if err != nil {
return 0, nil, nil, nil, err
}
textStart = sym.Value
if sect := obj.Section("text"); sect != nil {
textData, _ = sect.Data()
}
if pclntab, err = loadPlan9Table(obj, "pclntab", "epclntab"); err != nil {
return 0, nil, nil, nil, err
}
if symtab, err = loadPlan9Table(obj, "symtab", "esymtab"); err != nil {
return 0, nil, nil, nil, err
}
return textStart, textData, symtab, pclntab, nil
}
return 0, nil, nil, nil, fmt.Errorf("unrecognized binary format") return 0, nil, nil, nil, fmt.Errorf("unrecognized binary format")
} }
...@@ -379,6 +398,44 @@ func loadPETable(f *pe.File, sname, ename string) ([]byte, error) { ...@@ -379,6 +398,44 @@ func loadPETable(f *pe.File, sname, ename string) ([]byte, error) {
return data[ssym.Value:esym.Value], nil return data[ssym.Value:esym.Value], nil
} }
func findPlan9Symbol(f *plan9obj.File, name string) (*plan9obj.Sym, error) {
syms, err := f.Symbols()
if err != nil {
return nil, err
}
for _, s := range syms {
if s.Name != name {
continue
}
return &s, nil
}
return nil, fmt.Errorf("no %s symbol found", name)
}
func loadPlan9Table(f *plan9obj.File, sname, ename string) ([]byte, error) {
ssym, err := findPlan9Symbol(f, sname)
if err != nil {
return nil, err
}
esym, err := findPlan9Symbol(f, ename)
if err != nil {
return nil, err
}
text, err := findPlan9Symbol(f, "text")
if err != nil {
return nil, err
}
sect := f.Section("text")
if sect == nil {
return nil, err
}
data, err := sect.Data()
if err != nil {
return nil, err
}
return data[ssym.Value-text.Value : esym.Value-text.Value], nil
}
// TODO(rsc): This code is taken from cmd/nm. Arrange some way to share the code. // TODO(rsc): This code is taken from cmd/nm. Arrange some way to share the code.
var exitCode = 0 var exitCode = 0
......
...@@ -87,9 +87,6 @@ func testObjDump(t *testing.T, exe, startaddr, endaddr string) { ...@@ -87,9 +87,6 @@ func testObjDump(t *testing.T, exe, startaddr, endaddr string) {
// This is line 88. The test depends on that. // This is line 88. The test depends on that.
func TestObjDump(t *testing.T) { func TestObjDump(t *testing.T) {
if runtime.GOOS == "plan9" {
t.Skip("skipping test; see http://golang.org/issue/7947")
}
syms := loadSyms(t) syms := loadSyms(t)
tmp, exe := buildObjdump(t) tmp, exe := buildObjdump(t)
......
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