diff options
| author | ducky | 2015-10-26 17:30:15 -0700 |
|---|---|---|
| committer | Palmer Dabbelt | 2015-11-02 13:04:21 -0800 |
| commit | 6c34949c45cf7ddfdabafb749de2cb9e439b381e (patch) | |
| tree | b4bcdd586123b571a2f53b6726e501003dd46119 /src/main/scala/Chisel/util/Reg.scala | |
| parent | 178f5c564e9ab0594656185e2e0a5bcc029d5743 (diff) | |
Break out Utils.scala into smaller portions
Diffstat (limited to 'src/main/scala/Chisel/util/Reg.scala')
| -rw-r--r-- | src/main/scala/Chisel/util/Reg.scala | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/src/main/scala/Chisel/util/Reg.scala b/src/main/scala/Chisel/util/Reg.scala new file mode 100644 index 00000000..44593dfd --- /dev/null +++ b/src/main/scala/Chisel/util/Reg.scala @@ -0,0 +1,55 @@ +// See LICENSE for license details. + +/** Variations and helpers for registers. + */ + +package Chisel + +object RegNext { + + def apply[T <: Data](next: T): T = Reg[T](next, next, null.asInstanceOf[T]) + + def apply[T <: Data](next: T, init: T): T = Reg[T](next, next, init) + +} + +object RegInit { + + def apply[T <: Data](init: T): T = Reg[T](init, null.asInstanceOf[T], init) + +} + +/** A register with an Enable signal */ +object RegEnable +{ + def apply[T <: Data](updateData: T, enable: Bool): T = { + val r = Reg(updateData) + when (enable) { r := updateData } + r + } + def apply[T <: Data](updateData: T, resetData: T, enable: Bool): T = { + val r = RegInit(resetData) + when (enable) { r := updateData } + r + } +} + +/** Returns the n-cycle delayed version of the input signal. + */ +object ShiftRegister +{ + /** @param in input to delay + * @param n number of cycles to delay + * @param en enable the shift */ + def apply[T <: Data](in: T, n: Int, en: Bool = Bool(true)): T = + { + // The order of tests reflects the expected use cases. + if (n == 1) { + RegEnable(in, en) + } else if (n != 0) { + RegNext(apply(in, n-1, en)) + } else { + in + } + } +} |
