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 migen.bank import description, csrgen from migen.bank.description import * import sys sys.path.append("../") import spi2Csr def get_bit(dat, bit): return int(dat & (1<= a_w*self.clk_ratio and self.transaction_cnt < (a_w + d_w)*self.clk_ratio: bit = d_w-1-int((self.transaction_cnt-a_w*self.clk_ratio)/self.clk_ratio) data = get_bit(self.transaction.data,bit) s.wr(self.spi.spi_mosi, data) else: s.wr(self.spi.spi_mosi, 0) # Cs_n if self.transaction_cnt < (a_w + d_w)*self.clk_ratio: s.wr(self.spi.spi_cs_n,0) else: s.wr(self.spi.spi_cs_n, 1) s.wr(self.spi.spi_clk, 0) s.wr(self.spi.spi_mosi, 0) self.transaction = None # Incr transaction_cnt self.transaction_cnt +=1 elif isinstance(self.transaction, TRead): # Clk if (int(self.transaction_cnt/(self.clk_ratio/2)))%2: s.wr(self.spi.spi_clk, 1) else: s.wr(self.spi.spi_clk, 0) # Mosi Addr if self.transaction_cnt < a_w*self.clk_ratio: bit = a_w-1-int((self.transaction_cnt)/self.clk_ratio) if int(self.transaction_cnt/self.clk_ratio) == 0: data = 0 else: data = get_bit(self.transaction.address, bit) s.wr(self.spi.spi_mosi, data) else: s.wr(self.spi.spi_mosi, 0) # Miso Data if self.transaction_cnt >= a_w*self.clk_ratio and self.transaction_cnt%self.clk_ratio==self.clk_ratio/2: bit = d_w-1-int((self.transaction_cnt-a_w*self.clk_ratio)/self.clk_ratio) if s.rd(self.spi.spi_miso): self.r_dat = set_bit(self.r_dat, bit) # Cs_n if self.transaction_cnt < (a_w + d_w)*self.clk_ratio: s.wr(self.spi.spi_cs_n,0) else: s.wr(self.spi.spi_cs_n, 1) s.wr(self.spi.spi_clk, 0) s.wr(self.spi.spi_mosi, 0) self.transaction = None print("%02X" %self.r_dat) # Incr transaction_cnt self.transaction_cnt +=1 def main(): # Csr Slave scratch_reg0 = RegisterField("scratch_reg0", 32, reset=0, access_dev=READ_ONLY) scratch_reg1 = RegisterField("scratch_reg1", 32, reset=0, access_dev=READ_ONLY) scratch_reg2 = RegisterField("scratch_reg3", 32, reset=0, access_dev=READ_ONLY) scratch_reg3 = RegisterField("scratch_reg4", 32, reset=0, access_dev=READ_ONLY) regs = [scratch_reg0, scratch_reg1, scratch_reg2, scratch_reg3] bank0 = csrgen.Bank(regs,address=0x0000) # Spi2Csr spi2csr0 = spi2Csr.Spi2Csr(16,8) # Csr Interconnect csrcon0 = csr.Interconnect(spi2csr0.csr, [ bank0.interface ]) # Spi Master spi_master0 = SpiMaster(spi2csr0, 8, spi_transactions()) # Simulation def end_simulation(s): s.interrupt = spi_master0.done fragment = autofragment.from_local() fragment += Fragment(sim=[end_simulation]) sim = Simulator(fragment, Runner(),TopLevel("tb_spi2Csr.vcd")) sim.run(10000) main() input()