Commit 6561e4b6 authored by Alex Brainman's avatar Alex Brainman

cmd/link: introduce and use peFile.mapToPESection

Change-Id: I598e9da5587908f39faa13c11d2b42054f5a632d
Reviewed-on: https://go-review.googlesource.com/59423Reviewed-by: default avatarIan Lance Taylor <iant@golang.org>
parent 6f299c7f
...@@ -669,6 +669,33 @@ func (f *peFile) writeSymbol(s *Symbol, value int64, sectidx int, typ uint16, cl ...@@ -669,6 +669,33 @@ func (f *peFile) writeSymbol(s *Symbol, value int64, sectidx int, typ uint16, cl
f.symbolCount++ f.symbolCount++
} }
// mapToPESection searches peFile f for s symbol's location.
// It returns PE section index, and offset within that section.
func (f *peFile) mapToPESection(s *Symbol) (pesectidx int, offset int64, err error) {
if s.Sect == nil {
return 0, 0, fmt.Errorf("could not map %s symbol with no section", s.Name)
}
if s.Sect.Seg == &Segtext {
return f.textSect.index, int64(uint64(s.Value) - Segtext.Vaddr), nil
}
if s.Sect.Seg != &Segdata {
return 0, 0, fmt.Errorf("could not map %s symbol with non .text or .data section", s.Name)
}
v := uint64(s.Value) - Segdata.Vaddr
if Linkmode != LinkExternal {
return f.dataSect.index, int64(v), nil
}
if s.Type == SDATA {
return f.dataSect.index, int64(v), nil
}
// Note: although address of runtime.edata (type SDATA) is at the start of .bss section
// it still belongs to the .data section, not the .bss section.
if v < Segdata.Filelen {
return f.dataSect.index, int64(v), nil
}
return f.bssSect.index, int64(v - Segdata.Filelen), nil
}
var pefile peFile var pefile peFile
func Peinit(ctxt *Link) { func Peinit(ctxt *Link) {
...@@ -1077,25 +1104,13 @@ func writePESymTableRecords(ctxt *Link) { ...@@ -1077,25 +1104,13 @@ func writePESymTableRecords(ctxt *Link) {
} }
typ := uint16(IMAGE_SYM_TYPE_NULL) typ := uint16(IMAGE_SYM_TYPE_NULL)
var sect int sect, value, err := pefile.mapToPESection(s)
var value int64 if err != nil {
if s.Sect != nil && s.Sect.Seg == &Segdata { if type_ == UndefinedSym {
// Note: although address of runtime.edata (type SDATA) is at the start of .bss section typ = IMAGE_SYM_DTYPE_FUNCTION
// it still belongs to the .data section, not the .bss section.
if uint64(s.Value) >= Segdata.Vaddr+Segdata.Filelen && s.Type != SDATA && Linkmode == LinkExternal {
value = int64(uint64(s.Value) - Segdata.Vaddr - Segdata.Filelen)
sect = pefile.bssSect.index
} else { } else {
value = int64(uint64(s.Value) - Segdata.Vaddr) Errorf(s, "addpesym: %v", err)
sect = pefile.dataSect.index
} }
} else if s.Sect != nil && s.Sect.Seg == &Segtext {
value = int64(uint64(s.Value) - Segtext.Vaddr)
sect = pefile.textSect.index
} else if type_ == UndefinedSym {
typ = IMAGE_SYM_DTYPE_FUNCTION
} else {
Errorf(s, "addpesym %#x", addr)
} }
if typ != IMAGE_SYM_TYPE_NULL { if typ != IMAGE_SYM_TYPE_NULL {
} else if Linkmode != LinkExternal { } else if Linkmode != LinkExternal {
......
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