Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
raspberrypi-kernel
提交
96545299
R
raspberrypi-kernel
项目概览
openeuler
/
raspberrypi-kernel
通知
13
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
raspberrypi-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
96545299
编写于
11月 24, 2010
作者:
B
Ben Skeggs
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
drm/nvc0: fix channel dma init paths
Signed-off-by:
N
Ben Skeggs
<
bskeggs@redhat.com
>
上级
5216782b
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
38 addition
and
10 deletion
+38
-10
drivers/gpu/drm/nouveau/nouveau_channel.c
drivers/gpu/drm/nouveau/nouveau_channel.c
+16
-4
drivers/gpu/drm/nouveau/nouveau_dma.c
drivers/gpu/drm/nouveau/nouveau_dma.c
+16
-6
drivers/gpu/drm/nouveau/nouveau_dma.h
drivers/gpu/drm/nouveau/nouveau_dma.h
+6
-0
未找到文件。
drivers/gpu/drm/nouveau/nouveau_channel.c
浏览文件 @
96545299
...
...
@@ -38,9 +38,14 @@ nouveau_channel_pushbuf_ctxdma_init(struct nouveau_channel *chan)
int
ret
;
if
(
dev_priv
->
card_type
>=
NV_50
)
{
ret
=
nouveau_gpuobj_dma_new
(
chan
,
NV_CLASS_DMA_IN_MEMORY
,
0
,
(
1ULL
<<
40
),
NV_MEM_ACCESS_RO
,
NV_MEM_TARGET_VM
,
&
pushbuf
);
if
(
dev_priv
->
card_type
<
NV_C0
)
{
ret
=
nouveau_gpuobj_dma_new
(
chan
,
NV_CLASS_DMA_IN_MEMORY
,
0
,
(
1ULL
<<
40
),
NV_MEM_ACCESS_RO
,
NV_MEM_TARGET_VM
,
&
pushbuf
);
}
chan
->
pushbuf_base
=
pb
->
bo
.
offset
;
}
else
if
(
pb
->
bo
.
mem
.
mem_type
==
TTM_PL_TT
)
{
...
...
@@ -71,7 +76,7 @@ nouveau_channel_pushbuf_ctxdma_init(struct nouveau_channel *chan)
nouveau_gpuobj_ref
(
pushbuf
,
&
chan
->
pushbuf
);
nouveau_gpuobj_ref
(
NULL
,
&
pushbuf
);
return
0
;
return
ret
;
}
static
struct
nouveau_bo
*
...
...
@@ -99,6 +104,13 @@ nouveau_channel_user_pushbuf_alloc(struct drm_device *dev)
return
NULL
;
}
ret
=
nouveau_bo_map
(
pushbuf
);
if
(
ret
)
{
nouveau_bo_unpin
(
pushbuf
);
nouveau_bo_ref
(
NULL
,
&
pushbuf
);
return
NULL
;
}
return
pushbuf
;
}
...
...
drivers/gpu/drm/nouveau/nouveau_dma.c
浏览文件 @
96545299
...
...
@@ -36,7 +36,7 @@ nouveau_dma_pre_init(struct nouveau_channel *chan)
struct
drm_nouveau_private
*
dev_priv
=
chan
->
dev
->
dev_private
;
struct
nouveau_bo
*
pushbuf
=
chan
->
pushbuf_bo
;
if
(
dev_priv
->
card_type
=
=
NV_50
)
{
if
(
dev_priv
->
card_type
>
=
NV_50
)
{
const
int
ib_size
=
pushbuf
->
bo
.
mem
.
size
/
2
;
chan
->
dma
.
ib_base
=
(
pushbuf
->
bo
.
mem
.
size
-
ib_size
)
>>
2
;
...
...
@@ -61,6 +61,21 @@ nouveau_dma_init(struct nouveau_channel *chan)
struct
drm_nouveau_private
*
dev_priv
=
dev
->
dev_private
;
int
ret
,
i
;
if
(
dev_priv
->
card_type
>=
NV_C0
)
{
ret
=
nouveau_gpuobj_gr_new
(
chan
,
0x9039
,
0x9039
);
if
(
ret
)
return
ret
;
ret
=
RING_SPACE
(
chan
,
2
);
if
(
ret
)
return
ret
;
BEGIN_NVC0
(
chan
,
2
,
NvSubM2MF
,
0x0000
,
1
);
OUT_RING
(
chan
,
0x00009039
);
FIRE_RING
(
chan
);
return
0
;
}
/* Create NV_MEMORY_TO_MEMORY_FORMAT for buffer moves */
ret
=
nouveau_gpuobj_gr_new
(
chan
,
NvM2MF
,
dev_priv
->
card_type
<
NV_50
?
0x0039
:
0x5039
);
...
...
@@ -72,11 +87,6 @@ nouveau_dma_init(struct nouveau_channel *chan)
if
(
ret
)
return
ret
;
/* Map push buffer */
ret
=
nouveau_bo_map
(
chan
->
pushbuf_bo
);
if
(
ret
)
return
ret
;
/* Insert NOPS for NOUVEAU_DMA_SKIPS */
ret
=
RING_SPACE
(
chan
,
NOUVEAU_DMA_SKIPS
);
if
(
ret
)
...
...
drivers/gpu/drm/nouveau/nouveau_dma.h
浏览文件 @
96545299
...
...
@@ -124,6 +124,12 @@ OUT_RING(struct nouveau_channel *chan, int data)
extern
void
OUT_RINGp
(
struct
nouveau_channel
*
chan
,
const
void
*
data
,
unsigned
nr_dwords
);
static
inline
void
BEGIN_NVC0
(
struct
nouveau_channel
*
chan
,
int
op
,
int
subc
,
int
mthd
,
int
size
)
{
OUT_RING
(
chan
,
(
op
<<
28
)
|
(
size
<<
16
)
|
(
subc
<<
13
)
|
(
mthd
>>
2
));
}
static
inline
void
BEGIN_RING
(
struct
nouveau_channel
*
chan
,
int
subc
,
int
mthd
,
int
size
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录