Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
957e18a7
cloud-kernel
项目概览
openanolis
/
cloud-kernel
1 年多 前同步成功
通知
163
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看板
提交
957e18a7
编写于
7年前
作者:
B
Ben Skeggs
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
drm/nouveau/mmu/nv04-nv4x: type-based vram allocation and bar mapping
Signed-off-by:
N
Ben Skeggs
<
bskeggs@redhat.com
>
上级
eaf1a691
master
alk-4.19.24
alk-4.19.30
alk-4.19.34
alk-4.19.36
alk-4.19.43
alk-4.19.48
alk-4.19.57
ck-4.19.67
ck-4.19.81
ck-4.19.91
github/fork/deepanshu1422/fix-typo-in-comment
github/fork/haosdent/fix-typo
linux-next
v4.19.91
v4.19.90
v4.19.89
v4.19.88
v4.19.87
v4.19.86
v4.19.85
v4.19.84
v4.19.83
v4.19.82
v4.19.81
v4.19.80
v4.19.79
v4.19.78
v4.19.77
v4.19.76
v4.19.75
v4.19.74
v4.19.73
v4.19.72
v4.19.71
v4.19.70
v4.19.69
v4.19.68
v4.19.67
v4.19.66
v4.19.65
v4.19.64
v4.19.63
v4.19.62
v4.19.61
v4.19.60
v4.19.59
v4.19.58
v4.19.57
v4.19.56
v4.19.55
v4.19.54
v4.19.53
v4.19.52
v4.19.51
v4.19.50
v4.19.49
v4.19.48
v4.19.47
v4.19.46
v4.19.45
v4.19.44
v4.19.43
v4.19.42
v4.19.41
v4.19.40
v4.19.39
v4.19.38
v4.19.37
v4.19.36
v4.19.35
v4.19.34
v4.19.33
v4.19.32
v4.19.31
v4.19.30
v4.19.29
v4.19.28
v4.19.27
v4.19.26
v4.19.25
v4.19.24
v4.19.23
v4.19.22
v4.19.21
v4.19.20
v4.19.19
v4.19.18
v4.19.17
v4.19.16
v4.19.15
v4.19.14
v4.19.13
v4.19.12
v4.19.11
v4.19.10
v4.19.9
v4.19.8
v4.19.7
v4.19.6
v4.19.5
v4.19.4
v4.19.3
v4.19.2
v4.19.1
v4.19
v4.19-rc8
v4.19-rc7
v4.19-rc6
v4.19-rc5
v4.19-rc4
v4.19-rc3
v4.19-rc2
v4.19-rc1
ck-release-21
ck-release-20
ck-release-19.2
ck-release-19.1
ck-release-19
ck-release-18
ck-release-17.2
ck-release-17.1
ck-release-17
ck-release-16
ck-release-15.1
ck-release-15
ck-release-14
ck-release-13.2
ck-release-13
ck-release-12
ck-release-11
ck-release-10
ck-release-9
ck-release-7
alk-release-15
alk-release-14
alk-release-13.2
alk-release-13
alk-release-12
alk-release-11
alk-release-10
alk-release-9
alk-release-7
无相关合并请求
变更
8
隐藏空白更改
内联
并排
Showing
8 changed file
with
93 addition
and
0 deletion
+93
-0
drivers/gpu/drm/nouveau/include/nvif/class.h
drivers/gpu/drm/nouveau/include/nvif/class.h
+1
-0
drivers/gpu/drm/nouveau/include/nvif/if000b.h
drivers/gpu/drm/nouveau/include/nvif/if000b.h
+11
-0
drivers/gpu/drm/nouveau/nvkm/subdev/mmu/Kbuild
drivers/gpu/drm/nouveau/nvkm/subdev/mmu/Kbuild
+1
-0
drivers/gpu/drm/nouveau/nvkm/subdev/mmu/mem.h
drivers/gpu/drm/nouveau/nvkm/subdev/mmu/mem.h
+5
-0
drivers/gpu/drm/nouveau/nvkm/subdev/mmu/memnv04.c
drivers/gpu/drm/nouveau/nvkm/subdev/mmu/memnv04.c
+69
-0
drivers/gpu/drm/nouveau/nvkm/subdev/mmu/nv04.c
drivers/gpu/drm/nouveau/nvkm/subdev/mmu/nv04.c
+2
-0
drivers/gpu/drm/nouveau/nvkm/subdev/mmu/nv41.c
drivers/gpu/drm/nouveau/nvkm/subdev/mmu/nv41.c
+2
-0
drivers/gpu/drm/nouveau/nvkm/subdev/mmu/nv44.c
drivers/gpu/drm/nouveau/nvkm/subdev/mmu/nv44.c
+2
-0
未找到文件。
drivers/gpu/drm/nouveau/include/nvif/class.h
浏览文件 @
957e18a7
...
...
@@ -15,6 +15,7 @@
#define NVIF_CLASS_SW_GF100
/* if0005.h */
-0x00000007
#define NVIF_CLASS_MEM
/* if000a.h */
0x8000000a
#define NVIF_CLASS_MEM_NV04
/* if000b.h */
0x8000000b
#define NVIF_CLASS_VMM
/* if000c.h */
0x8000000c
#define NVIF_CLASS_VMM_NV04
/* if000d.h */
0x8000000d
...
...
This diff is collapsed.
Click to expand it.
drivers/gpu/drm/nouveau/include/nvif/if000b.h
0 → 100644
浏览文件 @
957e18a7
#ifndef __NVIF_IF000B_H__
#define __NVIF_IF000B_H__
#include "if000a.h"
struct
nv04_mem_vn
{
/* nvkm_mem_vX ... */
};
struct
nv04_mem_map_vn
{
};
#endif
This diff is collapsed.
Click to expand it.
drivers/gpu/drm/nouveau/nvkm/subdev/mmu/Kbuild
浏览文件 @
957e18a7
...
...
@@ -13,6 +13,7 @@ nvkm-y += nvkm/subdev/mmu/gp100.o
nvkm-y += nvkm/subdev/mmu/gp10b.o
nvkm-y += nvkm/subdev/mmu/mem.o
nvkm-y += nvkm/subdev/mmu/memnv04.o
nvkm-y += nvkm/subdev/mmu/vmm.o
nvkm-y += nvkm/subdev/mmu/vmmnv04.o
...
...
This diff is collapsed.
Click to expand it.
drivers/gpu/drm/nouveau/nvkm/subdev/mmu/mem.h
浏览文件 @
957e18a7
...
...
@@ -5,4 +5,9 @@
int
nvkm_mem_new_type
(
struct
nvkm_mmu
*
,
int
type
,
u8
page
,
u64
size
,
void
*
argv
,
u32
argc
,
struct
nvkm_memory
**
);
int
nvkm_mem_map_host
(
struct
nvkm_memory
*
,
void
**
pmap
);
int
nv04_mem_new
(
struct
nvkm_mmu
*
,
int
,
u8
,
u64
,
void
*
,
u32
,
struct
nvkm_memory
**
);
int
nv04_mem_map
(
struct
nvkm_mmu
*
,
struct
nvkm_memory
*
,
void
*
,
u32
,
u64
*
,
u64
*
,
struct
nvkm_vma
**
);
#endif
This diff is collapsed.
Click to expand it.
drivers/gpu/drm/nouveau/nvkm/subdev/mmu/memnv04.c
0 → 100644
浏览文件 @
957e18a7
/*
* Copyright 2017 Red Hat Inc.
*
* Permission is hereby granted, free of charge, to any person obtaining a
* copy of this software and associated documentation files (the "Software"),
* to deal in the Software without restriction, including without limitation
* the rights to use, copy, modify, merge, publish, distribute, sublicense,
* and/or sell copies of the Software, and to permit persons to whom the
* Software is furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
* THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
* OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
* OTHER DEALINGS IN THE SOFTWARE.
*/
#include "mem.h"
#include <core/memory.h>
#include <subdev/fb.h>
#include <nvif/if000b.h>
#include <nvif/unpack.h>
int
nv04_mem_map
(
struct
nvkm_mmu
*
mmu
,
struct
nvkm_memory
*
memory
,
void
*
argv
,
u32
argc
,
u64
*
paddr
,
u64
*
psize
,
struct
nvkm_vma
**
pvma
)
{
union
{
struct
nv04_mem_map_vn
vn
;
}
*
args
=
argv
;
struct
nvkm_device
*
device
=
mmu
->
subdev
.
device
;
const
u64
addr
=
nvkm_memory_addr
(
memory
);
int
ret
=
-
ENOSYS
;
if
((
ret
=
nvif_unvers
(
ret
,
&
argv
,
&
argc
,
args
->
vn
)))
return
ret
;
*
paddr
=
device
->
func
->
resource_addr
(
device
,
1
)
+
addr
;
*
psize
=
nvkm_memory_size
(
memory
);
*
pvma
=
ERR_PTR
(
-
ENODEV
);
return
0
;
}
int
nv04_mem_new
(
struct
nvkm_mmu
*
mmu
,
int
type
,
u8
page
,
u64
size
,
void
*
argv
,
u32
argc
,
struct
nvkm_memory
**
pmemory
)
{
union
{
struct
nv04_mem_vn
vn
;
}
*
args
=
argv
;
int
ret
=
-
ENOSYS
;
if
((
ret
=
nvif_unvers
(
ret
,
&
argv
,
&
argc
,
args
->
vn
)))
return
ret
;
if
(
mmu
->
type
[
type
].
type
&
NVKM_MEM_MAPPABLE
)
type
=
NVKM_RAM_MM_NORMAL
;
else
type
=
NVKM_RAM_MM_NOMAP
;
return
nvkm_ram_get
(
mmu
->
subdev
.
device
,
type
,
0x01
,
page
,
size
,
true
,
false
,
pmemory
);
}
This diff is collapsed.
Click to expand it.
drivers/gpu/drm/nouveau/nvkm/subdev/mmu/nv04.c
浏览文件 @
957e18a7
...
...
@@ -21,6 +21,7 @@
*
* Authors: Ben Skeggs
*/
#include "mem.h"
#include "vmm.h"
#include <nvif/class.h>
...
...
@@ -32,6 +33,7 @@ nv04_mmu = {
.
limit
=
NV04_PDMA_SIZE
,
.
dma_bits
=
32
,
.
lpg_shift
=
12
,
.
mem
=
{{
-
1
,
-
1
,
NVIF_CLASS_MEM_NV04
},
nv04_mem_new
,
nv04_mem_map
},
.
vmm
=
{{
-
1
,
-
1
,
NVIF_CLASS_VMM_NV04
},
nv04_vmm_new
,
true
},
};
...
...
This diff is collapsed.
Click to expand it.
drivers/gpu/drm/nouveau/nvkm/subdev/mmu/nv41.c
浏览文件 @
957e18a7
...
...
@@ -21,6 +21,7 @@
*
* Authors: Ben Skeggs
*/
#include "mem.h"
#include "vmm.h"
#include <core/option.h>
...
...
@@ -44,6 +45,7 @@ nv41_mmu = {
.
limit
=
NV41_GART_SIZE
,
.
dma_bits
=
39
,
.
lpg_shift
=
12
,
.
mem
=
{{
-
1
,
-
1
,
NVIF_CLASS_MEM_NV04
},
nv04_mem_new
,
nv04_mem_map
},
.
vmm
=
{{
-
1
,
-
1
,
NVIF_CLASS_VMM_NV04
},
nv41_vmm_new
,
true
},
};
...
...
This diff is collapsed.
Click to expand it.
drivers/gpu/drm/nouveau/nvkm/subdev/mmu/nv44.c
浏览文件 @
957e18a7
...
...
@@ -21,6 +21,7 @@
*
* Authors: Ben Skeggs
*/
#include "mem.h"
#include "vmm.h"
#include <core/option.h>
...
...
@@ -59,6 +60,7 @@ nv44_mmu = {
.
limit
=
NV44_GART_SIZE
,
.
dma_bits
=
39
,
.
lpg_shift
=
12
,
.
mem
=
{{
-
1
,
-
1
,
NVIF_CLASS_MEM_NV04
},
nv04_mem_new
,
nv04_mem_map
},
.
vmm
=
{{
-
1
,
-
1
,
NVIF_CLASS_VMM_NV04
},
nv44_vmm_new
,
true
},
};
...
...
This diff is collapsed.
Click to expand it.
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录
反馈
建议
客服
返回
顶部