vangogh.c 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  1. // SPDX-License-Identifier: (GPL-2.0-only OR BSD-3-Clause)
  2. //
  3. // This file is provided under a dual BSD/GPLv2 license. When using or
  4. // redistributing this file, you may do so under either license.
  5. //
  6. // Copyright(c) 2023 Advanced Micro Devices, Inc.
  7. //
  8. // Authors: Venkata Prasad Potturu <venkataprasad.potturu@amd.com>
  9. /*
  10. * Hardware interface for Audio DSP on Vangogh platform
  11. */
  12. #include <linux/delay.h>
  13. #include <linux/module.h>
  14. #include "acp.h"
  15. #define I2S_HS_INSTANCE 0
  16. #define I2S_BT_INSTANCE 1
  17. #define I2S_SP_INSTANCE 2
  18. #define PDM_DMIC_INSTANCE 3
  19. #define I2S_HS_VIRTUAL_INSTANCE 4
  20. static struct snd_soc_dai_driver vangogh_sof_dai[] = {
  21. [I2S_HS_INSTANCE] = {
  22. .id = I2S_HS_INSTANCE,
  23. .name = "acp-sof-hs",
  24. .playback = {
  25. .rates = SNDRV_PCM_RATE_8000_96000,
  26. .formats = SNDRV_PCM_FMTBIT_S16_LE | SNDRV_PCM_FMTBIT_S8 |
  27. SNDRV_PCM_FMTBIT_U8 | SNDRV_PCM_FMTBIT_S32_LE,
  28. .channels_min = 2,
  29. .channels_max = 8,
  30. .rate_min = 8000,
  31. .rate_max = 96000,
  32. },
  33. .capture = {
  34. .rates = SNDRV_PCM_RATE_8000_48000,
  35. .formats = SNDRV_PCM_FMTBIT_S16_LE | SNDRV_PCM_FMTBIT_S8 |
  36. SNDRV_PCM_FMTBIT_U8 | SNDRV_PCM_FMTBIT_S32_LE,
  37. /* Supporting only stereo for I2S HS controller capture */
  38. .channels_min = 2,
  39. .channels_max = 2,
  40. .rate_min = 8000,
  41. .rate_max = 48000,
  42. },
  43. },
  44. [I2S_BT_INSTANCE] = {
  45. .id = I2S_BT_INSTANCE,
  46. .name = "acp-sof-bt",
  47. .playback = {
  48. .rates = SNDRV_PCM_RATE_8000_96000,
  49. .formats = SNDRV_PCM_FMTBIT_S16_LE | SNDRV_PCM_FMTBIT_S8 |
  50. SNDRV_PCM_FMTBIT_U8 | SNDRV_PCM_FMTBIT_S32_LE,
  51. .channels_min = 2,
  52. .channels_max = 8,
  53. .rate_min = 8000,
  54. .rate_max = 96000,
  55. },
  56. .capture = {
  57. .rates = SNDRV_PCM_RATE_8000_48000,
  58. .formats = SNDRV_PCM_FMTBIT_S16_LE | SNDRV_PCM_FMTBIT_S8 |
  59. SNDRV_PCM_FMTBIT_U8 | SNDRV_PCM_FMTBIT_S32_LE,
  60. /* Supporting only stereo for I2S BT controller capture */
  61. .channels_min = 2,
  62. .channels_max = 2,
  63. .rate_min = 8000,
  64. .rate_max = 48000,
  65. },
  66. },
  67. [I2S_SP_INSTANCE] = {
  68. .id = I2S_SP_INSTANCE,
  69. .name = "acp-sof-sp",
  70. .playback = {
  71. .rates = SNDRV_PCM_RATE_8000_96000,
  72. .formats = SNDRV_PCM_FMTBIT_S16_LE | SNDRV_PCM_FMTBIT_S8 |
  73. SNDRV_PCM_FMTBIT_U8 | SNDRV_PCM_FMTBIT_S32_LE,
  74. .channels_min = 2,
  75. .channels_max = 8,
  76. .rate_min = 8000,
  77. .rate_max = 96000,
  78. },
  79. .capture = {
  80. .rates = SNDRV_PCM_RATE_8000_48000,
  81. .formats = SNDRV_PCM_FMTBIT_S16_LE | SNDRV_PCM_FMTBIT_S8 |
  82. SNDRV_PCM_FMTBIT_U8 | SNDRV_PCM_FMTBIT_S32_LE,
  83. /* Supporting only stereo for I2S SP controller capture */
  84. .channels_min = 2,
  85. .channels_max = 2,
  86. .rate_min = 8000,
  87. .rate_max = 48000,
  88. },
  89. },
  90. [PDM_DMIC_INSTANCE] = {
  91. .id = PDM_DMIC_INSTANCE,
  92. .name = "acp-sof-dmic",
  93. .capture = {
  94. .rates = SNDRV_PCM_RATE_8000_48000,
  95. .formats = SNDRV_PCM_FMTBIT_S32_LE,
  96. .channels_min = 2,
  97. .channels_max = 4,
  98. .rate_min = 8000,
  99. .rate_max = 48000,
  100. },
  101. },
  102. [I2S_HS_VIRTUAL_INSTANCE] = {
  103. .id = I2S_HS_VIRTUAL_INSTANCE,
  104. .name = "acp-sof-hs-virtual",
  105. .playback = {
  106. .rates = SNDRV_PCM_RATE_8000_96000,
  107. .formats = SNDRV_PCM_FMTBIT_S16_LE | SNDRV_PCM_FMTBIT_S8 |
  108. SNDRV_PCM_FMTBIT_U8 | SNDRV_PCM_FMTBIT_S32_LE,
  109. .channels_min = 2,
  110. .channels_max = 8,
  111. .rate_min = 8000,
  112. .rate_max = 96000,
  113. },
  114. .capture = {
  115. .rates = SNDRV_PCM_RATE_8000_48000,
  116. .formats = SNDRV_PCM_FMTBIT_S16_LE | SNDRV_PCM_FMTBIT_S8 |
  117. SNDRV_PCM_FMTBIT_U8 | SNDRV_PCM_FMTBIT_S32_LE,
  118. /* Supporting only stereo for I2S HS-Virtual controller capture */
  119. .channels_min = 2,
  120. .channels_max = 2,
  121. .rate_min = 8000,
  122. .rate_max = 48000,
  123. },
  124. },
  125. };
  126. static int sof_vangogh_post_fw_run_delay(struct snd_sof_dev *sdev)
  127. {
  128. /*
  129. * Resuming from suspend in some cases my cause the DSP firmware
  130. * to enter an unrecoverable faulty state. Delaying a bit any host
  131. * to DSP transmission right after firmware boot completion seems
  132. * to resolve the issue.
  133. */
  134. if (!sdev->first_boot)
  135. usleep_range(100, 150);
  136. return 0;
  137. }
  138. /* Vangogh ops */
  139. struct snd_sof_dsp_ops sof_vangogh_ops;
  140. EXPORT_SYMBOL_NS(sof_vangogh_ops, "SND_SOC_SOF_AMD_COMMON");
  141. int sof_vangogh_ops_init(struct snd_sof_dev *sdev)
  142. {
  143. const struct dmi_system_id *dmi_id;
  144. struct acp_quirk_entry *quirks;
  145. /* common defaults */
  146. memcpy(&sof_vangogh_ops, &sof_acp_common_ops, sizeof(struct snd_sof_dsp_ops));
  147. sof_vangogh_ops.drv = vangogh_sof_dai;
  148. sof_vangogh_ops.num_drv = ARRAY_SIZE(vangogh_sof_dai);
  149. dmi_id = dmi_first_match(acp_sof_quirk_table);
  150. if (dmi_id) {
  151. quirks = dmi_id->driver_data;
  152. if (quirks->signed_fw_image)
  153. sof_vangogh_ops.load_firmware = acp_sof_load_signed_firmware;
  154. if (quirks->post_fw_run_delay)
  155. sof_vangogh_ops.post_fw_run = sof_vangogh_post_fw_run_delay;
  156. }
  157. return 0;
  158. }