Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
dc49f3d5
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看板
提交
dc49f3d5
编写于
6月 02, 2014
作者:
M
Mark Brown
浏览文件
操作
浏览文件
下载
差异文件
Merge remote-tracking branch 'regulator/topic/constraints' into regulator-next
上级
277b1be9
064d5cd1
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
23 addition
and
10 deletion
+23
-10
drivers/regulator/core.c
drivers/regulator/core.c
+23
-10
未找到文件。
drivers/regulator/core.c
浏览文件 @
dc49f3d5
...
...
@@ -844,13 +844,22 @@ static int machine_constraints_voltage(struct regulator_dev *rdev,
/* do we need to apply the constraint voltage */
if
(
rdev
->
constraints
->
apply_uV
&&
rdev
->
constraints
->
min_uV
==
rdev
->
constraints
->
max_uV
)
{
ret
=
_regulator_do_set_voltage
(
rdev
,
rdev
->
constraints
->
min_uV
,
rdev
->
constraints
->
max_uV
);
if
(
ret
<
0
)
{
rdev_err
(
rdev
,
"failed to apply %duV constraint
\n
"
,
rdev
->
constraints
->
min_uV
);
return
ret
;
int
current_uV
=
_regulator_get_voltage
(
rdev
);
if
(
current_uV
<
0
)
{
rdev_err
(
rdev
,
"failed to get the current voltage
\n
"
);
return
current_uV
;
}
if
(
current_uV
<
rdev
->
constraints
->
min_uV
||
current_uV
>
rdev
->
constraints
->
max_uV
)
{
ret
=
_regulator_do_set_voltage
(
rdev
,
rdev
->
constraints
->
min_uV
,
rdev
->
constraints
->
max_uV
);
if
(
ret
<
0
)
{
rdev_err
(
rdev
,
"failed to apply %duV constraint
\n
"
,
rdev
->
constraints
->
min_uV
);
return
ret
;
}
}
}
...
...
@@ -3819,8 +3828,9 @@ static int __init regulator_init_complete(void)
mutex_lock
(
&
regulator_list_mutex
);
/* If we have a full configuration then disable any regulators
* which are not in use or always_on. This will become the
* default behaviour in the future.
* we have permission to change the status for and which are
* not in use or always_on. This is effectively the default
* for DT and ACPI as they have full constraints.
*/
list_for_each_entry
(
rdev
,
&
regulator_list
,
list
)
{
ops
=
rdev
->
desc
->
ops
;
...
...
@@ -3829,6 +3839,9 @@ static int __init regulator_init_complete(void)
if
(
c
&&
c
->
always_on
)
continue
;
if
(
c
&&
!
(
c
->
valid_ops_mask
&
REGULATOR_CHANGE_STATUS
))
continue
;
mutex_lock
(
&
rdev
->
mutex
);
if
(
rdev
->
use_count
)
...
...
@@ -3867,4 +3880,4 @@ static int __init regulator_init_complete(void)
return
0
;
}
late_initcall
(
regulator_init_complete
);
late_initcall
_sync
(
regulator_init_complete
);
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录