bfin-eval-adau1x81.c 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. /*
  2. * Machine driver for EVAL-ADAU1x81 on Analog Devices bfin
  3. * evaluation boards.
  4. *
  5. * Copyright 2011-2014 Analog Devices Inc.
  6. * Author: Lars-Peter Clausen <lars@metafoo.de>
  7. *
  8. * Licensed under the GPL-2 or later.
  9. */
  10. #include <linux/module.h>
  11. #include <linux/device.h>
  12. #include <linux/slab.h>
  13. #include <sound/core.h>
  14. #include <sound/pcm.h>
  15. #include <sound/soc.h>
  16. #include <sound/pcm_params.h>
  17. #include "../codecs/adau17x1.h"
  18. static const struct snd_soc_dapm_widget bfin_eval_adau1x81_dapm_widgets[] = {
  19. SND_SOC_DAPM_LINE("Stereo In", NULL),
  20. SND_SOC_DAPM_LINE("Beep", NULL),
  21. SND_SOC_DAPM_SPK("Speaker", NULL),
  22. SND_SOC_DAPM_HP("Headphone", NULL),
  23. };
  24. static const struct snd_soc_dapm_route bfin_eval_adau1x81_dapm_routes[] = {
  25. { "BEEP", NULL, "Beep" },
  26. { "LMIC", NULL, "Stereo In" },
  27. { "LMIC", NULL, "Stereo In" },
  28. { "Headphone", NULL, "AOUTL" },
  29. { "Headphone", NULL, "AOUTR" },
  30. { "Speaker", NULL, "SP" },
  31. };
  32. static int bfin_eval_adau1x81_hw_params(struct snd_pcm_substream *substream,
  33. struct snd_pcm_hw_params *params)
  34. {
  35. struct snd_soc_pcm_runtime *rtd = substream->private_data;
  36. struct snd_soc_dai *codec_dai = rtd->codec_dai;
  37. int pll_rate;
  38. int ret;
  39. switch (params_rate(params)) {
  40. case 48000:
  41. case 8000:
  42. case 12000:
  43. case 16000:
  44. case 24000:
  45. case 32000:
  46. case 96000:
  47. pll_rate = 48000 * 1024;
  48. break;
  49. case 44100:
  50. case 7350:
  51. case 11025:
  52. case 14700:
  53. case 22050:
  54. case 29400:
  55. case 88200:
  56. pll_rate = 44100 * 1024;
  57. break;
  58. default:
  59. return -EINVAL;
  60. }
  61. ret = snd_soc_dai_set_pll(codec_dai, ADAU17X1_PLL,
  62. ADAU17X1_PLL_SRC_MCLK, 12288000, pll_rate);
  63. if (ret)
  64. return ret;
  65. ret = snd_soc_dai_set_sysclk(codec_dai, ADAU17X1_CLK_SRC_PLL, pll_rate,
  66. SND_SOC_CLOCK_IN);
  67. return ret;
  68. }
  69. static const struct snd_soc_ops bfin_eval_adau1x81_ops = {
  70. .hw_params = bfin_eval_adau1x81_hw_params,
  71. };
  72. static struct snd_soc_dai_link bfin_eval_adau1x81_dai = {
  73. .name = "adau1x81",
  74. .stream_name = "adau1x81",
  75. .cpu_dai_name = "bfin-i2s.0",
  76. .codec_dai_name = "adau-hifi",
  77. .platform_name = "bfin-i2s-pcm-audio",
  78. .codec_name = "adau1781.0-0038",
  79. .ops = &bfin_eval_adau1x81_ops,
  80. .dai_fmt = SND_SOC_DAIFMT_I2S | SND_SOC_DAIFMT_NB_NF |
  81. SND_SOC_DAIFMT_CBM_CFM,
  82. };
  83. static struct snd_soc_card bfin_eval_adau1x81 = {
  84. .name = "bfin-eval-adau1x81",
  85. .driver_name = "eval-adau1x81",
  86. .dai_link = &bfin_eval_adau1x81_dai,
  87. .num_links = 1,
  88. .dapm_widgets = bfin_eval_adau1x81_dapm_widgets,
  89. .num_dapm_widgets = ARRAY_SIZE(bfin_eval_adau1x81_dapm_widgets),
  90. .dapm_routes = bfin_eval_adau1x81_dapm_routes,
  91. .num_dapm_routes = ARRAY_SIZE(bfin_eval_adau1x81_dapm_routes),
  92. .fully_routed = true,
  93. };
  94. static int bfin_eval_adau1x81_probe(struct platform_device *pdev)
  95. {
  96. bfin_eval_adau1x81.dev = &pdev->dev;
  97. return devm_snd_soc_register_card(&pdev->dev, &bfin_eval_adau1x81);
  98. }
  99. static struct platform_driver bfin_eval_adau1x81_driver = {
  100. .driver = {
  101. .name = "bfin-eval-adau1x81",
  102. .pm = &snd_soc_pm_ops,
  103. },
  104. .probe = bfin_eval_adau1x81_probe,
  105. };
  106. module_platform_driver(bfin_eval_adau1x81_driver);
  107. MODULE_AUTHOR("Lars-Peter Clausen <lars@metafoo.de>");
  108. MODULE_DESCRIPTION("ALSA SoC bfin adau1x81 driver");
  109. MODULE_LICENSE("GPL");
  110. MODULE_ALIAS("platform:bfin-eval-adau1x81");