mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
pytholite/io: support token push
This commit is contained in:
parent
bf5ce8dc20
commit
dd9a102a78
1 changed files with 34 additions and 9 deletions
|
@ -1,7 +1,9 @@
|
||||||
import ast
|
import ast
|
||||||
|
|
||||||
|
from migen.fhdl.structure import *
|
||||||
from migen.flow.actor import *
|
from migen.flow.actor import *
|
||||||
from migen.actorlib.sim import *
|
from migen.actorlib.sim import *
|
||||||
|
from migen.pytholite.fsm import *
|
||||||
|
|
||||||
class Pytholite:
|
class Pytholite:
|
||||||
def get_fragment(self):
|
def get_fragment(self):
|
||||||
|
@ -14,15 +16,38 @@ def make_io_object(dataflow=None):
|
||||||
if dataflow is None:
|
if dataflow is None:
|
||||||
return Pytholite()
|
return Pytholite()
|
||||||
else:
|
else:
|
||||||
return DFPytholite(dataflow)
|
return DFPytholite(*dataflow)
|
||||||
|
|
||||||
|
def gen_df_io(compiler, to_model, from_model):
|
||||||
|
if len(to_model) == 1 or len(to_model) == 2:
|
||||||
|
epname = ast.literal_eval(to_model[0])
|
||||||
|
ep = compiler.ioo.endpoints[epname]
|
||||||
|
else:
|
||||||
|
raise TypeError("Token() takes 1 or 2 arguments")
|
||||||
|
|
||||||
|
if len(to_model) == 1:
|
||||||
|
# token pull from sink
|
||||||
|
raise NotImplementedError # TODO
|
||||||
|
else:
|
||||||
|
# token push to source
|
||||||
|
if from_model:
|
||||||
|
raise TypeError("Attempted to read from pushed token")
|
||||||
|
d = to_model[1]
|
||||||
|
if not isinstance(d, ast.Dict):
|
||||||
|
raise NotImplementedError
|
||||||
|
state = []
|
||||||
|
for akey, value in zip(d.keys, d.values):
|
||||||
|
key = ast.literal_eval(akey)
|
||||||
|
signal = getattr(ep.token, key)
|
||||||
|
state.append(signal.eq(compiler.ec.visit_expr(value)))
|
||||||
|
state += [
|
||||||
|
ep.stb.eq(1),
|
||||||
|
If(~ep.ack, AbstractNextState(state))
|
||||||
|
]
|
||||||
|
return [state], [state]
|
||||||
|
|
||||||
def gen_io(compiler, model, to_model, from_model):
|
def gen_io(compiler, model, to_model, from_model):
|
||||||
print("model: " + str(model))
|
if model == Token:
|
||||||
print("to_model:")
|
return gen_df_io(compiler, to_model, from_model)
|
||||||
for arg in to_model:
|
else:
|
||||||
print(ast.dump(arg))
|
raise NotImplementedError
|
||||||
print("from_model:")
|
|
||||||
for target, expr in from_model:
|
|
||||||
print(str(target) + " <= " + ast.dump(expr))
|
|
||||||
return [], []
|
|
||||||
|
|
Loading…
Reference in a new issue