Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenXiangShan
XiangShan
提交
7eaf1071
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,发现更多精彩内容 >>
提交
7eaf1071
编写于
11月 06, 2020
作者:
Y
Yinan Xu
浏览文件
操作
浏览文件
下载
差异文件
Merge remote-tracking branch 'origin/fix-dispatch-replay' into xs-fpu
上级
a4b1d0d7
f48ee482
变更
6
隐藏空白更改
内联
并排
Showing
6 changed file
with
18 addition
and
4 deletion
+18
-4
src/main/scala/xiangshan/Bundle.scala
src/main/scala/xiangshan/Bundle.scala
+1
-0
src/main/scala/xiangshan/backend/Backend.scala
src/main/scala/xiangshan/backend/Backend.scala
+2
-1
src/main/scala/xiangshan/backend/dispatch/DispatchQueue.scala
...main/scala/xiangshan/backend/dispatch/DispatchQueue.scala
+10
-1
src/main/scala/xiangshan/backend/exu/JmpExeUnit.scala
src/main/scala/xiangshan/backend/exu/JmpExeUnit.scala
+1
-0
src/main/scala/xiangshan/backend/fu/CSR.scala
src/main/scala/xiangshan/backend/fu/CSR.scala
+2
-1
src/main/scala/xiangshan/backend/roq/Roq.scala
src/main/scala/xiangshan/backend/roq/Roq.scala
+2
-1
未找到文件。
src/main/scala/xiangshan/Bundle.scala
浏览文件 @
7eaf1071
...
...
@@ -218,6 +218,7 @@ class ExternalInterruptIO extends XSBundle {
class
CSRSpecialIO
extends
XSBundle
{
val
exception
=
Flipped
(
ValidIO
(
new
MicroOp
))
val
isInterrupt
=
Input
(
Bool
())
val
memExceptionVAddr
=
Input
(
UInt
(
VAddrBits
.
W
))
val
trapTarget
=
Output
(
UInt
(
VAddrBits
.
W
))
val
externalInterrupt
=
new
ExternalInterruptIO
...
...
src/main/scala/xiangshan/backend/Backend.scala
浏览文件 @
7eaf1071
...
...
@@ -148,11 +148,12 @@ class Backend extends XSModule
jmpExeUnit
.
io
.
csrOnly
.
exception
.
bits
:=
roq
.
io
.
exception
jmpExeUnit
.
fflags
:=
roq
.
io
.
fflags
jmpExeUnit
.
dirty_fs
:=
roq
.
io
.
dirty_fs
jmpExeUnit
.
io
.
csrOnly
.
externalInterrupt
:=
io
.
externalInterrupt
jmpExeUnit
.
io
.
csrOnly
.
memExceptionVAddr
:=
io
.
mem
.
exceptionAddr
.
vaddr
jmpExeUnit
.
fenceToSbuffer
<>
io
.
mem
.
fenceToSbuffer
io
.
mem
.
sfence
<>
jmpExeUnit
.
sfence
io
.
mem
.
csr
<>
jmpExeUnit
.
tlbCsrIO
io
.
mem
.
exceptionAddr
.
lsIdx
.
lsroqIdx
:=
roq
.
io
.
exception
.
lsroqIdx
io
.
mem
.
exceptionAddr
.
lsIdx
.
lqIdx
:=
roq
.
io
.
exception
.
lqIdx
io
.
mem
.
exceptionAddr
.
lsIdx
.
sqIdx
:=
roq
.
io
.
exception
.
sqIdx
...
...
src/main/scala/xiangshan/backend/dispatch/DispatchQueue.scala
浏览文件 @
7eaf1071
...
...
@@ -190,7 +190,16 @@ class DispatchQueue(size: Int, enqnum: Int, deqnum: Int, replayWidth: Int) exten
// In case of replay, we need to walk back and recover preg states in the busy table.
// We keep track of the number of entries needed to be walked instead of target position to reduce overhead
// for 11111111, replayPosition is unuseful. We naively set Cnt to size.U
val
dispatchReplayCnt
=
Mux
(
allReplay
,
size
.
U
,
Mux
(
maskedNeedReplay
(
size
-
1
),
(
dispatchPtr
+
replayPosition
).
value
,
(
dispatchPtr
-
replayPosition
).
value
))
val
dispatchReplayCnt
=
Mux
(
allReplay
,
size
.
U
,
Mux
(
maskedNeedReplay
(
size
-
1
),
// replay makes flag flipped
dispatchPtr
.
value
+
replayPosition
,
// the new replay does not change the flag
Mux
(
dispatchPtr
.
value
<=
replayPosition
,
// but we are currently in a replay that changes the flag
dispatchPtr
.
value
+
(
size
.
U
-
replayPosition
),
dispatchPtr
.
value
-
replayPosition
)))
val
dispatchReplayCntReg
=
RegInit
(
0.
U
)
// actually, if deqIndex points to head uops and they are replayed, there's no need for extraWalk
// however, to simplify logic, we simply let it do extra walk now
...
...
src/main/scala/xiangshan/backend/exu/JmpExeUnit.scala
浏览文件 @
7eaf1071
...
...
@@ -74,6 +74,7 @@ class JmpExeUnit extends Exu(Exu.jmpExeUnitCfg) {
csr
.
io
.
perf
<>
DontCare
csr
.
io
.
exception
:=
io
.
csrOnly
.
exception
csr
.
io
.
isInterrupt
:=
io
.
redirect
.
bits
.
isFlushPipe
csr
.
io
.
memExceptionVAddr
:=
io
.
csrOnly
.
memExceptionVAddr
io
.
csrOnly
.
trapTarget
:=
csr
.
io
.
trapTarget
csr
.
io
.
mtip
:=
io
.
csrOnly
.
externalInterrupt
.
mtip
...
...
src/main/scala/xiangshan/backend/fu/CSR.scala
浏览文件 @
7eaf1071
...
...
@@ -177,6 +177,7 @@ class CSRIO extends FunctionUnitIO[UInt, Null](csrCfg, len=64, extIn= FuOpType()
val
cfOut
=
Output
(
new
CtrlFlow
)
// from rob
val
exception
=
Flipped
(
ValidIO
(
new
MicroOp
))
val
isInterrupt
=
Input
(
Bool
())
// for exception check
val
instrValid
=
Input
(
Bool
())
val
flushPipe
=
Output
(
Bool
())
...
...
@@ -637,7 +638,7 @@ class CSR extends XSModule
val
intrBitSet
=
intrVec
.
orR
()
io
.
interrupt
:=
intrBitSet
val
intrNO
=
IntPriority
.
foldRight
(
0.
U
)((
i
:
Int
,
sum
:
UInt
)
=>
Mux
(
intrVec
(
i
),
i
.
U
,
sum
))
val
raiseIntr
=
intrBitSet
&&
io
.
exception
.
valid
val
raiseIntr
=
intrBitSet
&&
io
.
exception
.
valid
&&
io
.
isInterrupt
XSDebug
(
raiseIntr
,
"interrupt: pc=0x%x, %d\n"
,
io
.
exception
.
bits
.
cf
.
pc
,
intrNO
)
mipWire
.
t
.
m
:=
io
.
mtip
...
...
src/main/scala/xiangshan/backend/roq/Roq.scala
浏览文件 @
7eaf1071
...
...
@@ -148,7 +148,8 @@ class Roq extends XSModule with HasCircularQueuePtrHelper {
io
.
redirect
:=
DontCare
io
.
redirect
.
valid
:=
(
state
===
s_idle
)
&&
(
intrEnable
||
exceptionEnable
||
isFlushPipe
)
// TODO: add fence flush to flush the whole pipe
io
.
redirect
.
bits
.
isException
:=
intrEnable
||
exceptionEnable
io
.
redirect
.
bits
.
isFlushPipe
:=
isFlushPipe
// reuse isFlushPipe to represent interrupt for CSR
io
.
redirect
.
bits
.
isFlushPipe
:=
isFlushPipe
||
intrEnable
io
.
redirect
.
bits
.
target
:=
Mux
(
isFlushPipe
,
deqUop
.
cf
.
pc
+
4.
U
,
io
.
trapTarget
)
io
.
exception
:=
deqUop
XSDebug
(
io
.
redirect
.
valid
,
"generate redirect: pc 0x%x intr %d excp %d flushpp %d target:0x%x Traptarget 0x%x exceptionVec %b\n"
,
io
.
exception
.
cf
.
pc
,
intrEnable
,
exceptionEnable
,
isFlushPipe
,
io
.
redirect
.
bits
.
target
,
io
.
trapTarget
,
Cat
(
microOp
(
deqPtr
).
cf
.
exceptionVec
))
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录