Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
5bca1621
cloud-kernel
项目概览
openanolis
/
cloud-kernel
1 年多 前同步成功
通知
160
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看板
提交
5bca1621
编写于
5月 08, 2018
作者:
B
Ben Skeggs
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
drm/nouveau/kms/nv50-: move fb ctxdma tracking into windows
Signed-off-by:
N
Ben Skeggs
<
bskeggs@redhat.com
>
上级
62b290fc
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
84 addition
and
79 deletion
+84
-79
drivers/gpu/drm/nouveau/dispnv50/disp.c
drivers/gpu/drm/nouveau/dispnv50/disp.c
+84
-79
未找到文件。
drivers/gpu/drm/nouveau/dispnv50/disp.c
浏览文件 @
5bca1621
...
@@ -395,7 +395,7 @@ nv50_oimm_create(struct nvif_device *device, struct nvif_object *disp,
...
@@ -395,7 +395,7 @@ nv50_oimm_create(struct nvif_device *device, struct nvif_object *disp,
* DMA EVO channel
* DMA EVO channel
*****************************************************************************/
*****************************************************************************/
struct
nv50_
dmac
_ctxdma
{
struct
nv50_
wndw
_ctxdma
{
struct
list_head
head
;
struct
list_head
head
;
struct
nvif_object
object
;
struct
nvif_object
object
;
};
};
...
@@ -408,7 +408,6 @@ struct nv50_dmac {
...
@@ -408,7 +408,6 @@ struct nv50_dmac {
struct
nvif_object
sync
;
struct
nvif_object
sync
;
struct
nvif_object
vram
;
struct
nvif_object
vram
;
struct
list_head
ctxdma
;
/* Protects against concurrent pushbuf access to this channel, lock is
/* Protects against concurrent pushbuf access to this channel, lock is
* grabbed by evo_wait (if the pushbuf reservation is successful) and
* grabbed by evo_wait (if the pushbuf reservation is successful) and
...
@@ -416,83 +415,9 @@ struct nv50_dmac {
...
@@ -416,83 +415,9 @@ struct nv50_dmac {
struct
mutex
lock
;
struct
mutex
lock
;
};
};
static
void
nv50_dmac_ctxdma_del
(
struct
nv50_dmac_ctxdma
*
ctxdma
)
{
nvif_object_fini
(
&
ctxdma
->
object
);
list_del
(
&
ctxdma
->
head
);
kfree
(
ctxdma
);
}
static
struct
nv50_dmac_ctxdma
*
nv50_dmac_ctxdma_new
(
struct
nv50_dmac
*
dmac
,
struct
nouveau_framebuffer
*
fb
)
{
struct
nouveau_drm
*
drm
=
nouveau_drm
(
fb
->
base
.
dev
);
struct
nv50_dmac_ctxdma
*
ctxdma
;
const
u8
kind
=
fb
->
nvbo
->
kind
;
const
u32
handle
=
0xfb000000
|
kind
;
struct
{
struct
nv_dma_v0
base
;
union
{
struct
nv50_dma_v0
nv50
;
struct
gf100_dma_v0
gf100
;
struct
gf119_dma_v0
gf119
;
};
}
args
=
{};
u32
argc
=
sizeof
(
args
.
base
);
int
ret
;
list_for_each_entry
(
ctxdma
,
&
dmac
->
ctxdma
,
head
)
{
if
(
ctxdma
->
object
.
handle
==
handle
)
return
ctxdma
;
}
if
(
!
(
ctxdma
=
kzalloc
(
sizeof
(
*
ctxdma
),
GFP_KERNEL
)))
return
ERR_PTR
(
-
ENOMEM
);
list_add
(
&
ctxdma
->
head
,
&
dmac
->
ctxdma
);
args
.
base
.
target
=
NV_DMA_V0_TARGET_VRAM
;
args
.
base
.
access
=
NV_DMA_V0_ACCESS_RDWR
;
args
.
base
.
start
=
0
;
args
.
base
.
limit
=
drm
->
client
.
device
.
info
.
ram_user
-
1
;
if
(
drm
->
client
.
device
.
info
.
chipset
<
0x80
)
{
args
.
nv50
.
part
=
NV50_DMA_V0_PART_256
;
argc
+=
sizeof
(
args
.
nv50
);
}
else
if
(
drm
->
client
.
device
.
info
.
chipset
<
0xc0
)
{
args
.
nv50
.
part
=
NV50_DMA_V0_PART_256
;
args
.
nv50
.
kind
=
kind
;
argc
+=
sizeof
(
args
.
nv50
);
}
else
if
(
drm
->
client
.
device
.
info
.
chipset
<
0xd0
)
{
args
.
gf100
.
kind
=
kind
;
argc
+=
sizeof
(
args
.
gf100
);
}
else
{
args
.
gf119
.
page
=
GF119_DMA_V0_PAGE_LP
;
args
.
gf119
.
kind
=
kind
;
argc
+=
sizeof
(
args
.
gf119
);
}
ret
=
nvif_object_init
(
&
dmac
->
base
.
user
,
handle
,
NV_DMA_IN_MEMORY
,
&
args
,
argc
,
&
ctxdma
->
object
);
if
(
ret
)
{
nv50_dmac_ctxdma_del
(
ctxdma
);
return
ERR_PTR
(
ret
);
}
return
ctxdma
;
}
static
void
static
void
nv50_dmac_destroy
(
struct
nv50_dmac
*
dmac
)
nv50_dmac_destroy
(
struct
nv50_dmac
*
dmac
)
{
{
struct
nv50_dmac_ctxdma
*
ctxdma
,
*
ctxtmp
;
list_for_each_entry_safe
(
ctxdma
,
ctxtmp
,
&
dmac
->
ctxdma
,
head
)
{
nv50_dmac_ctxdma_del
(
ctxdma
);
}
nvif_object_fini
(
&
dmac
->
vram
);
nvif_object_fini
(
&
dmac
->
vram
);
nvif_object_fini
(
&
dmac
->
sync
);
nvif_object_fini
(
&
dmac
->
sync
);
...
@@ -511,7 +436,6 @@ nv50_dmac_create(struct nvif_device *device, struct nvif_object *disp,
...
@@ -511,7 +436,6 @@ nv50_dmac_create(struct nvif_device *device, struct nvif_object *disp,
int
ret
;
int
ret
;
mutex_init
(
&
dmac
->
lock
);
mutex_init
(
&
dmac
->
lock
);
INIT_LIST_HEAD
(
&
dmac
->
ctxdma
);
ret
=
nvif_mem_init_map
(
&
cli
->
mmu
,
NVIF_MEM_COHERENT
,
0x1000
,
ret
=
nvif_mem_init_map
(
&
cli
->
mmu
,
NVIF_MEM_COHERENT
,
0x1000
,
&
dmac
->
push
);
&
dmac
->
push
);
...
@@ -740,6 +664,11 @@ struct nv50_wndw {
...
@@ -740,6 +664,11 @@ struct nv50_wndw {
const
struct
nv50_wndw_func
*
func
;
const
struct
nv50_wndw_func
*
func
;
struct
nv50_dmac
*
dmac
;
struct
nv50_dmac
*
dmac
;
struct
{
struct
nvif_object
*
parent
;
struct
list_head
list
;
}
ctxdma
;
struct
drm_plane
plane
;
struct
drm_plane
plane
;
struct
nvif_notify
notify
;
struct
nvif_notify
notify
;
...
@@ -770,6 +699,74 @@ struct nv50_wndw_func {
...
@@ -770,6 +699,74 @@ struct nv50_wndw_func {
u32
(
*
update
)(
struct
nv50_wndw
*
,
u32
interlock
);
u32
(
*
update
)(
struct
nv50_wndw
*
,
u32
interlock
);
};
};
static
void
nv50_wndw_ctxdma_del
(
struct
nv50_wndw_ctxdma
*
ctxdma
)
{
nvif_object_fini
(
&
ctxdma
->
object
);
list_del
(
&
ctxdma
->
head
);
kfree
(
ctxdma
);
}
static
struct
nv50_wndw_ctxdma
*
nv50_wndw_ctxdma_new
(
struct
nv50_wndw
*
wndw
,
struct
nouveau_framebuffer
*
fb
)
{
struct
nouveau_drm
*
drm
=
nouveau_drm
(
fb
->
base
.
dev
);
struct
nv50_wndw_ctxdma
*
ctxdma
;
const
u8
kind
=
fb
->
nvbo
->
kind
;
const
u32
handle
=
0xfb000000
|
kind
;
struct
{
struct
nv_dma_v0
base
;
union
{
struct
nv50_dma_v0
nv50
;
struct
gf100_dma_v0
gf100
;
struct
gf119_dma_v0
gf119
;
};
}
args
=
{};
u32
argc
=
sizeof
(
args
.
base
);
int
ret
;
list_for_each_entry
(
ctxdma
,
&
wndw
->
ctxdma
.
list
,
head
)
{
if
(
ctxdma
->
object
.
handle
==
handle
)
return
ctxdma
;
}
if
(
!
(
ctxdma
=
kzalloc
(
sizeof
(
*
ctxdma
),
GFP_KERNEL
)))
return
ERR_PTR
(
-
ENOMEM
);
list_add
(
&
ctxdma
->
head
,
&
wndw
->
ctxdma
.
list
);
args
.
base
.
target
=
NV_DMA_V0_TARGET_VRAM
;
args
.
base
.
access
=
NV_DMA_V0_ACCESS_RDWR
;
args
.
base
.
start
=
0
;
args
.
base
.
limit
=
drm
->
client
.
device
.
info
.
ram_user
-
1
;
if
(
drm
->
client
.
device
.
info
.
chipset
<
0x80
)
{
args
.
nv50
.
part
=
NV50_DMA_V0_PART_256
;
argc
+=
sizeof
(
args
.
nv50
);
}
else
if
(
drm
->
client
.
device
.
info
.
chipset
<
0xc0
)
{
args
.
nv50
.
part
=
NV50_DMA_V0_PART_256
;
args
.
nv50
.
kind
=
kind
;
argc
+=
sizeof
(
args
.
nv50
);
}
else
if
(
drm
->
client
.
device
.
info
.
chipset
<
0xd0
)
{
args
.
gf100
.
kind
=
kind
;
argc
+=
sizeof
(
args
.
gf100
);
}
else
{
args
.
gf119
.
page
=
GF119_DMA_V0_PAGE_LP
;
args
.
gf119
.
kind
=
kind
;
argc
+=
sizeof
(
args
.
gf119
);
}
ret
=
nvif_object_init
(
wndw
->
ctxdma
.
parent
,
handle
,
NV_DMA_IN_MEMORY
,
&
args
,
argc
,
&
ctxdma
->
object
);
if
(
ret
)
{
nv50_wndw_ctxdma_del
(
ctxdma
);
return
ERR_PTR
(
ret
);
}
return
ctxdma
;
}
static
int
static
int
nv50_wndw_wait_armed
(
struct
nv50_wndw
*
wndw
,
struct
nv50_wndw_atom
*
asyw
)
nv50_wndw_wait_armed
(
struct
nv50_wndw
*
wndw
,
struct
nv50_wndw_atom
*
asyw
)
{
{
...
@@ -944,7 +941,7 @@ nv50_wndw_prepare_fb(struct drm_plane *plane, struct drm_plane_state *state)
...
@@ -944,7 +941,7 @@ nv50_wndw_prepare_fb(struct drm_plane *plane, struct drm_plane_state *state)
struct
nv50_wndw
*
wndw
=
nv50_wndw
(
plane
);
struct
nv50_wndw
*
wndw
=
nv50_wndw
(
plane
);
struct
nv50_wndw_atom
*
asyw
=
nv50_wndw_atom
(
state
);
struct
nv50_wndw_atom
*
asyw
=
nv50_wndw_atom
(
state
);
struct
nv50_head_atom
*
asyh
;
struct
nv50_head_atom
*
asyh
;
struct
nv50_
dmac
_ctxdma
*
ctxdma
;
struct
nv50_
wndw
_ctxdma
*
ctxdma
;
int
ret
;
int
ret
;
NV_ATOMIC
(
drm
,
"%s prepare: %p
\n
"
,
plane
->
name
,
state
->
fb
);
NV_ATOMIC
(
drm
,
"%s prepare: %p
\n
"
,
plane
->
name
,
state
->
fb
);
...
@@ -955,7 +952,7 @@ nv50_wndw_prepare_fb(struct drm_plane *plane, struct drm_plane_state *state)
...
@@ -955,7 +952,7 @@ nv50_wndw_prepare_fb(struct drm_plane *plane, struct drm_plane_state *state)
if
(
ret
)
if
(
ret
)
return
ret
;
return
ret
;
ctxdma
=
nv50_
dmac_ctxdma_new
(
wndw
->
dmac
,
fb
);
ctxdma
=
nv50_
wndw_ctxdma_new
(
wndw
,
fb
);
if
(
IS_ERR
(
ctxdma
))
{
if
(
IS_ERR
(
ctxdma
))
{
nouveau_bo_unpin
(
fb
->
nvbo
);
nouveau_bo_unpin
(
fb
->
nvbo
);
return
PTR_ERR
(
ctxdma
);
return
PTR_ERR
(
ctxdma
);
...
@@ -1030,7 +1027,13 @@ static void
...
@@ -1030,7 +1027,13 @@ static void
nv50_wndw_destroy
(
struct
drm_plane
*
plane
)
nv50_wndw_destroy
(
struct
drm_plane
*
plane
)
{
{
struct
nv50_wndw
*
wndw
=
nv50_wndw
(
plane
);
struct
nv50_wndw
*
wndw
=
nv50_wndw
(
plane
);
struct
nv50_wndw_ctxdma
*
ctxdma
,
*
ctxtmp
;
void
*
data
;
void
*
data
;
list_for_each_entry_safe
(
ctxdma
,
ctxtmp
,
&
wndw
->
ctxdma
.
list
,
head
)
{
nv50_wndw_ctxdma_del
(
ctxdma
);
}
nvif_notify_fini
(
&
wndw
->
notify
);
nvif_notify_fini
(
&
wndw
->
notify
);
data
=
wndw
->
func
->
dtor
(
wndw
);
data
=
wndw
->
func
->
dtor
(
wndw
);
drm_plane_cleanup
(
&
wndw
->
plane
);
drm_plane_cleanup
(
&
wndw
->
plane
);
...
@@ -1069,6 +1072,7 @@ nv50_wndw_ctor(const struct nv50_wndw_func *func, struct drm_device *dev,
...
@@ -1069,6 +1072,7 @@ nv50_wndw_ctor(const struct nv50_wndw_func *func, struct drm_device *dev,
wndw
->
func
=
func
;
wndw
->
func
=
func
;
wndw
->
dmac
=
dmac
;
wndw
->
dmac
=
dmac
;
wndw
->
ctxdma
.
parent
=
&
dmac
->
base
.
user
;
ret
=
drm_universal_plane_init
(
dev
,
&
wndw
->
plane
,
0
,
&
nv50_wndw
,
ret
=
drm_universal_plane_init
(
dev
,
&
wndw
->
plane
,
0
,
&
nv50_wndw
,
format
,
nformat
,
NULL
,
format
,
nformat
,
NULL
,
...
@@ -1077,6 +1081,7 @@ nv50_wndw_ctor(const struct nv50_wndw_func *func, struct drm_device *dev,
...
@@ -1077,6 +1081,7 @@ nv50_wndw_ctor(const struct nv50_wndw_func *func, struct drm_device *dev,
return
ret
;
return
ret
;
drm_plane_helper_add
(
&
wndw
->
plane
,
&
nv50_wndw_helper
);
drm_plane_helper_add
(
&
wndw
->
plane
,
&
nv50_wndw_helper
);
INIT_LIST_HEAD
(
&
wndw
->
ctxdma
.
list
);
return
0
;
return
0
;
}
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录