Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
15cace59
K
Kernel
项目概览
openeuler
/
Kernel
1 年多 前同步成功
通知
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看板
提交
15cace59
编写于
5月 13, 2013
作者:
B
Ben Skeggs
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
drm/nvc0/vm: handle bar tlb flushes internally
Signed-off-by:
N
Ben Skeggs
<
bskeggs@redhat.com
>
上级
ca97a366
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
28 addition
and
34 deletion
+28
-34
drivers/gpu/drm/nouveau/core/include/subdev/vm.h
drivers/gpu/drm/nouveau/core/include/subdev/vm.h
+0
-2
drivers/gpu/drm/nouveau/core/subdev/bar/nvc0.c
drivers/gpu/drm/nouveau/core/subdev/bar/nvc0.c
+4
-6
drivers/gpu/drm/nouveau/core/subdev/vm/nvc0.c
drivers/gpu/drm/nouveau/core/subdev/vm/nvc0.c
+24
-26
未找到文件。
drivers/gpu/drm/nouveau/core/include/subdev/vm.h
浏览文件 @
15cace59
...
@@ -117,8 +117,6 @@ int nv04_vm_create(struct nouveau_vmmgr *, u64, u64, u64,
...
@@ -117,8 +117,6 @@ int nv04_vm_create(struct nouveau_vmmgr *, u64, u64, u64,
struct
nouveau_vm
**
);
struct
nouveau_vm
**
);
void
nv04_vmmgr_dtor
(
struct
nouveau_object
*
);
void
nv04_vmmgr_dtor
(
struct
nouveau_object
*
);
void
nvc0_vm_flush_engine
(
struct
nouveau_subdev
*
,
u64
addr
,
int
type
);
/* nouveau_vm.c */
/* nouveau_vm.c */
int
nouveau_vm_create
(
struct
nouveau_vmmgr
*
,
u64
offset
,
u64
length
,
int
nouveau_vm_create
(
struct
nouveau_vmmgr
*
,
u64
offset
,
u64
length
,
u64
mm_offset
,
u32
block
,
struct
nouveau_vm
**
);
u64
mm_offset
,
u32
block
,
struct
nouveau_vm
**
);
...
...
drivers/gpu/drm/nouveau/core/subdev/bar/nvc0.c
浏览文件 @
15cace59
...
@@ -51,7 +51,6 @@ nvc0_bar_kmap(struct nouveau_bar *bar, struct nouveau_mem *mem,
...
@@ -51,7 +51,6 @@ nvc0_bar_kmap(struct nouveau_bar *bar, struct nouveau_mem *mem,
return
ret
;
return
ret
;
nouveau_vm_map
(
vma
,
mem
);
nouveau_vm_map
(
vma
,
mem
);
nvc0_vm_flush_engine
(
nv_subdev
(
bar
),
priv
->
bar
[
0
].
pgd
->
addr
,
5
);
return
0
;
return
0
;
}
}
...
@@ -68,18 +67,13 @@ nvc0_bar_umap(struct nouveau_bar *bar, struct nouveau_mem *mem,
...
@@ -68,18 +67,13 @@ nvc0_bar_umap(struct nouveau_bar *bar, struct nouveau_mem *mem,
return
ret
;
return
ret
;
nouveau_vm_map
(
vma
,
mem
);
nouveau_vm_map
(
vma
,
mem
);
nvc0_vm_flush_engine
(
nv_subdev
(
bar
),
priv
->
bar
[
1
].
pgd
->
addr
,
5
);
return
0
;
return
0
;
}
}
static
void
static
void
nvc0_bar_unmap
(
struct
nouveau_bar
*
bar
,
struct
nouveau_vma
*
vma
)
nvc0_bar_unmap
(
struct
nouveau_bar
*
bar
,
struct
nouveau_vma
*
vma
)
{
{
struct
nvc0_bar_priv
*
priv
=
(
void
*
)
bar
;
int
i
=
!
(
vma
->
vm
==
priv
->
bar
[
0
].
vm
);
nouveau_vm_unmap
(
vma
);
nouveau_vm_unmap
(
vma
);
nvc0_vm_flush_engine
(
nv_subdev
(
bar
),
priv
->
bar
[
i
].
pgd
->
addr
,
5
);
nouveau_vm_put
(
vma
);
nouveau_vm_put
(
vma
);
}
}
...
@@ -116,6 +110,8 @@ nvc0_bar_ctor(struct nouveau_object *parent, struct nouveau_object *engine,
...
@@ -116,6 +110,8 @@ nvc0_bar_ctor(struct nouveau_object *parent, struct nouveau_object *engine,
if
(
ret
)
if
(
ret
)
return
ret
;
return
ret
;
atomic_inc
(
&
vm
->
engref
[
NVDEV_SUBDEV_BAR
]);
ret
=
nouveau_gpuobj_new
(
nv_object
(
priv
),
NULL
,
ret
=
nouveau_gpuobj_new
(
nv_object
(
priv
),
NULL
,
(
pci_resource_len
(
pdev
,
3
)
>>
12
)
*
8
,
(
pci_resource_len
(
pdev
,
3
)
>>
12
)
*
8
,
0x1000
,
NVOBJ_FLAG_ZERO_ALLOC
,
0x1000
,
NVOBJ_FLAG_ZERO_ALLOC
,
...
@@ -150,6 +146,8 @@ nvc0_bar_ctor(struct nouveau_object *parent, struct nouveau_object *engine,
...
@@ -150,6 +146,8 @@ nvc0_bar_ctor(struct nouveau_object *parent, struct nouveau_object *engine,
if
(
ret
)
if
(
ret
)
return
ret
;
return
ret
;
atomic_inc
(
&
vm
->
engref
[
NVDEV_SUBDEV_BAR
]);
ret
=
nouveau_vm_ref
(
vm
,
&
priv
->
bar
[
1
].
vm
,
priv
->
bar
[
1
].
pgd
);
ret
=
nouveau_vm_ref
(
vm
,
&
priv
->
bar
[
1
].
vm
,
priv
->
bar
[
1
].
pgd
);
nouveau_vm_ref
(
NULL
,
&
vm
,
NULL
);
nouveau_vm_ref
(
NULL
,
&
vm
,
NULL
);
if
(
ret
)
if
(
ret
)
...
...
drivers/gpu/drm/nouveau/core/subdev/vm/nvc0.c
浏览文件 @
15cace59
...
@@ -159,39 +159,37 @@ nvc0_vm_unmap(struct nouveau_gpuobj *pgt, u32 pte, u32 cnt)
...
@@ -159,39 +159,37 @@ nvc0_vm_unmap(struct nouveau_gpuobj *pgt, u32 pte, u32 cnt)
}
}
}
}
void
nvc0_vm_flush_engine
(
struct
nouveau_subdev
*
subdev
,
u64
addr
,
int
type
)
{
struct
nvc0_vmmgr_priv
*
priv
=
(
void
*
)
nouveau_vmmgr
(
subdev
);
/* looks like maybe a "free flush slots" counter, the
* faster you write to 0x100cbc to more it decreases
*/
mutex_lock
(
&
nv_subdev
(
priv
)
->
mutex
);
if
(
!
nv_wait_ne
(
subdev
,
0x100c80
,
0x00ff0000
,
0x00000000
))
{
nv_error
(
subdev
,
"vm timeout 0: 0x%08x %d
\n
"
,
nv_rd32
(
subdev
,
0x100c80
),
type
);
}
nv_wr32
(
subdev
,
0x100cb8
,
addr
>>
8
);
nv_wr32
(
subdev
,
0x100cbc
,
0x80000000
|
type
);
/* wait for flush to be queued? */
if
(
!
nv_wait
(
subdev
,
0x100c80
,
0x00008000
,
0x00008000
))
{
nv_error
(
subdev
,
"vm timeout 1: 0x%08x %d
\n
"
,
nv_rd32
(
subdev
,
0x100c80
),
type
);
}
mutex_unlock
(
&
nv_subdev
(
priv
)
->
mutex
);
}
static
void
static
void
nvc0_vm_flush
(
struct
nouveau_vm
*
vm
)
nvc0_vm_flush
(
struct
nouveau_vm
*
vm
)
{
{
struct
nvc0_vmmgr_priv
*
priv
=
(
void
*
)
vm
->
vmm
;
struct
nouveau_vm_pgd
*
vpgd
;
struct
nouveau_vm_pgd
*
vpgd
;
u32
type
;
type
=
0x00000001
;
/* PAGE_ALL */
if
(
atomic_read
(
&
vm
->
engref
[
NVDEV_SUBDEV_BAR
]))
type
|=
0x00000004
;
/* HUB_ONLY */
mutex_lock
(
&
nv_subdev
(
priv
)
->
mutex
);
list_for_each_entry
(
vpgd
,
&
vm
->
pgd_list
,
head
)
{
list_for_each_entry
(
vpgd
,
&
vm
->
pgd_list
,
head
)
{
nvc0_vm_flush_engine
(
nv_subdev
(
vm
->
vmm
),
vpgd
->
obj
->
addr
,
1
);
/* looks like maybe a "free flush slots" counter, the
* faster you write to 0x100cbc to more it decreases
*/
if
(
!
nv_wait_ne
(
priv
,
0x100c80
,
0x00ff0000
,
0x00000000
))
{
nv_error
(
priv
,
"vm timeout 0: 0x%08x %d
\n
"
,
nv_rd32
(
priv
,
0x100c80
),
type
);
}
nv_wr32
(
priv
,
0x100cb8
,
vpgd
->
obj
->
addr
>>
8
);
nv_wr32
(
priv
,
0x100cbc
,
0x80000000
|
type
);
/* wait for flush to be queued? */
if
(
!
nv_wait
(
priv
,
0x100c80
,
0x00008000
,
0x00008000
))
{
nv_error
(
priv
,
"vm timeout 1: 0x%08x %d
\n
"
,
nv_rd32
(
priv
,
0x100c80
),
type
);
}
}
}
mutex_unlock
(
&
nv_subdev
(
priv
)
->
mutex
);
}
}
static
int
static
int
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录