Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
45aae62d
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看板
提交
45aae62d
编写于
2月 19, 2013
作者:
M
Mark Brown
浏览文件
操作
浏览文件
下载
差异文件
Merge remote-tracking branch 'regulator/topic/arizona' into regulator-next
上级
fc221525
57a10a1f
变更
4
隐藏空白更改
内联
并排
Showing
4 changed file
with
83 addition
and
4 deletion
+83
-4
drivers/regulator/Kconfig
drivers/regulator/Kconfig
+1
-0
drivers/regulator/arizona-micsupp.c
drivers/regulator/arizona-micsupp.c
+74
-4
sound/soc/codecs/wm5102.c
sound/soc/codecs/wm5102.c
+4
-0
sound/soc/codecs/wm5110.c
sound/soc/codecs/wm5110.c
+4
-0
未找到文件。
drivers/regulator/Kconfig
浏览文件 @
45aae62d
...
...
@@ -91,6 +91,7 @@ config REGULATOR_AAT2870
config REGULATOR_ARIZONA
tristate "Wolfson Arizona class devices"
depends on MFD_ARIZONA
depends on SND_SOC
help
Support for the regulators found on Wolfson Arizona class
devices.
...
...
drivers/regulator/arizona-micsupp.c
浏览文件 @
45aae62d
...
...
@@ -21,6 +21,8 @@
#include <linux/regulator/machine.h>
#include <linux/gpio.h>
#include <linux/slab.h>
#include <linux/workqueue.h>
#include <sound/soc.h>
#include <linux/mfd/arizona/core.h>
#include <linux/mfd/arizona/pdata.h>
...
...
@@ -34,6 +36,8 @@ struct arizona_micsupp {
struct
regulator_consumer_supply
supply
;
struct
regulator_init_data
init_data
;
struct
work_struct
check_cp_work
;
};
static
int
arizona_micsupp_list_voltage
(
struct
regulator_dev
*
rdev
,
...
...
@@ -72,9 +76,73 @@ static int arizona_micsupp_map_voltage(struct regulator_dev *rdev,
return
selector
;
}
static
void
arizona_micsupp_check_cp
(
struct
work_struct
*
work
)
{
struct
arizona_micsupp
*
micsupp
=
container_of
(
work
,
struct
arizona_micsupp
,
check_cp_work
);
struct
snd_soc_dapm_context
*
dapm
=
micsupp
->
arizona
->
dapm
;
struct
arizona
*
arizona
=
micsupp
->
arizona
;
struct
regmap
*
regmap
=
arizona
->
regmap
;
unsigned
int
reg
;
int
ret
;
ret
=
regmap_read
(
regmap
,
ARIZONA_MIC_CHARGE_PUMP_1
,
&
reg
);
if
(
ret
!=
0
)
{
dev_err
(
arizona
->
dev
,
"Failed to read CP state: %d
\n
"
,
ret
);
return
;
}
if
(
dapm
)
{
if
((
reg
&
(
ARIZONA_CPMIC_ENA
|
ARIZONA_CPMIC_BYPASS
))
==
ARIZONA_CPMIC_ENA
)
snd_soc_dapm_force_enable_pin
(
dapm
,
"MICSUPP"
);
else
snd_soc_dapm_disable_pin
(
dapm
,
"MICSUPP"
);
snd_soc_dapm_sync
(
dapm
);
}
}
static
int
arizona_micsupp_enable
(
struct
regulator_dev
*
rdev
)
{
struct
arizona_micsupp
*
micsupp
=
rdev_get_drvdata
(
rdev
);
int
ret
;
ret
=
regulator_enable_regmap
(
rdev
);
if
(
ret
==
0
)
schedule_work
(
&
micsupp
->
check_cp_work
);
return
ret
;
}
static
int
arizona_micsupp_disable
(
struct
regulator_dev
*
rdev
)
{
struct
arizona_micsupp
*
micsupp
=
rdev_get_drvdata
(
rdev
);
int
ret
;
ret
=
regulator_disable_regmap
(
rdev
);
if
(
ret
==
0
)
schedule_work
(
&
micsupp
->
check_cp_work
);
return
ret
;
}
static
int
arizona_micsupp_set_bypass
(
struct
regulator_dev
*
rdev
,
bool
ena
)
{
struct
arizona_micsupp
*
micsupp
=
rdev_get_drvdata
(
rdev
);
int
ret
;
ret
=
regulator_set_bypass_regmap
(
rdev
,
ena
);
if
(
ret
==
0
)
schedule_work
(
&
micsupp
->
check_cp_work
);
return
ret
;
}
static
struct
regulator_ops
arizona_micsupp_ops
=
{
.
enable
=
regulator_enable_regmap
,
.
disable
=
regulator_disable_regmap
,
.
enable
=
arizona_micsupp_enable
,
.
disable
=
arizona_micsupp_disable
,
.
is_enabled
=
regulator_is_enabled_regmap
,
.
list_voltage
=
arizona_micsupp_list_voltage
,
...
...
@@ -84,7 +152,7 @@ static struct regulator_ops arizona_micsupp_ops = {
.
set_voltage_sel
=
regulator_set_voltage_sel_regmap
,
.
get_bypass
=
regulator_get_bypass_regmap
,
.
set_bypass
=
regulator_set_bypass_regmap
,
.
set_bypass
=
arizona_micsupp_set_bypass
,
};
static
const
struct
regulator_desc
arizona_micsupp
=
{
...
...
@@ -109,7 +177,8 @@ static const struct regulator_desc arizona_micsupp = {
static
const
struct
regulator_init_data
arizona_micsupp_default
=
{
.
constraints
=
{
.
valid_ops_mask
=
REGULATOR_CHANGE_STATUS
|
REGULATOR_CHANGE_VOLTAGE
,
REGULATOR_CHANGE_VOLTAGE
|
REGULATOR_CHANGE_BYPASS
,
.
min_uV
=
1700000
,
.
max_uV
=
3300000
,
},
...
...
@@ -131,6 +200,7 @@ static int arizona_micsupp_probe(struct platform_device *pdev)
}
micsupp
->
arizona
=
arizona
;
INIT_WORK
(
&
micsupp
->
check_cp_work
,
arizona_micsupp_check_cp
);
/*
* Since the chip usually supplies itself we provide some
...
...
sound/soc/codecs/wm5102.c
浏览文件 @
45aae62d
...
...
@@ -1152,6 +1152,8 @@ SND_SOC_DAPM_OUTPUT("SPKOUTRN"),
SND_SOC_DAPM_OUTPUT
(
"SPKOUTRP"
),
SND_SOC_DAPM_OUTPUT
(
"SPKDAT1L"
),
SND_SOC_DAPM_OUTPUT
(
"SPKDAT1R"
),
SND_SOC_DAPM_OUTPUT
(
"MICSUPP"
),
};
#define ARIZONA_MIXER_INPUT_ROUTES(name) \
...
...
@@ -1364,6 +1366,8 @@ static const struct snd_soc_dapm_route wm5102_dapm_routes[] = {
{
"AEC Loopback"
,
"SPKDAT1R"
,
"OUT5R"
},
{
"SPKDAT1L"
,
NULL
,
"OUT5L"
},
{
"SPKDAT1R"
,
NULL
,
"OUT5R"
},
{
"MICSUPP"
,
NULL
,
"SYSCLK"
},
};
static
int
wm5102_set_fll
(
struct
snd_soc_codec
*
codec
,
int
fll_id
,
int
source
,
...
...
sound/soc/codecs/wm5110.c
浏览文件 @
45aae62d
...
...
@@ -624,6 +624,8 @@ SND_SOC_DAPM_OUTPUT("SPKDAT1L"),
SND_SOC_DAPM_OUTPUT
(
"SPKDAT1R"
),
SND_SOC_DAPM_OUTPUT
(
"SPKDAT2L"
),
SND_SOC_DAPM_OUTPUT
(
"SPKDAT2R"
),
SND_SOC_DAPM_OUTPUT
(
"MICSUPP"
),
};
#define ARIZONA_MIXER_INPUT_ROUTES(name) \
...
...
@@ -832,6 +834,8 @@ static const struct snd_soc_dapm_route wm5110_dapm_routes[] = {
{
"SPKDAT2L"
,
NULL
,
"OUT6L"
},
{
"SPKDAT2R"
,
NULL
,
"OUT6R"
},
{
"MICSUPP"
,
NULL
,
"SYSCLK"
},
};
static
int
wm5110_set_fll
(
struct
snd_soc_codec
*
codec
,
int
fll_id
,
int
source
,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录