Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenXiangShan
XiangShan
提交
0655b1a0
X
XiangShan
项目概览
OpenXiangShan
/
XiangShan
10 个月 前同步成功
通知
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,体验更适合开发者的 AI 搜索 >>
提交
0655b1a0
编写于
6月 07, 2023
作者:
X
Xuan Hu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
backend: update print info
上级
d387a573
变更
3
显示空白变更内容
内联
并排
Showing
3 changed file
with
35 addition
and
4 deletion
+35
-4
src/main/scala/xiangshan/backend/Backend.scala
src/main/scala/xiangshan/backend/Backend.scala
+6
-4
src/main/scala/xiangshan/backend/datapath/WbConfig.scala
src/main/scala/xiangshan/backend/datapath/WbConfig.scala
+11
-0
src/main/scala/xiangshan/package.scala
src/main/scala/xiangshan/package.scala
+18
-0
未找到文件。
src/main/scala/xiangshan/backend/Backend.scala
浏览文件 @
0655b1a0
...
...
@@ -21,11 +21,16 @@ import xiangshan.mem.{LqPtr, LsqEnqIO, SqPtr}
class
Backend
(
val
params
:
BackendParams
)(
implicit
p
:
Parameters
)
extends
LazyModule
with
HasXSParameter
{
println
(
"[Backend] ExuConfigs:"
)
for
(
exuCfg
<-
params
.
allExuParams
)
{
val
fuConfigs
=
exuCfg
.
fuConfigs
val
wbPortConfigs
=
exuCfg
.
wbPortConfigs
val
immType
=
exuCfg
.
immType
println
(
s
"exu: ${fuConfigs.map(_.name)}, wb: ${wbPortConfigs}, imm: ${immType}"
)
println
(
"[Backend] "
+
s
"${exuCfg.name}: "
+
s
"${ fuConfigs.map(_.name).mkString("
fu
(
s
)
:
{
"
,
"
,
", "
}
") }, "
+
s
"${ wbPortConfigs.mkString("
wb
:
{
"
,
"
,
", "
}
") }, "
+
s
"${ immType.map(SelImm.mkString(_)).mkString("
imm
:
{
"
,
"
,
" , "
}
") }"
)
require
(
wbPortConfigs
.
collectFirst
{
case
x
:
IntWB
=>
x
}.
nonEmpty
==
fuConfigs
.
map
(
_
.
writeIntRf
).
reduce
(
_
||
_
),
"int wb port has no priority"
)
...
...
@@ -34,9 +39,6 @@ class Backend(val params: BackendParams)(implicit p: Parameters) extends LazyMod
"vec wb port has no priority"
)
}
println
(
s
"Function Unit: Alu(${params.AluCnt}), Brh(${params.BrhCnt}), Jmp(${params.JmpCnt}), "
+
s
"Ldu(${params.LduCnt}), Sta(${params.StaCnt}), Std(${params.StdCnt})"
)
for
(
cfg
<-
FuConfig
.
allConfigs
)
{
println
(
s
"[Backend] $cfg"
)
}
...
...
src/main/scala/xiangshan/backend/datapath/WbConfig.scala
浏览文件 @
0655b1a0
...
...
@@ -15,6 +15,17 @@ object WbConfig {
def
writeInt
=
dataCfg
==
IntData
()
def
writeFp
=
dataCfg
==
FpData
()
def
writeVec
=
dataCfg
==
VecData
()
override
def
toString
:
String
=
{
var
res
=
dataCfg
match
{
case
IntData
()
=>
"I"
case
FpData
()
=>
"F"
case
VecData
()
=>
"V"
case
_
=>
"?"
}
res
+=
s
"($port)"
res
}
}
sealed
abstract
class
ExuWB
extends
WbConfig
...
...
src/main/scala/xiangshan/package.scala
浏览文件 @
0655b1a0
...
...
@@ -566,6 +566,24 @@ package object xiangshan {
def
X
=
BitPat
(
"b0000"
)
def
apply
()
=
UInt
(
4.
W
)
def
mkString
(
immType
:
UInt
)
:
String
=
{
val
strMap
=
Map
(
IMM_S
.
litValue
->
"S"
,
IMM_SB
.
litValue
->
"SB"
,
IMM_U
.
litValue
->
"U"
,
IMM_UJ
.
litValue
->
"UJ"
,
IMM_I
.
litValue
->
"I"
,
IMM_Z
.
litValue
->
"Z"
,
IMM_B6
.
litValue
->
"B6"
,
IMM_OPIVIS
.
litValue
->
"VIS"
,
IMM_OPIVIU
.
litValue
->
"VIU"
,
IMM_VSETVLI
.
litValue
->
"VSETVLI"
,
IMM_VSETIVLI
.
litValue
->
"VSETIVLI"
,
INVALID_INSTR
.
litValue
->
"INVALID"
,
)
strMap
(
immType
.
litValue
)
}
}
object
UopSplitType
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录