renoir.c 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  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) 2021 Advanced Micro Devices, Inc.
  7. //
  8. // Authors: Ajit Kumar Pandey <AjitKumar.Pandey@amd.com>
  9. /*
  10. * Hardware interface for Audio DSP on Renoir platform
  11. */
  12. #include <linux/platform_device.h>
  13. #include <linux/module.h>
  14. #include "../ops.h"
  15. #include "../sof-audio.h"
  16. #include "acp.h"
  17. #include "acp-dsp-offset.h"
  18. #define I2S_BT_INSTANCE 0
  19. #define I2S_SP_INSTANCE 1
  20. #define PDM_DMIC_INSTANCE 2
  21. #define I2S_SP_VIRTUAL_INSTANCE 3
  22. static struct snd_soc_dai_driver renoir_sof_dai[] = {
  23. [I2S_BT_INSTANCE] = {
  24. .id = I2S_BT_INSTANCE,
  25. .name = "acp-sof-bt",
  26. .playback = {
  27. .rates = SNDRV_PCM_RATE_8000_96000,
  28. .formats = SNDRV_PCM_FMTBIT_S16_LE | SNDRV_PCM_FMTBIT_S8 |
  29. SNDRV_PCM_FMTBIT_U8 | SNDRV_PCM_FMTBIT_S32_LE,
  30. .channels_min = 2,
  31. .channels_max = 8,
  32. .rate_min = 8000,
  33. .rate_max = 96000,
  34. },
  35. .capture = {
  36. .rates = SNDRV_PCM_RATE_8000_48000,
  37. .formats = SNDRV_PCM_FMTBIT_S16_LE | SNDRV_PCM_FMTBIT_S8 |
  38. SNDRV_PCM_FMTBIT_U8 | SNDRV_PCM_FMTBIT_S32_LE,
  39. /* Supporting only stereo for I2S BT controller capture */
  40. .channels_min = 2,
  41. .channels_max = 2,
  42. .rate_min = 8000,
  43. .rate_max = 48000,
  44. },
  45. },
  46. [I2S_SP_INSTANCE] = {
  47. .id = I2S_SP_INSTANCE,
  48. .name = "acp-sof-sp",
  49. .playback = {
  50. .rates = SNDRV_PCM_RATE_8000_96000,
  51. .formats = SNDRV_PCM_FMTBIT_S16_LE | SNDRV_PCM_FMTBIT_S8 |
  52. SNDRV_PCM_FMTBIT_U8 | SNDRV_PCM_FMTBIT_S32_LE,
  53. .channels_min = 2,
  54. .channels_max = 8,
  55. .rate_min = 8000,
  56. .rate_max = 96000,
  57. },
  58. .capture = {
  59. .rates = SNDRV_PCM_RATE_8000_48000,
  60. .formats = SNDRV_PCM_FMTBIT_S16_LE | SNDRV_PCM_FMTBIT_S8 |
  61. SNDRV_PCM_FMTBIT_U8 | SNDRV_PCM_FMTBIT_S32_LE,
  62. /* Supporting only stereo for I2S SP controller capture */
  63. .channels_min = 2,
  64. .channels_max = 2,
  65. .rate_min = 8000,
  66. .rate_max = 48000,
  67. },
  68. },
  69. [PDM_DMIC_INSTANCE] = {
  70. .id = PDM_DMIC_INSTANCE,
  71. .name = "acp-sof-dmic",
  72. .capture = {
  73. .rates = SNDRV_PCM_RATE_8000_48000,
  74. .formats = SNDRV_PCM_FMTBIT_S32_LE,
  75. .channels_min = 2,
  76. .channels_max = 4,
  77. .rate_min = 8000,
  78. .rate_max = 48000,
  79. },
  80. },
  81. [I2S_SP_VIRTUAL_INSTANCE] = {
  82. .id = I2S_SP_VIRTUAL_INSTANCE,
  83. .name = "acp-sof-sp-virtual",
  84. .playback = {
  85. .rates = SNDRV_PCM_RATE_8000_96000,
  86. .formats = SNDRV_PCM_FMTBIT_S16_LE | SNDRV_PCM_FMTBIT_S8 |
  87. SNDRV_PCM_FMTBIT_U8 | SNDRV_PCM_FMTBIT_S32_LE,
  88. .channels_min = 2,
  89. .channels_max = 8,
  90. .rate_min = 8000,
  91. .rate_max = 96000,
  92. },
  93. },
  94. };
  95. /* Renoir ops */
  96. struct snd_sof_dsp_ops sof_renoir_ops;
  97. EXPORT_SYMBOL_NS(sof_renoir_ops, "SND_SOC_SOF_AMD_COMMON");
  98. int sof_renoir_ops_init(struct snd_sof_dev *sdev)
  99. {
  100. /* common defaults */
  101. memcpy(&sof_renoir_ops, &sof_acp_common_ops, sizeof(struct snd_sof_dsp_ops));
  102. sof_renoir_ops.drv = renoir_sof_dai;
  103. sof_renoir_ops.num_drv = ARRAY_SIZE(renoir_sof_dai);
  104. return 0;
  105. }