From c0d2b5a78947814eeb9476fe7ca4c1e3d27e02f4 Mon Sep 17 00:00:00 2001 From: Sebastien Bourdeauducq Date: Mon, 21 Oct 2013 22:30:06 +0200 Subject: [PATCH] genlib/fifo: support RecordP --- migen/genlib/fifo.py | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/migen/genlib/fifo.py b/migen/genlib/fifo.py index afb397f83..b892e9c46 100644 --- a/migen/genlib/fifo.py +++ b/migen/genlib/fifo.py @@ -19,18 +19,18 @@ class _FIFOInterface: self.re = Signal() self.readable = Signal() # not empty - if isinstance(width_or_layout, list): - self.din = Record(width_or_layout) - self.dout = Record(width_or_layout) - self.din_bits = self.din.raw_bits() - self.dout_bits = self.dout.raw_bits() - self.width = layout_len(width_or_layout) - else: + if isinstance(width_or_layout, (int, tuple)): self.din = Signal(width_or_layout) self.dout = Signal(width_or_layout) self.din_bits = self.din self.dout_bits = self.dout self.width = width_or_layout + else: + self.din = Record(width_or_layout) + self.dout = Record(width_or_layout) + self.din_bits = self.din.raw_bits() + self.dout_bits = self.dout.raw_bits() + self.width = layout_len(width_or_layout) class SyncFIFO(Module, _FIFOInterface): def __init__(self, width_or_layout, depth):