Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenXiangShan
XiangShan
提交
93226391
X
XiangShan
项目概览
OpenXiangShan
/
XiangShan
9 个月 前同步成功
通知
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 搜索 >>
提交
93226391
编写于
7月 21, 2023
作者:
Z
Ziyue Zhang
提交者:
huxuan0307
8月 04, 2023
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
vector: fix mask for vipu and vppu
上级
59ef6009
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
8 addition
and
27 deletion
+8
-27
src/main/scala/xiangshan/backend/fu/wrapper/VIPU.scala
src/main/scala/xiangshan/backend/fu/wrapper/VIPU.scala
+7
-26
src/main/scala/xiangshan/backend/fu/wrapper/VPPU.scala
src/main/scala/xiangshan/backend/fu/wrapper/VPPU.scala
+1
-1
未找到文件。
src/main/scala/xiangshan/backend/fu/wrapper/VIPU.scala
浏览文件 @
93226391
...
...
@@ -105,17 +105,17 @@ class VIPU(cfg: FuConfig)(implicit p: Parameters) extends VecPipedFuncUnit(cfg)
// modules
private
val
decoder
=
Module
(
new
VIAluDecoder
)
private
val
vialu
=
Module
(
new
VIAlu
)
private
val
mgu
=
Module
(
new
Mgu
(
dataWidth
))
/**
* [[decoder]]'s in connection
*/
* [[decoder]]'s in connection
*/
decoder
.
io
.
in
.
fuOpType
:=
fuOpType
decoder
.
io
.
in
.
sew
:=
vsew
(
1
,
0
)
/**
* [[vialu]]'s in connection
*/
* [[vialu]]'s in connection
*/
vialu
.
io
match
{
case
subIO
=>
subIO
.
in
.
valid
:=
io
.
in
.
valid
...
...
@@ -136,27 +136,8 @@ class VIPU(cfg: FuConfig)(implicit p: Parameters) extends VecPipedFuncUnit(cfg)
((!
needClearVs1
)
&&
(!
needShiftVs1
))
->
vs1
))
subIO
.
in
.
bits
.
vs2
:=
vs2
subIO
.
in
.
bits
.
old_vd
:=
oldVd
subIO
.
in
.
bits
.
mask
:=
outS
rcMask
subIO
.
in
.
bits
.
mask
:=
s
rcMask
}
/**
* [[mgu]]'s in connection
*/
private
val
outVd
=
vialu
.
io
.
out
.
bits
.
vd
private
val
outWiden
=
fuOpType
===
VipuType
.
vwredsumu_vs
||
fuOpType
===
VipuType
.
vwredsum_vs
private
val
outEew
=
Mux
(
outWiden
,
outVecCtrl
.
vsew
+
1.
U
,
outVecCtrl
.
vsew
)
mgu
.
io
.
in
.
vd
:=
outVd
mgu
.
io
.
in
.
oldVd
:=
outOldVd
mgu
.
io
.
in
.
mask
:=
outSrcMask
mgu
.
io
.
in
.
info
.
ta
:=
outVecCtrl
.
vta
mgu
.
io
.
in
.
info
.
ma
:=
outVecCtrl
.
vma
mgu
.
io
.
in
.
info
.
vl
:=
outVl
mgu
.
io
.
in
.
info
.
vstart
:=
outVecCtrl
.
vstart
mgu
.
io
.
in
.
info
.
eew
:=
outEew
mgu
.
io
.
in
.
info
.
vdIdx
:=
outVecCtrl
.
vuopIdx
mgu
.
io
.
in
.
info
.
narrow
:=
0.
B
mgu
.
io
.
in
.
info
.
dstMask
:=
0.
B
io
.
out
.
bits
.
res
.
data
:=
mgu
.
io
.
out
.
vd
io
.
out
.
bits
.
res
.
data
:=
vialu
.
io
.
out
.
bits
.
vd
}
src/main/scala/xiangshan/backend/fu/wrapper/VPPU.scala
浏览文件 @
93226391
...
...
@@ -35,7 +35,7 @@ class VPPU(cfg: FuConfig)(implicit p: Parameters) extends VecPipedFuncUnit(cfg)
private
val
dataWidthOfDataModule
=
64
private
val
numVecModule
=
dataWidth
/
dataWidthOfDataModule
private
val
vppuNeedClearMask
=
(
VpermType
.
vcompress
===
io
.
in
.
bits
.
ctrl
.
fuOpType
)
&&
(
vuopIdx
(
log2Up
(
MaxUopSize
)-
1
,
1
)
===
0.
U
)
private
val
mask
=
Mux
(
vppuNeedClearMask
,
0.
U
,
outS
rcMask
)
private
val
mask
=
Mux
(
vppuNeedClearMask
,
0.
U
,
s
rcMask
)
// io alias
private
val
opcode
=
VpermType
.
getOpcode
(
fuOpType
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录