From ecd54b3efba89b161f16efc911e399033c5f3bce Mon Sep 17 00:00:00 2001 From: "mergify[bot]" <37929162+mergify[bot]@users.noreply.github.com> Date: Thu, 14 May 2020 02:40:55 +0000 Subject: [PATCH] Speed up InferTypes and CInferTypes (bp #1601) (#1617) * Use HashMap instead of LinkedHashMap in InferTypes Do the same in CInferTypes (cherry picked from commit a15f65c8eeb032899928dcd19332225d2d7d0f16) * Remove a redundant Expression traversal in InferTypes (cherry picked from commit 26693f72a15a2c3810ef60679a04e0fa86887f8f) Co-authored-by: Jack Koenig --- src/main/scala/firrtl/passes/InferTypes.scala | 24 ++++++++++++------- 1 file changed, 15 insertions(+), 9 deletions(-) diff --git a/src/main/scala/firrtl/passes/InferTypes.scala b/src/main/scala/firrtl/passes/InferTypes.scala index 78213f49e8..4702a87f7c 100644 --- a/src/main/scala/firrtl/passes/InferTypes.scala +++ b/src/main/scala/firrtl/passes/InferTypes.scala @@ -12,8 +12,11 @@ object InferTypes extends Pass with PreservesAll[Transform] { override def prerequisites = Dependency(ResolveKinds) +: firrtl.stage.Forms.WorkingIR + @deprecated("This should never have been public", "1.3.2") type TypeMap = collection.mutable.LinkedHashMap[String, Type] + private type TypeLookup = collection.mutable.HashMap[String, Type] + def run(c: Circuit): Circuit = { val namespace = Namespace() val mtypes = (c.modules map (m => m.name -> module_type(m))).toMap @@ -36,7 +39,7 @@ object InferTypes extends Pass with PreservesAll[Transform] { } } - def infer_types_e(types: TypeMap)(e: Expression): Expression = + def infer_types_e(types: TypeLookup)(e: Expression): Expression = e map infer_types_e(types) match { case e: WRef => e copy (tpe = types(e.name)) case e: WSubField => e copy (tpe = field_type(e.expr.tpe, e.name)) @@ -48,7 +51,7 @@ object InferTypes extends Pass with PreservesAll[Transform] { case e @ (_: UIntLiteral | _: SIntLiteral) => e } - def infer_types_s(types: TypeMap)(s: Statement): Statement = s match { + def infer_types_s(types: TypeLookup)(s: Statement): Statement = s match { case sx: WDefInstance => val t = mtypes(sx.module) types(sx.name) = t @@ -61,7 +64,7 @@ object InferTypes extends Pass with PreservesAll[Transform] { val sxx = (sx map infer_types_e(types)).asInstanceOf[DefNode] val t = remove_unknowns(sxx.value.tpe) types(sx.name) = t - sxx map infer_types_e(types) + sxx case sx: DefRegister => val t = remove_unknowns(sx.tpe) types(sx.name) = t @@ -73,14 +76,14 @@ object InferTypes extends Pass with PreservesAll[Transform] { case sx => sx map infer_types_s(types) map infer_types_e(types) } - def infer_types_p(types: TypeMap)(p: Port): Port = { + def infer_types_p(types: TypeLookup)(p: Port): Port = { val t = remove_unknowns(p.tpe) types(p.name) = t p copy (tpe = t) } def infer_types(m: DefModule): DefModule = { - val types = new TypeMap + val types = new TypeLookup m map infer_types_p(types) map infer_types_s(types) } @@ -92,12 +95,15 @@ object CInferTypes extends Pass with PreservesAll[Transform] { override def prerequisites = firrtl.stage.Forms.ChirrtlForm + @deprecated("This should never have been public", "1.3.2") type TypeMap = collection.mutable.LinkedHashMap[String, Type] + private type TypeLookup = collection.mutable.HashMap[String, Type] + def run(c: Circuit): Circuit = { val mtypes = (c.modules map (m => m.name -> module_type(m))).toMap - def infer_types_e(types: TypeMap)(e: Expression) : Expression = + def infer_types_e(types: TypeLookup)(e: Expression) : Expression = e map infer_types_e(types) match { case (e: Reference) => e copy (tpe = types.getOrElse(e.name, UnknownType)) case (e: SubField) => e copy (tpe = field_type(e.expr.tpe, e.name)) @@ -109,7 +115,7 @@ object CInferTypes extends Pass with PreservesAll[Transform] { case e @ (_: UIntLiteral | _: SIntLiteral) => e } - def infer_types_s(types: TypeMap)(s: Statement): Statement = s match { + def infer_types_s(types: TypeLookup)(s: Statement): Statement = s match { case sx: DefRegister => types(sx.name) = sx.tpe sx map infer_types_e(types) @@ -136,13 +142,13 @@ object CInferTypes extends Pass with PreservesAll[Transform] { case sx => sx map infer_types_s(types) map infer_types_e(types) } - def infer_types_p(types: TypeMap)(p: Port): Port = { + def infer_types_p(types: TypeLookup)(p: Port): Port = { types(p.name) = p.tpe p } def infer_types(m: DefModule): DefModule = { - val types = new TypeMap + val types = new TypeLookup m map infer_types_p(types) map infer_types_s(types) }