Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenXiangShan
XiangShan
提交
acf454a0
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,发现更多精彩内容 >>
提交
acf454a0
编写于
7月 13, 2020
作者:
J
jinyue110
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
IFU: if1_valid in 0~501
上级
a811cdbe
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
5 addition
and
8 deletion
+5
-8
src/main/scala/xiangshan/XSCore.scala
src/main/scala/xiangshan/XSCore.scala
+1
-1
src/main/scala/xiangshan/frontend/IFU.scala
src/main/scala/xiangshan/frontend/IFU.scala
+4
-7
未找到文件。
src/main/scala/xiangshan/XSCore.scala
浏览文件 @
acf454a0
...
...
@@ -26,7 +26,7 @@ trait HasXSParameter {
val
DataBytes
=
DataBits
/
8
val
HasFPU
=
true
val
FetchWidth
=
8
val
EnableBPU
=
fals
e
val
EnableBPU
=
tru
e
val
EnableBPD
=
true
// enable backing predictor(like Tage) in BPUStage3
val
HistoryLength
=
64
val
BtbSize
=
128
...
...
src/main/scala/xiangshan/frontend/IFU.scala
浏览文件 @
acf454a0
...
...
@@ -8,7 +8,6 @@ import xiangshan.utils._
trait
HasIFUConst
{
this:
XSModule
=>
val
resetVector
=
0x80000000
L
//TODO: set reset vec
val
enableBPU
=
false
val
groupAlign
=
log2Up
(
FetchWidth
*
4
)
def
groupPC
(
pc
:
UInt
)
:
UInt
=
Cat
(
pc
(
VAddrBits
-
1
,
groupAlign
),
0.
U
(
groupAlign
.
W
))
...
...
@@ -48,7 +47,7 @@ class IFU extends XSModule with HasIFUConst
//-------------------------
//local
val
if1_npc
=
WireInit
(
0.
U
(
VAddrBits
.
W
))
val
if1_valid
=
!
reset
.
asBool
&&
(
GTimer
()
>
500.
U
)
//TODO:this is ugly
val
if1_valid
=
!
reset
.
asBool
val
if1_pc
=
RegInit
(
resetVector
.
U
(
VAddrBits
.
W
))
//next
val
if2_ready
=
WireInit
(
false
.
B
)
...
...
@@ -63,8 +62,6 @@ class IFU extends XSModule with HasIFUConst
//when((GTimer() === 501.U)){ //TODO:this is ugly
XSDebug
(
"RESET....\n"
)
if1_npc
:=
resetVector
.
U
(
VAddrBits
.
W
)
}
.
elsewhen
(
GTimer
()
===
501.
U
){
//TODO: this may cause bug
if1_npc
:=
resetVector
.
U
(
VAddrBits
.
W
)
}
.
otherwise
{
if1_npc
:=
if2_snpc
}
...
...
@@ -170,10 +167,10 @@ class IFU extends XSModule with HasIFUConst
//Output -> iBuffer
//io.fetchPacket <> DontCare
if4_ready
:=
io
.
fetchPacket
.
ready
&&
(
io
.
icacheResp
.
valid
||
!
if4_valid
)
if4_ready
:=
io
.
fetchPacket
.
ready
&&
(
io
.
icacheResp
.
valid
||
!
if4_valid
)
&&
(
GTimer
()
>
500.
U
)
io
.
fetchPacket
.
valid
:=
if4_valid
&&
!
io
.
redirectInfo
.
flush
()
io
.
fetchPacket
.
bits
.
instrs
:=
io
.
icacheResp
.
bits
.
icacheOut
if
(
e
nableBPU
){
if
(
E
nableBPU
){
io
.
fetchPacket
.
bits
.
mask
:=
Mux
(
if4_tage_taken
,
(
Fill
(
FetchWidth
*
2
,
1.
U
(
1.
W
))
&
Cat
(
if4_tage_insMask
.
map
(
i
=>
Fill
(
2
,
i
.
asUInt
))).
asUInt
)
<<
if4_pc
(
2
+
log2Up
(
FetchWidth
)-
1
,
1
),
Fill
(
FetchWidth
*
2
,
1.
U
(
1.
W
))
<<
if4_pc
(
2
+
log2Up
(
FetchWidth
)-
1
,
1
)
...
...
@@ -211,7 +208,7 @@ class IFU extends XSModule with HasIFUConst
bpu
.
io
.
redirectInfo
:=
io
.
redirectInfo
io
.
icacheResp
.
ready
:=
io
.
fetchPacket
.
ready
io
.
icacheResp
.
ready
:=
io
.
fetchPacket
.
ready
&&
(
GTimer
()
>
500.
U
)
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录