1. 11 Apr, 2012 5 commits
    • Adam Langley's avatar
      crypto/tls: update how we create testing scripts. · 7247dcab
      Adam Langley authored
      crypto/tls is tested, in part, by replaying recorded TLS connections
      and checking that the bytes sent by the Go code haven't changed.
      
      Previously we used GnuTLS's debug output and extracted the bytes of
      the TLS connection using a Python script. That wasn't great, and I
      think GnuTLS removed that level of debugging in a more current
      release.
      
      This change records the connection with Go code and adds a test for
      ECDHE-AES clients generating using this method.
      
      R=golang-dev, rsc
      CC=golang-dev
      https://golang.org/cl/5988048
      7247dcab
    • Marcel van Lohuizen's avatar
      exp/norm: exposed runeInfo type in API. · 98aa4968
      Marcel van Lohuizen authored
      For completeness, we also expose the Canonical Combining Class of a rune.
      This does not increase the data size.
      
      R=r
      CC=golang-dev
      https://golang.org/cl/5931043
      98aa4968
    • Dave Cheney's avatar
      runtime: add interface microbenchmarks · d8e9b04c
      Dave Cheney authored
      2011 Mac Mini, Core i5 @ 2.3Ghz
      
      BenchmarkConvT2E        50000000                40.4 ns/op
      BenchmarkConvT2EBig     20000000               107 ns/op
      BenchmarkConvT2I        100000000               28.9 ns/op
      BenchmarkConvI2E        500000000                5.93 ns/op
      BenchmarkConvI2I        100000000               19.0 ns/op
      BenchmarkAssertE2T      100000000               14.1 ns/op
      BenchmarkAssertE2TBig   100000000               17.8 ns/op
      BenchmarkAssertE2I      100000000               21.3 ns/op
      BenchmarkAssertI2T      100000000               14.3 ns/op
      BenchmarkAssertI2I      100000000               20.8 ns/op
      BenchmarkAssertI2E      500000000                5.58 ns/op
      
      Pandaboard, 2 x Omap4 @ 1.2Ghz
      
      BenchmarkConvT2E        10000000               215 ns/op
      BenchmarkConvT2EBig      1000000              3697 ns/op
      BenchmarkConvT2I         5000000               666 ns/op
      BenchmarkConvI2E        50000000                42.4 ns/op
      BenchmarkConvI2I         5000000               489 ns/op
      BenchmarkAssertE2T      20000000                90.0 ns/op
      BenchmarkAssertE2TBig   20000000                91.6 ns/op
      BenchmarkAssertE2I       5000000               515 ns/op
      BenchmarkAssertI2T      20000000               124 ns/op
      BenchmarkAssertI2I       5000000               517 ns/op
      BenchmarkAssertI2E      50000000                47.2 ns/op
      BenchmarkAssertE2E      50000000                42.7 ns/op
      
      R=minux.ma, rsc, fullung, bsiegert, dsymonds
      CC=golang-dev
      https://golang.org/cl/5777048
      d8e9b04c
    • Joel Sing's avatar
      runtime: update openbsd thread related syscalls to match kernel · 8cea1bf1
      Joel Sing authored
      Update the threxit and thrsleep syscalls to match the ABI of the
      OpenBSD 5.1 kernel. These changes are backwards compatible with
      older kernels.
      
      Fixes #3311.
      
      R=golang-dev, rsc, devon.odell
      CC=golang-dev
      https://golang.org/cl/5777079
      8cea1bf1
    • Dave Cheney's avatar
      doc: fix minor typo in Go 1 release notes · d7bc644b
      Dave Cheney authored
      Fixes #3478.
      
      R=golang-dev, rsc
      CC=golang-dev
      https://golang.org/cl/5986074
      d7bc644b
  2. 10 Apr, 2012 16 commits
  3. 09 Apr, 2012 8 commits
    • Rob Pike's avatar
      runtime.Callers: make documentation match code · 6849c4db
      Rob Pike authored
      It is a bug that Caller and Callers disagree about the offset of the skip
      parameter. Document the bug.
      
      R=rsc, dsymonds, r, iant
      CC=golang-dev
      https://golang.org/cl/5976064
      6849c4db
    • Alexey Borzenkov's avatar
      cmd/dist: don't fail when Mercurial is a batch file on Windows · 0669261a
      Alexey Borzenkov authored
      On windows Mercurial installed with easy_install typically creates
      an hg.bat batch file in Python Scripts directory, which cannot be used
      with CreateProcess unless full path is specified. Work around by
      launching hg via cmd.exe /c.
      
      Additionally, fix a rare FormatMessageW crash.
      
      Fixes #3093.
      
      R=golang-dev, rsc, alex.brainman, aram, jdpoirier, mattn.jp
      CC=golang-dev
      https://golang.org/cl/5937043
      0669261a
    • Benny Siegert's avatar
      cmd/yacc: spring cleaning for units.y · f6d582db
      Benny Siegert authored
      * sort imports
      * use runtime.GOROOT
      * fix some typos
      
      R=golang-dev, dave, rsc
      CC=golang-dev
      https://golang.org/cl/5987054
      f6d582db
    • Brad Fitzpatrick's avatar
      debug/gosym: in test, use temp binary name in /tmp, and clean up. · 494fe3b0
      Brad Fitzpatrick authored
      This fixes all.bash on shared machines.
      
      R=golang-dev, rsc
      CC=golang-dev
      https://golang.org/cl/5992078
      494fe3b0
    • Shenghou Ma's avatar
      doc/code: update newmath.Sqrt test case to make sure test succeed · 25e02d51
      Shenghou Ma authored
              Fixes #3445.
      
      R=golang-dev, rsc, mtj
      CC=golang-dev
      https://golang.org/cl/5975061
      25e02d51
    • Shenghou Ma's avatar
      doc/go_spec: fix a typo · 9bc8dd39
      Shenghou Ma authored
      R=golang-dev, rsc
      CC=golang-dev
      https://golang.org/cl/5989065
      9bc8dd39
    • Shenghou Ma's avatar
      build: run.bash no longer accepts --no-banner · 149983f1
      Shenghou Ma authored
      R=golang-dev, rsc
      CC=golang-dev
      https://golang.org/cl/5986063
      149983f1
    • Dmitriy Vyukov's avatar
      runtime: preparation for parallel GC · 342658bb
      Dmitriy Vyukov authored
      make MHeap.allspans an array instead on a linked-list,
      it's required for parallel for
      
      benchmark                              old ns/op    new ns/op    delta
      
      garbage.BenchmarkTree                  494435529    487962705   -1.31%
      garbage.BenchmarkTree-2                499652705    485358000   -2.86%
      garbage.BenchmarkTree-4                468482117    454093117   -3.07%
      garbage.BenchmarkTree-8                488533235    471872470   -3.41%
      garbage.BenchmarkTree-16               507835176    492558470   -3.01%
      
      garbage.BenchmarkTree2                  31453900     31404300   -0.16%
      garbage.BenchmarkTree2-2                21440600     21477000   +0.17%
      garbage.BenchmarkTree2-4                10982000     11117400   +1.23%
      garbage.BenchmarkTree2-8                 7544700      7456700   -1.17%
      garbage.BenchmarkTree2-16                7049500      6805700   -3.46%
      
      garbage.BenchmarkParser               4448988000   4453264000   +0.10%
      garbage.BenchmarkParser-2             4086045000   4057948000   -0.69%
      garbage.BenchmarkParser-4             3677365000   3661246000   -0.44%
      garbage.BenchmarkParser-8             3517253000   3540190000   +0.65%
      garbage.BenchmarkParser-16            3506562000   3463478000   -1.23%
      
      garbage.BenchmarkTreePause              20969784     21100238   +0.62%
      garbage.BenchmarkTreePause-2            20215875     20139572   -0.38%
      garbage.BenchmarkTreePause-4            17240709     16683624   -3.23%
      garbage.BenchmarkTreePause-8            18196386     17639306   -3.06%
      garbage.BenchmarkTreePause-16           20621158     20215056   -1.97%
      
      garbage.BenchmarkTree2Pause            173992142    173872380   -0.07%
      garbage.BenchmarkTree2Pause-2          131281904    131366666   +0.06%
      garbage.BenchmarkTree2Pause-4           93484952     95109619   +1.74%
      garbage.BenchmarkTree2Pause-8           88950523     86533333   -2.72%
      garbage.BenchmarkTree2Pause-16          86071238     84089190   -2.30%
      
      garbage.BenchmarkParserPause           135815000    135255952   -0.41%
      garbage.BenchmarkParserPause-2          92691523     91451428   -1.34%
      garbage.BenchmarkParserPause-4          53392190     51611904   -3.33%
      garbage.BenchmarkParserPause-8          36059523     35116666   -2.61%
      garbage.BenchmarkParserPause-16         30174300     27340600   -9.39%
      
      garbage.BenchmarkTreeLastPause          28420000     29142000   +2.54%
      garbage.BenchmarkTreeLastPause-2        23514000     26779000  +13.89%
      garbage.BenchmarkTreeLastPause-4        21773000     18660000  -14.30%
      garbage.BenchmarkTreeLastPause-8        24072000     21276000  -11.62%
      garbage.BenchmarkTreeLastPause-16       25149000     28541000  +13.49%
      
      garbage.BenchmarkTree2LastPause        314491000    313982000   -0.16%
      garbage.BenchmarkTree2LastPause-2      214363000    214715000   +0.16%
      garbage.BenchmarkTree2LastPause-4      109778000    111115000   +1.22%
      garbage.BenchmarkTree2LastPause-8       75390000     74522000   -1.15%
      garbage.BenchmarkTree2LastPause-16      70333000     67880000   -3.49%
      
      garbage.BenchmarkParserLastPause       327247000    326815000   -0.13%
      garbage.BenchmarkParserLastPause-2     217039000    212529000   -2.08%
      garbage.BenchmarkParserLastPause-4     119722000    111535000   -6.84%
      garbage.BenchmarkParserLastPause-8      70806000     69613000   -1.68%
      garbage.BenchmarkParserLastPause-16     62813000     48009000  -23.57%
      
      R=rsc, r
      CC=golang-dev
      https://golang.org/cl/5992055
      342658bb
  4. 07 Apr, 2012 2 commits
    • Dmitriy Vyukov's avatar
      runtime: add memory prefetching to GC · f09e63a2
      Dmitriy Vyukov authored
      benchmark                              old ns/op    new ns/op    delta
      
      garbage.BenchmarkParser               4448988000   4370531000   -1.76%
      garbage.BenchmarkParser-2             4086045000   4023083000   -1.54%
      garbage.BenchmarkParser-4             3677365000   3667020000   -0.28%
      garbage.BenchmarkParser-8             3517253000   3543946000   +0.76%
      garbage.BenchmarkParser-16            3506562000   3512518000   +0.17%
      
      garbage.BenchmarkTree                  494435529    505784058   +2.30%
      garbage.BenchmarkTree-2                499652705    502774823   +0.62%
      garbage.BenchmarkTree-4                468482117    465713352   -0.59%
      garbage.BenchmarkTree-8                488533235    482287000   -1.28%
      garbage.BenchmarkTree-16               507835176    500654882   -1.41%
      
      garbage.BenchmarkTree2                  31453900     28804600   -8.42%
      garbage.BenchmarkTree2-2                21440600     19065800  -11.08%
      garbage.BenchmarkTree2-4                10982000     10009100   -8.86%
      garbage.BenchmarkTree2-8                 7544700      6479800  -14.11%
      garbage.BenchmarkTree2-16                7049500      6163200  -12.57%
      
      garbage.BenchmarkParserPause           135815000    125360666   -7.70%
      garbage.BenchmarkParserPause-2          92691523     84365476   -8.98%
      garbage.BenchmarkParserPause-4          53392190     46995809  -11.98%
      garbage.BenchmarkParserPause-8          36059523     30998900  -14.03%
      garbage.BenchmarkParserPause-16         30174300     27613350   -8.49%
      
      garbage.BenchmarkTreePause              20969784     22568102   +7.62%
      garbage.BenchmarkTreePause-2            20215875     20975130   +3.76%
      garbage.BenchmarkTreePause-4            17240709     17180666   -0.35%
      garbage.BenchmarkTreePause-8            18196386     18205870   +0.05%
      garbage.BenchmarkTreePause-16           20621158     20486867   -0.65%
      
      garbage.BenchmarkTree2Pause            173992142    159995285   -8.04%
      garbage.BenchmarkTree2Pause-2          131281904    118013714  -10.11%
      garbage.BenchmarkTree2Pause-4           93484952     85092666   -8.98%
      garbage.BenchmarkTree2Pause-8           88950523     77340809  -13.05%
      garbage.BenchmarkTree2Pause-16          86071238     76557952  -11.05%
      
      garbage.BenchmarkParserLastPause       327247000    288205000  -11.93%
      garbage.BenchmarkParserLastPause-2     217039000    187336000  -13.69%
      garbage.BenchmarkParserLastPause-4     119722000    105069000  -12.24%
      garbage.BenchmarkParserLastPause-8      70806000     64755000   -8.55%
      garbage.BenchmarkParserLastPause-16     62813000     53486000  -14.85%
      
      garbage.BenchmarkTreeLastPause          28420000     29735000   +4.63%
      garbage.BenchmarkTreeLastPause-2        23514000     25427000   +8.14%
      garbage.BenchmarkTreeLastPause-4        21773000     19548000  -10.22%
      garbage.BenchmarkTreeLastPause-8        24072000     24046000   -0.11%
      garbage.BenchmarkTreeLastPause-16       25149000     25291000   +0.56%
      
      garbage.BenchmarkTree2LastPause        314491000    287988000   -8.43%
      garbage.BenchmarkTree2LastPause-2      214363000    190616000  -11.08%
      garbage.BenchmarkTree2LastPause-4      109778000    100052000   -8.86%
      garbage.BenchmarkTree2LastPause-8       75390000     64753000  -14.11%
      garbage.BenchmarkTree2LastPause-16      70333000     61484000  -12.58%
      
      FTR, below are result with the empty prefetch function,
      that is, single RET but no real prefetching.
      It suggests that inlinable PREFETCH is worth pursuing.
      
      benchmark                              old ns/op    new ns/op    delta
      
      garbage.BenchmarkParser               4448988000   4560488000   +2.51%
      garbage.BenchmarkParser-2             4086045000   4129728000   +1.07%
      garbage.BenchmarkParser-4             3677365000   3728672000   +1.40%
      garbage.BenchmarkParser-8             3517253000   3583968000   +1.90%
      garbage.BenchmarkParser-16            3506562000   3591414000   +2.42%
      
      garbage.BenchmarkTree                  494435529    499580882   +1.04%
      garbage.BenchmarkTree-4                468482117    467387294   -0.23%
      garbage.BenchmarkTree-8                488533235    478311117   -2.09%
      garbage.BenchmarkTree-2                499652705    499324235   -0.07%
      garbage.BenchmarkTree-16               507835176    502005705   -1.15%
      
      garbage.BenchmarkTree2                  31453900     33296800   +5.86%
      garbage.BenchmarkTree2-2                21440600     22466400   +4.78%
      garbage.BenchmarkTree2-4                10982000     11402700   +3.83%
      garbage.BenchmarkTree2-8                 7544700      7476500   -0.90%
      garbage.BenchmarkTree2-16                7049500      7338200   +4.10%
      
      garbage.BenchmarkParserPause           135815000    139529142   +2.73%
      garbage.BenchmarkParserPause-2          92691523     95229190   +2.74%
      garbage.BenchmarkParserPause-4          53392190     53083476   -0.58%
      garbage.BenchmarkParserPause-8          36059523     34594800   -4.06%
      garbage.BenchmarkParserPause-16         30174300     30063300   -0.37%
      
      garbage.BenchmarkTreePause              20969784     21866920   +4.28%
      garbage.BenchmarkTreePause-2            20215875     20731125   +2.55%
      garbage.BenchmarkTreePause-4            17240709     17275837   +0.20%
      garbage.BenchmarkTreePause-8            18196386     17898777   -1.64%
      garbage.BenchmarkTreePause-16           20621158     20662772   +0.20%
      
      garbage.BenchmarkTree2Pause            173992142    184336857   +5.95%
      garbage.BenchmarkTree2Pause-2          131281904    138005714   +5.12%
      garbage.BenchmarkTree2Pause-4           93484952     98449238   +5.31%
      garbage.BenchmarkTree2Pause-8           88950523     89286095   +0.38%
      garbage.BenchmarkTree2Pause-16          86071238     89568666   +4.06%
      
      garbage.BenchmarkParserLastPause       327247000    342189000   +4.57%
      garbage.BenchmarkParserLastPause-2     217039000    217224000   +0.09%
      garbage.BenchmarkParserLastPause-4     119722000    121327000   +1.34%
      garbage.BenchmarkParserLastPause-8      70806000     71941000   +1.60%
      garbage.BenchmarkParserLastPause-16     62813000     60166000   -4.21%
      
      garbage.BenchmarkTreeLastPause          28420000     27840000   -2.04%
      garbage.BenchmarkTreeLastPause-2        23514000     27390000  +16.48%
      garbage.BenchmarkTreeLastPause-4        21773000     21414000   -1.65%
      garbage.BenchmarkTreeLastPause-8        24072000     21705000   -9.83%
      garbage.BenchmarkTreeLastPause-16       25149000     23932000   -4.84%
      
      garbage.BenchmarkTree2LastPause        314491000    332894000   +5.85%
      garbage.BenchmarkTree2LastPause-2      214363000    224611000   +4.78%
      garbage.BenchmarkTree2LastPause-4      109778000    113976000   +3.82%
      garbage.BenchmarkTree2LastPause-8       75390000     67223000  -10.83%
      garbage.BenchmarkTree2LastPause-16      70333000     73216000   +4.10%
      
      R=golang-dev, rsc
      CC=golang-dev
      https://golang.org/cl/5991057
      f09e63a2
    • Bobby Powers's avatar
      time: in Format give buffer an initial capacity · c9529e02
      Bobby Powers authored
      I have a small web server that simply sets several cookies
      along with an expires header, and then returns.  In the
      cpuprofile for a 200k request benchmark, time.Time.Format()
      was showing up as 8.3% of cpu usage.  Giving the buffer an
      inital capacity to avoid reallocs on append drops it down to
      7.6%.
      
      R=golang-dev, r
      CC=golang-dev
      https://golang.org/cl/5992058
      c9529e02
  5. 06 Apr, 2012 2 commits
  6. 05 Apr, 2012 7 commits