1. 28 Jul, 2015 1 commit
  2. 25 Jul, 2015 4 commits
  3. 24 Jul, 2015 2 commits
    • Chris Toshok's avatar
      bump travis to using gcc-4.9 · 70d26deb
      Chris Toshok authored
      70d26deb
    • Chris Toshok's avatar
      enable PGO for gcc. · 4d2fcb2f
      Chris Toshok authored
      instead of building twice in the same build dir (which if there's an error can lead
      to using the -fprofile-generate thinking it's the -fprofile-use build), we build the
      -fprofile-generate build as pyston_release_gcc_pgo.  The resulting -fprofile-use build
      is the normal pyston_release_gcc build.
      
      Deps aren't quite there yet, but this should also allows you to re-train the pgo build later
      and then apply the new data to the release build, e.g.:
      
      ```
         $ rm -f ./build/Release-gcc
         $ ./pyston_release_gcc_pgo ${training.py}
         $ make pyston_release_gcc
      ```
      4d2fcb2f
  4. 23 Jul, 2015 26 commits
  5. 22 Jul, 2015 7 commits
    • Kevin Modzelewski's avatar
      Merge pull request #743 from undingen/bjit_omit_fp · 6add43fe
      Kevin Modzelewski authored
      bjit: omit frame pointer + use R12 for ASTInterpreter*
      6add43fe
    • Kevin Modzelewski's avatar
      Inline boxBool more · a8ac40c3
      Kevin Modzelewski authored
      a8ac40c3
    • Kevin Modzelewski's avatar
      Optimize isinstance · d9709d1d
      Kevin Modzelewski authored
      isinstance(obj, cls) needs to do a bunch of dynamic checking: it needs to
      check cls's class to see if it defines __instancecheck__, and it needs
      to fetch __class__ on obj.  Most of those time those aren't overridden,
      so __instancecheck__ gets skipped and __class__ returns the type of the object.
      
      So use the same "type slot" machinery to cache whether an __instancecheck__
      or custom __class__ attribute have gotten added.  These are a bit different
      than the other slots since they are not "wrappers", they are simply bools
      that say whether or not the attribute exists.  This makes the slot handling
      code a bit messier / more divergent from CPython, but I think it still makes
      sense to put this here since we get the hooking-on-attribute-updating and
      update-all-subclasses-as-well automatically.
      d9709d1d
    • Kevin Modzelewski's avatar
      Add pypy's (via US) bm_django · 0251f5fa
      Kevin Modzelewski authored
      0251f5fa
    • Rudi Chen's avatar
      d1eb84d5
    • Marius Wachtler's avatar
      bjit: omit frame pointer + use R12 for ASTInterpreter* · 96027cdb
      Marius Wachtler authored
      This reduces the number of stack access, because previously when we accessed a field of the interpreter
      we always had to load it first from stack into a reg - and now we have a dedicated reg.
      This is currently only a very small perf change but when #736 lands this becomes more important.
      96027cdb
    • Kevin Modzelewski's avatar
      Try caching both the debug and release ccache dirs · 3a75208b
      Kevin Modzelewski authored
      My theory is that specifying the separate cache directories
      interacts badly with travis-ci.  I think it will either delete
      any cache directories that look like they are no longer cached
      (ie when it finishes the debug build it will delete the release
      ccache dir since it looks unused), or maybe it keeps them around
      but only checks the most recent build for a cache hit (ie the
      debug build might check and only find ccache_release).
      
      So anyway, try always specifying both directories.  Another
      option is to do the simpler thing and use a single directory for
      both caches, but I want to only change one thing at a time.
      3a75208b