Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
763a4a01
K
Kernel
项目概览
openeuler
/
Kernel
1 年多 前同步成功
通知
8
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
Kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
763a4a01
编写于
9月 05, 2010
作者:
C
Chris Wilson
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
drm/i915/tv: Mark the format names as constant and so avoid the memleak
Signed-off-by:
N
Chris Wilson
<
chris@chris-wilson.co.uk
>
上级
974b9331
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
17 addition
and
19 deletion
+17
-19
drivers/gpu/drm/i915/intel_tv.c
drivers/gpu/drm/i915/intel_tv.c
+17
-19
未找到文件。
drivers/gpu/drm/i915/intel_tv.c
浏览文件 @
763a4a01
...
...
@@ -48,7 +48,7 @@ struct intel_tv {
struct
intel_encoder
base
;
int
type
;
char
*
tv_format
;
c
onst
c
har
*
tv_format
;
int
margin
[
4
];
u32
save_TV_H_CTL_1
;
u32
save_TV_H_CTL_2
;
...
...
@@ -350,7 +350,7 @@ static const struct video_levels component_levels = {
struct
tv_mode
{
char
*
name
;
c
onst
c
har
*
name
;
int
clock
;
int
refresh
;
/* in millihertz (for precision) */
u32
oversample
;
...
...
@@ -922,7 +922,7 @@ intel_tv_dpms(struct drm_encoder *encoder, int mode)
}
static
const
struct
tv_mode
*
intel_tv_mode_lookup
(
char
*
tv_format
)
intel_tv_mode_lookup
(
const
char
*
tv_format
)
{
int
i
;
...
...
@@ -936,13 +936,14 @@ intel_tv_mode_lookup (char *tv_format)
}
static
const
struct
tv_mode
*
intel_tv_mode_find
(
struct
intel_tv
*
intel_tv
)
intel_tv_mode_find
(
struct
intel_tv
*
intel_tv
)
{
return
intel_tv_mode_lookup
(
intel_tv
->
tv_format
);
}
static
enum
drm_mode_status
intel_tv_mode_valid
(
struct
drm_connector
*
connector
,
struct
drm_display_mode
*
mode
)
intel_tv_mode_valid
(
struct
drm_connector
*
connector
,
struct
drm_display_mode
*
mode
)
{
struct
drm_encoder
*
encoder
=
intel_attached_encoder
(
connector
);
struct
intel_tv
*
intel_tv
=
enc_to_intel_tv
(
encoder
);
...
...
@@ -952,6 +953,7 @@ intel_tv_mode_valid(struct drm_connector *connector, struct drm_display_mode *mo
if
(
tv_mode
&&
abs
(
tv_mode
->
refresh
-
drm_mode_vrefresh
(
mode
)
*
1000
)
<
1000
)
return
MODE_OK
;
return
MODE_CLOCK_RANGE
;
}
...
...
@@ -1369,11 +1371,10 @@ intel_tv_detect(struct drm_connector *connector)
return
connector_status_connected
;
}
static
struct
input_res
{
char
*
name
;
static
const
struct
input_res
{
c
onst
c
har
*
name
;
int
w
,
h
;
}
input_res_table
[]
=
{
}
input_res_table
[]
=
{
{
"640x480"
,
640
,
480
},
{
"800x600"
,
800
,
600
},
{
"1024x768"
,
1024
,
768
},
...
...
@@ -1424,7 +1425,7 @@ intel_tv_get_modes(struct drm_connector *connector)
for
(
j
=
0
;
j
<
ARRAY_SIZE
(
input_res_table
);
j
++
)
{
struct
input_res
*
input
=
&
input_res_table
[
j
];
const
struct
input_res
*
input
=
&
input_res_table
[
j
];
unsigned
int
hactive_s
=
input
->
w
;
unsigned
int
vactive_s
=
input
->
h
;
...
...
@@ -1601,7 +1602,7 @@ intel_tv_init(struct drm_device *dev)
struct
intel_encoder
*
intel_encoder
;
struct
intel_connector
*
intel_connector
;
u32
tv_dac_on
,
tv_dac_off
,
save_tv_dac
;
char
*
*
tv_format_names
;
char
*
tv_format_names
[
ARRAY_SIZE
(
tv_modes
)]
;
int
i
,
initial_mode
=
0
;
if
((
I915_READ
(
TV_CTL
)
&
TV_FUSE_STATE_MASK
)
==
TV_FUSE_STATE_DISABLED
)
...
...
@@ -1672,7 +1673,7 @@ intel_tv_init(struct drm_device *dev)
intel_tv
->
margin
[
TV_MARGIN_RIGHT
]
=
46
;
intel_tv
->
margin
[
TV_MARGIN_BOTTOM
]
=
37
;
intel_tv
->
tv_format
=
kstrdup
(
tv_modes
[
initial_mode
].
name
,
GFP_KERNEL
)
;
intel_tv
->
tv_format
=
tv_modes
[
initial_mode
].
name
;
drm_encoder_helper_add
(
&
intel_encoder
->
enc
,
&
intel_tv_helper_funcs
);
drm_connector_helper_add
(
connector
,
&
intel_tv_connector_helper_funcs
);
...
...
@@ -1680,13 +1681,11 @@ intel_tv_init(struct drm_device *dev)
connector
->
doublescan_allowed
=
false
;
/* Create TV properties then attach current values */
tv_format_names
=
kmalloc
(
sizeof
(
char
*
)
*
ARRAY_SIZE
(
tv_modes
),
GFP_KERNEL
);
if
(
!
tv_format_names
)
goto
out
;
for
(
i
=
0
;
i
<
ARRAY_SIZE
(
tv_modes
);
i
++
)
tv_format_names
[
i
]
=
tv_modes
[
i
].
name
;
drm_mode_create_tv_properties
(
dev
,
ARRAY_SIZE
(
tv_modes
),
tv_format_names
);
tv_format_names
[
i
]
=
(
char
*
)
tv_modes
[
i
].
name
;
drm_mode_create_tv_properties
(
dev
,
ARRAY_SIZE
(
tv_modes
),
tv_format_names
);
drm_connector_attach_property
(
connector
,
dev
->
mode_config
.
tv_mode_property
,
initial_mode
);
...
...
@@ -1702,6 +1701,5 @@ intel_tv_init(struct drm_device *dev)
drm_connector_attach_property
(
connector
,
dev
->
mode_config
.
tv_bottom_margin_property
,
intel_tv
->
margin
[
TV_MARGIN_BOTTOM
]);
out:
drm_sysfs_connector_add
(
connector
);
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录