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