diff options
| author | Shahar Kohanim <skohanim@gmail.com> | 2016-03-23 00:44:07 +0200 |
|---|---|---|
| committer | Shahar Kohanim <skohanim@gmail.com> | 2016-03-30 03:44:41 +0000 |
| commit | 7f067c87d831f329d068fced1b136cd06039303c (patch) | |
| tree | 379aea9d949ef1a0c5534cc218cb8aba322e5e5d /src/cmd/internal/obj/objfile.go | |
| parent | 777a77b4d29853e13dc803b2923bf88b498ed306 (diff) | |
| download | go-7f067c87d831f329d068fced1b136cd06039303c.tar.xz | |
cmd/compile, cmd/link: record lengths in object file
Record total number of relocations, pcdata, automatics, funcdata and files in
object file and use these numbers in the linker to allocate contiguous
slices to later be filled by the defined symbols.
name old secs new secs delta
LinkCmdGo 0.52 ± 3% 0.49 ± 3% -4.21% (p=0.000 n=91+92)
LinkJuju 4.48 ± 4% 4.21 ± 7% -6.08% (p=0.000 n=96+100)
name old MaxRSS new MaxRSS delta
LinkCmdGo 122k ± 2% 120k ± 4% -1.66% (p=0.000 n=98+93)
LinkJuju 799k ± 5% 865k ± 8% +8.29% (p=0.000 n=89+99)
GOGC=off
name old secs new secs delta
LinkCmdGo 0.42 ± 2% 0.41 ± 0% -2.98% (p=0.000 n=89+70)
LinkJuju 3.61 ± 0% 3.52 ± 1% -2.46% (p=0.000 n=80+89)
name old MaxRSS new MaxRSS delta
LinkCmdGo 130k ± 1% 128k ± 1% -1.33% (p=0.000 n=100+100)
LinkJuju 1.00M ± 0% 0.99M ± 0% -1.70% (p=0.000 n=100+100)
Change-Id: Ie08f6ccd4311bb78d8950548c678230a58635c73
Reviewed-on: https://go-review.googlesource.com/21026
Reviewed-by: David Crawshaw <crawshaw@golang.org>
Run-TryBot: David Crawshaw <crawshaw@golang.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Diffstat (limited to 'src/cmd/internal/obj/objfile.go')
| -rw-r--r-- | src/cmd/internal/obj/objfile.go | 74 |
1 files changed, 61 insertions, 13 deletions
diff --git a/src/cmd/internal/obj/objfile.go b/src/cmd/internal/obj/objfile.go index b9eb8014ec..aba832f27b 100644 --- a/src/cmd/internal/obj/objfile.go +++ b/src/cmd/internal/obj/objfile.go @@ -21,7 +21,13 @@ // - empty string (marks end of sequence) // - sequence of symbol references used by the defined symbols // - byte 0xff (marks end of sequence) -// - integer (length of following data) +// - sequence of integer lengths: +// - total data length +// - total number of relocations +// - total number of pcdata +// - total number of automatics +// - total number of funcdata +// - total number of files // - data, the content of the defined symbols // - sequence of defined symbols // - byte 0xff (marks end of sequence) @@ -303,6 +309,54 @@ func flushplist(ctxt *Link, freeProgs bool) { } } +type sectionLengths struct { + data int + reloc int + pcdata int + autom int + funcdata int + file int +} + +func (l *sectionLengths) add(s *LSym) { + l.data += len(s.P) + l.reloc += len(s.R) + + if s.Type != STEXT { + return + } + + pc := s.Pcln + + data := 0 + data += len(pc.Pcsp.P) + data += len(pc.Pcfile.P) + data += len(pc.Pcline.P) + for i := 0; i < len(pc.Pcdata); i++ { + data += len(pc.Pcdata[i].P) + } + + l.data += data + l.pcdata += len(pc.Pcdata) + + autom := 0 + for a := s.Autom; a != nil; a = a.Link { + autom++ + } + l.autom += autom + l.funcdata += len(pc.Funcdataoff) + l.file += len(pc.File) +} + +func wrlengths(b *Biobuf, sl sectionLengths) { + wrint(b, int64(sl.data)) + wrint(b, int64(sl.reloc)) + wrint(b, int64(sl.pcdata)) + wrint(b, int64(sl.autom)) + wrint(b, int64(sl.funcdata)) + wrint(b, int64(sl.file)) +} + func Writeobjfile(ctxt *Link, b *Biobuf) { // Emit header. Bputc(b, 0) @@ -317,28 +371,22 @@ func Writeobjfile(ctxt *Link, b *Biobuf) { } wrstring(b, "") - var dataLength int64 + var lengths sectionLengths + // Emit symbol references. for _, s := range ctxt.Text { writerefs(ctxt, b, s) - dataLength += int64(len(s.P)) - - pc := s.Pcln - dataLength += int64(len(pc.Pcsp.P)) - dataLength += int64(len(pc.Pcfile.P)) - dataLength += int64(len(pc.Pcline.P)) - for i := 0; i < len(pc.Pcdata); i++ { - dataLength += int64(len(pc.Pcdata[i].P)) - } + lengths.add(s) } for _, s := range ctxt.Data { writerefs(ctxt, b, s) - dataLength += int64(len(s.P)) + lengths.add(s) } Bputc(b, 0xff) + wrlengths(b, lengths) + // Write data block - wrint(b, dataLength) for _, s := range ctxt.Text { b.w.Write(s.P) pc := s.Pcln |
