Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openanolis
cloud-kernel
提交
2a86e8e7
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看板
提交
2a86e8e7
编写于
10月 24, 2013
作者:
M
Mark Brown
浏览文件
操作
浏览文件
下载
差异文件
Merge remote-tracking branch 'regulator/topic/da9052' into regulator-next
上级
81e439f4
d706b1e4
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
35 addition
and
6 deletion
+35
-6
drivers/regulator/da9052-regulator.c
drivers/regulator/da9052-regulator.c
+35
-6
未找到文件。
drivers/regulator/da9052-regulator.c
浏览文件 @
2a86e8e7
...
@@ -70,6 +70,7 @@ struct da9052_regulator_info {
...
@@ -70,6 +70,7 @@ struct da9052_regulator_info {
int
step_uV
;
int
step_uV
;
int
min_uV
;
int
min_uV
;
int
max_uV
;
int
max_uV
;
unsigned
char
activate_bit
;
};
};
struct
da9052_regulator
{
struct
da9052_regulator
{
...
@@ -209,6 +210,36 @@ static int da9052_map_voltage(struct regulator_dev *rdev,
...
@@ -209,6 +210,36 @@ static int da9052_map_voltage(struct regulator_dev *rdev,
return
sel
;
return
sel
;
}
}
static
int
da9052_regulator_set_voltage_sel
(
struct
regulator_dev
*
rdev
,
unsigned
int
selector
)
{
struct
da9052_regulator
*
regulator
=
rdev_get_drvdata
(
rdev
);
struct
da9052_regulator_info
*
info
=
regulator
->
info
;
int
id
=
rdev_get_id
(
rdev
);
int
ret
;
ret
=
da9052_reg_update
(
regulator
->
da9052
,
rdev
->
desc
->
vsel_reg
,
rdev
->
desc
->
vsel_mask
,
selector
);
if
(
ret
<
0
)
return
ret
;
/* Some LDOs and DCDCs are DVC controlled which requires enabling of
* the activate bit to implment the changes on the output.
*/
switch
(
id
)
{
case
DA9052_ID_BUCK1
:
case
DA9052_ID_BUCK2
:
case
DA9052_ID_BUCK3
:
case
DA9052_ID_LDO2
:
case
DA9052_ID_LDO3
:
ret
=
da9052_reg_update
(
regulator
->
da9052
,
DA9052_SUPPLY_REG
,
info
->
activate_bit
,
info
->
activate_bit
);
break
;
}
return
ret
;
}
static
struct
regulator_ops
da9052_dcdc_ops
=
{
static
struct
regulator_ops
da9052_dcdc_ops
=
{
.
get_current_limit
=
da9052_dcdc_get_current_limit
,
.
get_current_limit
=
da9052_dcdc_get_current_limit
,
.
set_current_limit
=
da9052_dcdc_set_current_limit
,
.
set_current_limit
=
da9052_dcdc_set_current_limit
,
...
@@ -216,7 +247,7 @@ static struct regulator_ops da9052_dcdc_ops = {
...
@@ -216,7 +247,7 @@ static struct regulator_ops da9052_dcdc_ops = {
.
list_voltage
=
da9052_list_voltage
,
.
list_voltage
=
da9052_list_voltage
,
.
map_voltage
=
da9052_map_voltage
,
.
map_voltage
=
da9052_map_voltage
,
.
get_voltage_sel
=
regulator_get_voltage_sel_regmap
,
.
get_voltage_sel
=
regulator_get_voltage_sel_regmap
,
.
set_voltage_sel
=
regulator_set_voltage_sel_regmap
,
.
set_voltage_sel
=
da9052_regulator_set_voltage_sel
,
.
is_enabled
=
regulator_is_enabled_regmap
,
.
is_enabled
=
regulator_is_enabled_regmap
,
.
enable
=
regulator_enable_regmap
,
.
enable
=
regulator_enable_regmap
,
.
disable
=
regulator_disable_regmap
,
.
disable
=
regulator_disable_regmap
,
...
@@ -226,7 +257,7 @@ static struct regulator_ops da9052_ldo_ops = {
...
@@ -226,7 +257,7 @@ static struct regulator_ops da9052_ldo_ops = {
.
list_voltage
=
da9052_list_voltage
,
.
list_voltage
=
da9052_list_voltage
,
.
map_voltage
=
da9052_map_voltage
,
.
map_voltage
=
da9052_map_voltage
,
.
get_voltage_sel
=
regulator_get_voltage_sel_regmap
,
.
get_voltage_sel
=
regulator_get_voltage_sel_regmap
,
.
set_voltage_sel
=
regulator_set_voltage_sel_regmap
,
.
set_voltage_sel
=
da9052_regulator_set_voltage_sel
,
.
is_enabled
=
regulator_is_enabled_regmap
,
.
is_enabled
=
regulator_is_enabled_regmap
,
.
enable
=
regulator_enable_regmap
,
.
enable
=
regulator_enable_regmap
,
.
disable
=
regulator_disable_regmap
,
.
disable
=
regulator_disable_regmap
,
...
@@ -243,14 +274,13 @@ static struct regulator_ops da9052_ldo_ops = {
...
@@ -243,14 +274,13 @@ static struct regulator_ops da9052_ldo_ops = {
.owner = THIS_MODULE,\
.owner = THIS_MODULE,\
.vsel_reg = DA9052_BUCKCORE_REG + DA9052_ID_##_id, \
.vsel_reg = DA9052_BUCKCORE_REG + DA9052_ID_##_id, \
.vsel_mask = (1 << (sbits)) - 1,\
.vsel_mask = (1 << (sbits)) - 1,\
.apply_reg = DA9052_SUPPLY_REG, \
.apply_bit = (abits), \
.enable_reg = DA9052_BUCKCORE_REG + DA9052_ID_##_id, \
.enable_reg = DA9052_BUCKCORE_REG + DA9052_ID_##_id, \
.enable_mask = 1 << (ebits),\
.enable_mask = 1 << (ebits),\
},\
},\
.min_uV = (min) * 1000,\
.min_uV = (min) * 1000,\
.max_uV = (max) * 1000,\
.max_uV = (max) * 1000,\
.step_uV = (step) * 1000,\
.step_uV = (step) * 1000,\
.activate_bit = (abits),\
}
}
#define DA9052_DCDC(_id, step, min, max, sbits, ebits, abits) \
#define DA9052_DCDC(_id, step, min, max, sbits, ebits, abits) \
...
@@ -264,14 +294,13 @@ static struct regulator_ops da9052_ldo_ops = {
...
@@ -264,14 +294,13 @@ static struct regulator_ops da9052_ldo_ops = {
.owner = THIS_MODULE,\
.owner = THIS_MODULE,\
.vsel_reg = DA9052_BUCKCORE_REG + DA9052_ID_##_id, \
.vsel_reg = DA9052_BUCKCORE_REG + DA9052_ID_##_id, \
.vsel_mask = (1 << (sbits)) - 1,\
.vsel_mask = (1 << (sbits)) - 1,\
.apply_reg = DA9052_SUPPLY_REG, \
.apply_bit = (abits), \
.enable_reg = DA9052_BUCKCORE_REG + DA9052_ID_##_id, \
.enable_reg = DA9052_BUCKCORE_REG + DA9052_ID_##_id, \
.enable_mask = 1 << (ebits),\
.enable_mask = 1 << (ebits),\
},\
},\
.min_uV = (min) * 1000,\
.min_uV = (min) * 1000,\
.max_uV = (max) * 1000,\
.max_uV = (max) * 1000,\
.step_uV = (step) * 1000,\
.step_uV = (step) * 1000,\
.activate_bit = (abits),\
}
}
static
struct
da9052_regulator_info
da9052_regulator_info
[]
=
{
static
struct
da9052_regulator_info
da9052_regulator_info
[]
=
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录