Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenXiangShan
XiangShan
提交
b599c57a
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,发现更多精彩内容 >>
未验证
提交
b599c57a
编写于
12月 22, 2020
作者:
Y
Yinan Xu
提交者:
GitHub
12月 22, 2020
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #338 from RISCVERS/fix-brq-enq
brq, lsq: fix enqueue logic
上级
e332af4e
03f2cece
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
10 addition
and
5 deletion
+10
-5
src/main/scala/xiangshan/backend/brq/Brq.scala
src/main/scala/xiangshan/backend/brq/Brq.scala
+2
-1
src/main/scala/xiangshan/mem/lsqueue/LSQWrapper.scala
src/main/scala/xiangshan/mem/lsqueue/LSQWrapper.scala
+2
-0
src/main/scala/xiangshan/mem/lsqueue/LoadQueue.scala
src/main/scala/xiangshan/mem/lsqueue/LoadQueue.scala
+3
-2
src/main/scala/xiangshan/mem/lsqueue/StoreQueue.scala
src/main/scala/xiangshan/mem/lsqueue/StoreQueue.scala
+3
-2
未找到文件。
src/main/scala/xiangshan/backend/brq/Brq.scala
浏览文件 @
b599c57a
...
...
@@ -141,12 +141,13 @@ class Brq extends XSModule with HasCircularQueuePtrHelper {
)
// branch insts enq
val
lastCycleRedirect
=
RegNext
(
io
.
memRedirect
.
valid
||
io
.
roqRedirect
.
valid
)
val
validEntries
=
distanceBetween
(
tailPtr
,
headPtr
)
for
(
i
<-
0
until
DecodeWidth
){
val
offset
=
if
(
i
==
0
)
0.
U
else
PopCount
(
io
.
enqReqs
.
take
(
i
).
map
(
_
.
valid
))
val
brTag
=
tailPtr
+
offset
val
idx
=
brTag
.
value
io
.
enqReqs
(
i
).
ready
:=
validEntries
<=
(
BrqSize
-
(
i
+
1
)).
U
io
.
enqReqs
(
i
).
ready
:=
validEntries
<=
(
BrqSize
-
(
i
+
1
)).
U
&&
!
lastCycleRedirect
io
.
brTags
(
i
)
:=
brTag
when
(
io
.
enqReqs
(
i
).
fire
())
{
brQueue
(
idx
).
ptrFlag
:=
brTag
.
flag
...
...
src/main/scala/xiangshan/mem/lsqueue/LSQWrapper.scala
浏览文件 @
b599c57a
...
...
@@ -262,6 +262,8 @@ class LsqWrappper extends XSModule with HasDCacheParameters {
// LSQ: send out canAccept when both load queue and store queue are ready
// Dispatch: send instructions to LSQ only when they are ready
io
.
enq
.
canAccept
:=
loadQueue
.
io
.
enq
.
canAccept
&&
storeQueue
.
io
.
enq
.
canAccept
loadQueue
.
io
.
enq
.
sqCanAccept
:=
storeQueue
.
io
.
enq
.
canAccept
storeQueue
.
io
.
enq
.
lqCanAccept
:=
loadQueue
.
io
.
enq
.
canAccept
for
(
i
<-
0
until
RenameWidth
)
{
val
isStore
=
CommitType
.
lsInstIsStore
(
io
.
enq
.
req
(
i
).
bits
.
ctrl
.
commitType
)
...
...
src/main/scala/xiangshan/mem/lsqueue/LoadQueue.scala
浏览文件 @
b599c57a
...
...
@@ -25,6 +25,7 @@ object LqPtr extends HasXSParameter {
class
LqEnqIO
extends
XSBundle
{
val
canAccept
=
Output
(
Bool
())
val
sqCanAccept
=
Input
(
Bool
())
val
needAlloc
=
Vec
(
RenameWidth
,
Input
(
Bool
()))
val
req
=
Vec
(
RenameWidth
,
Flipped
(
ValidIO
(
new
MicroOp
)))
val
resp
=
Vec
(
RenameWidth
,
Output
(
new
LqPtr
))
...
...
@@ -87,7 +88,7 @@ class LoadQueue extends XSModule with HasDCacheParameters with HasCircularQueueP
val
offset
=
if
(
i
==
0
)
0.
U
else
PopCount
(
io
.
enq
.
needAlloc
.
take
(
i
))
val
lqIdx
=
enqPtrExt
(
offset
)
val
index
=
lqIdx
.
value
when
(
io
.
enq
.
req
(
i
).
valid
&&
io
.
enq
.
canAccept
&&
!
io
.
brqRedirect
.
valid
)
{
when
(
io
.
enq
.
req
(
i
).
valid
&&
io
.
enq
.
canAccept
&&
io
.
enq
.
sqCanAccept
&&
!
io
.
brqRedirect
.
valid
)
{
uop
(
index
)
:=
io
.
enq
.
req
(
i
).
bits
allocated
(
index
)
:=
true
.
B
datavalid
(
index
)
:=
false
.
B
...
...
@@ -101,7 +102,7 @@ class LoadQueue extends XSModule with HasDCacheParameters with HasCircularQueueP
}
// when io.brqRedirect.valid, we don't allow eneuque even though it may fire.
when
(
Cat
(
firedDispatch
).
orR
&&
io
.
enq
.
canAccept
&&
!
io
.
brqRedirect
.
valid
)
{
when
(
Cat
(
firedDispatch
).
orR
&&
io
.
enq
.
canAccept
&&
io
.
enq
.
sqCanAccept
&&
!
io
.
brqRedirect
.
valid
)
{
val
enqNumber
=
PopCount
(
firedDispatch
)
enqPtrExt
:=
VecInit
(
enqPtrExt
.
map
(
_
+
enqNumber
))
XSInfo
(
"dispatched %d insts to lq\n"
,
enqNumber
)
...
...
src/main/scala/xiangshan/mem/lsqueue/StoreQueue.scala
浏览文件 @
b599c57a
...
...
@@ -23,6 +23,7 @@ object SqPtr extends HasXSParameter {
class
SqEnqIO
extends
XSBundle
{
val
canAccept
=
Output
(
Bool
())
val
lqCanAccept
=
Input
(
Bool
())
val
needAlloc
=
Vec
(
RenameWidth
,
Input
(
Bool
()))
val
req
=
Vec
(
RenameWidth
,
Flipped
(
ValidIO
(
new
MicroOp
)))
val
resp
=
Vec
(
RenameWidth
,
Output
(
new
SqPtr
))
...
...
@@ -76,7 +77,7 @@ class StoreQueue extends XSModule with HasDCacheParameters with HasCircularQueue
val
offset
=
if
(
i
==
0
)
0.
U
else
PopCount
(
io
.
enq
.
needAlloc
.
take
(
i
))
val
sqIdx
=
enqPtrExt
(
offset
)
val
index
=
sqIdx
.
value
when
(
io
.
enq
.
req
(
i
).
valid
&&
io
.
enq
.
canAccept
&&
!
io
.
brqRedirect
.
valid
)
{
when
(
io
.
enq
.
req
(
i
).
valid
&&
io
.
enq
.
canAccept
&&
io
.
enq
.
lqCanAccept
&&
!
io
.
brqRedirect
.
valid
)
{
uop
(
index
)
:=
io
.
enq
.
req
(
i
).
bits
allocated
(
index
)
:=
true
.
B
datavalid
(
index
)
:=
false
.
B
...
...
@@ -87,7 +88,7 @@ class StoreQueue extends XSModule with HasDCacheParameters with HasCircularQueue
io
.
enq
.
resp
(
i
)
:=
sqIdx
}
when
(
Cat
(
firedDispatch
).
orR
&&
io
.
enq
.
canAccept
&&
!
io
.
brqRedirect
.
valid
)
{
when
(
Cat
(
firedDispatch
).
orR
&&
io
.
enq
.
canAccept
&&
io
.
enq
.
lqCanAccept
&&
!
io
.
brqRedirect
.
valid
)
{
val
enqNumber
=
PopCount
(
firedDispatch
)
enqPtrExt
:=
VecInit
(
enqPtrExt
.
map
(
_
+
enqNumber
))
XSInfo
(
"dispatched %d insts to sq\n"
,
enqNumber
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录