From 770c5671744502ba7865a41472972388b2fade2c Mon Sep 17 00:00:00 2001 From: Stevo Date: Mon, 30 Jan 2017 12:17:33 -0800 Subject: Add shift register with reset (#439) * [stevo]: add reset initialization to shift register * [stevo]: better comment * [stevo]: add tests, fix bug --- src/main/scala/chisel3/util/Reg.scala | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) (limited to 'src/main') diff --git a/src/main/scala/chisel3/util/Reg.scala b/src/main/scala/chisel3/util/Reg.scala index 00005e3a..27785dfb 100644 --- a/src/main/scala/chisel3/util/Reg.scala +++ b/src/main/scala/chisel3/util/Reg.scala @@ -61,4 +61,20 @@ object ShiftRegister in } } + + /** Returns the n-cycle delayed version of the input signal with reset initialization. + * + * @param in input to delay + * @param n number of cycles to delay + * @param resetData reset value for each register in the shift + * @param en enable the shift + */ + def apply[T <: Data](in: T, n: Int, resetData: T, en: Bool): T = { + // The order of tests reflects the expected use cases. + if (n != 0) { + RegEnable(apply(in, n-1, resetData, en), resetData, en) + } else { + in + } + } } -- cgit v1.2.3