phy: add bitslip module (we need to implement it in logic for Kintex Ultrascale since not provided by ISERDESE3)

This commit is contained in:
Florent Kermarrec 2017-02-09 17:21:07 +01:00
parent 1430cb3d49
commit 062177502b
2 changed files with 86 additions and 0 deletions

17
litedram/phy/bitslip.py Normal file
View file

@ -0,0 +1,17 @@
from litex.gen import *
class BitSlip(Module):
def __init__(self, dw):
self.i = Signal(dw)
self.o = Signal(dw)
self.value = Signal(max=dw)
# # #
r = Signal(2*dw)
self.sync += r.eq(Cat(r[dw:], self.i))
cases = {}
for i in range(dw):
cases[i] = self.o.eq(r[i:dw+i])
self.sync += Case(self.value, cases)

69
test/test_bitslip.py Normal file
View file

@ -0,0 +1,69 @@
import unittest
import random
from litex.gen import *
from litedram.phy.bitslip import BitSlip
class BitSlipModel:
def __init__(self, data_width, latency):
self.data_width = data_width
self.latency = latency
def simulate(self, bitslip, sequence):
# prepare sequence for simulation
s = [0]*self.latency
for d in sequence:
s.append(d)
# simulate bitslip
r = []
for i in range(len(s)-1):
v = (s[i+1] & (2**bitslip-1)) << (self.data_width-bitslip)
v |= (s[i] >> bitslip) & (2**(self.data_width-bitslip)-1)
r.append(v)
return r
def main_generator(dut):
dut.o_sequence = []
yield dut.value.eq(dut.bitslip)
for i, data in enumerate(dut.i_sequence):
yield dut.i.eq(data)
dut.o_sequence.append((yield dut.o))
yield
class TestBitSlip(unittest.TestCase):
def bitslip_test(self, data_width, length=128):
prng = random.Random(42)
sequence = [prng.randrange(2**data_width) for i in range(length)]
for i in range(data_width):
dut = BitSlip(data_width)
dut.bitslip = i
dut.i_sequence = sequence
run_simulation(dut, main_generator(dut))
model = BitSlipModel(data_width, 4)
m_sequence = model.simulate(i, sequence)
self.assertEqual(dut.o_sequence, m_sequence[:len(dut.o_sequence)])
def test_bitslip_4b(self):
self.bitslip_test(4)
def test_bitslip_8b(self):
self.bitslip_test(8)
def test_bitslip_16b(self):
self.bitslip_test(16)
def test_bitslip_32b(self):
self.bitslip_test(32)
def test_bitslip_64b(self):
self.bitslip_test(64)
def test_bitslip_128b(self):
self.bitslip_test(128)