Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
009ee7a0
cloud-kernel
项目概览
openanolis
/
cloud-kernel
大约 1 年 前同步成功
通知
158
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看板
体验新版 GitCode,发现更多精彩内容 >>
提交
009ee7a0
编写于
6月 04, 2012
作者:
A
Alex Deucher
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
drm/radeon/kms: add support for dma rings to radeon_test_moves()
Signed-off-by:
N
Alex Deucher
<
alexander.deucher@amd.com
>
上级
8c5fd7ef
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
33 addition
and
4 deletion
+33
-4
drivers/gpu/drm/radeon/radeon_test.c
drivers/gpu/drm/radeon/radeon_test.c
+33
-4
未找到文件。
drivers/gpu/drm/radeon/radeon_test.c
浏览文件 @
009ee7a0
...
...
@@ -26,16 +26,31 @@
#include "radeon_reg.h"
#include "radeon.h"
#define RADEON_TEST_COPY_BLIT 1
#define RADEON_TEST_COPY_DMA 0
/* Test BO GTT->VRAM and VRAM->GTT GPU copies across the whole GTT aperture */
void
radeon_test_moves
(
struct
radeon_device
*
rdev
)
static
void
radeon_do_test_moves
(
struct
radeon_device
*
rdev
,
int
flag
)
{
struct
radeon_bo
*
vram_obj
=
NULL
;
struct
radeon_bo
**
gtt_obj
=
NULL
;
struct
radeon_fence
*
fence
=
NULL
;
uint64_t
gtt_addr
,
vram_addr
;
unsigned
i
,
n
,
size
;
int
r
;
int
r
,
ring
;
switch
(
flag
)
{
case
RADEON_TEST_COPY_DMA
:
ring
=
radeon_copy_dma_ring_index
(
rdev
);
break
;
case
RADEON_TEST_COPY_BLIT
:
ring
=
radeon_copy_blit_ring_index
(
rdev
);
break
;
default:
DRM_ERROR
(
"Unknown copy method
\n
"
);
return
;
}
size
=
1024
*
1024
;
...
...
@@ -106,7 +121,10 @@ void radeon_test_moves(struct radeon_device *rdev)
radeon_bo_kunmap
(
gtt_obj
[
i
]);
r
=
radeon_copy
(
rdev
,
gtt_addr
,
vram_addr
,
size
/
RADEON_GPU_PAGE_SIZE
,
&
fence
);
if
(
ring
==
R600_RING_TYPE_DMA_INDEX
)
r
=
radeon_copy_dma
(
rdev
,
gtt_addr
,
vram_addr
,
size
/
RADEON_GPU_PAGE_SIZE
,
&
fence
);
else
r
=
radeon_copy_blit
(
rdev
,
gtt_addr
,
vram_addr
,
size
/
RADEON_GPU_PAGE_SIZE
,
&
fence
);
if
(
r
)
{
DRM_ERROR
(
"Failed GTT->VRAM copy %d
\n
"
,
i
);
goto
out_cleanup
;
...
...
@@ -149,7 +167,10 @@ void radeon_test_moves(struct radeon_device *rdev)
radeon_bo_kunmap
(
vram_obj
);
r
=
radeon_copy
(
rdev
,
vram_addr
,
gtt_addr
,
size
/
RADEON_GPU_PAGE_SIZE
,
&
fence
);
if
(
ring
==
R600_RING_TYPE_DMA_INDEX
)
r
=
radeon_copy_dma
(
rdev
,
vram_addr
,
gtt_addr
,
size
/
RADEON_GPU_PAGE_SIZE
,
&
fence
);
else
r
=
radeon_copy_blit
(
rdev
,
vram_addr
,
gtt_addr
,
size
/
RADEON_GPU_PAGE_SIZE
,
&
fence
);
if
(
r
)
{
DRM_ERROR
(
"Failed VRAM->GTT copy %d
\n
"
,
i
);
goto
out_cleanup
;
...
...
@@ -223,6 +244,14 @@ void radeon_test_moves(struct radeon_device *rdev)
}
}
void
radeon_test_moves
(
struct
radeon_device
*
rdev
)
{
if
(
rdev
->
asic
->
copy
.
dma
)
radeon_do_test_moves
(
rdev
,
RADEON_TEST_COPY_DMA
);
if
(
rdev
->
asic
->
copy
.
blit
)
radeon_do_test_moves
(
rdev
,
RADEON_TEST_COPY_BLIT
);
}
void
radeon_test_ring_sync
(
struct
radeon_device
*
rdev
,
struct
radeon_ring
*
ringA
,
struct
radeon_ring
*
ringB
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录