Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
2bfa0b01
cloud-kernel
项目概览
openanolis
/
cloud-kernel
接近 2 年 前同步成功
通知
170
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看板
提交
2bfa0b01
编写于
11月 01, 2017
作者:
B
Ben Skeggs
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
drm/nouveau/fb/ram/gt215: allocate training buffer with nvkm_ram_get()
Signed-off-by:
N
Ben Skeggs
<
bskeggs@redhat.com
>
上级
e9a8b218
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
9 addition
and
9 deletion
+9
-9
drivers/gpu/drm/nouveau/nvkm/subdev/fb/ramgt215.c
drivers/gpu/drm/nouveau/nvkm/subdev/fb/ramgt215.c
+9
-9
未找到文件。
drivers/gpu/drm/nouveau/nvkm/subdev/fb/ramgt215.c
浏览文件 @
2bfa0b01
...
...
@@ -26,6 +26,7 @@
#include "ram.h"
#include "ramfuc.h"
#include <core/memory.h>
#include <core/option.h>
#include <subdev/bios.h>
#include <subdev/bios/M0205.h>
...
...
@@ -86,7 +87,7 @@ struct gt215_ltrain {
u32
r_100720
;
u32
r_1111e0
;
u32
r_111400
;
struct
nvkm_mem
*
mem
;
struct
nvkm_mem
ory
*
memory
;
};
struct
gt215_ram
{
...
...
@@ -279,10 +280,10 @@ gt215_link_train_init(struct gt215_ram *ram)
struct
gt215_ltrain
*
train
=
&
ram
->
ltrain
;
struct
nvkm_device
*
device
=
ram
->
base
.
fb
->
subdev
.
device
;
struct
nvkm_bios
*
bios
=
device
->
bios
;
struct
nvkm_mem
*
mem
;
struct
nvbios_M0205E
M0205E
;
u8
ver
,
hdr
,
cnt
,
len
;
u32
r001700
;
u64
addr
;
int
ret
,
i
=
0
;
train
->
state
=
NVA3_TRAIN_UNSUPPORTED
;
...
...
@@ -297,14 +298,14 @@ gt215_link_train_init(struct gt215_ram *ram)
train
->
state
=
NVA3_TRAIN_ONCE
;
ret
=
ram
->
base
.
func
->
get
(
&
ram
->
base
,
0x8000
,
0x10000
,
0
,
0x8
00
,
&
ram
->
ltrain
.
mem
);
ret
=
nvkm_ram_get
(
device
,
NVKM_RAM_MM_NORMAL
,
0x01
,
16
,
0x80
00
,
true
,
true
,
&
ram
->
ltrain
.
memory
);
if
(
ret
)
return
ret
;
mem
=
ram
->
ltrain
.
mem
;
addr
=
nvkm_memory_addr
(
ram
->
ltrain
.
memory
)
;
nvkm_wr32
(
device
,
0x100538
,
0x10000000
|
(
mem
->
offset
>>
16
));
nvkm_wr32
(
device
,
0x100538
,
0x10000000
|
(
addr
>>
16
));
nvkm_wr32
(
device
,
0x1005a8
,
0x0000ffff
);
nvkm_mask
(
device
,
0x10f800
,
0x00000001
,
0x00000001
);
...
...
@@ -320,7 +321,7 @@ gt215_link_train_init(struct gt215_ram *ram)
/* And upload the pattern */
r001700
=
nvkm_rd32
(
device
,
0x1700
);
nvkm_wr32
(
device
,
0x1700
,
mem
->
offset
>>
16
);
nvkm_wr32
(
device
,
0x1700
,
addr
>>
16
);
for
(
i
=
0
;
i
<
16
;
i
++
)
nvkm_wr32
(
device
,
0x700000
+
(
i
<<
2
),
pattern
[
i
]);
for
(
i
=
0
;
i
<
16
;
i
++
)
...
...
@@ -336,8 +337,7 @@ gt215_link_train_init(struct gt215_ram *ram)
static
void
gt215_link_train_fini
(
struct
gt215_ram
*
ram
)
{
if
(
ram
->
ltrain
.
mem
)
ram
->
base
.
func
->
put
(
&
ram
->
base
,
&
ram
->
ltrain
.
mem
);
nvkm_memory_unref
(
&
ram
->
ltrain
.
memory
);
}
/*
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录