- 08 Jan, 2015 5 commits
-
-
Kevin Modzelewski authored
I thought it was just an implementation detail, but it has observable effects from Python.
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
Was tricky to find a way to do this while still allowing rewriting. Right now we only attempt rewriting for a whitelisted set of __new__ functions where __new__(cls) always returns an instance of cls.
-
Kevin Modzelewski authored
It's more efficient since __new__ ends up being harder for the JIT to handle than __init__. It's also more correct, though hopefully no one relies on this.
-
- 07 Jan, 2015 14 commits
-
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
Changes here due to the Metadata/Value split. Had some issues with intermediate commits due to leak detecting; not seeing them on this later commit. Hopefully everything is ok...
-
Kevin Modzelewski authored
Also, set "AlignOperands: true" to continue getting that behavior.
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
Primary challenge is rebasing past the JITEventListener changes. Some API changes, but also some considerable functionality changes, since we no longer get the loaded version of the object file. They added a feature to get the load address of a section, but not of a symbol; I think that makes sense so I'll submit a patch for that.
-
Kevin Modzelewski authored
Generators
-
Kevin Modzelewski authored
Previously, we just included a char[] buffer in the generator object, and used that as the stack. Now, mmap() a dedicated stack segment for it. Use MAP_GROWSDOWN so that the stack is automatically expandable, but add a redzone 4MB down to limit the maximum stack size.
-
Kevin Modzelewski authored
Turning off frame introspection can make things easier to debug, but will break features like tracebacks. If we turn it off, instead of trying to collect a traceback and crashing, just print out a warning and return an empty traceback.
-
Kevin Modzelewski authored
Previously it was pretty implicit where we rely on the fact that the generator object will exist on the previous stack, and once we notice the generator its GC handler will crawl the generator stack. I think we also missed the generator's registers, but only the top generator and only if it wasn't the current thread (was unable to reproduce this). Now, keep explicit track of all the previous stacks that a thread had been on. This cleans that up, and since things are explicit now, we can also track where we stopped executing on each stack. We were doing this hackily for the main stack before, but now we can do that for generator stacks, which will let us make those auto-growing as well. My confidence in this change: low.
-
- 06 Jan, 2015 13 commits
-
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
add doxygen
-
Kevin Modzelewski authored
implement viewkeys viewvalues viewitems method on dict object
-
Daniel Agar authored
-
asaka authored
-
Kevin Modzelewski authored
Need to 1) show that a thread is waiting, and 2) signal once we've acquired the GIL. Basically, what happens in acquireGL(). I feel like this isn't the sort of threading code that should be written by hand...
-
Daniel Agar authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
Previously, to allow other threads to acquire the GIL, we would just do a "releaseGIL(); acquireGIL();" and hope that another thread would grab it. The current thread has the best chance of grabbing the GIL again, so I think what's been happening is that it would tend to win the race to reacquire and starve all the other threads. Now, the current thread is forced to wait for at least one other thread to acquire the GIL before it can reaquire it. This means that we're at least fair between two threads, though not necessarily fair between more than that (but at least it's more random and not as stacked towards being unfair).
-
- 05 Jan, 2015 3 commits
-
-
Kevin Modzelewski authored
(update copyright notices)
-
Kevin Modzelewski authored
I'm only seeing "undefined reference to ..." errors in the CMake build on a specific machine; I'm not sure why they're only cropping up in that scenario. I think these functions are only referenced from dead functions, and in other environments the chains get dead-stripped.
-
Kevin Modzelewski authored
(We weren't including all of them)
-
- 04 Jan, 2015 5 commits
-
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
Our previous directory names: include/ lib_python/2.7/ lib_python/2.7_Modules/ lib_python/2.7_Objects/ lib_python/2.7_Python/ new directory names: from_cpython/Include/ from_cpython/Lib/ from_cpython/Modules/ from_cpython/Objects/ from_cpython/Python/ Sorry for the huge diff, but I think this makes way more sense.
-