cs35l56_hda.c 35 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. //
  3. // HDA audio driver for Cirrus Logic CS35L56 smart amp
  4. //
  5. // Copyright (C) 2023 Cirrus Logic, Inc. and
  6. // Cirrus Logic International Semiconductor Ltd.
  7. //
  8. #include <linux/acpi.h>
  9. #include <linux/debugfs.h>
  10. #include <linux/gpio/consumer.h>
  11. #include <linux/module.h>
  12. #include <linux/pm_runtime.h>
  13. #include <linux/regmap.h>
  14. #include <linux/slab.h>
  15. #include <sound/core.h>
  16. #include <sound/cs-amp-lib.h>
  17. #include <sound/hda_codec.h>
  18. #include <sound/tlv.h>
  19. #include "cirrus_scodec.h"
  20. #include "cs35l56_hda.h"
  21. #include "hda_component.h"
  22. #include "../generic.h"
  23. /*
  24. * The cs35l56_hda_dai_config[] reg sequence configures the device as
  25. * ASP1_BCLK_FREQ = 3.072 MHz
  26. * ASP1_RX_WIDTH = 32 cycles per slot, ASP1_TX_WIDTH = 32 cycles per slot, ASP1_FMT = I2S
  27. * ASP1_DOUT_HIZ_CONTROL = Hi-Z during unused timeslots
  28. * ASP1_RX_WL = 24 bits per sample
  29. * ASP1_TX_WL = 24 bits per sample
  30. * ASP1_RXn_EN 1..3 and ASP1_TXn_EN 1..4 disabled
  31. *
  32. * Override any Windows-specific mixer settings applied by the firmware.
  33. */
  34. static const struct reg_sequence cs35l56_hda_dai_config[] = {
  35. { CS35L56_ASP1_CONTROL1, 0x00000021 },
  36. { CS35L56_ASP1_CONTROL2, 0x20200200 },
  37. { CS35L56_ASP1_CONTROL3, 0x00000003 },
  38. { CS35L56_ASP1_FRAME_CONTROL1, 0x03020100 },
  39. { CS35L56_ASP1_FRAME_CONTROL5, 0x00020100 },
  40. { CS35L56_ASP1_DATA_CONTROL5, 0x00000018 },
  41. { CS35L56_ASP1_DATA_CONTROL1, 0x00000018 },
  42. { CS35L56_ASP1_ENABLES1, 0x00000000 },
  43. { CS35L56_ASP1TX1_INPUT, 0x00000018 },
  44. { CS35L56_ASP1TX2_INPUT, 0x00000019 },
  45. { CS35L56_ASP1TX3_INPUT, 0x00000020 },
  46. { CS35L56_ASP1TX4_INPUT, 0x00000028 },
  47. };
  48. static void cs35l56_hda_wait_dsp_ready(struct cs35l56_hda *cs35l56)
  49. {
  50. /* Wait for patching to complete */
  51. flush_work(&cs35l56->dsp_work);
  52. }
  53. static void cs35l56_hda_play(struct cs35l56_hda *cs35l56)
  54. {
  55. unsigned int val;
  56. int ret;
  57. cs35l56_hda_wait_dsp_ready(cs35l56);
  58. pm_runtime_get_sync(cs35l56->base.dev);
  59. ret = cs35l56_mbox_send(&cs35l56->base, CS35L56_MBOX_CMD_AUDIO_PLAY);
  60. if (ret == 0) {
  61. /* Wait for firmware to enter PS0 power state */
  62. ret = regmap_read_poll_timeout(cs35l56->base.regmap,
  63. cs35l56->base.fw_reg->transducer_actual_ps,
  64. val, (val == CS35L56_PS0),
  65. CS35L56_PS0_POLL_US,
  66. CS35L56_PS0_TIMEOUT_US);
  67. if (ret)
  68. dev_warn(cs35l56->base.dev, "PS0 wait failed: %d\n", ret);
  69. }
  70. regmap_set_bits(cs35l56->base.regmap, CS35L56_ASP1_ENABLES1,
  71. BIT(CS35L56_ASP_RX1_EN_SHIFT) | BIT(CS35L56_ASP_RX2_EN_SHIFT) |
  72. cs35l56->asp_tx_mask);
  73. cs35l56->playing = true;
  74. }
  75. static void cs35l56_hda_pause(struct cs35l56_hda *cs35l56)
  76. {
  77. cs35l56->playing = false;
  78. cs35l56_mbox_send(&cs35l56->base, CS35L56_MBOX_CMD_AUDIO_PAUSE);
  79. regmap_clear_bits(cs35l56->base.regmap, CS35L56_ASP1_ENABLES1,
  80. BIT(CS35L56_ASP_RX1_EN_SHIFT) | BIT(CS35L56_ASP_RX2_EN_SHIFT) |
  81. BIT(CS35L56_ASP_TX1_EN_SHIFT) | BIT(CS35L56_ASP_TX2_EN_SHIFT) |
  82. BIT(CS35L56_ASP_TX3_EN_SHIFT) | BIT(CS35L56_ASP_TX4_EN_SHIFT));
  83. pm_runtime_put_autosuspend(cs35l56->base.dev);
  84. }
  85. static void cs35l56_hda_playback_hook(struct device *dev, int action)
  86. {
  87. struct cs35l56_hda *cs35l56 = dev_get_drvdata(dev);
  88. dev_dbg(cs35l56->base.dev, "%s()%d: action: %d\n", __func__, __LINE__, action);
  89. switch (action) {
  90. case HDA_GEN_PCM_ACT_PREPARE:
  91. if (cs35l56->playing)
  92. break;
  93. /* If we're suspended: flag that resume should start playback */
  94. if (cs35l56->suspended) {
  95. cs35l56->playing = true;
  96. break;
  97. }
  98. cs35l56_hda_play(cs35l56);
  99. break;
  100. case HDA_GEN_PCM_ACT_CLEANUP:
  101. if (!cs35l56->playing)
  102. break;
  103. cs35l56_hda_pause(cs35l56);
  104. break;
  105. default:
  106. break;
  107. }
  108. }
  109. static int cs35l56_hda_runtime_suspend(struct device *dev)
  110. {
  111. struct cs35l56_hda *cs35l56 = dev_get_drvdata(dev);
  112. if (cs35l56->cs_dsp.booted)
  113. cs_dsp_stop(&cs35l56->cs_dsp);
  114. return cs35l56_runtime_suspend_common(&cs35l56->base);
  115. }
  116. static int cs35l56_hda_runtime_resume(struct device *dev)
  117. {
  118. struct cs35l56_hda *cs35l56 = dev_get_drvdata(dev);
  119. int ret;
  120. ret = cs35l56_runtime_resume_common(&cs35l56->base, false);
  121. if (ret < 0)
  122. return ret;
  123. if (cs35l56->cs_dsp.booted) {
  124. ret = cs_dsp_run(&cs35l56->cs_dsp);
  125. if (ret) {
  126. dev_dbg(cs35l56->base.dev, "%s: cs_dsp_run ret %d\n", __func__, ret);
  127. goto err;
  128. }
  129. }
  130. return 0;
  131. err:
  132. cs35l56_mbox_send(&cs35l56->base, CS35L56_MBOX_CMD_ALLOW_AUTO_HIBERNATE);
  133. regmap_write(cs35l56->base.regmap, CS35L56_DSP_VIRTUAL1_MBOX_1,
  134. CS35L56_MBOX_CMD_HIBERNATE_NOW);
  135. regcache_cache_only(cs35l56->base.regmap, true);
  136. return ret;
  137. }
  138. static int cs35l56_hda_mixer_info(struct snd_kcontrol *kcontrol,
  139. struct snd_ctl_elem_info *uinfo)
  140. {
  141. uinfo->type = SNDRV_CTL_ELEM_TYPE_ENUMERATED;
  142. uinfo->count = 1;
  143. uinfo->value.enumerated.items = CS35L56_NUM_INPUT_SRC;
  144. if (uinfo->value.enumerated.item >= CS35L56_NUM_INPUT_SRC)
  145. uinfo->value.enumerated.item = CS35L56_NUM_INPUT_SRC - 1;
  146. strscpy(uinfo->value.enumerated.name, cs35l56_tx_input_texts[uinfo->value.enumerated.item],
  147. sizeof(uinfo->value.enumerated.name));
  148. return 0;
  149. }
  150. static int cs35l56_hda_mixer_get(struct snd_kcontrol *kcontrol,
  151. struct snd_ctl_elem_value *ucontrol)
  152. {
  153. struct cs35l56_hda *cs35l56 = snd_kcontrol_chip(kcontrol);
  154. unsigned int reg_val;
  155. int i;
  156. cs35l56_hda_wait_dsp_ready(cs35l56);
  157. regmap_read(cs35l56->base.regmap, kcontrol->private_value, &reg_val);
  158. reg_val &= CS35L56_ASP_TXn_SRC_MASK;
  159. for (i = 0; i < CS35L56_NUM_INPUT_SRC; ++i) {
  160. if (cs35l56_tx_input_values[i] == reg_val) {
  161. ucontrol->value.enumerated.item[0] = i;
  162. break;
  163. }
  164. }
  165. return 0;
  166. }
  167. static int cs35l56_hda_mixer_put(struct snd_kcontrol *kcontrol,
  168. struct snd_ctl_elem_value *ucontrol)
  169. {
  170. struct cs35l56_hda *cs35l56 = snd_kcontrol_chip(kcontrol);
  171. unsigned int item = ucontrol->value.enumerated.item[0];
  172. bool changed;
  173. if (item >= CS35L56_NUM_INPUT_SRC)
  174. return -EINVAL;
  175. cs35l56_hda_wait_dsp_ready(cs35l56);
  176. regmap_update_bits_check(cs35l56->base.regmap, kcontrol->private_value,
  177. CS35L56_INPUT_MASK, cs35l56_tx_input_values[item],
  178. &changed);
  179. return changed;
  180. }
  181. static int cs35l56_hda_posture_info(struct snd_kcontrol *kcontrol,
  182. struct snd_ctl_elem_info *uinfo)
  183. {
  184. uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER;
  185. uinfo->count = 1;
  186. uinfo->value.integer.min = CS35L56_MAIN_POSTURE_MIN;
  187. uinfo->value.integer.max = CS35L56_MAIN_POSTURE_MAX;
  188. return 0;
  189. }
  190. static int cs35l56_hda_posture_get(struct snd_kcontrol *kcontrol,
  191. struct snd_ctl_elem_value *ucontrol)
  192. {
  193. struct cs35l56_hda *cs35l56 = snd_kcontrol_chip(kcontrol);
  194. unsigned int pos;
  195. int ret;
  196. cs35l56_hda_wait_dsp_ready(cs35l56);
  197. ret = regmap_read(cs35l56->base.regmap,
  198. cs35l56->base.fw_reg->posture_number, &pos);
  199. if (ret)
  200. return ret;
  201. ucontrol->value.integer.value[0] = pos;
  202. return 0;
  203. }
  204. static int cs35l56_hda_posture_put(struct snd_kcontrol *kcontrol,
  205. struct snd_ctl_elem_value *ucontrol)
  206. {
  207. struct cs35l56_hda *cs35l56 = snd_kcontrol_chip(kcontrol);
  208. long pos = ucontrol->value.integer.value[0];
  209. bool changed;
  210. int ret;
  211. if ((pos < CS35L56_MAIN_POSTURE_MIN) ||
  212. (pos > CS35L56_MAIN_POSTURE_MAX))
  213. return -EINVAL;
  214. cs35l56_hda_wait_dsp_ready(cs35l56);
  215. ret = regmap_update_bits_check(cs35l56->base.regmap, cs35l56->base.fw_reg->posture_number,
  216. CS35L56_MAIN_POSTURE_MASK, pos, &changed);
  217. if (ret)
  218. return ret;
  219. return changed;
  220. }
  221. static const struct {
  222. const char *name;
  223. unsigned int reg;
  224. } cs35l56_hda_mixer_controls[] = {
  225. { "ASP1 TX1 Source", CS35L56_ASP1TX1_INPUT },
  226. { "ASP1 TX2 Source", CS35L56_ASP1TX2_INPUT },
  227. { "ASP1 TX3 Source", CS35L56_ASP1TX3_INPUT },
  228. { "ASP1 TX4 Source", CS35L56_ASP1TX4_INPUT },
  229. };
  230. static const DECLARE_TLV_DB_SCALE(cs35l56_hda_vol_tlv, -10000, 25, 0);
  231. static int cs35l56_hda_vol_info(struct snd_kcontrol *kcontrol,
  232. struct snd_ctl_elem_info *uinfo)
  233. {
  234. uinfo->type = SNDRV_CTL_ELEM_TYPE_INTEGER;
  235. uinfo->count = 1;
  236. uinfo->value.integer.step = 1;
  237. uinfo->value.integer.min = 0;
  238. uinfo->value.integer.max = CS35L56_MAIN_RENDER_USER_VOLUME_MAX -
  239. CS35L56_MAIN_RENDER_USER_VOLUME_MIN;
  240. return 0;
  241. }
  242. static int cs35l56_hda_vol_get(struct snd_kcontrol *kcontrol,
  243. struct snd_ctl_elem_value *ucontrol)
  244. {
  245. struct cs35l56_hda *cs35l56 = snd_kcontrol_chip(kcontrol);
  246. unsigned int raw_vol;
  247. int vol;
  248. int ret;
  249. cs35l56_hda_wait_dsp_ready(cs35l56);
  250. ret = regmap_read(cs35l56->base.regmap, cs35l56->base.fw_reg->user_volume, &raw_vol);
  251. if (ret)
  252. return ret;
  253. vol = (s16)(raw_vol & 0xFFFF);
  254. vol >>= CS35L56_MAIN_RENDER_USER_VOLUME_SHIFT;
  255. if (vol & BIT(CS35L56_MAIN_RENDER_USER_VOLUME_SIGNBIT))
  256. vol |= ~((int)(BIT(CS35L56_MAIN_RENDER_USER_VOLUME_SIGNBIT) - 1));
  257. ucontrol->value.integer.value[0] = vol - CS35L56_MAIN_RENDER_USER_VOLUME_MIN;
  258. return 0;
  259. }
  260. static int cs35l56_hda_vol_put(struct snd_kcontrol *kcontrol,
  261. struct snd_ctl_elem_value *ucontrol)
  262. {
  263. struct cs35l56_hda *cs35l56 = snd_kcontrol_chip(kcontrol);
  264. long vol = ucontrol->value.integer.value[0];
  265. unsigned int raw_vol;
  266. bool changed;
  267. int ret;
  268. if ((vol < 0) || (vol > (CS35L56_MAIN_RENDER_USER_VOLUME_MAX -
  269. CS35L56_MAIN_RENDER_USER_VOLUME_MIN)))
  270. return -EINVAL;
  271. raw_vol = (vol + CS35L56_MAIN_RENDER_USER_VOLUME_MIN) <<
  272. CS35L56_MAIN_RENDER_USER_VOLUME_SHIFT;
  273. cs35l56_hda_wait_dsp_ready(cs35l56);
  274. ret = regmap_update_bits_check(cs35l56->base.regmap, cs35l56->base.fw_reg->user_volume,
  275. CS35L56_MAIN_RENDER_USER_VOLUME_MASK, raw_vol, &changed);
  276. if (ret)
  277. return ret;
  278. return changed;
  279. }
  280. static void cs35l56_hda_create_controls(struct cs35l56_hda *cs35l56)
  281. {
  282. struct snd_kcontrol_new ctl_template = {
  283. .iface = SNDRV_CTL_ELEM_IFACE_MIXER,
  284. .access = SNDRV_CTL_ELEM_ACCESS_READWRITE,
  285. .info = cs35l56_hda_posture_info,
  286. .get = cs35l56_hda_posture_get,
  287. .put = cs35l56_hda_posture_put,
  288. };
  289. char name[64];
  290. int i;
  291. snprintf(name, sizeof(name), "%s Posture Number", cs35l56->amp_name);
  292. ctl_template.name = name;
  293. cs35l56->posture_ctl = snd_ctl_new1(&ctl_template, cs35l56);
  294. if (snd_ctl_add(cs35l56->codec->card, cs35l56->posture_ctl))
  295. dev_err(cs35l56->base.dev, "Failed to add KControl: %s\n", ctl_template.name);
  296. /* Mixer controls */
  297. ctl_template.info = cs35l56_hda_mixer_info;
  298. ctl_template.get = cs35l56_hda_mixer_get;
  299. ctl_template.put = cs35l56_hda_mixer_put;
  300. BUILD_BUG_ON(ARRAY_SIZE(cs35l56->mixer_ctl) != ARRAY_SIZE(cs35l56_hda_mixer_controls));
  301. for (i = 0; i < ARRAY_SIZE(cs35l56_hda_mixer_controls); ++i) {
  302. snprintf(name, sizeof(name), "%s %s", cs35l56->amp_name,
  303. cs35l56_hda_mixer_controls[i].name);
  304. ctl_template.private_value = cs35l56_hda_mixer_controls[i].reg;
  305. cs35l56->mixer_ctl[i] = snd_ctl_new1(&ctl_template, cs35l56);
  306. if (snd_ctl_add(cs35l56->codec->card, cs35l56->mixer_ctl[i])) {
  307. dev_err(cs35l56->base.dev, "Failed to add KControl: %s\n",
  308. ctl_template.name);
  309. }
  310. }
  311. ctl_template.info = cs35l56_hda_vol_info;
  312. ctl_template.get = cs35l56_hda_vol_get;
  313. ctl_template.put = cs35l56_hda_vol_put;
  314. ctl_template.access = (SNDRV_CTL_ELEM_ACCESS_READWRITE | SNDRV_CTL_ELEM_ACCESS_TLV_READ);
  315. ctl_template.tlv.p = cs35l56_hda_vol_tlv;
  316. snprintf(name, sizeof(name), "%s Speaker Playback Volume", cs35l56->amp_name);
  317. ctl_template.name = name;
  318. cs35l56->volume_ctl = snd_ctl_new1(&ctl_template, cs35l56);
  319. if (snd_ctl_add(cs35l56->codec->card, cs35l56->volume_ctl))
  320. dev_err(cs35l56->base.dev, "Failed to add KControl: %s\n", ctl_template.name);
  321. }
  322. static void cs35l56_hda_remove_controls(struct cs35l56_hda *cs35l56)
  323. {
  324. int i;
  325. for (i = ARRAY_SIZE(cs35l56->mixer_ctl) - 1; i >= 0; i--)
  326. snd_ctl_remove(cs35l56->codec->card, cs35l56->mixer_ctl[i]);
  327. snd_ctl_remove(cs35l56->codec->card, cs35l56->posture_ctl);
  328. snd_ctl_remove(cs35l56->codec->card, cs35l56->volume_ctl);
  329. }
  330. static int cs35l56_hda_request_firmware_file(struct cs35l56_hda *cs35l56,
  331. const struct firmware **firmware, char **filename,
  332. const char *base_name, const char *system_name,
  333. const char *amp_name,
  334. const char *filetype)
  335. {
  336. char *s, c;
  337. int ret = 0;
  338. if (system_name && amp_name)
  339. *filename = kasprintf(GFP_KERNEL, "%s-%s-%s.%s", base_name,
  340. system_name, amp_name, filetype);
  341. else if (system_name)
  342. *filename = kasprintf(GFP_KERNEL, "%s-%s.%s", base_name,
  343. system_name, filetype);
  344. else
  345. *filename = kasprintf(GFP_KERNEL, "%s.%s", base_name, filetype);
  346. if (!*filename)
  347. return -ENOMEM;
  348. /*
  349. * Make sure that filename is lower-case and any non alpha-numeric
  350. * characters except full stop and forward slash are replaced with
  351. * hyphens.
  352. */
  353. s = *filename;
  354. while (*s) {
  355. c = *s;
  356. if (isalnum(c))
  357. *s = tolower(c);
  358. else if (c != '.' && c != '/')
  359. *s = '-';
  360. s++;
  361. }
  362. ret = firmware_request_nowarn(firmware, *filename, cs35l56->base.dev);
  363. if (ret) {
  364. dev_dbg(cs35l56->base.dev, "Failed to request '%s'\n", *filename);
  365. kfree(*filename);
  366. *filename = NULL;
  367. return ret;
  368. }
  369. dev_dbg(cs35l56->base.dev, "Found '%s'\n", *filename);
  370. return 0;
  371. }
  372. static void cs35l56_hda_request_firmware_files(struct cs35l56_hda *cs35l56,
  373. unsigned int preloaded_fw_ver,
  374. const struct firmware **wmfw_firmware,
  375. char **wmfw_filename,
  376. const struct firmware **coeff_firmware,
  377. char **coeff_filename)
  378. {
  379. const char *system_name = cs35l56->system_name;
  380. const char *amp_name = cs35l56->amp_name;
  381. char base_name[37];
  382. int ret;
  383. if (preloaded_fw_ver) {
  384. snprintf(base_name, sizeof(base_name),
  385. "cirrus/cs35l%02x-%02x%s-%06x-dsp1-misc",
  386. cs35l56->base.type,
  387. cs35l56->base.rev,
  388. cs35l56->base.secured ? "-s" : "",
  389. preloaded_fw_ver & 0xffffff);
  390. } else {
  391. snprintf(base_name, sizeof(base_name),
  392. "cirrus/cs35l%02x-%02x%s-dsp1-misc",
  393. cs35l56->base.type,
  394. cs35l56->base.rev,
  395. cs35l56->base.secured ? "-s" : "");
  396. }
  397. if (system_name && amp_name) {
  398. if (!cs35l56_hda_request_firmware_file(cs35l56, wmfw_firmware, wmfw_filename,
  399. base_name, system_name, amp_name, "wmfw")) {
  400. cs35l56_hda_request_firmware_file(cs35l56, coeff_firmware, coeff_filename,
  401. base_name, system_name, amp_name, "bin");
  402. return;
  403. }
  404. }
  405. if (system_name) {
  406. if (!cs35l56_hda_request_firmware_file(cs35l56, wmfw_firmware, wmfw_filename,
  407. base_name, system_name, NULL, "wmfw")) {
  408. if (amp_name)
  409. cs35l56_hda_request_firmware_file(cs35l56,
  410. coeff_firmware, coeff_filename,
  411. base_name, system_name,
  412. amp_name, "bin");
  413. if (!*coeff_firmware)
  414. cs35l56_hda_request_firmware_file(cs35l56,
  415. coeff_firmware, coeff_filename,
  416. base_name, system_name,
  417. NULL, "bin");
  418. return;
  419. }
  420. /*
  421. * Check for system-specific bin files without wmfw before
  422. * falling back to generic firmware
  423. */
  424. if (amp_name)
  425. cs35l56_hda_request_firmware_file(cs35l56, coeff_firmware, coeff_filename,
  426. base_name, system_name, amp_name, "bin");
  427. if (!*coeff_firmware)
  428. cs35l56_hda_request_firmware_file(cs35l56, coeff_firmware, coeff_filename,
  429. base_name, system_name, NULL, "bin");
  430. if (*coeff_firmware)
  431. return;
  432. }
  433. ret = cs35l56_hda_request_firmware_file(cs35l56, wmfw_firmware, wmfw_filename,
  434. base_name, NULL, NULL, "wmfw");
  435. if (!ret) {
  436. cs35l56_hda_request_firmware_file(cs35l56, coeff_firmware, coeff_filename,
  437. base_name, NULL, NULL, "bin");
  438. return;
  439. }
  440. if (!*coeff_firmware)
  441. cs35l56_hda_request_firmware_file(cs35l56, coeff_firmware, coeff_filename,
  442. base_name, NULL, NULL, "bin");
  443. }
  444. static void cs35l56_hda_release_firmware_files(const struct firmware *wmfw_firmware,
  445. char *wmfw_filename,
  446. const struct firmware *coeff_firmware,
  447. char *coeff_filename)
  448. {
  449. release_firmware(wmfw_firmware);
  450. kfree(wmfw_filename);
  451. release_firmware(coeff_firmware);
  452. kfree(coeff_filename);
  453. }
  454. static int cs35l56_hda_apply_calibration(struct cs35l56_hda *cs35l56)
  455. {
  456. int ret;
  457. if (!cs35l56->base.cal_data_valid || cs35l56->base.secured)
  458. return -EACCES;
  459. ret = cs_amp_write_cal_coeffs(&cs35l56->cs_dsp,
  460. &cs35l56_calibration_controls,
  461. &cs35l56->base.cal_data);
  462. if (ret < 0) {
  463. dev_warn(cs35l56->base.dev, "Failed to write calibration: %d\n", ret);
  464. return ret;
  465. }
  466. dev_info(cs35l56->base.dev, "Calibration applied\n");
  467. return 0;
  468. }
  469. static void cs35l56_hda_fw_load(struct cs35l56_hda *cs35l56)
  470. {
  471. const struct firmware *coeff_firmware = NULL;
  472. const struct firmware *wmfw_firmware = NULL;
  473. char *coeff_filename = NULL;
  474. char *wmfw_filename = NULL;
  475. unsigned int preloaded_fw_ver;
  476. bool firmware_missing;
  477. int ret;
  478. /*
  479. * Prepare for a new DSP power-up. If the DSP has had firmware
  480. * downloaded previously then it needs to be powered down so that it
  481. * can be updated.
  482. */
  483. if (cs35l56->base.fw_patched)
  484. cs_dsp_power_down(&cs35l56->cs_dsp);
  485. cs35l56->base.fw_patched = false;
  486. PM_RUNTIME_ACQUIRE_IF_ENABLED(cs35l56->base.dev, pm);
  487. ret = PM_RUNTIME_ACQUIRE_ERR(&pm);
  488. if (ret < 0) {
  489. dev_err(cs35l56->base.dev, "Failed to resume and get %d\n", ret);
  490. return;
  491. }
  492. /*
  493. * The firmware can only be upgraded if it is currently running
  494. * from the built-in ROM. If not, the wmfw/bin must be for the
  495. * version of firmware that is running on the chip.
  496. */
  497. ret = cs35l56_read_prot_status(&cs35l56->base, &firmware_missing, &preloaded_fw_ver);
  498. if (ret)
  499. return;
  500. if (firmware_missing)
  501. preloaded_fw_ver = 0;
  502. cs35l56_hda_request_firmware_files(cs35l56, preloaded_fw_ver,
  503. &wmfw_firmware, &wmfw_filename,
  504. &coeff_firmware, &coeff_filename);
  505. /*
  506. * If the BIOS didn't patch the firmware a bin file is mandatory to
  507. * enable the ASP·
  508. */
  509. if (!coeff_firmware && firmware_missing) {
  510. dev_err(cs35l56->base.dev, ".bin file required but not found\n");
  511. goto err_fw_release;
  512. }
  513. mutex_lock(&cs35l56->base.irq_lock);
  514. /*
  515. * If the firmware hasn't been patched it must be shutdown before
  516. * doing a full patch and reset afterwards. If it is already
  517. * running a patched version the firmware files only contain
  518. * tunings and we can use the lower cost reinit sequence instead.
  519. */
  520. if (firmware_missing && (wmfw_firmware || coeff_firmware)) {
  521. ret = cs35l56_firmware_shutdown(&cs35l56->base);
  522. if (ret)
  523. goto err;
  524. }
  525. ret = cs_dsp_power_up(&cs35l56->cs_dsp, wmfw_firmware, wmfw_filename,
  526. coeff_firmware, coeff_filename, "misc");
  527. if (ret) {
  528. dev_dbg(cs35l56->base.dev, "%s: cs_dsp_power_up ret %d\n", __func__, ret);
  529. goto err;
  530. }
  531. if (wmfw_filename)
  532. dev_dbg(cs35l56->base.dev, "Loaded WMFW Firmware: %s\n", wmfw_filename);
  533. if (coeff_filename)
  534. dev_dbg(cs35l56->base.dev, "Loaded Coefficients: %s\n", coeff_filename);
  535. /* If we downloaded firmware, reset the device and wait for it to boot */
  536. if (firmware_missing && (wmfw_firmware || coeff_firmware)) {
  537. cs35l56_system_reset(&cs35l56->base, false);
  538. regcache_mark_dirty(cs35l56->base.regmap);
  539. ret = cs35l56_wait_for_firmware_boot(&cs35l56->base);
  540. if (ret)
  541. goto err_powered_up;
  542. regcache_cache_only(cs35l56->base.regmap, false);
  543. }
  544. /* Disable auto-hibernate so that runtime_pm has control */
  545. ret = cs35l56_mbox_send(&cs35l56->base, CS35L56_MBOX_CMD_PREVENT_AUTO_HIBERNATE);
  546. if (ret)
  547. goto err_powered_up;
  548. regcache_sync(cs35l56->base.regmap);
  549. regmap_clear_bits(cs35l56->base.regmap,
  550. cs35l56->base.fw_reg->prot_sts,
  551. CS35L56_FIRMWARE_MISSING);
  552. cs35l56->base.fw_patched = true;
  553. ret = cs_dsp_run(&cs35l56->cs_dsp);
  554. if (ret)
  555. dev_dbg(cs35l56->base.dev, "%s: cs_dsp_run ret %d\n", __func__, ret);
  556. /* Don't need to check return code, it's not fatal if this fails */
  557. cs35l56_hda_apply_calibration(cs35l56);
  558. ret = cs35l56_mbox_send(&cs35l56->base, CS35L56_MBOX_CMD_AUDIO_REINIT);
  559. if (ret)
  560. cs_dsp_stop(&cs35l56->cs_dsp);
  561. cs35l56_log_tuning(&cs35l56->base, &cs35l56->cs_dsp);
  562. err_powered_up:
  563. if (!cs35l56->base.fw_patched)
  564. cs_dsp_power_down(&cs35l56->cs_dsp);
  565. err:
  566. mutex_unlock(&cs35l56->base.irq_lock);
  567. err_fw_release:
  568. cs35l56_hda_release_firmware_files(wmfw_firmware, wmfw_filename,
  569. coeff_firmware, coeff_filename);
  570. }
  571. static void cs35l56_hda_dsp_work(struct work_struct *work)
  572. {
  573. struct cs35l56_hda *cs35l56 = container_of(work, struct cs35l56_hda, dsp_work);
  574. cs35l56_hda_fw_load(cs35l56);
  575. }
  576. static ssize_t cs35l56_hda_debugfs_calibrate_write(struct file *file,
  577. const char __user *from,
  578. size_t count, loff_t *ppos)
  579. {
  580. struct cs35l56_base *cs35l56_base = file->private_data;
  581. ssize_t ret;
  582. PM_RUNTIME_ACQUIRE_IF_ENABLED_AUTOSUSPEND(cs35l56_base->dev, pm);
  583. ret = PM_RUNTIME_ACQUIRE_ERR(&pm);
  584. if (ret)
  585. return ret;
  586. return cs35l56_calibrate_debugfs_write(cs35l56_base, from, count, ppos);
  587. }
  588. static ssize_t cs35l56_hda_debugfs_cal_temperature_write(struct file *file,
  589. const char __user *from,
  590. size_t count, loff_t *ppos)
  591. {
  592. struct cs35l56_base *cs35l56_base = file->private_data;
  593. ssize_t ret;
  594. PM_RUNTIME_ACQUIRE_IF_ENABLED_AUTOSUSPEND(cs35l56_base->dev, pm);
  595. ret = PM_RUNTIME_ACQUIRE_ERR(&pm);
  596. if (ret)
  597. return ret;
  598. return cs35l56_cal_ambient_debugfs_write(cs35l56_base, from, count, ppos);
  599. }
  600. static ssize_t cs35l56_hda_debugfs_cal_data_read(struct file *file,
  601. char __user *to,
  602. size_t count, loff_t *ppos)
  603. {
  604. struct cs35l56_base *cs35l56_base = file->private_data;
  605. ssize_t ret;
  606. PM_RUNTIME_ACQUIRE_IF_ENABLED_AUTOSUSPEND(cs35l56_base->dev, pm);
  607. ret = PM_RUNTIME_ACQUIRE_ERR(&pm);
  608. if (ret)
  609. return ret;
  610. return cs35l56_cal_data_debugfs_read(cs35l56_base, to, count, ppos);
  611. }
  612. static ssize_t cs35l56_hda_debugfs_cal_data_write(struct file *file,
  613. const char __user *from,
  614. size_t count, loff_t *ppos)
  615. {
  616. struct cs35l56_base *cs35l56_base = file->private_data;
  617. struct cs35l56_hda *cs35l56 = cs35l56_hda_from_base(cs35l56_base);
  618. ssize_t ret;
  619. ret = cs35l56_cal_data_debugfs_write(cs35l56_base, from, count, ppos);
  620. if (ret == -ENODATA)
  621. return count; /* Ignore writes of empty cal blobs */
  622. if (ret < 0)
  623. return ret;
  624. PM_RUNTIME_ACQUIRE_IF_ENABLED_AUTOSUSPEND(cs35l56_base->dev, pm);
  625. ret = PM_RUNTIME_ACQUIRE_ERR(&pm);
  626. if (ret)
  627. return ret;
  628. ret = cs35l56_hda_apply_calibration(cs35l56);
  629. if (ret == 0)
  630. cs35l56_mbox_send(cs35l56_base, CS35L56_MBOX_CMD_AUDIO_REINIT);
  631. else
  632. count = -EIO;
  633. return count;
  634. }
  635. static const struct cs35l56_cal_debugfs_fops cs35l56_hda_cal_debugfs_fops = {
  636. .calibrate = {
  637. .write = cs35l56_hda_debugfs_calibrate_write,
  638. },
  639. .cal_temperature = {
  640. .write = cs35l56_hda_debugfs_cal_temperature_write,
  641. },
  642. .cal_data = {
  643. .read = cs35l56_hda_debugfs_cal_data_read,
  644. .write = cs35l56_hda_debugfs_cal_data_write,
  645. },
  646. };
  647. static int cs35l56_hda_bind(struct device *dev, struct device *master, void *master_data)
  648. {
  649. struct cs35l56_hda *cs35l56 = dev_get_drvdata(dev);
  650. struct hda_component_parent *parent = master_data;
  651. struct hda_component *comp;
  652. comp = hda_component_from_index(parent, cs35l56->index);
  653. if (!comp)
  654. return -EINVAL;
  655. if (comp->dev)
  656. return -EBUSY;
  657. comp->dev = dev;
  658. cs35l56->codec = parent->codec;
  659. strscpy(comp->name, dev_name(dev), sizeof(comp->name));
  660. comp->playback_hook = cs35l56_hda_playback_hook;
  661. queue_work(system_long_wq, &cs35l56->dsp_work);
  662. cs35l56_hda_create_controls(cs35l56);
  663. #if IS_ENABLED(CONFIG_SND_DEBUG)
  664. cs35l56->debugfs_root = debugfs_create_dir(dev_name(cs35l56->base.dev), sound_debugfs_root);
  665. cs_dsp_init_debugfs(&cs35l56->cs_dsp, cs35l56->debugfs_root);
  666. #endif
  667. if (IS_ENABLED(CONFIG_SND_HDA_SCODEC_CS35L56_CAL_DEBUGFS))
  668. cs35l56_create_cal_debugfs(&cs35l56->base, &cs35l56_hda_cal_debugfs_fops);
  669. dev_dbg(cs35l56->base.dev, "Bound\n");
  670. return 0;
  671. }
  672. static void cs35l56_hda_unbind(struct device *dev, struct device *master, void *master_data)
  673. {
  674. struct cs35l56_hda *cs35l56 = dev_get_drvdata(dev);
  675. struct hda_component_parent *parent = master_data;
  676. struct hda_component *comp;
  677. cancel_work_sync(&cs35l56->dsp_work);
  678. cs35l56_remove_cal_debugfs(&cs35l56->base);
  679. cs35l56_hda_remove_controls(cs35l56);
  680. #if IS_ENABLED(CONFIG_SND_DEBUG)
  681. cs_dsp_cleanup_debugfs(&cs35l56->cs_dsp);
  682. debugfs_remove_recursive(cs35l56->debugfs_root);
  683. #endif
  684. if (cs35l56->base.fw_patched)
  685. cs_dsp_power_down(&cs35l56->cs_dsp);
  686. comp = hda_component_from_index(parent, cs35l56->index);
  687. if (comp && (comp->dev == dev))
  688. memset(comp, 0, sizeof(*comp));
  689. cs35l56->codec = NULL;
  690. dev_dbg(cs35l56->base.dev, "Unbound\n");
  691. }
  692. static const struct component_ops cs35l56_hda_comp_ops = {
  693. .bind = cs35l56_hda_bind,
  694. .unbind = cs35l56_hda_unbind,
  695. };
  696. static int cs35l56_hda_system_suspend(struct device *dev)
  697. {
  698. struct cs35l56_hda *cs35l56 = dev_get_drvdata(dev);
  699. cs35l56_hda_wait_dsp_ready(cs35l56);
  700. if (cs35l56->playing)
  701. cs35l56_hda_pause(cs35l56);
  702. cs35l56->suspended = true;
  703. /*
  704. * The interrupt line is normally shared, but after we start suspending
  705. * we can't check if our device is the source of an interrupt, and can't
  706. * clear it. Prevent this race by temporarily disabling the parent irq
  707. * until we reach _no_irq.
  708. */
  709. if (cs35l56->base.irq)
  710. disable_irq(cs35l56->base.irq);
  711. return pm_runtime_force_suspend(dev);
  712. }
  713. static int cs35l56_hda_system_suspend_late(struct device *dev)
  714. {
  715. struct cs35l56_hda *cs35l56 = dev_get_drvdata(dev);
  716. /*
  717. * RESET is usually shared by all amps so it must not be asserted until
  718. * all driver instances have done their suspend() stage.
  719. */
  720. if (cs35l56->base.reset_gpio) {
  721. gpiod_set_value_cansleep(cs35l56->base.reset_gpio, 0);
  722. cs35l56_wait_min_reset_pulse();
  723. }
  724. return 0;
  725. }
  726. static int cs35l56_hda_system_suspend_no_irq(struct device *dev)
  727. {
  728. struct cs35l56_hda *cs35l56 = dev_get_drvdata(dev);
  729. /* Handlers are now disabled so the parent IRQ can safely be re-enabled. */
  730. if (cs35l56->base.irq)
  731. enable_irq(cs35l56->base.irq);
  732. return 0;
  733. }
  734. static int cs35l56_hda_system_resume_no_irq(struct device *dev)
  735. {
  736. struct cs35l56_hda *cs35l56 = dev_get_drvdata(dev);
  737. /*
  738. * WAKE interrupts unmask if the CS35L56 hibernates, which can cause
  739. * spurious interrupts, and the interrupt line is normally shared.
  740. * We can't check if our device is the source of an interrupt, and can't
  741. * clear it, until it has fully resumed. Prevent this race by temporarily
  742. * disabling the parent irq until we complete resume().
  743. */
  744. if (cs35l56->base.irq)
  745. disable_irq(cs35l56->base.irq);
  746. return 0;
  747. }
  748. static int cs35l56_hda_system_resume_early(struct device *dev)
  749. {
  750. struct cs35l56_hda *cs35l56 = dev_get_drvdata(dev);
  751. /* Ensure a spec-compliant RESET pulse. */
  752. if (cs35l56->base.reset_gpio) {
  753. gpiod_set_value_cansleep(cs35l56->base.reset_gpio, 0);
  754. cs35l56_wait_min_reset_pulse();
  755. /* Release shared RESET before drivers start resume(). */
  756. gpiod_set_value_cansleep(cs35l56->base.reset_gpio, 1);
  757. cs35l56_wait_control_port_ready();
  758. }
  759. return 0;
  760. }
  761. static int cs35l56_hda_system_resume(struct device *dev)
  762. {
  763. struct cs35l56_hda *cs35l56 = dev_get_drvdata(dev);
  764. int ret;
  765. /* Undo pm_runtime_force_suspend() before re-enabling the irq */
  766. ret = pm_runtime_force_resume(dev);
  767. if (cs35l56->base.irq)
  768. enable_irq(cs35l56->base.irq);
  769. if (ret)
  770. return ret;
  771. cs35l56->suspended = false;
  772. if (!cs35l56->codec)
  773. return 0;
  774. ret = cs35l56_is_fw_reload_needed(&cs35l56->base);
  775. dev_dbg(cs35l56->base.dev, "fw_reload_needed: %d\n", ret);
  776. if (ret > 0)
  777. queue_work(system_long_wq, &cs35l56->dsp_work);
  778. if (cs35l56->playing)
  779. cs35l56_hda_play(cs35l56);
  780. return 0;
  781. }
  782. static int cs35l56_hda_fixup_yoga9(struct cs35l56_hda *cs35l56, int *bus_addr)
  783. {
  784. /* The cirrus,dev-index property has the wrong values */
  785. switch (*bus_addr) {
  786. case 0x30:
  787. cs35l56->index = 1;
  788. return 0;
  789. case 0x31:
  790. cs35l56->index = 0;
  791. return 0;
  792. default:
  793. /* There is a pseudo-address for broadcast to both amps - ignore it */
  794. dev_dbg(cs35l56->base.dev, "Ignoring I2C address %#x\n", *bus_addr);
  795. return 0;
  796. }
  797. }
  798. static const struct {
  799. const char *sub;
  800. int (*fixup_fn)(struct cs35l56_hda *cs35l56, int *bus_addr);
  801. } cs35l56_hda_fixups[] = {
  802. {
  803. .sub = "17AA390B", /* Lenovo Yoga Book 9i GenX */
  804. .fixup_fn = cs35l56_hda_fixup_yoga9,
  805. },
  806. };
  807. static int cs35l56_hda_apply_platform_fixups(struct cs35l56_hda *cs35l56, const char *sub,
  808. int *bus_addr)
  809. {
  810. int i;
  811. if (IS_ERR(sub))
  812. return 0;
  813. for (i = 0; i < ARRAY_SIZE(cs35l56_hda_fixups); i++) {
  814. if (strcasecmp(cs35l56_hda_fixups[i].sub, sub) == 0) {
  815. dev_dbg(cs35l56->base.dev, "Applying fixup for %s\n",
  816. cs35l56_hda_fixups[i].sub);
  817. return (cs35l56_hda_fixups[i].fixup_fn)(cs35l56, bus_addr);
  818. }
  819. }
  820. return 0;
  821. }
  822. static int cs35l56_hda_read_acpi(struct cs35l56_hda *cs35l56, int hid, int id)
  823. {
  824. u32 values[HDA_MAX_COMPONENTS];
  825. char hid_string[8];
  826. struct acpi_device *adev;
  827. const char *property, *sub;
  828. size_t nval;
  829. int i, ret;
  830. /*
  831. * ACPI_COMPANION isn't available when this driver was instantiated by
  832. * the serial-multi-instantiate driver, so lookup the node by HID
  833. */
  834. if (!ACPI_COMPANION(cs35l56->base.dev)) {
  835. snprintf(hid_string, sizeof(hid_string), "CSC%04X", hid);
  836. adev = acpi_dev_get_first_match_dev(hid_string, NULL, -1);
  837. if (!adev) {
  838. dev_err(cs35l56->base.dev, "Failed to find an ACPI device for %s\n",
  839. dev_name(cs35l56->base.dev));
  840. return -ENODEV;
  841. }
  842. ACPI_COMPANION_SET(cs35l56->base.dev, adev);
  843. }
  844. /* Initialize things that could be overwritten by a fixup */
  845. cs35l56->index = -1;
  846. sub = acpi_get_subsystem_id(ACPI_HANDLE(cs35l56->base.dev));
  847. ret = cs35l56_hda_apply_platform_fixups(cs35l56, sub, &id);
  848. if (ret)
  849. return ret;
  850. if (cs35l56->index == -1) {
  851. property = "cirrus,dev-index";
  852. ret = device_property_count_u32(cs35l56->base.dev, property);
  853. if (ret <= 0)
  854. goto err;
  855. if (ret > ARRAY_SIZE(values)) {
  856. ret = -EINVAL;
  857. goto err;
  858. }
  859. nval = ret;
  860. ret = device_property_read_u32_array(cs35l56->base.dev, property, values, nval);
  861. if (ret)
  862. goto err;
  863. for (i = 0; i < nval; i++) {
  864. if (values[i] == id) {
  865. cs35l56->index = i;
  866. break;
  867. }
  868. }
  869. /*
  870. * It's not an error for the ID to be missing: for I2C there can be
  871. * an alias address that is not a real device. So reject silently.
  872. */
  873. if (cs35l56->index == -1) {
  874. dev_dbg(cs35l56->base.dev, "No index found in %s\n", property);
  875. ret = -ENODEV;
  876. goto err;
  877. }
  878. }
  879. if (IS_ERR(sub)) {
  880. dev_info(cs35l56->base.dev,
  881. "Read ACPI _SUB failed(%ld): fallback to generic firmware\n",
  882. PTR_ERR(sub));
  883. } else {
  884. ret = cirrus_scodec_get_speaker_id(cs35l56->base.dev, cs35l56->index, nval, -1);
  885. if (ret == -ENOENT) {
  886. cs35l56->system_name = sub;
  887. } else if (ret >= 0) {
  888. cs35l56->system_name = kasprintf(GFP_KERNEL, "%s-spkid%d", sub, ret);
  889. kfree(sub);
  890. if (!cs35l56->system_name)
  891. return -ENOMEM;
  892. } else {
  893. return ret;
  894. }
  895. }
  896. cs35l56->base.reset_gpio = devm_gpiod_get_index_optional(cs35l56->base.dev,
  897. "reset",
  898. cs35l56->index,
  899. GPIOD_OUT_LOW);
  900. if (IS_ERR(cs35l56->base.reset_gpio)) {
  901. ret = PTR_ERR(cs35l56->base.reset_gpio);
  902. /*
  903. * If RESET is shared the first amp to probe will grab the reset
  904. * line and reset all the amps
  905. */
  906. if (ret != -EBUSY)
  907. return dev_err_probe(cs35l56->base.dev, ret, "Failed to get reset GPIO\n");
  908. dev_info(cs35l56->base.dev, "Reset GPIO busy, assume shared reset\n");
  909. cs35l56->base.reset_gpio = NULL;
  910. }
  911. return 0;
  912. err:
  913. if (ret != -ENODEV)
  914. dev_err(cs35l56->base.dev, "Failed property %s: %d\n", property, ret);
  915. return ret;
  916. }
  917. int cs35l56_hda_common_probe(struct cs35l56_hda *cs35l56, int hid, int id)
  918. {
  919. int ret;
  920. mutex_init(&cs35l56->base.irq_lock);
  921. dev_set_drvdata(cs35l56->base.dev, cs35l56);
  922. INIT_WORK(&cs35l56->dsp_work, cs35l56_hda_dsp_work);
  923. ret = cs35l56_hda_read_acpi(cs35l56, hid, id);
  924. if (ret)
  925. goto err;
  926. cs35l56->amp_name = devm_kasprintf(cs35l56->base.dev, GFP_KERNEL, "AMP%d",
  927. cs35l56->index + 1);
  928. if (!cs35l56->amp_name) {
  929. ret = -ENOMEM;
  930. goto err;
  931. }
  932. cs35l56->base.type = hid & 0xff;
  933. cs35l56->base.cal_index = cs35l56->index;
  934. cs35l56_init_cs_dsp(&cs35l56->base, &cs35l56->cs_dsp);
  935. if (cs35l56->base.reset_gpio) {
  936. dev_dbg(cs35l56->base.dev, "Hard reset\n");
  937. /*
  938. * The GPIOD_OUT_LOW to *_gpiod_get_*() will be ignored if the
  939. * ACPI defines a different default state. So explicitly set low.
  940. */
  941. gpiod_set_value_cansleep(cs35l56->base.reset_gpio, 0);
  942. cs35l56_wait_min_reset_pulse();
  943. gpiod_set_value_cansleep(cs35l56->base.reset_gpio, 1);
  944. }
  945. ret = cs35l56_hw_init(&cs35l56->base);
  946. if (ret < 0)
  947. goto err;
  948. /* Reset the device and wait for it to boot */
  949. cs35l56_system_reset(&cs35l56->base, false);
  950. ret = cs35l56_wait_for_firmware_boot(&cs35l56->base);
  951. if (ret)
  952. goto err;
  953. regcache_cache_only(cs35l56->base.regmap, false);
  954. ret = cs35l56_set_patch(&cs35l56->base);
  955. if (ret)
  956. goto err;
  957. regcache_mark_dirty(cs35l56->base.regmap);
  958. regcache_sync(cs35l56->base.regmap);
  959. /* Disable auto-hibernate so that runtime_pm has control */
  960. ret = cs35l56_mbox_send(&cs35l56->base, CS35L56_MBOX_CMD_PREVENT_AUTO_HIBERNATE);
  961. if (ret)
  962. goto err;
  963. ret = cs35l56_get_calibration(&cs35l56->base);
  964. if (ret)
  965. goto err;
  966. ret = cs_dsp_halo_init(&cs35l56->cs_dsp);
  967. if (ret) {
  968. dev_err_probe(cs35l56->base.dev, ret, "cs_dsp_halo_init failed\n");
  969. goto err;
  970. }
  971. dev_info(cs35l56->base.dev, "DSP system name: '%s', amp name: '%s'\n",
  972. cs35l56->system_name, cs35l56->amp_name);
  973. regmap_multi_reg_write(cs35l56->base.regmap, cs35l56_hda_dai_config,
  974. ARRAY_SIZE(cs35l56_hda_dai_config));
  975. /*
  976. * By default only enable one ASP1TXn, where n=amplifier index,
  977. * This prevents multiple amps trying to drive the same slot.
  978. */
  979. cs35l56->asp_tx_mask = BIT(cs35l56->index);
  980. pm_runtime_set_autosuspend_delay(cs35l56->base.dev, 3000);
  981. pm_runtime_use_autosuspend(cs35l56->base.dev);
  982. pm_runtime_set_active(cs35l56->base.dev);
  983. pm_runtime_mark_last_busy(cs35l56->base.dev);
  984. pm_runtime_enable(cs35l56->base.dev);
  985. cs35l56->base.init_done = true;
  986. ret = component_add(cs35l56->base.dev, &cs35l56_hda_comp_ops);
  987. if (ret) {
  988. dev_err(cs35l56->base.dev, "Register component failed: %d\n", ret);
  989. goto pm_err;
  990. }
  991. return 0;
  992. pm_err:
  993. pm_runtime_disable(cs35l56->base.dev);
  994. cs_dsp_remove(&cs35l56->cs_dsp);
  995. err:
  996. gpiod_set_value_cansleep(cs35l56->base.reset_gpio, 0);
  997. return ret;
  998. }
  999. EXPORT_SYMBOL_NS_GPL(cs35l56_hda_common_probe, "SND_HDA_SCODEC_CS35L56");
  1000. void cs35l56_hda_remove(struct device *dev)
  1001. {
  1002. struct cs35l56_hda *cs35l56 = dev_get_drvdata(dev);
  1003. component_del(cs35l56->base.dev, &cs35l56_hda_comp_ops);
  1004. pm_runtime_dont_use_autosuspend(cs35l56->base.dev);
  1005. pm_runtime_get_sync(cs35l56->base.dev);
  1006. pm_runtime_disable(cs35l56->base.dev);
  1007. cs_dsp_remove(&cs35l56->cs_dsp);
  1008. kfree(cs35l56->system_name);
  1009. pm_runtime_put_noidle(cs35l56->base.dev);
  1010. gpiod_set_value_cansleep(cs35l56->base.reset_gpio, 0);
  1011. }
  1012. EXPORT_SYMBOL_NS_GPL(cs35l56_hda_remove, "SND_HDA_SCODEC_CS35L56");
  1013. const struct dev_pm_ops cs35l56_hda_pm_ops = {
  1014. RUNTIME_PM_OPS(cs35l56_hda_runtime_suspend, cs35l56_hda_runtime_resume, NULL)
  1015. SYSTEM_SLEEP_PM_OPS(cs35l56_hda_system_suspend, cs35l56_hda_system_resume)
  1016. LATE_SYSTEM_SLEEP_PM_OPS(cs35l56_hda_system_suspend_late,
  1017. cs35l56_hda_system_resume_early)
  1018. NOIRQ_SYSTEM_SLEEP_PM_OPS(cs35l56_hda_system_suspend_no_irq,
  1019. cs35l56_hda_system_resume_no_irq)
  1020. };
  1021. EXPORT_SYMBOL_NS_GPL(cs35l56_hda_pm_ops, "SND_HDA_SCODEC_CS35L56");
  1022. MODULE_DESCRIPTION("CS35L56 HDA Driver");
  1023. MODULE_IMPORT_NS("FW_CS_DSP");
  1024. MODULE_IMPORT_NS("SND_HDA_CIRRUS_SCODEC");
  1025. MODULE_IMPORT_NS("SND_SOC_CS35L56_SHARED");
  1026. MODULE_IMPORT_NS("SND_SOC_CS_AMP_LIB");
  1027. MODULE_AUTHOR("Richard Fitzgerald <rf@opensource.cirrus.com>");
  1028. MODULE_AUTHOR("Simon Trimmer <simont@opensource.cirrus.com>");
  1029. MODULE_LICENSE("GPL");
  1030. MODULE_FIRMWARE("cirrus/cs35l54-*.wmfw");
  1031. MODULE_FIRMWARE("cirrus/cs35l54-*.bin");
  1032. MODULE_FIRMWARE("cirrus/cs35l56-*.wmfw");
  1033. MODULE_FIRMWARE("cirrus/cs35l56-*.bin");