1. 09 Dec, 2013 12 commits
    • Russ Cox's avatar
      cmd/6l: fix linux/amd64 · 1eac128d
      Russ Cox authored
      TBR=iant
      CC=golang-dev
      https://golang.org/cl/39530043
      1eac128d
    • Russ Cox's avatar
      cmd/dist, cmd/go: pass -fmessage-length always · 65a643ba
      Russ Cox authored
      R=golang-dev, iant
      CC=golang-dev
      https://golang.org/cl/36300044
      65a643ba
    • Russ Cox's avatar
      cmd/gc: print more information for windows failure · 295e73e1
      Russ Cox authored
      TBR=iant
      CC=golang-dev
      https://golang.org/cl/39510043
      295e73e1
    • Russ Cox's avatar
      cmd/ld: fix linux/386 build · 0c0589ec
      Russ Cox authored
      TBR=iant
      CC=golang-dev
      https://golang.org/cl/39400044
      0c0589ec
    • Russ Cox's avatar
      cmd/dist, cmd/go: pass -fmessage-length=0 when using clang · 79479ac4
      Russ Cox authored
      That option turns off word wrapping of individual
      error messages generated by clang. The wrapping
      makes the errors harder to read and conflicts with the
      idea of a terminal window that can be resized.
      
      R=golang-dev, r
      CC=golang-dev
      https://golang.org/cl/35810043
      79479ac4
    • David du Colombier's avatar
      liblink: fix Plan 9 build · b9bed397
      David du Colombier authored
      R=golang-dev, rsc
      CC=golang-dev
      https://golang.org/cl/39280043
      b9bed397
    • Russ Cox's avatar
      runtime: remove cross-function jump in vlop_arm.s · 7c17982f
      Russ Cox authored
      The new linker will disallow this on arm
      (it is already disallowed on amd64 and 386)
      in order to be able to lay out each function
      separately.
      
      The restriction is only for jumps into the middle
      of a function; jumps to the beginning of a function
      remain fine.
      
      Prereq for linker cleanup (golang.org/s/go13linker).
      
      R=iant, r, minux.ma
      CC=golang-dev
      https://golang.org/cl/35800043
      7c17982f
    • Russ Cox's avatar
      cmd/5g, cmd/6g, cmd/8g: use liblink · f606c1be
      Russ Cox authored
      Preparation for golang.org/s/go13linker work.
      
      This CL does not build by itself. It depends on 35740044
      and 35790044 and will be submitted at the same time.
      
      R=iant
      CC=golang-dev
      https://golang.org/cl/34590045
      f606c1be
    • Russ Cox's avatar
      cmd/5c, cmd/6c, cmd/8c: use liblink · 76a8c873
      Russ Cox authored
      Preparation for golang.org/s/go13linker work.
      
      This CL does not build by itself. It depends on 35740044
      and 35790044 and will be submitted at the same time.
      
      R=iant
      CC=golang-dev
      https://golang.org/cl/34580044
      76a8c873
    • Russ Cox's avatar
      cmd/5a, cmd/6a, cmd/8a: use liblink · f7aaa553
      Russ Cox authored
      Preparation for golang.org/s/go13linker work.
      
      This CL does not build by itself. It depends on 35740044
      and 35790044 and will be submitted at the same time.
      
      R=iant
      CC=golang-dev
      https://golang.org/cl/35830043
      f7aaa553
    • Russ Cox's avatar
      liblink: create new library based on linker code · 7d507dc6
      Russ Cox authored
      There is an enormous amount of code moving around in this CL,
      but the code is the same, and it is invoked in the same ways.
      This CL is preparation for the new linker structure, not the new
      structure itself.
      
      The new library's definition is in include/link.h.
      
      The main change is the use of a Link structure to hold all the
      linker-relevant state, replacing the smattering of global variables.
      The Link structure should both make it clearer which state must
      be carried around and make it possible to parallelize more easily
      later.
      
      The main body of the linker has moved into the architecture-independent
      cmd/ld directory. That includes the list of known header types, so the
      distinction between Hplan9x32 and Hplan9x64 is removed (no other
      header type distinguished 32- and 64-bit formats), and code for unused
      formats such as ipaq kernels has been deleted.
      
      The code being deleted from 5l, 6l, and 8l reappears in liblink or in ld.
      Because multiple files are being merged in the liblink directory,
      it is not possible to show the diffs nicely in hg.
      
      The Prog and Addr structures have been unified into an
      architecture-independent form and moved to link.h, where they will
      be shared by all tools: the assemblers, the compilers, and the linkers.
      The unification makes it possible to write architecture-independent
      traversal of Prog lists, among other benefits.
      
      The Sym structures cannot be unified: they are too fundamentally
      different between the linker and the compilers. Instead, liblink defines
      an LSym - a linker Sym - to be used in the Prog and Addr structures,
      and the linker now refers exclusively to LSyms. The compilers will
      keep using their own syms but will fill out the corresponding LSyms in
      the Prog and Addr structures.
      
      Although code from 5l, 6l, and 8l is now in a single library, the
      code has been arranged so that only one architecture needs to
      be linked into a particular program: 5l will not contain the code
      needed for x86 instruction layout, for example.
      
      The object file writing code in liblink/obj.c is from cmd/gc/obj.c.
      
      Preparation for golang.org/s/go13linker work.
      
      This CL does not build by itself. It depends on 35740044
      and will be submitted at the same time.
      
      R=iant
      CC=golang-dev
      https://golang.org/cl/35790044
      7d507dc6
    • Russ Cox's avatar
      cmd/dist: add liblink build information · 8642cbd6
      Russ Cox authored
      In addition to adding the library, change the way the anames array is created.
      Previously, it was written to src/cmd/6l/enam.c (and similarly for 5l and 8l)
      and each of the other tools (6g, 6c, 6a) compiled the 6l/enam.c file in addition
      to their own sources.
      
      Now that there is a library shared by all these programs, move the anames
      array into that library. To eliminate name conflicts, name the array after
      the architecture letter: anames5, anames6, anames8.
      
      First step to linker cleanup (golang.org/s/go13linker).
      
      This CL does not build by itself. It depends on the CLs introducing
      liblink and changing commands to use it.
      
      R=iant
      CC=golang-dev
      https://golang.org/cl/35740044
      8642cbd6
  2. 06 Dec, 2013 7 commits
  3. 04 Dec, 2013 2 commits
  4. 03 Dec, 2013 8 commits
    • Carl Shapiro's avatar
      encoding/gob: do not hide an unsafe.Pointer in a uintptr · 77913e9a
      Carl Shapiro authored
      R=golang-dev, r, rsc
      CC=golang-dev
      https://golang.org/cl/23320044
      77913e9a
    • Carl Shapiro's avatar
      runtime: add an allocation and free tracing for gc debugging · 48279bd5
      Carl Shapiro authored
      Output for an allocation and free (sweep) follows
      
      MProf_Malloc(p=0xc2100210a0, size=0x50, type=0x0 <single object>)
              #0 0x46ee15 runtime.mallocgc /usr/local/google/home/cshapiro/go/src/pkg/runtime/malloc.goc:141
              #1 0x47004f runtime.settype_flush /usr/local/google/home/cshapiro/go/src/pkg/runtime/malloc.goc:612
              #2 0x45f92c gc /usr/local/google/home/cshapiro/go/src/pkg/runtime/mgc0.c:2071
              #3 0x45f89e mgc /usr/local/google/home/cshapiro/go/src/pkg/runtime/mgc0.c:2050
              #4 0x45258b runtime.mcall /usr/local/google/home/cshapiro/go/src/pkg/runtime/asm_amd64.s:179
      
      MProf_Free(p=0xc2100210a0, size=0x50)
              #0 0x46ee15 runtime.mallocgc /usr/local/google/home/cshapiro/go/src/pkg/runtime/malloc.goc:141
              #1 0x47004f runtime.settype_flush /usr/local/google/home/cshapiro/go/src/pkg/runtime/malloc.goc:612
              #2 0x45f92c gc /usr/local/google/home/cshapiro/go/src/pkg/runtime/mgc0.c:2071
              #3 0x45f89e mgc /usr/local/google/home/cshapiro/go/src/pkg/runtime/mgc0.c:2050
              #4 0x45258b runtime.mcall /usr/local/google/home/cshapiro/go/src/pkg/runtime/asm_amd64.s:179
      
      R=golang-dev, dvyukov, rsc, cshapiro
      CC=golang-dev
      https://golang.org/cl/21990045
      48279bd5
    • Keith Randall's avatar
      cmd/gc: fix special-casing of the printed names of map internal structures. · f238049a
      Keith Randall authored
      Shaves 1% off of binary size.
      
      update #6853
      
      R=golang-dev, rsc
      CC=golang-dev
      https://golang.org/cl/35940047
      f238049a
    • Carl Shapiro's avatar
      runtime: move stack scanning into the parallel mark phase · 0368a7ce
      Carl Shapiro authored
      This change reduces the cost of the stack scanning by frames.
      It moves the stack scanning from the serial root enumeration
      phase to the parallel tracing phase.  The output that follows
      are timings for the issue 6482 benchmark
      
      Baseline
      
      BenchmarkGoroutineSelect	      50	 108027405 ns/op
      BenchmarkGoroutineBlocking	      50	  89573332 ns/op
      BenchmarkGoroutineForRange	      20	  95614116 ns/op
      BenchmarkGoroutineIdle		      20	 122809512 ns/op
      
      Stack scan by frames, non-parallel
      
      BenchmarkGoroutineSelect	      20	 297138929 ns/op
      BenchmarkGoroutineBlocking	      20	 301137599 ns/op
      BenchmarkGoroutineForRange	      10	 312499469 ns/op
      BenchmarkGoroutineIdle		      10	 209428876 ns/op
      
      Stack scan by frames, parallel
      
      BenchmarkGoroutineSelect	      20	 183938431 ns/op
      BenchmarkGoroutineBlocking	      20	 170109999 ns/op
      BenchmarkGoroutineForRange	      20	 179628882 ns/op
      BenchmarkGoroutineIdle		      20	 157541498 ns/op
      
      The remaining performance disparity is due to inefficiencies
      in gentraceback and its callees.  The effect was isolated by
      using a parallel stack scan where scanstack was modified to do
      a conservative scan of the stack segments without gentraceback
      followed by a call of gentrackback with a no-op callback.
      
      The output that follows are the top-10 most frequent tops of
      stacks as determined by the Linux perf record facility.
      
      Baseline
      
      +  25.19%  gc.test  gc.test            [.] runtime.xchg
      +  19.00%  gc.test  gc.test            [.] scanblock
      +   8.53%  gc.test  gc.test            [.] scanstack
      +   8.46%  gc.test  gc.test            [.] flushptrbuf
      +   5.08%  gc.test  gc.test            [.] procresize
      +   3.57%  gc.test  gc.test            [.] runtime.chanrecv
      +   2.94%  gc.test  gc.test            [.] dequeue
      +   2.74%  gc.test  gc.test            [.] addroots
      +   2.25%  gc.test  gc.test            [.] runtime.ready
      +   1.33%  gc.test  gc.test            [.] runtime.cas64
      
      Gentraceback
      
      +  18.12%  gc.test  gc.test             [.] runtime.xchg
      +  14.68%  gc.test  gc.test             [.] scanblock
      +   8.20%  gc.test  gc.test             [.] runtime.gentraceback
      +   7.38%  gc.test  gc.test             [.] flushptrbuf
      +   6.84%  gc.test  gc.test             [.] scanstack
      +   5.92%  gc.test  gc.test             [.] runtime.findfunc
      +   3.62%  gc.test  gc.test             [.] procresize
      +   3.15%  gc.test  gc.test             [.] readvarint
      +   1.92%  gc.test  gc.test             [.] addroots
      +   1.87%  gc.test  gc.test             [.] runtime.chanrecv
      
      R=golang-dev, dvyukov, rsc
      CC=golang-dev
      https://golang.org/cl/17410043
      0368a7ce
    • Keith Randall's avatar
      runtime: get rid of concatstring's vararg C argument. · 24699fb0
      Keith Randall authored
      Pass as a slice of strings instead.  For 2-5 strings, implement
      dedicated routines so no slices are needed.
      
      static call counts in the go binary:
       2 strings: 342 occurrences
       3 strings:  98
       4 strings:  30
       5 strings:  13
      6+ strings:  14
      
      Why?  C varags, bad for stack scanning and copying.
      
      R=golang-dev, iant
      CC=golang-dev
      https://golang.org/cl/36380043
      24699fb0
    • Keith Randall's avatar
      runtime: fix race detector when map keys/values are passed by pointer. · c0f22945
      Keith Randall authored
      Now that the map implementation is reading the keys and values from
      arbitrary memory (instead of from stack slots), it needs to tell the
      race detector when it does so.
      
      Fixes #6875.
      
      R=golang-dev, dave
      CC=golang-dev
      https://golang.org/cl/36360043
      c0f22945
    • Keith Randall's avatar
      reflect: test to make sure big Zero()-obtained objects are really zero. · 742f755a
      Keith Randall authored
      Update #6876.
      
      R=dave, bradfitz
      CC=golang-dev
      https://golang.org/cl/36370043
      742f755a
    • Keith Randall's avatar
      reflect: fix Zero() implementation - not every type has a · e7d899cb
      Keith Randall authored
      zero object allocated, so we still need to allocate a new
      zero area every time.
      
      Fixes #6876.
      
      R=golang-dev
      CC=golang-dev
      https://golang.org/cl/36320043
      e7d899cb
  5. 02 Dec, 2013 3 commits
  6. 01 Dec, 2013 1 commit
  7. 27 Nov, 2013 1 commit
  8. 25 Nov, 2013 2 commits
  9. 20 Nov, 2013 2 commits
  10. 19 Nov, 2013 2 commits