Commit 0460ca63 authored by Kevin Modzelewski's avatar Kevin Modzelewski

Interpreter: refcount safety for signals

We would leak refs if an exception was thrown via the pending-calls handler.
parent cbed4274
......@@ -1012,6 +1012,8 @@ Value ASTInterpreter::visit_stmt(AST_stmt* node) {
// ignore those while interpreting.
if ((((AST_Expr*)node)->value)->type != AST_TYPE::Str) {
rtn = visit_expr((AST_Expr*)node);
Py_DECREF(rtn.o);
rtn = Value();
ASTInterpreterJitInterface::pendingCallsCheckHelper();
}
break;
......@@ -1028,8 +1030,13 @@ Value ASTInterpreter::visit_stmt(AST_stmt* node) {
break;
case AST_TYPE::Return:
rtn = visit_return((AST_Return*)node);
try {
ASTInterpreterJitInterface::pendingCallsCheckHelper();
break;
} catch (ExcInfo e) {
Py_DECREF(rtn.o);
throw e;
}
return rtn;
case AST_TYPE::Global:
rtn = visit_global((AST_Global*)node);
ASTInterpreterJitInterface::pendingCallsCheckHelper();
......@@ -1041,13 +1048,20 @@ Value ASTInterpreter::visit_stmt(AST_stmt* node) {
break;
case AST_TYPE::Jump:
rtn = visit_jump((AST_Jump*)node);
break;
return rtn;
case AST_TYPE::Invoke:
rtn = visit_invoke((AST_Invoke*)node);
break;
default:
RELEASE_ASSERT(0, "not implemented");
};
// This assertion tries to make sure that we are refcount-safe if an exception
// is thrown from pendingCallsCheckHelper. Any statement that returns a value needs
// to be careful to wrap pendingCallsCheckHelper, and it can signal that it was careful
// by returning from the function instead of breaking.
assert(!rtn.o);
return rtn;
}
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment