forked from M-Labs/artiq
transforms.artiq_ir_generator: fix devirtualized call annotation.
This commit is contained in:
parent
e9adfd639e
commit
5d64df829e
|
@ -105,7 +105,9 @@ class ARTIQIRGenerator(algorithm.Visitor):
|
||||||
def annotate_calls(self, devirtualization):
|
def annotate_calls(self, devirtualization):
|
||||||
for var_node in devirtualization.variable_map:
|
for var_node in devirtualization.variable_map:
|
||||||
callee_node = devirtualization.variable_map[var_node]
|
callee_node = devirtualization.variable_map[var_node]
|
||||||
callee = self.function_map[callee_node]
|
if callee_node is None:
|
||||||
|
continue
|
||||||
|
callee = self.function_map[callee_node]
|
||||||
|
|
||||||
call_target = self.variable_map[var_node]
|
call_target = self.variable_map[var_node]
|
||||||
for use in call_target.uses:
|
for use in call_target.uses:
|
||||||
|
@ -115,7 +117,9 @@ class ARTIQIRGenerator(algorithm.Visitor):
|
||||||
|
|
||||||
for type_and_method in devirtualization.method_map:
|
for type_and_method in devirtualization.method_map:
|
||||||
callee_node = devirtualization.method_map[type_and_method]
|
callee_node = devirtualization.method_map[type_and_method]
|
||||||
callee = self.function_map[callee_node]
|
if callee_node is None:
|
||||||
|
continue
|
||||||
|
callee = self.function_map[callee_node]
|
||||||
|
|
||||||
for call in self.method_map[type_and_method]:
|
for call in self.method_map[type_and_method]:
|
||||||
assert isinstance(call, (ir.Call, ir.Invoke))
|
assert isinstance(call, (ir.Call, ir.Invoke))
|
||||||
|
|
Loading…
Reference in New Issue