Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
kernel_linux
提交
63221755
K
kernel_linux
项目概览
OpenHarmony
/
kernel_linux
上一次同步 3 年多
通知
13
Star
8
Fork
2
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
kernel_linux
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
63221755
编写于
10月 17, 2011
作者:
B
Ben Skeggs
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
drm/nouveau: determine a value for display_info.bpc if edid doesn't
Signed-off-by:
N
Ben Skeggs
<
bskeggs@redhat.com
>
上级
9976f15c
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
46 addition
and
0 deletion
+46
-0
drivers/gpu/drm/nouveau/nouveau_connector.c
drivers/gpu/drm/nouveau/nouveau_connector.c
+46
-0
未找到文件。
drivers/gpu/drm/nouveau/nouveau_connector.c
浏览文件 @
63221755
...
...
@@ -644,6 +644,46 @@ nouveau_connector_scaler_modes_add(struct drm_connector *connector)
return
modes
;
}
static
void
nouveau_connector_detect_depth
(
struct
drm_connector
*
connector
)
{
struct
drm_nouveau_private
*
dev_priv
=
connector
->
dev
->
dev_private
;
struct
nouveau_connector
*
nv_connector
=
nouveau_connector
(
connector
);
struct
nouveau_encoder
*
nv_encoder
=
nv_connector
->
detected_encoder
;
struct
nvbios
*
bios
=
&
dev_priv
->
vbios
;
struct
drm_display_mode
*
mode
=
nv_connector
->
native_mode
;
bool
duallink
;
/* if the edid is feeling nice enough to provide this info, use it */
if
(
nv_connector
->
edid
&&
connector
->
display_info
.
bpc
)
return
;
/* if not, we're out of options unless we're LVDS, default to 6bpc */
connector
->
display_info
.
bpc
=
6
;
if
(
nv_encoder
->
dcb
->
type
!=
OUTPUT_LVDS
)
return
;
/* LVDS: panel straps */
if
(
bios
->
fp_no_ddc
)
{
if
(
bios
->
fp
.
if_is_24bit
)
connector
->
display_info
.
bpc
=
8
;
return
;
}
/* LVDS: DDC panel, need to first determine the number of links to
* know which if_is_24bit flag to check...
*/
if
(
nv_connector
->
edid
&&
nv_connector
->
dcb
->
type
==
DCB_CONNECTOR_LVDS_SPWG
)
duallink
=
((
u8
*
)
nv_connector
->
edid
)[
121
]
==
2
;
else
duallink
=
mode
->
clock
>=
bios
->
fp
.
duallink_transition_clk
;
if
((
!
duallink
&&
(
bios
->
fp
.
strapless_is_24bit
&
1
))
||
(
duallink
&&
(
bios
->
fp
.
strapless_is_24bit
&
2
)))
connector
->
display_info
.
bpc
=
8
;
}
static
int
nouveau_connector_get_modes
(
struct
drm_connector
*
connector
)
{
...
...
@@ -688,6 +728,12 @@ nouveau_connector_get_modes(struct drm_connector *connector)
ret
=
1
;
}
/* Attempt to determine display colour depth, this has to happen after
* we've determined the "native" mode for LVDS, as the VBIOS tables
* require us to compare against a pixel clock in some cases..
*/
nouveau_connector_detect_depth
(
connector
);
if
(
nv_encoder
->
dcb
->
type
==
OUTPUT_TV
)
ret
=
get_slave_funcs
(
encoder
)
->
get_modes
(
encoder
,
connector
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录