From 6c34949c45cf7ddfdabafb749de2cb9e439b381e Mon Sep 17 00:00:00 2001 From: ducky Date: Mon, 26 Oct 2015 17:30:15 -0700 Subject: Break out Utils.scala into smaller portions --- src/main/scala/Chisel/util/LFSR.scala | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) create mode 100644 src/main/scala/Chisel/util/LFSR.scala (limited to 'src/main/scala/Chisel/util/LFSR.scala') diff --git a/src/main/scala/Chisel/util/LFSR.scala b/src/main/scala/Chisel/util/LFSR.scala new file mode 100644 index 00000000..839b1d1f --- /dev/null +++ b/src/main/scala/Chisel/util/LFSR.scala @@ -0,0 +1,22 @@ +// See LICENSE for license details. + +/** LFSRs in all shapes and sizes. + */ + +package Chisel + +// scalastyle:off magic.number +/** linear feedback shift register + */ +object LFSR16 +{ + def apply(increment: Bool = Bool(true)): UInt = + { + val width = 16 + val lfsr = Reg(init=UInt(1, width)) + when (increment) { lfsr := Cat(lfsr(0)^lfsr(2)^lfsr(3)^lfsr(5), lfsr(width-1,1)) } + lfsr + } +} +// scalastyle:on magic.number + -- cgit v1.2.3