mirror of
https://github.com/m-labs/artiq.git
synced 2025-01-29 03:40:20 +08:00
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)
|
||||
local_access_validator = validators.LocalAccessValidator(engine=self.engine)
|
||||
devirtualization = analyses.Devirtualization()
|
||||
interleaver = transforms.Interleaver(engine=self.engine)
|
||||
|
||||
self.name = src.name
|
||||
self.globals = src.globals
|
||||
@ -71,6 +72,7 @@ class Module:
|
||||
artiq_ir_generator.annotate_calls(devirtualization)
|
||||
dead_code_eliminator.process(self.artiq_ir)
|
||||
local_access_validator.process(self.artiq_ir)
|
||||
interleaver.process(self.artiq_ir)
|
||||
|
||||
def build_llvm_ir(self, 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 .dead_code_eliminator import DeadCodeEliminator
|
||||
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