Commit cefce6a5 authored by Kevin Modzelewski's avatar Kevin Modzelewski

Rip out the vestiges of the old vref-counting system

parent c9b0d8f9
...@@ -117,9 +117,7 @@ public: ...@@ -117,9 +117,7 @@ public:
static CompilerVariable* makeIM(CompilerVariable* obj, CompilerVariable* func, CompilerVariable* im_class) { static CompilerVariable* makeIM(CompilerVariable* obj, CompilerVariable* func, CompilerVariable* im_class) {
CompilerVariable* rtn = new ValuedCompilerVariable<RawInstanceMethod*>( CompilerVariable* rtn = new ValuedCompilerVariable<RawInstanceMethod*>(
InstanceMethodType::get(obj->getType(), func->getType()), new RawInstanceMethod(obj, func, im_class), true); InstanceMethodType::get(obj->getType(), func->getType()), new RawInstanceMethod(obj, func, im_class));
obj->incvref();
func->incvref();
return rtn; return rtn;
} }
...@@ -136,14 +134,6 @@ public: ...@@ -136,14 +134,6 @@ public:
return "instanceMethod(" + obj_type->debugName() + " ; " + function_type->debugName() + ")"; return "instanceMethod(" + obj_type->debugName() + " ; " + function_type->debugName() + ")";
} }
void drop(IREmitter& emitter, VAR* var) override {
checkVar(var);
RawInstanceMethod* val = var->getValue();
val->obj->decvref(emitter);
val->func->decvref(emitter);
delete val;
}
CompilerVariable* call(IREmitter& emitter, const OpInfo& info, ValuedCompilerVariable<RawInstanceMethod*>* var, CompilerVariable* call(IREmitter& emitter, const OpInfo& info, ValuedCompilerVariable<RawInstanceMethod*>* var,
ArgPassSpec argspec, const std::vector<CompilerVariable*>& args, ArgPassSpec argspec, const std::vector<CompilerVariable*>& args,
const std::vector<BoxedString*>* keyword_names) override { const std::vector<BoxedString*>* keyword_names) override {
...@@ -172,10 +162,7 @@ public: ...@@ -172,10 +162,7 @@ public:
llvm::Value* boxed = emitter.getBuilder()->CreateCall3(g.funcs.boxInstanceMethod, obj->getValue(), llvm::Value* boxed = emitter.getBuilder()->CreateCall3(g.funcs.boxInstanceMethod, obj->getValue(),
func->getValue(), im_class->getValue()); func->getValue(), im_class->getValue());
obj->decvref(emitter); return new ConcreteCompilerVariable(other_type, boxed);
func->decvref(emitter);
return new ConcreteCompilerVariable(other_type, boxed, true);
} }
CompilerVariable* dup(VAR* var, DupCache& cache) override { CompilerVariable* dup(VAR* var, DupCache& cache) override {
checkVar(var); checkVar(var);
...@@ -185,9 +172,7 @@ public: ...@@ -185,9 +172,7 @@ public:
RawInstanceMethod* im = var->getValue(); RawInstanceMethod* im = var->getValue();
RawInstanceMethod* new_im RawInstanceMethod* new_im
= new RawInstanceMethod(im->obj->dup(cache), im->func->dup(cache), im->im_class->dup(cache)); = new RawInstanceMethod(im->obj->dup(cache), im->func->dup(cache), im->im_class->dup(cache));
rtn = new VAR(this, new_im, var->isGrabbed()); rtn = new VAR(this, new_im);
while (rtn->getVrefs() < var->getVrefs())
rtn->incvref();
} }
return rtn; return rtn;
} }
...@@ -209,7 +194,6 @@ std::unordered_map<std::pair<CompilerType*, CompilerType*>, InstanceMethodType*> ...@@ -209,7 +194,6 @@ std::unordered_map<std::pair<CompilerType*, CompilerType*>, InstanceMethodType*>
ConcreteCompilerVariable* ConcreteCompilerType::makeConverted(IREmitter& emitter, ConcreteCompilerVariable* var, ConcreteCompilerVariable* ConcreteCompilerType::makeConverted(IREmitter& emitter, ConcreteCompilerVariable* var,
ConcreteCompilerType* other_type) { ConcreteCompilerType* other_type) {
if (other_type == this) { if (other_type == this) {
var->incvref();
return var; return var;
} }
printf("makeConverted not defined for %s\n", debugName().c_str()); printf("makeConverted not defined for %s\n", debugName().c_str());
...@@ -218,9 +202,7 @@ ConcreteCompilerVariable* ConcreteCompilerType::makeConverted(IREmitter& emitter ...@@ -218,9 +202,7 @@ ConcreteCompilerVariable* ConcreteCompilerType::makeConverted(IREmitter& emitter
CompilerVariable* ConcreteCompilerType::dup(ConcreteCompilerVariable* v, DupCache& cache) { CompilerVariable* ConcreteCompilerType::dup(ConcreteCompilerVariable* v, DupCache& cache) {
auto& rtn = cache[v]; auto& rtn = cache[v];
if (rtn == NULL) { if (rtn == NULL) {
rtn = new ConcreteCompilerVariable(this, v->getValue(), v->isGrabbed()); rtn = new ConcreteCompilerVariable(this, v->getValue());
while (rtn->getVrefs() < v->getVrefs())
rtn->incvref();
} }
return rtn; return rtn;
} }
...@@ -231,9 +213,6 @@ public: ...@@ -231,9 +213,6 @@ public:
std::string debugName() override { return "AnyBox"; } std::string debugName() override { return "AnyBox"; }
void drop(IREmitter& emitter, VAR* var) override { emitter.getGC()->dropPointer(emitter, var->getValue()); }
void grab(IREmitter& emitter, VAR* var) override { emitter.getGC()->grabPointer(emitter, var->getValue()); }
bool isFitBy(BoxedClass* c) override { return true; } bool isFitBy(BoxedClass* c) override { return true; }
CompilerVariable* getattr(IREmitter& emitter, const OpInfo& info, ConcreteCompilerVariable* var, BoxedString* attr, CompilerVariable* getattr(IREmitter& emitter, const OpInfo& info, ConcreteCompilerVariable* var, BoxedString* attr,
...@@ -270,7 +249,6 @@ public: ...@@ -270,7 +249,6 @@ public:
} else { } else {
emitter.createCall3(info.unw_info, g.funcs.setattr, var->getValue(), ptr, converted->getValue()); emitter.createCall3(info.unw_info, g.funcs.setattr, var->getValue(), ptr, converted->getValue());
} }
converted->decvref(emitter);
} }
void delattr(IREmitter& emitter, const OpInfo& info, ConcreteCompilerVariable* var, BoxedString* attr) override { void delattr(IREmitter& emitter, const OpInfo& info, ConcreteCompilerVariable* var, BoxedString* attr) override {
...@@ -317,7 +295,6 @@ public: ...@@ -317,7 +295,6 @@ public:
ConcreteCompilerVariable* makeConverted(IREmitter& emitter, ConcreteCompilerVariable* var, ConcreteCompilerVariable* makeConverted(IREmitter& emitter, ConcreteCompilerVariable* var,
ConcreteCompilerType* other_type) override { ConcreteCompilerType* other_type) override {
if (other_type == this) { if (other_type == this) {
var->incvref();
return var; return var;
} }
fprintf(stderr, "Can't convert unknown to %s...\n", other_type->debugName().c_str()); fprintf(stderr, "Can't convert unknown to %s...\n", other_type->debugName().c_str());
...@@ -363,7 +340,7 @@ public: ...@@ -363,7 +340,7 @@ public:
emitter.checkAndPropagateCapiException(info.unw_info, r, getNullPtr(g.llvm_value_type_ptr)); emitter.checkAndPropagateCapiException(info.unw_info, r, getNullPtr(g.llvm_value_type_ptr));
return new ConcreteCompilerVariable(static_cast<ConcreteCompilerType*>(return_type), r, true); return new ConcreteCompilerVariable(static_cast<ConcreteCompilerType*>(return_type), r);
} }
} }
...@@ -389,12 +366,11 @@ public: ...@@ -389,12 +366,11 @@ public:
target_exception_style == CAPI ? g.funcs.getitem_capi : g.funcs.getitem, target_exception_style == CAPI ? g.funcs.getitem_capi : g.funcs.getitem,
var->getValue(), converted_slice->getValue(), target_exception_style); var->getValue(), converted_slice->getValue(), target_exception_style);
} }
converted_slice->decvref(emitter);
if (target_exception_style == CAPI) if (target_exception_style == CAPI)
emitter.checkAndPropagateCapiException(info.unw_info, rtn, getNullPtr(g.llvm_value_type_ptr)); emitter.checkAndPropagateCapiException(info.unw_info, rtn, getNullPtr(g.llvm_value_type_ptr));
return new ConcreteCompilerVariable(UNKNOWN, rtn, true); return new ConcreteCompilerVariable(UNKNOWN, rtn);
} }
CompilerVariable* getPystonIter(IREmitter& emitter, const OpInfo& info, ConcreteCompilerVariable* var) override { CompilerVariable* getPystonIter(IREmitter& emitter, const OpInfo& info, ConcreteCompilerVariable* var) override {
...@@ -407,7 +383,6 @@ public: ...@@ -407,7 +383,6 @@ public:
// If the type analysis could determine the iter type is a valid pyston iter (has 'hasnext') we are finished. // If the type analysis could determine the iter type is a valid pyston iter (has 'hasnext') we are finished.
CompilerType* iter_type = var->getType()->getPystonIterType(); CompilerType* iter_type = var->getType()->getPystonIterType();
if (iter_type != UNKNOWN) { if (iter_type != UNKNOWN) {
iter_call->decvref(emitter);
return converted_iter_call; return converted_iter_call;
} }
...@@ -444,10 +419,7 @@ public: ...@@ -444,10 +419,7 @@ public:
phi->addIncoming(value_has_iter, value_has_iter_bb); phi->addIncoming(value_has_iter, value_has_iter_bb);
phi->addIncoming(value_no_iter, value_no_iter_bb); phi->addIncoming(value_no_iter, value_no_iter_bb);
converted_iter_call->decvref(emitter); return new ConcreteCompilerVariable(UNKNOWN, phi);
iter_call->decvref(emitter);
return new ConcreteCompilerVariable(UNKNOWN, phi, true);
} }
CompilerVariable* binexp(IREmitter& emitter, const OpInfo& info, VAR* var, CompilerVariable* rhs, CompilerVariable* binexp(IREmitter& emitter, const OpInfo& info, VAR* var, CompilerVariable* rhs,
...@@ -485,15 +457,13 @@ public: ...@@ -485,15 +457,13 @@ public:
getConstantInt(op_type, g.i32)); getConstantInt(op_type, g.i32));
} }
converted_rhs->decvref(emitter);
if (op_type == AST_TYPE::In || op_type == AST_TYPE::NotIn || op_type == AST_TYPE::Is if (op_type == AST_TYPE::In || op_type == AST_TYPE::NotIn || op_type == AST_TYPE::Is
|| op_type == AST_TYPE::IsNot) { || op_type == AST_TYPE::IsNot) {
llvm::Value* unboxed = emitter.getBuilder()->CreateCall(g.funcs.unboxBool, rtn); llvm::Value* unboxed = emitter.getBuilder()->CreateCall(g.funcs.unboxBool, rtn);
return boolFromI1(emitter, unboxed); return boolFromI1(emitter, unboxed);
} }
return new ConcreteCompilerVariable(UNKNOWN, rtn, true); return new ConcreteCompilerVariable(UNKNOWN, rtn);
} }
CompilerVariable* contains(IREmitter& emitter, const OpInfo& info, VAR* var, CompilerVariable* lhs) override { CompilerVariable* contains(IREmitter& emitter, const OpInfo& info, VAR* var, CompilerVariable* lhs) override {
...@@ -516,7 +486,7 @@ public: ...@@ -516,7 +486,7 @@ public:
llvm::Value* val = emitter.getBuilder()->CreateLoad(ptr); llvm::Value* val = emitter.getBuilder()->CreateLoad(ptr);
assert(val->getType() == g.llvm_value_type_ptr); assert(val->getType() == g.llvm_value_type_ptr);
rtn.push_back(new ConcreteCompilerVariable(UNKNOWN, val, true)); rtn.push_back(new ConcreteCompilerVariable(UNKNOWN, val));
} }
return rtn; return rtn;
} }
...@@ -569,7 +539,7 @@ CompilerVariable* UnknownType::getattr(IREmitter& emitter, const OpInfo& info, C ...@@ -569,7 +539,7 @@ CompilerVariable* UnknownType::getattr(IREmitter& emitter, const OpInfo& info, C
if (target_exception_style == CAPI) if (target_exception_style == CAPI)
emitter.checkAndPropagateCapiException(info.unw_info, rtn_val, getNullPtr(g.llvm_value_type_ptr)); emitter.checkAndPropagateCapiException(info.unw_info, rtn_val, getNullPtr(g.llvm_value_type_ptr));
return new ConcreteCompilerVariable(UNKNOWN, rtn_val, true); return new ConcreteCompilerVariable(UNKNOWN, rtn_val);
} }
static ConcreteCompilerVariable* _call(IREmitter& emitter, const OpInfo& info, llvm::Value* func, static ConcreteCompilerVariable* _call(IREmitter& emitter, const OpInfo& info, llvm::Value* func,
...@@ -669,17 +639,13 @@ static ConcreteCompilerVariable* _call(IREmitter& emitter, const OpInfo& info, l ...@@ -669,17 +639,13 @@ static ConcreteCompilerVariable* _call(IREmitter& emitter, const OpInfo& info, l
rtn = emitter.createCall(info.unw_info, func, llvm_args, target_exception_style); rtn = emitter.createCall(info.unw_info, func, llvm_args, target_exception_style);
} }
for (int i = 0; i < args.size(); i++) {
converted_args[i]->decvref(emitter);
}
assert(rtn->getType() == rtn_type->llvmType()); assert(rtn->getType() == rtn_type->llvmType());
if (target_exception_style == CAPI) { if (target_exception_style == CAPI) {
emitter.checkAndPropagateCapiException(info.unw_info, rtn, getNullPtr(g.llvm_value_type_ptr)); emitter.checkAndPropagateCapiException(info.unw_info, rtn, getNullPtr(g.llvm_value_type_ptr));
} }
return new ConcreteCompilerVariable(rtn_type, rtn, true); return new ConcreteCompilerVariable(rtn_type, rtn);
} }
CompilerVariable* UnknownType::call(IREmitter& emitter, const OpInfo& info, ConcreteCompilerVariable* var, CompilerVariable* UnknownType::call(IREmitter& emitter, const OpInfo& info, ConcreteCompilerVariable* var,
...@@ -787,9 +753,7 @@ ConcreteCompilerVariable* UnknownType::unaryop(IREmitter& emitter, const OpInfo& ...@@ -787,9 +753,7 @@ ConcreteCompilerVariable* UnknownType::unaryop(IREmitter& emitter, const OpInfo&
getConstantInt(op_type, g.i32)); getConstantInt(op_type, g.i32));
} }
converted->decvref(emitter); return new ConcreteCompilerVariable(UNKNOWN, rtn);
return new ConcreteCompilerVariable(UNKNOWN, rtn, true);
} }
ConcreteCompilerVariable* UnknownType::hasnext(IREmitter& emitter, const OpInfo& info, ConcreteCompilerVariable* var) { ConcreteCompilerVariable* UnknownType::hasnext(IREmitter& emitter, const OpInfo& info, ConcreteCompilerVariable* var) {
...@@ -848,9 +812,7 @@ CompilerVariable* makeFunction(IREmitter& emitter, FunctionMetadata* f, Compiler ...@@ -848,9 +812,7 @@ CompilerVariable* makeFunction(IREmitter& emitter, FunctionMetadata* f, Compiler
std::vector<llvm::Value*>{ embedRelocatablePtr(f, g.llvm_functionmetadata_type_ptr), closure_v, globals, std::vector<llvm::Value*>{ embedRelocatablePtr(f, g.llvm_functionmetadata_type_ptr), closure_v, globals,
scratch, getConstantInt(defaults.size(), g.i64) }); scratch, getConstantInt(defaults.size(), g.i64) });
if (convertedClosure) return new ConcreteCompilerVariable(typeFromClass(function_cls), boxed);
convertedClosure->decvref(emitter);
return new ConcreteCompilerVariable(typeFromClass(function_cls), boxed, true);
} }
class AbstractFunctionType : public CompilerType { class AbstractFunctionType : public CompilerType {
...@@ -965,22 +927,12 @@ public: ...@@ -965,22 +927,12 @@ public:
// Subclasses need to implement: // Subclasses need to implement:
// _makeConverted // _makeConverted
// _dup // _dup
// _drop
// _numFrameArgs // _numFrameArgs
// _serializeToFrame // _serializeToFrame
// _deserializeFromFrame // _deserializeFromFrame
typedef UnboxedVal<T> Unboxed; typedef UnboxedVal<T> Unboxed;
typedef typename ValuedCompilerType<std::shared_ptr<UnboxedVal<T>>>::VAR VAR; typedef typename ValuedCompilerType<std::shared_ptr<UnboxedVal<T>>>::VAR VAR;
void drop(IREmitter& emitter, VAR* var) override final {
auto v = var->getValue();
if (v->boxed)
v->boxed->decvref(emitter);
static_cast<D*>(this)->_drop(emitter, v->val);
}
void grab(IREmitter& emitter, VAR* var) override final { RELEASE_ASSERT(0, ""); }
void assertMatches(std::shared_ptr<Unboxed> val) override final { void assertMatches(std::shared_ptr<Unboxed> val) override final {
static_cast<D*>(this)->_assertMatches(val->val); static_cast<D*>(this)->_assertMatches(val->val);
assert(!val->boxed || val->boxed->getType() == static_cast<D*>(this)->getBoxType()); assert(!val->boxed || val->boxed->getType() == static_cast<D*>(this)->getBoxType());
...@@ -999,9 +951,7 @@ public: ...@@ -999,9 +951,7 @@ public:
auto val auto val
= std::make_shared<Unboxed>(std::move(val_duped), static_cast<ConcreteCompilerVariable*>(box_duped)); = std::make_shared<Unboxed>(std::move(val_duped), static_cast<ConcreteCompilerVariable*>(box_duped));
rtn = new VAR(this, val, var->isGrabbed()); rtn = new VAR(this, val);
while (rtn->getVrefs() < var->getVrefs())
rtn->incvref();
} }
return rtn; return rtn;
} }
...@@ -1032,7 +982,6 @@ public: ...@@ -1032,7 +982,6 @@ public:
return boxed->makeConverted(emitter, other_type); return boxed->makeConverted(emitter, other_type);
} }
boxed->incvref();
return boxed; return boxed;
} }
...@@ -1082,8 +1031,6 @@ class IntType : public UnboxedType<llvm::Value*, IntType> { ...@@ -1082,8 +1031,6 @@ class IntType : public UnboxedType<llvm::Value*, IntType> {
public: public:
IntType() {} IntType() {}
void _drop(IREmitter& emitter, llvm::Value* v) {}
llvm::Value* _dup(llvm::Value* v, DupCache& cache) { return v; } llvm::Value* _dup(llvm::Value* v, DupCache& cache) { return v; }
void _assertMatches(llvm::Value* v) { assert(v->getType() == g.i64); } void _assertMatches(llvm::Value* v) { assert(v->getType() == g.i64); }
...@@ -1145,7 +1092,6 @@ public: ...@@ -1145,7 +1092,6 @@ public:
const std::vector<BoxedString*>* keyword_names) override { const std::vector<BoxedString*>* keyword_names) override {
ConcreteCompilerVariable* converted = var->makeConverted(emitter, BOXED_INT); ConcreteCompilerVariable* converted = var->makeConverted(emitter, BOXED_INT);
CompilerVariable* rtn = converted->callattr(emitter, info, attr, flags, args, keyword_names); CompilerVariable* rtn = converted->callattr(emitter, info, attr, flags, args, keyword_names);
converted->decvref(emitter);
return rtn; return rtn;
} }
...@@ -1153,7 +1099,6 @@ public: ...@@ -1153,7 +1099,6 @@ public:
bool cls_only) override { bool cls_only) override {
ConcreteCompilerVariable* converted = var->makeConverted(emitter, BOXED_INT); ConcreteCompilerVariable* converted = var->makeConverted(emitter, BOXED_INT);
CompilerVariable* rtn = converted->getattr(emitter, info, attr, cls_only); CompilerVariable* rtn = converted->getattr(emitter, info, attr, cls_only);
converted->decvref(emitter);
return rtn; return rtn;
} }
...@@ -1180,13 +1125,12 @@ public: ...@@ -1180,13 +1125,12 @@ public:
} else { } else {
boxed = emitter.getBuilder()->CreateCall(g.funcs.boxInt, unboxed); boxed = emitter.getBuilder()->CreateCall(g.funcs.boxInt, unboxed);
} }
return new ConcreteCompilerVariable(other_type, boxed, true); return new ConcreteCompilerVariable(other_type, boxed);
} }
CompilerVariable* getitem(IREmitter& emitter, const OpInfo& info, VAR* var, CompilerVariable* slice) override { CompilerVariable* getitem(IREmitter& emitter, const OpInfo& info, VAR* var, CompilerVariable* slice) override {
ConcreteCompilerVariable* converted = var->makeConverted(emitter, BOXED_INT); ConcreteCompilerVariable* converted = var->makeConverted(emitter, BOXED_INT);
CompilerVariable* rtn = converted->getitem(emitter, info, slice); CompilerVariable* rtn = converted->getitem(emitter, info, slice);
converted->decvref(emitter);
return rtn; return rtn;
} }
...@@ -1218,7 +1162,6 @@ public: ...@@ -1218,7 +1162,6 @@ public:
ConcreteCompilerVariable* converted = var->makeConverted(emitter, BOXED_INT); ConcreteCompilerVariable* converted = var->makeConverted(emitter, BOXED_INT);
auto rtn = converted->unaryop(emitter, info, op_type); auto rtn = converted->unaryop(emitter, info, op_type);
converted->decvref(emitter);
return rtn; return rtn;
} }
...@@ -1238,7 +1181,6 @@ public: ...@@ -1238,7 +1181,6 @@ public:
ConcreteCompilerVariable* converted = var->makeConverted(emitter, BOXED_INT); ConcreteCompilerVariable* converted = var->makeConverted(emitter, BOXED_INT);
CompilerVariable* rtn = converted->binexp(emitter, info, rhs, op_type, exp_type); CompilerVariable* rtn = converted->binexp(emitter, info, rhs, op_type, exp_type);
converted->decvref(emitter);
return rtn; return rtn;
} }
...@@ -1326,7 +1268,7 @@ public: ...@@ -1326,7 +1268,7 @@ public:
llvm::CallSite call llvm::CallSite call
= emitter.createCall(info.unw_info, g.funcs.raiseNotIterableError, embedConstantPtr("int", g.i8_ptr)); = emitter.createCall(info.unw_info, g.funcs.raiseNotIterableError, embedConstantPtr("int", g.i8_ptr));
call.setDoesNotReturn(); call.setDoesNotReturn();
return new ConcreteCompilerVariable(BOOL, llvm::UndefValue::get(BOOL->llvmType()), true); return new ConcreteCompilerVariable(BOOL, llvm::UndefValue::get(BOOL->llvmType()));
} }
ConcreteCompilerType* getBoxType() override { return BOXED_INT; } ConcreteCompilerType* getBoxType() override { return BOXED_INT; }
...@@ -1350,7 +1292,7 @@ CompilerType* INT = &_INT; ...@@ -1350,7 +1292,7 @@ CompilerType* INT = &_INT;
CompilerVariable* makeInt(llvm::Value* n) { CompilerVariable* makeInt(llvm::Value* n) {
assert(n->getType() == g.i64); assert(n->getType() == g.i64);
return new IntType::VAR(&_INT, std::make_shared<IntType::Unboxed>(n, nullptr), true); return new IntType::VAR(&_INT, std::make_shared<IntType::Unboxed>(n, nullptr));
} }
CompilerVariable* makeInt(int64_t n) { CompilerVariable* makeInt(int64_t n) {
...@@ -1360,12 +1302,12 @@ CompilerVariable* makeInt(int64_t n) { ...@@ -1360,12 +1302,12 @@ CompilerVariable* makeInt(int64_t n) {
CompilerVariable* makeUnboxedInt(IREmitter& emitter, ConcreteCompilerVariable* v) { CompilerVariable* makeUnboxedInt(IREmitter& emitter, ConcreteCompilerVariable* v) {
assert(v->getType() == BOXED_INT); assert(v->getType() == BOXED_INT);
llvm::Value* unboxed = emitter.getBuilder()->CreateCall(g.funcs.unboxInt, v->getValue()); llvm::Value* unboxed = emitter.getBuilder()->CreateCall(g.funcs.unboxInt, v->getValue());
return new IntType::VAR(&_INT, std::make_shared<IntType::Unboxed>(unboxed, v), true); return new IntType::VAR(&_INT, std::make_shared<IntType::Unboxed>(unboxed, v));
} }
CompilerVariable* makeUnboxedInt(IREmitter& emitter, llvm::Value* v) { CompilerVariable* makeUnboxedInt(IREmitter& emitter, llvm::Value* v) {
assert(v->getType() == g.llvm_value_type_ptr); assert(v->getType() == g.llvm_value_type_ptr);
return makeUnboxedInt(emitter, new ConcreteCompilerVariable(BOXED_INT, v, false)); return makeUnboxedInt(emitter, new ConcreteCompilerVariable(BOXED_INT, v));
} }
class FloatType : public UnboxedType<llvm::Value*, FloatType> { class FloatType : public UnboxedType<llvm::Value*, FloatType> {
...@@ -1374,10 +1316,6 @@ public: ...@@ -1374,10 +1316,6 @@ public:
std::string debugName() override { return "float"; } std::string debugName() override { return "float"; }
void _drop(IREmitter& emitter, llvm::Value* v) {
// pass
}
void _assertMatches(llvm::Value* v) { assert(v->getType() == g.double_); } void _assertMatches(llvm::Value* v) { assert(v->getType() == g.double_); }
llvm::Value* _dup(llvm::Value* v, DupCache& cache) { return v; } llvm::Value* _dup(llvm::Value* v, DupCache& cache) { return v; }
...@@ -1420,7 +1358,6 @@ public: ...@@ -1420,7 +1358,6 @@ public:
bool cls_only) override { bool cls_only) override {
ConcreteCompilerVariable* converted = var->makeConverted(emitter, BOXED_FLOAT); ConcreteCompilerVariable* converted = var->makeConverted(emitter, BOXED_FLOAT);
CompilerVariable* rtn = converted->getattr(emitter, info, attr, cls_only); CompilerVariable* rtn = converted->getattr(emitter, info, attr, cls_only);
converted->decvref(emitter);
return rtn; return rtn;
} }
...@@ -1429,7 +1366,6 @@ public: ...@@ -1429,7 +1366,6 @@ public:
const std::vector<BoxedString*>* keyword_names) override { const std::vector<BoxedString*>* keyword_names) override {
ConcreteCompilerVariable* converted = var->makeConverted(emitter, BOXED_FLOAT); ConcreteCompilerVariable* converted = var->makeConverted(emitter, BOXED_FLOAT);
CompilerVariable* rtn = converted->callattr(emitter, info, attr, flags, args, keyword_names); CompilerVariable* rtn = converted->callattr(emitter, info, attr, flags, args, keyword_names);
converted->decvref(emitter);
return rtn; return rtn;
} }
...@@ -1458,7 +1394,7 @@ public: ...@@ -1458,7 +1394,7 @@ public:
} else { } else {
boxed = emitter.getBuilder()->CreateCall(g.funcs.boxFloat, unboxed); boxed = emitter.getBuilder()->CreateCall(g.funcs.boxFloat, unboxed);
} }
return new ConcreteCompilerVariable(other_type, boxed, true); return new ConcreteCompilerVariable(other_type, boxed);
} }
ConcreteCompilerVariable* nonzero(IREmitter& emitter, const OpInfo& info, VAR* var) override { ConcreteCompilerVariable* nonzero(IREmitter& emitter, const OpInfo& info, VAR* var) override {
...@@ -1470,14 +1406,12 @@ public: ...@@ -1470,14 +1406,12 @@ public:
CompilerVariable* unaryop(IREmitter& emitter, const OpInfo& info, VAR* var, AST_TYPE::AST_TYPE op_type) override { CompilerVariable* unaryop(IREmitter& emitter, const OpInfo& info, VAR* var, AST_TYPE::AST_TYPE op_type) override {
ConcreteCompilerVariable* converted = var->makeConverted(emitter, BOXED_FLOAT); ConcreteCompilerVariable* converted = var->makeConverted(emitter, BOXED_FLOAT);
auto rtn = converted->unaryop(emitter, info, op_type); auto rtn = converted->unaryop(emitter, info, op_type);
converted->decvref(emitter);
return rtn; return rtn;
} }
CompilerVariable* getitem(IREmitter& emitter, const OpInfo& info, VAR* var, CompilerVariable* slice) override { CompilerVariable* getitem(IREmitter& emitter, const OpInfo& info, VAR* var, CompilerVariable* slice) override {
ConcreteCompilerVariable* converted = var->makeConverted(emitter, BOXED_FLOAT); ConcreteCompilerVariable* converted = var->makeConverted(emitter, BOXED_FLOAT);
CompilerVariable* rtn = converted->getitem(emitter, info, slice); CompilerVariable* rtn = converted->getitem(emitter, info, slice);
converted->decvref(emitter);
return rtn; return rtn;
} }
...@@ -1488,7 +1422,6 @@ public: ...@@ -1488,7 +1422,6 @@ public:
if (rhs->getType() != INT && rhs->getType() != FLOAT) { if (rhs->getType() != INT && rhs->getType() != FLOAT) {
ConcreteCompilerVariable* converted = var->makeConverted(emitter, BOXED_FLOAT); ConcreteCompilerVariable* converted = var->makeConverted(emitter, BOXED_FLOAT);
CompilerVariable* rtn = converted->binexp(emitter, info, rhs, op_type, exp_type); CompilerVariable* rtn = converted->binexp(emitter, info, rhs, op_type, exp_type);
converted->decvref(emitter);
return rtn; return rtn;
} }
...@@ -1585,7 +1518,6 @@ public: ...@@ -1585,7 +1518,6 @@ public:
// TODO duplication with top of function, other functions, etc // TODO duplication with top of function, other functions, etc
ConcreteCompilerVariable* converted = var->makeConverted(emitter, BOXED_FLOAT); ConcreteCompilerVariable* converted = var->makeConverted(emitter, BOXED_FLOAT);
CompilerVariable* rtn = converted->binexp(emitter, info, rhs, op_type, exp_type); CompilerVariable* rtn = converted->binexp(emitter, info, rhs, op_type, exp_type);
converted->decvref(emitter);
return rtn; return rtn;
} }
...@@ -1593,7 +1525,7 @@ public: ...@@ -1593,7 +1525,7 @@ public:
llvm::CallSite call llvm::CallSite call
= emitter.createCall(info.unw_info, g.funcs.raiseNotIterableError, embedConstantPtr("float", g.i8_ptr)); = emitter.createCall(info.unw_info, g.funcs.raiseNotIterableError, embedConstantPtr("float", g.i8_ptr));
call.setDoesNotReturn(); call.setDoesNotReturn();
return new ConcreteCompilerVariable(BOOL, llvm::UndefValue::get(BOOL->llvmType()), true); return new ConcreteCompilerVariable(BOOL, llvm::UndefValue::get(BOOL->llvmType()));
} }
ConcreteCompilerType* getBoxType() override { return BOXED_FLOAT; } ConcreteCompilerType* getBoxType() override { return BOXED_FLOAT; }
...@@ -1633,7 +1565,7 @@ ConcreteCompilerType* UNBOXED_FLOAT = new PhonyUnboxedType(llvm::Type::getDouble ...@@ -1633,7 +1565,7 @@ ConcreteCompilerType* UNBOXED_FLOAT = new PhonyUnboxedType(llvm::Type::getDouble
CompilerVariable* makeFloat(llvm::Value* n) { CompilerVariable* makeFloat(llvm::Value* n) {
assert(n->getType() == g.double_); assert(n->getType() == g.double_);
return new FloatType::VAR(&_FLOAT, std::make_shared<FloatType::Unboxed>(n, nullptr), true); return new FloatType::VAR(&_FLOAT, std::make_shared<FloatType::Unboxed>(n, nullptr));
} }
CompilerVariable* makeFloat(double n) { CompilerVariable* makeFloat(double n) {
...@@ -1643,21 +1575,21 @@ CompilerVariable* makeFloat(double n) { ...@@ -1643,21 +1575,21 @@ CompilerVariable* makeFloat(double n) {
CompilerVariable* makeUnboxedFloat(IREmitter& emitter, ConcreteCompilerVariable* v) { CompilerVariable* makeUnboxedFloat(IREmitter& emitter, ConcreteCompilerVariable* v) {
assert(v->getType() == BOXED_FLOAT); assert(v->getType() == BOXED_FLOAT);
llvm::Value* unboxed = emitter.getBuilder()->CreateCall(g.funcs.unboxFloat, v->getValue()); llvm::Value* unboxed = emitter.getBuilder()->CreateCall(g.funcs.unboxFloat, v->getValue());
return new FloatType::VAR(&_FLOAT, std::make_shared<FloatType::Unboxed>(unboxed, v), true); return new FloatType::VAR(&_FLOAT, std::make_shared<FloatType::Unboxed>(unboxed, v));
} }
CompilerVariable* makeUnboxedFloat(IREmitter& emitter, llvm::Value* v) { CompilerVariable* makeUnboxedFloat(IREmitter& emitter, llvm::Value* v) {
assert(v->getType() == g.llvm_value_type_ptr); assert(v->getType() == g.llvm_value_type_ptr);
return makeUnboxedFloat(emitter, new ConcreteCompilerVariable(BOXED_FLOAT, v, false)); return makeUnboxedFloat(emitter, new ConcreteCompilerVariable(BOXED_FLOAT, v));
} }
ConcreteCompilerVariable* makeLong(Box* v) { ConcreteCompilerVariable* makeLong(Box* v) {
return new ConcreteCompilerVariable(LONG, embedRelocatablePtr(v, g.llvm_value_type_ptr), true); return new ConcreteCompilerVariable(LONG, embedRelocatablePtr(v, g.llvm_value_type_ptr));
} }
ConcreteCompilerVariable* makePureImaginary(Box* v) { ConcreteCompilerVariable* makePureImaginary(Box* v) {
return new ConcreteCompilerVariable(BOXED_COMPLEX, embedRelocatablePtr(v, g.llvm_value_type_ptr), true); return new ConcreteCompilerVariable(BOXED_COMPLEX, embedRelocatablePtr(v, g.llvm_value_type_ptr));
} }
class KnownClassobjType : public ValuedCompilerType<BoxedClass*> { class KnownClassobjType : public ValuedCompilerType<BoxedClass*> {
...@@ -1726,17 +1658,12 @@ public: ...@@ -1726,17 +1658,12 @@ public:
ConcreteCompilerVariable* makeConverted(IREmitter& emitter, ConcreteCompilerVariable* var, ConcreteCompilerVariable* makeConverted(IREmitter& emitter, ConcreteCompilerVariable* var,
ConcreteCompilerType* other_type) override { ConcreteCompilerType* other_type) override {
if (other_type == this) { if (other_type == this) {
var->incvref();
return var; return var;
} }
ASSERT(other_type == UNKNOWN, "%s", other_type->debugName().c_str()); ASSERT(other_type == UNKNOWN, "%s", other_type->debugName().c_str());
return new ConcreteCompilerVariable(UNKNOWN, var->getValue(), false); return new ConcreteCompilerVariable(UNKNOWN, var->getValue());
// return (new ConcreteCompilerVariable(UNKNOWN, var->getValue(), false))->split(emitter);
} }
void drop(IREmitter& emitter, VAR* var) override { emitter.getGC()->dropPointer(emitter, var->getValue()); }
void grab(IREmitter& emitter, VAR* var) override { emitter.getGC()->grabPointer(emitter, var->getValue()); }
bool isFitBy(BoxedClass* c) override { bool isFitBy(BoxedClass* c) override {
// I don't think it's ok to accept subclasses // I don't think it's ok to accept subclasses
return c == cls; return c == cls;
...@@ -1795,11 +1722,11 @@ public: ...@@ -1795,11 +1722,11 @@ public:
ASSERT(rtattr, "%s.%s", debugName().c_str(), attr->data()); ASSERT(rtattr, "%s.%s", debugName().c_str(), attr->data());
if (rtattr->cls == function_cls) { if (rtattr->cls == function_cls) {
CompilerVariable* clattr = new ConcreteCompilerVariable( CompilerVariable* clattr = new ConcreteCompilerVariable(
typeFromClass(function_cls), embedRelocatablePtr(rtattr, g.llvm_value_type_ptr), false); typeFromClass(function_cls), embedRelocatablePtr(rtattr, g.llvm_value_type_ptr));
return InstanceMethodType::makeIM( return InstanceMethodType::makeIM(
var, clattr, var, clattr,
new ConcreteCompilerVariable(UNKNOWN, embedRelocatablePtr(cls, g.llvm_value_type_ptr), false)); new ConcreteCompilerVariable(UNKNOWN, embedRelocatablePtr(cls, g.llvm_value_type_ptr)));
} }
} }
...@@ -1821,7 +1748,6 @@ public: ...@@ -1821,7 +1748,6 @@ public:
const std::vector<BoxedString*>* keyword_names) override { const std::vector<BoxedString*>* keyword_names) override {
ConcreteCompilerVariable* converted = var->makeConverted(emitter, UNKNOWN); ConcreteCompilerVariable* converted = var->makeConverted(emitter, UNKNOWN);
CompilerVariable* rtn = converted->call(emitter, info, argspec, args, keyword_names); CompilerVariable* rtn = converted->call(emitter, info, argspec, args, keyword_names);
converted->decvref(emitter);
return rtn; return rtn;
} }
...@@ -1949,7 +1875,7 @@ public: ...@@ -1949,7 +1875,7 @@ public:
else else
llvm_value = getNullPtr(g.llvm_value_type_ptr); llvm_value = getNullPtr(g.llvm_value_type_ptr);
new_args.push_back(new ConcreteCompilerVariable(UNKNOWN, llvm_value, true)); new_args.push_back(new ConcreteCompilerVariable(UNKNOWN, llvm_value));
} }
std::vector<llvm::Value*> other_args; std::vector<llvm::Value*> other_args;
...@@ -1993,7 +1919,6 @@ public: ...@@ -1993,7 +1919,6 @@ public:
ConcreteCompilerVariable* converted = var->makeConverted(emitter, UNKNOWN); ConcreteCompilerVariable* converted = var->makeConverted(emitter, UNKNOWN);
CompilerVariable* rtn = converted->callattr(emitter, info, attr, flags, args, keyword_names); CompilerVariable* rtn = converted->callattr(emitter, info, attr, flags, args, keyword_names);
converted->decvref(emitter);
return rtn; return rtn;
} }
...@@ -2021,20 +1946,17 @@ public: ...@@ -2021,20 +1946,17 @@ public:
// Kind of hacky, but just call into getitem like normal. except... // Kind of hacky, but just call into getitem like normal. except...
auto r = UNKNOWN->binexp(emitter, info, var, converted_rhs, op_type, exp_type); auto r = UNKNOWN->binexp(emitter, info, var, converted_rhs, op_type, exp_type);
r->decvref(emitter);
// ... return the undef value, since that matches what the type analyzer thought we would do. // ... return the undef value, since that matches what the type analyzer thought we would do.
return called_constant; return called_constant;
} }
if (called_constant) { if (called_constant) {
converted_rhs->decvref(emitter);
return called_constant; return called_constant;
} }
} }
} }
auto rtn = UNKNOWN->binexp(emitter, info, var, converted_rhs, op_type, exp_type); auto rtn = UNKNOWN->binexp(emitter, info, var, converted_rhs, op_type, exp_type);
converted_rhs->decvref(emitter);
return rtn; return rtn;
} }
...@@ -2087,7 +2009,7 @@ public: ...@@ -2087,7 +2009,7 @@ public:
var->getValue(), start, stop); var->getValue(), start, stop);
emitter.checkAndPropagateCapiException(info.unw_info, r, getNullPtr(g.llvm_value_type_ptr)); emitter.checkAndPropagateCapiException(info.unw_info, r, getNullPtr(g.llvm_value_type_ptr));
return new ConcreteCompilerVariable(static_cast<ConcreteCompilerType*>(return_type), r, true); return new ConcreteCompilerVariable(static_cast<ConcreteCompilerType*>(return_type), r);
} }
} }
} }
...@@ -2106,7 +2028,6 @@ public: ...@@ -2106,7 +2028,6 @@ public:
// Kind of hacky, but just call into getitem like normal. except... // Kind of hacky, but just call into getitem like normal. except...
auto r = UNKNOWN->getitem(emitter, info, var, slice); auto r = UNKNOWN->getitem(emitter, info, var, slice);
r->decvref(emitter);
// ... return the undef value, since that matches what the type analyzer thought we would do. // ... return the undef value, since that matches what the type analyzer thought we would do.
return called_constant; return called_constant;
} }
...@@ -2227,9 +2148,6 @@ public: ...@@ -2227,9 +2148,6 @@ public:
ConcreteCompilerType* getConcreteType() override { return this; } ConcreteCompilerType* getConcreteType() override { return this; }
ConcreteCompilerType* getBoxType() override { return this; } ConcreteCompilerType* getBoxType() override { return this; }
void drop(IREmitter& emitter, VAR* var) override {}
void grab(IREmitter& emitter, VAR* var) override {}
Box* deserializeFromFrame(const FrameVals& vals) override { Box* deserializeFromFrame(const FrameVals& vals) override {
assert(vals.size() == 1); assert(vals.size() == 1);
return reinterpret_cast<Box*>(vals[0]); return reinterpret_cast<Box*>(vals[0]);
...@@ -2245,13 +2163,6 @@ public: ...@@ -2245,13 +2163,6 @@ public:
ConcreteCompilerType* getConcreteType() override { return this; } ConcreteCompilerType* getConcreteType() override { return this; }
ConcreteCompilerType* getBoxType() override { return GENERATOR; } ConcreteCompilerType* getBoxType() override { return GENERATOR; }
void drop(IREmitter& emitter, VAR* var) override {
// pass
}
void grab(IREmitter& emitter, VAR* var) override {
// pass
}
Box* deserializeFromFrame(const FrameVals& vals) override { Box* deserializeFromFrame(const FrameVals& vals) override {
assert(vals.size() == numFrameArgs()); assert(vals.size() == numFrameArgs());
return reinterpret_cast<Box*>(vals[0]); return reinterpret_cast<Box*>(vals[0]);
...@@ -2267,13 +2178,6 @@ public: ...@@ -2267,13 +2178,6 @@ public:
ConcreteCompilerType* getConcreteType() override { return this; } ConcreteCompilerType* getConcreteType() override { return this; }
ConcreteCompilerType* getBoxType() override { return FRAME_INFO; } ConcreteCompilerType* getBoxType() override { return FRAME_INFO; }
void drop(IREmitter& emitter, VAR* var) override {
// pass
}
void grab(IREmitter& emitter, VAR* var) override {
// pass
}
Box* deserializeFromFrame(const FrameVals& vals) override { Box* deserializeFromFrame(const FrameVals& vals) override {
RELEASE_ASSERT(false, "should not be called"); // This function shouldn't be called. RELEASE_ASSERT(false, "should not be called"); // This function shouldn't be called.
} }
...@@ -2290,18 +2194,10 @@ public: ...@@ -2290,18 +2194,10 @@ public:
ConcreteCompilerType* getBoxType() override { return STR; } ConcreteCompilerType* getBoxType() override { return STR; }
void drop(IREmitter& emitter, VAR* var) override {
// pass
}
void grab(IREmitter& emitter, VAR* var) override {
// pass
}
ConcreteCompilerVariable* makeConverted(IREmitter& emitter, VAR* var, ConcreteCompilerType* other_type) override { ConcreteCompilerVariable* makeConverted(IREmitter& emitter, VAR* var, ConcreteCompilerType* other_type) override {
assert(other_type == STR || other_type == UNKNOWN); assert(other_type == STR || other_type == UNKNOWN);
llvm::Value* boxed = embedRelocatablePtr(var->getValue(), g.llvm_value_type_ptr); llvm::Value* boxed = embedRelocatablePtr(var->getValue(), g.llvm_value_type_ptr);
return new ConcreteCompilerVariable(other_type, boxed, true); return new ConcreteCompilerVariable(other_type, boxed);
} }
bool canConvertTo(CompilerType* other) override { return (other == STR || other == UNKNOWN); } bool canConvertTo(CompilerType* other) override { return (other == STR || other == UNKNOWN); }
...@@ -2310,7 +2206,6 @@ public: ...@@ -2310,7 +2206,6 @@ public:
bool cls_only) override { bool cls_only) override {
ConcreteCompilerVariable* converted = var->makeConverted(emitter, STR); ConcreteCompilerVariable* converted = var->makeConverted(emitter, STR);
CompilerVariable* rtn = converted->getattr(emitter, info, attr, cls_only); CompilerVariable* rtn = converted->getattr(emitter, info, attr, cls_only);
converted->decvref(emitter);
return rtn; return rtn;
} }
...@@ -2319,14 +2214,12 @@ public: ...@@ -2319,14 +2214,12 @@ public:
const std::vector<BoxedString*>* keyword_names) override { const std::vector<BoxedString*>* keyword_names) override {
ConcreteCompilerVariable* converted = var->makeConverted(emitter, STR); ConcreteCompilerVariable* converted = var->makeConverted(emitter, STR);
CompilerVariable* rtn = converted->callattr(emitter, info, attr, flags, args, keyword_names); CompilerVariable* rtn = converted->callattr(emitter, info, attr, flags, args, keyword_names);
converted->decvref(emitter);
return rtn; return rtn;
} }
CompilerVariable* getitem(IREmitter& emitter, const OpInfo& info, VAR* var, CompilerVariable* slice) override { CompilerVariable* getitem(IREmitter& emitter, const OpInfo& info, VAR* var, CompilerVariable* slice) override {
ConcreteCompilerVariable* converted = var->makeConverted(emitter, STR); ConcreteCompilerVariable* converted = var->makeConverted(emitter, STR);
CompilerVariable* rtn = converted->getitem(emitter, info, slice); CompilerVariable* rtn = converted->getitem(emitter, info, slice);
converted->decvref(emitter);
return rtn; return rtn;
} }
...@@ -2334,14 +2227,12 @@ public: ...@@ -2334,14 +2227,12 @@ public:
AST_TYPE::AST_TYPE op_type, BinExpType exp_type) override { AST_TYPE::AST_TYPE op_type, BinExpType exp_type) override {
ConcreteCompilerVariable* converted = var->makeConverted(emitter, STR); ConcreteCompilerVariable* converted = var->makeConverted(emitter, STR);
CompilerVariable* rtn = converted->binexp(emitter, info, rhs, op_type, exp_type); CompilerVariable* rtn = converted->binexp(emitter, info, rhs, op_type, exp_type);
converted->decvref(emitter);
return rtn; return rtn;
} }
CompilerVariable* contains(IREmitter& emitter, const OpInfo& info, VAR* var, CompilerVariable* lhs) override { CompilerVariable* contains(IREmitter& emitter, const OpInfo& info, VAR* var, CompilerVariable* lhs) override {
ConcreteCompilerVariable* converted = var->makeConverted(emitter, STR); ConcreteCompilerVariable* converted = var->makeConverted(emitter, STR);
CompilerVariable* rtn = converted->contains(emitter, info, lhs); CompilerVariable* rtn = converted->contains(emitter, info, lhs);
converted->decvref(emitter);
return rtn; return rtn;
} }
...@@ -2353,9 +2244,7 @@ public: ...@@ -2353,9 +2244,7 @@ public:
CompilerVariable*& rtn = cache[var]; CompilerVariable*& rtn = cache[var];
if (rtn == NULL) { if (rtn == NULL) {
rtn = new VAR(this, var->getValue(), var->isGrabbed()); rtn = new VAR(this, var->getValue());
while (rtn->getVrefs() < var->getVrefs())
rtn->incvref();
} }
return rtn; return rtn;
} }
...@@ -2385,7 +2274,7 @@ public: ...@@ -2385,7 +2274,7 @@ public:
static ValuedCompilerType<BoxedString*>* STR_CONSTANT = new StrConstantType(); static ValuedCompilerType<BoxedString*>* STR_CONSTANT = new StrConstantType();
CompilerVariable* makeStr(BoxedString* s) { CompilerVariable* makeStr(BoxedString* s) {
return new ValuedCompilerVariable<BoxedString*>(STR_CONSTANT, s, true); return new ValuedCompilerVariable<BoxedString*>(STR_CONSTANT, s);
} }
ConcreteCompilerType* typeFromClass(BoxedClass* c) { ConcreteCompilerType* typeFromClass(BoxedClass* c) {
...@@ -2405,15 +2294,7 @@ public: ...@@ -2405,15 +2294,7 @@ public:
bool isFitBy(BoxedClass* c) override { return false; } bool isFitBy(BoxedClass* c) override { return false; }
void drop(IREmitter& emitter, VAR* var) override {
// pass
}
void grab(IREmitter& emitter, VAR* var) override {
// pass
}
ConcreteCompilerVariable* nonzero(IREmitter& emitter, const OpInfo& info, ConcreteCompilerVariable* var) override { ConcreteCompilerVariable* nonzero(IREmitter& emitter, const OpInfo& info, ConcreteCompilerVariable* var) override {
var->incvref();
return var; return var;
} }
...@@ -2424,7 +2305,6 @@ public: ...@@ -2424,7 +2305,6 @@ public:
ConcreteCompilerVariable* makeConverted(IREmitter& emitter, ConcreteCompilerVariable* var, ConcreteCompilerVariable* makeConverted(IREmitter& emitter, ConcreteCompilerVariable* var,
ConcreteCompilerType* other_type) override { ConcreteCompilerType* other_type) override {
if (other_type == BOOL) { if (other_type == BOOL) {
var->incvref();
return var; return var;
} }
...@@ -2432,7 +2312,7 @@ public: ...@@ -2432,7 +2312,7 @@ public:
llvm::Value* boxed = emitter.getBuilder()->CreateSelect(i1FromBool(emitter, var), llvm::Value* boxed = emitter.getBuilder()->CreateSelect(i1FromBool(emitter, var),
embedConstantPtr(True, g.llvm_value_type_ptr), embedConstantPtr(True, g.llvm_value_type_ptr),
embedConstantPtr(False, g.llvm_value_type_ptr)); embedConstantPtr(False, g.llvm_value_type_ptr));
return new ConcreteCompilerVariable(other_type, boxed, true); return new ConcreteCompilerVariable(other_type, boxed);
} }
CompilerType* getattrType(BoxedString* attr, bool cls_only) override { CompilerType* getattrType(BoxedString* attr, bool cls_only) override {
...@@ -2443,7 +2323,6 @@ public: ...@@ -2443,7 +2323,6 @@ public:
bool cls_only) override { bool cls_only) override {
ConcreteCompilerVariable* converted = var->makeConverted(emitter, BOXED_BOOL); ConcreteCompilerVariable* converted = var->makeConverted(emitter, BOXED_BOOL);
CompilerVariable* rtn = converted->getattr(emitter, info, attr, cls_only); CompilerVariable* rtn = converted->getattr(emitter, info, attr, cls_only);
converted->decvref(emitter);
return rtn; return rtn;
} }
...@@ -2452,7 +2331,6 @@ public: ...@@ -2452,7 +2331,6 @@ public:
const std::vector<BoxedString*>* keyword_names) override { const std::vector<BoxedString*>* keyword_names) override {
ConcreteCompilerVariable* converted = var->makeConverted(emitter, BOXED_BOOL); ConcreteCompilerVariable* converted = var->makeConverted(emitter, BOXED_BOOL);
CompilerVariable* rtn = converted->callattr(emitter, info, attr, flags, args, keyword_names); CompilerVariable* rtn = converted->callattr(emitter, info, attr, flags, args, keyword_names);
converted->decvref(emitter);
return rtn; return rtn;
} }
...@@ -2460,7 +2338,6 @@ public: ...@@ -2460,7 +2338,6 @@ public:
AST_TYPE::AST_TYPE op_type, BinExpType exp_type) override { AST_TYPE::AST_TYPE op_type, BinExpType exp_type) override {
ConcreteCompilerVariable* converted = var->makeConverted(emitter, UNKNOWN); ConcreteCompilerVariable* converted = var->makeConverted(emitter, UNKNOWN);
CompilerVariable* rtn = converted->binexp(emitter, info, rhs, op_type, exp_type); CompilerVariable* rtn = converted->binexp(emitter, info, rhs, op_type, exp_type);
converted->decvref(emitter);
return rtn; return rtn;
} }
...@@ -2468,7 +2345,7 @@ public: ...@@ -2468,7 +2345,7 @@ public:
llvm::CallSite call llvm::CallSite call
= emitter.createCall(info.unw_info, g.funcs.raiseNotIterableError, embedConstantPtr("bool", g.i8_ptr)); = emitter.createCall(info.unw_info, g.funcs.raiseNotIterableError, embedConstantPtr("bool", g.i8_ptr));
call.setDoesNotReturn(); call.setDoesNotReturn();
return new ConcreteCompilerVariable(BOOL, llvm::UndefValue::get(BOOL->llvmType()), true); return new ConcreteCompilerVariable(BOOL, llvm::UndefValue::get(BOOL->llvmType()));
} }
ConcreteCompilerType* getBoxType() override { return BOXED_BOOL; } ConcreteCompilerType* getBoxType() override { return BOXED_BOOL; }
...@@ -2482,7 +2359,7 @@ public: ...@@ -2482,7 +2359,7 @@ public:
}; };
ConcreteCompilerType* BOOL = new BoolType(); ConcreteCompilerType* BOOL = new BoolType();
ConcreteCompilerVariable* makeBool(bool b) { ConcreteCompilerVariable* makeBool(bool b) {
return new ConcreteCompilerVariable(BOOL, llvm::ConstantInt::get(BOOL->llvmType(), b, false), true); return new ConcreteCompilerVariable(BOOL, llvm::ConstantInt::get(BOOL->llvmType(), b, false));
} }
ConcreteCompilerVariable* doIs(IREmitter& emitter, CompilerVariable* lhs, CompilerVariable* rhs, bool negate) { ConcreteCompilerVariable* doIs(IREmitter& emitter, CompilerVariable* lhs, CompilerVariable* rhs, bool negate) {
...@@ -2496,9 +2373,6 @@ ConcreteCompilerVariable* doIs(IREmitter& emitter, CompilerVariable* lhs, Compil ...@@ -2496,9 +2373,6 @@ ConcreteCompilerVariable* doIs(IREmitter& emitter, CompilerVariable* lhs, Compil
else else
cmp = emitter.getBuilder()->CreateICmpNE(converted_left->getValue(), converted_right->getValue()); cmp = emitter.getBuilder()->CreateICmpNE(converted_left->getValue(), converted_right->getValue());
converted_left->decvref(emitter);
converted_right->decvref(emitter);
return boolFromI1(emitter, cmp); return boolFromI1(emitter, cmp);
} }
...@@ -2533,12 +2407,6 @@ public: ...@@ -2533,12 +2407,6 @@ public:
std::string debugName() override { return name; } std::string debugName() override { return name; }
void _drop(IREmitter& emitter, const VEC& val) {
for (int i = 0; i < val.size(); i++) {
val[i]->decvref(emitter);
}
}
VEC _dup(const VEC& orig_elts, DupCache& cache) { VEC _dup(const VEC& orig_elts, DupCache& cache) {
std::vector<CompilerVariable*> elts; std::vector<CompilerVariable*> elts;
...@@ -2576,10 +2444,7 @@ public: ...@@ -2576,10 +2444,7 @@ public:
llvm::Value* rtn = emitter.getBuilder()->CreateCall2(g.funcs.createTuple, nelts, scratch); llvm::Value* rtn = emitter.getBuilder()->CreateCall2(g.funcs.createTuple, nelts, scratch);
for (int i = 0; i < converted_args.size(); i++) { return new ConcreteCompilerVariable(other_type, rtn);
converted_args[i]->decvref(emitter);
}
return new ConcreteCompilerVariable(other_type, rtn, true);
} }
ConcreteCompilerType* getBoxType() override { return BOXED_TUPLE; } ConcreteCompilerType* getBoxType() override { return BOXED_TUPLE; }
...@@ -2597,11 +2462,9 @@ public: ...@@ -2597,11 +2462,9 @@ public:
const VEC* elts = &v->val; const VEC* elts = &v->val;
if (i >= 0 && i < elts->size()) { if (i >= 0 && i < elts->size()) {
CompilerVariable* rtn = (*elts)[i]; CompilerVariable* rtn = (*elts)[i];
rtn->incvref();
return rtn; return rtn;
} else if (i < 0 && -i <= elts->size()) { } else if (i < 0 && -i <= elts->size()) {
CompilerVariable* rtn = (*elts)[elts->size() + i]; CompilerVariable* rtn = (*elts)[elts->size() + i];
rtn->incvref();
return rtn; return rtn;
} else { } else {
ExceptionStyle target_exception_style = info.preferredExceptionStyle(); ExceptionStyle target_exception_style = info.preferredExceptionStyle();
...@@ -2623,7 +2486,6 @@ public: ...@@ -2623,7 +2486,6 @@ public:
ConcreteCompilerVariable* converted = var->makeConverted(emitter, BOXED_TUPLE); ConcreteCompilerVariable* converted = var->makeConverted(emitter, BOXED_TUPLE);
CompilerVariable* rtn = converted->getitem(emitter, info, slice); CompilerVariable* rtn = converted->getitem(emitter, info, slice);
converted->decvref(emitter);
return rtn; return rtn;
} }
...@@ -2639,7 +2501,6 @@ public: ...@@ -2639,7 +2501,6 @@ public:
AST_TYPE::AST_TYPE op_type, BinExpType exp_type) override { AST_TYPE::AST_TYPE op_type, BinExpType exp_type) override {
ConcreteCompilerVariable* converted = var->makeConverted(emitter, UNKNOWN); ConcreteCompilerVariable* converted = var->makeConverted(emitter, UNKNOWN);
CompilerVariable* rtn = converted->binexp(emitter, info, rhs, op_type, exp_type); CompilerVariable* rtn = converted->binexp(emitter, info, rhs, op_type, exp_type);
converted->decvref(emitter);
return rtn; return rtn;
} }
...@@ -2690,8 +2551,6 @@ public: ...@@ -2690,8 +2551,6 @@ public:
phi->addIncoming(p.second, p.first); phi->addIncoming(p.second, p.first);
} }
converted_lhs->decvref(emitter);
return boolFromI1(emitter, phi); return boolFromI1(emitter, phi);
} }
...@@ -2739,10 +2598,6 @@ public: ...@@ -2739,10 +2598,6 @@ public:
return ValuedCompilerType::unpack(emitter, info, var, num_into); return ValuedCompilerType::unpack(emitter, info, var, num_into);
} }
// Not sure if this is right:
for (auto e : var->getValue()->val)
e->incvref();
return var->getValue()->val; return var->getValue()->val;
} }
...@@ -2762,22 +2617,18 @@ CompilerType* makeTupleType(const std::vector<CompilerType*>& elt_types) { ...@@ -2762,22 +2617,18 @@ CompilerType* makeTupleType(const std::vector<CompilerType*>& elt_types) {
CompilerVariable* makeTuple(const std::vector<CompilerVariable*>& elts) { CompilerVariable* makeTuple(const std::vector<CompilerVariable*>& elts) {
std::vector<CompilerType*> elt_types; std::vector<CompilerType*> elt_types;
for (int i = 0; i < elts.size(); i++) { for (int i = 0; i < elts.size(); i++) {
elts[i]->incvref();
elt_types.push_back(elts[i]->getType()); elt_types.push_back(elts[i]->getType());
} }
TupleType* type = TupleType::make(elt_types); TupleType* type = TupleType::make(elt_types);
auto alloc_var = std::make_shared<TupleType::Unboxed>(elts, nullptr); auto alloc_var = std::make_shared<TupleType::Unboxed>(elts, nullptr);
return new TupleType::VAR(type, alloc_var, true); return new TupleType::VAR(type, alloc_var);
} }
class UnboxedSliceType : public ValuedCompilerType<UnboxedSlice> { class UnboxedSliceType : public ValuedCompilerType<UnboxedSlice> {
public: public:
std::string debugName() override { return "slice"; } std::string debugName() override { return "slice"; }
void drop(IREmitter& emitter, VAR* var) override {}
void grab(IREmitter& emitter, VAR* var) override {}
void assertMatches(UnboxedSlice slice) {} void assertMatches(UnboxedSlice slice) {}
int numFrameArgs() override { RELEASE_ASSERT(0, "unboxed slice should never get serialized"); } int numFrameArgs() override { RELEASE_ASSERT(0, "unboxed slice should never get serialized"); }
...@@ -2811,16 +2662,13 @@ public: ...@@ -2811,16 +2662,13 @@ public:
args.push_back(cstep->getValue()); args.push_back(cstep->getValue());
llvm::Value* rtn = emitter.getBuilder()->CreateCall(g.funcs.createSlice, args); llvm::Value* rtn = emitter.getBuilder()->CreateCall(g.funcs.createSlice, args);
cstart->decvref(emitter); return new ConcreteCompilerVariable(SLICE, rtn);
cstop->decvref(emitter);
cstep->decvref(emitter);
return new ConcreteCompilerVariable(SLICE, rtn, true);
} }
} _UNBOXED_SLICE; } _UNBOXED_SLICE;
CompilerType* UNBOXED_SLICE = &_UNBOXED_SLICE; CompilerType* UNBOXED_SLICE = &_UNBOXED_SLICE;
CompilerVariable* makeSlice(CompilerVariable* start, CompilerVariable* stop, CompilerVariable* step) { CompilerVariable* makeSlice(CompilerVariable* start, CompilerVariable* stop, CompilerVariable* step) {
return new UnboxedSliceType::VAR(&_UNBOXED_SLICE, UnboxedSlice{ start, stop, step }, true); return new UnboxedSliceType::VAR(&_UNBOXED_SLICE, UnboxedSlice{ start, stop, step });
} }
UnboxedSlice extractSlice(CompilerVariable* slice) { UnboxedSlice extractSlice(CompilerVariable* slice) {
...@@ -2830,7 +2678,7 @@ UnboxedSlice extractSlice(CompilerVariable* slice) { ...@@ -2830,7 +2678,7 @@ UnboxedSlice extractSlice(CompilerVariable* slice) {
ConcreteCompilerVariable* getNone() { ConcreteCompilerVariable* getNone() {
llvm::Constant* none = embedRelocatablePtr(None, g.llvm_value_type_ptr, "cNone"); llvm::Constant* none = embedRelocatablePtr(None, g.llvm_value_type_ptr, "cNone");
return new ConcreteCompilerVariable(typeFromClass(none_cls), none, false); return new ConcreteCompilerVariable(typeFromClass(none_cls), none);
} }
class UndefType : public ConcreteCompilerType { class UndefType : public ConcreteCompilerType {
...@@ -2848,21 +2696,17 @@ public: ...@@ -2848,21 +2696,17 @@ public:
const std::vector<BoxedString*>* keyword_names) override { const std::vector<BoxedString*>* keyword_names) override {
return undefVariable(); return undefVariable();
} }
void drop(IREmitter& emitter, VAR* var) override {}
void grab(IREmitter& emitter, VAR* var) override {}
CompilerVariable* dup(VAR* v, DupCache& cache) override { CompilerVariable* dup(VAR* v, DupCache& cache) override {
// TODO copied from UnknownType // TODO copied from UnknownType
auto& rtn = cache[v]; auto& rtn = cache[v];
if (rtn == NULL) { if (rtn == NULL) {
rtn = new VAR(this, v->getValue(), v->isGrabbed()); rtn = new VAR(this, v->getValue());
while (rtn->getVrefs() < v->getVrefs())
rtn->incvref();
} }
return rtn; return rtn;
} }
ConcreteCompilerVariable* makeConverted(IREmitter& emitter, VAR* var, ConcreteCompilerType* other_type) override { ConcreteCompilerVariable* makeConverted(IREmitter& emitter, VAR* var, ConcreteCompilerType* other_type) override {
llvm::Value* v = llvm::UndefValue::get(other_type->llvmType()); llvm::Value* v = llvm::UndefValue::get(other_type->llvmType());
return new ConcreteCompilerVariable(other_type, v, true); return new ConcreteCompilerVariable(other_type, v);
} }
CompilerVariable* getattr(IREmitter& emitter, const OpInfo& info, VAR* var, BoxedString* attr, CompilerVariable* getattr(IREmitter& emitter, const OpInfo& info, VAR* var, BoxedString* attr,
bool cls_only) override { bool cls_only) override {
...@@ -2881,7 +2725,7 @@ public: ...@@ -2881,7 +2725,7 @@ public:
} }
ConcreteCompilerVariable* nonzero(IREmitter& emitter, const OpInfo& info, VAR* var) override { ConcreteCompilerVariable* nonzero(IREmitter& emitter, const OpInfo& info, VAR* var) override {
return new ConcreteCompilerVariable(BOOL, llvm::UndefValue::get(BOOL->llvmType()), true); return new ConcreteCompilerVariable(BOOL, llvm::UndefValue::get(BOOL->llvmType()));
} }
CompilerVariable* binexp(IREmitter& emitter, const OpInfo& info, VAR* var, CompilerVariable* rhs, CompilerVariable* binexp(IREmitter& emitter, const OpInfo& info, VAR* var, CompilerVariable* rhs,
...@@ -2916,7 +2760,7 @@ public: ...@@ -2916,7 +2760,7 @@ public:
CompilerType* UNDEF = &_UNDEF; CompilerType* UNDEF = &_UNDEF;
ConcreteCompilerVariable* undefVariable() { ConcreteCompilerVariable* undefVariable() {
return new ConcreteCompilerVariable(&_UNDEF, llvm::UndefValue::get(_UNDEF.llvmType()), true); return new ConcreteCompilerVariable(&_UNDEF, llvm::UndefValue::get(_UNDEF.llvmType()));
} }
ConcreteCompilerVariable* boolFromI1(IREmitter& emitter, llvm::Value* v) { ConcreteCompilerVariable* boolFromI1(IREmitter& emitter, llvm::Value* v) {
...@@ -2924,9 +2768,9 @@ ConcreteCompilerVariable* boolFromI1(IREmitter& emitter, llvm::Value* v) { ...@@ -2924,9 +2768,9 @@ ConcreteCompilerVariable* boolFromI1(IREmitter& emitter, llvm::Value* v) {
assert(v->getType() == g.i1); assert(v->getType() == g.i1);
assert(BOOL->llvmType() == g.i64); assert(BOOL->llvmType() == g.i64);
llvm::Value* v2 = emitter.getBuilder()->CreateZExt(v, BOOL->llvmType()); llvm::Value* v2 = emitter.getBuilder()->CreateZExt(v, BOOL->llvmType());
return new ConcreteCompilerVariable(BOOL, v2, true); return new ConcreteCompilerVariable(BOOL, v2);
} else { } else {
return new ConcreteCompilerVariable(BOOL, v, true); return new ConcreteCompilerVariable(BOOL, v);
} }
} }
......
...@@ -93,14 +93,6 @@ public: ...@@ -93,14 +93,6 @@ public:
printf("getBoxType not defined for %s\n", debugName().c_str()); printf("getBoxType not defined for %s\n", debugName().c_str());
abort(); abort();
} }
virtual void drop(IREmitter& emmitter, VAR* var) {
printf("drop not defined for %s\n", debugName().c_str());
abort();
}
virtual void grab(IREmitter& emmitter, VAR* var) {
printf("grab not defined for %s\n", debugName().c_str());
abort();
}
bool canConvertTo(CompilerType* other_type) override { bool canConvertTo(CompilerType* other_type) override {
printf("canConvertTo not defined for %s\n", debugName().c_str()); printf("canConvertTo not defined for %s\n", debugName().c_str());
abort(); abort();
...@@ -216,52 +208,10 @@ public: ...@@ -216,52 +208,10 @@ public:
}; };
class CompilerVariable { class CompilerVariable {
private:
int vrefs;
bool grabbed;
protected:
virtual void drop(IREmitter& emitter) = 0;
virtual void grab(IREmitter& emmitter) = 0;
public: public:
CompilerVariable(bool grabbed) : vrefs(1), grabbed(grabbed) {} CompilerVariable() {}
virtual ~CompilerVariable() {} virtual ~CompilerVariable() {}
bool isGrabbed() { return grabbed; }
void incvref() {
assert(vrefs);
vrefs++;
}
void decvrefNodrop() {
assert(vrefs > 0 && vrefs < (1 << 20));
// It'd be nice to print out the type of the variable, but this is all happening
// after the object got deleted so it's pretty precarious, and the getType()
// debugging call will probably segfault:
// ASSERT(vrefs, "%s", getType()->debugName().c_str());
vrefs--;
if (vrefs == 0) {
delete this;
}
}
void decvref(IREmitter& emitter) {
ASSERT(vrefs > 0 && vrefs < (1 << 20), "%d", vrefs);
// ASSERT(vrefs, "%s", getType()->debugName().c_str());
vrefs--;
if (vrefs == 0) {
if (grabbed)
drop(emitter);
delete this;
}
}
int getVrefs() { return vrefs; }
void ensureGrabbed(IREmitter& emitter) {
if (!grabbed) {
grab(emitter);
grabbed = true;
}
}
virtual CompilerVariable* split(IREmitter& emitter) = 0;
virtual CompilerVariable* dup(DupCache& cache) = 0; virtual CompilerVariable* dup(DupCache& cache) = 0;
virtual CompilerType* getType() = 0; virtual CompilerType* getType() = 0;
...@@ -302,12 +252,8 @@ private: ...@@ -302,12 +252,8 @@ private:
T* type; T* type;
V value; V value;
protected:
void drop(IREmitter& emitter) override { type->drop(emitter, this); }
void grab(IREmitter& emitter) override { type->grab(emitter, this); }
public: public:
ValuedCompilerVariable(T* type, V value, bool grabbed) : CompilerVariable(grabbed), type(type), value(value) { ValuedCompilerVariable(T* type, V value) : CompilerVariable(), type(type), value(value) {
#ifndef NDEBUG #ifndef NDEBUG
type->assertMatches(value); type->assertMatches(value);
#endif #endif
...@@ -318,21 +264,9 @@ public: ...@@ -318,21 +264,9 @@ public:
ConcreteCompilerType* getConcreteType() override { return type->getConcreteType(); } ConcreteCompilerType* getConcreteType() override { return type->getConcreteType(); }
ConcreteCompilerType* getBoxType() override { return type->getBoxType(); } ConcreteCompilerType* getBoxType() override { return type->getBoxType(); }
ValuedCompilerVariable<V>* split(IREmitter& emitter) override {
ValuedCompilerVariable<V>* rtn;
if (getVrefs() == 1) {
rtn = this;
} else {
rtn = new ValuedCompilerVariable<V>(type, value, false);
this->decvref(emitter);
}
rtn->ensureGrabbed(emitter);
return rtn;
}
CompilerVariable* dup(DupCache& cache) override { CompilerVariable* dup(DupCache& cache) override {
CompilerVariable* rtn = type->dup(this, cache); CompilerVariable* rtn = type->dup(this, cache);
ASSERT(rtn->getVrefs() == getVrefs(), "%d %s", rtn->getVrefs(), type->debugName().c_str());
return rtn; return rtn;
} }
...@@ -402,12 +336,6 @@ public: ...@@ -402,12 +336,6 @@ public:
} }
}; };
// template <>
// inline ConcreteCompilerVariable::ValuedCompilerVariable(ConcreteCompilerType *type, llvm::Value* value, bool grabbed)
// : CompilerVariable(grabbed), type(type), value(value) {
// assert(value->getType() == type->llvmType());
//}
// Emit the test for whether one variable 'is' another one. // Emit the test for whether one variable 'is' another one.
ConcreteCompilerVariable* doIs(IREmitter& emitter, CompilerVariable* lhs, CompilerVariable* rhs, bool negate); ConcreteCompilerVariable* doIs(IREmitter& emitter, CompilerVariable* lhs, CompilerVariable* rhs, bool negate);
...@@ -457,7 +385,6 @@ template <typename V> ...@@ -457,7 +385,6 @@ template <typename V>
CompilerVariable* _ValuedCompilerType<V>::getPystonIter(IREmitter& emitter, const OpInfo& info, VAR* var) { CompilerVariable* _ValuedCompilerType<V>::getPystonIter(IREmitter& emitter, const OpInfo& info, VAR* var) {
ConcreteCompilerVariable* converted = makeConverted(emitter, var, getBoxType()); ConcreteCompilerVariable* converted = makeConverted(emitter, var, getBoxType());
auto r = UNKNOWN->getPystonIter(emitter, info, converted); auto r = UNKNOWN->getPystonIter(emitter, info, converted);
converted->decvref(emitter);
return r; return r;
} }
...@@ -466,7 +393,6 @@ CompilerVariable* _ValuedCompilerType<V>::contains(IREmitter& emitter, const OpI ...@@ -466,7 +393,6 @@ CompilerVariable* _ValuedCompilerType<V>::contains(IREmitter& emitter, const OpI
CompilerVariable* rhs) { CompilerVariable* rhs) {
ConcreteCompilerVariable* converted = makeConverted(emitter, var, getBoxType()); ConcreteCompilerVariable* converted = makeConverted(emitter, var, getBoxType());
auto r = UNKNOWN->contains(emitter, info, converted, rhs); auto r = UNKNOWN->contains(emitter, info, converted, rhs);
converted->decvref(emitter);
return r; return r;
} }
...@@ -475,7 +401,6 @@ CompilerVariable* _ValuedCompilerType<V>::unaryop(IREmitter& emitter, const OpIn ...@@ -475,7 +401,6 @@ CompilerVariable* _ValuedCompilerType<V>::unaryop(IREmitter& emitter, const OpIn
AST_TYPE::AST_TYPE op_type) { AST_TYPE::AST_TYPE op_type) {
ConcreteCompilerVariable* converted = makeConverted(emitter, var, getBoxType()); ConcreteCompilerVariable* converted = makeConverted(emitter, var, getBoxType());
auto r = UNKNOWN->unaryop(emitter, info, converted, op_type); auto r = UNKNOWN->unaryop(emitter, info, converted, op_type);
converted->decvref(emitter);
return r; return r;
} }
...@@ -486,7 +411,6 @@ std::vector<CompilerVariable*> _ValuedCompilerType<V>::unpack(IREmitter& emitter ...@@ -486,7 +411,6 @@ std::vector<CompilerVariable*> _ValuedCompilerType<V>::unpack(IREmitter& emitter
ConcreteCompilerVariable* converted = makeConverted(emitter, var, UNKNOWN); ConcreteCompilerVariable* converted = makeConverted(emitter, var, UNKNOWN);
auto r = UNKNOWN->unpack(emitter, info, converted, num_into); auto r = UNKNOWN->unpack(emitter, info, converted, num_into);
converted->decvref(emitter);
return r; return r;
} }
......
...@@ -452,7 +452,7 @@ static void emitBBs(IRGenState* irstate, TypeAnalysis* types, const OSREntryDesc ...@@ -452,7 +452,7 @@ static void emitBBs(IRGenState* irstate, TypeAnalysis* types, const OSREntryDesc
ConcreteCompilerType* phi_type; ConcreteCompilerType* phi_type;
phi_type = getTypeAtBlockStart(types, p.first, target_block); phi_type = getTypeAtBlockStart(types, p.first, target_block);
ConcreteCompilerVariable* var = new ConcreteCompilerVariable(p.second, from_arg, true); ConcreteCompilerVariable* var = new ConcreteCompilerVariable(p.second, from_arg);
(*initial_syms)[p.first] = var; (*initial_syms)[p.first] = var;
// It's possible to OSR into a version of the function with a higher speculation level; // It's possible to OSR into a version of the function with a higher speculation level;
...@@ -477,7 +477,7 @@ static void emitBBs(IRGenState* irstate, TypeAnalysis* types, const OSREntryDesc ...@@ -477,7 +477,7 @@ static void emitBBs(IRGenState* irstate, TypeAnalysis* types, const OSREntryDesc
if (VERBOSITY("irgen") >= 2) if (VERBOSITY("irgen") >= 2)
v->setName("prev_" + p.first.s()); v->setName("prev_" + p.first.s());
(*osr_syms)[p.first] = new ConcreteCompilerVariable(phi_type, v, true); (*osr_syms)[p.first] = new ConcreteCompilerVariable(phi_type, v);
} }
entry_emitter->getBuilder()->CreateBr(osr_unbox_block); entry_emitter->getBuilder()->CreateBr(osr_unbox_block);
...@@ -624,7 +624,7 @@ static void emitBBs(IRGenState* irstate, TypeAnalysis* types, const OSREntryDesc ...@@ -624,7 +624,7 @@ static void emitBBs(IRGenState* irstate, TypeAnalysis* types, const OSREntryDesc
llvm::PHINode* phi = emitter->getBuilder()->CreatePHI(analyzed_type->llvmType(), llvm::PHINode* phi = emitter->getBuilder()->CreatePHI(analyzed_type->llvmType(),
block->predecessors.size() + 1, p.first.s()); block->predecessors.size() + 1, p.first.s());
ConcreteCompilerVariable* var = new ConcreteCompilerVariable(analyzed_type, phi, true); ConcreteCompilerVariable* var = new ConcreteCompilerVariable(analyzed_type, phi);
generator->giveLocalSymbol(p.first, var); generator->giveLocalSymbol(p.first, var);
(*phis)[p.first] = std::make_pair(analyzed_type, phi); (*phis)[p.first] = std::make_pair(analyzed_type, phi);
} }
...@@ -661,7 +661,7 @@ static void emitBBs(IRGenState* irstate, TypeAnalysis* types, const OSREntryDesc ...@@ -661,7 +661,7 @@ static void emitBBs(IRGenState* irstate, TypeAnalysis* types, const OSREntryDesc
ConcreteCompilerType* type = getTypeAtBlockStart(types, s, block); ConcreteCompilerType* type = getTypeAtBlockStart(types, s, block);
llvm::PHINode* phi llvm::PHINode* phi
= emitter->getBuilder()->CreatePHI(type->llvmType(), block->predecessors.size(), s.s()); = emitter->getBuilder()->CreatePHI(type->llvmType(), block->predecessors.size(), s.s());
ConcreteCompilerVariable* var = new ConcreteCompilerVariable(type, phi, true); ConcreteCompilerVariable* var = new ConcreteCompilerVariable(type, phi);
generator->giveLocalSymbol(s, var); generator->giveLocalSymbol(s, var);
(*phis)[s] = std::make_pair(type, phi); (*phis)[s] = std::make_pair(type, phi);
...@@ -761,7 +761,7 @@ static void emitBBs(IRGenState* irstate, TypeAnalysis* types, const OSREntryDesc ...@@ -761,7 +761,7 @@ static void emitBBs(IRGenState* irstate, TypeAnalysis* types, const OSREntryDesc
llvm::PHINode* phi = emitter->getBuilder()->CreatePHI(cv->getType()->llvmType(), llvm::PHINode* phi = emitter->getBuilder()->CreatePHI(cv->getType()->llvmType(),
block->predecessors.size(), name.s()); block->predecessors.size(), name.s());
// emitter->getBuilder()->CreateCall(g.funcs.dump, phi); // emitter->getBuilder()->CreateCall(g.funcs.dump, phi);
ConcreteCompilerVariable* var = new ConcreteCompilerVariable(cv->getType(), phi, true); ConcreteCompilerVariable* var = new ConcreteCompilerVariable(cv->getType(), phi);
generator->giveLocalSymbol(name, var); generator->giveLocalSymbol(name, var);
(*phis)[name] = std::make_pair(cv->getType(), phi); (*phis)[name] = std::make_pair(cv->getType(), phi);
...@@ -851,7 +851,6 @@ static void emitBBs(IRGenState* irstate, TypeAnalysis* types, const OSREntryDesc ...@@ -851,7 +851,6 @@ static void emitBBs(IRGenState* irstate, TypeAnalysis* types, const OSREntryDesc
ConcreteCompilerVariable* v = (*phi_ending_symbol_tables[bpred])[it->first]; ConcreteCompilerVariable* v = (*phi_ending_symbol_tables[bpred])[it->first];
assert(v); assert(v);
assert(v->isGrabbed());
// Make sure they all prepared for the same type: // Make sure they all prepared for the same type:
ASSERT(it->second.first == v->getType(), "%d %d: %s %s %s", b->idx, bpred->idx, it->first.c_str(), ASSERT(it->second.first == v->getType(), "%d %d: %s %s %s", b->idx, bpred->idx, it->first.c_str(),
...@@ -864,7 +863,6 @@ static void emitBBs(IRGenState* irstate, TypeAnalysis* types, const OSREntryDesc ...@@ -864,7 +863,6 @@ static void emitBBs(IRGenState* irstate, TypeAnalysis* types, const OSREntryDesc
if (this_is_osr_entry) { if (this_is_osr_entry) {
ConcreteCompilerVariable* v = (*osr_syms)[it->first]; ConcreteCompilerVariable* v = (*osr_syms)[it->first];
assert(v); assert(v);
assert(v->isGrabbed());
ASSERT(it->second.first == v->getType(), ""); ASSERT(it->second.first == v->getType(), "");
llvm_phi->addIncoming(v->getValue(), osr_unbox_block_end); llvm_phi->addIncoming(v->getValue(), osr_unbox_block_end);
...@@ -880,14 +878,6 @@ static void emitBBs(IRGenState* irstate, TypeAnalysis* types, const OSREntryDesc ...@@ -880,14 +878,6 @@ static void emitBBs(IRGenState* irstate, TypeAnalysis* types, const OSREntryDesc
if (ending_symbol_tables[b] == NULL) if (ending_symbol_tables[b] == NULL)
continue; continue;
for (SymbolTable::iterator it = ending_symbol_tables[b]->begin(); it != ending_symbol_tables[b]->end(); ++it) {
it->second->decvrefNodrop();
}
for (ConcreteSymbolTable::iterator it = phi_ending_symbol_tables[b]->begin();
it != phi_ending_symbol_tables[b]->end(); ++it) {
it->second->decvrefNodrop();
}
delete phi_ending_symbol_tables[b];
delete ending_symbol_tables[b]; delete ending_symbol_tables[b];
delete created_phis[b]; delete created_phis[b];
} }
......
...@@ -645,14 +645,12 @@ private: ...@@ -645,14 +645,12 @@ private:
CompilerVariable* value = evalExpr(node->value, unw_info); CompilerVariable* value = evalExpr(node->value, unw_info);
CompilerVariable* rtn = value->getattr(emitter, getOpInfoForNode(node, unw_info), node->attr.getBox(), false); CompilerVariable* rtn = value->getattr(emitter, getOpInfoForNode(node, unw_info), node->attr.getBox(), false);
value->decvref(emitter);
return rtn; return rtn;
} }
CompilerVariable* evalClsAttribute(AST_ClsAttribute* node, const UnwindInfo& unw_info) { CompilerVariable* evalClsAttribute(AST_ClsAttribute* node, const UnwindInfo& unw_info) {
CompilerVariable* value = evalExpr(node->value, unw_info); CompilerVariable* value = evalExpr(node->value, unw_info);
CompilerVariable* rtn = value->getattr(emitter, getOpInfoForNode(node, unw_info), node->attr.getBox(), true); CompilerVariable* rtn = value->getattr(emitter, getOpInfoForNode(node, unw_info), node->attr.getBox(), true);
value->decvref(emitter);
return rtn; return rtn;
} }
...@@ -665,8 +663,6 @@ private: ...@@ -665,8 +663,6 @@ private:
ConcreteCompilerVariable* converted_obj = obj->makeConverted(emitter, obj->getBoxType()); ConcreteCompilerVariable* converted_obj = obj->makeConverted(emitter, obj->getBoxType());
ConcreteCompilerVariable* converted_cls = cls->makeConverted(emitter, cls->getBoxType()); ConcreteCompilerVariable* converted_cls = cls->makeConverted(emitter, cls->getBoxType());
obj->decvref(emitter);
cls->decvref(emitter);
llvm::Value* v = emitter.createCall(unw_info, g.funcs.exceptionMatches, llvm::Value* v = emitter.createCall(unw_info, g.funcs.exceptionMatches,
{ converted_obj->getValue(), converted_cls->getValue() }); { converted_obj->getValue(), converted_cls->getValue() });
...@@ -696,9 +692,9 @@ private: ...@@ -696,9 +692,9 @@ private:
phi_exc_value->addIncoming(e.exc_value->getValue(), e.from_block); phi_exc_value->addIncoming(e.exc_value->getValue(), e.from_block);
phi_exc_tb->addIncoming(e.exc_tb->getValue(), e.from_block); phi_exc_tb->addIncoming(e.exc_tb->getValue(), e.from_block);
} }
exc_type = new ConcreteCompilerVariable(UNKNOWN, phi_exc_type, true); exc_type = new ConcreteCompilerVariable(UNKNOWN, phi_exc_type);
exc_value = new ConcreteCompilerVariable(UNKNOWN, phi_exc_value, true); exc_value = new ConcreteCompilerVariable(UNKNOWN, phi_exc_value);
exc_tb = new ConcreteCompilerVariable(UNKNOWN, phi_exc_tb, true); exc_tb = new ConcreteCompilerVariable(UNKNOWN, phi_exc_tb);
} }
} else { } else {
// There can be no incoming exception if the irgenerator was able to prove that // There can be no incoming exception if the irgenerator was able to prove that
...@@ -717,13 +713,12 @@ private: ...@@ -717,13 +713,12 @@ private:
return makeTuple({ exc_type, exc_value, exc_tb }); return makeTuple({ exc_type, exc_value, exc_tb });
} }
case AST_LangPrimitive::LOCALS: { case AST_LangPrimitive::LOCALS: {
return new ConcreteCompilerVariable(UNKNOWN, irstate->getBoxedLocalsVar(), true); return new ConcreteCompilerVariable(UNKNOWN, irstate->getBoxedLocalsVar());
} }
case AST_LangPrimitive::GET_ITER: { case AST_LangPrimitive::GET_ITER: {
assert(node->args.size() == 1); assert(node->args.size() == 1);
CompilerVariable* obj = evalExpr(node->args[0], unw_info); CompilerVariable* obj = evalExpr(node->args[0], unw_info);
auto rtn = obj->getPystonIter(emitter, getOpInfoForNode(node, unw_info)); auto rtn = obj->getPystonIter(emitter, getOpInfoForNode(node, unw_info));
obj->decvref(emitter);
return rtn; return rtn;
} }
case AST_LangPrimitive::IMPORT_FROM: { case AST_LangPrimitive::IMPORT_FROM: {
...@@ -733,7 +728,6 @@ private: ...@@ -733,7 +728,6 @@ private:
CompilerVariable* module = evalExpr(node->args[0], unw_info); CompilerVariable* module = evalExpr(node->args[0], unw_info);
ConcreteCompilerVariable* converted_module = module->makeConverted(emitter, module->getBoxType()); ConcreteCompilerVariable* converted_module = module->makeConverted(emitter, module->getBoxType());
module->decvref(emitter);
auto ast_str = ast_cast<AST_Str>(node->args[1]); auto ast_str = ast_cast<AST_Str>(node->args[1]);
assert(ast_str->str_type == AST_Str::STR); assert(ast_str->str_type == AST_Str::STR);
...@@ -746,9 +740,7 @@ private: ...@@ -746,9 +740,7 @@ private:
llvm::Value* r llvm::Value* r
= emitter.createCall2(unw_info, g.funcs.importFrom, converted_module->getValue(), name_arg); = emitter.createCall2(unw_info, g.funcs.importFrom, converted_module->getValue(), name_arg);
CompilerVariable* v = new ConcreteCompilerVariable(UNKNOWN, r, true); CompilerVariable* v = new ConcreteCompilerVariable(UNKNOWN, r);
converted_module->decvref(emitter);
return v; return v;
} }
case AST_LangPrimitive::IMPORT_STAR: { case AST_LangPrimitive::IMPORT_STAR: {
...@@ -760,13 +752,10 @@ private: ...@@ -760,13 +752,10 @@ private:
CompilerVariable* module = evalExpr(node->args[0], unw_info); CompilerVariable* module = evalExpr(node->args[0], unw_info);
ConcreteCompilerVariable* converted_module = module->makeConverted(emitter, module->getBoxType()); ConcreteCompilerVariable* converted_module = module->makeConverted(emitter, module->getBoxType());
module->decvref(emitter);
llvm::Value* r = emitter.createCall2(unw_info, g.funcs.importStar, converted_module->getValue(), llvm::Value* r = emitter.createCall2(unw_info, g.funcs.importStar, converted_module->getValue(),
irstate->getGlobals()); irstate->getGlobals());
CompilerVariable* v = new ConcreteCompilerVariable(UNKNOWN, r, true); CompilerVariable* v = new ConcreteCompilerVariable(UNKNOWN, r);
converted_module->decvref(emitter);
return v; return v;
} }
case AST_LangPrimitive::IMPORT_NAME: { case AST_LangPrimitive::IMPORT_NAME: {
...@@ -780,7 +769,6 @@ private: ...@@ -780,7 +769,6 @@ private:
// TODO this could be a constant Box* too // TODO this could be a constant Box* too
CompilerVariable* froms = evalExpr(node->args[1], unw_info); CompilerVariable* froms = evalExpr(node->args[1], unw_info);
ConcreteCompilerVariable* converted_froms = froms->makeConverted(emitter, froms->getBoxType()); ConcreteCompilerVariable* converted_froms = froms->makeConverted(emitter, froms->getBoxType());
froms->decvref(emitter);
auto ast_str = ast_cast<AST_Str>(node->args[2]); auto ast_str = ast_cast<AST_Str>(node->args[2]);
assert(ast_str->str_type == AST_Str::STR); assert(ast_str->str_type == AST_Str::STR);
...@@ -790,9 +778,7 @@ private: ...@@ -790,9 +778,7 @@ private:
{ getConstantInt(level, g.i32), converted_froms->getValue(), { getConstantInt(level, g.i32), converted_froms->getValue(),
embedRelocatablePtr(module_name.c_str(), g.i8_ptr), embedRelocatablePtr(module_name.c_str(), g.i8_ptr),
getConstantInt(module_name.size(), g.i64) }); getConstantInt(module_name.size(), g.i64) });
ConcreteCompilerVariable* v = new ConcreteCompilerVariable(UNKNOWN, imported, true); ConcreteCompilerVariable* v = new ConcreteCompilerVariable(UNKNOWN, imported);
converted_froms->decvref(emitter);
return v; return v;
} }
case AST_LangPrimitive::NONE: { case AST_LangPrimitive::NONE: {
...@@ -803,7 +789,6 @@ private: ...@@ -803,7 +789,6 @@ private:
CompilerVariable* obj = evalExpr(node->args[0], unw_info); CompilerVariable* obj = evalExpr(node->args[0], unw_info);
CompilerVariable* rtn = obj->nonzero(emitter, getOpInfoForNode(node, unw_info)); CompilerVariable* rtn = obj->nonzero(emitter, getOpInfoForNode(node, unw_info));
obj->decvref(emitter);
return rtn; return rtn;
} }
case AST_LangPrimitive::HASNEXT: { case AST_LangPrimitive::HASNEXT: {
...@@ -811,7 +796,6 @@ private: ...@@ -811,7 +796,6 @@ private:
CompilerVariable* obj = evalExpr(node->args[0], unw_info); CompilerVariable* obj = evalExpr(node->args[0], unw_info);
CompilerVariable* rtn = obj->hasnext(emitter, getOpInfoForNode(node, unw_info)); CompilerVariable* rtn = obj->hasnext(emitter, getOpInfoForNode(node, unw_info));
obj->decvref(emitter);
return rtn; return rtn;
} }
case AST_LangPrimitive::SET_EXC_INFO: { case AST_LangPrimitive::SET_EXC_INFO: {
...@@ -828,14 +812,11 @@ private: ...@@ -828,14 +812,11 @@ private:
ConcreteCompilerVariable* converted_type = type->makeConverted(emitter, UNKNOWN); ConcreteCompilerVariable* converted_type = type->makeConverted(emitter, UNKNOWN);
builder->CreateStore(converted_type->getValue(), builder->CreateConstInBoundsGEP2_32(exc_info, 0, 0)); builder->CreateStore(converted_type->getValue(), builder->CreateConstInBoundsGEP2_32(exc_info, 0, 0));
converted_type->decvref(emitter);
ConcreteCompilerVariable* converted_value = value->makeConverted(emitter, UNKNOWN); ConcreteCompilerVariable* converted_value = value->makeConverted(emitter, UNKNOWN);
builder->CreateStore(converted_value->getValue(), builder->CreateConstInBoundsGEP2_32(exc_info, 0, 1)); builder->CreateStore(converted_value->getValue(), builder->CreateConstInBoundsGEP2_32(exc_info, 0, 1));
converted_value->decvref(emitter);
ConcreteCompilerVariable* converted_traceback = traceback->makeConverted(emitter, UNKNOWN); ConcreteCompilerVariable* converted_traceback = traceback->makeConverted(emitter, UNKNOWN);
builder->CreateStore(converted_traceback->getValue(), builder->CreateStore(converted_traceback->getValue(),
builder->CreateConstInBoundsGEP2_32(exc_info, 0, 2)); builder->CreateConstInBoundsGEP2_32(exc_info, 0, 2));
converted_traceback->decvref(emitter);
return getNone(); return getNone();
} }
...@@ -899,8 +880,6 @@ private: ...@@ -899,8 +880,6 @@ private:
assert(node->op_type != AST_TYPE::Is && node->op_type != AST_TYPE::IsNot && "not tested yet"); assert(node->op_type != AST_TYPE::Is && node->op_type != AST_TYPE::IsNot && "not tested yet");
CompilerVariable* rtn = this->_evalBinExp(node, left, right, node->op_type, BinOp, unw_info); CompilerVariable* rtn = this->_evalBinExp(node, left, right, node->op_type, BinOp, unw_info);
left->decvref(emitter);
right->decvref(emitter);
return rtn; return rtn;
} }
...@@ -911,8 +890,6 @@ private: ...@@ -911,8 +890,6 @@ private:
assert(node->op_type != AST_TYPE::Is && node->op_type != AST_TYPE::IsNot && "not tested yet"); assert(node->op_type != AST_TYPE::Is && node->op_type != AST_TYPE::IsNot && "not tested yet");
CompilerVariable* rtn = this->_evalBinExp(node, left, right, node->op_type, AugBinOp, unw_info); CompilerVariable* rtn = this->_evalBinExp(node, left, right, node->op_type, AugBinOp, unw_info);
left->decvref(emitter);
right->decvref(emitter);
return rtn; return rtn;
} }
...@@ -930,8 +907,6 @@ private: ...@@ -930,8 +907,6 @@ private:
} }
CompilerVariable* rtn = _evalBinExp(node, left, right, node->ops[0], Compare, unw_info); CompilerVariable* rtn = _evalBinExp(node, left, right, node->ops[0], Compare, unw_info);
left->decvref(emitter);
right->decvref(emitter);
return rtn; return rtn;
} }
...@@ -992,17 +967,12 @@ private: ...@@ -992,17 +967,12 @@ private:
rtn = func->call(emitter, getOpInfoForNode(node, unw_info), argspec, args, keyword_names); rtn = func->call(emitter, getOpInfoForNode(node, unw_info), argspec, args, keyword_names);
} }
func->decvref(emitter);
for (int i = 0; i < args.size(); i++) {
args[i]->decvref(emitter);
}
return rtn; return rtn;
} }
CompilerVariable* evalDict(AST_Dict* node, const UnwindInfo& unw_info) { CompilerVariable* evalDict(AST_Dict* node, const UnwindInfo& unw_info) {
llvm::Value* v = emitter.getBuilder()->CreateCall(g.funcs.createDict); llvm::Value* v = emitter.getBuilder()->CreateCall(g.funcs.createDict);
ConcreteCompilerVariable* rtn = new ConcreteCompilerVariable(DICT, v, true); ConcreteCompilerVariable* rtn = new ConcreteCompilerVariable(DICT, v);
if (node->keys.size()) { if (node->keys.size()) {
static BoxedString* setitem_str = getStaticString("__setitem__"); static BoxedString* setitem_str = getStaticString("__setitem__");
CompilerVariable* setitem = rtn->getattr(emitter, getEmptyOpInfo(unw_info), setitem_str, true); CompilerVariable* setitem = rtn->getattr(emitter, getEmptyOpInfo(unw_info), setitem_str, true);
...@@ -1017,12 +987,7 @@ private: ...@@ -1017,12 +987,7 @@ private:
args.push_back(value); args.push_back(value);
// TODO should use callattr // TODO should use callattr
CompilerVariable* rtn = setitem->call(emitter, getEmptyOpInfo(unw_info), ArgPassSpec(2), args, NULL); CompilerVariable* rtn = setitem->call(emitter, getEmptyOpInfo(unw_info), ArgPassSpec(2), args, NULL);
rtn->decvref(emitter);
key->decvref(emitter);
value->decvref(emitter);
} }
setitem->decvref(emitter);
} }
return rtn; return rtn;
} }
...@@ -1044,7 +1009,6 @@ private: ...@@ -1044,7 +1009,6 @@ private:
std::vector<AST_stmt*> body = { expr }; std::vector<AST_stmt*> body = { expr };
CompilerVariable* func = _createFunction(node, unw_info, node->args, body); CompilerVariable* func = _createFunction(node, unw_info, node->args, body);
ConcreteCompilerVariable* converted = func->makeConverted(emitter, func->getBoxType()); ConcreteCompilerVariable* converted = func->makeConverted(emitter, func->getBoxType());
func->decvref(emitter);
return converted; return converted;
} }
...@@ -1058,7 +1022,7 @@ private: ...@@ -1058,7 +1022,7 @@ private:
} }
llvm::Value* v = emitter.getBuilder()->CreateCall(g.funcs.createList); llvm::Value* v = emitter.getBuilder()->CreateCall(g.funcs.createList);
ConcreteCompilerVariable* rtn = new ConcreteCompilerVariable(LIST, v, true); ConcreteCompilerVariable* rtn = new ConcreteCompilerVariable(LIST, v);
llvm::Value* f = g.funcs.listAppendInternal; llvm::Value* f = g.funcs.listAppendInternal;
llvm::Value* bitcast = emitter.getBuilder()->CreateBitCast( llvm::Value* bitcast = emitter.getBuilder()->CreateBitCast(
...@@ -1068,10 +1032,8 @@ private: ...@@ -1068,10 +1032,8 @@ private:
for (int i = 0; i < node->elts.size(); i++) { for (int i = 0; i < node->elts.size(); i++) {
CompilerVariable* elt = elts[i]; CompilerVariable* elt = elts[i];
ConcreteCompilerVariable* converted = elt->makeConverted(emitter, elt->getBoxType()); ConcreteCompilerVariable* converted = elt->makeConverted(emitter, elt->getBoxType());
elt->decvref(emitter);
emitter.createCall2(unw_info, f, bitcast, converted->getValue()); emitter.createCall2(unw_info, f, bitcast, converted->getValue());
converted->decvref(emitter);
} }
return rtn; return rtn;
} }
...@@ -1079,7 +1041,7 @@ private: ...@@ -1079,7 +1041,7 @@ private:
ConcreteCompilerVariable* getEllipsis() { ConcreteCompilerVariable* getEllipsis() {
llvm::Constant* ellipsis = embedRelocatablePtr(Ellipsis, g.llvm_value_type_ptr, "cEllipsis"); llvm::Constant* ellipsis = embedRelocatablePtr(Ellipsis, g.llvm_value_type_ptr, "cEllipsis");
auto ellipsis_cls = Ellipsis->cls; auto ellipsis_cls = Ellipsis->cls;
return new ConcreteCompilerVariable(typeFromClass(ellipsis_cls), ellipsis, false); return new ConcreteCompilerVariable(typeFromClass(ellipsis_cls), ellipsis);
} }
llvm::Constant* embedParentModulePtr() { llvm::Constant* embedParentModulePtr() {
...@@ -1101,11 +1063,11 @@ private: ...@@ -1101,11 +1063,11 @@ private:
llvm::Value* uncasted = emitter.createIC(pp, (void*)pyston::getGlobal, llvm_args, unw_info); llvm::Value* uncasted = emitter.createIC(pp, (void*)pyston::getGlobal, llvm_args, unw_info);
llvm::Value* r = emitter.getBuilder()->CreateIntToPtr(uncasted, g.llvm_value_type_ptr); llvm::Value* r = emitter.getBuilder()->CreateIntToPtr(uncasted, g.llvm_value_type_ptr);
return new ConcreteCompilerVariable(UNKNOWN, r, true); return new ConcreteCompilerVariable(UNKNOWN, r);
} else { } else {
llvm::Value* r = emitter.createCall2(unw_info, g.funcs.getGlobal, irstate->getGlobals(), llvm::Value* r = emitter.createCall2(unw_info, g.funcs.getGlobal, irstate->getGlobals(),
embedRelocatablePtr(node->id.getBox(), g.llvm_boxedstring_type_ptr)); embedRelocatablePtr(node->id.getBox(), g.llvm_boxedstring_type_ptr));
return new ConcreteCompilerVariable(UNKNOWN, r, true); return new ConcreteCompilerVariable(UNKNOWN, r);
} }
} }
...@@ -1135,7 +1097,6 @@ private: ...@@ -1135,7 +1097,6 @@ private:
// Where the parent lookup is done `deref_info.num_parents_from_passed_closure` times // Where the parent lookup is done `deref_info.num_parents_from_passed_closure` times
CompilerVariable* closure = symbol_table[internString(PASSED_CLOSURE_NAME)]; CompilerVariable* closure = symbol_table[internString(PASSED_CLOSURE_NAME)];
llvm::Value* closureValue = closure->makeConverted(emitter, CLOSURE)->getValue(); llvm::Value* closureValue = closure->makeConverted(emitter, CLOSURE)->getValue();
closure->decvref(emitter);
for (int i = 0; i < deref_info.num_parents_from_passed_closure; i++) { for (int i = 0; i < deref_info.num_parents_from_passed_closure; i++) {
closureValue = emitter.getBuilder()->CreateLoad(getClosureParentGep(emitter, closureValue)); closureValue = emitter.getBuilder()->CreateLoad(getClosureParentGep(emitter, closureValue));
} }
...@@ -1167,13 +1128,13 @@ private: ...@@ -1167,13 +1128,13 @@ private:
curblock = success_bb; curblock = success_bb;
emitter.getBuilder()->SetInsertPoint(curblock); emitter.getBuilder()->SetInsertPoint(curblock);
return new ConcreteCompilerVariable(UNKNOWN, lookupResult, true); return new ConcreteCompilerVariable(UNKNOWN, lookupResult);
} else if (vst == ScopeInfo::VarScopeType::NAME) { } else if (vst == ScopeInfo::VarScopeType::NAME) {
llvm::Value* boxedLocals = irstate->getBoxedLocalsVar(); llvm::Value* boxedLocals = irstate->getBoxedLocalsVar();
llvm::Value* attr = embedRelocatablePtr(node->id.getBox(), g.llvm_boxedstring_type_ptr); llvm::Value* attr = embedRelocatablePtr(node->id.getBox(), g.llvm_boxedstring_type_ptr);
llvm::Value* module = irstate->getGlobals(); llvm::Value* module = irstate->getGlobals();
llvm::Value* r = emitter.createCall3(unw_info, g.funcs.boxedLocalsGet, boxedLocals, attr, module); llvm::Value* r = emitter.createCall3(unw_info, g.funcs.boxedLocalsGet, boxedLocals, attr, module);
return new ConcreteCompilerVariable(UNKNOWN, r, true); return new ConcreteCompilerVariable(UNKNOWN, r);
} else { } else {
// vst is one of {FAST, CLOSURE} // vst is one of {FAST, CLOSURE}
if (symbol_table.find(node->id) == symbol_table.end()) { if (symbol_table.find(node->id) == symbol_table.end()) {
...@@ -1204,8 +1165,6 @@ private: ...@@ -1204,8 +1165,6 @@ private:
CompilerVariable* rtn = symbol_table[node->id]; CompilerVariable* rtn = symbol_table[node->id];
if (is_kill) if (is_kill)
symbol_table.erase(node->id); symbol_table.erase(node->id);
else
rtn->incvref();
return rtn; return rtn;
} }
} }
...@@ -1227,14 +1186,12 @@ private: ...@@ -1227,14 +1186,12 @@ private:
CompilerVariable* evalRepr(AST_Repr* node, const UnwindInfo& unw_info) { CompilerVariable* evalRepr(AST_Repr* node, const UnwindInfo& unw_info) {
CompilerVariable* var = evalExpr(node->value, unw_info); CompilerVariable* var = evalExpr(node->value, unw_info);
ConcreteCompilerVariable* cvar = var->makeConverted(emitter, var->getBoxType()); ConcreteCompilerVariable* cvar = var->makeConverted(emitter, var->getBoxType());
var->decvref(emitter);
std::vector<llvm::Value*> args{ cvar->getValue() }; std::vector<llvm::Value*> args{ cvar->getValue() };
llvm::Value* rtn = emitter.createCall(unw_info, g.funcs.repr, args); llvm::Value* rtn = emitter.createCall(unw_info, g.funcs.repr, args);
cvar->decvref(emitter);
rtn = emitter.getBuilder()->CreateBitCast(rtn, g.llvm_value_type_ptr); rtn = emitter.getBuilder()->CreateBitCast(rtn, g.llvm_value_type_ptr);
return new ConcreteCompilerVariable(STR, rtn, true); return new ConcreteCompilerVariable(STR, rtn);
} }
CompilerVariable* evalSet(AST_Set* node, const UnwindInfo& unw_info) { CompilerVariable* evalSet(AST_Set* node, const UnwindInfo& unw_info) {
...@@ -1245,7 +1202,7 @@ private: ...@@ -1245,7 +1202,7 @@ private:
} }
llvm::Value* v = emitter.getBuilder()->CreateCall(g.funcs.createSet); llvm::Value* v = emitter.getBuilder()->CreateCall(g.funcs.createSet);
ConcreteCompilerVariable* rtn = new ConcreteCompilerVariable(SET, v, true); ConcreteCompilerVariable* rtn = new ConcreteCompilerVariable(SET, v);
static BoxedString* add_str = getStaticString("add"); static BoxedString* add_str = getStaticString("add");
...@@ -1254,8 +1211,6 @@ private: ...@@ -1254,8 +1211,6 @@ private:
CallattrFlags flags = {.cls_only = true, .null_on_nonexistent = false, .argspec = ArgPassSpec(1) }; CallattrFlags flags = {.cls_only = true, .null_on_nonexistent = false, .argspec = ArgPassSpec(1) };
CompilerVariable* r CompilerVariable* r
= rtn->callattr(emitter, getOpInfoForNode(node, unw_info), add_str, flags, { elt }, NULL); = rtn->callattr(emitter, getOpInfoForNode(node, unw_info), add_str, flags, { elt }, NULL);
r->decvref(emitter);
elt->decvref(emitter);
} }
return rtn; return rtn;
...@@ -1276,11 +1231,7 @@ private: ...@@ -1276,11 +1231,7 @@ private:
elts.push_back(evalSlice(e, unw_info)); elts.push_back(evalSlice(e, unw_info));
} }
// TODO makeTuple should probably just transfer the vref, but I want to keep things consistent
CompilerVariable* rtn = makeTuple(elts); CompilerVariable* rtn = makeTuple(elts);
for (auto* e : elts) {
e->decvref(emitter);
}
return rtn; return rtn;
} }
...@@ -1290,12 +1241,12 @@ private: ...@@ -1290,12 +1241,12 @@ private:
= embedRelocatablePtr(irstate->getSourceInfo()->parent_module->getStringConstant(node->str_data, true), = embedRelocatablePtr(irstate->getSourceInfo()->parent_module->getStringConstant(node->str_data, true),
g.llvm_value_type_ptr); g.llvm_value_type_ptr);
return new ConcreteCompilerVariable(STR, rtn, true); return new ConcreteCompilerVariable(STR, rtn);
} else if (node->str_type == AST_Str::UNICODE) { } else if (node->str_type == AST_Str::UNICODE) {
llvm::Value* rtn = embedRelocatablePtr( llvm::Value* rtn = embedRelocatablePtr(
irstate->getSourceInfo()->parent_module->getUnicodeConstant(node->str_data), g.llvm_value_type_ptr); irstate->getSourceInfo()->parent_module->getUnicodeConstant(node->str_data), g.llvm_value_type_ptr);
return new ConcreteCompilerVariable(typeFromClass(unicode_cls), rtn, true); return new ConcreteCompilerVariable(typeFromClass(unicode_cls), rtn);
} else { } else {
RELEASE_ASSERT(0, "%d", node->str_type); RELEASE_ASSERT(0, "%d", node->str_type);
} }
...@@ -1306,8 +1257,6 @@ private: ...@@ -1306,8 +1257,6 @@ private:
CompilerVariable* slice = evalSlice(node->slice, unw_info); CompilerVariable* slice = evalSlice(node->slice, unw_info);
CompilerVariable* rtn = value->getitem(emitter, getOpInfoForNode(node, unw_info), slice); CompilerVariable* rtn = value->getitem(emitter, getOpInfoForNode(node, unw_info), slice);
value->decvref(emitter);
slice->decvref(emitter);
return rtn; return rtn;
} }
...@@ -1318,11 +1267,7 @@ private: ...@@ -1318,11 +1267,7 @@ private:
elts.push_back(value); elts.push_back(value);
} }
// TODO makeTuple should probably just transfer the vref, but I want to keep things consistent
CompilerVariable* rtn = makeTuple(elts); CompilerVariable* rtn = makeTuple(elts);
for (int i = 0; i < node->elts.size(); i++) {
elts[i]->decvref(emitter);
}
return rtn; return rtn;
} }
...@@ -1331,18 +1276,15 @@ private: ...@@ -1331,18 +1276,15 @@ private:
if (node->op_type == AST_TYPE::Not) { if (node->op_type == AST_TYPE::Not) {
CompilerVariable* rtn = operand->nonzero(emitter, getOpInfoForNode(node, unw_info)); CompilerVariable* rtn = operand->nonzero(emitter, getOpInfoForNode(node, unw_info));
operand->decvref(emitter);
assert(rtn->getType() == BOOL); assert(rtn->getType() == BOOL);
llvm::Value* v = i1FromBool(emitter, static_cast<ConcreteCompilerVariable*>(rtn)); llvm::Value* v = i1FromBool(emitter, static_cast<ConcreteCompilerVariable*>(rtn));
assert(v->getType() == g.i1); assert(v->getType() == g.i1);
llvm::Value* negated = emitter.getBuilder()->CreateNot(v); llvm::Value* negated = emitter.getBuilder()->CreateNot(v);
rtn->decvref(emitter);
return boolFromI1(emitter, negated); return boolFromI1(emitter, negated);
} else { } else {
CompilerVariable* rtn = operand->unaryop(emitter, getOpInfoForNode(node, unw_info), node->op_type); CompilerVariable* rtn = operand->unaryop(emitter, getOpInfoForNode(node, unw_info), node->op_type);
operand->decvref(emitter);
return rtn; return rtn;
} }
} }
...@@ -1355,14 +1297,11 @@ private: ...@@ -1355,14 +1297,11 @@ private:
CompilerVariable* value = node->value ? evalExpr(node->value, unw_info) : getNone(); CompilerVariable* value = node->value ? evalExpr(node->value, unw_info) : getNone();
ConcreteCompilerVariable* convertedValue = value->makeConverted(emitter, value->getBoxType()); ConcreteCompilerVariable* convertedValue = value->makeConverted(emitter, value->getBoxType());
value->decvref(emitter);
llvm::Value* rtn llvm::Value* rtn
= emitter.createCall2(unw_info, g.funcs.yield, convertedGenerator->getValue(), convertedValue->getValue()); = emitter.createCall2(unw_info, g.funcs.yield, convertedGenerator->getValue(), convertedValue->getValue());
convertedGenerator->decvref(emitter);
convertedValue->decvref(emitter);
return new ConcreteCompilerVariable(UNKNOWN, rtn, true); return new ConcreteCompilerVariable(UNKNOWN, rtn);
} }
CompilerVariable* evalMakeClass(AST_MakeClass* mkclass, const UnwindInfo& unw_info) { CompilerVariable* evalMakeClass(AST_MakeClass* mkclass, const UnwindInfo& unw_info) {
...@@ -1378,12 +1317,7 @@ private: ...@@ -1378,12 +1317,7 @@ private:
} }
CompilerVariable* _bases_tuple = makeTuple(bases); CompilerVariable* _bases_tuple = makeTuple(bases);
for (auto b : bases) {
b->decvref(emitter);
}
ConcreteCompilerVariable* bases_tuple = _bases_tuple->makeConverted(emitter, _bases_tuple->getBoxType()); ConcreteCompilerVariable* bases_tuple = _bases_tuple->makeConverted(emitter, _bases_tuple->getBoxType());
_bases_tuple->decvref(emitter);
std::vector<CompilerVariable*> decorators; std::vector<CompilerVariable*> decorators;
for (auto d : node->decorator_list) { for (auto d : node->decorator_list) {
...@@ -1413,24 +1347,19 @@ private: ...@@ -1413,24 +1347,19 @@ private:
CompilerVariable* attr_dict = func->call(emitter, getEmptyOpInfo(unw_info), ArgPassSpec(0), {}, NULL); CompilerVariable* attr_dict = func->call(emitter, getEmptyOpInfo(unw_info), ArgPassSpec(0), {}, NULL);
func->decvref(emitter);
ConcreteCompilerVariable* converted_attr_dict = attr_dict->makeConverted(emitter, attr_dict->getBoxType()); ConcreteCompilerVariable* converted_attr_dict = attr_dict->makeConverted(emitter, attr_dict->getBoxType());
attr_dict->decvref(emitter);
llvm::Value* classobj = emitter.createCall3( llvm::Value* classobj = emitter.createCall3(
unw_info, g.funcs.createUserClass, embedRelocatablePtr(node->name.getBox(), g.llvm_boxedstring_type_ptr), unw_info, g.funcs.createUserClass, embedRelocatablePtr(node->name.getBox(), g.llvm_boxedstring_type_ptr),
bases_tuple->getValue(), converted_attr_dict->getValue()); bases_tuple->getValue(), converted_attr_dict->getValue());
// Note: createuserClass is free to manufacture non-class objects // Note: createuserClass is free to manufacture non-class objects
CompilerVariable* cls = new ConcreteCompilerVariable(UNKNOWN, classobj, true); CompilerVariable* cls = new ConcreteCompilerVariable(UNKNOWN, classobj);
for (int i = decorators.size() - 1; i >= 0; i--) { for (int i = decorators.size() - 1; i >= 0; i--) {
cls = decorators[i]->call(emitter, getOpInfoForNode(node, unw_info), ArgPassSpec(1), { cls }, NULL); cls = decorators[i]->call(emitter, getOpInfoForNode(node, unw_info), ArgPassSpec(1), { cls }, NULL);
decorators[i]->decvref(emitter);
} }
// do we need to decvref this?
return cls; return cls;
} }
...@@ -1442,7 +1371,6 @@ private: ...@@ -1442,7 +1371,6 @@ private:
for (auto d : args->defaults) { for (auto d : args->defaults) {
CompilerVariable* e = evalExpr(d, unw_info); CompilerVariable* e = evalExpr(d, unw_info);
ConcreteCompilerVariable* converted = e->makeConverted(emitter, e->getBoxType()); ConcreteCompilerVariable* converted = e->makeConverted(emitter, e->getBoxType());
e->decvref(emitter);
defaults.push_back(converted); defaults.push_back(converted);
} }
...@@ -1474,10 +1402,6 @@ private: ...@@ -1474,10 +1402,6 @@ private:
CompilerVariable* func = makeFunction(emitter, md, created_closure, irstate->getGlobalsIfCustom(), defaults); CompilerVariable* func = makeFunction(emitter, md, created_closure, irstate->getGlobalsIfCustom(), defaults);
for (auto d : defaults) {
d->decvref(emitter);
}
return func; return func;
} }
...@@ -1492,14 +1416,13 @@ private: ...@@ -1492,14 +1416,13 @@ private:
for (int i = decorators.size() - 1; i >= 0; i--) { for (int i = decorators.size() - 1; i >= 0; i--) {
func = decorators[i]->call(emitter, getOpInfoForNode(node, unw_info), ArgPassSpec(1), { func }, NULL); func = decorators[i]->call(emitter, getOpInfoForNode(node, unw_info), ArgPassSpec(1), { func }, NULL);
decorators[i]->decvref(emitter);
} }
return func; return func;
} }
// Note: the behavior of this function must match type_analysis.cpp:unboxedType() // Note: the behavior of this function must match type_analysis.cpp:unboxedType()
CompilerVariable* unboxVar(ConcreteCompilerType* t, llvm::Value* v, bool grabbed) { CompilerVariable* unboxVar(ConcreteCompilerType* t, llvm::Value* v) {
if (t == BOXED_INT) { if (t == BOXED_INT) {
return makeUnboxedInt(emitter, v); return makeUnboxedInt(emitter, v);
} }
...@@ -1510,7 +1433,7 @@ private: ...@@ -1510,7 +1433,7 @@ private:
llvm::Value* unboxed = emitter.getBuilder()->CreateCall(g.funcs.unboxBool, v); llvm::Value* unboxed = emitter.getBuilder()->CreateCall(g.funcs.unboxBool, v);
return boolFromI1(emitter, unboxed); return boolFromI1(emitter, unboxed);
} }
return new ConcreteCompilerVariable(t, v, grabbed); return new ConcreteCompilerVariable(t, v);
} }
template <typename AstType> template <typename AstType>
...@@ -1546,13 +1469,12 @@ private: ...@@ -1546,13 +1469,12 @@ private:
#endif #endif
ConcreteCompilerVariable* old_rtn = rtn->makeConverted(emitter, UNKNOWN); ConcreteCompilerVariable* old_rtn = rtn->makeConverted(emitter, UNKNOWN);
rtn->decvref(emitter);
llvm::Value* guard_check = old_rtn->makeClassCheck(emitter, speculated_class); llvm::Value* guard_check = old_rtn->makeClassCheck(emitter, speculated_class);
assert(guard_check->getType() == g.i1); assert(guard_check->getType() == g.i1);
createExprTypeGuard(guard_check, node, old_rtn->getValue(), unw_info.current_stmt); createExprTypeGuard(guard_check, node, old_rtn->getValue(), unw_info.current_stmt);
rtn = unboxVar(speculated_type, old_rtn->getValue(), true); rtn = unboxVar(speculated_type, old_rtn->getValue());
} }
assert(rtn); assert(rtn);
...@@ -1714,15 +1636,13 @@ private: ...@@ -1714,15 +1636,13 @@ private:
if (vst == ScopeInfo::VarScopeType::GLOBAL) { if (vst == ScopeInfo::VarScopeType::GLOBAL) {
if (irstate->getSourceInfo()->scoping->areGlobalsFromModule()) { if (irstate->getSourceInfo()->scoping->areGlobalsFromModule()) {
auto parent_module = llvm::ConstantExpr::getPointerCast(embedParentModulePtr(), g.llvm_value_type_ptr); auto parent_module = llvm::ConstantExpr::getPointerCast(embedParentModulePtr(), g.llvm_value_type_ptr);
ConcreteCompilerVariable* module = new ConcreteCompilerVariable(MODULE, parent_module, false); ConcreteCompilerVariable* module = new ConcreteCompilerVariable(MODULE, parent_module);
module->setattr(emitter, getEmptyOpInfo(unw_info), name.getBox(), val); module->setattr(emitter, getEmptyOpInfo(unw_info), name.getBox(), val);
module->decvref(emitter);
} else { } else {
auto converted = val->makeConverted(emitter, val->getBoxType()); auto converted = val->makeConverted(emitter, val->getBoxType());
emitter.createCall3(unw_info, g.funcs.setGlobal, irstate->getGlobals(), emitter.createCall3(unw_info, g.funcs.setGlobal, irstate->getGlobals(),
embedRelocatablePtr(name.getBox(), g.llvm_boxedstring_type_ptr), embedRelocatablePtr(name.getBox(), g.llvm_boxedstring_type_ptr),
converted->getValue()); converted->getValue());
converted->decvref(emitter);
} }
} else if (vst == ScopeInfo::VarScopeType::NAME) { } else if (vst == ScopeInfo::VarScopeType::NAME) {
// TODO inefficient // TODO inefficient
...@@ -1734,11 +1654,7 @@ private: ...@@ -1734,11 +1654,7 @@ private:
// FAST or CLOSURE // FAST or CLOSURE
CompilerVariable*& prev = symbol_table[name]; CompilerVariable*& prev = symbol_table[name];
if (prev != NULL) {
prev->decvref(emitter);
}
prev = val; prev = val;
val->incvref();
// Clear out the is_defined name since it is now definitely defined: // Clear out the is_defined name since it is now definitely defined:
assert(!isIsDefinedName(name.s())); assert(!isIsDefinedName(name.s()));
...@@ -1751,7 +1667,6 @@ private: ...@@ -1751,7 +1667,6 @@ private:
// This is basically `closure->elts[offset] = val;` // This is basically `closure->elts[offset] = val;`
CompilerVariable* closure = symbol_table[internString(CREATED_CLOSURE_NAME)]; CompilerVariable* closure = symbol_table[internString(CREATED_CLOSURE_NAME)];
llvm::Value* closureValue = closure->makeConverted(emitter, CLOSURE)->getValue(); llvm::Value* closureValue = closure->makeConverted(emitter, CLOSURE)->getValue();
closure->decvref(emitter);
llvm::Value* gep = getClosureElementGep(emitter, closureValue, offset); llvm::Value* gep = getClosureElementGep(emitter, closureValue, offset);
emitter.getBuilder()->CreateStore(val->makeConverted(emitter, UNKNOWN)->getValue(), gep); emitter.getBuilder()->CreateStore(val->makeConverted(emitter, UNKNOWN)->getValue(), gep);
} }
...@@ -1761,7 +1676,6 @@ private: ...@@ -1761,7 +1676,6 @@ private:
void _doSetattr(AST_Attribute* target, CompilerVariable* val, const UnwindInfo& unw_info) { void _doSetattr(AST_Attribute* target, CompilerVariable* val, const UnwindInfo& unw_info) {
CompilerVariable* t = evalExpr(target->value, unw_info); CompilerVariable* t = evalExpr(target->value, unw_info);
t->setattr(emitter, getEmptyOpInfo(unw_info), target->attr.getBox(), val); t->setattr(emitter, getEmptyOpInfo(unw_info), target->attr.getBox(), val);
t->decvref(emitter);
} }
void _doSetitem(AST_Subscript* target, CompilerVariable* val, const UnwindInfo& unw_info) { void _doSetitem(AST_Subscript* target, CompilerVariable* val, const UnwindInfo& unw_info) {
...@@ -1770,8 +1684,6 @@ private: ...@@ -1770,8 +1684,6 @@ private:
ConcreteCompilerVariable* converted_target = tget->makeConverted(emitter, tget->getBoxType()); ConcreteCompilerVariable* converted_target = tget->makeConverted(emitter, tget->getBoxType());
ConcreteCompilerVariable* converted_slice = slice->makeConverted(emitter, slice->getBoxType()); ConcreteCompilerVariable* converted_slice = slice->makeConverted(emitter, slice->getBoxType());
tget->decvref(emitter);
slice->decvref(emitter);
ConcreteCompilerVariable* converted_val = val->makeConverted(emitter, val->getBoxType()); ConcreteCompilerVariable* converted_val = val->makeConverted(emitter, val->getBoxType());
...@@ -1792,10 +1704,6 @@ private: ...@@ -1792,10 +1704,6 @@ private:
emitter.createCall3(unw_info, g.funcs.setitem, converted_target->getValue(), converted_slice->getValue(), emitter.createCall3(unw_info, g.funcs.setitem, converted_target->getValue(), converted_slice->getValue(),
converted_val->getValue()); converted_val->getValue());
} }
converted_target->decvref(emitter);
converted_slice->decvref(emitter);
converted_val->decvref(emitter);
} }
void _doUnpackTuple(AST_Tuple* target, CompilerVariable* val, const UnwindInfo& unw_info) { void _doUnpackTuple(AST_Tuple* target, CompilerVariable* val, const UnwindInfo& unw_info) {
...@@ -1813,7 +1721,6 @@ private: ...@@ -1813,7 +1721,6 @@ private:
for (int i = 0; i < ntargets; i++) { for (int i = 0; i < ntargets; i++) {
CompilerVariable* thisval = unpacked[i]; CompilerVariable* thisval = unpacked[i];
_doSet(target->elts[i], thisval, unw_info); _doSet(target->elts[i], thisval, unw_info);
thisval->decvref(emitter);
} }
} }
...@@ -1857,7 +1764,6 @@ private: ...@@ -1857,7 +1764,6 @@ private:
if (node->msg) { if (node->msg) {
CompilerVariable* msg = evalExpr(node->msg, unw_info); CompilerVariable* msg = evalExpr(node->msg, unw_info);
converted_msg = msg->makeConverted(emitter, msg->getBoxType()); converted_msg = msg->makeConverted(emitter, msg->getBoxType());
msg->decvref(emitter);
llvm_args.push_back(converted_msg->getValue()); llvm_args.push_back(converted_msg->getValue());
} else { } else {
llvm_args.push_back(getNullPtr(g.llvm_value_type_ptr)); llvm_args.push_back(getNullPtr(g.llvm_value_type_ptr));
...@@ -1872,7 +1778,6 @@ private: ...@@ -1872,7 +1778,6 @@ private:
for (int i = 0; i < node->targets.size(); i++) { for (int i = 0; i < node->targets.size(); i++) {
_doSet(node->targets[i], val, unw_info); _doSet(node->targets[i], val, unw_info);
} }
val->decvref(emitter);
} }
void doDelete(AST_Delete* node, const UnwindInfo& unw_info) { void doDelete(AST_Delete* node, const UnwindInfo& unw_info) {
...@@ -1901,8 +1806,6 @@ private: ...@@ -1901,8 +1806,6 @@ private:
ConcreteCompilerVariable* converted_target = tget->makeConverted(emitter, tget->getBoxType()); ConcreteCompilerVariable* converted_target = tget->makeConverted(emitter, tget->getBoxType());
ConcreteCompilerVariable* converted_slice = slice->makeConverted(emitter, slice->getBoxType()); ConcreteCompilerVariable* converted_slice = slice->makeConverted(emitter, slice->getBoxType());
tget->decvref(emitter);
slice->decvref(emitter);
bool do_patchpoint = ENABLE_ICDELITEMS; bool do_patchpoint = ENABLE_ICDELITEMS;
if (do_patchpoint) { if (do_patchpoint) {
...@@ -1916,9 +1819,6 @@ private: ...@@ -1916,9 +1819,6 @@ private:
} else { } else {
emitter.createCall2(unw_info, g.funcs.delitem, converted_target->getValue(), converted_slice->getValue()); emitter.createCall2(unw_info, g.funcs.delitem, converted_target->getValue(), converted_slice->getValue());
} }
converted_target->decvref(emitter);
converted_slice->decvref(emitter);
} }
void _doDelAttr(AST_Attribute* node, const UnwindInfo& unw_info) { void _doDelAttr(AST_Attribute* node, const UnwindInfo& unw_info) {
...@@ -1974,13 +1874,11 @@ private: ...@@ -1974,13 +1874,11 @@ private:
void doExec(AST_Exec* node, const UnwindInfo& unw_info) { void doExec(AST_Exec* node, const UnwindInfo& unw_info) {
CompilerVariable* body = evalExpr(node->body, unw_info); CompilerVariable* body = evalExpr(node->body, unw_info);
llvm::Value* vbody = body->makeConverted(emitter, body->getBoxType())->getValue(); llvm::Value* vbody = body->makeConverted(emitter, body->getBoxType())->getValue();
body->decvref(emitter);
llvm::Value* vglobals; llvm::Value* vglobals;
if (node->globals) { if (node->globals) {
CompilerVariable* globals = evalExpr(node->globals, unw_info); CompilerVariable* globals = evalExpr(node->globals, unw_info);
vglobals = globals->makeConverted(emitter, globals->getBoxType())->getValue(); vglobals = globals->makeConverted(emitter, globals->getBoxType())->getValue();
globals->decvref(emitter);
} else { } else {
vglobals = getNullPtr(g.llvm_value_type_ptr); vglobals = getNullPtr(g.llvm_value_type_ptr);
} }
...@@ -1989,7 +1887,6 @@ private: ...@@ -1989,7 +1887,6 @@ private:
if (node->locals) { if (node->locals) {
CompilerVariable* locals = evalExpr(node->locals, unw_info); CompilerVariable* locals = evalExpr(node->locals, unw_info);
vlocals = locals->makeConverted(emitter, locals->getBoxType())->getValue(); vlocals = locals->makeConverted(emitter, locals->getBoxType())->getValue();
locals->decvref(emitter);
} else { } else {
vlocals = getNullPtr(g.llvm_value_type_ptr); vlocals = getNullPtr(g.llvm_value_type_ptr);
} }
...@@ -2004,10 +1901,9 @@ private: ...@@ -2004,10 +1901,9 @@ private:
if (node->dest) { if (node->dest) {
auto d = evalExpr(node->dest, unw_info); auto d = evalExpr(node->dest, unw_info);
dest = d->makeConverted(emitter, d->getBoxType()); dest = d->makeConverted(emitter, d->getBoxType());
d->decvref(emitter);
} else { } else {
llvm::Value* sys_stdout_val = emitter.createCall(unw_info, g.funcs.getSysStdout); llvm::Value* sys_stdout_val = emitter.createCall(unw_info, g.funcs.getSysStdout);
dest = new ConcreteCompilerVariable(UNKNOWN, sys_stdout_val, true); dest = new ConcreteCompilerVariable(UNKNOWN, sys_stdout_val);
// TODO: speculate that sys.stdout is a file? // TODO: speculate that sys.stdout is a file?
} }
assert(dest); assert(dest);
...@@ -2018,16 +1914,12 @@ private: ...@@ -2018,16 +1914,12 @@ private:
if (node->values.size() == 1) { if (node->values.size() == 1) {
CompilerVariable* var = evalExpr(node->values[0], unw_info); CompilerVariable* var = evalExpr(node->values[0], unw_info);
converted = var->makeConverted(emitter, var->getBoxType()); converted = var->makeConverted(emitter, var->getBoxType());
var->decvref(emitter);
} else { } else {
converted = new ConcreteCompilerVariable(UNKNOWN, getNullPtr(g.llvm_value_type_ptr), true); converted = new ConcreteCompilerVariable(UNKNOWN, getNullPtr(g.llvm_value_type_ptr));
} }
emitter.createCall3(unw_info, g.funcs.printHelper, dest->getValue(), converted->getValue(), emitter.createCall3(unw_info, g.funcs.printHelper, dest->getValue(), converted->getValue(),
getConstantInt(node->nl, g.i1)); getConstantInt(node->nl, g.i1));
dest->decvref(emitter);
converted->decvref(emitter);
} }
void doReturn(AST_Return* node, const UnwindInfo& unw_info) { void doReturn(AST_Return* node, const UnwindInfo& unw_info) {
...@@ -2041,30 +1933,16 @@ private: ...@@ -2041,30 +1933,16 @@ private:
} }
assert(val); assert(val);
// If we ask the return variable to become UNKNOWN (the typical return type),
// it will be forced to split a copy of itself and incref.
// But often the return variable will already be in the right shape, so in
// that case asking it to convert to itself ends up just being an incvref
// and doesn't end up emitting an incref+decref pair.
// This could also be handled by casting from the CompilerVariable to
// ConcreteCompilerVariable, but this way feels a little more robust to me.
ConcreteCompilerType* opt_rtn_type = irstate->getReturnType(); ConcreteCompilerType* opt_rtn_type = irstate->getReturnType();
if (irstate->getReturnType()->llvmType() == val->getConcreteType()->llvmType()) if (irstate->getReturnType()->llvmType() == val->getConcreteType()->llvmType())
opt_rtn_type = val->getConcreteType(); opt_rtn_type = val->getConcreteType();
ConcreteCompilerVariable* rtn = val->makeConverted(emitter, opt_rtn_type); ConcreteCompilerVariable* rtn = val->makeConverted(emitter, opt_rtn_type);
rtn->ensureGrabbed(emitter);
val->decvref(emitter);
for (auto& p : symbol_table) {
p.second->decvref(emitter);
}
symbol_table.clear(); symbol_table.clear();
endBlock(DEAD); endBlock(DEAD);
// This is tripping in test/tests/return_selfreferential.py. kmod says it should be removed.
// ASSERT(rtn->getVrefs() == 1, "%d", rtn->getVrefs());
assert(rtn->getValue()); assert(rtn->getValue());
emitter.getBuilder()->CreateRet(rtn->getValue()); emitter.getBuilder()->CreateRet(rtn->getValue());
} }
...@@ -2094,8 +1972,6 @@ private: ...@@ -2094,8 +1972,6 @@ private:
void doExpr(AST_Expr* node, const UnwindInfo& unw_info) { void doExpr(AST_Expr* node, const UnwindInfo& unw_info) {
CompilerVariable* var = evalExpr(node->value, unw_info); CompilerVariable* var = evalExpr(node->value, unw_info);
var->decvref(emitter);
} }
void doOSRExit(llvm::BasicBlock* normal_target, AST_Jump* osr_key) { void doOSRExit(llvm::BasicBlock* normal_target, AST_Jump* osr_key) {
...@@ -2137,11 +2013,11 @@ private: ...@@ -2137,11 +2013,11 @@ private:
SortedSymbolTable sorted_symbol_table(symbol_table.begin(), symbol_table.end()); SortedSymbolTable sorted_symbol_table(symbol_table.begin(), symbol_table.end());
sorted_symbol_table[internString(FRAME_INFO_PTR_NAME)] sorted_symbol_table[internString(FRAME_INFO_PTR_NAME)]
= new ConcreteCompilerVariable(FRAME_INFO, irstate->getFrameInfoVar(), true); = new ConcreteCompilerVariable(FRAME_INFO, irstate->getFrameInfoVar());
if (!irstate->getSourceInfo()->scoping->areGlobalsFromModule()) { if (!irstate->getSourceInfo()->scoping->areGlobalsFromModule()) {
sorted_symbol_table[internString(PASSED_GLOBALS_NAME)] sorted_symbol_table[internString(PASSED_GLOBALS_NAME)]
= new ConcreteCompilerVariable(UNKNOWN, irstate->getGlobals(), true); = new ConcreteCompilerVariable(UNKNOWN, irstate->getGlobals());
} }
// For OSR calls, we use the same calling convention as in some other places; namely, // For OSR calls, we use the same calling convention as in some other places; namely,
...@@ -2192,12 +2068,6 @@ private: ...@@ -2192,12 +2068,6 @@ private:
assert(var->getType() != BOXED_FLOAT assert(var->getType() != BOXED_FLOAT
&& "should probably unbox it, but why is it boxed in the first place?"); && "should probably unbox it, but why is it boxed in the first place?");
// This line can never get hit right now for the same reason that the variables must already be
// concrete,
// because we're over-generating phis.
ASSERT(var->isGrabbed(), "%s", p.first.c_str());
// var->ensureGrabbed(emitter);
llvm::Value* val = var->getValue(); llvm::Value* val = var->getValue();
if (arg_num < 3) { if (arg_num < 3) {
...@@ -2260,10 +2130,6 @@ private: ...@@ -2260,10 +2130,6 @@ private:
emitter.getBuilder()->CreateCall(l_free, malloc_save); emitter.getBuilder()->CreateCall(l_free, malloc_save);
} }
for (int i = 0; i < converted_args.size(); i++) {
converted_args[i]->decvref(emitter);
}
emitter.getBuilder()->CreateRet(rtn); emitter.getBuilder()->CreateRet(rtn);
emitter.getBuilder()->SetInsertPoint(starting_block); emitter.getBuilder()->SetInsertPoint(starting_block);
...@@ -2317,7 +2183,6 @@ private: ...@@ -2317,7 +2183,6 @@ private:
if (a) { if (a) {
CompilerVariable* v = evalExpr(a, unw_info); CompilerVariable* v = evalExpr(a, unw_info);
ConcreteCompilerVariable* converted = v->makeConverted(emitter, v->getBoxType()); ConcreteCompilerVariable* converted = v->makeConverted(emitter, v->getBoxType());
v->decvref(emitter);
args.push_back(converted->getValue()); args.push_back(converted->getValue());
} else { } else {
args.push_back(embedRelocatablePtr(None, g.llvm_value_type_ptr, "cNone")); args.push_back(embedRelocatablePtr(None, g.llvm_value_type_ptr, "cNone"));
...@@ -2414,15 +2279,13 @@ private: ...@@ -2414,15 +2279,13 @@ private:
void loadArgument(InternedString name, ConcreteCompilerType* t, llvm::Value* v, const UnwindInfo& unw_info) { void loadArgument(InternedString name, ConcreteCompilerType* t, llvm::Value* v, const UnwindInfo& unw_info) {
assert(name.s() != FRAME_INFO_PTR_NAME); assert(name.s() != FRAME_INFO_PTR_NAME);
CompilerVariable* var = unboxVar(t, v, false); CompilerVariable* var = unboxVar(t, v);
_doSet(name, var, unw_info); _doSet(name, var, unw_info);
var->decvref(emitter);
} }
void loadArgument(AST_expr* name, ConcreteCompilerType* t, llvm::Value* v, const UnwindInfo& unw_info) { void loadArgument(AST_expr* name, ConcreteCompilerType* t, llvm::Value* v, const UnwindInfo& unw_info) {
CompilerVariable* var = unboxVar(t, v, false); CompilerVariable* var = unboxVar(t, v);
_doSet(name, var, unw_info); _doSet(name, var, unw_info);
var->decvref(emitter);
} }
bool allowableFakeEndingSymbol(InternedString name) { bool allowableFakeEndingSymbol(InternedString name) {
...@@ -2451,10 +2314,6 @@ private: ...@@ -2451,10 +2314,6 @@ private:
// symbol table? '%s'", p.first.c_str()); // symbol table? '%s'", p.first.c_str());
if (!irstate->getLiveness()->isLiveAtEnd(p.first, myblock)) { if (!irstate->getLiveness()->isLiveAtEnd(p.first, myblock)) {
// printf("%s dead at end of %d; grabbed = %d, %d vrefs\n", p.first.c_str(), myblock->idx,
// p.second->isGrabbed(), p.second->getVrefs());
p.second->decvref(emitter);
symbol_table.erase(getIsDefinedName(p.first)); symbol_table.erase(getIsDefinedName(p.first));
symbol_table.erase(p.first); symbol_table.erase(p.first);
} else if (irstate->getPhis()->isRequiredAfter(p.first, myblock)) { } else if (irstate->getPhis()->isRequiredAfter(p.first, myblock)) {
...@@ -2466,8 +2325,7 @@ private: ...@@ -2466,8 +2325,7 @@ private:
// printf("have to convert %s from %s to %s\n", p.first.c_str(), // printf("have to convert %s from %s to %s\n", p.first.c_str(),
// p.second->getType()->debugName().c_str(), phi_type->debugName().c_str()); // p.second->getType()->debugName().c_str(), phi_type->debugName().c_str());
ConcreteCompilerVariable* v = p.second->makeConverted(emitter, phi_type); ConcreteCompilerVariable* v = p.second->makeConverted(emitter, phi_type);
p.second->decvref(emitter); symbol_table[p.first] = v;
symbol_table[p.first] = v->split(emitter);
} else { } else {
#ifndef NDEBUG #ifndef NDEBUG
if (myblock->successors.size()) { if (myblock->successors.size()) {
...@@ -2512,7 +2370,7 @@ private: ...@@ -2512,7 +2370,7 @@ private:
// printf("no st entry, setting undefined\n"); // printf("no st entry, setting undefined\n");
ConcreteCompilerType* phi_type = types->getTypeAtBlockEnd(*it, myblock); ConcreteCompilerType* phi_type = types->getTypeAtBlockEnd(*it, myblock);
assert(phi_type->isUsable()); assert(phi_type->isUsable());
cur = new ConcreteCompilerVariable(phi_type, llvm::UndefValue::get(phi_type->llvmType()), true); cur = new ConcreteCompilerVariable(phi_type, llvm::UndefValue::get(phi_type->llvmType()));
_setFake(defined_name, makeBool(0)); _setFake(defined_name, makeBool(0));
} }
} }
...@@ -2567,10 +2425,6 @@ public: ...@@ -2567,10 +2425,6 @@ public:
EndingState getEndingSymbolTable() override { EndingState getEndingSymbolTable() override {
assert(state == FINISHED || state == DEAD); assert(state == FINISHED || state == DEAD);
// for (SymbolTable::iterator it = symbol_table.begin(); it != symbol_table.end(); ++it) {
// printf("%s %p %d\n", it->first.c_str(), it->second, it->second->getVrefs());
//}
SourceInfo* source = irstate->getSourceInfo(); SourceInfo* source = irstate->getSourceInfo();
SymbolTable* st = new SymbolTable(symbol_table); SymbolTable* st = new SymbolTable(symbol_table);
...@@ -2584,9 +2438,6 @@ public: ...@@ -2584,9 +2438,6 @@ public:
} }
if (myblock->successors.size() == 0) { if (myblock->successors.size() == 0) {
for (auto& p : *st) {
p.second->decvref(emitter);
}
st->clear(); st->clear();
symbol_table.clear(); symbol_table.clear();
return EndingState(st, phi_st, curblock, outgoing_exc_state); return EndingState(st, phi_st, curblock, outgoing_exc_state);
...@@ -2610,8 +2461,6 @@ public: ...@@ -2610,8 +2461,6 @@ public:
// We're going to sort out which symbols need to go in phi_st and which belong inst. // We're going to sort out which symbols need to go in phi_st and which belong inst.
for (SymbolTable::iterator it = st->begin(); it != st->end();) { for (SymbolTable::iterator it = st->begin(); it != st->end();) {
if (allowableFakeEndingSymbol(it->first) || irstate->getPhis()->isRequiredAfter(it->first, myblock)) { if (allowableFakeEndingSymbol(it->first) || irstate->getPhis()->isRequiredAfter(it->first, myblock)) {
ASSERT(it->second->isGrabbed(), "%s", it->first.c_str());
assert(it->second->getVrefs() == 1);
// this conversion should have already happened... should refactor this. // this conversion should have already happened... should refactor this.
ConcreteCompilerType* ending_type; ConcreteCompilerType* ending_type;
if (isIsDefinedName(it->first.s())) { if (isIsDefinedName(it->first.s())) {
...@@ -2630,8 +2479,7 @@ public: ...@@ -2630,8 +2479,7 @@ public:
} }
assert(ending_type->isUsable()); assert(ending_type->isUsable());
//(*phi_st)[it->first] = it->second->makeConverted(emitter, it->second->getConcreteType()); //(*phi_st)[it->first] = it->second->makeConverted(emitter, it->second->getConcreteType());
// printf("%s %p %d\n", it->first.c_str(), it->second, it->second->getVrefs()); (*phi_st)[it->first] = it->second->makeConverted(emitter, ending_type);
(*phi_st)[it->first] = it->second->split(emitter)->makeConverted(emitter, ending_type);
it = st->erase(it); it = st->erase(it);
} else { } else {
++it; ++it;
...@@ -2657,11 +2505,9 @@ public: ...@@ -2657,11 +2505,9 @@ public:
assert(st); assert(st);
DupCache cache; DupCache cache;
for (SymbolTable::iterator it = st->begin(); it != st->end(); ++it) { for (SymbolTable::iterator it = st->begin(); it != st->end(); ++it) {
// printf("Copying in %s: %p, %d\n", it->first.c_str(), it->second, it->second->getVrefs());
// printf("Copying in %s, a %s\n", it->first.c_str(), it->second->getType()->debugName().c_str()); // printf("Copying in %s, a %s\n", it->first.c_str(), it->second->getType()->debugName().c_str());
symbol_table[it->first] = it->second->dup(cache); symbol_table[it->first] = it->second->dup(cache);
assert(symbol_table[it->first]->getType()->isUsable()); assert(symbol_table[it->first]->getType()->isUsable());
// printf("got: %p, %d\n", symbol_table[it->first], symbol_table[it->first]->getVrefs());
} }
} }
...@@ -2686,7 +2532,7 @@ public: ...@@ -2686,7 +2532,7 @@ public:
if (scope_info->takesClosure()) { if (scope_info->takesClosure()) {
passed_closure = AI; passed_closure = AI;
symbol_table[internString(PASSED_CLOSURE_NAME)] symbol_table[internString(PASSED_CLOSURE_NAME)]
= new ConcreteCompilerVariable(getPassedClosureType(), AI, true); = new ConcreteCompilerVariable(getPassedClosureType(), AI);
++AI; ++AI;
} }
...@@ -2697,11 +2543,11 @@ public: ...@@ -2697,11 +2543,11 @@ public:
llvm::Value* new_closure = emitter.getBuilder()->CreateCall2( llvm::Value* new_closure = emitter.getBuilder()->CreateCall2(
g.funcs.createClosure, passed_closure, getConstantInt(scope_info->getClosureSize(), g.i64)); g.funcs.createClosure, passed_closure, getConstantInt(scope_info->getClosureSize(), g.i64));
symbol_table[internString(CREATED_CLOSURE_NAME)] symbol_table[internString(CREATED_CLOSURE_NAME)]
= new ConcreteCompilerVariable(getCreatedClosureType(), new_closure, true); = new ConcreteCompilerVariable(getCreatedClosureType(), new_closure);
} }
if (irstate->getSourceInfo()->is_generator) { if (irstate->getSourceInfo()->is_generator) {
symbol_table[internString(PASSED_GENERATOR_NAME)] = new ConcreteCompilerVariable(GENERATOR, AI, true); symbol_table[internString(PASSED_GENERATOR_NAME)] = new ConcreteCompilerVariable(GENERATOR, AI);
++AI; ++AI;
} }
...@@ -2857,9 +2703,9 @@ public: ...@@ -2857,9 +2703,9 @@ public:
llvm::Value* exc_traceback = emitter.getBuilder()->CreateLoad(exc_traceback_ptr); llvm::Value* exc_traceback = emitter.getBuilder()->CreateLoad(exc_traceback_ptr);
addOutgoingExceptionState( addOutgoingExceptionState(
IRGenerator::ExceptionState(capi_exc_dest, new ConcreteCompilerVariable(UNKNOWN, exc_type, true), IRGenerator::ExceptionState(capi_exc_dest, new ConcreteCompilerVariable(UNKNOWN, exc_type),
new ConcreteCompilerVariable(UNKNOWN, exc_value, true), new ConcreteCompilerVariable(UNKNOWN, exc_value),
new ConcreteCompilerVariable(UNKNOWN, exc_traceback, true))); new ConcreteCompilerVariable(UNKNOWN, exc_traceback)));
emitter.getBuilder()->CreateBr(final_dest); emitter.getBuilder()->CreateBr(final_dest);
} }
...@@ -2916,9 +2762,9 @@ public: ...@@ -2916,9 +2762,9 @@ public:
if (final_dest) { if (final_dest) {
// Catch the exception and forward to final_dest: // Catch the exception and forward to final_dest:
addOutgoingExceptionState(ExceptionState(cxx_exc_dest, addOutgoingExceptionState(ExceptionState(cxx_exc_dest,
new ConcreteCompilerVariable(UNKNOWN, exc_type, true), new ConcreteCompilerVariable(UNKNOWN, exc_type),
new ConcreteCompilerVariable(UNKNOWN, exc_value, true), new ConcreteCompilerVariable(UNKNOWN, exc_value),
new ConcreteCompilerVariable(UNKNOWN, exc_traceback, true))); new ConcreteCompilerVariable(UNKNOWN, exc_traceback)));
builder->CreateBr(final_dest); builder->CreateBr(final_dest);
} else { } else {
......
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