mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
Add simulation skeleton
Remove SRLC16E, will be replaced by distributed ram
This commit is contained in:
parent
7dd51b3d92
commit
f4cac2c102
3 changed files with 79 additions and 68 deletions
|
@ -2,6 +2,7 @@ from migen.fhdl.structure import *
|
|||
from migen.bus import csr
|
||||
from migen.bank import description, csrgen
|
||||
from migen.bank.description import *
|
||||
from migen.corelogic.misc import optree
|
||||
|
||||
class Term:
|
||||
def __init__(self, width, pipe=False):
|
||||
|
@ -143,84 +144,25 @@ class Timer:
|
|||
return Fragment(comb, sync)
|
||||
|
||||
class Sum:
|
||||
def __init__(self,size=4,pipe=False,prog_mode="PAR"):
|
||||
def __init__(self,size=4,pipe=False):
|
||||
self.size = size
|
||||
self.pipe = pipe
|
||||
self.prog_mode = prog_mode
|
||||
assert (size <= 4), "size > 4 (This version support only non cascadable SRL16)"
|
||||
self.i = Array(Signal() for j in range(4))
|
||||
for j in range(4):
|
||||
self.i[j].name_override = "i%d"%j
|
||||
|
||||
self._ce = Signal()
|
||||
self._shift_in = Signal()
|
||||
|
||||
self.o = Signal()
|
||||
self.i = Array(Signal() for j in range(self.size))
|
||||
self._o = Signal()
|
||||
self.o = Signal()
|
||||
|
||||
if self.prog_mode == "PAR":
|
||||
self.prog = Signal()
|
||||
self.prog_dat = Signal(BV(16))
|
||||
self._shift_dat = Signal(BV(17))
|
||||
self._shift_cnt = Signal(BV(4))
|
||||
elif self.prog_mode == "SHIFT":
|
||||
self.shift_ce = Signal()
|
||||
self.shift_in = Signal()
|
||||
self.shift_out = Signal()
|
||||
|
||||
|
||||
def get_fragment(self):
|
||||
_shift_out = Signal()
|
||||
comb = []
|
||||
sync = []
|
||||
if self.prog_mode == "PAR":
|
||||
sync += [
|
||||
If(self.prog,
|
||||
self._shift_dat.eq(self.prog_dat),
|
||||
self._shift_cnt.eq(16)
|
||||
),
|
||||
|
||||
If(self._shift_cnt != 0,
|
||||
self._shift_dat.eq(self._shift_dat[1:]),
|
||||
self._shift_cnt.eq(self._shift_cnt-1),
|
||||
self._ce.eq(1)
|
||||
).Else(
|
||||
self._ce.eq(0)
|
||||
)
|
||||
]
|
||||
comb += [
|
||||
self._shift_in.eq(self._shift_dat[0])
|
||||
]
|
||||
elif self.prog_mode == "SHIFT":
|
||||
comb += [
|
||||
self._ce.eq(self.shift_ce),
|
||||
self._shift_in.eq(self.shift_in)
|
||||
]
|
||||
inst = [
|
||||
Instance("SRLC16E",
|
||||
[
|
||||
("a0", self.i[0]),
|
||||
("a1", self.i[1]),
|
||||
("a2", self.i[2]),
|
||||
("a3", self.i[3]),
|
||||
("ce", self._ce),
|
||||
("d", self._shift_in)
|
||||
] , [
|
||||
("q", self._o),
|
||||
("q15",_shift_out)
|
||||
] ,
|
||||
clkport="clk",
|
||||
)
|
||||
]
|
||||
if self.prog_mode == "SHIFT":
|
||||
comb += [
|
||||
self.shift_out.eq(_shift_out)
|
||||
]
|
||||
comb +=[self.o.eq(optree("|", [self.i[j] for j in range(self.size)]))]
|
||||
if self.pipe:
|
||||
sync += [self.o.eq(self._o)]
|
||||
else:
|
||||
comb += [self.o.eq(self._o)]
|
||||
return Fragment(comb=comb,sync=sync,instances=inst)
|
||||
return Fragment(comb=comb,sync=sync)
|
||||
|
||||
|
||||
class Trigger:
|
||||
|
|
60
sim/tb_migScopeCsr.py
Normal file
60
sim/tb_migScopeCsr.py
Normal file
|
@ -0,0 +1,60 @@
|
|||
from migen.fhdl.structure import *
|
||||
from migen.fhdl import verilog, autofragment
|
||||
from migen.bus import csr
|
||||
from migen.sim.generic import Simulator, PureSimulable, TopLevel
|
||||
from migen.sim.icarus import Runner
|
||||
from migen.bus.transactions import *
|
||||
|
||||
from random import Random
|
||||
|
||||
import sys
|
||||
sys.path.append("../")
|
||||
import migScope
|
||||
|
||||
|
||||
def csr_transactions():
|
||||
prng = Random(92837)
|
||||
|
||||
# Write to the first addresses.
|
||||
for x in range(10):
|
||||
t = TWrite(x, 2*x)
|
||||
yield t
|
||||
print("Wrote in " + str(t.latency) + " cycle(s)")
|
||||
# Insert some dead cycles to simulate bus inactivity.
|
||||
for delay in range(prng.randrange(0, 3)):
|
||||
yield None
|
||||
|
||||
# Read from the first addresses.
|
||||
for x in range(10):
|
||||
t = TRead(x)
|
||||
yield t
|
||||
print("Read " + str(t.data) + " in " + str(t.latency) + " cycle(s)")
|
||||
for delay in range(prng.randrange(0, 3)):
|
||||
yield None
|
||||
|
||||
|
||||
|
||||
def main():
|
||||
# Csr Master
|
||||
csr_master0 = csr.Initiator(csr_transactions())
|
||||
|
||||
term0 = migScope.Term(32)
|
||||
|
||||
trigger0 = migScope.Trigger(0,32,64,[term0])
|
||||
csrcon0 = csr.Interconnect(csr_master0.bus,
|
||||
[
|
||||
trigger0.bank.interface
|
||||
])
|
||||
def end_simulation(s):
|
||||
s.interrupt = csr_master0.done
|
||||
|
||||
fragment = autofragment.from_local() + Fragment(sim=[end_simulation])
|
||||
sim = Simulator(fragment, Runner(),TopLevel("myvcd"))
|
||||
sim.run(20)
|
||||
|
||||
main()
|
||||
|
||||
|
||||
|
||||
|
||||
|
9
sim/tb_spi2Csr.py
Normal file
9
sim/tb_spi2Csr.py
Normal file
|
@ -0,0 +1,9 @@
|
|||
from migen.fhdl.structure import *
|
||||
from migen.fhdl import verilog, autofragment
|
||||
|
||||
import sys
|
||||
sys.path.append("../")
|
||||
import spi2Csr
|
||||
|
||||
|
||||
spi2csr0 = spi2Csr.Spi2Csr(16,8)
|
Loading…
Reference in a new issue