xref: /XiangShan/src/main/scala/xiangshan/transforms/PrintModuleName.scala (revision 12c5a998999e2fe717535076b2c4cc859fe9304f)
1e3da8badSTang Haojin/***************************************************************************************
2e3da8badSTang Haojin* Copyright (c) 2024 Beijing Institute of Open Source Chip (BOSC)
3e3da8badSTang Haojin* Copyright (c) 2020-2024 Institute of Computing Technology, Chinese Academy of Sciences
4e3da8badSTang Haojin* Copyright (c) 2020-2021 Peng Cheng Laboratory
5e3da8badSTang Haojin*
6e3da8badSTang Haojin* XiangShan is licensed under Mulan PSL v2.
7e3da8badSTang Haojin* You can use this software according to the terms and conditions of the Mulan PSL v2.
8e3da8badSTang Haojin* You may obtain a copy of Mulan PSL v2 at:
9e3da8badSTang Haojin*          http://license.coscl.org.cn/MulanPSL2
10e3da8badSTang Haojin*
11e3da8badSTang Haojin* THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
12e3da8badSTang Haojin* EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
13e3da8badSTang Haojin* MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
14e3da8badSTang Haojin*
15e3da8badSTang Haojin* See the Mulan PSL v2 for more details.
16e3da8badSTang Haojin***************************************************************************************/
17e3da8badSTang Haojin
18e3da8badSTang Haojinpackage xiangshan.transforms
19e3da8badSTang Haojin
20*12c5a998Sklin02import utility.XSLog
21*12c5a998Sklin02
22e3da8badSTang Haojinclass PrintModuleName extends firrtl.options.Phase {
23e3da8badSTang Haojin
24e3da8badSTang Haojin  override def invalidates(a: firrtl.options.Phase) = false
25e3da8badSTang Haojin
26e3da8badSTang Haojin  override def transform(annotations: firrtl.AnnotationSeq): firrtl.AnnotationSeq = {
27e3da8badSTang Haojin
28e3da8badSTang Haojin    import xiangshan.transforms.Helpers._
29e3da8badSTang Haojin
30e3da8badSTang Haojin    val (Seq(circuitAnno: firrtl.stage.FirrtlCircuitAnnotation), otherAnnos) = annotations.partition {
31e3da8badSTang Haojin      case _: firrtl.stage.FirrtlCircuitAnnotation => true
32e3da8badSTang Haojin      case _ => false
33e3da8badSTang Haojin    }
34e3da8badSTang Haojin    val c = circuitAnno.circuit
35e3da8badSTang Haojin
36e3da8badSTang Haojin    def onStmt(s: firrtl.ir.Statement): firrtl.ir.Statement = s match {
37e3da8badSTang Haojin      case firrtl.ir.Print(info, firrtl.ir.StringLit(string), args, clk, en) =>
38*12c5a998Sklin02        firrtl.ir.Print(info, firrtl.ir.StringLit(XSLog.replaceFIRStr(string)), args, clk, en)
39e3da8badSTang Haojin      case other: firrtl.ir.Statement =>
40e3da8badSTang Haojin        other.mapStmt(onStmt)
41e3da8badSTang Haojin    }
42e3da8badSTang Haojin
43e3da8badSTang Haojin    firrtl.stage.FirrtlCircuitAnnotation(c.mapModule(m => m.mapStmt(onStmt))) +: otherAnnos
44e3da8badSTang Haojin  }
45e3da8badSTang Haojin}
46