- 15 Apr, 2016 2 commits
-
-
Kevin Modzelewski authored
I wasn't sure what we would have to do in this case -- we don't really have any way of cleaning up the data referenced by those other threads. Fortunately(?), CPython doesn't do much cleanup of those threads (cleans up their metadata but doesn't try to clean up any references held by the thread), so we don't have to do much either. Just set a flag saying that this happened and that we should skip asserting that we got down to 0 refs.
-
Kevin Modzelewski authored
Our underlying implementation still looks pretty different, but rather than implement some newly-needed APIs completely from scratch, I copied in some of CPython's implementation. The result is a bit messy (multiple ways of doing similar things), but I think it's a step in the right direction. Regardless, this commit adds "clean up thread-local storage when the local object dies" functionality, as well as better cleanup when there are multiple threads. I think this should help with the fork issues as well.
-
- 13 Apr, 2016 14 commits
-
-
Kevin Modzelewski authored
Or rather, add some more refcount-related calls to it to help it get down to zero refs at the end.
-
Kevin Modzelewski authored
Ref nexedi fixing
-
Boxiang Sun authored
-
Kevin Modzelewski authored
I don't quite remember this but I think the goal was to ignore core/from_llvm, not all of core/
-
Kevin Modzelewski authored
I think this adds some pretty heavy debugging that we might not always want, but turning this on is always my first debugging step.
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
instead of using a hardcoded version. This is important since we have some "#ifndef NDEBUG" conditionals in our include files, and we would always compile shared modules in release mode (hence pyston and extension modules would get compiled with different options). Now, a debug build of pyston will build extensions in debug mode.
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
To silence results for passing tests. We have a lot of tests and most of them are passing and are crowding out the failing ones. Also, turn it on when testing on travis-ci
-
- 12 Apr, 2016 19 commits
-
-
Kevin Modzelewski authored
Since we have a dedicated dict_comparisons.py test for tracking that issue
-
Kevin Modzelewski authored
I think this ends up not affecting the interpreter because the interpreter frame (that spawns the thread) ends up keeping the args alive for long enough?
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
It was just an error-message difference.
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
I guess it's good that we have that since it was firing to tell us that we were generating bad assembly.
-
Kevin Modzelewski authored
Will take some more work to actually free thread-locals since we don't expose that I'm surprised we didn't actually free any of that before!
-
Kevin Modzelewski authored
It wasn't decreffing the previous value if there was one
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Marius Wachtler authored
- a lot of the tests were I removed the skip line are failing in the llvm tier - we will have to look at them later - this does not enable the bjit yet
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Marius Wachtler authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
well, ones that aren't quite constant. They can just register their C static variables and then change them at will. The _warnings module does this
-
Kevin Modzelewski authored
It's bad that we need to do that right now, but it's not the job of these tests to test that.
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
- Some missing refcounting annotations - We would allocate before guarding, so if the guards failed we would leak those objects. - The code now treats this conservatively (like it should), which might result in more rewriter aborts. I manually tried to fix the case that was hitting this for now. - Small bug in the llvm-tier type specialization
-
- 11 Apr, 2016 5 commits
-
-
Kevin Modzelewski authored
- simple bug where when clearing the IC I forgot to clear the old list of gc references. - keep gc references alive during the duration of the rewrite. There are some cases where the thing we are guarding on would normally get destroyed by the end of the operation. So make the ref an owned ref. But at the end if we see that we hold the only reference to the object, abort the rewrite (since the guard could never pass in the future)
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
-
Kevin Modzelewski authored
ie a commit that worked around our (previous) lack of refcounting.
-
Kevin Modzelewski authored
-