blob: 56cd34223100a3d31ae99db6d1719e23884fb43e [file] [log] [blame]
Kuninori Morimotob8e583f2009-08-21 09:42:59 +09001/*
2 * FSI-AK464x sound support for ms7724se
3 *
4 * Copyright (C) 2009 Renesas Solutions Corp.
5 * Kuninori Morimoto <morimoto.kuninori@renesas.com>
6 *
7 * This file is subject to the terms and conditions of the GNU General Public
8 * License. See the file "COPYING" in the main directory of this archive
9 * for more details.
10 */
11
Kuninori Morimotob8e583f2009-08-21 09:42:59 +090012#include <linux/platform_device.h>
Kuninori Morimotob8e583f2009-08-21 09:42:59 +090013#include <sound/sh_fsi.h>
Kuninori Morimotob8e583f2009-08-21 09:42:59 +090014
Kuninori Morimotoc8d6bf92010-11-30 11:32:04 +090015struct fsi_ak4642_data {
16 const char *name;
Kuninori Morimoto806bfed2010-12-01 15:50:52 +090017 const char *card;
Kuninori Morimotoc8d6bf92010-11-30 11:32:04 +090018 const char *cpu_dai;
19 const char *codec;
20 const char *platform;
Kuninori Morimotoa1934362011-01-12 15:32:07 +090021 int id;
Kuninori Morimotoc8d6bf92010-11-30 11:32:04 +090022};
23
Liam Girdwoodf0fba2a2010-03-17 20:15:21 +000024static int fsi_ak4642_dai_init(struct snd_soc_pcm_runtime *rtd)
Kuninori Morimoto4b6316b2010-03-23 16:27:28 +090025{
Liam Girdwoodf0fba2a2010-03-17 20:15:21 +000026 struct snd_soc_dai *dai = rtd->codec_dai;
Kuninori Morimoto4b6316b2010-03-23 16:27:28 +090027 int ret;
28
Liam Girdwoodf0fba2a2010-03-17 20:15:21 +000029 ret = snd_soc_dai_set_fmt(dai, SND_SOC_DAIFMT_CBM_CFM);
Kuninori Morimoto0643ce82010-03-15 18:10:50 +090030 if (ret < 0)
31 return ret;
32
Liam Girdwoodf0fba2a2010-03-17 20:15:21 +000033 ret = snd_soc_dai_set_sysclk(dai, 0, 11289600, 0);
Kuninori Morimoto4b6316b2010-03-23 16:27:28 +090034
35 return ret;
36}
37
Kuninori Morimotob8e583f2009-08-21 09:42:59 +090038static struct snd_soc_dai_link fsi_dai_link = {
Liam Girdwoodf0fba2a2010-03-17 20:15:21 +000039 .codec_dai_name = "ak4642-hifi",
Kuninori Morimoto4b6316b2010-03-23 16:27:28 +090040 .init = fsi_ak4642_dai_init,
Kuninori Morimotob8e583f2009-08-21 09:42:59 +090041};
42
43static struct snd_soc_card fsi_soc_card = {
Kuninori Morimotob8e583f2009-08-21 09:42:59 +090044 .dai_link = &fsi_dai_link,
45 .num_links = 1,
46};
47
Kuninori Morimotob8e583f2009-08-21 09:42:59 +090048static struct platform_device *fsi_snd_device;
49
Kuninori Morimotoc8d6bf92010-11-30 11:32:04 +090050static int fsi_ak4642_probe(struct platform_device *pdev)
Kuninori Morimotob8e583f2009-08-21 09:42:59 +090051{
52 int ret = -ENOMEM;
Kuninori Morimotoc8d6bf92010-11-30 11:32:04 +090053 const struct platform_device_id *id_entry;
54 struct fsi_ak4642_data *pdata;
55
56 id_entry = pdev->id_entry;
57 if (!id_entry) {
58 dev_err(&pdev->dev, "unknown fsi ak4642\n");
59 return -ENODEV;
60 }
61
62 pdata = (struct fsi_ak4642_data *)id_entry->driver_data;
Kuninori Morimotob8e583f2009-08-21 09:42:59 +090063
Kuninori Morimotoa1934362011-01-12 15:32:07 +090064 fsi_snd_device = platform_device_alloc("soc-audio", pdata->id);
Kuninori Morimotob8e583f2009-08-21 09:42:59 +090065 if (!fsi_snd_device)
66 goto out;
67
Kuninori Morimotoc8d6bf92010-11-30 11:32:04 +090068 fsi_dai_link.name = pdata->name;
69 fsi_dai_link.stream_name = pdata->name;
70 fsi_dai_link.cpu_dai_name = pdata->cpu_dai;
71 fsi_dai_link.platform_name = pdata->platform;
72 fsi_dai_link.codec_name = pdata->codec;
Kuninori Morimoto806bfed2010-12-01 15:50:52 +090073 fsi_soc_card.name = pdata->card;
Kuninori Morimotoc8d6bf92010-11-30 11:32:04 +090074
Liam Girdwoodf0fba2a2010-03-17 20:15:21 +000075 platform_set_drvdata(fsi_snd_device, &fsi_soc_card);
Kuninori Morimotob8e583f2009-08-21 09:42:59 +090076 ret = platform_device_add(fsi_snd_device);
77
78 if (ret)
79 platform_device_put(fsi_snd_device);
80
81out:
82 return ret;
83}
84
Kuninori Morimotoc8d6bf92010-11-30 11:32:04 +090085static int fsi_ak4642_remove(struct platform_device *pdev)
Kuninori Morimotob8e583f2009-08-21 09:42:59 +090086{
87 platform_device_unregister(fsi_snd_device);
Kuninori Morimotoc8d6bf92010-11-30 11:32:04 +090088 return 0;
89}
90
91static struct fsi_ak4642_data fsi_a_ak4642 = {
92 .name = "AK4642",
Kuninori Morimoto806bfed2010-12-01 15:50:52 +090093 .card = "FSIA (AK4642)",
Kuninori Morimotoc8d6bf92010-11-30 11:32:04 +090094 .cpu_dai = "fsia-dai",
95 .codec = "ak4642-codec.0-0012",
96 .platform = "sh_fsi.0",
Kuninori Morimotoa1934362011-01-12 15:32:07 +090097 .id = FSI_PORT_A,
Kuninori Morimotoc8d6bf92010-11-30 11:32:04 +090098};
99
100static struct fsi_ak4642_data fsi_b_ak4642 = {
101 .name = "AK4642",
Kuninori Morimoto806bfed2010-12-01 15:50:52 +0900102 .card = "FSIB (AK4642)",
Kuninori Morimotoc8d6bf92010-11-30 11:32:04 +0900103 .cpu_dai = "fsib-dai",
104 .codec = "ak4642-codec.0-0012",
105 .platform = "sh_fsi.0",
Kuninori Morimotoa1934362011-01-12 15:32:07 +0900106 .id = FSI_PORT_B,
Kuninori Morimotoc8d6bf92010-11-30 11:32:04 +0900107};
108
109static struct fsi_ak4642_data fsi_a_ak4643 = {
110 .name = "AK4643",
Kuninori Morimoto806bfed2010-12-01 15:50:52 +0900111 .card = "FSIA (AK4643)",
Kuninori Morimotoc8d6bf92010-11-30 11:32:04 +0900112 .cpu_dai = "fsia-dai",
113 .codec = "ak4642-codec.0-0013",
114 .platform = "sh_fsi.0",
Kuninori Morimotoa1934362011-01-12 15:32:07 +0900115 .id = FSI_PORT_A,
Kuninori Morimotoc8d6bf92010-11-30 11:32:04 +0900116};
117
118static struct fsi_ak4642_data fsi_b_ak4643 = {
119 .name = "AK4643",
Kuninori Morimoto806bfed2010-12-01 15:50:52 +0900120 .card = "FSIB (AK4643)",
Kuninori Morimotoc8d6bf92010-11-30 11:32:04 +0900121 .cpu_dai = "fsib-dai",
122 .codec = "ak4642-codec.0-0013",
123 .platform = "sh_fsi.0",
Kuninori Morimotoa1934362011-01-12 15:32:07 +0900124 .id = FSI_PORT_B,
Kuninori Morimotoc8d6bf92010-11-30 11:32:04 +0900125};
126
127static struct fsi_ak4642_data fsi2_a_ak4642 = {
128 .name = "AK4642",
Kuninori Morimoto806bfed2010-12-01 15:50:52 +0900129 .card = "FSI2A (AK4642)",
Kuninori Morimotoc8d6bf92010-11-30 11:32:04 +0900130 .cpu_dai = "fsia-dai",
131 .codec = "ak4642-codec.0-0012",
132 .platform = "sh_fsi2",
Kuninori Morimotoa1934362011-01-12 15:32:07 +0900133 .id = FSI_PORT_A,
Kuninori Morimotoc8d6bf92010-11-30 11:32:04 +0900134};
135
136static struct fsi_ak4642_data fsi2_b_ak4642 = {
137 .name = "AK4642",
Kuninori Morimoto806bfed2010-12-01 15:50:52 +0900138 .card = "FSI2B (AK4642)",
Kuninori Morimotoc8d6bf92010-11-30 11:32:04 +0900139 .cpu_dai = "fsib-dai",
140 .codec = "ak4642-codec.0-0012",
141 .platform = "sh_fsi2",
Kuninori Morimotoa1934362011-01-12 15:32:07 +0900142 .id = FSI_PORT_B,
Kuninori Morimotoc8d6bf92010-11-30 11:32:04 +0900143};
144
145static struct fsi_ak4642_data fsi2_a_ak4643 = {
146 .name = "AK4643",
Kuninori Morimoto806bfed2010-12-01 15:50:52 +0900147 .card = "FSI2A (AK4643)",
Kuninori Morimotoc8d6bf92010-11-30 11:32:04 +0900148 .cpu_dai = "fsia-dai",
149 .codec = "ak4642-codec.0-0013",
150 .platform = "sh_fsi2",
Kuninori Morimotoa1934362011-01-12 15:32:07 +0900151 .id = FSI_PORT_A,
Kuninori Morimotoc8d6bf92010-11-30 11:32:04 +0900152};
153
154static struct fsi_ak4642_data fsi2_b_ak4643 = {
155 .name = "AK4643",
Kuninori Morimoto806bfed2010-12-01 15:50:52 +0900156 .card = "FSI2B (AK4643)",
Kuninori Morimotoc8d6bf92010-11-30 11:32:04 +0900157 .cpu_dai = "fsib-dai",
158 .codec = "ak4642-codec.0-0013",
159 .platform = "sh_fsi2",
Kuninori Morimotoa1934362011-01-12 15:32:07 +0900160 .id = FSI_PORT_B,
Kuninori Morimotoc8d6bf92010-11-30 11:32:04 +0900161};
162
163static struct platform_device_id fsi_id_table[] = {
164 /* FSI */
165 { "sh_fsi_a_ak4642", (kernel_ulong_t)&fsi_a_ak4642 },
166 { "sh_fsi_b_ak4642", (kernel_ulong_t)&fsi_b_ak4642 },
167 { "sh_fsi_a_ak4643", (kernel_ulong_t)&fsi_a_ak4643 },
168 { "sh_fsi_b_ak4643", (kernel_ulong_t)&fsi_b_ak4643 },
169
170 /* FSI 2 */
171 { "sh_fsi2_a_ak4642", (kernel_ulong_t)&fsi2_a_ak4642 },
172 { "sh_fsi2_b_ak4642", (kernel_ulong_t)&fsi2_b_ak4642 },
173 { "sh_fsi2_a_ak4643", (kernel_ulong_t)&fsi2_a_ak4643 },
174 { "sh_fsi2_b_ak4643", (kernel_ulong_t)&fsi2_b_ak4643 },
175 {},
176};
177
178static struct platform_driver fsi_ak4642 = {
179 .driver = {
180 .name = "fsi-ak4642-audio",
181 },
182 .probe = fsi_ak4642_probe,
183 .remove = fsi_ak4642_remove,
184 .id_table = fsi_id_table,
185};
186
187static int __init fsi_ak4642_init(void)
188{
189 return platform_driver_register(&fsi_ak4642);
190}
191
192static void __exit fsi_ak4642_exit(void)
193{
194 platform_driver_unregister(&fsi_ak4642);
Kuninori Morimotob8e583f2009-08-21 09:42:59 +0900195}
196
197module_init(fsi_ak4642_init);
198module_exit(fsi_ak4642_exit);
199
200MODULE_LICENSE("GPL");
201MODULE_DESCRIPTION("Generic SH4 FSI-AK4642 sound card");
202MODULE_AUTHOR("Kuninori Morimoto <morimoto.kuninori@renesas.com>");