mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
192 lines
4.6 KiB
Python
192 lines
4.6 KiB
Python
from migen.fhdl.structure import *
|
|
from migen.fhdl import verilog
|
|
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 miscope.trigger import *
|
|
from miscope.recorder import *
|
|
from miscope.tools.truthtable import *
|
|
from miscope.tools.vcd import *
|
|
|
|
TRIGGER_ADDR = 0x0000
|
|
RECORDER_ADDR = 0x0200
|
|
|
|
rec_done = False
|
|
dat_rdy = False
|
|
|
|
dat_vcd = VcdDat(32)
|
|
rec_size = 64
|
|
|
|
def term_prog(off, dat):
|
|
for i in range(4):
|
|
yield TWrite(off+3-i, (dat>>(8*i))&0xFF)
|
|
|
|
|
|
def sum_prog(off, addr, dat):
|
|
we = 2
|
|
yield TWrite(off+3, addr%0xFF)
|
|
yield TWrite(off+2, (addr>>8)%0xFF)
|
|
yield TWrite(off+1, we+dat)
|
|
yield TWrite(off+0, 0)
|
|
for i in range(4):
|
|
yield TWrite(off+i,0)
|
|
|
|
def csr_transactions(trigger0, recorder0):
|
|
|
|
# Trigger Prog
|
|
##############################
|
|
|
|
# Term Prog
|
|
term_trans = []
|
|
term_trans += [term_prog(trigger0.ports[0].reg_p.base+0, 0xFFFFFFFF)]
|
|
term_trans += [term_prog(trigger0.ports[0].reg_p.base+4, 0x00000000)]
|
|
term_trans += [term_prog(trigger0.ports[1].reg_p.base+0, 0xFFFFFFFF)]
|
|
term_trans += [term_prog(trigger0.ports[1].reg_p.base+4, 0x00000004)]
|
|
term_trans += [term_prog(trigger0.ports[2].reg_p.base+0, 0xFFFFFFFF)]
|
|
term_trans += [term_prog(trigger0.ports[2].reg_p.base+4, 0x00000008)]
|
|
term_trans += [term_prog(trigger0.ports[3].reg_p.base+0, 0xFFFFFFFF)]
|
|
term_trans += [term_prog(trigger0.ports[3].reg_p.base+4, 0x0000000C)]
|
|
for t in term_trans:
|
|
for r in t:
|
|
yield r
|
|
|
|
# Sum Prog
|
|
sum_tt = gen_truth_table("term0 | term1 | term2 | term3")
|
|
sum_trans = []
|
|
for i in range(len(sum_tt)):
|
|
sum_trans.append(sum_prog(trigger0.sum.reg_p.base, i, sum_tt[i]))
|
|
for t in sum_trans:
|
|
for r in t:
|
|
yield r
|
|
|
|
# Recorder Prog
|
|
##############################
|
|
#Reset
|
|
yield TWrite(recorder0.address + REC_RST_BASE, 1)
|
|
yield TWrite(recorder0.address + REC_RST_BASE, 0)
|
|
|
|
# RLE
|
|
yield TWrite(REC_RLE_BASE, 0)
|
|
|
|
#Size
|
|
yield TWrite(recorder0.address + REC_SIZE_BASE + 0, 0)
|
|
yield TWrite(recorder0.address + REC_OFFSET_BASE + 1, rec_size)
|
|
|
|
#Offset
|
|
yield TWrite(recorder0.address + REC_OFFSET_BASE + 0, 0)
|
|
yield TWrite(recorder0.address + REC_OFFSET_BASE + 1, 16)
|
|
|
|
#Arm
|
|
yield TWrite(recorder0.address + REC_ARM_BASE, 1)
|
|
yield TWrite(recorder0.address + REC_ARM_BASE, 0)
|
|
|
|
# Wait Record to be done
|
|
##############################
|
|
global rec_done
|
|
while not rec_done:
|
|
yield None
|
|
|
|
# Read recorded data
|
|
##############################
|
|
global dat_rdy
|
|
for t in range(rec_size):
|
|
yield TWrite(recorder0.address + REC_READ_BASE, 1)
|
|
dat_rdy = False
|
|
yield TWrite(recorder0.address + REC_READ_BASE, 0)
|
|
yield TRead(recorder0.address + REC_READ_DATA_BASE + 0)
|
|
yield TRead(recorder0.address + REC_READ_DATA_BASE + 1)
|
|
yield TRead(recorder0.address + REC_READ_DATA_BASE + 2)
|
|
yield TRead(recorder0.address + REC_READ_DATA_BASE + 3)
|
|
dat_rdy = True
|
|
|
|
dat_rdy = False
|
|
|
|
for t in range(512):
|
|
yield None
|
|
|
|
|
|
trig_sig_val = 0
|
|
|
|
|
|
def main():
|
|
|
|
# Trigger
|
|
term0 = Term(32)
|
|
term1 = Term(32)
|
|
term2 = Term(32)
|
|
term3 = Term(32)
|
|
trigger0 = Trigger(32, [term0, term1, term2, term3], address=TRIGGER_ADDR)
|
|
|
|
# Recorder
|
|
recorder0 = Recorder(32, 1024, address=RECORDER_ADDR)
|
|
|
|
# Csr Master
|
|
csr_master0 = csr.Initiator(csr_transactions(trigger0, recorder0))
|
|
|
|
# Csr Interconnect
|
|
csrcon0 = csr.Interconnect(csr_master0.bus,
|
|
[
|
|
trigger0.bank.bus,
|
|
recorder0.bank.bus
|
|
])
|
|
|
|
trig_sig = Signal(32)
|
|
comb =[
|
|
trigger0.trig.eq(trig_sig)
|
|
]
|
|
|
|
comb += [
|
|
recorder0.dat.eq(trig_sig),
|
|
recorder0.hit.eq(trigger0.hit)
|
|
]
|
|
# Term Test
|
|
def term_stimuli(s):
|
|
global trig_sig_val
|
|
s.wr(trig_sig,trig_sig_val)
|
|
trig_sig_val += 1
|
|
trig_sig_val = trig_sig_val % 256
|
|
|
|
# Recorder Data
|
|
def recorder_data(s):
|
|
global rec_done
|
|
if s.rd(recorder0.sequencer.done) == 1:
|
|
rec_done = True
|
|
|
|
global dat_rdy
|
|
if dat_rdy:
|
|
print("%08X" %s.rd(recorder0._pull_dat.field.w))
|
|
global dat_vcd
|
|
dat_vcd.append(s.rd(recorder0._pull_dat.field.w))
|
|
|
|
|
|
# Simulation
|
|
def end_simulation(s):
|
|
s.interrupt = csr_master0.done
|
|
myvcd = Vcd()
|
|
myvcd.add(Var("trig_dat", 32, dat_vcd))
|
|
f = open("tb_miscope_out.vcd", "w")
|
|
f.write(str(myvcd))
|
|
f.close()
|
|
|
|
fragment = term0.get_fragment()
|
|
fragment += term1.get_fragment()
|
|
fragment += term2.get_fragment()
|
|
fragment += term3.get_fragment()
|
|
fragment += trigger0.get_fragment()
|
|
fragment += recorder0.get_fragment()
|
|
fragment += csr_master0.get_fragment()
|
|
fragment += csrcon0.get_fragment()
|
|
|
|
fragment += Fragment(comb=comb)
|
|
fragment += Fragment(sim=[term_stimuli])
|
|
fragment += Fragment(sim=[recorder_data])
|
|
fragment += Fragment(sim=[end_simulation])
|
|
|
|
sim = Simulator(fragment, TopLevel("tb_miscope.vcd"))
|
|
sim.run(2000)
|
|
|
|
main()
|
|
print("Sim Done")
|
|
input()
|