Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
raspberrypi-kernel
提交
2d1d898b
R
raspberrypi-kernel
项目概览
openeuler
/
raspberrypi-kernel
通知
13
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
raspberrypi-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
2d1d898b
编写于
11月 11, 2011
作者:
B
Ben Skeggs
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
drm/nvd0/disp: update crtc timing calculations for interlace/doublescan
Signed-off-by:
N
Ben Skeggs
<
bskeggs@redhat.com
>
上级
f62b27db
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
34 addition
and
18 deletion
+34
-18
drivers/gpu/drm/nouveau/nvd0_display.c
drivers/gpu/drm/nouveau/nvd0_display.c
+34
-18
未找到文件。
drivers/gpu/drm/nouveau/nvd0_display.c
浏览文件 @
2d1d898b
...
@@ -352,21 +352,35 @@ nvd0_crtc_mode_set(struct drm_crtc *crtc, struct drm_display_mode *umode,
...
@@ -352,21 +352,35 @@ nvd0_crtc_mode_set(struct drm_crtc *crtc, struct drm_display_mode *umode,
{
{
struct
nouveau_crtc
*
nv_crtc
=
nouveau_crtc
(
crtc
);
struct
nouveau_crtc
*
nv_crtc
=
nouveau_crtc
(
crtc
);
struct
nouveau_connector
*
nv_connector
;
struct
nouveau_connector
*
nv_connector
;
u32
htotal
=
mode
->
htotal
;
u32
ilace
=
(
mode
->
flags
&
DRM_MODE_FLAG_INTERLACE
)
?
2
:
1
;
u32
vtotal
=
mode
->
vtotal
;
u32
vscan
=
(
mode
->
flags
&
DRM_MODE_FLAG_DBLSCAN
)
?
2
:
1
;
u32
hsyncw
=
mode
->
hsync_end
-
mode
->
hsync_start
-
1
;
u32
hactive
,
hsynce
,
hbackp
,
hfrontp
,
hblanke
,
hblanks
;
u32
vsyncw
=
mode
->
vsync_end
-
mode
->
vsync_start
-
1
;
u32
vactive
,
vsynce
,
vbackp
,
vfrontp
,
vblanke
,
vblanks
;
u32
hfrntp
=
mode
->
hsync_start
-
mode
->
hdisplay
;
u32
vblan2e
=
0
,
vblan2s
=
1
;
u32
vfrntp
=
mode
->
vsync_start
-
mode
->
vdisplay
;
u32
magic
=
0x31ec6000
;
u32
hbackp
=
mode
->
htotal
-
mode
->
hsync_end
;
u32
vbackp
=
mode
->
vtotal
-
mode
->
vsync_end
;
u32
hss2be
=
hsyncw
+
hbackp
;
u32
vss2be
=
vsyncw
+
vbackp
;
u32
hss2de
=
htotal
-
hfrntp
;
u32
vss2de
=
vtotal
-
vfrntp
;
u32
syncs
,
*
push
;
u32
syncs
,
*
push
;
int
ret
;
int
ret
;
hactive
=
mode
->
htotal
;
hsynce
=
mode
->
hsync_end
-
mode
->
hsync_start
-
1
;
hbackp
=
mode
->
htotal
-
mode
->
hsync_end
;
hblanke
=
hsynce
+
hbackp
;
hfrontp
=
mode
->
hsync_start
-
mode
->
hdisplay
;
hblanks
=
mode
->
htotal
-
hfrontp
-
1
;
vactive
=
mode
->
vtotal
*
vscan
/
ilace
;
vsynce
=
((
mode
->
vsync_end
-
mode
->
vsync_start
)
*
vscan
/
ilace
)
-
1
;
vbackp
=
(
mode
->
vtotal
-
mode
->
vsync_end
)
*
vscan
/
ilace
;
vblanke
=
vsynce
+
vbackp
;
vfrontp
=
(
mode
->
vsync_start
-
mode
->
vdisplay
)
*
vscan
/
ilace
;
vblanks
=
vactive
-
vfrontp
-
1
;
if
(
mode
->
flags
&
DRM_MODE_FLAG_INTERLACE
)
{
vblan2e
=
vactive
+
vsynce
+
vbackp
;
vblan2s
=
vblan2e
+
(
mode
->
vdisplay
*
vscan
/
ilace
);
vactive
=
(
vactive
*
2
)
+
1
;
magic
|=
0x00000001
;
}
syncs
=
0x00000001
;
syncs
=
0x00000001
;
if
(
mode
->
flags
&
DRM_MODE_FLAG_NHSYNC
)
if
(
mode
->
flags
&
DRM_MODE_FLAG_NHSYNC
)
syncs
|=
0x00000008
;
syncs
|=
0x00000008
;
...
@@ -379,20 +393,22 @@ nvd0_crtc_mode_set(struct drm_crtc *crtc, struct drm_display_mode *umode,
...
@@ -379,20 +393,22 @@ nvd0_crtc_mode_set(struct drm_crtc *crtc, struct drm_display_mode *umode,
push
=
evo_wait
(
crtc
->
dev
,
0
,
64
);
push
=
evo_wait
(
crtc
->
dev
,
0
,
64
);
if
(
push
)
{
if
(
push
)
{
evo_mthd
(
push
,
0x0410
+
(
nv_crtc
->
index
*
0x300
),
5
);
evo_mthd
(
push
,
0x0410
+
(
nv_crtc
->
index
*
0x300
),
6
);
evo_data
(
push
,
0x00000000
);
evo_data
(
push
,
0x00000000
);
evo_data
(
push
,
(
vtotal
<<
16
)
|
htotal
);
evo_data
(
push
,
(
vactive
<<
16
)
|
hactive
);
evo_data
(
push
,
(
vsyncw
<<
16
)
|
hsyncw
);
evo_data
(
push
,
(
vsynce
<<
16
)
|
hsynce
);
evo_data
(
push
,
(
vss2be
<<
16
)
|
hss2be
);
evo_data
(
push
,
(
vblanke
<<
16
)
|
hblanke
);
evo_data
(
push
,
(
vss2de
<<
16
)
|
hss2de
);
evo_data
(
push
,
(
vblanks
<<
16
)
|
hblanks
);
evo_data
(
push
,
(
vblan2e
<<
16
)
|
vblan2s
);
evo_mthd
(
push
,
0x042c
+
(
nv_crtc
->
index
*
0x300
),
1
);
evo_mthd
(
push
,
0x042c
+
(
nv_crtc
->
index
*
0x300
),
1
);
evo_data
(
push
,
0x00000000
);
/* ??? */
evo_data
(
push
,
0x00000000
);
/* ??? */
evo_mthd
(
push
,
0x0450
+
(
nv_crtc
->
index
*
0x300
),
3
);
evo_mthd
(
push
,
0x0450
+
(
nv_crtc
->
index
*
0x300
),
3
);
evo_data
(
push
,
mode
->
clock
*
1000
);
evo_data
(
push
,
mode
->
clock
*
1000
);
evo_data
(
push
,
0x00200000
);
/* ??? */
evo_data
(
push
,
0x00200000
);
/* ??? */
evo_data
(
push
,
mode
->
clock
*
1000
);
evo_data
(
push
,
mode
->
clock
*
1000
);
evo_mthd
(
push
,
0x0404
+
(
nv_crtc
->
index
*
0x300
),
1
);
evo_mthd
(
push
,
0x0404
+
(
nv_crtc
->
index
*
0x300
),
2
);
evo_data
(
push
,
syncs
);
evo_data
(
push
,
syncs
);
evo_data
(
push
,
magic
);
evo_kick
(
push
,
crtc
->
dev
,
0
);
evo_kick
(
push
,
crtc
->
dev
,
0
);
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录