Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
e84a35a8
cloud-kernel
项目概览
openanolis
/
cloud-kernel
1 年多 前同步成功
通知
161
Star
36
Fork
7
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
10
列表
看板
标记
里程碑
合并请求
2
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
cloud-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
10
Issue
10
列表
看板
标记
里程碑
合并请求
2
合并请求
2
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
e84a35a8
编写于
6月 05, 2014
作者:
B
Ben Skeggs
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
drm/nv50-: prepare for attaching a SOR to multiple heads
Signed-off-by:
N
Ben Skeggs
<
bskeggs@redhat.com
>
上级
e32d68c9
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
46 addition
and
42 deletion
+46
-42
drivers/gpu/drm/nouveau/nouveau_crtc.h
drivers/gpu/drm/nouveau/nouveau_crtc.h
+1
-1
drivers/gpu/drm/nouveau/nouveau_encoder.h
drivers/gpu/drm/nouveau/nouveau_encoder.h
+1
-0
drivers/gpu/drm/nouveau/nv50_display.c
drivers/gpu/drm/nouveau/nv50_display.c
+44
-41
未找到文件。
drivers/gpu/drm/nouveau/nouveau_crtc.h
浏览文件 @
e84a35a8
...
...
@@ -74,7 +74,7 @@ struct nouveau_crtc {
static
inline
struct
nouveau_crtc
*
nouveau_crtc
(
struct
drm_crtc
*
crtc
)
{
return
c
ontainer_of
(
crtc
,
struct
nouveau_crtc
,
base
)
;
return
c
rtc
?
container_of
(
crtc
,
struct
nouveau_crtc
,
base
)
:
NULL
;
}
static
inline
struct
drm_crtc
*
to_drm_crtc
(
struct
nouveau_crtc
*
crtc
)
...
...
drivers/gpu/drm/nouveau/nouveau_encoder.h
浏览文件 @
e84a35a8
...
...
@@ -46,6 +46,7 @@ struct nouveau_encoder {
/* different to drm_encoder.crtc, this reflects what's
* actually programmed on the hw, not the proposed crtc */
struct
drm_crtc
*
crtc
;
u32
ctrl
;
struct
drm_display_mode
mode
;
int
last_dpms
;
...
...
drivers/gpu/drm/nouveau/nv50_display.c
浏览文件 @
e84a35a8
...
...
@@ -1701,10 +1701,9 @@ nv50_hdmi_mode_set(struct drm_encoder *encoder, struct drm_display_mode *mode)
}
static
void
nv50_hdmi_disconnect
(
struct
drm_encoder
*
encoder
)
nv50_hdmi_disconnect
(
struct
drm_encoder
*
encoder
,
struct
nouveau_crtc
*
nv_crtc
)
{
struct
nouveau_encoder
*
nv_encoder
=
nouveau_encoder
(
encoder
);
struct
nouveau_crtc
*
nv_crtc
=
nouveau_crtc
(
nv_encoder
->
crtc
);
struct
nv50_disp
*
disp
=
nv50_disp
(
encoder
->
dev
);
const
u32
moff
=
(
nv_crtc
->
index
<<
3
)
|
nv_encoder
->
or
;
...
...
@@ -1775,33 +1774,36 @@ nv50_sor_mode_fixup(struct drm_encoder *encoder,
}
static
void
nv50_sor_
disconnect
(
struct
drm_encoder
*
encoder
)
nv50_sor_
ctrl
(
struct
nouveau_encoder
*
nv_encoder
,
u32
mask
,
u32
data
)
{
struct
nouveau_encoder
*
nv_encoder
=
nouveau_encoder
(
encoder
);
struct
nv50_mast
*
mast
=
nv50_mast
(
encoder
->
dev
);
const
int
or
=
nv_encoder
->
or
;
u32
*
push
;
if
(
nv_encoder
->
crtc
)
{
nv50_crtc_prepare
(
nv_encoder
->
crtc
);
push
=
evo_wait
(
mast
,
4
);
if
(
push
)
{
if
(
nv50_vers
(
mast
)
<
NVD0_DISP_MAST_CLASS
)
{
evo_mthd
(
push
,
0x0600
+
(
or
*
0x40
),
1
);
evo_data
(
push
,
0x00000000
);
}
else
{
evo_mthd
(
push
,
0x0200
+
(
or
*
0x20
),
1
);
evo_data
(
push
,
0x00000000
);
}
evo_kick
(
push
,
mast
);
struct
nv50_mast
*
mast
=
nv50_mast
(
nv_encoder
->
base
.
base
.
dev
);
u32
temp
=
(
nv_encoder
->
ctrl
&
~
mask
)
|
(
data
&
mask
),
*
push
;
if
(
temp
!=
nv_encoder
->
ctrl
&&
(
push
=
evo_wait
(
mast
,
2
)))
{
if
(
nv50_vers
(
mast
)
<
NVD0_DISP_MAST_CLASS
)
{
evo_mthd
(
push
,
0x0600
+
(
nv_encoder
->
or
*
0x40
),
1
);
evo_data
(
push
,
(
nv_encoder
->
ctrl
=
temp
));
}
else
{
evo_mthd
(
push
,
0x0200
+
(
nv_encoder
->
or
*
0x20
),
1
);
evo_data
(
push
,
(
nv_encoder
->
ctrl
=
temp
));
}
nv50_hdmi_disconnect
(
encoder
);
evo_kick
(
push
,
mast
);
}
}
static
void
nv50_sor_disconnect
(
struct
drm_encoder
*
encoder
)
{
struct
nouveau_encoder
*
nv_encoder
=
nouveau_encoder
(
encoder
);
struct
nouveau_crtc
*
nv_crtc
=
nouveau_crtc
(
nv_encoder
->
crtc
);
nv_encoder
->
last_dpms
=
DRM_MODE_DPMS_OFF
;
nv_encoder
->
crtc
=
NULL
;
if
(
nv_crtc
)
{
nv50_crtc_prepare
(
&
nv_crtc
->
base
);
nv50_sor_ctrl
(
nv_encoder
,
1
<<
nv_crtc
->
index
,
0
);
nv50_hdmi_disconnect
(
&
nv_encoder
->
base
.
base
,
nv_crtc
);
}
}
static
void
...
...
@@ -1821,12 +1823,14 @@ nv50_sor_mode_set(struct drm_encoder *encoder, struct drm_display_mode *umode,
struct
nouveau_crtc
*
nv_crtc
=
nouveau_crtc
(
encoder
->
crtc
);
struct
nouveau_connector
*
nv_connector
;
struct
nvbios
*
bios
=
&
drm
->
vbios
;
u32
*
push
,
lvds
=
0
;
u32
lvds
=
0
,
mask
,
ctrl
;
u8
owner
=
1
<<
nv_crtc
->
index
;
u8
proto
=
0xf
;
u8
depth
=
0x0
;
nv_connector
=
nouveau_encoder_connector_get
(
nv_encoder
);
nv_encoder
->
crtc
=
encoder
->
crtc
;
switch
(
nv_encoder
->
dcb
->
type
)
{
case
DCB_OUTPUT_TMDS
:
if
(
nv_encoder
->
dcb
->
sorconf
.
link
&
1
)
{
...
...
@@ -1838,7 +1842,7 @@ nv50_sor_mode_set(struct drm_encoder *encoder, struct drm_display_mode *umode,
proto
=
0x2
;
}
nv50_hdmi_mode_set
(
encoder
,
mode
);
nv50_hdmi_mode_set
(
&
nv_encoder
->
base
.
base
,
mode
);
break
;
case
DCB_OUTPUT_LVDS
:
proto
=
0x0
;
...
...
@@ -1894,19 +1898,11 @@ nv50_sor_mode_set(struct drm_encoder *encoder, struct drm_display_mode *umode,
break
;
}
nv50_sor_dpms
(
encoder
,
DRM_MODE_DPMS_ON
);
nv50_sor_dpms
(
&
nv_encoder
->
base
.
base
,
DRM_MODE_DPMS_ON
);
push
=
evo_wait
(
nv50_mast
(
dev
),
8
);
if
(
push
)
{
if
(
nv50_vers
(
mast
)
<
NVD0_DISP_CLASS
)
{
u32
ctrl
=
(
depth
<<
16
)
|
(
proto
<<
8
)
|
owner
;
if
(
mode
->
flags
&
DRM_MODE_FLAG_NHSYNC
)
ctrl
|=
0x00001000
;
if
(
mode
->
flags
&
DRM_MODE_FLAG_NVSYNC
)
ctrl
|=
0x00002000
;
evo_mthd
(
push
,
0x0600
+
(
nv_encoder
->
or
*
0x040
),
1
);
evo_data
(
push
,
ctrl
);
}
else
{
if
(
nv50_vers
(
mast
)
>=
NVD0_DISP_CLASS
)
{
u32
*
push
=
evo_wait
(
mast
,
3
);
if
(
push
)
{
u32
magic
=
0x31ec6000
|
(
nv_crtc
->
index
<<
25
);
u32
syncs
=
0x00000001
;
...
...
@@ -1921,14 +1917,21 @@ nv50_sor_mode_set(struct drm_encoder *encoder, struct drm_display_mode *umode,
evo_mthd
(
push
,
0x0404
+
(
nv_crtc
->
index
*
0x300
),
2
);
evo_data
(
push
,
syncs
|
(
depth
<<
6
));
evo_data
(
push
,
magic
);
evo_mthd
(
push
,
0x0200
+
(
nv_encoder
->
or
*
0x020
),
1
);
evo_data
(
push
,
owner
|
(
proto
<<
8
));
evo_kick
(
push
,
mast
);
}
evo_kick
(
push
,
mast
);
ctrl
=
proto
<<
8
;
mask
=
0x00000f00
;
}
else
{
ctrl
=
(
depth
<<
16
)
|
(
proto
<<
8
);
if
(
mode
->
flags
&
DRM_MODE_FLAG_NHSYNC
)
ctrl
|=
0x00001000
;
if
(
mode
->
flags
&
DRM_MODE_FLAG_NVSYNC
)
ctrl
|=
0x00002000
;
mask
=
0x000f3f00
;
}
nv
_encoder
->
crtc
=
encoder
->
crtc
;
nv
50_sor_ctrl
(
nv_encoder
,
mask
|
owner
,
ctrl
|
owner
)
;
}
static
void
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录