1. 02 Jul, 2013 9 commits
  2. 01 Jul, 2013 7 commits
  3. 30 Jun, 2013 1 commit
  4. 28 Jun, 2013 10 commits
  5. 27 Jun, 2013 13 commits
    • Rick Arnold's avatar
      flag: add Getter interface; implement for all Value types · 49b3301f
      Rick Arnold authored
      Fixes #5383.
      
      R=golang-dev, 0xjnml, r, rsc
      CC=golang-dev
      https://golang.org/cl/10472043
      49b3301f
    • Paul van Brouwershaven's avatar
    • Russ Cox's avatar
      cmd/go: add -coverpkg · 97c19f0f
      Russ Cox authored
      The new -coverpkg flag allows computing coverage in
      one set of packages while running the tests of a different set.
      
      Also clean up some of the previous CL's recompileForTest,
      using packageList to avoid the clumsy recursion.
      
      R=golang-dev, r
      CC=golang-dev
      https://golang.org/cl/10705043
      97c19f0f
    • Russ Cox's avatar
      runtime: use gp->sched.sp for stack overflow check · f0d73fbc
      Russ Cox authored
      On x86 it is a few words lower on the stack than m->morebuf.sp
      so it is a more precise check. Enabling the check requires recording
      a valid gp->sched in reflect.call too. This is a good thing in general,
      since it will make stack traces during reflect.call work better, and it
      may be useful for preemption too.
      
      R=dvyukov
      CC=golang-dev
      https://golang.org/cl/10709043
      f0d73fbc
    • Dmitriy Vyukov's avatar
      runtime: fix goroutine status corruption · 4eb17ecd
      Dmitriy Vyukov authored
      runtime.entersyscall() sets g->status = Gsyscall,
      then calls runtime.lock() which causes stack split.
      runtime.newstack() resets g->status to Grunning.
      This will lead to crash during GC (world is not stopped) or GC will scan stack incorrectly.
      
      R=golang-dev, rsc
      CC=golang-dev
      https://golang.org/cl/10696043
      4eb17ecd
    • Frithjof Schulze's avatar
      crypto/tls: Change TLS version to 1.1 in the package comment. · b92b0930
      Frithjof Schulze authored
      Also use 2048-bit RSA keys as default in generate_cert.go,
      as recommended by the NIST.
      
      R=golang-dev, rsc, bradfitz
      CC=golang-dev
      https://golang.org/cl/10676043
      b92b0930
    • Brad Fitzpatrick's avatar
      A+C: Frithjof Schulze (individual CLA) other email · a93fbb53
      Brad Fitzpatrick authored
      Generated by addca, but then manually merged
      the two lines onto one.
      
      R=gobot
      CC=golang-dev
      https://golang.org/cl/10701043
      a93fbb53
    • Adam Langley's avatar
      crypto/elliptic: add constant-time, P-256 implementation. · d2a19e9f
      Adam Langley authored
      On my 64-bit machine, despite being 32-bit code, fixed-base
      multiplications are 7.1x faster and arbitary multiplications are 2.6x
      faster.
      
      It is difficult to review this change. However, the code is essentially
      the same as code that has been open-sourced in Chromium. There it has
      been successfully performing P-256 operations for several months on
      many machines so the arithmetic of the code should be sound.
      
      R=golang-dev, rsc
      CC=golang-dev
      https://golang.org/cl/10551044
      d2a19e9f
    • Dmitriy Vyukov's avatar
      undo CL 9776044 / 1e280889f997 · 7ebb187e
      Dmitriy Vyukov authored
      Failure on bot:
      http://build.golang.org/log/f4c648906e1289ec2237c1d0880fb1a8b1852a08
      
      ««« original CL description
      runtime: fix CPU underutilization
      runtime.newproc/ready are deliberately sloppy about waking new M's,
      they only ensure that there is at least 1 spinning M.
      Currently to compensate for that, schedule() checks if the current P
      has local work and there are no spinning M's, it wakes up another one.
      It does not work if goroutines do not call schedule.
      With this change a spinning M wakes up another M when it finds work to do.
      It's also not ideal, but it fixes the underutilization.
      A proper check would require to know the exact number of runnable G's,
      but it's too expensive to maintain.
      Fixes #5586.
      
      R=rsc
      TBR=rsc
      CC=gobot, golang-dev
      https://golang.org/cl/9776044
      »»»
      
      R=golang-dev
      CC=golang-dev
      https://golang.org/cl/10692043
      7ebb187e
    • Dmitriy Vyukov's avatar
      runtime: fix CPU underutilization · 15a1c3d1
      Dmitriy Vyukov authored
      runtime.newproc/ready are deliberately sloppy about waking new M's,
      they only ensure that there is at least 1 spinning M.
      Currently to compensate for that, schedule() checks if the current P
      has local work and there are no spinning M's, it wakes up another one.
      It does not work if goroutines do not call schedule.
      With this change a spinning M wakes up another M when it finds work to do.
      It's also not ideal, but it fixes the underutilization.
      A proper check would require to know the exact number of runnable G's,
      but it's too expensive to maintain.
      Fixes #5586.
      
      R=rsc
      CC=gobot, golang-dev
      https://golang.org/cl/9776044
      15a1c3d1
    • Dmitriy Vyukov's avatar
      runtime: fix argument printing during traceback · eac6bee7
      Dmitriy Vyukov authored
      Current code can print more arguments than necessary
      and also incorrectly prints "...".
      Update #5723.
      
      R=golang-dev, rsc
      CC=golang-dev
      https://golang.org/cl/10689043
      eac6bee7
    • Rob Pike's avatar
      doc/go1.2.txt: cmd/go and coverage; simple hash Sum functions · 4f2278d4
      Rob Pike authored
      R=golang-dev, dave, rsc
      CC=golang-dev
      https://golang.org/cl/10631043
      4f2278d4
    • Russ Cox's avatar
      runtime: record proper goroutine state during stack split · 6fa3c89b
      Russ Cox authored
      Until now, the goroutine state has been scattered during the
      execution of newstack and oldstack. It's all there, and those routines
      know how to get back to a working goroutine, but other pieces of
      the system, like stack traces, do not. If something does interrupt
      the newstack or oldstack execution, the rest of the system can't
      understand the goroutine. For example, if newstack decides there
      is an overflow and calls throw, the stack tracer wouldn't dump the
      goroutine correctly.
      
      For newstack to save a useful state snapshot, it needs to be able
      to rewind the PC in the function that triggered the split back to
      the beginning of the function. (The PC is a few instructions in, just
      after the call to morestack.) To make that possible, we change the
      prologues to insert a jmp back to the beginning of the function
      after the call to morestack. That is, the prologue used to be roughly:
      
              TEXT myfunc
                      check for split
                      jmpcond nosplit
                      call morestack
              nosplit:
                      sub $xxx, sp
      
      Now an extra instruction is inserted after the call:
      
              TEXT myfunc
              start:
                      check for split
                      jmpcond nosplit
                      call morestack
                      jmp start
              nosplit:
                      sub $xxx, sp
      
      The jmp is not executed directly. It is decoded and simulated by
      runtime.rewindmorestack to discover the beginning of the function,
      and then the call to morestack returns directly to the start label
      instead of to the jump instruction. So logically the jmp is still
      executed, just not by the cpu.
      
      The prologue thus repeats in the case of a function that needs a
      stack split, but against the cost of the split itself, the extra few
      instructions are noise. The repeated prologue has the nice effect of
      making a stack split double-check that the new stack is big enough:
      if morestack happens to return on a too-small stack, we'll now notice
      before corruption happens.
      
      The ability for newstack to rewind to the beginning of the function
      should help preemption too. If newstack decides that it was called
      for preemption instead of a stack split, it now has the goroutine state
      correctly paused if rescheduling is needed, and when the goroutine
      can run again, it can return to the start label on its original stack
      and re-execute the split check.
      
      Here is an example of a split stack overflow showing the full
      trace, without any special cases in the stack printer.
      (This one was triggered by making the split check incorrect.)
      
      runtime: newstack framesize=0x0 argsize=0x18 sp=0x6aebd0 stack=[0x6b0000, 0x6b0fa0]
              morebuf={pc:0x69f5b sp:0x6aebd8 lr:0x0}
              sched={pc:0x68880 sp:0x6aebd0 lr:0x0 ctxt:0x34e700}
      runtime: split stack overflow: 0x6aebd0 < 0x6b0000
      fatal error: runtime: split stack overflow
      
      goroutine 1 [stack split]:
      runtime.mallocgc(0x290, 0x100000000, 0x1)
              /Users/rsc/g/go/src/pkg/runtime/zmalloc_darwin_amd64.c:21 fp=0x6aebd8
      runtime.new()
              /Users/rsc/g/go/src/pkg/runtime/zmalloc_darwin_amd64.c:682 +0x5b fp=0x6aec08
      go/build.(*Context).Import(0x5ae340, 0xc210030c71, 0xa, 0xc2100b4380, 0x1b, ...)
              /Users/rsc/g/go/src/pkg/go/build/build.go:424 +0x3a fp=0x6b00a0
      main.loadImport(0xc210030c71, 0xa, 0xc2100b4380, 0x1b, 0xc2100b42c0, ...)
              /Users/rsc/g/go/src/cmd/go/pkg.go:249 +0x371 fp=0x6b01a8
      main.(*Package).load(0xc21017c800, 0xc2100b42c0, 0xc2101828c0, 0x0, 0x0, ...)
              /Users/rsc/g/go/src/cmd/go/pkg.go:431 +0x2801 fp=0x6b0c98
      main.loadPackage(0x369040, 0x7, 0xc2100b42c0, 0x0)
              /Users/rsc/g/go/src/cmd/go/pkg.go:709 +0x857 fp=0x6b0f80
      ----- stack segment boundary -----
      main.(*builder).action(0xc2100902a0, 0x0, 0x0, 0xc2100e6c00, 0xc2100e5750, ...)
              /Users/rsc/g/go/src/cmd/go/build.go:539 +0x437 fp=0x6b14a0
      main.(*builder).action(0xc2100902a0, 0x0, 0x0, 0xc21015b400, 0x2, ...)
              /Users/rsc/g/go/src/cmd/go/build.go:528 +0x1d2 fp=0x6b1658
      main.(*builder).test(0xc2100902a0, 0xc210092000, 0x0, 0x0, 0xc21008ff60, ...)
              /Users/rsc/g/go/src/cmd/go/test.go:622 +0x1b53 fp=0x6b1f68
      ----- stack segment boundary -----
      main.runTest(0x5a6b20, 0xc21000a020, 0x2, 0x2)
              /Users/rsc/g/go/src/cmd/go/test.go:366 +0xd09 fp=0x6a5cf0
      main.main()
              /Users/rsc/g/go/src/cmd/go/main.go:161 +0x4f9 fp=0x6a5f78
      runtime.main()
              /Users/rsc/g/go/src/pkg/runtime/proc.c:183 +0x92 fp=0x6a5fa0
      runtime.goexit()
              /Users/rsc/g/go/src/pkg/runtime/proc.c:1266 fp=0x6a5fa8
      
      And here is a seg fault during oldstack:
      
      SIGSEGV: segmentation violation
      PC=0x1b2a6
      
      runtime.oldstack()
              /Users/rsc/g/go/src/pkg/runtime/stack.c:159 +0x76
      runtime.lessstack()
              /Users/rsc/g/go/src/pkg/runtime/asm_amd64.s:270 +0x22
      
      goroutine 1 [stack unsplit]:
      fmt.(*pp).printArg(0x2102e64e0, 0xe5c80, 0x2102c9220, 0x73, 0x0, ...)
              /Users/rsc/g/go/src/pkg/fmt/print.go:818 +0x3d3 fp=0x221031e6f8
      fmt.(*pp).doPrintf(0x2102e64e0, 0x12fb20, 0x2, 0x221031eb98, 0x1, ...)
              /Users/rsc/g/go/src/pkg/fmt/print.go:1183 +0x15cb fp=0x221031eaf0
      fmt.Sprintf(0x12fb20, 0x2, 0x221031eb98, 0x1, 0x1, ...)
              /Users/rsc/g/go/src/pkg/fmt/print.go:234 +0x67 fp=0x221031eb40
      flag.(*stringValue).String(0x2102c9210, 0x1, 0x0)
              /Users/rsc/g/go/src/pkg/flag/flag.go:180 +0xb3 fp=0x221031ebb0
      flag.(*FlagSet).Var(0x2102f6000, 0x293d38, 0x2102c9210, 0x143490, 0xa, ...)
              /Users/rsc/g/go/src/pkg/flag/flag.go:633 +0x40 fp=0x221031eca0
      flag.(*FlagSet).StringVar(0x2102f6000, 0x2102c9210, 0x143490, 0xa, 0x12fa60, ...)
              /Users/rsc/g/go/src/pkg/flag/flag.go:550 +0x91 fp=0x221031ece8
      flag.(*FlagSet).String(0x2102f6000, 0x143490, 0xa, 0x12fa60, 0x0, ...)
              /Users/rsc/g/go/src/pkg/flag/flag.go:563 +0x87 fp=0x221031ed38
      flag.String(0x143490, 0xa, 0x12fa60, 0x0, 0x161950, ...)
              /Users/rsc/g/go/src/pkg/flag/flag.go:570 +0x6b fp=0x221031ed80
      testing.init()
              /Users/rsc/g/go/src/pkg/testing/testing.go:-531 +0xbb fp=0x221031edc0
      strings_test.init()
              /Users/rsc/g/go/src/pkg/strings/strings_test.go:1115 +0x62 fp=0x221031ef70
      main.init()
              strings/_test/_testmain.go:90 +0x3d fp=0x221031ef78
      runtime.main()
              /Users/rsc/g/go/src/pkg/runtime/proc.c:180 +0x8a fp=0x221031efa0
      runtime.goexit()
              /Users/rsc/g/go/src/pkg/runtime/proc.c:1269 fp=0x221031efa8
      
      goroutine 2 [runnable]:
      runtime.MHeap_Scavenger()
              /Users/rsc/g/go/src/pkg/runtime/mheap.c:438
      runtime.goexit()
              /Users/rsc/g/go/src/pkg/runtime/proc.c:1269
      created by runtime.main
              /Users/rsc/g/go/src/pkg/runtime/proc.c:166
      
      rax     0x23ccc0
      rbx     0x23ccc0
      rcx     0x0
      rdx     0x38
      rdi     0x2102c0170
      rsi     0x221032cfe0
      rbp     0x221032cfa0
      rsp     0x7fff5fbff5b0
      r8      0x2102c0120
      r9      0x221032cfa0
      r10     0x221032c000
      r11     0x104ce8
      r12     0xe5c80
      r13     0x1be82baac718
      r14     0x13091135f7d69200
      r15     0x0
      rip     0x1b2a6
      rflags  0x10246
      cs      0x2b
      fs      0x0
      gs      0x0
      
      Fixes #5723.
      
      R=r, dvyukov, go.peter.90, dave, iant
      CC=golang-dev
      https://golang.org/cl/10360048
      6fa3c89b