Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
L
linux
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
nexedi
linux
Commits
5445d626
Commit
5445d626
authored
Jun 22, 2015
by
Mark Brown
Browse files
Options
Browse Files
Download
Plain Diff
Merge remote-tracking branch 'asoc/topic/rt5645' into asoc-next
parents
208a128f
851b81e8
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
128 additions
and
59 deletions
+128
-59
Documentation/devicetree/bindings/sound/rt5645.txt
Documentation/devicetree/bindings/sound/rt5645.txt
+72
-0
include/sound/rt5645.h
include/sound/rt5645.h
+0
-3
sound/soc/codecs/rt5645.c
sound/soc/codecs/rt5645.c
+55
-56
sound/soc/codecs/rt5645.h
sound/soc/codecs/rt5645.h
+1
-0
No files found.
Documentation/devicetree/bindings/sound/rt5645.txt
0 → 100644
View file @
5445d626
RT5650/RT5645 audio CODEC
This device supports I2C only.
Required properties:
- compatible : One of "realtek,rt5645" or "realtek,rt5650".
- reg : The I2C address of the device.
- interrupts : The CODEC's interrupt output.
Optional properties:
- hp-detect-gpios:
a GPIO spec for the external headphone detect pin. If jd-mode = 0,
we will get the JD status by getting the value of hp-detect-gpios.
- realtek,in2-differential
Boolean. Indicate MIC2 input are differential, rather than single-ended.
- realtek,dmic1-data-pin
0: dmic1 is not used
1: using IN2P pin as dmic1 data pin
2: using GPIO6 pin as dmic1 data pin
3: using GPIO10 pin as dmic1 data pin
4: using GPIO12 pin as dmic1 data pin
- realtek,dmic2-data-pin
0: dmic2 is not used
1: using IN2N pin as dmic2 data pin
2: using GPIO5 pin as dmic2 data pin
3: using GPIO11 pin as dmic2 data pin
-- realtek,jd-mode : The JD mode of rt5645/rt5650
0 : rt5645/rt5650 JD function is not used
1 : Mode-0 (VDD=3.3V), two port jack detection
2 : Mode-1 (VDD=3.3V), one port jack detection
3 : Mode-2 (VDD=1.8V), one port jack detection
Pins on the device (for linking into audio routes) for RT5645/RT5650:
* DMIC L1
* DMIC R1
* DMIC L2
* DMIC R2
* IN1P
* IN1N
* IN2P
* IN2N
* Haptic Generator
* HPOL
* HPOR
* LOUTL
* LOUTR
* PDM1L
* PDM1R
* SPOL
* SPOR
Example:
codec: rt5650@1a {
compatible = "realtek,rt5650";
reg = <0x1a>;
hp-detect-gpios = <&gpio 19 0>;
interrupt-parent = <&gpio>;
interrupts = <7 IRQ_TYPE_EDGE_FALLING>;
realtek,dmic-en = "true";
realtek,en-jd-func = "true";
realtek,jd-mode = <3>;
};
\ No newline at end of file
include/sound/rt5645.h
View file @
5445d626
...
...
@@ -20,9 +20,6 @@ struct rt5645_platform_data {
unsigned
int
dmic2_data_pin
;
/* 0 = IN2P; 1 = GPIO6; 2 = GPIO10; 3 = GPIO12 */
unsigned
int
hp_det_gpio
;
bool
gpio_hp_det_active_high
;
unsigned
int
jd_mode
;
};
...
...
sound/soc/codecs/rt5645.c
View file @
5445d626
...
...
@@ -349,6 +349,7 @@ static bool rt5645_readable_register(struct device *dev, unsigned int reg)
case
RT5645_TDM_CTRL_1
:
case
RT5645_TDM_CTRL_2
:
case
RT5645_TDM_CTRL_3
:
case
RT5650_TDM_CTRL_4
:
case
RT5645_GLB_CLK
:
case
RT5645_PLL_CTRL1
:
case
RT5645_PLL_CTRL2
:
...
...
@@ -1705,15 +1706,6 @@ static const struct snd_soc_dapm_widget rt5645_dapm_widgets[] = {
SND_SOC_DAPM_MUX
(
"RT5645 IF1 ADC Mux"
,
SND_SOC_NOPM
,
0
,
0
,
&
rt5645_if1_adc_in_mux
),
SND_SOC_DAPM_MUX
(
"RT5650 IF1 ADC1 Swap Mux"
,
SND_SOC_NOPM
,
0
,
0
,
&
rt5650_if1_adc1_in_mux
),
SND_SOC_DAPM_MUX
(
"RT5650 IF1 ADC2 Swap Mux"
,
SND_SOC_NOPM
,
0
,
0
,
&
rt5650_if1_adc2_in_mux
),
SND_SOC_DAPM_MUX
(
"RT5650 IF1 ADC3 Swap Mux"
,
SND_SOC_NOPM
,
0
,
0
,
&
rt5650_if1_adc3_in_mux
),
SND_SOC_DAPM_MUX
(
"RT5650 IF1 ADC Mux"
,
SND_SOC_NOPM
,
0
,
0
,
&
rt5650_if1_adc_in_mux
),
SND_SOC_DAPM_MUX
(
"IF2 ADC Mux"
,
SND_SOC_NOPM
,
0
,
0
,
&
rt5645_if2_adc_in_mux
),
...
...
@@ -1732,14 +1724,6 @@ static const struct snd_soc_dapm_widget rt5645_dapm_widgets[] = {
&
rt5645_if1_dac2_tdm_sel_mux
),
SND_SOC_DAPM_MUX
(
"RT5645 IF1 DAC2 R Mux"
,
SND_SOC_NOPM
,
0
,
0
,
&
rt5645_if1_dac3_tdm_sel_mux
),
SND_SOC_DAPM_MUX
(
"RT5650 IF1 DAC1 L Mux"
,
SND_SOC_NOPM
,
0
,
0
,
&
rt5650_if1_dac0_tdm_sel_mux
),
SND_SOC_DAPM_MUX
(
"RT5650 IF1 DAC1 R Mux"
,
SND_SOC_NOPM
,
0
,
0
,
&
rt5650_if1_dac1_tdm_sel_mux
),
SND_SOC_DAPM_MUX
(
"RT5650 IF1 DAC2 L Mux"
,
SND_SOC_NOPM
,
0
,
0
,
&
rt5650_if1_dac2_tdm_sel_mux
),
SND_SOC_DAPM_MUX
(
"RT5650 IF1 DAC2 R Mux"
,
SND_SOC_NOPM
,
0
,
0
,
&
rt5650_if1_dac3_tdm_sel_mux
),
SND_SOC_DAPM_PGA
(
"IF1 ADC"
,
SND_SOC_NOPM
,
0
,
0
,
NULL
,
0
),
SND_SOC_DAPM_PGA
(
"IF1 ADC L"
,
SND_SOC_NOPM
,
0
,
0
,
NULL
,
0
),
SND_SOC_DAPM_PGA
(
"IF1 ADC R"
,
SND_SOC_NOPM
,
0
,
0
,
NULL
,
0
),
...
...
@@ -1881,6 +1865,24 @@ static const struct snd_soc_dapm_widget rt5650_specific_dapm_widgets[] = {
0
,
0
,
&
rt5650_a_dac2_l_mux
),
SND_SOC_DAPM_MUX
(
"A DAC2 R Mux"
,
SND_SOC_NOPM
,
0
,
0
,
&
rt5650_a_dac2_r_mux
),
SND_SOC_DAPM_MUX
(
"RT5650 IF1 ADC1 Swap Mux"
,
SND_SOC_NOPM
,
0
,
0
,
&
rt5650_if1_adc1_in_mux
),
SND_SOC_DAPM_MUX
(
"RT5650 IF1 ADC2 Swap Mux"
,
SND_SOC_NOPM
,
0
,
0
,
&
rt5650_if1_adc2_in_mux
),
SND_SOC_DAPM_MUX
(
"RT5650 IF1 ADC3 Swap Mux"
,
SND_SOC_NOPM
,
0
,
0
,
&
rt5650_if1_adc3_in_mux
),
SND_SOC_DAPM_MUX
(
"RT5650 IF1 ADC Mux"
,
SND_SOC_NOPM
,
0
,
0
,
&
rt5650_if1_adc_in_mux
),
SND_SOC_DAPM_MUX
(
"RT5650 IF1 DAC1 L Mux"
,
SND_SOC_NOPM
,
0
,
0
,
&
rt5650_if1_dac0_tdm_sel_mux
),
SND_SOC_DAPM_MUX
(
"RT5650 IF1 DAC1 R Mux"
,
SND_SOC_NOPM
,
0
,
0
,
&
rt5650_if1_dac1_tdm_sel_mux
),
SND_SOC_DAPM_MUX
(
"RT5650 IF1 DAC2 L Mux"
,
SND_SOC_NOPM
,
0
,
0
,
&
rt5650_if1_dac2_tdm_sel_mux
),
SND_SOC_DAPM_MUX
(
"RT5650 IF1 DAC2 R Mux"
,
SND_SOC_NOPM
,
0
,
0
,
&
rt5650_if1_dac3_tdm_sel_mux
),
};
static
const
struct
snd_soc_dapm_route
rt5645_dapm_routes
[]
=
{
...
...
@@ -2761,6 +2763,7 @@ static void rt5645_enable_push_button_irq(struct snd_soc_codec *codec,
struct
rt5645_priv
*
rt5645
=
snd_soc_codec_get_drvdata
(
codec
);
if
(
enable
)
{
snd_soc_dapm_mutex_lock
(
&
codec
->
dapm
);
snd_soc_dapm_force_enable_pin_unlocked
(
&
codec
->
dapm
,
"ADC L power"
);
snd_soc_dapm_force_enable_pin_unlocked
(
&
codec
->
dapm
,
...
...
@@ -2770,6 +2773,8 @@ static void rt5645_enable_push_button_irq(struct snd_soc_codec *codec,
snd_soc_dapm_force_enable_pin_unlocked
(
&
codec
->
dapm
,
"Mic Det Power"
);
snd_soc_dapm_sync_unlocked
(
&
codec
->
dapm
);
snd_soc_dapm_mutex_unlock
(
&
codec
->
dapm
);
snd_soc_update_bits
(
codec
,
RT5645_INT_IRQ_ST
,
0x8
,
0x8
);
snd_soc_update_bits
(
codec
,
...
...
@@ -2780,6 +2785,8 @@ static void rt5645_enable_push_button_irq(struct snd_soc_codec *codec,
}
else
{
snd_soc_update_bits
(
codec
,
RT5650_4BTN_IL_CMD2
,
0x8000
,
0x0
);
snd_soc_update_bits
(
codec
,
RT5645_INT_IRQ_ST
,
0x8
,
0x0
);
snd_soc_dapm_mutex_lock
(
&
codec
->
dapm
);
snd_soc_dapm_disable_pin_unlocked
(
&
codec
->
dapm
,
"ADC L power"
);
snd_soc_dapm_disable_pin_unlocked
(
&
codec
->
dapm
,
...
...
@@ -2790,6 +2797,7 @@ static void rt5645_enable_push_button_irq(struct snd_soc_codec *codec,
snd_soc_dapm_disable_pin_unlocked
(
&
codec
->
dapm
,
"Mic Det Power"
);
snd_soc_dapm_sync_unlocked
(
&
codec
->
dapm
);
snd_soc_dapm_mutex_unlock
(
&
codec
->
dapm
);
}
}
...
...
@@ -2937,17 +2945,11 @@ static int rt5645_irq_detection(struct rt5645_priv *rt5645)
switch
(
rt5645
->
pdata
.
jd_mode
)
{
case
0
:
/* Not using rt5645 JD */
if
(
gpio_is_valid
(
rt5645
->
pdata
.
hp_det_gpio
))
{
gpio_state
=
gpio_get_value
(
rt5645
->
pdata
.
hp_det_gpio
);
dev_dbg
(
rt5645
->
codec
->
dev
,
"gpio = %d(%d)
\n
"
,
rt5645
->
pdata
.
hp_det_gpio
,
gpio_state
);
}
if
((
rt5645
->
pdata
.
gpio_hp_det_active_high
&&
gpio_state
)
||
(
!
rt5645
->
pdata
.
gpio_hp_det_active_high
&&
!
gpio_state
))
{
report
=
rt5645_jack_detect
(
rt5645
->
codec
,
1
);
}
else
{
report
=
rt5645_jack_detect
(
rt5645
->
codec
,
0
);
if
(
rt5645
->
gpiod_hp_det
)
{
gpio_state
=
gpiod_get_value
(
rt5645
->
gpiod_hp_det
);
dev_dbg
(
rt5645
->
codec
->
dev
,
"gpio_state = %d
\n
"
,
gpio_state
);
report
=
rt5645_jack_detect
(
rt5645
->
codec
,
gpio_state
);
}
snd_soc_jack_report
(
rt5645
->
hp_jack
,
report
,
SND_JACK_HEADPHONE
);
...
...
@@ -3230,6 +3232,20 @@ static struct dmi_system_id dmi_platform_intel_braswell[] = {
{
}
};
static
int
rt5645_parse_dt
(
struct
rt5645_priv
*
rt5645
,
struct
device
*
dev
)
{
rt5645
->
pdata
.
in2_diff
=
device_property_read_bool
(
dev
,
"realtek,in2-differential"
);
device_property_read_u32
(
dev
,
"realtek,dmic1-data-pin"
,
&
rt5645
->
pdata
.
dmic1_data_pin
);
device_property_read_u32
(
dev
,
"realtek,dmic2-data-pin"
,
&
rt5645
->
pdata
.
dmic2_data_pin
);
device_property_read_u32
(
dev
,
"realtek,jd-mode"
,
&
rt5645
->
pdata
.
jd_mode
);
return
0
;
}
static
int
rt5645_i2c_probe
(
struct
i2c_client
*
i2c
,
const
struct
i2c_device_id
*
id
)
{
...
...
@@ -3237,7 +3253,6 @@ static int rt5645_i2c_probe(struct i2c_client *i2c,
struct
rt5645_priv
*
rt5645
;
int
ret
;
unsigned
int
val
;
struct
gpio_desc
*
gpiod
;
rt5645
=
devm_kzalloc
(
&
i2c
->
dev
,
sizeof
(
struct
rt5645_priv
),
GFP_KERNEL
);
...
...
@@ -3247,22 +3262,19 @@ static int rt5645_i2c_probe(struct i2c_client *i2c,
rt5645
->
i2c
=
i2c
;
i2c_set_clientdata
(
i2c
,
rt5645
);
if
(
pdata
)
{
if
(
pdata
)
rt5645
->
pdata
=
*
pdata
;
}
else
{
if
(
dmi_check_system
(
dmi_platform_intel_braswell
))
{
rt5645
->
pdata
=
*
rt5645_pdata
;
gpiod
=
devm_gpiod_get_index
(
&
i2c
->
dev
,
"rt5645"
,
0
);
else
if
(
dmi_check_system
(
dmi_platform_intel_braswell
))
rt5645
->
pdata
=
*
rt5645_pdata
;
else
rt5645_parse_dt
(
rt5645
,
&
i2c
->
dev
);
if
(
IS_ERR
(
gpiod
)
||
gpiod_direction_input
(
gpiod
))
{
rt5645
->
pdata
.
hp_det_gpio
=
-
1
;
dev_err
(
&
i2c
->
dev
,
"failed to initialize gpiod
\n
"
);
}
else
{
rt5645
->
pdata
.
hp_det_gpio
=
desc_to_gpio
(
gpiod
);
rt5645
->
pdata
.
gpio_hp_det_active_high
=
!
gpiod_is_active_low
(
gpiod
);
}
}
rt5645
->
gpiod_hp_det
=
devm_gpiod_get_optional
(
&
i2c
->
dev
,
"hp-detect"
,
GPIOD_IN
);
if
(
IS_ERR
(
rt5645
->
gpiod_hp_det
))
{
dev_err
(
&
i2c
->
dev
,
"failed to initialize gpiod
\n
"
);
return
PTR_ERR
(
rt5645
->
gpiod_hp_det
);
}
rt5645
->
regmap
=
devm_regmap_init_i2c
(
i2c
,
&
rt5645_regmap
);
...
...
@@ -3426,16 +3438,6 @@ static int rt5645_i2c_probe(struct i2c_client *i2c,
dev_err
(
&
i2c
->
dev
,
"Failed to reguest IRQ: %d
\n
"
,
ret
);
}
if
(
gpio_is_valid
(
rt5645
->
pdata
.
hp_det_gpio
))
{
ret
=
gpio_request
(
rt5645
->
pdata
.
hp_det_gpio
,
"rt5645"
);
if
(
ret
)
dev_err
(
&
i2c
->
dev
,
"Fail gpio_request hp_det_gpio
\n
"
);
ret
=
gpio_direction_input
(
rt5645
->
pdata
.
hp_det_gpio
);
if
(
ret
)
dev_err
(
&
i2c
->
dev
,
"Fail gpio_direction hp_det_gpio
\n
"
);
}
return
snd_soc_register_codec
(
&
i2c
->
dev
,
&
soc_codec_dev_rt5645
,
rt5645_dai
,
ARRAY_SIZE
(
rt5645_dai
));
}
...
...
@@ -3449,9 +3451,6 @@ static int rt5645_i2c_remove(struct i2c_client *i2c)
cancel_delayed_work_sync
(
&
rt5645
->
jack_detect_work
);
if
(
gpio_is_valid
(
rt5645
->
pdata
.
hp_det_gpio
))
gpio_free
(
rt5645
->
pdata
.
hp_det_gpio
);
snd_soc_unregister_codec
(
&
i2c
->
dev
);
return
0
;
...
...
sound/soc/codecs/rt5645.h
View file @
5445d626
...
...
@@ -2182,6 +2182,7 @@ struct rt5645_priv {
struct
rt5645_platform_data
pdata
;
struct
regmap
*
regmap
;
struct
i2c_client
*
i2c
;
struct
gpio_desc
*
gpiod_hp_det
;
struct
snd_soc_jack
*
hp_jack
;
struct
snd_soc_jack
*
mic_jack
;
struct
snd_soc_jack
*
btn_jack
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment