Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
0ade74b6
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看板
提交
0ade74b6
编写于
5月 08, 2012
作者:
B
Ben Skeggs
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
drm/nv50: extend vblank semaphore to generic dmaobj + offset pair
Signed-off-by:
N
Ben Skeggs
<
bskeggs@redhat.com
>
上级
2a259a3d
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
32 addition
and
53 deletion
+32
-53
drivers/gpu/drm/nouveau/nouveau_drv.h
drivers/gpu/drm/nouveau/nouveau_drv.h
+0
-1
drivers/gpu/drm/nouveau/nouveau_notifier.c
drivers/gpu/drm/nouveau/nouveau_notifier.c
+0
-18
drivers/gpu/drm/nouveau/nouveau_software.h
drivers/gpu/drm/nouveau/nouveau_software.h
+4
-18
drivers/gpu/drm/nouveau/nv50_display.c
drivers/gpu/drm/nouveau/nv50_display.c
+24
-1
drivers/gpu/drm/nouveau/nv50_software.c
drivers/gpu/drm/nouveau/nv50_software.c
+4
-15
未找到文件。
drivers/gpu/drm/nouveau/nouveau_drv.h
浏览文件 @
0ade74b6
...
...
@@ -910,7 +910,6 @@ extern void nouveau_notifier_takedown_channel(struct nouveau_channel *);
extern
int
nouveau_notifier_alloc
(
struct
nouveau_channel
*
,
uint32_t
handle
,
int
cout
,
uint32_t
start
,
uint32_t
end
,
uint32_t
*
offset
);
extern
int
nouveau_notifier_offset
(
struct
nouveau_gpuobj
*
,
uint32_t
*
);
/* nouveau_channel.c */
extern
void
nouveau_channel_cleanup
(
struct
drm_device
*
,
struct
drm_file
*
);
...
...
drivers/gpu/drm/nouveau/nouveau_notifier.c
浏览文件 @
0ade74b6
...
...
@@ -161,21 +161,3 @@ nouveau_notifier_alloc(struct nouveau_channel *chan, uint32_t handle,
*
b_offset
=
mem
->
start
;
return
0
;
}
int
nouveau_notifier_offset
(
struct
nouveau_gpuobj
*
nobj
,
uint32_t
*
poffset
)
{
if
(
!
nobj
||
nobj
->
dtor
!=
nouveau_notifier_gpuobj_dtor
)
return
-
EINVAL
;
if
(
poffset
)
{
struct
drm_mm_node
*
mem
=
nobj
->
priv
;
if
(
*
poffset
>=
mem
->
size
)
return
false
;
*
poffset
+=
mem
->
start
;
}
return
0
;
}
drivers/gpu/drm/nouveau/nouveau_software.h
浏览文件 @
0ade74b6
...
...
@@ -4,36 +4,21 @@
struct
nouveau_software_priv
{
struct
nouveau_exec_engine
base
;
struct
list_head
vblank
;
spinlock_t
peephole_lock
;
};
struct
nouveau_software_chan
{
struct
list_head
flip
;
struct
{
struct
list_head
list
;
struct
nouveau_bo
*
bo
;
u32
channel
;
u32
ctxdma
;
u32
offset
;
u32
value
;
u32
head
;
}
vblank
;
};
static
inline
void
nouveau_software_vblank
(
struct
drm_device
*
dev
,
int
crtc
)
{
struct
nouveau_software_priv
*
psw
=
nv_engine
(
dev
,
NVOBJ_ENGINE_SW
);
struct
nouveau_software_chan
*
pch
,
*
tmp
;
list_for_each_entry_safe
(
pch
,
tmp
,
&
psw
->
vblank
,
vblank
.
list
)
{
if
(
pch
->
vblank
.
head
!=
crtc
)
continue
;
nouveau_bo_wr32
(
pch
->
vblank
.
bo
,
pch
->
vblank
.
offset
,
pch
->
vblank
.
value
);
list_del
(
&
pch
->
vblank
.
list
);
drm_vblank_put
(
dev
,
crtc
);
}
}
static
inline
void
nouveau_software_context_new
(
struct
nouveau_software_chan
*
pch
)
{
...
...
@@ -44,6 +29,7 @@ static inline void
nouveau_software_create
(
struct
nouveau_software_priv
*
psw
)
{
INIT_LIST_HEAD
(
&
psw
->
vblank
);
spin_lock_init
(
&
psw
->
peephole_lock
);
}
static
inline
u16
...
...
drivers/gpu/drm/nouveau/nv50_display.c
浏览文件 @
0ade74b6
...
...
@@ -646,7 +646,30 @@ nv50_display_script_select(struct drm_device *dev, struct dcb_entry *dcb,
static
void
nv50_display_vblank_crtc_handler
(
struct
drm_device
*
dev
,
int
crtc
)
{
nouveau_software_vblank
(
dev
,
crtc
);
struct
drm_nouveau_private
*
dev_priv
=
dev
->
dev_private
;
struct
nouveau_software_priv
*
psw
=
nv_engine
(
dev
,
NVOBJ_ENGINE_SW
);
struct
nouveau_software_chan
*
pch
,
*
tmp
;
list_for_each_entry_safe
(
pch
,
tmp
,
&
psw
->
vblank
,
vblank
.
list
)
{
if
(
pch
->
vblank
.
head
!=
crtc
)
continue
;
spin_lock
(
&
psw
->
peephole_lock
);
nv_wr32
(
dev
,
0x001704
,
pch
->
vblank
.
channel
);
nv_wr32
(
dev
,
0x001710
,
0x80000000
|
pch
->
vblank
.
ctxdma
);
if
(
dev_priv
->
chipset
==
0x50
)
{
nv_wr32
(
dev
,
0x001570
,
pch
->
vblank
.
offset
);
nv_wr32
(
dev
,
0x001574
,
pch
->
vblank
.
value
);
}
else
{
nv_wr32
(
dev
,
0x060010
,
pch
->
vblank
.
offset
);
nv_wr32
(
dev
,
0x060014
,
pch
->
vblank
.
value
);
}
spin_unlock
(
&
psw
->
peephole_lock
);
list_del
(
&
pch
->
vblank
.
list
);
drm_vblank_put
(
dev
,
crtc
);
}
drm_handle_vblank
(
dev
,
crtc
);
}
...
...
drivers/gpu/drm/nouveau/nv50_software.c
浏览文件 @
0ade74b6
...
...
@@ -36,9 +36,6 @@ struct nv50_software_priv {
struct
nv50_software_chan
{
struct
nouveau_software_chan
base
;
struct
{
struct
nouveau_gpuobj
*
object
;
}
vblank
;
};
static
int
...
...
@@ -51,11 +48,7 @@ mthd_dma_vblsem(struct nouveau_channel *chan, u32 class, u32 mthd, u32 data)
if
(
!
gpuobj
)
return
-
ENOENT
;
if
(
nouveau_notifier_offset
(
gpuobj
,
NULL
))
return
-
EINVAL
;
pch
->
vblank
.
object
=
gpuobj
;
pch
->
base
.
vblank
.
offset
=
~
0
;
pch
->
base
.
vblank
.
ctxdma
=
gpuobj
->
cinst
>>
4
;
return
0
;
}
...
...
@@ -63,11 +56,7 @@ static int
mthd_vblsem_offset
(
struct
nouveau_channel
*
chan
,
u32
class
,
u32
mthd
,
u32
data
)
{
struct
nv50_software_chan
*
pch
=
chan
->
engctx
[
NVOBJ_ENGINE_SW
];
if
(
nouveau_notifier_offset
(
pch
->
vblank
.
object
,
&
data
))
return
-
ERANGE
;
pch
->
base
.
vblank
.
offset
=
data
>>
2
;
pch
->
base
.
vblank
.
offset
=
data
;
return
0
;
}
...
...
@@ -86,7 +75,7 @@ mthd_vblsem_release(struct nouveau_channel *chan, u32 class, u32 mthd, u32 data)
struct
nv50_software_chan
*
pch
=
chan
->
engctx
[
NVOBJ_ENGINE_SW
];
struct
drm_device
*
dev
=
chan
->
dev
;
if
(
!
pch
->
vblank
.
object
||
pch
->
base
.
vblank
.
offset
==
~
0
||
data
>
1
)
if
(
data
>
1
)
return
-
EINVAL
;
drm_vblank_get
(
dev
,
data
);
...
...
@@ -116,7 +105,7 @@ nv50_software_context_new(struct nouveau_channel *chan, int engine)
return
-
ENOMEM
;
nouveau_software_context_new
(
&
pch
->
base
);
pch
->
base
.
vblank
.
bo
=
chan
->
notifier_bo
;
pch
->
base
.
vblank
.
channel
=
chan
->
ramin
->
vinst
>>
12
;
chan
->
engctx
[
engine
]
=
pch
;
/* dma objects for display sync channel semaphore blocks */
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录