blob: a9f4b3304fee96e5fa4d781d949fd12ebf7d8dd6 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
|
// See LICENSE for license details.
package firrtl.passes
package memlib
import firrtl.Mappers._
import firrtl.ir._
/** Annotates sequential memories that are candidates for macro replacement.
* Requirements for macro replacement:
* - read latency and write latency of one
* - only one readwrite port or write port
* - zero or one read port
*/
object ToMemIR extends Pass {
/** Only annotate memories that are candidates for memory macro replacements
* i.e. rw, w + r (read, write 1 cycle delay)
*/
def updateStmts(s: Statement): Statement = s match {
case m: DefMemory if m.readLatency == 1 && m.writeLatency == 1 &&
(m.writers.length + m.readwriters.length) == 1 && m.readers.length <= 1 =>
DefAnnotatedMemory(m)
case sx => sx map updateStmts
}
def annotateModMems(m: DefModule) = m map updateStmts
def run(c: Circuit) = c copy (modules = c.modules map annotateModMems)
}
|