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.bus import csr
|
||||||
from migen.bank import description, csrgen
|
from migen.bank import description, csrgen
|
||||||
from migen.bank.description import *
|
from migen.bank.description import *
|
||||||
|
from migen.corelogic.misc import optree
|
||||||
|
|
||||||
class Term:
|
class Term:
|
||||||
def __init__(self, width, pipe=False):
|
def __init__(self, width, pipe=False):
|
||||||
|
@ -143,84 +144,25 @@ class Timer:
|
||||||
return Fragment(comb, sync)
|
return Fragment(comb, sync)
|
||||||
|
|
||||||
class Sum:
|
class Sum:
|
||||||
def __init__(self,size=4,pipe=False,prog_mode="PAR"):
|
def __init__(self,size=4,pipe=False):
|
||||||
self.size = size
|
self.size = size
|
||||||
self.pipe = pipe
|
self.pipe = pipe
|
||||||
self.prog_mode = prog_mode
|
self.i = Array(Signal() for j in range(self.size))
|
||||||
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._o = Signal()
|
self._o = Signal()
|
||||||
|
self.o = Signal()
|
||||||
|
|
||||||
if self.prog_mode == "PAR":
|
|
||||||
self.prog = Signal()
|
self.prog = Signal()
|
||||||
self.prog_dat = Signal(BV(16))
|
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):
|
def get_fragment(self):
|
||||||
_shift_out = Signal()
|
|
||||||
comb = []
|
comb = []
|
||||||
sync = []
|
sync = []
|
||||||
if self.prog_mode == "PAR":
|
comb +=[self.o.eq(optree("|", [self.i[j] for j in range(self.size)]))]
|
||||||
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)
|
|
||||||
]
|
|
||||||
if self.pipe:
|
if self.pipe:
|
||||||
sync += [self.o.eq(self._o)]
|
sync += [self.o.eq(self._o)]
|
||||||
else:
|
else:
|
||||||
comb += [self.o.eq(self._o)]
|
comb += [self.o.eq(self._o)]
|
||||||
return Fragment(comb=comb,sync=sync,instances=inst)
|
return Fragment(comb=comb,sync=sync)
|
||||||
|
|
||||||
|
|
||||||
class Trigger:
|
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