mirror of
https://github.com/rdolbeau/NuBusFPGA.git
synced 2025-01-10 11:29:48 +00:00
71 lines
2.8 KiB
Python
71 lines
2.8 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 NuBus2Wishbone(Module):
|
|
def __init__(self, nubus, wb):
|
|
|
|
# memory
|
|
# nubus.mem_valid
|
|
# nubus.mem_addr
|
|
# nubus.mem_wdata
|
|
# nubus.mem_write
|
|
# nubus.mem_ready
|
|
# nubus.mem_rdata
|
|
#nubus.mem_error
|
|
#nubus.mem_tryagain
|
|
|
|
assert(len(wb.dat_r) == 32)
|
|
assert(len(nubus.mem_wdata) == 32)
|
|
assert(len(nubus.mem_write) == 4)
|
|
|
|
#wb_dat_r_rev = Signal(32)
|
|
#self.comb += [ wb_dat_r_rev[ 0: 8].eq(wb.dat_r[24:32]),
|
|
# wb_dat_r_rev[ 8:16].eq(wb.dat_r[16:24]),
|
|
# wb_dat_r_rev[16:24].eq(wb.dat_r[ 8:16]),
|
|
# wb_dat_r_rev[24:32].eq(wb.dat_r[ 0: 8]), ]
|
|
#nubus_mem_wdata_rev = Signal(32)
|
|
#self.comb += [ nubus_mem_wdata_rev[ 0: 8].eq(nubus.mem_wdata[24:32]),
|
|
# nubus_mem_wdata_rev[ 8:16].eq(nubus.mem_wdata[16:24]),
|
|
# nubus_mem_wdata_rev[16:24].eq(nubus.mem_wdata[ 8:16]),
|
|
# nubus_mem_wdata_rev[24:32].eq(nubus.mem_wdata[ 0: 8]), ]
|
|
#nubus_mem_write_rev = Signal(4)
|
|
#self.comb += [ nubus_mem_write_rev[0].eq(nubus.mem_write[3]),
|
|
# nubus_mem_write_rev[1].eq(nubus.mem_write[2]),
|
|
# nubus_mem_write_rev[2].eq(nubus.mem_write[1]),
|
|
# nubus_mem_write_rev[3].eq(nubus.mem_write[0]), ]
|
|
|
|
self.comb += wb.cyc.eq(nubus.mem_valid)
|
|
self.comb += wb.stb.eq(nubus.mem_valid)
|
|
self.comb += wb.we.eq(nubus.mem_write != 0)
|
|
|
|
self.comb += [
|
|
If(~nubus.mem_addr[23], # first 8 MiB of slot space: remap to last 8 Mib of SDRAM
|
|
wb.adr.eq(Cat(nubus.mem_addr[2:23], Signal(1, reset=1), Signal(8, reset = 0x8f))), # 0x8f8...
|
|
).Else( # second 8 MiB: direct access
|
|
wb.adr.eq(Cat(nubus.mem_addr[2:24], Signal(8, reset = 0xf0)))), # 24 bits, a.k.a 22 bits of words
|
|
]
|
|
|
|
self.comb += If(nubus.mem_write == 0,
|
|
wb.sel.eq(0xF)).Else(
|
|
wb.sel.eq(nubus.mem_write))
|
|
self.comb += [
|
|
wb.dat_w.eq(nubus.mem_wdata),
|
|
nubus.mem_rdata.eq(wb.dat_r),
|
|
]
|
|
#self.comb += If(nubus.mem_write == 0,
|
|
# wb.sel.eq(0xF)).Else(
|
|
# wb.sel.eq(nubus_mem_write_rev))
|
|
#self.comb += [
|
|
# wb.dat_w.eq(nubus_mem_wdata_rev),
|
|
# nubus.mem_rdata.eq(wb_dat_r_rev),
|
|
#]
|
|
|
|
self.comb += nubus.mem_ready.eq(wb.ack)
|
|
self.comb += nubus.mem_error.eq(0) # FIXME: TODO: ???
|
|
self.comb += nubus.mem_tryagain.eq(0) # FIXME: TODO: ???
|