1. 16 Nov, 2015 3 commits
    • Austin Clements's avatar
      runtime: handle sysReserve returning a pointer below the arena · 0de59c27
      Austin Clements authored
      In mheap.sysAlloc, if an allocation at arena_used would exceed
      arena_end (but wouldn't yet push us past arena_start+_MaxArean32), it
      trie to extend the arena reservation by another 256 MB. It extends the
      arena by calling sysReserve, which, on 32-bit, calls mmap without
      MAP_FIXED, which means the address is just a hint and the kernel can
      put the mapping wherever it wants. In particular, mmap may choose an
      address below arena_start (the kernel also chose arena_start, so there
      could be lots of space below it). Currently, we don't detect this case
      and, if it happens, mheap.sysAlloc will corrupt arena_end and
      arena_used then return the low pointer to mheap.grow, which will crash
      when it attempts to index in to h_spans with an underflowed index.
      
      Fix this by checking not only that that p+p_size isn't too high, but
      that p isn't too low.
      
      Fixes #13143.
      
      Change-Id: I8d0f42bd1484460282a83c6f1a6f8f0df7fb2048
      Reviewed-on: https://go-review.googlesource.com/16927
      Run-TryBot: Austin Clements <austin@google.com>
      TryBot-Result: Gobot Gobot <gobot@golang.org>
      Reviewed-by: default avatarIan Lance Taylor <iant@golang.org>
      0de59c27
    • Austin Clements's avatar
      runtime: avoid stat underflow crash · 97dc5915
      Austin Clements authored
      If the area returned by sysReserve in mheap.sysAlloc is outside the
      usable arena, we sysFree it. We pass a fake stat pointer to sysFree
      because we haven't added the allocation to any stat at that point.
      However, we pass a 0 stat, so sysFree panics when it decrements the
      stat because the fake stat underflows.
      
      Fix this by setting the fake stat to the allocation size.
      
      Updates #13143 (this is a prerequisite to fixing that bug).
      
      Change-Id: I61a6c9be19ac1c95863cf6a8435e19790c8bfc9a
      Reviewed-on: https://go-review.googlesource.com/16926Reviewed-by: default avatarIan Lance Taylor <iant@golang.org>
      97dc5915
    • Marcel van Lohuizen's avatar
      unicode/utf8: removed uses of ranging over string · 9b299c1e
      Marcel van Lohuizen authored
      Ranging over string is much slower than using DecodeRuneInString.
      See golang.org/issue/13162.
      
      Replacing ranging over a string with the implementation of the Bytes
      counterpart results in the following performance improvements:
      
      RuneCountInStringTenASCIIChars-8     43.0ns ± 1%  16.4ns ± 2%  -61.80%  (p=0.000 n=7+8)
      RuneCountInStringTenJapaneseChars-8   161ns ± 2%   154ns ± 2%   -4.58%  (p=0.000 n=8+8)
      ValidStringTenASCIIChars-8           52.2ns ± 1%  13.2ns ± 1%  -74.62%  (p=0.001 n=7+7)
      ValidStringTenJapaneseChars-8         173ns ± 2%   153ns ± 2%  -11.78%  (p=0.000 n=7+8)
      
      Update golang/go#13162
      
      Change-Id: Ifc40a6a94bb3317f1f2d929d310bd2694645e9f6
      Reviewed-on: https://go-review.googlesource.com/16695Reviewed-by: default avatarRuss Cox <rsc@golang.org>
      9b299c1e
  2. 15 Nov, 2015 7 commits
  3. 14 Nov, 2015 12 commits
  4. 13 Nov, 2015 18 commits