Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
d02836b4
K
Kernel
项目概览
openeuler
/
Kernel
接近 2 年 前同步成功
通知
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看板
提交
d02836b4
编写于
6月 07, 2011
作者:
B
Ben Skeggs
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
drm/nv84-nvc0: explicitly map semaphore buffer into channel vm
Signed-off-by:
N
Ben Skeggs
<
bskeggs@redhat.com
>
上级
ce163f69
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
14 addition
and
16 deletion
+14
-16
drivers/gpu/drm/nouveau/nouveau_drv.h
drivers/gpu/drm/nouveau/nouveau_drv.h
+1
-0
drivers/gpu/drm/nouveau/nouveau_fence.c
drivers/gpu/drm/nouveau/nouveau_fence.c
+13
-16
未找到文件。
drivers/gpu/drm/nouveau/nouveau_drv.h
浏览文件 @
d02836b4
...
...
@@ -240,6 +240,7 @@ struct nouveau_channel {
uint32_t
sequence
;
uint32_t
sequence_ack
;
atomic_t
last_sequence_irq
;
struct
nouveau_vma
vma
;
}
fence
;
/* DMA push buffer */
...
...
drivers/gpu/drm/nouveau/nouveau_fence.c
浏览文件 @
d02836b4
...
...
@@ -336,6 +336,7 @@ semaphore_acquire(struct nouveau_channel *chan, struct nouveau_semaphore *sema)
{
struct
drm_nouveau_private
*
dev_priv
=
chan
->
dev
->
dev_private
;
struct
nouveau_fence
*
fence
=
NULL
;
u64
offset
=
chan
->
fence
.
vma
.
offset
+
sema
->
mem
->
start
;
int
ret
;
if
(
dev_priv
->
chipset
<
0x84
)
{
...
...
@@ -345,13 +346,10 @@ semaphore_acquire(struct nouveau_channel *chan, struct nouveau_semaphore *sema)
BEGIN_RING
(
chan
,
NvSubSw
,
NV_SW_DMA_SEMAPHORE
,
3
);
OUT_RING
(
chan
,
NvSema
);
OUT_RING
(
chan
,
sema
->
mem
->
star
t
);
OUT_RING
(
chan
,
offse
t
);
OUT_RING
(
chan
,
1
);
}
else
if
(
dev_priv
->
chipset
<
0xc0
)
{
struct
nouveau_vma
*
vma
=
&
dev_priv
->
fence
.
bo
->
vma
;
u64
offset
=
vma
->
offset
+
sema
->
mem
->
start
;
ret
=
RING_SPACE
(
chan
,
7
);
if
(
ret
)
return
ret
;
...
...
@@ -364,9 +362,6 @@ semaphore_acquire(struct nouveau_channel *chan, struct nouveau_semaphore *sema)
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
;
...
...
@@ -394,6 +389,7 @@ semaphore_release(struct nouveau_channel *chan, struct nouveau_semaphore *sema)
{
struct
drm_nouveau_private
*
dev_priv
=
chan
->
dev
->
dev_private
;
struct
nouveau_fence
*
fence
=
NULL
;
u64
offset
=
chan
->
fence
.
vma
.
offset
+
sema
->
mem
->
start
;
int
ret
;
if
(
dev_priv
->
chipset
<
0x84
)
{
...
...
@@ -403,14 +399,11 @@ semaphore_release(struct nouveau_channel *chan, struct nouveau_semaphore *sema)
BEGIN_RING
(
chan
,
NvSubSw
,
NV_SW_DMA_SEMAPHORE
,
2
);
OUT_RING
(
chan
,
NvSema
);
OUT_RING
(
chan
,
sema
->
mem
->
star
t
);
OUT_RING
(
chan
,
offse
t
);
BEGIN_RING
(
chan
,
NvSubSw
,
NV_SW_SEMAPHORE_RELEASE
,
1
);
OUT_RING
(
chan
,
1
);
}
else
if
(
dev_priv
->
chipset
<
0xc0
)
{
struct
nouveau_vma
*
vma
=
&
dev_priv
->
fence
.
bo
->
vma
;
u64
offset
=
vma
->
offset
+
sema
->
mem
->
start
;
ret
=
RING_SPACE
(
chan
,
7
);
if
(
ret
)
return
ret
;
...
...
@@ -423,9 +416,6 @@ semaphore_release(struct nouveau_channel *chan, struct nouveau_semaphore *sema)
OUT_RING
(
chan
,
1
);
OUT_RING
(
chan
,
2
);
/* RELEASE */
}
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
;
...
...
@@ -540,6 +530,12 @@ nouveau_fence_channel_init(struct nouveau_channel *chan)
nouveau_gpuobj_ref
(
NULL
,
&
obj
);
if
(
ret
)
return
ret
;
}
else
{
/* map fence bo into channel's vm */
ret
=
nouveau_bo_vma_add
(
dev_priv
->
fence
.
bo
,
chan
->
vm
,
&
chan
->
fence
.
vma
);
if
(
ret
)
return
ret
;
}
INIT_LIST_HEAD
(
&
chan
->
fence
.
pending
);
...
...
@@ -551,10 +547,10 @@ nouveau_fence_channel_init(struct nouveau_channel *chan)
void
nouveau_fence_channel_fini
(
struct
nouveau_channel
*
chan
)
{
struct
drm_nouveau_private
*
dev_priv
=
chan
->
dev
->
dev_private
;
struct
nouveau_fence
*
tmp
,
*
fence
;
spin_lock
(
&
chan
->
fence
.
lock
);
list_for_each_entry_safe
(
fence
,
tmp
,
&
chan
->
fence
.
pending
,
entry
)
{
fence
->
signalled
=
true
;
list_del
(
&
fence
->
entry
);
...
...
@@ -564,8 +560,9 @@ nouveau_fence_channel_fini(struct nouveau_channel *chan)
kref_put
(
&
fence
->
refcount
,
nouveau_fence_del
);
}
spin_unlock
(
&
chan
->
fence
.
lock
);
nouveau_bo_vma_del
(
dev_priv
->
fence
.
bo
,
&
chan
->
fence
.
vma
);
}
int
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录