Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenXiangShan
XiangShan
提交
5386f9e2
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 搜索 >>
提交
5386f9e2
编写于
7月 02, 2020
作者:
L
LinJiawei
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Decode: set DecodeWidth to 6
上级
761bcfa6
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
28 addition
and
17 deletion
+28
-17
src/main/scala/xiangshan/XSCore.scala
src/main/scala/xiangshan/XSCore.scala
+1
-2
src/main/scala/xiangshan/backend/decode/DecodeBuffer.scala
src/main/scala/xiangshan/backend/decode/DecodeBuffer.scala
+27
-15
未找到文件。
src/main/scala/xiangshan/XSCore.scala
浏览文件 @
5386f9e2
...
...
@@ -27,8 +27,7 @@ trait HasXSParameter {
val
HasFPU
=
true
val
FetchWidth
=
8
val
IBufSize
=
64
val
DecodeWidth
=
8
val
DecBufSize
=
8
val
DecodeWidth
=
6
val
RenameWidth
=
6
val
CommitWidth
=
6
val
BrqSize
=
16
...
...
src/main/scala/xiangshan/backend/decode/DecodeBuffer.scala
浏览文件 @
5386f9e2
...
...
@@ -12,20 +12,32 @@ class DecodeBuffer extends XSModule {
val
out
=
Vec
(
RenameWidth
,
DecoupledIO
(
new
CfCtrl
))
})
val
q
=
Module
(
new
MIMOQueue
[
CfCtrl
](
gen
=
new
CfCtrl
,
entries
=
DecBufSize
,
inCnt
=
io
.
in
.
size
,
outCnt
=
io
.
out
.
size
,
mem
=
true
,
perf
=
false
))
q
.
io
.
flush
:=
io
.
redirect
.
valid
q
.
io
.
enq
<>
io
.
in
for
((
out
,
deq
)
<-
io
.
out
.
zip
(
q
.
io
.
deq
)){
out
.
bits
:=
deq
.
bits
out
.
valid
:=
deq
.
valid
&&
!
io
.
redirect
.
valid
deq
.
ready
:=
out
.
ready
require
(
DecodeWidth
==
RenameWidth
)
val
validVec
=
RegInit
(
VecInit
(
Seq
.
fill
(
DecodeWidth
)(
false
.
B
)))
val
leftCanIn
=
ParallelAND
(
validVec
.
zip
(
io
.
out
.
map
(
_
.
fire
())).
map
({
case
(
v
,
fire
)
=>
!
v
||
fire
})
).
asBool
()
val
rightRdyVec
=
io
.
out
.
map
(
_
.
ready
&&
leftCanIn
)
for
(
i
<-
0
until
RenameWidth
){
when
(
io
.
out
(
i
).
fire
()){
validVec
(
i
)
:=
false
.
B
}
when
(
io
.
in
(
i
).
fire
()){
validVec
(
i
)
:=
true
.
B
}
when
(
io
.
redirect
.
valid
){
validVec
(
i
)
:=
false
.
B
}
io
.
in
(
i
).
ready
:=
rightRdyVec
(
i
)
io
.
out
(
i
).
bits
<>
RegEnable
(
io
.
in
(
i
).
bits
,
io
.
in
(
i
).
fire
())
io
.
out
(
i
).
valid
:=
validVec
(
i
)
&&
!
io
.
redirect
.
valid
}
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录