Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
a91d3221
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看板
提交
a91d3221
编写于
12月 22, 2014
作者:
B
Ben Skeggs
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
drm/nv50-/kms: move identical scaler mode fixup code into a function
Signed-off-by:
N
Ben Skeggs
<
bskeggs@redhat.com
>
上级
495b2176
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
24 addition
and
54 deletion
+24
-54
drivers/gpu/drm/nouveau/nv50_display.c
drivers/gpu/drm/nouveau/nv50_display.c
+24
-54
未找到文件。
drivers/gpu/drm/nouveau/nv50_display.c
浏览文件 @
a91d3221
...
...
@@ -1465,6 +1465,26 @@ nv50_crtc_create(struct drm_device *dev, int index)
return
ret
;
}
/******************************************************************************
* Encoder helpers
*****************************************************************************/
static
bool
nv50_encoder_mode_fixup
(
struct
drm_encoder
*
encoder
,
const
struct
drm_display_mode
*
mode
,
struct
drm_display_mode
*
adjusted_mode
)
{
struct
nouveau_encoder
*
nv_encoder
=
nouveau_encoder
(
encoder
);
struct
nouveau_connector
*
nv_connector
;
nv_connector
=
nouveau_encoder_connector_get
(
nv_encoder
);
if
(
nv_connector
&&
nv_connector
->
native_mode
)
{
if
(
nv_connector
->
scaling_mode
!=
DRM_MODE_SCALE_NONE
)
drm_mode_copy
(
adjusted_mode
,
nv_connector
->
native_mode
);
}
return
true
;
}
/******************************************************************************
* DAC
*****************************************************************************/
...
...
@@ -1492,26 +1512,6 @@ nv50_dac_dpms(struct drm_encoder *encoder, int mode)
nvif_mthd
(
disp
->
disp
,
0
,
&
args
,
sizeof
(
args
));
}
static
bool
nv50_dac_mode_fixup
(
struct
drm_encoder
*
encoder
,
const
struct
drm_display_mode
*
mode
,
struct
drm_display_mode
*
adjusted_mode
)
{
struct
nouveau_encoder
*
nv_encoder
=
nouveau_encoder
(
encoder
);
struct
nouveau_connector
*
nv_connector
;
nv_connector
=
nouveau_encoder_connector_get
(
nv_encoder
);
if
(
nv_connector
&&
nv_connector
->
native_mode
)
{
if
(
nv_connector
->
scaling_mode
!=
DRM_MODE_SCALE_NONE
)
{
int
id
=
adjusted_mode
->
base
.
id
;
*
adjusted_mode
=
*
nv_connector
->
native_mode
;
adjusted_mode
->
base
.
id
=
id
;
}
}
return
true
;
}
static
void
nv50_dac_commit
(
struct
drm_encoder
*
encoder
)
{
...
...
@@ -1629,7 +1629,7 @@ nv50_dac_destroy(struct drm_encoder *encoder)
static
const
struct
drm_encoder_helper_funcs
nv50_dac_hfunc
=
{
.
dpms
=
nv50_dac_dpms
,
.
mode_fixup
=
nv50_
dac
_mode_fixup
,
.
mode_fixup
=
nv50_
encoder
_mode_fixup
,
.
prepare
=
nv50_dac_disconnect
,
.
commit
=
nv50_dac_commit
,
.
mode_set
=
nv50_dac_mode_set
,
...
...
@@ -1834,26 +1834,6 @@ nv50_sor_dpms(struct drm_encoder *encoder, int mode)
}
}
static
bool
nv50_sor_mode_fixup
(
struct
drm_encoder
*
encoder
,
const
struct
drm_display_mode
*
mode
,
struct
drm_display_mode
*
adjusted_mode
)
{
struct
nouveau_encoder
*
nv_encoder
=
nouveau_encoder
(
encoder
);
struct
nouveau_connector
*
nv_connector
;
nv_connector
=
nouveau_encoder_connector_get
(
nv_encoder
);
if
(
nv_connector
&&
nv_connector
->
native_mode
)
{
if
(
nv_connector
->
scaling_mode
!=
DRM_MODE_SCALE_NONE
)
{
int
id
=
adjusted_mode
->
base
.
id
;
*
adjusted_mode
=
*
nv_connector
->
native_mode
;
adjusted_mode
->
base
.
id
=
id
;
}
}
return
true
;
}
static
void
nv50_sor_ctrl
(
struct
nouveau_encoder
*
nv_encoder
,
u32
mask
,
u32
data
)
{
...
...
@@ -2035,7 +2015,7 @@ nv50_sor_destroy(struct drm_encoder *encoder)
static
const
struct
drm_encoder_helper_funcs
nv50_sor_hfunc
=
{
.
dpms
=
nv50_sor_dpms
,
.
mode_fixup
=
nv50_
so
r_mode_fixup
,
.
mode_fixup
=
nv50_
encode
r_mode_fixup
,
.
prepare
=
nv50_sor_disconnect
,
.
commit
=
nv50_sor_commit
,
.
mode_set
=
nv50_sor_mode_set
,
...
...
@@ -2112,18 +2092,8 @@ nv50_pior_mode_fixup(struct drm_encoder *encoder,
const
struct
drm_display_mode
*
mode
,
struct
drm_display_mode
*
adjusted_mode
)
{
struct
nouveau_encoder
*
nv_encoder
=
nouveau_encoder
(
encoder
);
struct
nouveau_connector
*
nv_connector
;
nv_connector
=
nouveau_encoder_connector_get
(
nv_encoder
);
if
(
nv_connector
&&
nv_connector
->
native_mode
)
{
if
(
nv_connector
->
scaling_mode
!=
DRM_MODE_SCALE_NONE
)
{
int
id
=
adjusted_mode
->
base
.
id
;
*
adjusted_mode
=
*
nv_connector
->
native_mode
;
adjusted_mode
->
base
.
id
=
id
;
}
}
if
(
!
nv50_encoder_mode_fixup
(
encoder
,
mode
,
adjusted_mode
))
return
false
;
adjusted_mode
->
clock
*=
2
;
return
true
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录