Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
aee582de
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看板
提交
aee582de
编写于
9月 27, 2010
作者:
B
Ben Skeggs
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
drm/nouveau: run perflvl and M table scripts on mem clock change
Signed-off-by:
N
Ben Skeggs
<
bskeggs@redhat.com
>
上级
5c6dc657
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
25 addition
and
0 deletion
+25
-0
drivers/gpu/drm/nouveau/nouveau_drv.h
drivers/gpu/drm/nouveau/nouveau_drv.h
+2
-0
drivers/gpu/drm/nouveau/nouveau_perf.c
drivers/gpu/drm/nouveau/nouveau_perf.c
+1
-0
drivers/gpu/drm/nouveau/nv50_pm.c
drivers/gpu/drm/nouveau/nv50_pm.c
+22
-0
未找到文件。
drivers/gpu/drm/nouveau/nouveau_drv.h
浏览文件 @
aee582de
...
...
@@ -385,6 +385,8 @@ struct nouveau_pm_level {
u8
voltage
;
u8
fanspeed
;
u16
memscript
;
};
struct
nouveau_pm_temp_sensor_constants
{
...
...
drivers/gpu/drm/nouveau/nouveau_perf.c
浏览文件 @
aee582de
...
...
@@ -160,6 +160,7 @@ nouveau_perf_init(struct drm_device *dev)
perflvl
->
memory
=
ROM16
(
entry
[
12
])
*
1000
;
break
;
case
0x30
:
perflvl
->
memscript
=
ROM16
(
entry
[
2
]);
case
0x35
:
perflvl
->
fanspeed
=
entry
[
6
];
perflvl
->
voltage
=
entry
[
7
];
...
...
drivers/gpu/drm/nouveau/nv50_pm.c
浏览文件 @
aee582de
...
...
@@ -24,6 +24,7 @@
#include "drmP.h"
#include "nouveau_drv.h"
#include "nouveau_bios.h"
#include "nouveau_pm.h"
/*XXX: boards using limits 0x40 need fixing, the register layout
...
...
@@ -33,6 +34,7 @@
*/
struct
nv50_pm_state
{
struct
nouveau_pm_level
*
perflvl
;
struct
pll_lims
pll
;
enum
pll_types
type
;
int
N
,
M
,
P
;
...
...
@@ -77,6 +79,7 @@ nv50_pm_clock_pre(struct drm_device *dev, struct nouveau_pm_level *perflvl,
if
(
!
state
)
return
ERR_PTR
(
-
ENOMEM
);
state
->
type
=
id
;
state
->
perflvl
=
perflvl
;
ret
=
get_pll_limits
(
dev
,
id
,
&
state
->
pll
);
if
(
ret
<
0
)
{
...
...
@@ -98,11 +101,30 @@ void
nv50_pm_clock_set
(
struct
drm_device
*
dev
,
void
*
pre_state
)
{
struct
nv50_pm_state
*
state
=
pre_state
;
struct
nouveau_pm_level
*
perflvl
=
state
->
perflvl
;
u32
reg
=
state
->
pll
.
reg
,
tmp
;
struct
bit_entry
BIT_M
;
u16
script
;
int
N
=
state
->
N
;
int
M
=
state
->
M
;
int
P
=
state
->
P
;
if
(
state
->
type
==
PLL_MEMORY
&&
perflvl
->
memscript
&&
bit_table
(
dev
,
'M'
,
&
BIT_M
)
==
0
&&
BIT_M
.
version
==
1
&&
BIT_M
.
length
>=
0x0b
)
{
script
=
ROM16
(
BIT_M
.
data
[
0x05
]);
if
(
script
)
nouveau_bios_run_init_table
(
dev
,
script
,
NULL
);
script
=
ROM16
(
BIT_M
.
data
[
0x07
]);
if
(
script
)
nouveau_bios_run_init_table
(
dev
,
script
,
NULL
);
script
=
ROM16
(
BIT_M
.
data
[
0x09
]);
if
(
script
)
nouveau_bios_run_init_table
(
dev
,
script
,
NULL
);
nouveau_bios_run_init_table
(
dev
,
perflvl
->
memscript
,
NULL
);
}
if
(
state
->
pll
.
vco2
.
maxfreq
)
{
if
(
state
->
type
==
PLL_MEMORY
)
{
nv_wr32
(
dev
,
0x100210
,
0
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录