Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenXiangShan
XiangShan
提交
6567ff05
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 搜索 >>
提交
6567ff05
编写于
1月 31, 2021
作者:
Y
Yinan Xu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
load,store: don't mark the instruction as mmio if it has exceptions
上级
40ae100f
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
11 addition
and
10 deletion
+11
-10
src/main/scala/xiangshan/mem/lsqueue/LoadQueue.scala
src/main/scala/xiangshan/mem/lsqueue/LoadQueue.scala
+4
-4
src/main/scala/xiangshan/mem/pipeline/LoadUnit.scala
src/main/scala/xiangshan/mem/pipeline/LoadUnit.scala
+2
-2
src/main/scala/xiangshan/mem/pipeline/StoreUnit.scala
src/main/scala/xiangshan/mem/pipeline/StoreUnit.scala
+5
-4
未找到文件。
src/main/scala/xiangshan/mem/lsqueue/LoadQueue.scala
浏览文件 @
6567ff05
...
...
@@ -237,7 +237,7 @@ class LoadQueue extends XSModule
})).
asUInt
()
// use uint instead vec to reduce verilog lines
val
evenDeqMask
=
getEvenBits
(
deqMask
)
val
oddDeqMask
=
getOddBits
(
deqMask
)
// generate lastCycleSelect mask
// generate lastCycleSelect mask
val
evenSelectMask
=
Mux
(
io
.
ldout
(
0
).
fire
(),
getEvenBits
(
UIntToOH
(
loadWbSel
(
0
))),
0.
U
)
val
oddSelectMask
=
Mux
(
io
.
ldout
(
1
).
fire
(),
getOddBits
(
UIntToOH
(
loadWbSel
(
1
))),
0.
U
)
// generate real select vec
...
...
@@ -254,7 +254,7 @@ class LoadQueue extends XSModule
loadWbSelVGen
(
0
):=
loadEvenSelVec
.
asUInt
.
orR
loadWbSelGen
(
1
)
:=
Cat
(
getFirstOne
(
toVec
(
loadOddSelVec
),
oddDeqMask
),
1.
U
(
1.
W
))
loadWbSelVGen
(
1
)
:=
loadOddSelVec
.
asUInt
.
orR
(
0
until
LoadPipelineWidth
).
map
(
i
=>
{
loadWbSel
(
i
)
:=
RegNext
(
loadWbSelGen
(
i
))
loadWbSelV
(
i
)
:=
RegNext
(
loadWbSelVGen
(
i
),
init
=
false
.
B
)
...
...
@@ -462,7 +462,7 @@ class LoadQueue extends XSModule
val
lastCycleRedirect
=
RegNext
(
io
.
brqRedirect
)
val
lastCycleFlush
=
RegNext
(
io
.
flush
)
// S2: select rollback and generate rollback request
// S2: select rollback and generate rollback request
// Note that we use roqIdx - 1.U to flush the load instruction itself.
// Thus, here if last cycle's roqIdx equals to this cycle's roqIdx, it still triggers the redirect.
val
rollbackGen
=
Wire
(
Valid
(
new
Redirect
))
...
...
@@ -483,7 +483,7 @@ class LoadQueue extends XSModule
// S3: fire rollback request
io
.
rollback
:=
rollbackReg
io
.
rollback
.
valid
:=
rollbackReg
.
valid
&&
io
.
rollback
.
valid
:=
rollbackReg
.
valid
&&
(!
lastCycleRedirect
.
valid
||
!
isAfter
(
rollbackReg
.
bits
.
roqIdx
,
lastCycleRedirect
.
bits
.
roqIdx
))
&&
!
lastCycleFlush
...
...
src/main/scala/xiangshan/mem/pipeline/LoadUnit.scala
浏览文件 @
6567ff05
...
...
@@ -30,7 +30,7 @@ class LoadUnit_S0 extends XSModule {
val
s0_vaddr_old
=
io
.
in
.
bits
.
src1
+
SignExt
(
ImmUnion
.
I
.
toImm32
(
s0_uop
.
ctrl
.
imm
),
XLEN
)
val
imm12
=
WireInit
(
s0_uop
.
ctrl
.
imm
(
11
,
0
))
val
s0_vaddr_lo
=
io
.
in
.
bits
.
src1
(
11
,
0
)
+
Cat
(
0.
U
(
1.
W
),
imm12
)
val
s0_vaddr_hi
=
Mux
(
imm12
(
11
),
val
s0_vaddr_hi
=
Mux
(
imm12
(
11
),
Mux
((
s0_vaddr_lo
(
12
)),
io
.
in
.
bits
.
src1
(
VAddrBits
-
1
,
12
),
io
.
in
.
bits
.
src1
(
VAddrBits
-
1
,
12
)+
SignExt
(
1.
U
,
VAddrBits
-
12
)),
Mux
((
s0_vaddr_lo
(
12
)),
io
.
in
.
bits
.
src1
(
VAddrBits
-
1
,
12
)+
1.
U
,
io
.
in
.
bits
.
src1
(
VAddrBits
-
1
,
12
))
)
...
...
@@ -152,8 +152,8 @@ class LoadUnit_S2 extends XSModule with HasLoadHelper {
val
s2_mask
=
io
.
in
.
bits
.
mask
val
s2_paddr
=
io
.
in
.
bits
.
paddr
val
s2_tlb_miss
=
io
.
in
.
bits
.
tlbMiss
val
s2_mmio
=
io
.
in
.
bits
.
mmio
val
s2_exception
=
selectLoad
(
io
.
in
.
bits
.
uop
.
cf
.
exceptionVec
,
false
).
asUInt
.
orR
val
s2_mmio
=
io
.
in
.
bits
.
mmio
&&
!
s2_exception
val
s2_cache_miss
=
io
.
dcacheResp
.
bits
.
miss
val
s2_cache_replay
=
io
.
dcacheResp
.
bits
.
replay
...
...
src/main/scala/xiangshan/mem/pipeline/StoreUnit.scala
浏览文件 @
6567ff05
...
...
@@ -20,7 +20,7 @@ class StoreUnit_S0 extends XSModule {
val
saddr_old
=
io
.
in
.
bits
.
src1
+
SignExt
(
ImmUnion
.
S
.
toImm32
(
io
.
in
.
bits
.
uop
.
ctrl
.
imm
),
XLEN
)
val
imm12
=
WireInit
(
io
.
in
.
bits
.
uop
.
ctrl
.
imm
(
11
,
0
))
val
saddr_lo
=
io
.
in
.
bits
.
src1
(
11
,
0
)
+
Cat
(
0.
U
(
1.
W
),
imm12
)
val
saddr_hi
=
Mux
(
imm12
(
11
),
val
saddr_hi
=
Mux
(
imm12
(
11
),
Mux
((
saddr_lo
(
12
)),
io
.
in
.
bits
.
src1
(
VAddrBits
-
1
,
12
),
io
.
in
.
bits
.
src1
(
VAddrBits
-
1
,
12
)+
SignExt
(
1.
U
,
VAddrBits
-
12
)),
Mux
((
saddr_lo
(
12
)),
io
.
in
.
bits
.
src1
(
VAddrBits
-
1
,
12
)+
1.
U
,
io
.
in
.
bits
.
src1
(
VAddrBits
-
1
,
12
))
)
...
...
@@ -73,6 +73,8 @@ class StoreUnit_S1 extends XSModule {
val
s1_paddr
=
io
.
dtlbResp
.
bits
.
paddr
val
s1_tlb_miss
=
io
.
dtlbResp
.
bits
.
miss
val
s1_mmio
=
io
.
dtlbResp
.
bits
.
mmio
val
s1_exception
=
selectStore
(
io
.
out
.
bits
.
uop
.
cf
.
exceptionVec
,
false
).
asUInt
.
orR
io
.
in
.
ready
:=
true
.
B
...
...
@@ -95,13 +97,12 @@ class StoreUnit_S1 extends XSModule {
io
.
lsq
.
bits
:=
io
.
in
.
bits
io
.
lsq
.
bits
.
paddr
:=
s1_paddr
io
.
lsq
.
bits
.
miss
:=
false
.
B
io
.
lsq
.
bits
.
mmio
:=
io
.
dtlbResp
.
bits
.
mmio
io
.
lsq
.
bits
.
mmio
:=
s1_mmio
&&
!
s1_exception
io
.
lsq
.
bits
.
uop
.
cf
.
exceptionVec
(
storePageFault
)
:=
io
.
dtlbResp
.
bits
.
excp
.
pf
.
st
io
.
lsq
.
bits
.
uop
.
cf
.
exceptionVec
(
storeAccessFault
)
:=
io
.
dtlbResp
.
bits
.
excp
.
af
.
st
// mmio inst with exception will be writebacked immediately
val
hasException
=
selectStore
(
io
.
out
.
bits
.
uop
.
cf
.
exceptionVec
,
false
).
asUInt
.
orR
io
.
out
.
valid
:=
io
.
in
.
valid
&&
(!
io
.
out
.
bits
.
mmio
||
hasException
)
&&
!
s1_tlb_miss
io
.
out
.
valid
:=
io
.
in
.
valid
&&
(!
io
.
out
.
bits
.
mmio
||
s1_exception
)
&&
!
s1_tlb_miss
io
.
out
.
bits
:=
io
.
lsq
.
bits
// encode data for fp store
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录