forked from Minki/linux
f5a246eab9
This contains pretty many small commits covering fairly large range of files in sound/ directory. Partly because of additional API support and partly because of constantly developed ASoC and ARM stuff. Some highlights: - Introduced the helper function and documentation for exposing the channel map via control API, as discussed in Plumbers; most of PCI drivers are covered, will follow more drivers later - Most of drivers have been replaced with the new PM callbacks (if the bus is supported) - HD-audio controller got the support of runtime PM and the support of D3 clock-stop. Also changing the power_save option in sysfs kicks off immediately to enable / disable the power-save mode. - Another significant code change in HD-audio is the rewrite of firmware loading code. Other than that, most of changes in HD-audio are continued cleanups and standardization for the generic auto parser and bug fixes (HBR, device-specific fixups), in addition to the support of channel-map API. - Addition of ASoC bindings for the compressed API, used by the mid-x86 drivers. - Lots of cleanups and API refreshes for ASoC codec drivers and DaVinci. - Conversion of OMAP to dmaengine. - New machine driver for Wolfson Microelectronics Bells. - New CODEC driver for Wolfson Microelectronics WM0010. - Enhancements to the ux500 and wm2000 drivers - A new driver for DA9055 and the support for regulator bypass mode. -----BEGIN PGP SIGNATURE----- Version: GnuPG v2.0.19 (GNU/Linux) iQIcBAABAgAGBQJQcpeWAAoJEGwxgFQ9KSmkpi4P/2etDDz5aEkEHNa1l4xEmFcm ymiGTgjaalqpUAVbM/gYx9G59EFMEbzUl1BHAqE5La4wO/v9lNPb+VrdUo+B+NZ7 WSxIPWcNqdinSuoSqyYPjoPMVnhs3EMtNOqmf4jm1JOvdqA+4rO29xQVAqK/5Gfu LpMOyPiRi5ODnbQ1BOIWwpKICioY/mLwGJudK3z0i/fYVA7gLub20f+w+sOjKIA4 wmwQAMTjAR798Cg/tVy4fQmf4SLw+c2nIgGe/PD+2gVlGXLNKBrJfMonHPTbmwKu lmJO/EtnijNOnpbn6up7ryUQ9cSoZAUZOfdIOgmAeQgQ/LWR0f+zf2IQehSPwrul g6hqOnQI2DNN7ugT3cYVbYnsh56TjyhnxhhxZgkapqh706QkqHGyKJNMRetzuXmP 1O//MnZJrFQWd6sOKLlTL2ZzRvnxEJcNVGaE6bbwZTfQMtPeo9l1842uIq1dLUtG VxZb/svKUkMXv4is1dwUYUkpDsKxsgMEmabmuovceGf2N7jj/irkXgqxf6LWkaY1 JQ7ZFWUJyDzEMXRaFfzdGO15T532CfB84wvFX5xoPMwMste2AA7QuybFBVstXhKu AtKNDgRJFUTlnLIxydpPBWdWH3UJdEaFwwsSfuNKI8OmmGKhWC/aP83k4hzueu9H KYLvY/0ObMSMqiwh/ndQ =uNqD -----END PGP SIGNATURE----- Merge tag 'sound-3.7' of git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound Pull sound updates from Takashi Iwai: "This contains pretty many small commits covering fairly large range of files in sound/ directory. Partly because of additional API support and partly because of constantly developed ASoC and ARM stuff. Some highlights: - Introduced the helper function and documentation for exposing the channel map via control API, as discussed in Plumbers; most of PCI drivers are covered, will follow more drivers later - Most of drivers have been replaced with the new PM callbacks (if the bus is supported) - HD-audio controller got the support of runtime PM and the support of D3 clock-stop. Also changing the power_save option in sysfs kicks off immediately to enable / disable the power-save mode. - Another significant code change in HD-audio is the rewrite of firmware loading code. Other than that, most of changes in HD-audio are continued cleanups and standardization for the generic auto parser and bug fixes (HBR, device-specific fixups), in addition to the support of channel-map API. - Addition of ASoC bindings for the compressed API, used by the mid-x86 drivers. - Lots of cleanups and API refreshes for ASoC codec drivers and DaVinci. - Conversion of OMAP to dmaengine. - New machine driver for Wolfson Microelectronics Bells. - New CODEC driver for Wolfson Microelectronics WM0010. - Enhancements to the ux500 and wm2000 drivers - A new driver for DA9055 and the support for regulator bypass mode." Fix up various arm soc header file reorg conflicts. * tag 'sound-3.7' of git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound: (339 commits) ALSA: hda - Add new codec ALC283 ALC290 support ALSA: hda - avoid unneccesary indices on "Headphone Jack" controls ALSA: hda - fix indices on boost volume on Conexant ALSA: aloop - add locking to timer access ALSA: hda - Fix hang caused by race during suspend. sound: Remove unnecessary semicolon ALSA: hda/realtek - Fix detection of ALC271X codec ALSA: hda - Add inverted internal mic quirk for Lenovo IdeaPad U310 ALSA: hda - make Realtek/Sigmatel/Conexant use the generic unsol event ALSA: hda - make a generic unsol event handler ASoC: codecs: Add DA9055 codec driver ASoC: eukrea-tlv320: Convert it to platform driver ALSA: ASoC: add DT bindings for CS4271 ASoC: wm_hubs: Ensure volume updates are handled during class W startup ASoC: wm5110: Adding missing volume update bits ASoC: wm5110: Add OUT3R support ASoC: wm5110: Add AEC loopback support ASoC: wm5110: Rename EPOUT to HPOUT3 ASoC: arizona: Add more clock rates ASoC: arizona: Add more DSP options for mixer input muxes ...
216 lines
5.7 KiB
C
216 lines
5.7 KiB
C
/*
|
|
* zoom2.c -- SoC audio for Zoom2
|
|
*
|
|
* Author: Misael Lopez Cruz <x0052729@ti.com>
|
|
*
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public License
|
|
* version 2 as published by the Free Software Foundation.
|
|
*
|
|
* 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.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
|
|
* 02110-1301 USA
|
|
*
|
|
*/
|
|
|
|
#include <linux/clk.h>
|
|
#include <linux/platform_device.h>
|
|
#include <sound/core.h>
|
|
#include <sound/pcm.h>
|
|
#include <sound/soc.h>
|
|
|
|
#include <asm/mach-types.h>
|
|
#include <mach/hardware.h>
|
|
#include <mach/gpio.h>
|
|
#include <mach/board-zoom.h>
|
|
#include <linux/platform_data/asoc-ti-mcbsp.h>
|
|
|
|
/* Register descriptions for twl4030 codec part */
|
|
#include <linux/mfd/twl4030-audio.h>
|
|
#include <linux/module.h>
|
|
|
|
#include "omap-mcbsp.h"
|
|
#include "omap-pcm.h"
|
|
|
|
#define ZOOM2_HEADSET_MUX_GPIO (OMAP_MAX_GPIO_LINES + 15)
|
|
|
|
static int zoom2_hw_params(struct snd_pcm_substream *substream,
|
|
struct snd_pcm_hw_params *params)
|
|
{
|
|
struct snd_soc_pcm_runtime *rtd = substream->private_data;
|
|
struct snd_soc_dai *codec_dai = rtd->codec_dai;
|
|
int ret;
|
|
|
|
/* Set the codec system clock for DAC and ADC */
|
|
ret = snd_soc_dai_set_sysclk(codec_dai, 0, 26000000,
|
|
SND_SOC_CLOCK_IN);
|
|
if (ret < 0) {
|
|
printk(KERN_ERR "can't set codec system clock\n");
|
|
return ret;
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
static struct snd_soc_ops zoom2_ops = {
|
|
.hw_params = zoom2_hw_params,
|
|
};
|
|
|
|
/* Zoom2 machine DAPM */
|
|
static const struct snd_soc_dapm_widget zoom2_twl4030_dapm_widgets[] = {
|
|
SND_SOC_DAPM_MIC("Ext Mic", NULL),
|
|
SND_SOC_DAPM_SPK("Ext Spk", NULL),
|
|
SND_SOC_DAPM_MIC("Headset Mic", NULL),
|
|
SND_SOC_DAPM_HP("Headset Stereophone", NULL),
|
|
SND_SOC_DAPM_LINE("Aux In", NULL),
|
|
};
|
|
|
|
static const struct snd_soc_dapm_route audio_map[] = {
|
|
/* External Mics: MAINMIC, SUBMIC with bias*/
|
|
{"MAINMIC", NULL, "Mic Bias 1"},
|
|
{"SUBMIC", NULL, "Mic Bias 2"},
|
|
{"Mic Bias 1", NULL, "Ext Mic"},
|
|
{"Mic Bias 2", NULL, "Ext Mic"},
|
|
|
|
/* External Speakers: HFL, HFR */
|
|
{"Ext Spk", NULL, "HFL"},
|
|
{"Ext Spk", NULL, "HFR"},
|
|
|
|
/* Headset Stereophone: HSOL, HSOR */
|
|
{"Headset Stereophone", NULL, "HSOL"},
|
|
{"Headset Stereophone", NULL, "HSOR"},
|
|
|
|
/* Headset Mic: HSMIC with bias */
|
|
{"HSMIC", NULL, "Headset Mic Bias"},
|
|
{"Headset Mic Bias", NULL, "Headset Mic"},
|
|
|
|
/* Aux In: AUXL, AUXR */
|
|
{"Aux In", NULL, "AUXL"},
|
|
{"Aux In", NULL, "AUXR"},
|
|
};
|
|
|
|
static int zoom2_twl4030_init(struct snd_soc_pcm_runtime *rtd)
|
|
{
|
|
struct snd_soc_codec *codec = rtd->codec;
|
|
struct snd_soc_dapm_context *dapm = &codec->dapm;
|
|
|
|
/* TWL4030 not connected pins */
|
|
snd_soc_dapm_nc_pin(dapm, "CARKITMIC");
|
|
snd_soc_dapm_nc_pin(dapm, "DIGIMIC0");
|
|
snd_soc_dapm_nc_pin(dapm, "DIGIMIC1");
|
|
snd_soc_dapm_nc_pin(dapm, "EARPIECE");
|
|
snd_soc_dapm_nc_pin(dapm, "PREDRIVEL");
|
|
snd_soc_dapm_nc_pin(dapm, "PREDRIVER");
|
|
snd_soc_dapm_nc_pin(dapm, "CARKITL");
|
|
snd_soc_dapm_nc_pin(dapm, "CARKITR");
|
|
|
|
return 0;
|
|
}
|
|
|
|
static int zoom2_twl4030_voice_init(struct snd_soc_pcm_runtime *rtd)
|
|
{
|
|
struct snd_soc_codec *codec = rtd->codec;
|
|
unsigned short reg;
|
|
|
|
/* Enable voice interface */
|
|
reg = codec->driver->read(codec, TWL4030_REG_VOICE_IF);
|
|
reg |= TWL4030_VIF_DIN_EN | TWL4030_VIF_DOUT_EN | TWL4030_VIF_EN;
|
|
codec->driver->write(codec, TWL4030_REG_VOICE_IF, reg);
|
|
|
|
return 0;
|
|
}
|
|
|
|
/* Digital audio interface glue - connects codec <--> CPU */
|
|
static struct snd_soc_dai_link zoom2_dai[] = {
|
|
{
|
|
.name = "TWL4030 I2S",
|
|
.stream_name = "TWL4030 Audio",
|
|
.cpu_dai_name = "omap-mcbsp.2",
|
|
.codec_dai_name = "twl4030-hifi",
|
|
.platform_name = "omap-pcm-audio",
|
|
.codec_name = "twl4030-codec",
|
|
.dai_fmt = SND_SOC_DAIFMT_I2S | SND_SOC_DAIFMT_NB_NF |
|
|
SND_SOC_DAIFMT_CBM_CFM,
|
|
.init = zoom2_twl4030_init,
|
|
.ops = &zoom2_ops,
|
|
},
|
|
{
|
|
.name = "TWL4030 PCM",
|
|
.stream_name = "TWL4030 Voice",
|
|
.cpu_dai_name = "omap-mcbsp.3",
|
|
.codec_dai_name = "twl4030-voice",
|
|
.platform_name = "omap-pcm-audio",
|
|
.codec_name = "twl4030-codec",
|
|
.dai_fmt = SND_SOC_DAIFMT_DSP_A | SND_SOC_DAIFMT_IB_NF |
|
|
SND_SOC_DAIFMT_CBM_CFM,
|
|
.init = zoom2_twl4030_voice_init,
|
|
.ops = &zoom2_ops,
|
|
},
|
|
};
|
|
|
|
/* Audio machine driver */
|
|
static struct snd_soc_card snd_soc_zoom2 = {
|
|
.name = "Zoom2",
|
|
.owner = THIS_MODULE,
|
|
.dai_link = zoom2_dai,
|
|
.num_links = ARRAY_SIZE(zoom2_dai),
|
|
|
|
.dapm_widgets = zoom2_twl4030_dapm_widgets,
|
|
.num_dapm_widgets = ARRAY_SIZE(zoom2_twl4030_dapm_widgets),
|
|
.dapm_routes = audio_map,
|
|
.num_dapm_routes = ARRAY_SIZE(audio_map),
|
|
};
|
|
|
|
static struct platform_device *zoom2_snd_device;
|
|
|
|
static int __init zoom2_soc_init(void)
|
|
{
|
|
int ret;
|
|
|
|
if (!machine_is_omap_zoom2())
|
|
return -ENODEV;
|
|
printk(KERN_INFO "Zoom2 SoC init\n");
|
|
|
|
zoom2_snd_device = platform_device_alloc("soc-audio", -1);
|
|
if (!zoom2_snd_device) {
|
|
printk(KERN_ERR "Platform device allocation failed\n");
|
|
return -ENOMEM;
|
|
}
|
|
|
|
platform_set_drvdata(zoom2_snd_device, &snd_soc_zoom2);
|
|
ret = platform_device_add(zoom2_snd_device);
|
|
if (ret)
|
|
goto err1;
|
|
|
|
BUG_ON(gpio_request(ZOOM2_HEADSET_MUX_GPIO, "hs_mux") < 0);
|
|
gpio_direction_output(ZOOM2_HEADSET_MUX_GPIO, 0);
|
|
|
|
return 0;
|
|
|
|
err1:
|
|
printk(KERN_ERR "Unable to add platform device\n");
|
|
platform_device_put(zoom2_snd_device);
|
|
|
|
return ret;
|
|
}
|
|
module_init(zoom2_soc_init);
|
|
|
|
static void __exit zoom2_soc_exit(void)
|
|
{
|
|
gpio_free(ZOOM2_HEADSET_MUX_GPIO);
|
|
|
|
platform_device_unregister(zoom2_snd_device);
|
|
}
|
|
module_exit(zoom2_soc_exit);
|
|
|
|
MODULE_AUTHOR("Misael Lopez Cruz <x0052729@ti.com>");
|
|
MODULE_DESCRIPTION("ALSA SoC Zoom2");
|
|
MODULE_LICENSE("GPL");
|
|
|