Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
raspberrypi-kernel
提交
d14bc151
R
raspberrypi-kernel
项目概览
openeuler
/
raspberrypi-kernel
通知
13
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
raspberrypi-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
d14bc151
编写于
4月 12, 2013
作者:
M
Mark Brown
浏览文件
操作
浏览文件
下载
差异文件
Merge remote-tracking branch 'asoc/topic/tegra' into asoc-next
上级
5b9fd769
a7fc5d25
变更
11
显示空白变更内容
内联
并排
Showing
11 changed file
with
214 addition
and
223 deletion
+214
-223
Documentation/devicetree/bindings/sound/nvidia,tegra30-ahub.txt
...ntation/devicetree/bindings/sound/nvidia,tegra30-ahub.txt
+21
-5
include/sound/tegra_wm8903.h
include/sound/tegra_wm8903.h
+0
-26
sound/soc/tegra/tegra30_ahub.c
sound/soc/tegra/tegra30_ahub.c
+47
-17
sound/soc/tegra/tegra30_ahub.h
sound/soc/tegra/tegra30_ahub.h
+16
-0
sound/soc/tegra/tegra_alc5632.c
sound/soc/tegra/tegra_alc5632.c
+4
-11
sound/soc/tegra/tegra_asoc_utils.c
sound/soc/tegra/tegra_asoc_utils.c
+24
-10
sound/soc/tegra/tegra_asoc_utils.h
sound/soc/tegra/tegra_asoc_utils.h
+1
-0
sound/soc/tegra/tegra_wm8753.c
sound/soc/tegra/tegra_wm8753.c
+7
-8
sound/soc/tegra/tegra_wm8903.c
sound/soc/tegra/tegra_wm8903.c
+70
-109
sound/soc/tegra/tegra_wm9712.c
sound/soc/tegra/tegra_wm9712.c
+0
-5
sound/soc/tegra/trimslice.c
sound/soc/tegra/trimslice.c
+24
-32
未找到文件。
Documentation/devicetree/bindings/sound/nvidia,tegra30-ahub.txt
浏览文件 @
d14bc151
NVIDIA Tegra30 AHUB (Audio Hub)
Required properties:
- compatible : "nvidia,tegra30-ahub"
- compatible : "nvidia,tegra30-ahub"
, "nvidia,tegra114-ahub", etc.
- reg : Should contain the register physical address and length for each of
the AHUB's APBIF registers and the AHUB's own registers.
the AHUB's register blocks.
- Tegra30 requires 2 entries, for the APBIF and AHUB/AUDIO register blocks.
- Tegra114 requires an additional entry, for the APBIF2 register block.
- interrupts : Should contain AHUB interrupt
- nvidia,dma-request-selector : The Tegra DMA controller's phandle and
request selector for the first APBIF channel.
- nvidia,dma-request-selector : A list of the DMA channel specifiers. Each
entry contains the Tegra DMA controller's phandle and request selector.
If a single entry is present, the request selectors for the channels are
assumed to be contiguous, and increment from this value.
If multiple values are given, one value must be given per channel.
- clocks : Must contain an entry for each required entry in clock-names.
- clock-names : Must include the following entries:
- Tegra30: Requires d_audio, apbif, i2s0, i2s1, i2s2, i2s3, i2s4, dam0,
dam1, dam2, spdif_in.
- Tegra114: Additionally requires amx, adx.
- ranges : The bus address mapping for the configlink register bus.
Can be empty since the mapping is 1:1.
- #address-cells : For the configlink bus. Should be <1>;
...
...
@@ -25,7 +35,13 @@ ahub@70080000 {
reg = <0x70080000 0x200 0x70080200 0x100>;
interrupts = < 0 103 0x04 >;
nvidia,dma-request-selector = <&apbdma 1>;
clocks = <&tegra_car 106>, <&tegra_car 107>, <&tegra_car 30>,
<&tegra_car 11>, <&tegra_car 18>, <&tegra_car 101>,
<&tegra_car 102>, <&tegra_car 108>, <&tegra_car 109>,
<&tegra_car 110>, <&tegra_car 162>;
clock-names = "d_audio", "apbif", "i2s0", "i2s1", "i2s2",
"i2s3", "i2s4", "dam0", "dam1", "dam2",
"spdif_in";
ranges;
#address-cells = <1>;
#size-cells = <1>;
...
...
include/sound/tegra_wm8903.h
已删除
100644 → 0
浏览文件 @
5b9fd769
/*
* Copyright 2011 NVIDIA, Inc.
*
* This software is licensed under the terms of the GNU General Public
* License version 2, as published by the Free Software Foundation, and
* may be copied, distributed, and modified under those terms.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
*/
#ifndef __SOUND_TEGRA_WM38903_H
#define __SOUND_TEGRA_WM38903_H
struct
tegra_wm8903_platform_data
{
int
gpio_spkr_en
;
int
gpio_hp_det
;
int
gpio_hp_mute
;
int
gpio_int_mic_en
;
int
gpio_ext_mic_en
;
};
#endif
sound/soc/tegra/tegra30_ahub.c
浏览文件 @
d14bc151
...
...
@@ -287,16 +287,27 @@ int tegra30_ahub_unset_rx_cif_source(enum tegra30_ahub_rxcif rxcif)
}
EXPORT_SYMBOL_GPL
(
tegra30_ahub_unset_rx_cif_source
);
static
const
char
*
const
configlink_clocks
[]
=
{
"i2s0"
,
"i2s1"
,
"i2s2"
,
"i2s3"
,
"i2s4"
,
"dam0"
,
"dam1"
,
"dam2"
,
"spdif_in"
,
#define CLK_LIST_MASK_TEGRA30 BIT(0)
#define CLK_LIST_MASK_TEGRA114 BIT(1)
#define CLK_LIST_MASK_TEGRA30_OR_LATER \
(CLK_LIST_MASK_TEGRA30 | CLK_LIST_MASK_TEGRA114)
static
const
struct
{
const
char
*
clk_name
;
u32
clk_list_mask
;
}
configlink_clocks
[]
=
{
{
"i2s0"
,
CLK_LIST_MASK_TEGRA30_OR_LATER
},
{
"i2s1"
,
CLK_LIST_MASK_TEGRA30_OR_LATER
},
{
"i2s2"
,
CLK_LIST_MASK_TEGRA30_OR_LATER
},
{
"i2s3"
,
CLK_LIST_MASK_TEGRA30_OR_LATER
},
{
"i2s4"
,
CLK_LIST_MASK_TEGRA30_OR_LATER
},
{
"dam0"
,
CLK_LIST_MASK_TEGRA30_OR_LATER
},
{
"dam1"
,
CLK_LIST_MASK_TEGRA30_OR_LATER
},
{
"dam2"
,
CLK_LIST_MASK_TEGRA30_OR_LATER
},
{
"spdif_in"
,
CLK_LIST_MASK_TEGRA30_OR_LATER
},
{
"amx"
,
CLK_LIST_MASK_TEGRA114
},
{
"adx"
,
CLK_LIST_MASK_TEGRA114
},
};
#define LAST_REG(name) \
...
...
@@ -424,8 +435,24 @@ static const struct regmap_config tegra30_ahub_ahub_regmap_config = {
.
cache_type
=
REGCACHE_RBTREE
,
};
static
struct
tegra30_ahub_soc_data
soc_data_tegra30
=
{
.
clk_list_mask
=
CLK_LIST_MASK_TEGRA30
,
};
static
struct
tegra30_ahub_soc_data
soc_data_tegra114
=
{
.
clk_list_mask
=
CLK_LIST_MASK_TEGRA114
,
};
static
const
struct
of_device_id
tegra30_ahub_of_match
[]
=
{
{
.
compatible
=
"nvidia,tegra114-ahub"
,
.
data
=
&
soc_data_tegra114
},
{
.
compatible
=
"nvidia,tegra30-ahub"
,
.
data
=
&
soc_data_tegra30
},
{},
};
static
int
tegra30_ahub_probe
(
struct
platform_device
*
pdev
)
{
const
struct
of_device_id
*
match
;
const
struct
tegra30_ahub_soc_data
*
soc_data
;
struct
clk
*
clk
;
int
i
;
struct
resource
*
res0
,
*
res1
,
*
region
;
...
...
@@ -436,16 +463,24 @@ static int tegra30_ahub_probe(struct platform_device *pdev)
if
(
ahub
)
return
-
ENODEV
;
match
=
of_match_device
(
tegra30_ahub_of_match
,
&
pdev
->
dev
);
if
(
!
match
)
return
-
EINVAL
;
soc_data
=
match
->
data
;
/*
* The AHUB hosts a register bus: the "configlink". For this to
* operate correctly, all devices on this bus must be out of reset.
* Ensure that here.
*/
for
(
i
=
0
;
i
<
ARRAY_SIZE
(
configlink_clocks
);
i
++
)
{
clk
=
clk_get
(
&
pdev
->
dev
,
configlink_clocks
[
i
]);
if
(
!
(
configlink_clocks
[
i
].
clk_list_mask
&
soc_data
->
clk_list_mask
))
continue
;
clk
=
clk_get
(
&
pdev
->
dev
,
configlink_clocks
[
i
].
clk_name
);
if
(
IS_ERR
(
clk
))
{
dev_err
(
&
pdev
->
dev
,
"Can't get clock %s
\n
"
,
configlink_clocks
[
i
]);
configlink_clocks
[
i
]
.
clk_name
);
ret
=
PTR_ERR
(
clk
);
goto
err
;
}
...
...
@@ -592,11 +627,6 @@ static int tegra30_ahub_remove(struct platform_device *pdev)
return
0
;
}
static
const
struct
of_device_id
tegra30_ahub_of_match
[]
=
{
{
.
compatible
=
"nvidia,tegra30-ahub"
,
},
{},
};
static
const
struct
dev_pm_ops
tegra30_ahub_pm_ops
=
{
SET_RUNTIME_PM_OPS
(
tegra30_ahub_runtime_suspend
,
tegra30_ahub_runtime_resume
,
NULL
)
...
...
sound/soc/tegra/tegra30_ahub.h
浏览文件 @
d14bc151
...
...
@@ -468,7 +468,23 @@ extern int tegra30_ahub_set_rx_cif_source(enum tegra30_ahub_rxcif rxcif,
enum
tegra30_ahub_txcif
txcif
);
extern
int
tegra30_ahub_unset_rx_cif_source
(
enum
tegra30_ahub_rxcif
rxcif
);
struct
tegra30_ahub_soc_data
{
u32
clk_list_mask
;
/*
* FIXME: There are many more differences in HW, such as:
* - More APBIF channels.
* - Extra separate chunks of register address space to represent
* the extra APBIF channels.
* - More units connected to the AHUB, so that tegra30_ahub_[rt]xcif
* need expansion, coupled with there being more defined bits in
* the AHUB routing registers.
* However, the driver doesn't support those new features yet, so we
* don't represent them here yet.
*/
};
struct
tegra30_ahub
{
const
struct
tegra30_ahub_soc_data
*
soc_data
;
struct
device
*
dev
;
struct
clk
*
clk_d_audio
;
struct
clk
*
clk_apbif
;
...
...
sound/soc/tegra/tegra_alc5632.c
浏览文件 @
d14bc151
...
...
@@ -161,20 +161,13 @@ static int tegra_alc5632_probe(struct platform_device *pdev)
sizeof
(
struct
tegra_alc5632
),
GFP_KERNEL
);
if
(
!
alc5632
)
{
dev_err
(
&
pdev
->
dev
,
"Can't allocate tegra_alc5632
\n
"
);
ret
=
-
ENOMEM
;
goto
err
;
return
-
ENOMEM
;
}
card
->
dev
=
&
pdev
->
dev
;
platform_set_drvdata
(
pdev
,
card
);
snd_soc_card_set_drvdata
(
card
,
alc5632
);
if
(
!
(
pdev
->
dev
.
of_node
))
{
dev_err
(
&
pdev
->
dev
,
"Must be instantiated using device tree
\n
"
);
ret
=
-
EINVAL
;
goto
err
;
}
alc5632
->
gpio_hp_det
=
of_get_named_gpio
(
np
,
"nvidia,hp-det-gpios"
,
0
);
if
(
alc5632
->
gpio_hp_det
==
-
EPROBE_DEFER
)
return
-
EPROBE_DEFER
;
...
...
@@ -197,8 +190,8 @@ static int tegra_alc5632_probe(struct platform_device *pdev)
goto
err
;
}
tegra_alc5632_dai
.
cpu_of_node
=
of_parse_phandle
(
pdev
->
dev
.
of_node
,
"nvidia,i2s-controller"
,
0
);
tegra_alc5632_dai
.
cpu_of_node
=
of_parse_phandle
(
np
,
"nvidia,i2s-controller"
,
0
);
if
(
!
tegra_alc5632_dai
.
cpu_of_node
)
{
dev_err
(
&
pdev
->
dev
,
"Property 'nvidia,i2s-controller' missing or invalid
\n
"
);
...
...
sound/soc/tegra/tegra_asoc_utils.c
浏览文件 @
d14bc151
...
...
@@ -43,8 +43,10 @@ int tegra_asoc_utils_set_rate(struct tegra_asoc_utils_data *data, int srate,
case
88200
:
if
(
data
->
soc
==
TEGRA_ASOC_UTILS_SOC_TEGRA20
)
new_baseclock
=
56448000
;
else
else
if
(
data
->
soc
==
TEGRA_ASOC_UTILS_SOC_TEGRA30
)
new_baseclock
=
564480000
;
else
new_baseclock
=
282240000
;
break
;
case
8000
:
case
16000
:
...
...
@@ -54,8 +56,10 @@ int tegra_asoc_utils_set_rate(struct tegra_asoc_utils_data *data, int srate,
case
96000
:
if
(
data
->
soc
==
TEGRA_ASOC_UTILS_SOC_TEGRA20
)
new_baseclock
=
73728000
;
else
else
if
(
data
->
soc
==
TEGRA_ASOC_UTILS_SOC_TEGRA30
)
new_baseclock
=
552960000
;
else
new_baseclock
=
368640000
;
break
;
default:
return
-
EINVAL
;
...
...
@@ -169,6 +173,7 @@ int tegra_asoc_utils_init(struct tegra_asoc_utils_data *data,
struct
device
*
dev
)
{
int
ret
;
bool
new_clocks
=
false
;
data
->
dev
=
dev
;
...
...
@@ -176,13 +181,17 @@ int tegra_asoc_utils_init(struct tegra_asoc_utils_data *data,
data
->
soc
=
TEGRA_ASOC_UTILS_SOC_TEGRA20
;
else
if
(
of_machine_is_compatible
(
"nvidia,tegra30"
))
data
->
soc
=
TEGRA_ASOC_UTILS_SOC_TEGRA30
;
else
if
(
!
dev
->
of_node
)
/* non-DT is always Tegra20 */
data
->
soc
=
TEGRA_ASOC_UTILS_SOC_TEGRA20
;
else
/* DT boot, but unknown SoC */
else
if
(
of_machine_is_compatible
(
"nvidia,tegra114"
))
{
data
->
soc
=
TEGRA_ASOC_UTILS_SOC_TEGRA114
;
new_clocks
=
true
;
}
else
{
dev_err
(
data
->
dev
,
"SoC unknown to Tegra ASoC utils
\n
"
);
return
-
EINVAL
;
}
if
(
new_clocks
)
data
->
clk_pll_a
=
clk_get
(
dev
,
"pll_a"
);
else
data
->
clk_pll_a
=
clk_get_sys
(
NULL
,
"pll_a"
);
if
(
IS_ERR
(
data
->
clk_pll_a
))
{
dev_err
(
data
->
dev
,
"Can't retrieve clk pll_a
\n
"
);
...
...
@@ -190,6 +199,9 @@ int tegra_asoc_utils_init(struct tegra_asoc_utils_data *data,
goto
err
;
}
if
(
new_clocks
)
data
->
clk_pll_a_out0
=
clk_get
(
dev
,
"pll_a_out0"
);
else
data
->
clk_pll_a_out0
=
clk_get_sys
(
NULL
,
"pll_a_out0"
);
if
(
IS_ERR
(
data
->
clk_pll_a_out0
))
{
dev_err
(
data
->
dev
,
"Can't retrieve clk pll_a_out0
\n
"
);
...
...
@@ -197,7 +209,9 @@ int tegra_asoc_utils_init(struct tegra_asoc_utils_data *data,
goto
err_put_pll_a
;
}
if
(
data
->
soc
==
TEGRA_ASOC_UTILS_SOC_TEGRA20
)
if
(
new_clocks
)
data
->
clk_cdev1
=
clk_get
(
dev
,
"mclk"
);
else
if
(
data
->
soc
==
TEGRA_ASOC_UTILS_SOC_TEGRA20
)
data
->
clk_cdev1
=
clk_get_sys
(
NULL
,
"cdev1"
);
else
data
->
clk_cdev1
=
clk_get_sys
(
"extern1"
,
NULL
);
...
...
sound/soc/tegra/tegra_asoc_utils.h
浏览文件 @
d14bc151
...
...
@@ -29,6 +29,7 @@ struct device;
enum
tegra_asoc_utils_soc
{
TEGRA_ASOC_UTILS_SOC_TEGRA20
,
TEGRA_ASOC_UTILS_SOC_TEGRA30
,
TEGRA_ASOC_UTILS_SOC_TEGRA114
,
};
struct
tegra_asoc_utils_data
{
...
...
sound/soc/tegra/tegra_wm8753.c
浏览文件 @
d14bc151
...
...
@@ -124,6 +124,7 @@ static struct snd_soc_card snd_soc_tegra_wm8753 = {
static
int
tegra_wm8753_driver_probe
(
struct
platform_device
*
pdev
)
{
struct
device_node
*
np
=
pdev
->
dev
.
of_node
;
struct
snd_soc_card
*
card
=
&
snd_soc_tegra_wm8753
;
struct
tegra_wm8753
*
machine
;
int
ret
;
...
...
@@ -132,8 +133,7 @@ static int tegra_wm8753_driver_probe(struct platform_device *pdev)
GFP_KERNEL
);
if
(
!
machine
)
{
dev_err
(
&
pdev
->
dev
,
"Can't allocate tegra_wm8753 struct
\n
"
);
ret
=
-
ENOMEM
;
goto
err
;
return
-
ENOMEM
;
}
card
->
dev
=
&
pdev
->
dev
;
...
...
@@ -148,8 +148,8 @@ static int tegra_wm8753_driver_probe(struct platform_device *pdev)
if
(
ret
)
goto
err
;
tegra_wm8753_dai
.
codec_of_node
=
of_parse_phandle
(
pdev
->
dev
.
of_node
,
"nvidia,audio-codec"
,
0
);
tegra_wm8753_dai
.
codec_of_node
=
of_parse_phandle
(
np
,
"nvidia,audio-codec"
,
0
);
if
(
!
tegra_wm8753_dai
.
codec_of_node
)
{
dev_err
(
&
pdev
->
dev
,
"Property 'nvidia,audio-codec' missing or invalid
\n
"
);
...
...
@@ -157,8 +157,8 @@ static int tegra_wm8753_driver_probe(struct platform_device *pdev)
goto
err
;
}
tegra_wm8753_dai
.
cpu_of_node
=
of_parse_phandle
(
pdev
->
dev
.
of_node
,
"nvidia,i2s-controller"
,
0
);
tegra_wm8753_dai
.
cpu_of_node
=
of_parse_phandle
(
np
,
"nvidia,i2s-controller"
,
0
);
if
(
!
tegra_wm8753_dai
.
cpu_of_node
)
{
dev_err
(
&
pdev
->
dev
,
"Property 'nvidia,i2s-controller' missing or invalid
\n
"
);
...
...
@@ -166,8 +166,7 @@ static int tegra_wm8753_driver_probe(struct platform_device *pdev)
goto
err
;
}
tegra_wm8753_dai
.
platform_of_node
=
tegra_wm8753_dai
.
cpu_of_node
;
tegra_wm8753_dai
.
platform_of_node
=
tegra_wm8753_dai
.
cpu_of_node
;
ret
=
tegra_asoc_utils_init
(
&
machine
->
util_data
,
&
pdev
->
dev
);
if
(
ret
)
...
...
sound/soc/tegra/tegra_wm8903.c
浏览文件 @
d14bc151
...
...
@@ -39,7 +39,6 @@
#include <sound/pcm.h>
#include <sound/pcm_params.h>
#include <sound/soc.h>
#include <sound/tegra_wm8903.h>
#include "../codecs/wm8903.h"
...
...
@@ -48,7 +47,11 @@
#define DRV_NAME "tegra-snd-wm8903"
struct
tegra_wm8903
{
struct
tegra_wm8903_platform_data
pdata
;
int
gpio_spkr_en
;
int
gpio_hp_det
;
int
gpio_hp_mute
;
int
gpio_int_mic_en
;
int
gpio_ext_mic_en
;
struct
tegra_asoc_utils_data
util_data
;
};
...
...
@@ -129,12 +132,11 @@ static int tegra_wm8903_event_int_spk(struct snd_soc_dapm_widget *w,
struct
snd_soc_dapm_context
*
dapm
=
w
->
dapm
;
struct
snd_soc_card
*
card
=
dapm
->
card
;
struct
tegra_wm8903
*
machine
=
snd_soc_card_get_drvdata
(
card
);
struct
tegra_wm8903_platform_data
*
pdata
=
&
machine
->
pdata
;
if
(
!
gpio_is_valid
(
pdata
->
gpio_spkr_en
))
if
(
!
gpio_is_valid
(
machine
->
gpio_spkr_en
))
return
0
;
gpio_set_value_cansleep
(
pdata
->
gpio_spkr_en
,
gpio_set_value_cansleep
(
machine
->
gpio_spkr_en
,
SND_SOC_DAPM_EVENT_ON
(
event
));
return
0
;
...
...
@@ -146,12 +148,11 @@ static int tegra_wm8903_event_hp(struct snd_soc_dapm_widget *w,
struct
snd_soc_dapm_context
*
dapm
=
w
->
dapm
;
struct
snd_soc_card
*
card
=
dapm
->
card
;
struct
tegra_wm8903
*
machine
=
snd_soc_card_get_drvdata
(
card
);
struct
tegra_wm8903_platform_data
*
pdata
=
&
machine
->
pdata
;
if
(
!
gpio_is_valid
(
pdata
->
gpio_hp_mute
))
if
(
!
gpio_is_valid
(
machine
->
gpio_hp_mute
))
return
0
;
gpio_set_value_cansleep
(
pdata
->
gpio_hp_mute
,
gpio_set_value_cansleep
(
machine
->
gpio_hp_mute
,
!
SND_SOC_DAPM_EVENT_ON
(
event
));
return
0
;
...
...
@@ -163,17 +164,6 @@ static const struct snd_soc_dapm_widget tegra_wm8903_dapm_widgets[] = {
SND_SOC_DAPM_MIC
(
"Mic Jack"
,
NULL
),
};
static
const
struct
snd_soc_dapm_route
harmony_audio_map
[]
=
{
{
"Headphone Jack"
,
NULL
,
"HPOUTR"
},
{
"Headphone Jack"
,
NULL
,
"HPOUTL"
},
{
"Int Spk"
,
NULL
,
"ROP"
},
{
"Int Spk"
,
NULL
,
"RON"
},
{
"Int Spk"
,
NULL
,
"LOP"
},
{
"Int Spk"
,
NULL
,
"LON"
},
{
"Mic Jack"
,
NULL
,
"MICBIAS"
},
{
"IN1L"
,
NULL
,
"Mic Jack"
},
};
static
const
struct
snd_kcontrol_new
tegra_wm8903_controls
[]
=
{
SOC_DAPM_PIN_SWITCH
(
"Int Spk"
),
};
...
...
@@ -185,10 +175,9 @@ static int tegra_wm8903_init(struct snd_soc_pcm_runtime *rtd)
struct
snd_soc_dapm_context
*
dapm
=
&
codec
->
dapm
;
struct
snd_soc_card
*
card
=
codec
->
card
;
struct
tegra_wm8903
*
machine
=
snd_soc_card_get_drvdata
(
card
);
struct
tegra_wm8903_platform_data
*
pdata
=
&
machine
->
pdata
;
if
(
gpio_is_valid
(
pdata
->
gpio_hp_det
))
{
tegra_wm8903_hp_jack_gpio
.
gpio
=
pdata
->
gpio_hp_det
;
if
(
gpio_is_valid
(
machine
->
gpio_hp_det
))
{
tegra_wm8903_hp_jack_gpio
.
gpio
=
machine
->
gpio_hp_det
;
snd_soc_jack_new
(
codec
,
"Headphone Jack"
,
SND_JACK_HEADPHONE
,
&
tegra_wm8903_hp_jack
);
snd_soc_jack_add_pins
(
&
tegra_wm8903_hp_jack
,
...
...
@@ -226,9 +215,6 @@ static int tegra_wm8903_remove(struct snd_soc_card *card)
static
struct
snd_soc_dai_link
tegra_wm8903_dai
=
{
.
name
=
"WM8903"
,
.
stream_name
=
"WM8903 PCM"
,
.
codec_name
=
"wm8903.0-001a"
,
.
platform_name
=
"tegra20-i2s.0"
,
.
cpu_dai_name
=
"tegra20-i2s.0"
,
.
codec_dai_name
=
"wm8903-hifi"
,
.
init
=
tegra_wm8903_init
,
.
ops
=
&
tegra_wm8903_ops
,
...
...
@@ -257,67 +243,87 @@ static int tegra_wm8903_driver_probe(struct platform_device *pdev)
struct
device_node
*
np
=
pdev
->
dev
.
of_node
;
struct
snd_soc_card
*
card
=
&
snd_soc_tegra_wm8903
;
struct
tegra_wm8903
*
machine
;
struct
tegra_wm8903_platform_data
*
pdata
;
int
ret
;
if
(
!
pdev
->
dev
.
platform_data
&&
!
pdev
->
dev
.
of_node
)
{
dev_err
(
&
pdev
->
dev
,
"No platform data supplied
\n
"
);
return
-
EINVAL
;
}
machine
=
devm_kzalloc
(
&
pdev
->
dev
,
sizeof
(
struct
tegra_wm8903
),
GFP_KERNEL
);
if
(
!
machine
)
{
dev_err
(
&
pdev
->
dev
,
"Can't allocate tegra_wm8903 struct
\n
"
);
ret
=
-
ENOMEM
;
goto
err
;
return
-
ENOMEM
;
}
pdata
=
&
machine
->
pdata
;
card
->
dev
=
&
pdev
->
dev
;
platform_set_drvdata
(
pdev
,
card
);
snd_soc_card_set_drvdata
(
card
,
machine
);
if
(
pdev
->
dev
.
platform_data
)
{
memcpy
(
pdata
,
card
->
dev
->
platform_data
,
sizeof
(
*
pdata
));
}
else
if
(
np
)
{
pdata
->
gpio_spkr_en
=
of_get_named_gpio
(
np
,
"nvidia,spkr-en-gpios"
,
0
);
if
(
pdata
->
gpio_spkr_en
==
-
EPROBE_DEFER
)
machine
->
gpio_spkr_en
=
of_get_named_gpio
(
np
,
"nvidia,spkr-en-gpios"
,
0
);
if
(
machine
->
gpio_spkr_en
==
-
EPROBE_DEFER
)
return
-
EPROBE_DEFER
;
if
(
gpio_is_valid
(
machine
->
gpio_spkr_en
))
{
ret
=
devm_gpio_request_one
(
&
pdev
->
dev
,
machine
->
gpio_spkr_en
,
GPIOF_OUT_INIT_LOW
,
"spkr_en"
);
if
(
ret
)
{
dev_err
(
card
->
dev
,
"cannot get spkr_en gpio
\n
"
);
return
ret
;
}
}
pdata
->
gpio_hp_mute
=
of_get_named_gpio
(
np
,
"nvidia,hp-mute-gpios"
,
0
);
if
(
pdata
->
gpio_hp_mute
==
-
EPROBE_DEFER
)
machine
->
gpio_hp_mute
=
of_get_named_gpio
(
np
,
"nvidia,hp-mute-gpios"
,
0
);
if
(
machine
->
gpio_hp_mute
==
-
EPROBE_DEFER
)
return
-
EPROBE_DEFER
;
if
(
gpio_is_valid
(
machine
->
gpio_hp_mute
))
{
ret
=
devm_gpio_request_one
(
&
pdev
->
dev
,
machine
->
gpio_hp_mute
,
GPIOF_OUT_INIT_HIGH
,
"hp_mute"
);
if
(
ret
)
{
dev_err
(
card
->
dev
,
"cannot get hp_mute gpio
\n
"
);
return
ret
;
}
}
pdata
->
gpio_hp_det
=
of_get_named_gpio
(
np
,
"nvidia,hp-det-gpios"
,
0
);
if
(
pdata
->
gpio_hp_det
==
-
EPROBE_DEFER
)
machine
->
gpio_hp_det
=
of_get_named_gpio
(
np
,
"nvidia,hp-det-gpios"
,
0
);
if
(
machine
->
gpio_hp_det
==
-
EPROBE_DEFER
)
return
-
EPROBE_DEFER
;
pdata
->
gpio_int_mic_en
=
of_get_named_gpio
(
np
,
machine
->
gpio_int_mic_en
=
of_get_named_gpio
(
np
,
"nvidia,int-mic-en-gpios"
,
0
);
if
(
pdata
->
gpio_int_mic_en
==
-
EPROBE_DEFER
)
if
(
machine
->
gpio_int_mic_en
==
-
EPROBE_DEFER
)
return
-
EPROBE_DEFER
;
if
(
gpio_is_valid
(
machine
->
gpio_int_mic_en
))
{
/* Disable int mic; enable signal is active-high */
ret
=
devm_gpio_request_one
(
&
pdev
->
dev
,
machine
->
gpio_int_mic_en
,
GPIOF_OUT_INIT_LOW
,
"int_mic_en"
);
if
(
ret
)
{
dev_err
(
card
->
dev
,
"cannot get int_mic_en gpio
\n
"
);
return
ret
;
}
}
pdata
->
gpio_ext_mic_en
=
of_get_named_gpio
(
np
,
machine
->
gpio_ext_mic_en
=
of_get_named_gpio
(
np
,
"nvidia,ext-mic-en-gpios"
,
0
);
if
(
pdata
->
gpio_ext_mic_en
==
-
EPROBE_DEFER
)
if
(
machine
->
gpio_ext_mic_en
==
-
EPROBE_DEFER
)
return
-
EPROBE_DEFER
;
if
(
gpio_is_valid
(
machine
->
gpio_ext_mic_en
))
{
/* Enable ext mic; enable signal is active-low */
ret
=
devm_gpio_request_one
(
&
pdev
->
dev
,
machine
->
gpio_ext_mic_en
,
GPIOF_OUT_INIT_LOW
,
"ext_mic_en"
);
if
(
ret
)
{
dev_err
(
card
->
dev
,
"cannot get ext_mic_en gpio
\n
"
);
return
ret
;
}
}
if
(
np
)
{
ret
=
snd_soc_of_parse_card_name
(
card
,
"nvidia,model"
);
if
(
ret
)
goto
err
;
ret
=
snd_soc_of_parse_audio_routing
(
card
,
"nvidia,audio-routing"
);
ret
=
snd_soc_of_parse_audio_routing
(
card
,
"nvidia,audio-routing"
);
if
(
ret
)
goto
err
;
tegra_wm8903_dai
.
codec_name
=
NULL
;
tegra_wm8903_dai
.
codec_of_node
=
of_parse_phandle
(
np
,
"nvidia,audio-codec"
,
0
);
if
(
!
tegra_wm8903_dai
.
codec_of_node
)
{
...
...
@@ -327,7 +333,6 @@ static int tegra_wm8903_driver_probe(struct platform_device *pdev)
goto
err
;
}
tegra_wm8903_dai
.
cpu_dai_name
=
NULL
;
tegra_wm8903_dai
.
cpu_of_node
=
of_parse_phandle
(
np
,
"nvidia,i2s-controller"
,
0
);
if
(
!
tegra_wm8903_dai
.
cpu_of_node
)
{
...
...
@@ -337,51 +342,7 @@ static int tegra_wm8903_driver_probe(struct platform_device *pdev)
goto
err
;
}
tegra_wm8903_dai
.
platform_name
=
NULL
;
tegra_wm8903_dai
.
platform_of_node
=
tegra_wm8903_dai
.
cpu_of_node
;
}
else
{
card
->
dapm_routes
=
harmony_audio_map
;
card
->
num_dapm_routes
=
ARRAY_SIZE
(
harmony_audio_map
);
}
if
(
gpio_is_valid
(
pdata
->
gpio_spkr_en
))
{
ret
=
devm_gpio_request_one
(
&
pdev
->
dev
,
pdata
->
gpio_spkr_en
,
GPIOF_OUT_INIT_LOW
,
"spkr_en"
);
if
(
ret
)
{
dev_err
(
card
->
dev
,
"cannot get spkr_en gpio
\n
"
);
return
ret
;
}
}
if
(
gpio_is_valid
(
pdata
->
gpio_hp_mute
))
{
ret
=
devm_gpio_request_one
(
&
pdev
->
dev
,
pdata
->
gpio_hp_mute
,
GPIOF_OUT_INIT_HIGH
,
"hp_mute"
);
if
(
ret
)
{
dev_err
(
card
->
dev
,
"cannot get hp_mute gpio
\n
"
);
return
ret
;
}
}
if
(
gpio_is_valid
(
pdata
->
gpio_int_mic_en
))
{
/* Disable int mic; enable signal is active-high */
ret
=
devm_gpio_request_one
(
&
pdev
->
dev
,
pdata
->
gpio_int_mic_en
,
GPIOF_OUT_INIT_LOW
,
"int_mic_en"
);
if
(
ret
)
{
dev_err
(
card
->
dev
,
"cannot get int_mic_en gpio
\n
"
);
return
ret
;
}
}
if
(
gpio_is_valid
(
pdata
->
gpio_ext_mic_en
))
{
/* Enable ext mic; enable signal is active-low */
ret
=
devm_gpio_request_one
(
&
pdev
->
dev
,
pdata
->
gpio_ext_mic_en
,
GPIOF_OUT_INIT_LOW
,
"ext_mic_en"
);
if
(
ret
)
{
dev_err
(
card
->
dev
,
"cannot get ext_mic_en gpio
\n
"
);
return
ret
;
}
}
tegra_wm8903_dai
.
platform_of_node
=
tegra_wm8903_dai
.
cpu_of_node
;
ret
=
tegra_asoc_utils_init
(
&
machine
->
util_data
,
&
pdev
->
dev
);
if
(
ret
)
...
...
sound/soc/tegra/tegra_wm9712.c
浏览文件 @
d14bc151
...
...
@@ -79,11 +79,6 @@ static int tegra_wm9712_driver_probe(struct platform_device *pdev)
struct
tegra_wm9712
*
machine
;
int
ret
;
if
(
!
pdev
->
dev
.
of_node
)
{
dev_err
(
&
pdev
->
dev
,
"No platform data supplied
\n
"
);
return
-
EINVAL
;
}
machine
=
devm_kzalloc
(
&
pdev
->
dev
,
sizeof
(
struct
tegra_wm9712
),
GFP_KERNEL
);
if
(
!
machine
)
{
...
...
sound/soc/tegra/trimslice.c
浏览文件 @
d14bc151
...
...
@@ -97,9 +97,6 @@ static const struct snd_soc_dapm_route trimslice_audio_map[] = {
static
struct
snd_soc_dai_link
trimslice_tlv320aic23_dai
=
{
.
name
=
"TLV320AIC23"
,
.
stream_name
=
"AIC23"
,
.
codec_name
=
"tlv320aic23-codec.2-001a"
,
.
platform_name
=
"tegra20-i2s.0"
,
.
cpu_dai_name
=
"tegra20-i2s.0"
,
.
codec_dai_name
=
"tlv320aic23-hifi"
,
.
ops
=
&
trimslice_asoc_ops
,
.
dai_fmt
=
SND_SOC_DAIFMT_I2S
|
...
...
@@ -122,6 +119,7 @@ static struct snd_soc_card snd_soc_trimslice = {
static
int
tegra_snd_trimslice_probe
(
struct
platform_device
*
pdev
)
{
struct
device_node
*
np
=
pdev
->
dev
.
of_node
;
struct
snd_soc_card
*
card
=
&
snd_soc_trimslice
;
struct
tegra_trimslice
*
trimslice
;
int
ret
;
...
...
@@ -130,14 +128,15 @@ static int tegra_snd_trimslice_probe(struct platform_device *pdev)
GFP_KERNEL
);
if
(
!
trimslice
)
{
dev_err
(
&
pdev
->
dev
,
"Can't allocate tegra_trimslice
\n
"
);
ret
=
-
ENOMEM
;
goto
err
;
return
-
ENOMEM
;
}
if
(
pdev
->
dev
.
of_node
)
{
trimslice_tlv320aic23_dai
.
codec_name
=
NULL
;
trimslice_tlv320aic23_dai
.
codec_of_node
=
of_parse_phandle
(
pdev
->
dev
.
of_node
,
"nvidia,audio-codec"
,
0
);
card
->
dev
=
&
pdev
->
dev
;
platform_set_drvdata
(
pdev
,
card
);
snd_soc_card_set_drvdata
(
card
,
trimslice
);
trimslice_tlv320aic23_dai
.
codec_of_node
=
of_parse_phandle
(
np
,
"nvidia,audio-codec"
,
0
);
if
(
!
trimslice_tlv320aic23_dai
.
codec_of_node
)
{
dev_err
(
&
pdev
->
dev
,
"Property 'nvidia,audio-codec' missing or invalid
\n
"
);
...
...
@@ -145,9 +144,8 @@ static int tegra_snd_trimslice_probe(struct platform_device *pdev)
goto
err
;
}
trimslice_tlv320aic23_dai
.
cpu_dai_name
=
NULL
;
trimslice_tlv320aic23_dai
.
cpu_of_node
=
of_parse_phandle
(
pdev
->
dev
.
of_node
,
"nvidia,i2s-controller"
,
0
);
trimslice_tlv320aic23_dai
.
cpu_of_node
=
of_parse_phandle
(
np
,
"nvidia,i2s-controller"
,
0
);
if
(
!
trimslice_tlv320aic23_dai
.
cpu_of_node
)
{
dev_err
(
&
pdev
->
dev
,
"Property 'nvidia,i2s-controller' missing or invalid
\n
"
);
...
...
@@ -155,19 +153,13 @@ static int tegra_snd_trimslice_probe(struct platform_device *pdev)
goto
err
;
}
trimslice_tlv320aic23_dai
.
platform_name
=
NULL
;
trimslice_tlv320aic23_dai
.
platform_of_node
=
trimslice_tlv320aic23_dai
.
cpu_of_node
;
}
ret
=
tegra_asoc_utils_init
(
&
trimslice
->
util_data
,
&
pdev
->
dev
);
if
(
ret
)
goto
err
;
card
->
dev
=
&
pdev
->
dev
;
platform_set_drvdata
(
pdev
,
card
);
snd_soc_card_set_drvdata
(
card
,
trimslice
);
ret
=
snd_soc_register_card
(
card
);
if
(
ret
)
{
dev_err
(
&
pdev
->
dev
,
"snd_soc_register_card failed (%d)
\n
"
,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录