blob: d50c14df34112ed2095942062bcaab90d90697bd [file] [log] [blame]
Liam Girdwoodeb1a6af2006-10-06 18:34:51 +02001ASoC Machine Driver
2===================
3
4The ASoC machine (or board) driver is the code that glues together the platform
5and codec drivers.
6
7The machine driver can contain codec and platform specific code. It registers
8the audio subsystem with the kernel as a platform device and is represented by
9the following struct:-
10
11/* SoC machine */
Mark Brown4f904732008-11-21 15:08:23 +000012struct snd_soc_card {
Liam Girdwoodeb1a6af2006-10-06 18:34:51 +020013 char *name;
14
Seungwhan Youn379c4bf2011-01-13 11:08:21 +090015 ...
16
Liam Girdwoodeb1a6af2006-10-06 18:34:51 +020017 int (*probe)(struct platform_device *pdev);
18 int (*remove)(struct platform_device *pdev);
19
20 /* the pre and post PM functions are used to do any PM work before and
Mark Brown7c4dbbd2008-01-23 08:41:46 +010021 * after the codec and DAIs do any PM work. */
Liam Girdwoodeb1a6af2006-10-06 18:34:51 +020022 int (*suspend_pre)(struct platform_device *pdev, pm_message_t state);
23 int (*suspend_post)(struct platform_device *pdev, pm_message_t state);
24 int (*resume_pre)(struct platform_device *pdev);
25 int (*resume_post)(struct platform_device *pdev);
26
Seungwhan Youn379c4bf2011-01-13 11:08:21 +090027 ...
Liam Girdwoodeb1a6af2006-10-06 18:34:51 +020028
29 /* CPU <--> Codec DAI links */
30 struct snd_soc_dai_link *dai_link;
31 int num_links;
Seungwhan Youn379c4bf2011-01-13 11:08:21 +090032
33 ...
Liam Girdwoodeb1a6af2006-10-06 18:34:51 +020034};
35
36probe()/remove()
37----------------
38probe/remove are optional. Do any machine specific probe here.
39
40
41suspend()/resume()
42------------------
43The machine driver has pre and post versions of suspend and resume to take care
Mark Brown7c4dbbd2008-01-23 08:41:46 +010044of any machine audio tasks that have to be done before or after the codec, DAIs
Liam Girdwoodeb1a6af2006-10-06 18:34:51 +020045and DMA is suspended and resumed. Optional.
46
47
Liam Girdwoodeb1a6af2006-10-06 18:34:51 +020048Machine DAI Configuration
49-------------------------
Mark Brown7c4dbbd2008-01-23 08:41:46 +010050The machine DAI configuration glues all the codec and CPU DAIs together. It can
Liam Girdwoodeb1a6af2006-10-06 18:34:51 +020051also be used to set up the DAI system clock and for any machine related DAI
52initialisation e.g. the machine audio map can be connected to the codec audio
Mark Brown145294c2011-12-05 18:27:25 +000053map, unconnected codec pins can be set as such.
Liam Girdwoodeb1a6af2006-10-06 18:34:51 +020054
55struct snd_soc_dai_link is used to set up each DAI in your machine. e.g.
56
57/* corgi digital audio interface glue - connects codec <--> CPU */
58static struct snd_soc_dai_link corgi_dai = {
59 .name = "WM8731",
60 .stream_name = "WM8731",
Seungwhan Youn379c4bf2011-01-13 11:08:21 +090061 .cpu_dai_name = "pxa-is2-dai",
62 .codec_dai_name = "wm8731-hifi",
63 .platform_name = "pxa-pcm-audio",
64 .codec_name = "wm8713-codec.0-001a",
Liam Girdwoodeb1a6af2006-10-06 18:34:51 +020065 .init = corgi_wm8731_init,
Liam Girdwood10b98522007-02-08 17:06:09 +010066 .ops = &corgi_ops,
Liam Girdwoodeb1a6af2006-10-06 18:34:51 +020067};
68
Francis Galieguea33f3222010-04-23 00:08:02 +020069struct snd_soc_card then sets up the machine with its DAIs. e.g.
Liam Girdwoodeb1a6af2006-10-06 18:34:51 +020070
71/* corgi audio machine driver */
Mark Brown87506542008-11-18 20:50:34 +000072static struct snd_soc_card snd_soc_corgi = {
Liam Girdwoodeb1a6af2006-10-06 18:34:51 +020073 .name = "Corgi",
74 .dai_link = &corgi_dai,
75 .num_links = 1,
Liam Girdwoodeb1a6af2006-10-06 18:34:51 +020076};
77
78
Liam Girdwoodeb1a6af2006-10-06 18:34:51 +020079Machine Power Map
80-----------------
81
82The machine driver can optionally extend the codec power map and to become an
83audio power map of the audio subsystem. This allows for automatic power up/down
84of speaker/HP amplifiers, etc. Codec pins can be connected to the machines jack
Mark Brown145294c2011-12-05 18:27:25 +000085sockets in the machine init function.
Liam Girdwoodeb1a6af2006-10-06 18:34:51 +020086
87
88Machine Controls
89----------------
90
Mark Brown7c4dbbd2008-01-23 08:41:46 +010091Machine specific audio mixer controls can be added in the DAI init function.