1package utils 2 3import chisel3._ 4import freechips.rocketchip.tilelink.{TLBundle, TLBundleA, TLBundleB, TLBundleC, TLBundleD, TLBundleE, TLChannel} 5import xiangshan.HasXSLog 6 7trait HasTLDump { this: HasXSLog => 8 9 implicit class TLDump(channel: TLChannel) { 10 def dump = channel match { 11 case a: TLBundleA => 12 XSDebug(false, true.B, 13 a.channelName + " opcode: %x param: %x size: %x source: %d address: %x mask: %x data: %x corrupt: %b\n", 14 a.opcode, a.param, a.size, a.source, a.address, a.mask, a.data, a.corrupt 15 ) 16 case b: TLBundleB => 17 XSDebug(false, true.B, 18 b.channelName + " opcode: %x param: %x size: %x source: %d address: %x mask: %x data: %x corrupt: %b\n", 19 b.opcode, b.param, b.size, b.source, b.address, b.mask, b.data, b.corrupt 20 ) 21 case c: TLBundleC => 22 XSDebug(false, true.B, 23 c.channelName + " opcode: %x param: %x size: %x source: %d address: %x data: %x corrupt: %b\n", 24 c.opcode, c.param, c.size, c.source, c.address, c.data, c.corrupt 25 ) 26 case d: TLBundleD => 27 XSDebug(false, true.B, 28 d.channelName + " opcode: %x param: %x size: %x source: %d sink: %d denied: %b data: %x corrupt: %b\n", 29 d.opcode, d.param, d.size, d.source, d.sink, d.denied, d.data, d.corrupt 30 ) 31 case e: TLBundleE => 32 XSDebug(false, true.B, e.channelName + " sink: %d\n", e.sink) 33 } 34 } 35} 36