Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenXiangShan
XiangShan
提交
8f653805
X
XiangShan
项目概览
OpenXiangShan
/
XiangShan
11 个月 前同步成功
通知
1183
Star
3914
Fork
526
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
X
XiangShan
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
8f653805
编写于
9月 01, 2020
作者:
L
LinJiawei
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
TLDump: opt print
上级
6ef34ce8
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
38 addition
and
43 deletion
+38
-43
src/main/scala/utils/DebugIdentityNode.scala
src/main/scala/utils/DebugIdentityNode.scala
+13
-8
src/main/scala/utils/TLDump.scala
src/main/scala/utils/TLDump.scala
+25
-35
未找到文件。
src/main/scala/utils/DebugIdentityNode.scala
浏览文件 @
8f653805
...
...
@@ -2,8 +2,9 @@ package utils
import
chisel3._
import
chipsalliance.rocketchip.config.Parameters
import
chisel3.util.DecoupledIO
import
freechips.rocketchip.diplomacy.
{
LazyModule
,
LazyModuleImp
}
import
freechips.rocketchip.tilelink.
{
TLClientNode
,
TLIdentityNode
,
TLMasterParameters
,
TLMasterPortParameters
}
import
freechips.rocketchip.tilelink.
{
TL
Bundle
,
TL
ClientNode
,
TLIdentityNode
,
TLMasterParameters
,
TLMasterPortParameters
}
import
xiangshan.HasXSLog
class
DebugIdentityNode
()(
implicit
p
:
Parameters
)
extends
LazyModule
{
...
...
@@ -19,14 +20,18 @@ class DebugIdentityNode()(implicit p: Parameters) extends LazyModule {
lazy
val
module
=
new
LazyModuleImp
(
this
)
with
HasXSLog
with
HasTLDump
{
val
(
out
,
_
)
=
node
.
out
(
0
)
val
(
in
,
_
)
=
node
.
in
(
0
)
when
(
in
.
a
.
fire
()){
XSDebug
(
" "
)
in
.
a
.
bits
.
dump
}
when
(
in
.
d
.
fire
()){
XSDebug
(
" "
)
in
.
d
.
bits
.
dump
def
debug
(
t
:
TLBundle
,
valid
:
Boolean
=
false
)
:
Unit
={
def
fire
[
T
<:
Data
](
x
:
DecoupledIO
[
T
])
=
if
(
valid
)
x
.
valid
else
x
.
fire
()
val
channels
=
Seq
(
t
.
a
,
t
.
b
,
t
.
c
,
t
.
d
,
t
.
e
)
channels
.
foreach
(
c
=>
when
(
fire
(
c
)){
XSDebug
(
" "
)
c
.
bits
.
dump
}
)
}
debug
(
in
,
true
)
}
}
...
...
src/main/scala/utils/TLDump.scala
浏览文件 @
8f653805
...
...
@@ -6,40 +6,30 @@ import xiangshan.HasXSLog
trait
HasTLDump
{
this:
HasXSLog
=>
implicit
class
dumpA
(
a
:
TLBundleA
)
{
def
dump
=
XSDebug
(
false
,
true
.
B
,
a
.
channelName
+
" opcode: %x param: %x size: %x source: %d address: %x mask: %x data: %x corrupt: %b\n"
,
a
.
opcode
,
a
.
param
,
a
.
size
,
a
.
source
,
a
.
address
,
a
.
mask
,
a
.
data
,
a
.
corrupt
)
}
implicit
class
dumpB
(
b
:
TLBundleB
)
{
def
dump
=
XSDebug
(
false
,
true
.
B
,
b
.
channelName
+
" opcode: %x param: %x size: %x source: %d address: %x mask: %x data: %x corrupt: %b\n"
,
b
.
opcode
,
b
.
param
,
b
.
size
,
b
.
source
,
b
.
address
,
b
.
mask
,
b
.
data
,
b
.
corrupt
)
}
implicit
class
dumpC
(
c
:
TLBundleC
)
{
def
dump
=
XSDebug
(
false
,
true
.
B
,
c
.
channelName
+
" opcode: %x param: %x size: %x source: %d address: %x data: %x corrupt: %b\n"
,
c
.
opcode
,
c
.
param
,
c
.
size
,
c
.
source
,
c
.
address
,
c
.
data
,
c
.
corrupt
)
}
implicit
class
dumpD
(
d
:
TLBundleD
)
{
def
dump
=
XSDebug
(
false
,
true
.
B
,
d
.
channelName
+
" opcode: %x param: %x size: %x source: %d sink: %d denied: %b data: %x corrupt: %b\n"
,
d
.
opcode
,
d
.
param
,
d
.
size
,
d
.
source
,
d
.
sink
,
d
.
denied
,
d
.
data
,
d
.
corrupt
)
}
implicit
class
dumpE
(
e
:
TLBundleE
)
{
def
dump
=
XSDebug
(
false
,
true
.
B
,
e
.
channelName
+
" sink: %d\n"
,
e
.
sink
)
implicit
class
TLDump
(
channel
:
TLChannel
)
{
def
dump
=
channel
match
{
case
a
:
TLBundleA
=>
XSDebug
(
false
,
true
.
B
,
a
.
channelName
+
" opcode: %x param: %x size: %x source: %d address: %x mask: %x data: %x corrupt: %b\n"
,
a
.
opcode
,
a
.
param
,
a
.
size
,
a
.
source
,
a
.
address
,
a
.
mask
,
a
.
data
,
a
.
corrupt
)
case
b
:
TLBundleB
=>
XSDebug
(
false
,
true
.
B
,
b
.
channelName
+
" opcode: %x param: %x size: %x source: %d address: %x mask: %x data: %x corrupt: %b\n"
,
b
.
opcode
,
b
.
param
,
b
.
size
,
b
.
source
,
b
.
address
,
b
.
mask
,
b
.
data
,
b
.
corrupt
)
case
c
:
TLBundleC
=>
XSDebug
(
false
,
true
.
B
,
c
.
channelName
+
" opcode: %x param: %x size: %x source: %d address: %x data: %x corrupt: %b\n"
,
c
.
opcode
,
c
.
param
,
c
.
size
,
c
.
source
,
c
.
address
,
c
.
data
,
c
.
corrupt
)
case
d
:
TLBundleD
=>
XSDebug
(
false
,
true
.
B
,
d
.
channelName
+
" opcode: %x param: %x size: %x source: %d sink: %d denied: %b data: %x corrupt: %b\n"
,
d
.
opcode
,
d
.
param
,
d
.
size
,
d
.
source
,
d
.
sink
,
d
.
denied
,
d
.
data
,
d
.
corrupt
)
case
e
:
TLBundleE
=>
XSDebug
(
false
,
true
.
B
,
e
.
channelName
+
" sink: %d\n"
,
e
.
sink
)
}
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录