Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
raspberrypi-kernel
提交
cb1d771a
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看板
提交
cb1d771a
编写于
1月 28, 2011
作者:
B
Ben Skeggs
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
drm/nvc0: implement semaphores for inter-channel sync
Signed-off-by:
N
Ben Skeggs
<
bskeggs@redhat.com
>
上级
cc8cd647
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
40 addition
and
12 deletion
+40
-12
drivers/gpu/drm/nouveau/nouveau_fence.c
drivers/gpu/drm/nouveau/nouveau_fence.c
+40
-12
未找到文件。
drivers/gpu/drm/nouveau/nouveau_fence.c
浏览文件 @
cb1d771a
...
...
@@ -32,8 +32,7 @@
#include "nouveau_dma.h"
#define USE_REFCNT(dev) (nouveau_private(dev)->chipset >= 0x10)
#define USE_SEMA(dev) (nouveau_private(dev)->chipset >= 0x17 && \
nouveau_private(dev)->card_type < NV_C0)
#define USE_SEMA(dev) (nouveau_private(dev)->chipset >= 0x17)
struct
nouveau_fence
{
struct
nouveau_channel
*
channel
;
...
...
@@ -338,7 +337,8 @@ semaphore_acquire(struct nouveau_channel *chan, struct nouveau_semaphore *sema)
BEGIN_RING
(
chan
,
NvSubSw
,
NV_SW_SEMAPHORE_OFFSET
,
2
);
OUT_RING
(
chan
,
sema
->
mem
->
start
);
OUT_RING
(
chan
,
1
);
}
else
{
}
else
if
(
dev_priv
->
chipset
<
0xc0
)
{
/*
* NV50 tries to be too smart and context-switch
* between semaphores instead of doing a "first come,
...
...
@@ -367,6 +367,19 @@ semaphore_acquire(struct nouveau_channel *chan, struct nouveau_semaphore *sema)
OUT_RING
(
chan
,
lower_32_bits
(
sema
->
mem
->
start
));
OUT_RING
(
chan
,
1
);
OUT_RING
(
chan
,
1
);
/* ACQUIRE_EQ */
}
else
{
struct
nouveau_vma
*
vma
=
&
dev_priv
->
fence
.
bo
->
vma
;
u64
offset
=
vma
->
offset
+
sema
->
mem
->
start
;
ret
=
RING_SPACE
(
chan
,
5
);
if
(
ret
)
return
ret
;
BEGIN_NVC0
(
chan
,
2
,
NvSubM2MF
,
0x0010
,
4
);
OUT_RING
(
chan
,
upper_32_bits
(
offset
));
OUT_RING
(
chan
,
lower_32_bits
(
offset
));
OUT_RING
(
chan
,
1
);
OUT_RING
(
chan
,
0x1001
);
/* ACQUIRE_EQ */
}
/* Delay semaphore destruction until its work is done */
...
...
@@ -396,7 +409,8 @@ semaphore_release(struct nouveau_channel *chan, struct nouveau_semaphore *sema)
OUT_RING
(
chan
,
sema
->
mem
->
start
);
BEGIN_RING
(
chan
,
NvSubSw
,
NV_SW_SEMAPHORE_RELEASE
,
1
);
OUT_RING
(
chan
,
1
);
}
else
{
}
else
if
(
dev_priv
->
chipset
<
0xc0
)
{
/*
* Emits release and forces the card to context switch right
* afterwards, there may be another channel waiting for the
...
...
@@ -414,6 +428,19 @@ semaphore_release(struct nouveau_channel *chan, struct nouveau_semaphore *sema)
OUT_RING
(
chan
,
2
);
/* RELEASE */
BEGIN_RING
(
chan
,
NvSubSw
,
0x0080
,
1
);
OUT_RING
(
chan
,
0
);
}
else
{
struct
nouveau_vma
*
vma
=
&
dev_priv
->
fence
.
bo
->
vma
;
u64
offset
=
vma
->
offset
+
sema
->
mem
->
start
;
ret
=
RING_SPACE
(
chan
,
5
);
if
(
ret
)
return
ret
;
BEGIN_NVC0
(
chan
,
2
,
NvSubM2MF
,
0x0010
,
4
);
OUT_RING
(
chan
,
upper_32_bits
(
offset
));
OUT_RING
(
chan
,
lower_32_bits
(
offset
));
OUT_RING
(
chan
,
1
);
OUT_RING
(
chan
,
0x1002
);
/* RELEASE */
}
/* Delay semaphore destruction until its work is done */
...
...
@@ -489,19 +516,20 @@ nouveau_fence_channel_init(struct nouveau_channel *chan)
struct
nouveau_gpuobj
*
obj
=
NULL
;
int
ret
;
if
(
dev_priv
->
card_type
>=
NV_C0
)
goto
out_initialised
;
/* Create an NV_SW object for various sync purposes */
ret
=
nouveau_gpuobj_gr_new
(
chan
,
NvSw
,
NV_SW
);
if
(
ret
)
return
ret
;
/* we leave subchannel empty for nvc0 */
if
(
dev_priv
->
card_type
<
NV_C0
)
{
ret
=
RING_SPACE
(
chan
,
2
);
if
(
ret
)
return
ret
;
BEGIN_RING
(
chan
,
NvSubSw
,
0
,
1
);
OUT_RING
(
chan
,
NvSw
);
}
ret
=
RING_SPACE
(
chan
,
2
);
if
(
ret
)
return
ret
;
BEGIN_RING
(
chan
,
NvSubSw
,
0
,
1
);
OUT_RING
(
chan
,
NvSw
);
/* Create a DMA object for the shared cross-channel sync area. */
if
(
USE_SEMA
(
dev
))
{
...
...
@@ -528,10 +556,10 @@ nouveau_fence_channel_init(struct nouveau_channel *chan)
FIRE_RING
(
chan
);
out_initialised:
INIT_LIST_HEAD
(
&
chan
->
fence
.
pending
);
spin_lock_init
(
&
chan
->
fence
.
lock
);
atomic_set
(
&
chan
->
fence
.
last_sequence_irq
,
0
);
return
0
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录