1. 06 Apr, 2016 2 commits
  2. 05 Apr, 2016 12 commits
  3. 04 Apr, 2016 9 commits
    • Kevin Modzelewski's avatar
      these tests are passing now · 84bee77c
      Kevin Modzelewski authored
      I think they were timing out before
      84bee77c
    • Kevin Modzelewski's avatar
      Low-tech optimization: add xdecrefAll() function · 19ed7064
      Kevin Modzelewski authored
      For use on the exception path.  Rather than emitting the instructions
      for a bunch of decrefs, instead just emit a single call to xdecrefAll()
      
      Improves performance quite a lot: sre_parse_parse llvm instructions goes
      from 360k to 80k, and it's 60k if I manually disable cxx fixups.
      Overall time [which is entirely compile time] goes from 12.5s to 4.4s,
      though master does it in 1.3s so there's still some work to do.  But
      even if I turn off cxx fixups entirely it still takes 2.9s.
      19ed7064
    • Kevin Modzelewski's avatar
      Generate cxx "fixups" on-demand · 21b20e3b
      Kevin Modzelewski authored
      fixups aka the stubs that decref whatever's needed when an exception is thrown
      
      I looked into this because most (75%?) of the refcounting overhead
      comes from the cxx fixups.  Previously we would always generate them in
      the IRGenerator, regardless of whether they were needed.  Now they are
      generated in the refcounter, which knows whether they are needed or not.
      
      Unfortunately it looks like they are usually needed, so the gains here
      aren't that great (saves about 10% llvm instructions whereas cxx fixups
      in general added about 400% more llvm instructions).
      
      I think this is still a good change because it's also necessary in order to use
      Marius's EH stuff.
      
      I think the cost of the fixups is mostly related to the cost of the decrefs
      that it adds, so even though most of the refcounting overhead seems to be due to
      adding the cxx fixups, reducing general decref overhead might reduce cxx fixup overhead
      21b20e3b
    • Boxiang Sun's avatar
      small refcounting fixing in tuple · b2f3653a
      Boxiang Sun authored
      b2f3653a
    • Kevin Modzelewski's avatar
      Count the number of llvm instructions · 7b95f4d5
      Kevin Modzelewski authored
      7b95f4d5
    • Kevin Modzelewski's avatar
      Format! · fcf746df
      Kevin Modzelewski authored
      Any existing work on top of the unformatted branch might have a hard time
      merging -- it should work ok to do a format on top of your changes and then
      merge with this commit.
      fcf746df
    • Kevin Modzelewski's avatar
      This test is working now · 7e955a99
      Kevin Modzelewski authored
      7e955a99
    • Kevin Modzelewski's avatar
      Fix a few more list refcount issues · 5a03ae22
      Kevin Modzelewski authored
      5a03ae22
    • Kevin Modzelewski's avatar
      Fix a bug in list.__index__ · 8b483912
      Kevin Modzelewski authored
      I think this exists on master as well.
      8b483912
  4. 02 Apr, 2016 4 commits
  5. 01 Apr, 2016 5 commits
  6. 31 Mar, 2016 6 commits
  7. 30 Mar, 2016 2 commits
    • Kevin Modzelewski's avatar
      Fix some bugs that made None createable · 0eca1ddb
      Kevin Modzelewski authored
      Copy over tp_new_wrapper, which is the main thing that should be doing the check.
      Our implementation was pretty much the same minus that check.
      
      There's also a separate check that isn't completely necessary but seems like a good idea,
      and we had it on certain codepaths, and whether you hit it depended on whether you were
      in CAPI mode or not.
      0eca1ddb
    • Kevin Modzelewski's avatar
      these are working · 0e2566d1
      Kevin Modzelewski authored
      0e2566d1