swr-dmic.c 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * Copyright (c) 2019-2020, The Linux Foundation. All rights reserved.
  4. */
  5. #include <linux/module.h>
  6. #include <linux/init.h>
  7. #include <linux/slab.h>
  8. #include <linux/platform_device.h>
  9. #include <linux/device.h>
  10. #include <linux/printk.h>
  11. #include <linux/bitops.h>
  12. #include <linux/regulator/consumer.h>
  13. #include <linux/pm_runtime.h>
  14. #include <linux/delay.h>
  15. #include <linux/kernel.h>
  16. #include <linux/gpio.h>
  17. #include <linux/of_gpio.h>
  18. #include <linux/of_platform.h>
  19. #include <linux/debugfs.h>
  20. #include <soc/soundwire.h>
  21. #include <sound/pcm.h>
  22. #include <sound/pcm_params.h>
  23. #include <sound/soc.h>
  24. #include <sound/soc-dapm.h>
  25. #include <sound/tlv.h>
  26. #include <asoc/msm-cdc-pinctrl.h>
  27. #include <asoc/msm-cdc-supply.h>
  28. #include <dt-bindings/sound/audio-codec-port-types.h>
  29. #include "wcd938x/wcd938x.h"
  30. #include "swr-dmic.h"
  31. #define NUM_ATTEMPTS 5
  32. static int swr_master_channel_map[] = {
  33. ZERO,
  34. SWRM_TX1_CH1,
  35. SWRM_TX1_CH2,
  36. SWRM_TX1_CH3,
  37. SWRM_TX1_CH4,
  38. SWRM_TX2_CH1,
  39. SWRM_TX2_CH2,
  40. SWRM_TX2_CH3,
  41. SWRM_TX2_CH4,
  42. SWRM_TX3_CH1,
  43. SWRM_TX3_CH2,
  44. SWRM_TX3_CH3,
  45. SWRM_TX3_CH4,
  46. SWRM_PCM_IN,
  47. };
  48. /*
  49. * Private data Structure for swr-dmic. All parameters related to
  50. * external mic codec needs to be defined here.
  51. */
  52. struct swr_dmic_priv {
  53. struct device *dev;
  54. struct swr_device *swr_slave;
  55. struct snd_soc_component *component;
  56. struct snd_soc_component_driver *driver;
  57. struct snd_soc_dai_driver *dai_driver;
  58. struct snd_soc_component *supply_component;
  59. u32 micb_num;
  60. struct device_node *wcd_handle;
  61. bool is_wcd_supply;
  62. int is_en_supply;
  63. int port_type;
  64. u8 tx_master_port_map[SWR_DMIC_MAX_PORTS];
  65. };
  66. const char *codec_name_list[] = {
  67. "swr-dmic.01",
  68. "swr-dmic.02",
  69. "swr-dmic.03",
  70. "swr-dmic.04",
  71. };
  72. const char *dai_name_list[] = {
  73. "swr_dmic_tx0",
  74. "swr_dmic_tx1",
  75. "swr_dmic_tx2",
  76. "swr_dmic_tx3",
  77. };
  78. const char *aif_name_list[] = {
  79. "SWR_DMIC_AIF0 Capture",
  80. "SWR_DMIC_AIF1 Capture",
  81. "SWR_DMIC_AIF2 Capture",
  82. "SWR_DMIC_AIF3 Capture",
  83. };
  84. static int swr_dmic_reset(struct swr_device *pdev);
  85. static int swr_dmic_up(struct swr_device *pdev);
  86. static int swr_dmic_down(struct swr_device *pdev);
  87. static inline int swr_dmic_tx_get_slave_port_type_idx(const char *wname,
  88. unsigned int *port_idx)
  89. {
  90. u8 port_type;
  91. if (strnstr(wname, "HIFI", strlen(wname)))
  92. port_type = SWR_DMIC_HIFI_PORT;
  93. else if (strnstr(wname, "LP", strlen(wname)))
  94. port_type = SWR_DMIC_LP_PORT;
  95. else
  96. return -EINVAL;
  97. *port_idx = port_type;
  98. return 0;
  99. }
  100. static inline int swr_dmic_get_master_port_val(int port)
  101. {
  102. int i;
  103. for (i = 0; i < ARRAY_SIZE(swr_master_channel_map); i++)
  104. if (port == swr_master_channel_map[i])
  105. return i;
  106. return 0;
  107. }
  108. static int swr_dmic_tx_master_port_get(struct snd_kcontrol *kcontrol,
  109. struct snd_ctl_elem_value *ucontrol)
  110. {
  111. struct snd_soc_component *component =
  112. snd_soc_kcontrol_component(kcontrol);
  113. struct swr_dmic_priv *swr_dmic = snd_soc_component_get_drvdata(component);
  114. int ret = 0;
  115. int slave_port_idx;
  116. ret = swr_dmic_tx_get_slave_port_type_idx(kcontrol->id.name,
  117. &slave_port_idx);
  118. if (ret) {
  119. dev_dbg(component->dev, "%s: invalid port string\n", __func__);
  120. return ret;
  121. }
  122. swr_dmic->port_type = slave_port_idx;
  123. ucontrol->value.integer.value[0] =
  124. swr_dmic_get_master_port_val(
  125. swr_dmic->tx_master_port_map[slave_port_idx]);
  126. dev_dbg(component->dev, "%s: ucontrol->value.integer.value[0] = %ld\n",
  127. __func__, ucontrol->value.integer.value[0]);
  128. return 0;
  129. }
  130. static int swr_dmic_tx_master_port_put(struct snd_kcontrol *kcontrol,
  131. struct snd_ctl_elem_value *ucontrol)
  132. {
  133. struct snd_soc_component *component =
  134. snd_soc_kcontrol_component(kcontrol);
  135. struct swr_dmic_priv *swr_dmic = snd_soc_component_get_drvdata(component);
  136. int ret = 0;
  137. int slave_port_idx;
  138. ret = swr_dmic_tx_get_slave_port_type_idx(kcontrol->id.name,
  139. &slave_port_idx);
  140. if (ret) {
  141. dev_dbg(component->dev, "%s: invalid port string\n", __func__);
  142. return ret;
  143. }
  144. swr_dmic->port_type = slave_port_idx;
  145. swr_dmic->tx_master_port_map[slave_port_idx] =
  146. swr_master_channel_map[ucontrol->value.enumerated.item[0]];
  147. dev_dbg(component->dev, "%s: slv port id: %d, master_port_type: %d\n",
  148. __func__, slave_port_idx,
  149. swr_dmic->tx_master_port_map[slave_port_idx]);
  150. return 0;
  151. }
  152. static int swr_dmic_port_enable(struct snd_soc_dapm_widget *w,
  153. struct snd_kcontrol *kcontrol, int event)
  154. {
  155. int ret = 0;
  156. struct snd_soc_component *component =
  157. snd_soc_dapm_to_component(w->dapm);
  158. struct swr_dmic_priv *swr_dmic =
  159. snd_soc_component_get_drvdata(component);
  160. u8 ch_mask = 0x01; // only DpnChannelEN1 register is available
  161. u8 num_port = 1;
  162. u8 port_id = swr_dmic->port_type;
  163. u8 port_type = swr_dmic->tx_master_port_map[port_id];
  164. switch (event) {
  165. case SND_SOC_DAPM_POST_PMU:
  166. ret = swr_slvdev_datapath_control(swr_dmic->swr_slave,
  167. swr_dmic->swr_slave->dev_num, true);
  168. break;
  169. case SND_SOC_DAPM_PRE_PMD:
  170. ret = swr_disconnect_port(swr_dmic->swr_slave,
  171. &port_id, num_port, &ch_mask, &port_type);
  172. break;
  173. };
  174. return ret;
  175. }
  176. static int dmic_swr_ctrl(struct snd_soc_dapm_widget *w,
  177. struct snd_kcontrol *kcontrol, int event)
  178. {
  179. int ret = 0;
  180. struct snd_soc_component *component =
  181. snd_soc_dapm_to_component(w->dapm);
  182. struct swr_dmic_priv *swr_dmic =
  183. snd_soc_component_get_drvdata(component);
  184. u8 num_ch = 1;
  185. u8 ch_mask = 0x01; // only DpnChannelEN1 register is available
  186. u32 ch_rate = SWR_CLK_RATE_4P8MHZ;
  187. u8 num_port = 1;
  188. u8 port_type = 0;
  189. u8 port_id = swr_dmic->port_type;
  190. /*
  191. * Port 1 is high quality / 2.4 or 3.072 Mbps
  192. * Port 2 is listen low power / 0.6 or 0.768 Mbps
  193. */
  194. if(swr_dmic->port_type == SWR_DMIC_HIFI_PORT)
  195. ch_rate = SWR_CLK_RATE_2P4MHZ;
  196. else
  197. ch_rate = SWR_CLK_RATE_0P6MHZ;
  198. port_type = swr_dmic->tx_master_port_map[port_id];
  199. dev_dbg(component->dev, "%s port_type: %d event: %d\n", __func__,
  200. port_type, event);
  201. switch (event) {
  202. case SND_SOC_DAPM_PRE_PMU:
  203. ret = swr_connect_port(swr_dmic->swr_slave, &port_id,
  204. num_port, &ch_mask, &ch_rate,
  205. &num_ch, &port_type);
  206. break;
  207. case SND_SOC_DAPM_POST_PMD:
  208. ret = swr_slvdev_datapath_control(swr_dmic->swr_slave,
  209. swr_dmic->swr_slave->dev_num, false);
  210. break;
  211. };
  212. return ret;
  213. }
  214. static int swr_dmic_enable_supply(struct snd_soc_dapm_widget *w,
  215. struct snd_kcontrol *kcontrol,
  216. int event)
  217. {
  218. struct snd_soc_component *component =
  219. snd_soc_dapm_to_component(w->dapm);
  220. struct swr_dmic_priv *swr_dmic =
  221. snd_soc_component_get_drvdata(component);
  222. int ret = 0;
  223. dev_dbg(component->dev, "%s wname: %s event: %d\n", __func__,
  224. w->name, event);
  225. switch (event) {
  226. case SND_SOC_DAPM_PRE_PMU:
  227. ret = swr_dmic_up(swr_dmic->swr_slave);
  228. break;
  229. case SND_SOC_DAPM_POST_PMU:
  230. ret = swr_dmic_reset(swr_dmic->swr_slave);
  231. break;
  232. case SND_SOC_DAPM_POST_PMD:
  233. ret = swr_dmic_down(swr_dmic->swr_slave);
  234. break;
  235. }
  236. if (ret)
  237. dev_dbg(component->dev, "%s wname: %s event: %d ret : %d\n",
  238. __func__, w->name, event, ret);
  239. return ret;
  240. }
  241. static const char * const tx_master_port_text[] = {
  242. "ZERO", "SWRM_TX1_CH1", "SWRM_TX1_CH2", "SWRM_TX1_CH3", "SWRM_TX1_CH4",
  243. "SWRM_TX2_CH1", "SWRM_TX2_CH2", "SWRM_TX2_CH3", "SWRM_TX2_CH4",
  244. "SWRM_TX3_CH1", "SWRM_TX3_CH2", "SWRM_TX3_CH3", "SWRM_TX3_CH4",
  245. "SWRM_PCM_IN",
  246. };
  247. static const struct soc_enum tx_master_port_enum =
  248. SOC_ENUM_SINGLE_EXT(ARRAY_SIZE(tx_master_port_text),
  249. tx_master_port_text);
  250. static const struct snd_kcontrol_new swr_dmic_snd_controls[] = {
  251. SOC_ENUM_EXT("HIFI PortMap", tx_master_port_enum,
  252. swr_dmic_tx_master_port_get, swr_dmic_tx_master_port_put),
  253. SOC_ENUM_EXT("LP PortMap", tx_master_port_enum,
  254. swr_dmic_tx_master_port_get, swr_dmic_tx_master_port_put),
  255. };
  256. static const struct snd_kcontrol_new dmic_switch[] = {
  257. SOC_DAPM_SINGLE("Switch", SND_SOC_NOPM, 0, 1, 0)
  258. };
  259. static const struct snd_soc_dapm_widget swr_dmic_dapm_widgets[] = {
  260. SND_SOC_DAPM_MIXER_E("SWR_DMIC_MIXER", SND_SOC_NOPM, 0, 0,
  261. dmic_switch, ARRAY_SIZE(dmic_switch), dmic_swr_ctrl,
  262. SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
  263. SND_SOC_DAPM_INPUT("SWR_DMIC"),
  264. SND_SOC_DAPM_SUPPLY_S("SMIC_SUPPLY", 1, SND_SOC_NOPM, 0, 0,
  265. swr_dmic_enable_supply,
  266. SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMU |
  267. SND_SOC_DAPM_POST_PMD),
  268. SND_SOC_DAPM_OUT_DRV_E("SMIC_PORT_EN", SND_SOC_NOPM, 0, 0, NULL, 0,
  269. swr_dmic_port_enable,
  270. SND_SOC_DAPM_POST_PMU | SND_SOC_DAPM_PRE_PMD),
  271. SND_SOC_DAPM_OUTPUT("SWR_DMIC_OUTPUT"),
  272. };
  273. static const struct snd_soc_dapm_route swr_dmic_audio_map[] = {
  274. {"SWR_DMIC", NULL, "SMIC_SUPPLY"},
  275. {"SWR_DMIC_MIXER", "Switch", "SWR_DMIC"},
  276. {"SMIC_PORT_EN", NULL, "SWR_DMIC_MIXER"},
  277. {"SWR_DMIC_OUTPUT", NULL, "SMIC_PORT_EN"},
  278. };
  279. static int swr_dmic_codec_probe(struct snd_soc_component *component)
  280. {
  281. struct swr_dmic_priv *swr_dmic =
  282. snd_soc_component_get_drvdata(component);
  283. struct snd_soc_dapm_context *dapm =
  284. snd_soc_component_get_dapm(component);
  285. char w_name[100];
  286. if (!swr_dmic)
  287. return -EINVAL;
  288. swr_dmic->component = component;
  289. snd_soc_dapm_ignore_suspend(dapm,
  290. swr_dmic->dai_driver->capture.stream_name);
  291. memset(w_name, 0, 100);
  292. strlcpy(w_name, component->name_prefix, 100);
  293. strlcat(w_name, " SWR_DMIC", 100);
  294. snd_soc_dapm_ignore_suspend(dapm, w_name);
  295. memset(w_name, 0, 100);
  296. strlcpy(w_name, component->name_prefix, 100);
  297. strlcat(w_name, " SMIC_SUPPLY", 100);
  298. snd_soc_dapm_ignore_suspend(dapm, w_name);
  299. memset(w_name, 0, 100);
  300. strlcpy(w_name, component->name_prefix, 100);
  301. strlcat(w_name, " SMIC_PORT_EN", 100);
  302. snd_soc_dapm_ignore_suspend(dapm, w_name);
  303. memset(w_name, 0, 100);
  304. strlcpy(w_name, component->name_prefix, 100);
  305. strlcat(w_name, " SWR_DMIC_OUTPUT", 100);
  306. snd_soc_dapm_ignore_suspend(dapm, w_name);
  307. snd_soc_dapm_sync(dapm);
  308. return 0;
  309. }
  310. static void swr_dmic_codec_remove(struct snd_soc_component *component)
  311. {
  312. struct swr_dmic_priv *swr_dmic =
  313. snd_soc_component_get_drvdata(component);
  314. swr_dmic->component = NULL;
  315. return;
  316. }
  317. static const struct snd_soc_component_driver soc_codec_dev_swr_dmic = {
  318. .name = NULL,
  319. .probe = swr_dmic_codec_probe,
  320. .remove = swr_dmic_codec_remove,
  321. .controls = swr_dmic_snd_controls,
  322. .num_controls = ARRAY_SIZE(swr_dmic_snd_controls),
  323. .dapm_widgets = swr_dmic_dapm_widgets,
  324. .num_dapm_widgets = ARRAY_SIZE(swr_dmic_dapm_widgets),
  325. .dapm_routes = swr_dmic_audio_map,
  326. .num_dapm_routes = ARRAY_SIZE(swr_dmic_audio_map),
  327. };
  328. static int enable_wcd_codec_supply(struct swr_dmic_priv *swr_dmic, bool enable)
  329. {
  330. int rc = 0;
  331. int micb_num = swr_dmic->micb_num;
  332. struct snd_soc_component *component = swr_dmic->supply_component;
  333. if (!component) {
  334. pr_err("%s: component is NULL\n", __func__);
  335. return -EINVAL;
  336. }
  337. if (enable)
  338. rc = wcd938x_codec_force_enable_micbias_v2(component,
  339. SND_SOC_DAPM_PRE_PMU, micb_num);
  340. else
  341. rc = wcd938x_codec_force_enable_micbias_v2(component,
  342. SND_SOC_DAPM_POST_PMD, micb_num);
  343. return rc;
  344. }
  345. static int swr_dmic_parse_supply(struct device_node *np,
  346. struct swr_dmic_priv *swr_dmic)
  347. {
  348. struct platform_device *pdev = NULL;
  349. if (!np || !swr_dmic)
  350. return -EINVAL;
  351. pdev = of_find_device_by_node(np);
  352. if (!pdev)
  353. return -EINVAL;
  354. swr_dmic->supply_component = snd_soc_lookup_component(&pdev->dev, NULL);
  355. return 0;
  356. }
  357. static struct snd_soc_dai_driver swr_dmic_dai[] = {
  358. {
  359. .name = "",
  360. .id = 0,
  361. .capture = {
  362. .stream_name = "",
  363. .rates = (SNDRV_PCM_RATE_8000 | SNDRV_PCM_RATE_16000 |
  364. SNDRV_PCM_RATE_32000 | SNDRV_PCM_RATE_48000 |
  365. SNDRV_PCM_RATE_96000 | SNDRV_PCM_RATE_192000),
  366. .formats = (SNDRV_PCM_FMTBIT_S16_LE |
  367. SNDRV_PCM_FMTBIT_S24_LE |
  368. SNDRV_PCM_FMTBIT_S32_LE),
  369. .rate_max = 192000,
  370. .rate_min = 8000,
  371. .channels_min = 1,
  372. .channels_max = 2,
  373. },
  374. },
  375. };
  376. static int swr_dmic_probe(struct swr_device *pdev)
  377. {
  378. int ret = 0;
  379. int i = 0;
  380. u8 swr_devnum = 0;
  381. int dev_index = -1;
  382. char* prefix_name = NULL;
  383. struct swr_dmic_priv *swr_dmic = NULL;
  384. const char *swr_dmic_name_prefix_of = NULL;
  385. const char *swr_dmic_codec_name_of = NULL;
  386. struct snd_soc_component *component = NULL;
  387. int num_retry = NUM_ATTEMPTS;
  388. swr_dmic = devm_kzalloc(&pdev->dev, sizeof(struct swr_dmic_priv),
  389. GFP_KERNEL);
  390. if (!swr_dmic)
  391. return -ENOMEM;
  392. ret = of_property_read_u32(pdev->dev.of_node, "qcom,swr-dmic-supply",
  393. &swr_dmic->micb_num);
  394. if (ret) {
  395. dev_dbg(&pdev->dev, "%s: Looking up %s property in node %s failed\n",
  396. __func__, "qcom,swr-dmic-supply",
  397. pdev->dev.of_node->full_name);
  398. goto err;
  399. }
  400. swr_dmic->wcd_handle = of_parse_phandle(pdev->dev.of_node,
  401. "qcom,wcd-handle", 0);
  402. if (!swr_dmic->wcd_handle) {
  403. dev_dbg(&pdev->dev, "%s: no wcd handle listed\n",
  404. __func__);
  405. swr_dmic->is_wcd_supply = false;
  406. } else {
  407. swr_dmic_parse_supply(swr_dmic->wcd_handle, swr_dmic);
  408. swr_dmic->is_wcd_supply = true;
  409. }
  410. if (swr_dmic->is_wcd_supply) {
  411. ret = enable_wcd_codec_supply(swr_dmic, true);
  412. if (ret) {
  413. ret = -EPROBE_DEFER;
  414. goto err;
  415. }
  416. ++swr_dmic->is_en_supply;
  417. }
  418. swr_set_dev_data(pdev, swr_dmic);
  419. swr_dmic->swr_slave = pdev;
  420. ret = of_property_read_string(pdev->dev.of_node, "qcom,swr-dmic-prefix",
  421. &swr_dmic_name_prefix_of);
  422. if (ret) {
  423. dev_dbg(&pdev->dev, "%s: Looking up %s property in node %s failed\n",
  424. __func__, "qcom,swr-dmic-prefix",
  425. pdev->dev.of_node->full_name);
  426. goto dev_err;
  427. }
  428. ret = of_property_read_string(pdev->dev.of_node, "qcom,codec-name",
  429. &swr_dmic_codec_name_of);
  430. if (ret) {
  431. dev_dbg(&pdev->dev, "%s: Looking up %s property in node %s failed\n",
  432. __func__, "qcom,codec-name",
  433. pdev->dev.of_node->full_name);
  434. goto dev_err;
  435. }
  436. /*
  437. * Add 5msec delay to provide sufficient time for
  438. * soundwire auto enumeration of slave devices as
  439. * as per HW requirement.
  440. */
  441. usleep_range(5000, 5010);
  442. do {
  443. /* Add delay for soundwire enumeration */
  444. usleep_range(100, 110);
  445. ret = swr_get_logical_dev_num(pdev, pdev->addr, &swr_devnum);
  446. } while (ret && --num_retry);
  447. if (ret) {
  448. dev_info(&pdev->dev,
  449. "%s get devnum %d for dev addr %llx failed\n",
  450. __func__, swr_devnum, pdev->addr);
  451. ret = -EPROBE_DEFER;
  452. goto err;
  453. }
  454. pdev->dev_num = swr_devnum;
  455. swr_dmic->driver = devm_kzalloc(&pdev->dev,
  456. sizeof(struct snd_soc_component_driver), GFP_KERNEL);
  457. if (!swr_dmic->driver) {
  458. ret = -ENOMEM;
  459. goto dev_err;
  460. }
  461. memcpy(swr_dmic->driver, &soc_codec_dev_swr_dmic,
  462. sizeof(struct snd_soc_component_driver));
  463. for (i = 0; i < ARRAY_SIZE(codec_name_list); i++) {
  464. if (!strcmp(swr_dmic_codec_name_of, codec_name_list[i])) {
  465. dev_index = i;
  466. break;
  467. }
  468. }
  469. if (dev_index < 0) {
  470. ret = -EINVAL;
  471. goto dev_err;
  472. }
  473. swr_dmic->driver->name = codec_name_list[dev_index];
  474. swr_dmic->dai_driver = devm_kzalloc(&pdev->dev,
  475. sizeof(struct snd_soc_dai_driver), GFP_KERNEL);
  476. if (!swr_dmic->dai_driver) {
  477. ret = -ENOMEM;
  478. goto dev_err;
  479. }
  480. memcpy(swr_dmic->dai_driver, swr_dmic_dai,
  481. sizeof(struct snd_soc_dai_driver));
  482. swr_dmic->dai_driver->id = dev_index;
  483. swr_dmic->dai_driver->name = dai_name_list[dev_index];
  484. swr_dmic->dai_driver->capture.stream_name = aif_name_list[dev_index];
  485. /* Number of DAI's used is 1 */
  486. ret = snd_soc_register_component(&pdev->dev, swr_dmic->driver,
  487. swr_dmic->dai_driver, 1);
  488. if (ret) {
  489. dev_err(&pdev->dev, "%s: Codec registration failed\n",
  490. __func__);
  491. goto dev_err;
  492. }
  493. component = snd_soc_lookup_component(&pdev->dev,
  494. swr_dmic->driver->name);
  495. if (!component) {
  496. dev_err(&pdev->dev, "%s: could not find swr_dmic component\n",
  497. __func__);
  498. goto dev_err;
  499. }
  500. swr_dmic->component = component;
  501. prefix_name = devm_kzalloc(&pdev->dev,
  502. strlen(swr_dmic_name_prefix_of) + 1,
  503. GFP_KERNEL);
  504. if (!prefix_name) {
  505. ret = -ENOMEM;
  506. goto dev_err;
  507. }
  508. strlcpy(prefix_name, swr_dmic_name_prefix_of,
  509. strlen(swr_dmic_name_prefix_of) + 1);
  510. component->name_prefix = prefix_name;
  511. if (swr_dmic->is_en_supply == 1) {
  512. enable_wcd_codec_supply(swr_dmic, false);
  513. --swr_dmic->is_en_supply;
  514. }
  515. return 0;
  516. dev_err:
  517. if (swr_dmic->is_en_supply == 1) {
  518. enable_wcd_codec_supply(swr_dmic, false);
  519. --swr_dmic->is_en_supply;
  520. }
  521. swr_dmic->is_wcd_supply = false;
  522. swr_dmic->wcd_handle = NULL;
  523. swr_remove_device(pdev);
  524. err:
  525. return ret;
  526. }
  527. static int swr_dmic_remove(struct swr_device *pdev)
  528. {
  529. struct swr_dmic_priv *swr_dmic;
  530. swr_dmic = swr_get_dev_data(pdev);
  531. if (!swr_dmic) {
  532. dev_err(&pdev->dev, "%s: swr_dmic is NULL\n", __func__);
  533. return -EINVAL;
  534. }
  535. snd_soc_unregister_component(&pdev->dev);
  536. swr_set_dev_data(pdev, NULL);
  537. return 0;
  538. }
  539. static int swr_dmic_up(struct swr_device *pdev)
  540. {
  541. int ret = 0;
  542. struct swr_dmic_priv *swr_dmic;
  543. swr_dmic = swr_get_dev_data(pdev);
  544. if (!swr_dmic) {
  545. dev_err(&pdev->dev, "%s: swr_dmic is NULL\n", __func__);
  546. return -EINVAL;
  547. }
  548. ++swr_dmic->is_en_supply;
  549. if (swr_dmic->is_en_supply == 1)
  550. ret = enable_wcd_codec_supply(swr_dmic, true);
  551. return ret;
  552. }
  553. static int swr_dmic_down(struct swr_device *pdev)
  554. {
  555. struct swr_dmic_priv *swr_dmic;
  556. int ret = 0;
  557. swr_dmic = swr_get_dev_data(pdev);
  558. if (!swr_dmic) {
  559. dev_err(&pdev->dev, "%s: swr_dmic is NULL\n", __func__);
  560. return -EINVAL;
  561. }
  562. dev_dbg(&pdev->dev, "%s: is_en_supply: %d\n",
  563. __func__, swr_dmic->is_en_supply);
  564. --swr_dmic->is_en_supply;
  565. if (swr_dmic->is_en_supply < 0) {
  566. dev_warn(&pdev->dev, "%s: mismatch in supply count %d\n",
  567. __func__, swr_dmic->is_en_supply);
  568. swr_dmic->is_en_supply = 0;
  569. goto done;
  570. }
  571. if (!swr_dmic->is_en_supply)
  572. enable_wcd_codec_supply(swr_dmic, false);
  573. done:
  574. return ret;
  575. }
  576. static int swr_dmic_reset(struct swr_device *pdev)
  577. {
  578. struct swr_dmic_priv *swr_dmic;
  579. u8 retry = NUM_ATTEMPTS;
  580. u8 devnum = 0;
  581. swr_dmic = swr_get_dev_data(pdev);
  582. if (!swr_dmic) {
  583. dev_err(&pdev->dev, "%s: swr_dmic is NULL\n", __func__);
  584. return -EINVAL;
  585. }
  586. while (swr_get_logical_dev_num(pdev, pdev->addr, &devnum) && retry--) {
  587. /* Retry after 1 msec delay */
  588. usleep_range(1000, 1100);
  589. }
  590. pdev->dev_num = devnum;
  591. dev_dbg(&pdev->dev, "%s: devnum: %d\n", __func__, devnum);
  592. return 0;
  593. }
  594. #ifdef CONFIG_PM_SLEEP
  595. static int swr_dmic_suspend(struct device *dev)
  596. {
  597. dev_dbg(dev, "%s: system suspend\n", __func__);
  598. return 0;
  599. }
  600. static int swr_dmic_resume(struct device *dev)
  601. {
  602. struct swr_dmic_priv *swr_dmic = swr_get_dev_data(to_swr_device(dev));
  603. if (!swr_dmic) {
  604. dev_err(dev, "%s: swr_dmic private data is NULL\n", __func__);
  605. return -EINVAL;
  606. }
  607. dev_dbg(dev, "%s: system resume\n", __func__);
  608. return 0;
  609. }
  610. #endif /* CONFIG_PM_SLEEP */
  611. static const struct dev_pm_ops swr_dmic_pm_ops = {
  612. SET_SYSTEM_SLEEP_PM_OPS(swr_dmic_suspend, swr_dmic_resume)
  613. };
  614. static const struct swr_device_id swr_dmic_id[] = {
  615. {"swr-dmic", 0},
  616. {}
  617. };
  618. static const struct of_device_id swr_dmic_dt_match[] = {
  619. {
  620. .compatible = "qcom,swr-dmic",
  621. },
  622. {}
  623. };
  624. static struct swr_driver swr_dmic_driver = {
  625. .driver = {
  626. .name = "swr-dmic",
  627. .owner = THIS_MODULE,
  628. .pm = &swr_dmic_pm_ops,
  629. .of_match_table = swr_dmic_dt_match,
  630. },
  631. .probe = swr_dmic_probe,
  632. .remove = swr_dmic_remove,
  633. .id_table = swr_dmic_id,
  634. .device_down = swr_dmic_down,
  635. };
  636. static int __init swr_dmic_init(void)
  637. {
  638. return swr_driver_register(&swr_dmic_driver);
  639. }
  640. static void __exit swr_dmic_exit(void)
  641. {
  642. swr_driver_unregister(&swr_dmic_driver);
  643. }
  644. module_init(swr_dmic_init);
  645. module_exit(swr_dmic_exit);
  646. MODULE_DESCRIPTION("SWR DMIC driver");
  647. MODULE_LICENSE("GPL v2");