Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
6c8e4633
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看板
提交
6c8e4633
编写于
11月 15, 2012
作者:
B
Ben Skeggs
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
drm/nouveau/dp: move core link training calls to common code
Signed-off-by:
N
Ben Skeggs
<
bskeggs@redhat.com
>
上级
b6e4ad20
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
30 addition
and
94 deletion
+30
-94
drivers/gpu/drm/nouveau/nouveau_dp.c
drivers/gpu/drm/nouveau/nouveau_dp.c
+25
-9
drivers/gpu/drm/nouveau/nouveau_encoder.h
drivers/gpu/drm/nouveau/nouveau_encoder.h
+1
-1
drivers/gpu/drm/nouveau/nv50_sor.c
drivers/gpu/drm/nouveau/nv50_sor.c
+2
-42
drivers/gpu/drm/nouveau/nvd0_display.c
drivers/gpu/drm/nouveau/nvd0_display.c
+2
-42
未找到文件。
drivers/gpu/drm/nouveau/nouveau_dp.c
浏览文件 @
6c8e4633
...
...
@@ -30,6 +30,8 @@
#include "nouveau_encoder.h"
#include "nouveau_crtc.h"
#include <core/class.h>
#include <subdev/gpio.h>
#include <subdev/i2c.h>
...
...
@@ -83,7 +85,7 @@ nouveau_dp_bios_data(struct drm_device *dev, struct dcb_output *dcb, u8 **entry)
*****************************************************************************/
struct
dp_state
{
struct
nouveau_i2c_port
*
auxch
;
struct
dp_train_func
*
func
;
struct
nouveau_object
*
core
;
struct
dcb_output
*
dcb
;
int
crtc
;
u8
*
dpcd
;
...
...
@@ -97,13 +99,20 @@ static void
dp_set_link_config
(
struct
drm_device
*
dev
,
struct
dp_state
*
dp
)
{
struct
nouveau_drm
*
drm
=
nouveau_drm
(
dev
);
struct
dcb_output
*
dcb
=
dp
->
dcb
;
const
u32
or
=
ffs
(
dcb
->
or
)
-
1
,
link
=
!
(
dcb
->
sorconf
.
link
&
1
);
const
u32
moff
=
(
dp
->
crtc
<<
3
)
|
(
link
<<
2
)
|
or
;
u8
sink
[
2
];
u32
data
;
NV_DEBUG
(
drm
,
"%d lanes at %d KB/s
\n
"
,
dp
->
link_nr
,
dp
->
link_bw
);
/* set desired link configuration on the source */
dp
->
func
->
link_set
(
dev
,
dp
->
dcb
,
dp
->
crtc
,
dp
->
link_nr
,
dp
->
link_bw
,
dp
->
dpcd
[
2
]
&
DP_ENHANCED_FRAME_CAP
);
data
=
((
dp
->
link_bw
/
27000
)
<<
8
)
|
dp
->
link_nr
;
if
(
dp
->
dpcd
[
2
]
&
DP_ENHANCED_FRAME_CAP
)
data
|=
NV94_DISP_SOR_DP_LNKCTL_FRAME_ENH
;
nv_call
(
dp
->
core
,
NV94_DISP_SOR_DP_LNKCTL
+
moff
,
data
);
/* inform the sink of the new configuration */
sink
[
0
]
=
dp
->
link_bw
/
27000
;
...
...
@@ -118,11 +127,14 @@ static void
dp_set_training_pattern
(
struct
drm_device
*
dev
,
struct
dp_state
*
dp
,
u8
pattern
)
{
struct
nouveau_drm
*
drm
=
nouveau_drm
(
dev
);
struct
dcb_output
*
dcb
=
dp
->
dcb
;
const
u32
or
=
ffs
(
dcb
->
or
)
-
1
,
link
=
!
(
dcb
->
sorconf
.
link
&
1
);
const
u32
moff
=
(
dp
->
crtc
<<
3
)
|
(
link
<<
2
)
|
or
;
u8
sink_tp
;
NV_DEBUG
(
drm
,
"training pattern %d
\n
"
,
pattern
);
dp
->
func
->
train_set
(
dev
,
dp
->
dcb
,
pattern
);
nv_call
(
dp
->
core
,
NV94_DISP_SOR_DP_TRAIN
+
moff
,
pattern
);
nv_rdaux
(
dp
->
auxch
,
DP_TRAINING_PATTERN_SET
,
&
sink_tp
,
1
);
sink_tp
&=
~
DP_TRAINING_PATTERN_MASK
;
...
...
@@ -134,6 +146,9 @@ static int
dp_link_train_commit
(
struct
drm_device
*
dev
,
struct
dp_state
*
dp
)
{
struct
nouveau_drm
*
drm
=
nouveau_drm
(
dev
);
struct
dcb_output
*
dcb
=
dp
->
dcb
;
const
u32
or
=
ffs
(
dcb
->
or
)
-
1
,
link
=
!
(
dcb
->
sorconf
.
link
&
1
);
const
u32
moff
=
(
dp
->
crtc
<<
3
)
|
(
link
<<
2
)
|
or
;
int
i
;
for
(
i
=
0
;
i
<
dp
->
link_nr
;
i
++
)
{
...
...
@@ -148,7 +163,8 @@ dp_link_train_commit(struct drm_device *dev, struct dp_state *dp)
dp
->
conf
[
i
]
|=
DP_TRAIN_MAX_PRE_EMPHASIS_REACHED
;
NV_DEBUG
(
drm
,
"config lane %d %02x
\n
"
,
i
,
dp
->
conf
[
i
]);
dp
->
func
->
train_adj
(
dev
,
dp
->
dcb
,
i
,
lvsw
,
lpre
);
nv_call
(
dp
->
core
,
NV94_DISP_SOR_DP_DRVCTL
(
i
)
+
moff
,
(
lvsw
<<
8
)
|
lpre
);
}
return
nv_wraux
(
dp
->
auxch
,
DP_TRAINING_LANE0_SET
,
dp
->
conf
,
4
);
...
...
@@ -286,7 +302,7 @@ dp_link_train_fini(struct drm_device *dev, struct dp_state *dp)
static
bool
nouveau_dp_link_train
(
struct
drm_encoder
*
encoder
,
u32
datarate
,
struct
dp_train_func
*
func
)
struct
nouveau_object
*
core
)
{
struct
nouveau_encoder
*
nv_encoder
=
nouveau_encoder
(
encoder
);
struct
nouveau_crtc
*
nv_crtc
=
nouveau_crtc
(
encoder
->
crtc
);
...
...
@@ -304,7 +320,7 @@ nouveau_dp_link_train(struct drm_encoder *encoder, u32 datarate,
if
(
!
dp
.
auxch
)
return
false
;
dp
.
func
=
func
;
dp
.
core
=
core
;
dp
.
dcb
=
nv_encoder
->
dcb
;
dp
.
crtc
=
nv_crtc
->
index
;
dp
.
dpcd
=
nv_encoder
->
dp
.
dpcd
;
...
...
@@ -365,7 +381,7 @@ nouveau_dp_link_train(struct drm_encoder *encoder, u32 datarate,
void
nouveau_dp_dpms
(
struct
drm_encoder
*
encoder
,
int
mode
,
u32
datarate
,
struct
dp_train_func
*
func
)
struct
nouveau_object
*
core
)
{
struct
nouveau_encoder
*
nv_encoder
=
nouveau_encoder
(
encoder
);
struct
nouveau_drm
*
drm
=
nouveau_drm
(
encoder
->
dev
);
...
...
@@ -385,7 +401,7 @@ nouveau_dp_dpms(struct drm_encoder *encoder, int mode, u32 datarate,
nv_wraux
(
auxch
,
DP_SET_POWER
,
&
status
,
1
);
if
(
mode
==
DRM_MODE_DPMS_ON
)
nouveau_dp_link_train
(
encoder
,
datarate
,
func
);
nouveau_dp_link_train
(
encoder
,
datarate
,
core
);
}
static
void
...
...
drivers/gpu/drm/nouveau/nouveau_encoder.h
浏览文件 @
6c8e4633
...
...
@@ -93,7 +93,7 @@ get_slave_funcs(struct drm_encoder *enc)
/* nouveau_dp.c */
bool
nouveau_dp_detect
(
struct
drm_encoder
*
);
void
nouveau_dp_dpms
(
struct
drm_encoder
*
,
int
mode
,
u32
datarate
,
struct
dp_train_func
*
);
struct
nouveau_object
*
);
u8
*
nouveau_dp_bios_data
(
struct
drm_device
*
,
struct
dcb_output
*
,
u8
**
);
struct
nouveau_connector
*
...
...
drivers/gpu/drm/nouveau/nv50_sor.c
浏览文件 @
6c8e4633
...
...
@@ -40,39 +40,6 @@
#include <subdev/timer.h>
static
void
nv50_sor_dp_train_set
(
struct
drm_device
*
dev
,
struct
dcb_output
*
dcb
,
u8
pattern
)
{
struct
nv50_display
*
disp
=
nv50_display
(
dev
);
const
u32
or
=
ffs
(
dcb
->
or
)
-
1
,
link
=
!
(
dcb
->
sorconf
.
link
&
1
);
const
u32
moff
=
(
link
<<
2
)
|
or
;
nv_call
(
disp
->
core
,
NV94_DISP_SOR_DP_TRAIN
+
moff
,
pattern
);
}
static
void
nv50_sor_dp_train_adj
(
struct
drm_device
*
dev
,
struct
dcb_output
*
dcb
,
u8
lane
,
u8
swing
,
u8
preem
)
{
struct
nv50_display
*
disp
=
nv50_display
(
dev
);
const
u32
or
=
ffs
(
dcb
->
or
)
-
1
,
link
=
!
(
dcb
->
sorconf
.
link
&
1
);
const
u32
moff
=
(
link
<<
2
)
|
or
;
const
u32
data
=
(
swing
<<
8
)
|
preem
;
nv_call
(
disp
->
core
,
NV94_DISP_SOR_DP_DRVCTL
(
lane
)
+
moff
,
data
);
}
static
void
nv50_sor_dp_link_set
(
struct
drm_device
*
dev
,
struct
dcb_output
*
dcb
,
int
crtc
,
int
link_nr
,
u32
link_bw
,
bool
enhframe
)
{
struct
nv50_display
*
disp
=
nv50_display
(
dev
);
const
u32
or
=
ffs
(
dcb
->
or
)
-
1
,
link
=
!
(
dcb
->
sorconf
.
link
&
1
);
const
u32
moff
=
(
crtc
<<
3
)
|
(
link
<<
2
)
|
or
;
u32
data
=
((
link_bw
/
27000
)
<<
8
)
|
link_nr
;
if
(
enhframe
)
data
|=
NV94_DISP_SOR_DP_LNKCTL_FRAME_ENH
;
nv_call
(
disp
->
core
,
NV94_DISP_SOR_DP_LNKCTL
+
moff
,
data
);
}
static
void
nv50_sor_disconnect
(
struct
drm_encoder
*
encoder
)
{
...
...
@@ -133,15 +100,8 @@ nv50_sor_dpms(struct drm_encoder *encoder, int mode)
nv_call
(
priv
->
core
,
NV50_DISP_SOR_PWR
+
or
,
(
mode
==
DRM_MODE_DPMS_ON
));
if
(
nv_encoder
->
dcb
->
type
==
DCB_OUTPUT_DP
)
{
struct
dp_train_func
func
=
{
.
link_set
=
nv50_sor_dp_link_set
,
.
train_set
=
nv50_sor_dp_train_set
,
.
train_adj
=
nv50_sor_dp_train_adj
};
nouveau_dp_dpms
(
encoder
,
mode
,
nv_encoder
->
dp
.
datarate
,
&
func
);
}
if
(
nv_encoder
->
dcb
->
type
==
DCB_OUTPUT_DP
)
nouveau_dp_dpms
(
encoder
,
mode
,
nv_encoder
->
dp
.
datarate
,
priv
->
core
);
}
static
void
...
...
drivers/gpu/drm/nouveau/nvd0_display.c
浏览文件 @
6c8e4633
...
...
@@ -1305,39 +1305,6 @@ nvd0_hdmi_disconnect(struct drm_encoder *encoder)
/******************************************************************************
* SOR
*****************************************************************************/
static
void
nvd0_sor_dp_train_set
(
struct
drm_device
*
dev
,
struct
dcb_output
*
dcb
,
u8
pattern
)
{
struct
nvd0_disp
*
disp
=
nvd0_disp
(
dev
);
const
u32
or
=
ffs
(
dcb
->
or
)
-
1
,
link
=
!
(
dcb
->
sorconf
.
link
&
1
);
const
u32
moff
=
(
link
<<
2
)
|
or
;
nv_call
(
disp
->
core
,
NV94_DISP_SOR_DP_TRAIN
+
moff
,
pattern
);
}
static
void
nvd0_sor_dp_train_adj
(
struct
drm_device
*
dev
,
struct
dcb_output
*
dcb
,
u8
lane
,
u8
swing
,
u8
preem
)
{
struct
nvd0_disp
*
disp
=
nvd0_disp
(
dev
);
const
u32
or
=
ffs
(
dcb
->
or
)
-
1
,
link
=
!
(
dcb
->
sorconf
.
link
&
1
);
const
u32
moff
=
(
link
<<
2
)
|
or
;
const
u32
data
=
(
swing
<<
8
)
|
preem
;
nv_call
(
disp
->
core
,
NV94_DISP_SOR_DP_DRVCTL
(
lane
)
+
moff
,
data
);
}
static
void
nvd0_sor_dp_link_set
(
struct
drm_device
*
dev
,
struct
dcb_output
*
dcb
,
int
crtc
,
int
link_nr
,
u32
link_bw
,
bool
enhframe
)
{
struct
nvd0_disp
*
disp
=
nvd0_disp
(
dev
);
const
u32
or
=
ffs
(
dcb
->
or
)
-
1
,
link
=
!
(
dcb
->
sorconf
.
link
&
1
);
const
u32
moff
=
(
crtc
<<
3
)
|
(
link
<<
2
)
|
or
;
u32
data
=
((
link_bw
/
27000
)
<<
8
)
|
link_nr
;
if
(
enhframe
)
data
|=
NV94_DISP_SOR_DP_LNKCTL_FRAME_ENH
;
nv_call
(
disp
->
core
,
NV94_DISP_SOR_DP_LNKCTL
+
moff
,
data
);
}
static
void
nvd0_sor_dpms
(
struct
drm_encoder
*
encoder
,
int
mode
)
{
...
...
@@ -1365,15 +1332,8 @@ nvd0_sor_dpms(struct drm_encoder *encoder, int mode)
nv_call
(
disp
->
core
,
NV50_DISP_SOR_PWR
+
or
,
(
mode
==
DRM_MODE_DPMS_ON
));
if
(
nv_encoder
->
dcb
->
type
==
DCB_OUTPUT_DP
)
{
struct
dp_train_func
func
=
{
.
link_set
=
nvd0_sor_dp_link_set
,
.
train_set
=
nvd0_sor_dp_train_set
,
.
train_adj
=
nvd0_sor_dp_train_adj
};
nouveau_dp_dpms
(
encoder
,
mode
,
nv_encoder
->
dp
.
datarate
,
&
func
);
}
if
(
nv_encoder
->
dcb
->
type
==
DCB_OUTPUT_DP
)
nouveau_dp_dpms
(
encoder
,
mode
,
nv_encoder
->
dp
.
datarate
,
disp
->
core
);
}
static
bool
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录