blob: bd42ad34e00499c92b6bc49c716829fe3ed6ea43 [file] [log] [blame]
Ricardo Neri54520302012-05-18 01:42:33 -05001/*
Barry Songbf7c6e62013-05-16 14:08:07 +08002 * ALSA SoC codec driver for HDMI audio codecs.
Ricardo Neri54520302012-05-18 01:42:33 -05003 * Copyright (C) 2012 Texas Instruments Incorporated - http://www.ti.com/
4 * Author: Ricardo Neri <ricardo.neri@ti.com>
5 *
6 * This program is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU General Public License
8 * version 2 as published by the Free Software Foundation.
9 *
10 * This program is distributed in the hope that it will be useful, but
11 * WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * General Public License for more details.
14 *
15 * You should have received a copy of the GNU General Public License
16 * along with this program; if not, write to the Free Software
17 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
18 * 02110-1301 USA
19 *
20 */
21#include <linux/module.h>
22#include <sound/soc.h>
Sachin Kamata6b34312014-04-04 11:29:09 +053023#include <linux/of.h>
Jyri Sarha0f7f3d12013-12-20 12:40:16 +020024#include <linux/of_device.h>
Ricardo Neri54520302012-05-18 01:42:33 -050025
26#define DRV_NAME "hdmi-audio-codec"
27
Mark Brownc34e51b2013-08-19 12:17:36 +010028static const struct snd_soc_dapm_widget hdmi_widgets[] = {
29 SND_SOC_DAPM_INPUT("RX"),
30 SND_SOC_DAPM_OUTPUT("TX"),
31};
32
33static const struct snd_soc_dapm_route hdmi_routes[] = {
34 { "Capture", NULL, "RX" },
35 { "TX", NULL, "Playback" },
36};
Ricardo Neri54520302012-05-18 01:42:33 -050037
Barry Songbf7c6e62013-05-16 14:08:07 +080038static struct snd_soc_dai_driver hdmi_codec_dai = {
39 .name = "hdmi-hifi",
Ricardo Neri54520302012-05-18 01:42:33 -050040 .playback = {
Mark Brownc34e51b2013-08-19 12:17:36 +010041 .stream_name = "Playback",
Ricardo Neri54520302012-05-18 01:42:33 -050042 .channels_min = 2,
43 .channels_max = 8,
44 .rates = SNDRV_PCM_RATE_32000 |
45 SNDRV_PCM_RATE_44100 | SNDRV_PCM_RATE_48000 |
46 SNDRV_PCM_RATE_88200 | SNDRV_PCM_RATE_96000 |
47 SNDRV_PCM_RATE_176400 | SNDRV_PCM_RATE_192000,
48 .formats = SNDRV_PCM_FMTBIT_S16_LE |
Jyri Sarhac600e952013-11-19 14:12:25 +020049 SNDRV_PCM_FMTBIT_S24_LE | SNDRV_PCM_FMTBIT_S32_LE,
Jyri Sarha74d813c2014-10-14 20:29:26 +030050 .sig_bits = 24,
Ricardo Neri54520302012-05-18 01:42:33 -050051 },
Rongjun Yingc6c09252013-07-17 14:12:16 +080052 .capture = {
Mark Brownc34e51b2013-08-19 12:17:36 +010053 .stream_name = "Capture",
Rongjun Yingc6c09252013-07-17 14:12:16 +080054 .channels_min = 2,
55 .channels_max = 2,
56 .rates = SNDRV_PCM_RATE_32000 |
57 SNDRV_PCM_RATE_44100 | SNDRV_PCM_RATE_48000 |
58 SNDRV_PCM_RATE_88200 | SNDRV_PCM_RATE_96000 |
59 SNDRV_PCM_RATE_176400 | SNDRV_PCM_RATE_192000,
60 .formats = SNDRV_PCM_FMTBIT_S16_LE |
61 SNDRV_PCM_FMTBIT_S24_LE,
62 },
63
Ricardo Neri54520302012-05-18 01:42:33 -050064};
65
Jyri Sarha0f7f3d12013-12-20 12:40:16 +020066#ifdef CONFIG_OF
67static const struct of_device_id hdmi_audio_codec_ids[] = {
68 { .compatible = "linux,hdmi-audio", },
69 { }
70};
71MODULE_DEVICE_TABLE(of, hdmi_audio_codec_ids);
72#endif
73
Mark Brownc34e51b2013-08-19 12:17:36 +010074static struct snd_soc_codec_driver hdmi_codec = {
75 .dapm_widgets = hdmi_widgets,
76 .num_dapm_widgets = ARRAY_SIZE(hdmi_widgets),
77 .dapm_routes = hdmi_routes,
78 .num_dapm_routes = ARRAY_SIZE(hdmi_routes),
Jyri Sarha69434092014-10-14 20:29:27 +030079 .ignore_pmdown_time = true,
Mark Brownc34e51b2013-08-19 12:17:36 +010080};
81
Barry Songbf7c6e62013-05-16 14:08:07 +080082static int hdmi_codec_probe(struct platform_device *pdev)
Ricardo Neri54520302012-05-18 01:42:33 -050083{
Barry Songbf7c6e62013-05-16 14:08:07 +080084 return snd_soc_register_codec(&pdev->dev, &hdmi_codec,
85 &hdmi_codec_dai, 1);
Ricardo Neri54520302012-05-18 01:42:33 -050086}
87
Barry Songbf7c6e62013-05-16 14:08:07 +080088static int hdmi_codec_remove(struct platform_device *pdev)
Ricardo Neri54520302012-05-18 01:42:33 -050089{
90 snd_soc_unregister_codec(&pdev->dev);
91 return 0;
92}
93
Barry Songbf7c6e62013-05-16 14:08:07 +080094static struct platform_driver hdmi_codec_driver = {
Ricardo Neri54520302012-05-18 01:42:33 -050095 .driver = {
96 .name = DRV_NAME,
Jyri Sarha0f7f3d12013-12-20 12:40:16 +020097 .of_match_table = of_match_ptr(hdmi_audio_codec_ids),
Ricardo Neri54520302012-05-18 01:42:33 -050098 },
99
Barry Songbf7c6e62013-05-16 14:08:07 +0800100 .probe = hdmi_codec_probe,
101 .remove = hdmi_codec_remove,
Ricardo Neri54520302012-05-18 01:42:33 -0500102};
103
Barry Songbf7c6e62013-05-16 14:08:07 +0800104module_platform_driver(hdmi_codec_driver);
Ricardo Neri54520302012-05-18 01:42:33 -0500105
106MODULE_AUTHOR("Ricardo Neri <ricardo.neri@ti.com>");
Barry Songbf7c6e62013-05-16 14:08:07 +0800107MODULE_DESCRIPTION("ASoC generic HDMI codec driver");
Ricardo Neri54520302012-05-18 01:42:33 -0500108MODULE_LICENSE("GPL");
109MODULE_ALIAS("platform:" DRV_NAME);