2022-04-17 11:25:48 +02:00
|
|
|
from migen import *
|
|
|
|
from migen.genlib.fifo import *
|
|
|
|
|
|
|
|
import litex
|
|
|
|
from litex.soc.interconnect import wishbone
|
|
|
|
|
|
|
|
class PingMaster(Module):
|
2022-06-04 09:53:09 +02:00
|
|
|
def __init__(self, nubus, platform):
|
2022-04-17 11:25:48 +02:00
|
|
|
self.bus_slv = bus_slv = wishbone.Interface()
|
|
|
|
self.bus_mst = bus_mst = wishbone.Interface()
|
|
|
|
|
2022-06-04 09:53:09 +02:00
|
|
|
#led0 = platform.request("user_led", 0)
|
|
|
|
#led1 = platform.request("user_led", 1)
|
2022-05-30 19:06:33 +02:00
|
|
|
|
2022-04-17 11:25:48 +02:00
|
|
|
valu_reg = Signal(32)
|
2022-06-04 09:53:09 +02:00
|
|
|
waddr_reg = Signal(32)
|
|
|
|
raddr_reg = Signal(32)
|
2022-04-17 11:25:48 +02:00
|
|
|
writ_del = Signal(6)
|
2022-06-04 09:53:09 +02:00
|
|
|
read_del = Signal(6)
|
2022-05-30 19:06:33 +02:00
|
|
|
do_write = Signal()
|
2022-06-04 09:53:09 +02:00
|
|
|
do_read = Signal()
|
|
|
|
#waddr_reg_rev = Signal(32)
|
|
|
|
#self.comb += [ waddr_reg_rev[ 0: 8].eq(waddr_reg[24:32]),
|
|
|
|
# waddr_reg_rev[ 8:16].eq(waddr_reg[16:24]),
|
|
|
|
# waddr_reg_rev[16:24].eq(waddr_reg[ 8:16]),
|
|
|
|
# waddr_reg_rev[24:32].eq(waddr_reg[ 0: 8]), ]
|
2022-04-17 11:25:48 +02:00
|
|
|
|
2022-05-30 19:06:33 +02:00
|
|
|
self.sync += [ If(writ_del != 0,
|
|
|
|
writ_del.eq(writ_del - 1),),
|
|
|
|
If(writ_del == 1,
|
|
|
|
do_write.eq(1),
|
2022-06-04 09:53:09 +02:00
|
|
|
),
|
|
|
|
If(read_del != 0,
|
|
|
|
read_del.eq(read_del - 1),),
|
|
|
|
If(read_del == 1,
|
|
|
|
do_read.eq(1),
|
2022-05-30 19:06:33 +02:00
|
|
|
)
|
|
|
|
]
|
2022-04-17 11:25:48 +02:00
|
|
|
|
|
|
|
self.submodules.wishbone_fsm = wishbone_fsm = FSM(reset_state = "Reset")
|
|
|
|
wishbone_fsm.act("Reset",
|
|
|
|
NextValue(bus_slv.ack, 0),
|
|
|
|
NextState("Idle"))
|
|
|
|
wishbone_fsm.act("Idle",
|
|
|
|
If(bus_slv.cyc & bus_slv.stb & bus_slv.we & ~bus_slv.ack, #write
|
|
|
|
# FIXME: should check for prefix?
|
2022-06-04 09:53:09 +02:00
|
|
|
Case(bus_slv.adr[0:2], {
|
2022-04-17 11:25:48 +02:00
|
|
|
0x0: [ NextValue(valu_reg, bus_slv.dat_w[0:32]), ],
|
2022-06-04 09:53:09 +02:00
|
|
|
0x1: [ NextValue(waddr_reg, bus_slv.dat_w[0:32]),
|
|
|
|
NextValue(writ_del, 3), ],
|
|
|
|
0x2: [ NextValue(raddr_reg, bus_slv.dat_w[0:32]),
|
|
|
|
NextValue(read_del, 3), ],
|
2022-04-17 11:25:48 +02:00
|
|
|
}),
|
|
|
|
NextValue(bus_slv.ack, 1),
|
|
|
|
).Elif(bus_slv.cyc & bus_slv.stb & ~bus_slv.we & ~bus_slv.ack, #read
|
2022-06-04 09:53:09 +02:00
|
|
|
Case(bus_slv.adr[0:2], {
|
2022-04-17 11:25:48 +02:00
|
|
|
0x0: [ NextValue(bus_slv.dat_r, valu_reg), ],
|
2022-06-04 09:53:09 +02:00
|
|
|
0x1: [ NextValue(bus_slv.dat_r, waddr_reg), ],
|
|
|
|
0x2: [ NextValue(bus_slv.dat_r, raddr_reg), ],
|
2022-04-17 11:25:48 +02:00
|
|
|
}),
|
|
|
|
NextValue(bus_slv.ack, 1),
|
|
|
|
).Else(
|
|
|
|
NextValue(bus_slv.ack, 0),
|
2022-05-30 19:06:33 +02:00
|
|
|
)
|
2022-04-17 11:25:48 +02:00
|
|
|
)
|
|
|
|
|
2022-05-30 19:06:33 +02:00
|
|
|
self.submodules.writer_fsm = writer_fsm = FSM(reset_state = "Reset")
|
|
|
|
writer_fsm.act("Reset",
|
|
|
|
NextState("Idle"),)
|
|
|
|
writer_fsm.act("Idle",
|
2022-06-04 18:56:41 +02:00
|
|
|
If(do_write,
|
2022-05-30 19:06:33 +02:00
|
|
|
NextValue(do_write, 0),
|
2022-06-04 09:53:09 +02:00
|
|
|
bus_mst.cyc.eq(1),
|
|
|
|
bus_mst.stb.eq(1),
|
|
|
|
bus_mst.we.eq(1),
|
|
|
|
bus_mst.dat_w.eq(valu_reg),
|
|
|
|
bus_mst.adr.eq(waddr_reg[2:32]),
|
|
|
|
bus_mst.sel.eq(0xf),
|
|
|
|
If(bus_mst.ack,
|
|
|
|
NextState("Idle")
|
|
|
|
).Else(
|
|
|
|
NextState("Write")
|
|
|
|
)
|
|
|
|
).Elif(do_read,
|
|
|
|
NextValue(do_read, 0),
|
|
|
|
bus_mst.cyc.eq(1),
|
|
|
|
bus_mst.stb.eq(1),
|
|
|
|
bus_mst.we.eq(0),
|
|
|
|
bus_mst.adr.eq(raddr_reg[2:32]),
|
|
|
|
bus_mst.sel.eq(0xf),
|
|
|
|
NextState("Read"),
|
|
|
|
)
|
|
|
|
)
|
2022-05-30 19:06:33 +02:00
|
|
|
writer_fsm.act("Write",
|
|
|
|
bus_mst.cyc.eq(1),
|
|
|
|
bus_mst.stb.eq(1),
|
|
|
|
bus_mst.we.eq(1),
|
|
|
|
bus_mst.dat_w.eq(valu_reg),
|
2022-06-04 09:53:09 +02:00
|
|
|
bus_mst.adr.eq(waddr_reg[2:32]),
|
|
|
|
bus_mst.sel.eq(0xf),
|
|
|
|
If(bus_mst.ack,
|
|
|
|
NextState("Idle")
|
|
|
|
),
|
|
|
|
)
|
|
|
|
writer_fsm.act("Read",
|
|
|
|
bus_mst.cyc.eq(1),
|
|
|
|
bus_mst.stb.eq(1),
|
|
|
|
bus_mst.we.eq(0),
|
|
|
|
bus_mst.adr.eq(raddr_reg[2:32]),
|
2022-05-30 19:06:33 +02:00
|
|
|
bus_mst.sel.eq(0xf),
|
|
|
|
If(bus_mst.ack,
|
2022-06-04 09:53:09 +02:00
|
|
|
NextValue(valu_reg, bus_mst.dat_r),
|
|
|
|
NextState("Idle")
|
|
|
|
),
|
2022-05-30 19:06:33 +02:00
|
|
|
)
|
2022-04-17 11:25:48 +02:00
|
|
|
|
2022-06-04 09:53:09 +02:00
|
|
|
#self.comb += [ led0.eq(bus_mst.cyc),
|
|
|
|
# led1.eq(writ_del != 0), ]
|