Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
19142ae6
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看板
提交
19142ae6
编写于
3月 13, 2016
作者:
M
Mark Brown
浏览文件
操作
浏览文件
下载
差异文件
Merge remote-tracking branch 'asoc/topic/pcm179x' into asoc-next
上级
fc122f63
e0236f54
变更
7
隐藏空白更改
内联
并排
Showing
7 changed file
with
196 addition
and
49 deletion
+196
-49
Documentation/devicetree/bindings/sound/pcm179x.txt
Documentation/devicetree/bindings/sound/pcm179x.txt
+10
-1
sound/soc/codecs/Kconfig
sound/soc/codecs/Kconfig
+18
-2
sound/soc/codecs/Makefile
sound/soc/codecs/Makefile
+4
-0
sound/soc/codecs/pcm179x-i2c.c
sound/soc/codecs/pcm179x-i2c.c
+73
-0
sound/soc/codecs/pcm179x-spi.c
sound/soc/codecs/pcm179x-spi.c
+72
-0
sound/soc/codecs/pcm179x.c
sound/soc/codecs/pcm179x.c
+14
-42
sound/soc/codecs/pcm179x.h
sound/soc/codecs/pcm179x.h
+5
-4
未找到文件。
Documentation/devicetree/bindings/sound/pcm179x.txt
浏览文件 @
19142ae6
Texas Instruments pcm179x DT bindings
Texas Instruments pcm179x DT bindings
This driver supports
the
SPI bus.
This driver supports
both the I2C and
SPI bus.
Required properties:
Required properties:
...
@@ -9,6 +9,11 @@ Required properties:
...
@@ -9,6 +9,11 @@ Required properties:
For required properties on SPI, please consult
For required properties on SPI, please consult
Documentation/devicetree/bindings/spi/spi-bus.txt
Documentation/devicetree/bindings/spi/spi-bus.txt
Required properties on I2C:
- reg: the I2C address
Examples:
Examples:
codec_spi: 1792a@0 {
codec_spi: 1792a@0 {
...
@@ -16,3 +21,7 @@ Examples:
...
@@ -16,3 +21,7 @@ Examples:
spi-max-frequency = <600000>;
spi-max-frequency = <600000>;
};
};
codec_i2c: 1792a@4c {
compatible = "ti,pcm1792a";
reg = <0x4c>;
};
sound/soc/codecs/Kconfig
浏览文件 @
19142ae6
...
@@ -87,7 +87,8 @@ config SND_SOC_ALL_CODECS
...
@@ -87,7 +87,8 @@ config SND_SOC_ALL_CODECS
select SND_SOC_ML26124 if I2C
select SND_SOC_ML26124 if I2C
select SND_SOC_NAU8825 if I2C
select SND_SOC_NAU8825 if I2C
select SND_SOC_PCM1681 if I2C
select SND_SOC_PCM1681 if I2C
select SND_SOC_PCM179X if SPI_MASTER
select SND_SOC_PCM179X_I2C if I2C
select SND_SOC_PCM179X_SPI if SPI_MASTER
select SND_SOC_PCM3008
select SND_SOC_PCM3008
select SND_SOC_PCM3168A_I2C if I2C
select SND_SOC_PCM3168A_I2C if I2C
select SND_SOC_PCM3168A_SPI if SPI_MASTER
select SND_SOC_PCM3168A_SPI if SPI_MASTER
...
@@ -528,8 +529,23 @@ config SND_SOC_PCM1681
...
@@ -528,8 +529,23 @@ config SND_SOC_PCM1681
depends on I2C
depends on I2C
config SND_SOC_PCM179X
config SND_SOC_PCM179X
tristate "Texas Instruments PCM179X CODEC"
tristate
config SND_SOC_PCM179X_I2C
tristate "Texas Instruments PCM179X CODEC (I2C)"
depends on I2C
select SND_SOC_PCM179X
help
Enable support for Texas Instruments PCM179x CODEC.
Select this if your PCM179x is connected via an I2C bus.
config SND_SOC_PCM179X_SPI
tristate "Texas Instruments PCM179X CODEC (SPI)"
depends on SPI_MASTER
depends on SPI_MASTER
select SND_SOC_PCM179X
help
Enable support for Texas Instruments PCM179x CODEC.
Select this if your PCM179x is connected via an SPI bus.
config SND_SOC_PCM3008
config SND_SOC_PCM3008
tristate
tristate
...
...
sound/soc/codecs/Makefile
浏览文件 @
19142ae6
...
@@ -81,6 +81,8 @@ snd-soc-ml26124-objs := ml26124.o
...
@@ -81,6 +81,8 @@ snd-soc-ml26124-objs := ml26124.o
snd-soc-nau8825-objs
:=
nau8825.o
snd-soc-nau8825-objs
:=
nau8825.o
snd-soc-pcm1681-objs
:=
pcm1681.o
snd-soc-pcm1681-objs
:=
pcm1681.o
snd-soc-pcm179x-codec-objs
:=
pcm179x.o
snd-soc-pcm179x-codec-objs
:=
pcm179x.o
snd-soc-pcm179x-i2c-objs
:=
pcm179x-i2c.o
snd-soc-pcm179x-spi-objs
:=
pcm179x-spi.o
snd-soc-pcm3008-objs
:=
pcm3008.o
snd-soc-pcm3008-objs
:=
pcm3008.o
snd-soc-pcm3168a-objs
:=
pcm3168a.o
snd-soc-pcm3168a-objs
:=
pcm3168a.o
snd-soc-pcm3168a-i2c-objs
:=
pcm3168a-i2c.o
snd-soc-pcm3168a-i2c-objs
:=
pcm3168a-i2c.o
...
@@ -285,6 +287,8 @@ obj-$(CONFIG_SND_SOC_ML26124) += snd-soc-ml26124.o
...
@@ -285,6 +287,8 @@ obj-$(CONFIG_SND_SOC_ML26124) += snd-soc-ml26124.o
obj-$(CONFIG_SND_SOC_NAU8825)
+=
snd-soc-nau8825.o
obj-$(CONFIG_SND_SOC_NAU8825)
+=
snd-soc-nau8825.o
obj-$(CONFIG_SND_SOC_PCM1681)
+=
snd-soc-pcm1681.o
obj-$(CONFIG_SND_SOC_PCM1681)
+=
snd-soc-pcm1681.o
obj-$(CONFIG_SND_SOC_PCM179X)
+=
snd-soc-pcm179x-codec.o
obj-$(CONFIG_SND_SOC_PCM179X)
+=
snd-soc-pcm179x-codec.o
obj-$(CONFIG_SND_SOC_PCM179X_I2C)
+=
snd-soc-pcm179x-i2c.o
obj-$(CONFIG_SND_SOC_PCM179X_SPI)
+=
snd-soc-pcm179x-spi.o
obj-$(CONFIG_SND_SOC_PCM3008)
+=
snd-soc-pcm3008.o
obj-$(CONFIG_SND_SOC_PCM3008)
+=
snd-soc-pcm3008.o
obj-$(CONFIG_SND_SOC_PCM3168A)
+=
snd-soc-pcm3168a.o
obj-$(CONFIG_SND_SOC_PCM3168A)
+=
snd-soc-pcm3168a.o
obj-$(CONFIG_SND_SOC_PCM3168A_I2C)
+=
snd-soc-pcm3168a-i2c.o
obj-$(CONFIG_SND_SOC_PCM3168A_I2C)
+=
snd-soc-pcm3168a-i2c.o
...
...
sound/soc/codecs/pcm179x-i2c.c
0 → 100644
浏览文件 @
19142ae6
/*
* PCM179X ASoC I2C driver
*
* Copyright (c) Teenage Engineering AB 2016
*
* Jacob Siverskog <jacob@teenage.engineering>
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* 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.
*/
#include <linux/module.h>
#include <linux/of.h>
#include <linux/i2c.h>
#include <linux/regmap.h>
#include "pcm179x.h"
static
int
pcm179x_i2c_probe
(
struct
i2c_client
*
client
,
const
struct
i2c_device_id
*
id
)
{
struct
regmap
*
regmap
;
int
ret
;
regmap
=
devm_regmap_init_i2c
(
client
,
&
pcm179x_regmap_config
);
if
(
IS_ERR
(
regmap
))
{
ret
=
PTR_ERR
(
regmap
);
dev_err
(
&
client
->
dev
,
"Failed to allocate regmap: %d
\n
"
,
ret
);
return
ret
;
}
return
pcm179x_common_init
(
&
client
->
dev
,
regmap
);
}
static
int
pcm179x_i2c_remove
(
struct
i2c_client
*
client
)
{
return
pcm179x_common_exit
(
&
client
->
dev
);
}
static
const
struct
of_device_id
pcm179x_of_match
[]
=
{
{
.
compatible
=
"ti,pcm1792a"
,
},
{
}
};
MODULE_DEVICE_TABLE
(
of
,
pcm179x_of_match
);
static
const
struct
i2c_device_id
pcm179x_i2c_ids
[]
=
{
{
"pcm179x"
,
0
},
{
}
};
MODULE_DEVICE_TABLE
(
i2c
,
pcm179x_i2c_ids
);
static
struct
i2c_driver
pcm179x_i2c_driver
=
{
.
driver
=
{
.
name
=
"pcm179x"
,
.
of_match_table
=
of_match_ptr
(
pcm179x_of_match
),
},
.
id_table
=
pcm179x_i2c_ids
,
.
probe
=
pcm179x_i2c_probe
,
.
remove
=
pcm179x_i2c_remove
,
};
module_i2c_driver
(
pcm179x_i2c_driver
);
MODULE_DESCRIPTION
(
"ASoC PCM179X I2C driver"
);
MODULE_AUTHOR
(
"Jacob Siverskog <jacob@teenage.engineering>"
);
MODULE_LICENSE
(
"GPL"
);
sound/soc/codecs/pcm179x-spi.c
0 → 100644
浏览文件 @
19142ae6
/*
* PCM179X ASoC SPI driver
*
* Copyright (c) Amarula Solutions B.V. 2013
*
* Michael Trimarchi <michael@amarulasolutions.com>
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation; either version 2
* of the License, or (at your option) any later version.
*
* 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.
*/
#include <linux/module.h>
#include <linux/of.h>
#include <linux/spi/spi.h>
#include <linux/regmap.h>
#include "pcm179x.h"
static
int
pcm179x_spi_probe
(
struct
spi_device
*
spi
)
{
struct
regmap
*
regmap
;
int
ret
;
regmap
=
devm_regmap_init_spi
(
spi
,
&
pcm179x_regmap_config
);
if
(
IS_ERR
(
regmap
))
{
ret
=
PTR_ERR
(
regmap
);
dev_err
(
&
spi
->
dev
,
"Failed to allocate regmap: %d
\n
"
,
ret
);
return
ret
;
}
return
pcm179x_common_init
(
&
spi
->
dev
,
regmap
);
}
static
int
pcm179x_spi_remove
(
struct
spi_device
*
spi
)
{
return
pcm179x_common_exit
(
&
spi
->
dev
);
}
static
const
struct
of_device_id
pcm179x_of_match
[]
=
{
{
.
compatible
=
"ti,pcm1792a"
,
},
{
}
};
MODULE_DEVICE_TABLE
(
of
,
pcm179x_of_match
);
static
const
struct
spi_device_id
pcm179x_spi_ids
[]
=
{
{
"pcm179x"
,
0
},
{
},
};
MODULE_DEVICE_TABLE
(
spi
,
pcm179x_spi_ids
);
static
struct
spi_driver
pcm179x_spi_driver
=
{
.
driver
=
{
.
name
=
"pcm179x"
,
.
of_match_table
=
of_match_ptr
(
pcm179x_of_match
),
},
.
id_table
=
pcm179x_spi_ids
,
.
probe
=
pcm179x_spi_probe
,
.
remove
=
pcm179x_spi_remove
,
};
module_spi_driver
(
pcm179x_spi_driver
);
MODULE_DESCRIPTION
(
"ASoC PCM179X SPI driver"
);
MODULE_AUTHOR
(
"Michael Trimarchi <michael@amarulasolutions.com>"
);
MODULE_LICENSE
(
"GPL"
);
sound/soc/codecs/pcm179x.c
浏览文件 @
19142ae6
...
@@ -20,7 +20,6 @@
...
@@ -20,7 +20,6 @@
#include <linux/slab.h>
#include <linux/slab.h>
#include <linux/kernel.h>
#include <linux/kernel.h>
#include <linux/device.h>
#include <linux/device.h>
#include <linux/spi/spi.h>
#include <sound/core.h>
#include <sound/core.h>
#include <sound/pcm.h>
#include <sound/pcm.h>
...
@@ -29,7 +28,6 @@
...
@@ -29,7 +28,6 @@
#include <sound/soc.h>
#include <sound/soc.h>
#include <sound/tlv.h>
#include <sound/tlv.h>
#include <linux/of.h>
#include <linux/of.h>
#include <linux/of_device.h>
#include "pcm179x.h"
#include "pcm179x.h"
...
@@ -189,18 +187,14 @@ static struct snd_soc_dai_driver pcm179x_dai = {
...
@@ -189,18 +187,14 @@ static struct snd_soc_dai_driver pcm179x_dai = {
.
stream_name
=
"Playback"
,
.
stream_name
=
"Playback"
,
.
channels_min
=
2
,
.
channels_min
=
2
,
.
channels_max
=
2
,
.
channels_max
=
2
,
.
rates
=
PCM1792A_RATES
,
.
rates
=
SNDRV_PCM_RATE_CONTINUOUS
,
.
rate_min
=
10000
,
.
rate_max
=
200000
,
.
formats
=
PCM1792A_FORMATS
,
},
.
formats
=
PCM1792A_FORMATS
,
},
.
ops
=
&
pcm179x_dai_ops
,
.
ops
=
&
pcm179x_dai_ops
,
};
};
static
const
struct
of_device_id
pcm179x_of_match
[]
=
{
const
struct
regmap_config
pcm179x_regmap_config
=
{
{
.
compatible
=
"ti,pcm1792a"
,
},
{
}
};
MODULE_DEVICE_TABLE
(
of
,
pcm179x_of_match
);
static
const
struct
regmap_config
pcm179x_regmap
=
{
.
reg_bits
=
8
,
.
reg_bits
=
8
,
.
val_bits
=
8
,
.
val_bits
=
8
,
.
max_register
=
23
,
.
max_register
=
23
,
...
@@ -209,6 +203,7 @@ static const struct regmap_config pcm179x_regmap = {
...
@@ -209,6 +203,7 @@ static const struct regmap_config pcm179x_regmap = {
.
writeable_reg
=
pcm179x_writeable_reg
,
.
writeable_reg
=
pcm179x_writeable_reg
,
.
readable_reg
=
pcm179x_accessible_reg
,
.
readable_reg
=
pcm179x_accessible_reg
,
};
};
EXPORT_SYMBOL_GPL
(
pcm179x_regmap_config
);
static
struct
snd_soc_codec_driver
soc_codec_dev_pcm179x
=
{
static
struct
snd_soc_codec_driver
soc_codec_dev_pcm179x
=
{
.
controls
=
pcm179x_controls
,
.
controls
=
pcm179x_controls
,
...
@@ -219,52 +214,29 @@ static struct snd_soc_codec_driver soc_codec_dev_pcm179x = {
...
@@ -219,52 +214,29 @@ static struct snd_soc_codec_driver soc_codec_dev_pcm179x = {
.
num_dapm_routes
=
ARRAY_SIZE
(
pcm179x_dapm_routes
),
.
num_dapm_routes
=
ARRAY_SIZE
(
pcm179x_dapm_routes
),
};
};
static
int
pcm179x_spi_probe
(
struct
spi_device
*
spi
)
int
pcm179x_common_init
(
struct
device
*
dev
,
struct
regmap
*
regmap
)
{
{
struct
pcm179x_private
*
pcm179x
;
struct
pcm179x_private
*
pcm179x
;
int
ret
;
pcm179x
=
devm_kzalloc
(
&
spi
->
dev
,
sizeof
(
struct
pcm179x_private
),
pcm179x
=
devm_kzalloc
(
dev
,
sizeof
(
struct
pcm179x_private
),
GFP_KERNEL
);
GFP_KERNEL
);
if
(
!
pcm179x
)
if
(
!
pcm179x
)
return
-
ENOMEM
;
return
-
ENOMEM
;
spi_set_drvdata
(
spi
,
pcm179x
);
pcm179x
->
regmap
=
regmap
;
dev_set_drvdata
(
dev
,
pcm179x
);
pcm179x
->
regmap
=
devm_regmap_init_spi
(
spi
,
&
pcm179x_regmap
);
if
(
IS_ERR
(
pcm179x
->
regmap
))
{
ret
=
PTR_ERR
(
pcm179x
->
regmap
);
dev_err
(
&
spi
->
dev
,
"Failed to register regmap: %d
\n
"
,
ret
);
return
ret
;
}
return
snd_soc_register_codec
(
&
spi
->
dev
,
return
snd_soc_register_codec
(
dev
,
&
soc_codec_dev_pcm179x
,
&
pcm179x_dai
,
1
);
&
soc_codec_dev_pcm179x
,
&
pcm179x_dai
,
1
);
}
}
EXPORT_SYMBOL_GPL
(
pcm179x_common_init
);
static
int
pcm179x_spi_remove
(
struct
spi_device
*
spi
)
int
pcm179x_common_exit
(
struct
device
*
dev
)
{
{
snd_soc_unregister_codec
(
&
spi
->
dev
);
snd_soc_unregister_codec
(
dev
);
return
0
;
return
0
;
}
}
EXPORT_SYMBOL_GPL
(
pcm179x_common_exit
);
static
const
struct
spi_device_id
pcm179x_spi_ids
[]
=
{
{
"pcm179x"
,
0
},
{
},
};
MODULE_DEVICE_TABLE
(
spi
,
pcm179x_spi_ids
);
static
struct
spi_driver
pcm179x_codec_driver
=
{
.
driver
=
{
.
name
=
"pcm179x"
,
.
of_match_table
=
of_match_ptr
(
pcm179x_of_match
),
},
.
id_table
=
pcm179x_spi_ids
,
.
probe
=
pcm179x_spi_probe
,
.
remove
=
pcm179x_spi_remove
,
};
module_spi_driver
(
pcm179x_codec_driver
);
MODULE_DESCRIPTION
(
"ASoC PCM179X driver"
);
MODULE_DESCRIPTION
(
"ASoC PCM179X driver"
);
MODULE_AUTHOR
(
"Michael Trimarchi <michael@amarulasolutions.com>"
);
MODULE_AUTHOR
(
"Michael Trimarchi <michael@amarulasolutions.com>"
);
...
...
sound/soc/codecs/pcm179x.h
浏览文件 @
19142ae6
...
@@ -17,11 +17,12 @@
...
@@ -17,11 +17,12 @@
#ifndef __PCM179X_H__
#ifndef __PCM179X_H__
#define __PCM179X_H__
#define __PCM179X_H__
#define PCM1792A_RATES (SNDRV_PCM_RATE_44100 | SNDRV_PCM_RATE_8000_48000 | \
SNDRV_PCM_RATE_88200 | SNDRV_PCM_RATE_96000 | \
SNDRV_PCM_RATE_192000)
#define PCM1792A_FORMATS (SNDRV_PCM_FMTBIT_S32_LE | SNDRV_PCM_FMTBIT_S24_LE | \
#define PCM1792A_FORMATS (SNDRV_PCM_FMTBIT_S32_LE | SNDRV_PCM_FMTBIT_S24_LE | \
SNDRV_PCM_FMTBIT_S16_LE)
SNDRV_PCM_FMTBIT_S16_LE)
extern
const
struct
regmap_config
pcm179x_regmap_config
;
int
pcm179x_common_init
(
struct
device
*
dev
,
struct
regmap
*
regmap
);
int
pcm179x_common_exit
(
struct
device
*
dev
);
#endif
#endif
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录