forked from M-Labs/artiq
transforms.interleaver: add boilerplate.
This commit is contained in:
parent
de9d7eb2e4
commit
48a2bb10d5
@ -58,6 +58,7 @@ class Module:
|
|||||||
dead_code_eliminator = transforms.DeadCodeEliminator(engine=self.engine)
|
dead_code_eliminator = transforms.DeadCodeEliminator(engine=self.engine)
|
||||||
local_access_validator = validators.LocalAccessValidator(engine=self.engine)
|
local_access_validator = validators.LocalAccessValidator(engine=self.engine)
|
||||||
devirtualization = analyses.Devirtualization()
|
devirtualization = analyses.Devirtualization()
|
||||||
|
interleaver = transforms.Interleaver(engine=self.engine)
|
||||||
|
|
||||||
self.name = src.name
|
self.name = src.name
|
||||||
self.globals = src.globals
|
self.globals = src.globals
|
||||||
@ -71,6 +72,7 @@ class Module:
|
|||||||
artiq_ir_generator.annotate_calls(devirtualization)
|
artiq_ir_generator.annotate_calls(devirtualization)
|
||||||
dead_code_eliminator.process(self.artiq_ir)
|
dead_code_eliminator.process(self.artiq_ir)
|
||||||
local_access_validator.process(self.artiq_ir)
|
local_access_validator.process(self.artiq_ir)
|
||||||
|
interleaver.process(self.artiq_ir)
|
||||||
|
|
||||||
def build_llvm_ir(self, target):
|
def build_llvm_ir(self, target):
|
||||||
"""Compile the module to LLVM IR for the specified target."""
|
"""Compile the module to LLVM IR for the specified target."""
|
||||||
|
@ -5,3 +5,4 @@ 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 .llvm_ir_generator import LLVMIRGenerator
|
from .llvm_ir_generator import LLVMIRGenerator
|
||||||
|
from .interleaver import Interleaver
|
||||||
|
22
artiq/compiler/transforms/interleaver.py
Normal file
22
artiq/compiler/transforms/interleaver.py
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
"""
|
||||||
|
:class:`Interleaver` reorders requests to the RTIO core so that
|
||||||
|
the timestamp would always monotonically nondecrease.
|
||||||
|
"""
|
||||||
|
|
||||||
|
from .. import ir
|
||||||
|
from ..analyses import domination
|
||||||
|
|
||||||
|
class Interleaver:
|
||||||
|
def __init__(self, engine):
|
||||||
|
self.engine = engine
|
||||||
|
|
||||||
|
def process(self, functions):
|
||||||
|
for func in functions:
|
||||||
|
self.process_function(func)
|
||||||
|
|
||||||
|
def process_function(self, func):
|
||||||
|
domtree = domination.PostDominatorTree(func)
|
||||||
|
print(func)
|
||||||
|
for block in func.basic_blocks:
|
||||||
|
idom = domtree.immediate_dominator(block)
|
||||||
|
print(block.name, "->", idom.name if idom else "<exit>")
|
Loading…
Reference in New Issue
Block a user