Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenXiangShan
XiangShan
提交
ec9268f7
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,发现更多精彩内容 >>
提交
ec9268f7
编写于
10月 01, 2019
作者:
Z
Zihao Yu
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
device,AXI4VGA: support hdmi signals
上级
c5351ba6
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
23 addition
and
12 deletion
+23
-12
src/main/scala/device/AXI4VGA.scala
src/main/scala/device/AXI4VGA.scala
+23
-12
未找到文件。
src/main/scala/device/AXI4VGA.scala
浏览文件 @
ec9268f7
...
...
@@ -7,7 +7,6 @@ import bus.axi4._
import
utils._
trait
HasVGAConst
{
// these are only fit for 800x600
val
ScreenW
=
800
val
ScreenH
=
600
...
...
@@ -19,25 +18,40 @@ trait HasVGAConst {
val
VActive
=
VFrontPorch
+
6
val
VBackPorch
=
VActive
+
ScreenH
val
VTotal
=
VBackPorch
+
23
}
trait
HasHDMIConst
{
val
ScreenW
=
800
val
ScreenH
=
600
val
HFrontPorch
=
40
val
HActive
=
HFrontPorch
+
128
val
HBackPorch
=
HActive
+
ScreenW
val
HTotal
=
HBackPorch
+
88
val
VFrontPorch
=
1
val
VActive
=
VFrontPorch
+
4
val
VBackPorch
=
VActive
+
ScreenH
val
VTotal
=
VBackPorch
+
23
}
trait
HasVGAParameter
extends
HasHDMIConst
{
val
FBWidth
=
ScreenW
/
2
val
FBHeight
=
ScreenH
/
2
val
FBPixels
=
FBWidth
*
FBHeight
}
class
VGABundle
extends
Bundle
{
val
r
=
Output
(
UInt
(
4.
W
))
val
g
=
Output
(
UInt
(
4.
W
))
val
b
=
Output
(
UInt
(
4.
W
))
val
rgb
=
Output
(
UInt
(
24.
W
))
val
hsync
=
Output
(
Bool
())
val
vsync
=
Output
(
Bool
())
val
valid
=
Output
(
Bool
())
}
class
VGACtrlBundle
extends
Bundle
{
val
sync
=
Output
(
Bool
())
}
class
VGACtrl
extends
AXI4SlaveModule
(
new
AXI4Lite
,
new
VGACtrlBundle
)
with
HasVGA
Const
{
class
VGACtrl
extends
AXI4SlaveModule
(
new
AXI4Lite
,
new
VGACtrlBundle
)
with
HasVGA
Parameter
{
val
fbSizeReg
=
Cat
(
FBWidth
.
U
(
16.
W
),
FBHeight
.
U
(
16.
W
))
val
sync
=
in
.
aw
.
fire
()
...
...
@@ -81,9 +95,8 @@ class FBHelper extends BlackBox with HasBlackBoxInline {
"""
.
stripMargin
)
}
class
AXI4VGA
(
sim
:
Boolean
=
false
)
extends
Module
with
HasVGA
Const
{
class
AXI4VGA
(
sim
:
Boolean
=
false
)
extends
Module
with
HasVGA
Parameter
{
val
AXIidBits
=
2
// need a 50MHz clock
val
io
=
IO
(
new
Bundle
{
val
in
=
new
Bundle
{
val
fb
=
Flipped
(
new
AXI4Lite
)
...
...
@@ -115,7 +128,7 @@ class AXI4VGA(sim: Boolean = false) extends Module with HasVGAConst {
val
hInRange
=
inRange
(
hCounter
,
HActive
,
HBackPorch
)
val
vInRange
=
inRange
(
vCounter
,
VActive
,
VBackPorch
)
val
videoValid
=
hInRange
&&
vInRange
io
.
vga
.
valid
:
=
hInRange
&&
vInRange
val
hCounterIsOdd
=
hCounter
(
0
)
val
hCounterIs2
=
hCounter
(
1
,
0
)
===
2.
U
...
...
@@ -134,14 +147,12 @@ class AXI4VGA(sim: Boolean = false) extends Module with HasVGAConst {
fb
.
io
.
in
.
r
.
ready
:=
true
.
B
val
data
=
HoldUnless
(
fb
.
io
.
in
.
r
.
bits
.
data
,
fb
.
io
.
in
.
r
.
fire
())
val
color
=
Mux
(
hCounter
(
1
),
data
(
63
,
32
),
data
(
31
,
0
))
io
.
vga
.
r
:=
Mux
(
videoValid
,
color
(
23
,
20
),
0.
U
)
io
.
vga
.
g
:=
Mux
(
videoValid
,
color
(
15
,
12
),
0.
U
)
io
.
vga
.
b
:=
Mux
(
videoValid
,
color
(
7
,
4
),
0.
U
)
io
.
vga
.
rgb
:=
Mux
(
io
.
vga
.
valid
,
color
(
23
,
0
),
0.
U
)
if
(
sim
)
{
val
fbHelper
=
Module
(
new
FBHelper
)
fbHelper
.
io
.
clk
:=
clock
fbHelper
.
io
.
valid
:=
videoV
alid
fbHelper
.
io
.
valid
:=
io
.
vga
.
v
alid
fbHelper
.
io
.
pixel
:=
color
fbHelper
.
io
.
sync
:=
ctrl
.
io
.
extra
.
get
.
sync
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录