shader: Fix dependency on identity removal pass

This commit is contained in:
ReinUsesLisp 2021-04-01 01:07:51 -03:00 committed by ameerj
parent 5f22cd89e2
commit f1dd743731
2 changed files with 8 additions and 3 deletions

View file

@ -114,7 +114,7 @@ EmitContext::~EmitContext() = default;
Id EmitContext::Def(const IR::Value& value) {
if (!value.IsImmediate()) {
return value.Inst()->Definition<Id>();
return value.InstRecursive()->Definition<Id>();
}
switch (value.Type()) {
case IR::Type::Void:

View file

@ -250,7 +250,7 @@ Id PhiArgDef(EmitContext& ctx, IR::Inst* inst, size_t index) {
// Let the context handle immediate definitions, as it already knows how
return ctx.Def(arg);
}
IR::Inst* const arg_inst{arg.Inst()};
IR::Inst* const arg_inst{arg.InstRecursive()};
if (const Id def{arg_inst->Definition<Id>()}; Sirit::ValidId(def)) {
// Return the current definition if it exists
return def;
@ -296,7 +296,12 @@ Id EmitPhi(EmitContext& ctx, IR::Inst* inst) {
void EmitVoid(EmitContext&) {}
Id EmitIdentity(EmitContext& ctx, const IR::Value& value) {
return ctx.Def(value);
if (const Id id = ctx.Def(value); Sirit::ValidId(id)) {
return id;
}
const Id def{ctx.ForwardDeclarationId()};
value.InstRecursive()->SetDefinition<Id>(def);
return def;
}
void EmitGetZeroFromOp(EmitContext&) {