forked from M-Labs/artiq
parent
c9287cfc69
commit
12d1b9819c
@ -6,6 +6,6 @@ from .iodelay_estimator import IODelayEstimator
|
|||||||
from .artiq_ir_generator import ARTIQIRGenerator
|
from .artiq_ir_generator import ARTIQIRGenerator
|
||||||
from .dead_code_eliminator import DeadCodeEliminator
|
from .dead_code_eliminator import DeadCodeEliminator
|
||||||
from .local_demoter import LocalDemoter
|
from .local_demoter import LocalDemoter
|
||||||
from .llvm_ir_generator import LLVMIRGenerator
|
|
||||||
from .interleaver import Interleaver
|
from .interleaver import Interleaver
|
||||||
from .typedtree_printer import TypedtreePrinter
|
from .typedtree_printer import TypedtreePrinter
|
||||||
|
from .llvm_ir_generator import LLVMIRGenerator
|
||||||
|
@ -9,6 +9,7 @@ from pythonparser import ast, diagnostic
|
|||||||
from llvmlite_artiq import ir as ll, binding as llvm
|
from llvmlite_artiq import ir as ll, binding as llvm
|
||||||
from ...language import core as language_core
|
from ...language import core as language_core
|
||||||
from .. import types, builtins, ir
|
from .. import types, builtins, ir
|
||||||
|
from ..embedding import SpecializedFunction
|
||||||
|
|
||||||
|
|
||||||
llvoid = ll.VoidType()
|
llvoid = ll.VoidType()
|
||||||
@ -1549,8 +1550,16 @@ class LLVMIRGenerator:
|
|||||||
# RPC and C functions have no runtime representation.
|
# RPC and C functions have no runtime representation.
|
||||||
return ll.Constant(llty, ll.Undefined)
|
return ll.Constant(llty, ll.Undefined)
|
||||||
elif types.is_function(typ):
|
elif types.is_function(typ):
|
||||||
return self.get_function_with_undef_env(typ.find(),
|
try:
|
||||||
self.embedding_map.retrieve_function(value))
|
func = self.embedding_map.retrieve_function(value)
|
||||||
|
except KeyError:
|
||||||
|
# If a class function was embedded directly (e.g. by a `C.f(...)` call),
|
||||||
|
# but it also appears in a class hierarchy, we might need to fall back
|
||||||
|
# to the non-specialized one, since direct invocations do not cause
|
||||||
|
# monomorphization.
|
||||||
|
assert isinstance(value, SpecializedFunction)
|
||||||
|
func = self.embedding_map.retrieve_function(value.host_function)
|
||||||
|
return self.get_function_with_undef_env(typ.find(), func)
|
||||||
elif types.is_method(typ):
|
elif types.is_method(typ):
|
||||||
llclosure = self._quote(value.__func__, types.get_method_function(typ),
|
llclosure = self._quote(value.__func__, types.get_method_function(typ),
|
||||||
lambda: path() + ['__func__'])
|
lambda: path() + ['__func__'])
|
||||||
|
20
artiq/test/lit/embedding/class_fn_direct_call.py
Normal file
20
artiq/test/lit/embedding/class_fn_direct_call.py
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
# RUN: %python -m artiq.compiler.testbench.embedding %s
|
||||||
|
|
||||||
|
from artiq.language.core import *
|
||||||
|
from artiq.language.types import *
|
||||||
|
|
||||||
|
class C:
|
||||||
|
@kernel
|
||||||
|
def f(self):
|
||||||
|
pass
|
||||||
|
|
||||||
|
class D(C):
|
||||||
|
@kernel
|
||||||
|
def f(self):
|
||||||
|
# super().f() # super() not bound
|
||||||
|
C.f(self) # KeyError in compile
|
||||||
|
|
||||||
|
di = D()
|
||||||
|
@kernel
|
||||||
|
def entrypoint():
|
||||||
|
di.f()
|
Loading…
Reference in New Issue
Block a user