Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenXiangShan
XiangShan
提交
307f6068
X
XiangShan
项目概览
OpenXiangShan
/
XiangShan
9 个月 前同步成功
通知
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 搜索 >>
提交
307f6068
编写于
6月 22, 2020
作者:
W
William Wang
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Roq: setup Roq framework
上级
d43dd6a5
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
49 addition
and
1 deletion
+49
-1
src/main/scala/xiangshan/XSCore.scala
src/main/scala/xiangshan/XSCore.scala
+1
-0
src/main/scala/xiangshan/backend/roq/Roq.scala
src/main/scala/xiangshan/backend/roq/Roq.scala
+48
-1
未找到文件。
src/main/scala/xiangshan/XSCore.scala
浏览文件 @
307f6068
...
...
@@ -37,6 +37,7 @@ trait HasXSParameter {
val
NRWritePorts
=
8
val
RoqSize
=
128
val
RoqIdxWidth
=
log2Up
(
RoqSize
)
val
ExtendedRoqIdxWidth
=
RoqIdxWidth
+
1
val
IntDqDeqWidth
=
4
val
FpDqDeqWidth
=
4
val
LsDqDeqWidth
=
4
...
...
src/main/scala/xiangshan/backend/roq/Roq.scala
浏览文件 @
307f6068
...
...
@@ -9,9 +9,56 @@ class Roq extends XSModule with NeedImpl {
val
io
=
IO
(
new
Bundle
()
{
val
brqRedirect
=
Input
(
Valid
(
new
Redirect
))
val
dp1Req
=
Vec
(
RenameWidth
,
Flipped
(
DecoupledIO
(
new
MicroOp
)))
val
roqIdxs
=
Output
(
Vec
(
RenameWidth
,
UInt
(
RoqIdxWidth
.
W
)))
val
roqIdxs
=
Output
(
Vec
(
RenameWidth
,
UInt
(
Extended
RoqIdxWidth
.
W
)))
val
redirect
=
Output
(
Valid
(
new
Redirect
))
val
exeWbResults
=
Vec
(
exuConfig
.
ExuCnt
,
Flipped
(
DecoupledIO
(
new
ExuOutput
)))
val
commits
=
Vec
(
CommitWidth
,
Valid
(
new
RoqCommit
))
})
val
microOp
=
Reg
(
Vec
(
RoqSize
,
new
MicroOp
))
// val brMask = Reg(Vec(RoqSize, UInt(BrqSize.W)))
val
valid
=
RegInit
(
VecInit
(
List
.
fill
(
RoqSize
)
false
.
B
))
val
writebacked
=
Reg
(
Vec
(
RoqSize
,
Bool
()))
val
redirect
=
Reg
(
Vec
(
RoqSize
,
new
Redirect
))
val
isMMIO
=
Reg
(
Vec
(
RoqSize
,
Bool
()))
//for debug
val
intrNO
=
Reg
(
Vec
(
RoqSize
,
UInt
(
XLEN
.
W
)))
//for debug
val
ringBufferHeadExtended
=
RegInit
(
0.
U
(
ExtendedRoqIdxWidth
.
W
))
val
ringBufferTailExtended
=
RegInit
(
0.
U
(
ExtendedRoqIdxWidth
.
W
))
val
ringBufferHead
=
ringBufferHead
(
RoqIdxWidth
-
1
,
0
)
val
ringBufferTail
=
ringBufferTail
(
RoqIdxWidth
-
1
,
0
)
val
ringBufferEmpty
=
ringBufferHead
===
ringBufferTail
&&
ringBufferHead
(
RoqIdxWidth
)===
ringBufferTail
(
RoqIdxWidth
)
val
ringBufferEmpty
=
ringBufferHead
===
ringBufferTail
&&
ringBufferHead
(
RoqIdxWidth
)=/=
ringBufferTail
(
RoqIdxWidth
)
val
ringBufferAllowin
=
!
ringBufferFull
// Dispatch
for
(
i
<-
0
until
RenameWidth
){
when
(
dp1Req
(
i
).
fire
()){
microOp
(
ringBufferHead
+
i
)
:=
io
.
dp1Req
(
i
).
bits
valid
(
ringBufferHead
+
i
)
:=
true
.
B
}
io
.
dp1Req
(
i
).
ready
:=
ringBufferAllowin
&&
!
vaild
(
ringBufferHead
+
i
)
io
.
roqIdxs
(
i
)
:=
ringBufferHeadExtended
+
i
}
// Writeback
for
(
i
<-
0
until
exuConfig
.
ExuCnt
){
when
(
exeWbResults
(
i
).
fire
()){
writebacked
(
io
.
exeWbResults
(
i
).
bits
.
uop
.
roqIdx
)
:=
true
.
B
}
}
// Commit
// TODO
// for(i <- 0 until CommitWidth){
// io.commits.valid := valid(ringBufferTail+i) && writebacked(ringBufferTail+i)
// io.commits.bits.uop := microOp(ringBufferTail+i)
// io.commits.bits.isWalk := DontCare //TODO
// }
// io.redirect := DontCare //TODO
// io.redirect.valid := false.B //TODO
// Flush
// TODO
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录