aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/cmd/link/internal/loader/loader.go24
1 files changed, 18 insertions, 6 deletions
diff --git a/src/cmd/link/internal/loader/loader.go b/src/cmd/link/internal/loader/loader.go
index e1d5c864ab..f4d91644c9 100644
--- a/src/cmd/link/internal/loader/loader.go
+++ b/src/cmd/link/internal/loader/loader.go
@@ -2128,12 +2128,14 @@ func (l *Loader) LoadFull(arch *sys.Arch, syms *sym.Symbols, needReloc bool) {
// Resolve ABI aliases for external symbols. This is only
// needed for internal cgo linking.
- for _, i := range l.extReader.syms {
- if s := l.Syms[i]; s != nil && s.Attr.Reachable() {
- for ri := range s.R {
- r := &s.R[ri]
- if r.Sym != nil && r.Sym.Type == sym.SABIALIAS {
- r.Sym = r.Sym.R[0].Sym
+ if needReloc {
+ for _, i := range l.extReader.syms {
+ if s := l.Syms[i]; s != nil && s.Attr.Reachable() {
+ for ri := range s.R {
+ r := &s.R[ri]
+ if r.Sym != nil && r.Sym.Type == sym.SABIALIAS {
+ r.Sym = r.Sym.R[0].Sym
+ }
}
}
}
@@ -2170,6 +2172,16 @@ func (l *Loader) LoadFull(arch *sys.Arch, syms *sym.Symbols, needReloc bool) {
l.dynid = nil
l.relocVariant = nil
l.extRelocs = nil
+
+ // Drop fields that are no longer needed.
+ for _, i := range l.extReader.syms {
+ pp := l.getPayload(i)
+ pp.name = ""
+ pp.relocs = nil
+ pp.reltypes = nil
+ pp.auxs = nil
+ pp.data = nil
+ }
}
// ResolveABIAlias given a symbol returns the ABI alias target of that