2022-04-17 11:25:48 +02:00

33 lines
1.0 KiB
Python

from migen import *
from migen.genlib.fifo import *
import litex
from litex.soc.interconnect import wishbone
from migen.genlib.cdc import BusSynchronizer
class Wishbone2NuBus(Module):
def __init__(self, nubus, wb):
# cpu
# input cpu_valid,
# input [31:0] cpu_addr,
# input [31:0] cpu_wdata,
# input [ 3:0] cpu_write,
# output cpu_ready,
# output [31:0] cpu_rdata,
#input cpu_lock,
#input cpu_eclr,
#output [3:0] cpu_errors,
self.comb += nubus.cpu_valid.eq(wb.cyc & wb.stb)
self.comb += nubus.cpu_addr.eq(Cat(Signal(2, reset = 0), wb.adr))
self.comb += nubus.cpu_wdata.eq(wb.dat_w)
self.comb += If(wb.we == 1,
nubus.cpu_write.eq(wb.sel)).Else(
nubus.cpu_write.eq(0))
self.comb += wb.ack.eq(nubus.cpu_ready)
self.comb += wb.dat_r.eq(nubus.cpu_rdata)
self.comb += nubus.cpu_lock.eq(0) # FIXME: TODO: ???
self.comb += nubus.cpu_eclr.eq(0) # FIXME: TODO: ???