From bf7864104a042a93583da8c29ba5125997ee25c1 Mon Sep 17 00:00:00 2001 From: Florent Kermarrec Date: Sun, 26 Aug 2012 13:03:11 +0200 Subject: [PATCH] tb_spi2Csr: Add clk_ratio tb_spi2Csr: Add Read spi2Csr : fixs --- sim/tb_spi2Csr.py | 90 +++++++++++++++++++++++++++++++++++++-------- spi2Csr/__init__.py | 6 +-- 2 files changed, 77 insertions(+), 19 deletions(-) diff --git a/sim/tb_spi2Csr.py b/sim/tb_spi2Csr.py index 1f3a04cf4..781c657e4 100644 --- a/sim/tb_spi2Csr.py +++ b/sim/tb_spi2Csr.py @@ -13,22 +13,35 @@ import spi2Csr def get_bit(dat, bit): return int(dat & (1<= a_w*2 and self.transaction_cnt < a_w*2+d_w*2: - bit = d_w-1-int((self.transaction_cnt-a_w*2)/2) + elif self.transaction_cnt >= 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*2+d_w*2: + 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) @@ -76,6 +94,46 @@ class SpiMaster(PureSimulable): # 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) @@ -96,7 +154,7 @@ def main(): ]) # Spi Master - spi_master0 = SpiMaster(spi2csr0,spi_transactions()) + spi_master0 = SpiMaster(spi2csr0, 8, spi_transactions()) # Simulation def end_simulation(s): @@ -106,7 +164,7 @@ def main(): fragment = autofragment.from_local() fragment += Fragment(sim=[end_simulation]) sim = Simulator(fragment, Runner(),TopLevel("tb_spi2Csr.vcd")) - sim.run(1000) + sim.run(10000) main() input() diff --git a/spi2Csr/__init__.py b/spi2Csr/__init__.py index 07ea10a10..72e1ad0d2 100644 --- a/spi2Csr/__init__.py +++ b/spi2Csr/__init__.py @@ -59,8 +59,8 @@ class Spi2Csr : spi_mosi_dat = Signal() comb += [ - spi_clk_rising.eq(spi_clk_d3 & ~spi_clk_d2), - spi_clk_falling.eq(~spi_clk_d3 & spi_clk_d2), + spi_clk_rising.eq(spi_clk_d2 & ~spi_clk_d3), + spi_clk_falling.eq(~spi_clk_d2 & spi_clk_d3), spi_cs_n_active.eq(~spi_cs_n_d3), spi_mosi_dat.eq(spi_mosi_d3) ] @@ -136,7 +136,7 @@ class Spi2Csr : spi_miso_dat.eq(0) ).Elif(spi_clk_falling, spi_miso_dat.eq(spi_r_dat_shift[self.d_width-1]), - spi_r_dat_shift.eq(Cat(spi_r_dat_shift[:self.d_width-2],0)) + spi_r_dat_shift.eq(Cat(0,spi_r_dat_shift[:self.d_width-1])) ) ]