Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
38945be6
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看板
提交
38945be6
编写于
7月 10, 2013
作者:
P
Patrik Jakobsson
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
drm/gma500: Add generic cursor functions
Signed-off-by:
N
Patrik Jakobsson
<
patrik.r.jakobsson@gmail.com
>
上级
b1255b88
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
156 addition
and
0 deletion
+156
-0
drivers/gpu/drm/gma500/gma_display.c
drivers/gpu/drm/gma500/gma_display.c
+151
-0
drivers/gpu/drm/gma500/gma_display.h
drivers/gpu/drm/gma500/gma_display.h
+5
-0
未找到文件。
drivers/gpu/drm/gma500/gma_display.c
浏览文件 @
38945be6
...
...
@@ -327,6 +327,157 @@ void gma_crtc_dpms(struct drm_crtc *crtc, int mode)
REG_WRITE
(
DSPARB
,
0x3F3E
);
}
int
gma_crtc_cursor_set
(
struct
drm_crtc
*
crtc
,
struct
drm_file
*
file_priv
,
uint32_t
handle
,
uint32_t
width
,
uint32_t
height
)
{
struct
drm_device
*
dev
=
crtc
->
dev
;
struct
drm_psb_private
*
dev_priv
=
dev
->
dev_private
;
struct
psb_intel_crtc
*
psb_intel_crtc
=
to_psb_intel_crtc
(
crtc
);
int
pipe
=
psb_intel_crtc
->
pipe
;
uint32_t
control
=
(
pipe
==
0
)
?
CURACNTR
:
CURBCNTR
;
uint32_t
base
=
(
pipe
==
0
)
?
CURABASE
:
CURBBASE
;
uint32_t
temp
;
size_t
addr
=
0
;
struct
gtt_range
*
gt
;
struct
gtt_range
*
cursor_gt
=
psb_intel_crtc
->
cursor_gt
;
struct
drm_gem_object
*
obj
;
void
*
tmp_dst
,
*
tmp_src
;
int
ret
=
0
,
i
,
cursor_pages
;
/* If we didn't get a handle then turn the cursor off */
if
(
!
handle
)
{
temp
=
CURSOR_MODE_DISABLE
;
if
(
gma_power_begin
(
dev
,
false
))
{
REG_WRITE
(
control
,
temp
);
REG_WRITE
(
base
,
0
);
gma_power_end
(
dev
);
}
/* Unpin the old GEM object */
if
(
psb_intel_crtc
->
cursor_obj
)
{
gt
=
container_of
(
psb_intel_crtc
->
cursor_obj
,
struct
gtt_range
,
gem
);
psb_gtt_unpin
(
gt
);
drm_gem_object_unreference
(
psb_intel_crtc
->
cursor_obj
);
psb_intel_crtc
->
cursor_obj
=
NULL
;
}
return
0
;
}
/* Currently we only support 64x64 cursors */
if
(
width
!=
64
||
height
!=
64
)
{
dev_dbg
(
dev
->
dev
,
"We currently only support 64x64 cursors
\n
"
);
return
-
EINVAL
;
}
obj
=
drm_gem_object_lookup
(
dev
,
file_priv
,
handle
);
if
(
!
obj
)
return
-
ENOENT
;
if
(
obj
->
size
<
width
*
height
*
4
)
{
dev_dbg
(
dev
->
dev
,
"Buffer is too small
\n
"
);
ret
=
-
ENOMEM
;
goto
unref_cursor
;
}
gt
=
container_of
(
obj
,
struct
gtt_range
,
gem
);
/* Pin the memory into the GTT */
ret
=
psb_gtt_pin
(
gt
);
if
(
ret
)
{
dev_err
(
dev
->
dev
,
"Can not pin down handle 0x%x
\n
"
,
handle
);
goto
unref_cursor
;
}
if
(
dev_priv
->
ops
->
cursor_needs_phys
)
{
if
(
cursor_gt
==
NULL
)
{
dev_err
(
dev
->
dev
,
"No hardware cursor mem available"
);
ret
=
-
ENOMEM
;
goto
unref_cursor
;
}
/* Prevent overflow */
if
(
gt
->
npage
>
4
)
cursor_pages
=
4
;
else
cursor_pages
=
gt
->
npage
;
/* Copy the cursor to cursor mem */
tmp_dst
=
dev_priv
->
vram_addr
+
cursor_gt
->
offset
;
for
(
i
=
0
;
i
<
cursor_pages
;
i
++
)
{
tmp_src
=
kmap
(
gt
->
pages
[
i
]);
memcpy
(
tmp_dst
,
tmp_src
,
PAGE_SIZE
);
kunmap
(
gt
->
pages
[
i
]);
tmp_dst
+=
PAGE_SIZE
;
}
addr
=
psb_intel_crtc
->
cursor_addr
;
}
else
{
addr
=
gt
->
offset
;
psb_intel_crtc
->
cursor_addr
=
addr
;
}
temp
=
0
;
/* set the pipe for the cursor */
temp
|=
(
pipe
<<
28
);
temp
|=
CURSOR_MODE_64_ARGB_AX
|
MCURSOR_GAMMA_ENABLE
;
if
(
gma_power_begin
(
dev
,
false
))
{
REG_WRITE
(
control
,
temp
);
REG_WRITE
(
base
,
addr
);
gma_power_end
(
dev
);
}
/* unpin the old bo */
if
(
psb_intel_crtc
->
cursor_obj
)
{
gt
=
container_of
(
psb_intel_crtc
->
cursor_obj
,
struct
gtt_range
,
gem
);
psb_gtt_unpin
(
gt
);
drm_gem_object_unreference
(
psb_intel_crtc
->
cursor_obj
);
}
psb_intel_crtc
->
cursor_obj
=
obj
;
return
ret
;
unref_cursor:
drm_gem_object_unreference
(
obj
);
return
ret
;
}
int
gma_crtc_cursor_move
(
struct
drm_crtc
*
crtc
,
int
x
,
int
y
)
{
struct
drm_device
*
dev
=
crtc
->
dev
;
struct
psb_intel_crtc
*
psb_intel_crtc
=
to_psb_intel_crtc
(
crtc
);
int
pipe
=
psb_intel_crtc
->
pipe
;
uint32_t
temp
=
0
;
uint32_t
addr
;
if
(
x
<
0
)
{
temp
|=
(
CURSOR_POS_SIGN
<<
CURSOR_X_SHIFT
);
x
=
-
x
;
}
if
(
y
<
0
)
{
temp
|=
(
CURSOR_POS_SIGN
<<
CURSOR_Y_SHIFT
);
y
=
-
y
;
}
temp
|=
((
x
&
CURSOR_POS_MASK
)
<<
CURSOR_X_SHIFT
);
temp
|=
((
y
&
CURSOR_POS_MASK
)
<<
CURSOR_Y_SHIFT
);
addr
=
psb_intel_crtc
->
cursor_addr
;
if
(
gma_power_begin
(
dev
,
false
))
{
REG_WRITE
((
pipe
==
0
)
?
CURAPOS
:
CURBPOS
,
temp
);
REG_WRITE
((
pipe
==
0
)
?
CURABASE
:
CURBBASE
,
addr
);
gma_power_end
(
dev
);
}
return
0
;
}
bool
gma_crtc_mode_fixup
(
struct
drm_crtc
*
crtc
,
const
struct
drm_display_mode
*
mode
,
struct
drm_display_mode
*
adjusted_mode
)
...
...
drivers/gpu/drm/gma500/gma_display.h
浏览文件 @
38945be6
...
...
@@ -64,6 +64,11 @@ extern bool gma_pipe_has_type(struct drm_crtc *crtc, int type);
extern
void
gma_wait_for_vblank
(
struct
drm_device
*
dev
);
extern
int
gma_pipe_set_base
(
struct
drm_crtc
*
crtc
,
int
x
,
int
y
,
struct
drm_framebuffer
*
old_fb
);
extern
int
gma_crtc_cursor_set
(
struct
drm_crtc
*
crtc
,
struct
drm_file
*
file_priv
,
uint32_t
handle
,
uint32_t
width
,
uint32_t
height
);
extern
int
gma_crtc_cursor_move
(
struct
drm_crtc
*
crtc
,
int
x
,
int
y
);
extern
void
gma_crtc_load_lut
(
struct
drm_crtc
*
crtc
);
extern
void
gma_crtc_gamma_set
(
struct
drm_crtc
*
crtc
,
u16
*
red
,
u16
*
green
,
u16
*
blue
,
u32
start
,
u32
size
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录