Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenXiangShan
XiangShan
提交
b5442aab
X
XiangShan
项目概览
OpenXiangShan
/
XiangShan
12 个月 前同步成功
通知
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,发现更多精彩内容 >>
未验证
提交
b5442aab
编写于
11月 23, 2020
作者:
L
ljw
提交者:
GitHub
11月 23, 2020
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #263 from RISCVERS/opt-brq-timing
brq: opt timing
上级
82ea4ddc
f4b5cb3d
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
21 addition
and
23 deletion
+21
-23
src/main/scala/xiangshan/backend/brq/Brq.scala
src/main/scala/xiangshan/backend/brq/Brq.scala
+21
-23
未找到文件。
src/main/scala/xiangshan/backend/brq/Brq.scala
浏览文件 @
b5442aab
...
...
@@ -67,25 +67,22 @@ class Brq extends XSModule with HasCircularQueuePtrHelper {
val
exuOut
=
new
ExuOutput
}
val
s_idle
::
s_wb
::
s_commited
::
Nil
=
List
.
tabulate
(
3
)(
i
=>
(
1
<<
i
).
U
(
3
.
W
).
asTypeOf
(
new
StateQueueEntry
))
val
s_i
nvalid
::
s_i
dle
::
s_wb
::
s_commited
::
Nil
=
List
.
tabulate
(
4
)(
i
=>
(
1
<<
i
).
U
(
4
.
W
).
asTypeOf
(
new
StateQueueEntry
))
class
StateQueueEntry
extends
Bundle
{
val
isCommit
=
Bool
()
val
isWb
=
Bool
()
val
isIdle
=
Bool
()
val
isInvalid
=
Bool
()
}
val
brCommitCnt
=
RegInit
(
0.
U
(
BrTagWidth
.
W
))
val
brQueue
=
Mem
(
BrqSize
,
new
BrqEntry
)
//Reg(Vec(BrqSize, new BrqEntry))
val
stateQueue
=
RegInit
(
VecInit
(
Seq
.
fill
(
BrqSize
)(
s_i
dle
)))
val
stateQueue
=
RegInit
(
VecInit
(
Seq
.
fill
(
BrqSize
)(
s_i
nvalid
)))
val
headPtr
,
tailPtr
=
RegInit
(
BrqPtr
(
false
.
B
,
0.
U
))
// def isEmpty(ptr1: BrqPtr, ptr2: BrqPtr): Bool = ptr1 === ptr2
// def isFull(ptr1: BrqPtr, ptr2: BrqPtr): Bool = (ptr1.flag=/=ptr2.flag) && (ptr1.value===ptr2.value)
// dequeue
val
headIdx
=
headPtr
.
value
...
...
@@ -147,7 +144,8 @@ class Brq extends XSModule with HasCircularQueuePtrHelper {
XSDebug
(
p
"headPtr:$headPtr tailPtr:$tailPtr\n"
)
XSDebug
(
""
)
stateQueue
.
reverse
.
map
(
s
=>{
XSDebug
(
false
,
s
.
isIdle
,
"-"
)
XSDebug
(
false
,
s
.
isInvalid
,
"-"
)
XSDebug
(
false
,
s
.
isIdle
,
"i"
)
XSDebug
(
false
,
s
.
isWb
,
"w"
)
XSDebug
(
false
,
s
.
isCommit
,
"c"
)
})
...
...
@@ -159,7 +157,7 @@ class Brq extends XSModule with HasCircularQueuePtrHelper {
stateQueue
(
commitIdx
)
:=
s_commited
}
when
(
deqValid
){
stateQueue
(
headIdx
)
:=
s_i
dle
stateQueue
(
headIdx
)
:=
s_i
nvalid
}
assert
(!(
commitIdx
===
headIdx
&&
commitValid
&&
deqValid
),
"Error: deq and commit a same entry!"
)
...
...
@@ -184,20 +182,20 @@ class Brq extends XSModule with HasCircularQueuePtrHelper {
)
// branch insts enq
var
full
=
WireInit
(
isFull
(
headPtrNext
,
tailPtr
))
var
tailPtrNext
=
WireInit
(
tailPtr
)
for
((
enq
,
brTag
)
<-
io
.
enqReqs
.
zip
(
io
.
brTags
)){
enq
.
ready
:=
!
full
brTag
:=
tailPtrNext
when
(
enq
.
fire
()){
brQueue
(
tailPtrNext
.
value
).
npc
:=
enq
.
bits
.
cf
.
brUpdate
.
pnpc
brQueue
(
tailPtrNext
.
value
).
ptrFlag
:=
tailPtrNext
.
flag
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
:=
stateQueue
(
idx
).
isInvalid
io
.
brTags
(
i
)
:=
brTag
when
(
io
.
enqReqs
(
i
).
fire
()){
brQueue
(
idx
).
npc
:=
io
.
enqReqs
(
i
).
bits
.
cf
.
brUpdate
.
pnpc
brQueue
(
idx
).
ptrFlag
:=
brTag
.
flag
stateQueue
(
idx
)
:=
s_idle
}
tailPtrNext
=
tailPtrNext
+
enq
.
fire
()
full
=
isFull
(
tailPtrNext
,
headPtrNext
)
}
tailPtr
:=
tailPtrNext
val
enqCnt
=
PopCount
(
io
.
enqReqs
.
map
(
_
.
fire
()))
tailPtr
:=
tailPtr
+
enqCnt
// exu write back
for
(
exuWb
<-
io
.
exuRedirect
){
...
...
@@ -218,7 +216,7 @@ class Brq extends XSModule with HasCircularQueuePtrHelper {
when
(
io
.
roqRedirect
.
valid
){
// exception
stateQueue
.
foreach
(
_
:=
s_i
dle
)
stateQueue
.
foreach
(
_
:=
s_i
nvalid
)
headPtr
:=
BrqPtr
(
false
.
B
,
0.
U
)
tailPtr
:=
BrqPtr
(
false
.
B
,
0.
U
)
brCommitCnt
:=
0.
U
...
...
@@ -230,7 +228,7 @@ class Brq extends XSModule with HasCircularQueuePtrHelper {
(
io
.
redirect
.
valid
&&
ptr
.
needBrFlush
(
io
.
redirect
.
bits
.
brTag
))
||
(
s
.
isWb
&&
brQueue
(
i
).
exuOut
.
uop
.
roqIdx
.
needFlush
(
io
.
memRedirect
))
){
s
:=
s_i
dle
s
:=
s_i
nvalid
}
})
when
(
io
.
redirect
.
valid
){
// Only Br Mispred reset tailPtr, replay does not
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录