Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
51beb428
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看板
提交
51beb428
编写于
7月 05, 2011
作者:
B
Ben Skeggs
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
drm/nvd0/disp: whip up some basic dma handling for the evo channels
Signed-off-by:
N
Ben Skeggs
<
bskeggs@redhat.com
>
上级
26f6d88b
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
65 addition
and
3 deletion
+65
-3
drivers/gpu/drm/nouveau/nvd0_display.c
drivers/gpu/drm/nouveau/nvd0_display.c
+65
-3
未找到文件。
drivers/gpu/drm/nouveau/nvd0_display.c
浏览文件 @
51beb428
...
...
@@ -22,6 +22,7 @@
* Authors: Ben Skeggs
*/
#include <linux/dma-mapping.h>
#include "drmP.h"
#include "nouveau_drv.h"
...
...
@@ -31,6 +32,10 @@
struct
nvd0_display
{
struct
nouveau_gpuobj
*
mem
;
struct
{
dma_addr_t
handle
;
u32
*
ptr
;
}
evo
[
1
];
};
static
struct
nvd0_display
*
...
...
@@ -40,6 +45,50 @@ nvd0_display(struct drm_device *dev)
return
dev_priv
->
engine
.
display
.
priv
;
}
static
int
evo_icmd
(
struct
drm_device
*
dev
,
int
id
,
u32
mthd
,
u32
data
)
{
int
ret
=
0
;
nv_mask
(
dev
,
0x610700
+
(
id
*
0x10
),
0x00000001
,
0x00000001
);
nv_wr32
(
dev
,
0x610704
+
(
id
*
0x10
),
data
);
nv_mask
(
dev
,
0x610704
+
(
id
*
0x10
),
0x80000ffc
,
0x80000000
|
mthd
);
if
(
!
nv_wait
(
dev
,
0x610704
+
(
id
*
0x10
),
0x80000000
,
0x00000000
))
ret
=
-
EBUSY
;
nv_mask
(
dev
,
0x610700
+
(
id
*
0x10
),
0x00000001
,
0x00000000
);
return
ret
;
}
static
u32
*
evo_wait
(
struct
drm_device
*
dev
,
int
id
,
int
nr
)
{
struct
nvd0_display
*
disp
=
nvd0_display
(
dev
);
u32
put
=
nv_rd32
(
dev
,
0x640000
+
(
id
*
0x1000
))
/
4
;
if
(
put
+
nr
>=
(
PAGE_SIZE
/
4
))
{
disp
->
evo
[
id
].
ptr
[
put
]
=
0x20000000
;
nv_wr32
(
dev
,
0x640000
+
(
id
*
0x1000
),
0x00000000
);
if
(
!
nv_wait
(
dev
,
0x640004
+
(
id
*
0x1000
),
~
0
,
0x00000000
))
{
NV_ERROR
(
dev
,
"evo %d dma stalled
\n
"
,
id
);
return
NULL
;
}
put
=
0
;
}
return
disp
->
evo
[
id
].
ptr
+
put
;
}
static
void
evo_kick
(
u32
*
push
,
struct
drm_device
*
dev
,
int
id
)
{
struct
nvd0_display
*
disp
=
nvd0_display
(
dev
);
nv_wr32
(
dev
,
0x640000
+
(
id
*
0x1000
),
(
push
-
disp
->
evo
[
id
].
ptr
)
<<
2
);
}
#define evo_mthd(p,m,s) *((p)++) = (((s) << 18) | (m))
#define evo_data(p,d) *((p)++) = (d)
/******************************************************************************
* DAC
*****************************************************************************/
...
...
@@ -100,7 +149,7 @@ nvd0_display_init(struct drm_device *dev)
nv_wr32
(
dev
,
0x610010
,
(
disp
->
mem
->
vinst
>>
8
)
|
9
);
/* init master */
nv_wr32
(
dev
,
0x610494
,
(
(
disp
->
mem
->
vinst
+
0x1000
)
>>
8
)
|
1
);
nv_wr32
(
dev
,
0x610494
,
(
disp
->
evo
[
0
].
handle
>>
8
)
|
3
);
nv_wr32
(
dev
,
0x610498
,
0x00010000
);
nv_wr32
(
dev
,
0x61049c
,
0x00000000
);
nv_mask
(
dev
,
0x610490
,
0x00000010
,
0x00000010
);
...
...
@@ -135,11 +184,14 @@ nvd0_display_destroy(struct drm_device *dev)
{
struct
drm_nouveau_private
*
dev_priv
=
dev
->
dev_private
;
struct
nvd0_display
*
disp
=
nvd0_display
(
dev
);
struct
pci_dev
*
pdev
=
dev
->
pdev
;
nvd0_display_fini
(
dev
);
dev_priv
->
engine
.
display
.
priv
=
NULL
;
pci_free_consistent
(
pdev
,
PAGE_SIZE
,
disp
->
evo
[
0
].
ptr
,
disp
->
evo
[
0
].
handle
)
;
nouveau_gpuobj_ref
(
NULL
,
&
disp
->
mem
);
dev_priv
->
engine
.
display
.
priv
=
NULL
;
kfree
(
disp
);
}
...
...
@@ -147,6 +199,7 @@ int
nvd0_display_create
(
struct
drm_device
*
dev
)
{
struct
drm_nouveau_private
*
dev_priv
=
dev
->
dev_private
;
struct
pci_dev
*
pdev
=
dev
->
pdev
;
struct
nvd0_display
*
disp
;
int
ret
;
...
...
@@ -155,10 +208,19 @@ nvd0_display_create(struct drm_device *dev)
return
-
ENOMEM
;
dev_priv
->
engine
.
display
.
priv
=
disp
;
ret
=
nouveau_gpuobj_new
(
dev
,
NULL
,
8
*
1024
,
0x1000
,
0
,
&
disp
->
mem
);
/* hash table and dma objects for the memory areas we care about */
ret
=
nouveau_gpuobj_new
(
dev
,
NULL
,
4
*
1024
,
0x1000
,
0
,
&
disp
->
mem
);
if
(
ret
)
goto
out
;
/* push buffers for evo channels */
disp
->
evo
[
0
].
ptr
=
pci_alloc_consistent
(
pdev
,
PAGE_SIZE
,
&
disp
->
evo
[
0
].
handle
);
if
(
!
disp
->
evo
[
0
].
ptr
)
{
ret
=
-
ENOMEM
;
goto
out
;
}
ret
=
nvd0_display_init
(
dev
);
if
(
ret
)
goto
out
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录