mt8186-afe-pcm.c 92 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999
  1. // SPDX-License-Identifier: GPL-2.0
  2. //
  3. // Mediatek ALSA SoC AFE platform driver for 8186
  4. //
  5. // Copyright (c) 2022 MediaTek Inc.
  6. // Author: Jiaxin Yu <[email protected]>
  7. #include <linux/delay.h>
  8. #include <linux/dma-mapping.h>
  9. #include <linux/module.h>
  10. #include <linux/of.h>
  11. #include <linux/of_address.h>
  12. #include <linux/pm_runtime.h>
  13. #include <linux/reset.h>
  14. #include <sound/soc.h>
  15. #include "../common/mtk-afe-platform-driver.h"
  16. #include "../common/mtk-afe-fe-dai.h"
  17. #include "mt8186-afe-common.h"
  18. #include "mt8186-afe-clk.h"
  19. #include "mt8186-afe-gpio.h"
  20. #include "mt8186-interconnection.h"
  21. static const struct snd_pcm_hardware mt8186_afe_hardware = {
  22. .info = (SNDRV_PCM_INFO_MMAP |
  23. SNDRV_PCM_INFO_INTERLEAVED |
  24. SNDRV_PCM_INFO_MMAP_VALID),
  25. .formats = (SNDRV_PCM_FMTBIT_S16_LE |
  26. SNDRV_PCM_FMTBIT_S24_LE |
  27. SNDRV_PCM_FMTBIT_S32_LE),
  28. .period_bytes_min = 96,
  29. .period_bytes_max = 4 * 48 * 1024,
  30. .periods_min = 2,
  31. .periods_max = 256,
  32. .buffer_bytes_max = 4 * 48 * 1024,
  33. .fifo_size = 0,
  34. };
  35. static int mt8186_fe_startup(struct snd_pcm_substream *substream,
  36. struct snd_soc_dai *dai)
  37. {
  38. struct snd_soc_pcm_runtime *rtd = substream->private_data;
  39. struct mtk_base_afe *afe = snd_soc_dai_get_drvdata(dai);
  40. struct snd_pcm_runtime *runtime = substream->runtime;
  41. int id = asoc_rtd_to_cpu(rtd, 0)->id;
  42. struct mtk_base_afe_memif *memif = &afe->memif[id];
  43. const struct snd_pcm_hardware *mtk_afe_hardware = afe->mtk_afe_hardware;
  44. int ret;
  45. memif->substream = substream;
  46. snd_pcm_hw_constraint_step(substream->runtime, 0,
  47. SNDRV_PCM_HW_PARAM_BUFFER_BYTES, 16);
  48. snd_soc_set_runtime_hwparams(substream, mtk_afe_hardware);
  49. ret = snd_pcm_hw_constraint_integer(runtime,
  50. SNDRV_PCM_HW_PARAM_PERIODS);
  51. if (ret < 0) {
  52. dev_err(afe->dev, "snd_pcm_hw_constraint_integer failed\n");
  53. return ret;
  54. }
  55. /* dynamic allocate irq to memif */
  56. if (memif->irq_usage < 0) {
  57. int irq_id = mtk_dynamic_irq_acquire(afe);
  58. if (irq_id != afe->irqs_size) {
  59. /* link */
  60. memif->irq_usage = irq_id;
  61. } else {
  62. dev_err(afe->dev, "%s() error: no more asys irq\n",
  63. __func__);
  64. return -EBUSY;
  65. }
  66. }
  67. return 0;
  68. }
  69. static void mt8186_fe_shutdown(struct snd_pcm_substream *substream,
  70. struct snd_soc_dai *dai)
  71. {
  72. struct snd_soc_pcm_runtime *rtd = substream->private_data;
  73. struct mtk_base_afe *afe = snd_soc_dai_get_drvdata(dai);
  74. struct mt8186_afe_private *afe_priv = afe->platform_priv;
  75. int id = asoc_rtd_to_cpu(rtd, 0)->id;
  76. struct mtk_base_afe_memif *memif = &afe->memif[id];
  77. int irq_id = memif->irq_usage;
  78. memif->substream = NULL;
  79. afe_priv->irq_cnt[id] = 0;
  80. afe_priv->xrun_assert[id] = 0;
  81. if (!memif->const_irq) {
  82. mtk_dynamic_irq_release(afe, irq_id);
  83. memif->irq_usage = -1;
  84. memif->substream = NULL;
  85. }
  86. }
  87. static int mt8186_fe_hw_params(struct snd_pcm_substream *substream,
  88. struct snd_pcm_hw_params *params,
  89. struct snd_soc_dai *dai)
  90. {
  91. struct snd_soc_pcm_runtime *rtd = substream->private_data;
  92. struct mtk_base_afe *afe = snd_soc_dai_get_drvdata(dai);
  93. int id = asoc_rtd_to_cpu(rtd, 0)->id;
  94. unsigned int channels = params_channels(params);
  95. unsigned int rate = params_rate(params);
  96. int ret;
  97. ret = mtk_afe_fe_hw_params(substream, params, dai);
  98. if (ret)
  99. return ret;
  100. /* channel merge configuration, enable control is in UL5_IN_MUX */
  101. if (id == MT8186_MEMIF_VUL3) {
  102. int update_cnt = 8;
  103. unsigned int val = 0;
  104. unsigned int mask = 0;
  105. int fs_mode = mt8186_rate_transform(afe->dev, rate, id);
  106. /* set rate, channel, update cnt, disable sgen */
  107. val = fs_mode << CM1_FS_SELECT_SFT |
  108. (channels - 1) << CHANNEL_MERGE0_CHNUM_SFT |
  109. update_cnt << CHANNEL_MERGE0_UPDATE_CNT_SFT;
  110. mask = CM1_FS_SELECT_MASK_SFT |
  111. CHANNEL_MERGE0_CHNUM_MASK_SFT |
  112. CHANNEL_MERGE0_UPDATE_CNT_MASK_SFT;
  113. regmap_update_bits(afe->regmap, AFE_CM1_CON, mask, val);
  114. }
  115. return 0;
  116. }
  117. static int mt8186_fe_hw_free(struct snd_pcm_substream *substream,
  118. struct snd_soc_dai *dai)
  119. {
  120. struct mtk_base_afe *afe = snd_soc_dai_get_drvdata(dai);
  121. int ret;
  122. ret = mtk_afe_fe_hw_free(substream, dai);
  123. if (ret) {
  124. dev_err(afe->dev, "%s failed\n", __func__);
  125. return ret;
  126. }
  127. return 0;
  128. }
  129. static int mt8186_fe_trigger(struct snd_pcm_substream *substream, int cmd,
  130. struct snd_soc_dai *dai)
  131. {
  132. struct snd_soc_pcm_runtime *rtd = substream->private_data;
  133. struct snd_pcm_runtime * const runtime = substream->runtime;
  134. struct mtk_base_afe *afe = snd_soc_dai_get_drvdata(dai);
  135. struct mt8186_afe_private *afe_priv = afe->platform_priv;
  136. int id = asoc_rtd_to_cpu(rtd, 0)->id;
  137. struct mtk_base_afe_memif *memif = &afe->memif[id];
  138. int irq_id = memif->irq_usage;
  139. struct mtk_base_afe_irq *irqs = &afe->irqs[irq_id];
  140. const struct mtk_base_irq_data *irq_data = irqs->irq_data;
  141. unsigned int rate = runtime->rate;
  142. unsigned int counter;
  143. int fs;
  144. int ret;
  145. dev_dbg(afe->dev, "%s(), %s cmd %d, irq_id %d\n",
  146. __func__, memif->data->name, cmd, irq_id);
  147. switch (cmd) {
  148. case SNDRV_PCM_TRIGGER_START:
  149. case SNDRV_PCM_TRIGGER_RESUME:
  150. ret = mtk_memif_set_enable(afe, id);
  151. if (ret) {
  152. dev_err(afe->dev, "%s(), error, id %d, memif enable, ret %d\n",
  153. __func__, id, ret);
  154. return ret;
  155. }
  156. /*
  157. * for small latency record
  158. * ul memif need read some data before irq enable
  159. */
  160. if (substream->stream == SNDRV_PCM_STREAM_CAPTURE &&
  161. ((runtime->period_size * 1000) / rate <= 10))
  162. udelay(300);
  163. /* set irq counter */
  164. if (afe_priv->irq_cnt[id] > 0)
  165. counter = afe_priv->irq_cnt[id];
  166. else
  167. counter = runtime->period_size;
  168. regmap_update_bits(afe->regmap, irq_data->irq_cnt_reg,
  169. irq_data->irq_cnt_maskbit
  170. << irq_data->irq_cnt_shift,
  171. counter << irq_data->irq_cnt_shift);
  172. /* set irq fs */
  173. fs = afe->irq_fs(substream, runtime->rate);
  174. if (fs < 0)
  175. return -EINVAL;
  176. regmap_update_bits(afe->regmap, irq_data->irq_fs_reg,
  177. irq_data->irq_fs_maskbit
  178. << irq_data->irq_fs_shift,
  179. fs << irq_data->irq_fs_shift);
  180. /* enable interrupt */
  181. if (runtime->stop_threshold != ~(0U))
  182. regmap_update_bits(afe->regmap,
  183. irq_data->irq_en_reg,
  184. 1 << irq_data->irq_en_shift,
  185. 1 << irq_data->irq_en_shift);
  186. return 0;
  187. case SNDRV_PCM_TRIGGER_STOP:
  188. case SNDRV_PCM_TRIGGER_SUSPEND:
  189. if (afe_priv->xrun_assert[id] > 0) {
  190. if (substream->stream == SNDRV_PCM_STREAM_CAPTURE) {
  191. int avail = snd_pcm_capture_avail(runtime);
  192. /* alsa can trigger stop/start when occur xrun */
  193. if (avail >= runtime->buffer_size)
  194. dev_dbg(afe->dev, "%s(), id %d, xrun assert\n",
  195. __func__, id);
  196. }
  197. }
  198. ret = mtk_memif_set_disable(afe, id);
  199. if (ret)
  200. dev_err(afe->dev, "%s(), error, id %d, memif enable, ret %d\n",
  201. __func__, id, ret);
  202. /* disable interrupt */
  203. if (runtime->stop_threshold != ~(0U))
  204. regmap_update_bits(afe->regmap,
  205. irq_data->irq_en_reg,
  206. 1 << irq_data->irq_en_shift,
  207. 0 << irq_data->irq_en_shift);
  208. /* clear pending IRQ */
  209. regmap_write(afe->regmap, irq_data->irq_clr_reg,
  210. 1 << irq_data->irq_clr_shift);
  211. return ret;
  212. default:
  213. return -EINVAL;
  214. }
  215. }
  216. static int mt8186_memif_fs(struct snd_pcm_substream *substream,
  217. unsigned int rate)
  218. {
  219. struct snd_soc_pcm_runtime *rtd = substream->private_data;
  220. struct snd_soc_component *component =
  221. snd_soc_rtdcom_lookup(rtd, AFE_PCM_NAME);
  222. struct mtk_base_afe *afe = snd_soc_component_get_drvdata(component);
  223. int id = asoc_rtd_to_cpu(rtd, 0)->id;
  224. return mt8186_rate_transform(afe->dev, rate, id);
  225. }
  226. static int mt8186_get_dai_fs(struct mtk_base_afe *afe,
  227. int dai_id, unsigned int rate)
  228. {
  229. return mt8186_rate_transform(afe->dev, rate, dai_id);
  230. }
  231. static int mt8186_irq_fs(struct snd_pcm_substream *substream, unsigned int rate)
  232. {
  233. struct snd_soc_pcm_runtime *rtd = substream->private_data;
  234. struct snd_soc_component *component =
  235. snd_soc_rtdcom_lookup(rtd, AFE_PCM_NAME);
  236. struct mtk_base_afe *afe = snd_soc_component_get_drvdata(component);
  237. return mt8186_general_rate_transform(afe->dev, rate);
  238. }
  239. static int mt8186_get_memif_pbuf_size(struct snd_pcm_substream *substream)
  240. {
  241. struct snd_pcm_runtime *runtime = substream->runtime;
  242. if ((runtime->period_size * 1000) / runtime->rate > 10)
  243. return MT8186_MEMIF_PBUF_SIZE_256_BYTES;
  244. return MT8186_MEMIF_PBUF_SIZE_32_BYTES;
  245. }
  246. static int mt8186_fe_prepare(struct snd_pcm_substream *substream,
  247. struct snd_soc_dai *dai)
  248. {
  249. struct snd_soc_pcm_runtime *rtd = substream->private_data;
  250. struct snd_pcm_runtime * const runtime = substream->runtime;
  251. struct mtk_base_afe *afe = snd_soc_dai_get_drvdata(dai);
  252. int id = asoc_rtd_to_cpu(rtd, 0)->id;
  253. struct mtk_base_afe_memif *memif = &afe->memif[id];
  254. int irq_id = memif->irq_usage;
  255. struct mtk_base_afe_irq *irqs = &afe->irqs[irq_id];
  256. const struct mtk_base_irq_data *irq_data = irqs->irq_data;
  257. unsigned int counter = runtime->period_size;
  258. int fs;
  259. int ret;
  260. ret = mtk_afe_fe_prepare(substream, dai);
  261. if (ret)
  262. return ret;
  263. /* set irq counter */
  264. regmap_update_bits(afe->regmap, irq_data->irq_cnt_reg,
  265. irq_data->irq_cnt_maskbit
  266. << irq_data->irq_cnt_shift,
  267. counter << irq_data->irq_cnt_shift);
  268. /* set irq fs */
  269. fs = afe->irq_fs(substream, runtime->rate);
  270. if (fs < 0)
  271. return -EINVAL;
  272. regmap_update_bits(afe->regmap, irq_data->irq_fs_reg,
  273. irq_data->irq_fs_maskbit
  274. << irq_data->irq_fs_shift,
  275. fs << irq_data->irq_fs_shift);
  276. return 0;
  277. }
  278. /* FE DAIs */
  279. static const struct snd_soc_dai_ops mt8186_memif_dai_ops = {
  280. .startup = mt8186_fe_startup,
  281. .shutdown = mt8186_fe_shutdown,
  282. .hw_params = mt8186_fe_hw_params,
  283. .hw_free = mt8186_fe_hw_free,
  284. .prepare = mt8186_fe_prepare,
  285. .trigger = mt8186_fe_trigger,
  286. };
  287. #define MTK_PCM_RATES (SNDRV_PCM_RATE_8000_48000 |\
  288. SNDRV_PCM_RATE_88200 |\
  289. SNDRV_PCM_RATE_96000 |\
  290. SNDRV_PCM_RATE_176400 |\
  291. SNDRV_PCM_RATE_192000)
  292. #define MTK_PCM_DAI_RATES (SNDRV_PCM_RATE_8000 |\
  293. SNDRV_PCM_RATE_16000 |\
  294. SNDRV_PCM_RATE_32000 |\
  295. SNDRV_PCM_RATE_48000)
  296. #define MTK_PCM_FORMATS (SNDRV_PCM_FMTBIT_S16_LE |\
  297. SNDRV_PCM_FMTBIT_S24_LE |\
  298. SNDRV_PCM_FMTBIT_S32_LE)
  299. static struct snd_soc_dai_driver mt8186_memif_dai_driver[] = {
  300. /* FE DAIs: memory intefaces to CPU */
  301. {
  302. .name = "DL1",
  303. .id = MT8186_MEMIF_DL1,
  304. .playback = {
  305. .stream_name = "DL1",
  306. .channels_min = 1,
  307. .channels_max = 2,
  308. .rates = MTK_PCM_RATES,
  309. .formats = MTK_PCM_FORMATS,
  310. },
  311. .ops = &mt8186_memif_dai_ops,
  312. },
  313. {
  314. .name = "DL12",
  315. .id = MT8186_MEMIF_DL12,
  316. .playback = {
  317. .stream_name = "DL12",
  318. .channels_min = 1,
  319. .channels_max = 4,
  320. .rates = MTK_PCM_RATES,
  321. .formats = MTK_PCM_FORMATS,
  322. },
  323. .ops = &mt8186_memif_dai_ops,
  324. },
  325. {
  326. .name = "DL2",
  327. .id = MT8186_MEMIF_DL2,
  328. .playback = {
  329. .stream_name = "DL2",
  330. .channels_min = 1,
  331. .channels_max = 2,
  332. .rates = MTK_PCM_RATES,
  333. .formats = MTK_PCM_FORMATS,
  334. },
  335. .ops = &mt8186_memif_dai_ops,
  336. },
  337. {
  338. .name = "DL3",
  339. .id = MT8186_MEMIF_DL3,
  340. .playback = {
  341. .stream_name = "DL3",
  342. .channels_min = 1,
  343. .channels_max = 2,
  344. .rates = MTK_PCM_RATES,
  345. .formats = MTK_PCM_FORMATS,
  346. },
  347. .ops = &mt8186_memif_dai_ops,
  348. },
  349. {
  350. .name = "DL4",
  351. .id = MT8186_MEMIF_DL4,
  352. .playback = {
  353. .stream_name = "DL4",
  354. .channels_min = 1,
  355. .channels_max = 2,
  356. .rates = MTK_PCM_RATES,
  357. .formats = MTK_PCM_FORMATS,
  358. },
  359. .ops = &mt8186_memif_dai_ops,
  360. },
  361. {
  362. .name = "DL5",
  363. .id = MT8186_MEMIF_DL5,
  364. .playback = {
  365. .stream_name = "DL5",
  366. .channels_min = 1,
  367. .channels_max = 2,
  368. .rates = MTK_PCM_RATES,
  369. .formats = MTK_PCM_FORMATS,
  370. },
  371. .ops = &mt8186_memif_dai_ops,
  372. },
  373. {
  374. .name = "DL6",
  375. .id = MT8186_MEMIF_DL6,
  376. .playback = {
  377. .stream_name = "DL6",
  378. .channels_min = 1,
  379. .channels_max = 2,
  380. .rates = MTK_PCM_RATES,
  381. .formats = MTK_PCM_FORMATS,
  382. },
  383. .ops = &mt8186_memif_dai_ops,
  384. },
  385. {
  386. .name = "DL7",
  387. .id = MT8186_MEMIF_DL7,
  388. .playback = {
  389. .stream_name = "DL7",
  390. .channels_min = 1,
  391. .channels_max = 2,
  392. .rates = MTK_PCM_RATES,
  393. .formats = MTK_PCM_FORMATS,
  394. },
  395. .ops = &mt8186_memif_dai_ops,
  396. },
  397. {
  398. .name = "DL8",
  399. .id = MT8186_MEMIF_DL8,
  400. .playback = {
  401. .stream_name = "DL8",
  402. .channels_min = 1,
  403. .channels_max = 2,
  404. .rates = MTK_PCM_RATES,
  405. .formats = MTK_PCM_FORMATS,
  406. },
  407. .ops = &mt8186_memif_dai_ops,
  408. },
  409. {
  410. .name = "UL1",
  411. .id = MT8186_MEMIF_VUL12,
  412. .capture = {
  413. .stream_name = "UL1",
  414. .channels_min = 1,
  415. .channels_max = 4,
  416. .rates = MTK_PCM_RATES,
  417. .formats = MTK_PCM_FORMATS,
  418. },
  419. .ops = &mt8186_memif_dai_ops,
  420. },
  421. {
  422. .name = "UL2",
  423. .id = MT8186_MEMIF_AWB,
  424. .capture = {
  425. .stream_name = "UL2",
  426. .channels_min = 1,
  427. .channels_max = 2,
  428. .rates = MTK_PCM_RATES,
  429. .formats = MTK_PCM_FORMATS,
  430. },
  431. .ops = &mt8186_memif_dai_ops,
  432. },
  433. {
  434. .name = "UL3",
  435. .id = MT8186_MEMIF_VUL2,
  436. .capture = {
  437. .stream_name = "UL3",
  438. .channels_min = 1,
  439. .channels_max = 2,
  440. .rates = MTK_PCM_RATES,
  441. .formats = MTK_PCM_FORMATS,
  442. },
  443. .ops = &mt8186_memif_dai_ops,
  444. },
  445. {
  446. .name = "UL4",
  447. .id = MT8186_MEMIF_AWB2,
  448. .capture = {
  449. .stream_name = "UL4",
  450. .channels_min = 1,
  451. .channels_max = 2,
  452. .rates = MTK_PCM_RATES,
  453. .formats = MTK_PCM_FORMATS,
  454. },
  455. .ops = &mt8186_memif_dai_ops,
  456. },
  457. {
  458. .name = "UL5",
  459. .id = MT8186_MEMIF_VUL3,
  460. .capture = {
  461. .stream_name = "UL5",
  462. .channels_min = 1,
  463. .channels_max = 12,
  464. .rates = MTK_PCM_RATES,
  465. .formats = MTK_PCM_FORMATS,
  466. },
  467. .ops = &mt8186_memif_dai_ops,
  468. },
  469. {
  470. .name = "UL6",
  471. .id = MT8186_MEMIF_VUL4,
  472. .capture = {
  473. .stream_name = "UL6",
  474. .channels_min = 1,
  475. .channels_max = 2,
  476. .rates = MTK_PCM_RATES,
  477. .formats = MTK_PCM_FORMATS,
  478. },
  479. .ops = &mt8186_memif_dai_ops,
  480. },
  481. {
  482. .name = "UL7",
  483. .id = MT8186_MEMIF_VUL5,
  484. .capture = {
  485. .stream_name = "UL7",
  486. .channels_min = 1,
  487. .channels_max = 2,
  488. .rates = MTK_PCM_RATES,
  489. .formats = MTK_PCM_FORMATS,
  490. },
  491. .ops = &mt8186_memif_dai_ops,
  492. },
  493. {
  494. .name = "UL8",
  495. .id = MT8186_MEMIF_VUL6,
  496. .capture = {
  497. .stream_name = "UL8",
  498. .channels_min = 1,
  499. .channels_max = 2,
  500. .rates = MTK_PCM_RATES,
  501. .formats = MTK_PCM_FORMATS,
  502. },
  503. .ops = &mt8186_memif_dai_ops,
  504. }
  505. };
  506. /* kcontrol */
  507. static int mt8186_irq_cnt1_get(struct snd_kcontrol *kcontrol,
  508. struct snd_ctl_elem_value *ucontrol)
  509. {
  510. struct snd_soc_component *cmpnt = snd_soc_kcontrol_component(kcontrol);
  511. struct mtk_base_afe *afe = snd_soc_component_get_drvdata(cmpnt);
  512. struct mt8186_afe_private *afe_priv = afe->platform_priv;
  513. ucontrol->value.integer.value[0] =
  514. afe_priv->irq_cnt[MT8186_PRIMARY_MEMIF];
  515. return 0;
  516. }
  517. static int mt8186_irq_cnt1_set(struct snd_kcontrol *kcontrol,
  518. struct snd_ctl_elem_value *ucontrol)
  519. {
  520. struct snd_soc_component *cmpnt = snd_soc_kcontrol_component(kcontrol);
  521. struct mtk_base_afe *afe = snd_soc_component_get_drvdata(cmpnt);
  522. struct mt8186_afe_private *afe_priv = afe->platform_priv;
  523. int memif_num = MT8186_PRIMARY_MEMIF;
  524. struct mtk_base_afe_memif *memif = &afe->memif[memif_num];
  525. int irq_id = memif->irq_usage;
  526. int irq_cnt = afe_priv->irq_cnt[memif_num];
  527. dev_dbg(afe->dev, "%s(), irq_id %d, irq_cnt = %d, value = %ld\n",
  528. __func__, irq_id, irq_cnt, ucontrol->value.integer.value[0]);
  529. if (irq_cnt == ucontrol->value.integer.value[0])
  530. return 0;
  531. irq_cnt = ucontrol->value.integer.value[0];
  532. afe_priv->irq_cnt[memif_num] = irq_cnt;
  533. if (!pm_runtime_status_suspended(afe->dev) && irq_id >= 0) {
  534. struct mtk_base_afe_irq *irqs = &afe->irqs[irq_id];
  535. const struct mtk_base_irq_data *irq_data = irqs->irq_data;
  536. regmap_update_bits(afe->regmap, irq_data->irq_cnt_reg,
  537. irq_data->irq_cnt_maskbit
  538. << irq_data->irq_cnt_shift,
  539. irq_cnt << irq_data->irq_cnt_shift);
  540. } else {
  541. dev_dbg(afe->dev, "%s(), suspended || irq_id %d, not set\n",
  542. __func__, irq_id);
  543. }
  544. return 1;
  545. }
  546. static int mt8186_irq_cnt2_get(struct snd_kcontrol *kcontrol,
  547. struct snd_ctl_elem_value *ucontrol)
  548. {
  549. struct snd_soc_component *cmpnt = snd_soc_kcontrol_component(kcontrol);
  550. struct mtk_base_afe *afe = snd_soc_component_get_drvdata(cmpnt);
  551. struct mt8186_afe_private *afe_priv = afe->platform_priv;
  552. ucontrol->value.integer.value[0] =
  553. afe_priv->irq_cnt[MT8186_RECORD_MEMIF];
  554. return 0;
  555. }
  556. static int mt8186_irq_cnt2_set(struct snd_kcontrol *kcontrol,
  557. struct snd_ctl_elem_value *ucontrol)
  558. {
  559. struct snd_soc_component *cmpnt = snd_soc_kcontrol_component(kcontrol);
  560. struct mtk_base_afe *afe = snd_soc_component_get_drvdata(cmpnt);
  561. struct mt8186_afe_private *afe_priv = afe->platform_priv;
  562. int memif_num = MT8186_RECORD_MEMIF;
  563. struct mtk_base_afe_memif *memif = &afe->memif[memif_num];
  564. int irq_id = memif->irq_usage;
  565. int irq_cnt = afe_priv->irq_cnt[memif_num];
  566. dev_dbg(afe->dev, "%s(), irq_id %d, irq_cnt = %d, value = %ld\n",
  567. __func__, irq_id, irq_cnt, ucontrol->value.integer.value[0]);
  568. if (irq_cnt == ucontrol->value.integer.value[0])
  569. return 0;
  570. irq_cnt = ucontrol->value.integer.value[0];
  571. afe_priv->irq_cnt[memif_num] = irq_cnt;
  572. if (!pm_runtime_status_suspended(afe->dev) && irq_id >= 0) {
  573. struct mtk_base_afe_irq *irqs = &afe->irqs[irq_id];
  574. const struct mtk_base_irq_data *irq_data = irqs->irq_data;
  575. regmap_update_bits(afe->regmap, irq_data->irq_cnt_reg,
  576. irq_data->irq_cnt_maskbit
  577. << irq_data->irq_cnt_shift,
  578. irq_cnt << irq_data->irq_cnt_shift);
  579. } else {
  580. dev_dbg(afe->dev, "%s(), suspended || irq_id %d, not set\n",
  581. __func__, irq_id);
  582. }
  583. return 1;
  584. }
  585. static int mt8186_record_xrun_assert_get(struct snd_kcontrol *kcontrol,
  586. struct snd_ctl_elem_value *ucontrol)
  587. {
  588. struct snd_soc_component *cmpnt = snd_soc_kcontrol_component(kcontrol);
  589. struct mtk_base_afe *afe = snd_soc_component_get_drvdata(cmpnt);
  590. struct mt8186_afe_private *afe_priv = afe->platform_priv;
  591. int xrun_assert = afe_priv->xrun_assert[MT8186_RECORD_MEMIF];
  592. ucontrol->value.integer.value[0] = xrun_assert;
  593. return 0;
  594. }
  595. static int mt8186_record_xrun_assert_set(struct snd_kcontrol *kcontrol,
  596. struct snd_ctl_elem_value *ucontrol)
  597. {
  598. struct snd_soc_component *cmpnt = snd_soc_kcontrol_component(kcontrol);
  599. struct mtk_base_afe *afe = snd_soc_component_get_drvdata(cmpnt);
  600. struct mt8186_afe_private *afe_priv = afe->platform_priv;
  601. int xrun_assert = ucontrol->value.integer.value[0];
  602. dev_dbg(afe->dev, "%s(), xrun_assert %d\n", __func__, xrun_assert);
  603. if (xrun_assert == afe_priv->xrun_assert[MT8186_RECORD_MEMIF])
  604. return 0;
  605. afe_priv->xrun_assert[MT8186_RECORD_MEMIF] = xrun_assert;
  606. return 1;
  607. }
  608. static const struct snd_kcontrol_new mt8186_pcm_kcontrols[] = {
  609. SOC_SINGLE_EXT("Audio IRQ1 CNT", SND_SOC_NOPM, 0, 0x3ffff, 0,
  610. mt8186_irq_cnt1_get, mt8186_irq_cnt1_set),
  611. SOC_SINGLE_EXT("Audio IRQ2 CNT", SND_SOC_NOPM, 0, 0x3ffff, 0,
  612. mt8186_irq_cnt2_get, mt8186_irq_cnt2_set),
  613. SOC_SINGLE_EXT("record_xrun_assert", SND_SOC_NOPM, 0, 0x1, 0,
  614. mt8186_record_xrun_assert_get,
  615. mt8186_record_xrun_assert_set),
  616. };
  617. /* dma widget & routes*/
  618. static const struct snd_kcontrol_new memif_ul1_ch1_mix[] = {
  619. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH1 Switch", AFE_CONN21,
  620. I_ADDA_UL_CH1, 1, 0),
  621. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH2 Switch", AFE_CONN21,
  622. I_ADDA_UL_CH2, 1, 0),
  623. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH3 Switch", AFE_CONN21,
  624. I_ADDA_UL_CH3, 1, 0),
  625. SOC_DAPM_SINGLE_AUTODISABLE("TDM_IN_CH1 Switch", AFE_CONN21_1,
  626. I_TDM_IN_CH1, 1, 0),
  627. };
  628. static const struct snd_kcontrol_new memif_ul1_ch2_mix[] = {
  629. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH1 Switch", AFE_CONN22,
  630. I_ADDA_UL_CH1, 1, 0),
  631. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH2 Switch", AFE_CONN22,
  632. I_ADDA_UL_CH2, 1, 0),
  633. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH3 Switch", AFE_CONN22,
  634. I_ADDA_UL_CH3, 1, 0),
  635. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH4 Switch", AFE_CONN22,
  636. I_ADDA_UL_CH4, 1, 0),
  637. SOC_DAPM_SINGLE_AUTODISABLE("TDM_IN_CH2 Switch", AFE_CONN22_1,
  638. I_TDM_IN_CH2, 1, 0),
  639. };
  640. static const struct snd_kcontrol_new memif_ul1_ch3_mix[] = {
  641. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH1 Switch", AFE_CONN9,
  642. I_ADDA_UL_CH1, 1, 0),
  643. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH2 Switch", AFE_CONN9,
  644. I_ADDA_UL_CH2, 1, 0),
  645. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH3 Switch", AFE_CONN9,
  646. I_ADDA_UL_CH3, 1, 0),
  647. SOC_DAPM_SINGLE_AUTODISABLE("TDM_IN_CH3 Switch", AFE_CONN9_1,
  648. I_TDM_IN_CH3, 1, 0),
  649. };
  650. static const struct snd_kcontrol_new memif_ul1_ch4_mix[] = {
  651. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH1 Switch", AFE_CONN10,
  652. I_ADDA_UL_CH1, 1, 0),
  653. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH2 Switch", AFE_CONN10,
  654. I_ADDA_UL_CH2, 1, 0),
  655. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH3 Switch", AFE_CONN10,
  656. I_ADDA_UL_CH3, 1, 0),
  657. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH4 Switch", AFE_CONN10,
  658. I_ADDA_UL_CH4, 1, 0),
  659. SOC_DAPM_SINGLE_AUTODISABLE("TDM_IN_CH4 Switch", AFE_CONN10_1,
  660. I_TDM_IN_CH4, 1, 0),
  661. };
  662. static const struct snd_kcontrol_new memif_ul2_ch1_mix[] = {
  663. SOC_DAPM_SINGLE_AUTODISABLE("I2S0_CH1 Switch", AFE_CONN5,
  664. I_I2S0_CH1, 1, 0),
  665. SOC_DAPM_SINGLE_AUTODISABLE("DL1_CH1 Switch", AFE_CONN5,
  666. I_DL1_CH1, 1, 0),
  667. SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH1 Switch", AFE_CONN5,
  668. I_DL12_CH1, 1, 0),
  669. SOC_DAPM_SINGLE_AUTODISABLE("DL2_CH1 Switch", AFE_CONN5,
  670. I_DL2_CH1, 1, 0),
  671. SOC_DAPM_SINGLE_AUTODISABLE("DL3_CH1 Switch", AFE_CONN5,
  672. I_DL3_CH1, 1, 0),
  673. SOC_DAPM_SINGLE_AUTODISABLE("DL4_CH1 Switch", AFE_CONN5_1,
  674. I_DL4_CH1, 1, 0),
  675. SOC_DAPM_SINGLE_AUTODISABLE("DL5_CH1 Switch", AFE_CONN5_1,
  676. I_DL5_CH1, 1, 0),
  677. SOC_DAPM_SINGLE_AUTODISABLE("DL6_CH1 Switch", AFE_CONN5_1,
  678. I_DL6_CH1, 1, 0),
  679. SOC_DAPM_SINGLE_AUTODISABLE("PCM_1_CAP_CH1 Switch", AFE_CONN5,
  680. I_PCM_1_CAP_CH1, 1, 0),
  681. SOC_DAPM_SINGLE_AUTODISABLE("I2S2_CH1 Switch", AFE_CONN5,
  682. I_I2S2_CH1, 1, 0),
  683. SOC_DAPM_SINGLE_AUTODISABLE("CONNSYS_I2S_CH1 Switch", AFE_CONN5_1,
  684. I_CONNSYS_I2S_CH1, 1, 0),
  685. SOC_DAPM_SINGLE_AUTODISABLE("SRC_1_OUT_CH1 Switch", AFE_CONN5_1,
  686. I_SRC_1_OUT_CH1, 1, 0),
  687. };
  688. static const struct snd_kcontrol_new memif_ul2_ch2_mix[] = {
  689. SOC_DAPM_SINGLE_AUTODISABLE("I2S0_CH2 Switch", AFE_CONN6,
  690. I_I2S0_CH2, 1, 0),
  691. SOC_DAPM_SINGLE_AUTODISABLE("DL1_CH2 Switch", AFE_CONN6,
  692. I_DL1_CH2, 1, 0),
  693. SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH2 Switch", AFE_CONN6,
  694. I_DL12_CH2, 1, 0),
  695. SOC_DAPM_SINGLE_AUTODISABLE("DL2_CH2 Switch", AFE_CONN6,
  696. I_DL2_CH2, 1, 0),
  697. SOC_DAPM_SINGLE_AUTODISABLE("DL3_CH2 Switch", AFE_CONN6,
  698. I_DL3_CH2, 1, 0),
  699. SOC_DAPM_SINGLE_AUTODISABLE("DL4_CH2 Switch", AFE_CONN6_1,
  700. I_DL4_CH2, 1, 0),
  701. SOC_DAPM_SINGLE_AUTODISABLE("DL5_CH2 Switch", AFE_CONN6_1,
  702. I_DL5_CH2, 1, 0),
  703. SOC_DAPM_SINGLE_AUTODISABLE("DL6_CH2 Switch", AFE_CONN6_1,
  704. I_DL6_CH2, 1, 0),
  705. SOC_DAPM_SINGLE_AUTODISABLE("PCM_1_CAP_CH2 Switch", AFE_CONN6,
  706. I_PCM_1_CAP_CH2, 1, 0),
  707. SOC_DAPM_SINGLE_AUTODISABLE("I2S2_CH2 Switch", AFE_CONN6,
  708. I_I2S2_CH2, 1, 0),
  709. SOC_DAPM_SINGLE_AUTODISABLE("CONNSYS_I2S_CH2 Switch", AFE_CONN6_1,
  710. I_CONNSYS_I2S_CH2, 1, 0),
  711. SOC_DAPM_SINGLE_AUTODISABLE("SRC_1_OUT_CH2 Switch", AFE_CONN6_1,
  712. I_SRC_1_OUT_CH2, 1, 0),
  713. };
  714. static const struct snd_kcontrol_new memif_ul3_ch1_mix[] = {
  715. SOC_DAPM_SINGLE_AUTODISABLE("CONNSYS_I2S_CH1 Switch", AFE_CONN32_1,
  716. I_CONNSYS_I2S_CH1, 1, 0),
  717. SOC_DAPM_SINGLE_AUTODISABLE("DL1_CH1 Switch", AFE_CONN32,
  718. I_DL1_CH1, 1, 0),
  719. SOC_DAPM_SINGLE_AUTODISABLE("DL2_CH1 Switch", AFE_CONN32,
  720. I_DL2_CH1, 1, 0),
  721. };
  722. static const struct snd_kcontrol_new memif_ul3_ch2_mix[] = {
  723. SOC_DAPM_SINGLE_AUTODISABLE("CONNSYS_I2S_CH2 Switch", AFE_CONN33_1,
  724. I_CONNSYS_I2S_CH2, 1, 0),
  725. };
  726. static const struct snd_kcontrol_new memif_ul4_ch1_mix[] = {
  727. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH1 Switch", AFE_CONN38,
  728. I_ADDA_UL_CH1, 1, 0),
  729. SOC_DAPM_SINGLE_AUTODISABLE("I2S0_CH1 Switch", AFE_CONN38,
  730. I_I2S0_CH1, 1, 0),
  731. };
  732. static const struct snd_kcontrol_new memif_ul4_ch2_mix[] = {
  733. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH2 Switch", AFE_CONN39,
  734. I_ADDA_UL_CH2, 1, 0),
  735. SOC_DAPM_SINGLE_AUTODISABLE("I2S0_CH2 Switch", AFE_CONN39,
  736. I_I2S0_CH2, 1, 0),
  737. };
  738. static const struct snd_kcontrol_new memif_ul5_ch1_mix[] = {
  739. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH1 Switch", AFE_CONN44,
  740. I_ADDA_UL_CH1, 1, 0),
  741. };
  742. static const struct snd_kcontrol_new memif_ul5_ch2_mix[] = {
  743. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH2 Switch", AFE_CONN45,
  744. I_ADDA_UL_CH2, 1, 0),
  745. };
  746. static const struct snd_kcontrol_new memif_ul6_ch1_mix[] = {
  747. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH1 Switch", AFE_CONN46,
  748. I_ADDA_UL_CH1, 1, 0),
  749. SOC_DAPM_SINGLE_AUTODISABLE("DL1_CH1 Switch", AFE_CONN46,
  750. I_DL1_CH1, 1, 0),
  751. SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH1 Switch", AFE_CONN46,
  752. I_DL12_CH1, 1, 0),
  753. SOC_DAPM_SINGLE_AUTODISABLE("DL6_CH1 Switch", AFE_CONN46_1,
  754. I_DL6_CH1, 1, 0),
  755. SOC_DAPM_SINGLE_AUTODISABLE("DL2_CH1 Switch", AFE_CONN46,
  756. I_DL2_CH1, 1, 0),
  757. SOC_DAPM_SINGLE_AUTODISABLE("DL3_CH1 Switch", AFE_CONN46,
  758. I_DL3_CH1, 1, 0),
  759. SOC_DAPM_SINGLE_AUTODISABLE("DL4_CH1 Switch", AFE_CONN46_1,
  760. I_DL4_CH1, 1, 0),
  761. SOC_DAPM_SINGLE_AUTODISABLE("PCM_1_CAP_CH1 Switch", AFE_CONN46,
  762. I_PCM_1_CAP_CH1, 1, 0),
  763. SOC_DAPM_SINGLE_AUTODISABLE("GAIN1_OUT_CH1 Switch", AFE_CONN46,
  764. I_GAIN1_OUT_CH1, 1, 0),
  765. };
  766. static const struct snd_kcontrol_new memif_ul6_ch2_mix[] = {
  767. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH2 Switch", AFE_CONN47,
  768. I_ADDA_UL_CH2, 1, 0),
  769. SOC_DAPM_SINGLE_AUTODISABLE("DL1_CH2 Switch", AFE_CONN47,
  770. I_DL1_CH2, 1, 0),
  771. SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH2 Switch", AFE_CONN47,
  772. I_DL12_CH2, 1, 0),
  773. SOC_DAPM_SINGLE_AUTODISABLE("DL6_CH2 Switch", AFE_CONN47_1,
  774. I_DL6_CH2, 1, 0),
  775. SOC_DAPM_SINGLE_AUTODISABLE("DL2_CH2 Switch", AFE_CONN47,
  776. I_DL2_CH2, 1, 0),
  777. SOC_DAPM_SINGLE_AUTODISABLE("DL3_CH2 Switch", AFE_CONN47,
  778. I_DL3_CH2, 1, 0),
  779. SOC_DAPM_SINGLE_AUTODISABLE("DL4_CH2 Switch", AFE_CONN47_1,
  780. I_DL4_CH2, 1, 0),
  781. SOC_DAPM_SINGLE_AUTODISABLE("PCM_1_CAP_CH2 Switch", AFE_CONN47,
  782. I_PCM_1_CAP_CH2, 1, 0),
  783. SOC_DAPM_SINGLE_AUTODISABLE("GAIN1_OUT_CH2 Switch", AFE_CONN47,
  784. I_GAIN1_OUT_CH2, 1, 0),
  785. };
  786. static const struct snd_kcontrol_new memif_ul7_ch1_mix[] = {
  787. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH1 Switch", AFE_CONN48,
  788. I_ADDA_UL_CH1, 1, 0),
  789. SOC_DAPM_SINGLE_AUTODISABLE("HW_GAIN2_OUT_CH1 Switch", AFE_CONN48,
  790. I_GAIN2_OUT_CH1, 1, 0),
  791. SOC_DAPM_SINGLE_AUTODISABLE("HW_SRC_2_OUT_CH1 Switch", AFE_CONN48_1,
  792. I_SRC_2_OUT_CH1, 1, 0),
  793. };
  794. static const struct snd_kcontrol_new memif_ul7_ch2_mix[] = {
  795. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH2 Switch", AFE_CONN49,
  796. I_ADDA_UL_CH2, 1, 0),
  797. SOC_DAPM_SINGLE_AUTODISABLE("HW_GAIN2_OUT_CH2 Switch", AFE_CONN49,
  798. I_GAIN2_OUT_CH2, 1, 0),
  799. SOC_DAPM_SINGLE_AUTODISABLE("HW_SRC_2_OUT_CH2 Switch", AFE_CONN49_1,
  800. I_SRC_2_OUT_CH2, 1, 0),
  801. };
  802. static const struct snd_kcontrol_new memif_ul8_ch1_mix[] = {
  803. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH1 Switch", AFE_CONN50,
  804. I_ADDA_UL_CH1, 1, 0),
  805. };
  806. static const struct snd_kcontrol_new memif_ul8_ch2_mix[] = {
  807. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH2 Switch", AFE_CONN51,
  808. I_ADDA_UL_CH2, 1, 0),
  809. };
  810. static const struct snd_kcontrol_new hw_cm1_ch1_mix[] = {
  811. SOC_DAPM_SINGLE_AUTODISABLE("TDM_IN_CH1 Switch", AFE_CONN58_1,
  812. I_TDM_IN_CH1, 1, 0),
  813. SOC_DAPM_SINGLE_AUTODISABLE("I2S0_CH1 Switch", AFE_CONN58,
  814. I_I2S0_CH1, 1, 0),
  815. SOC_DAPM_SINGLE_AUTODISABLE("I2S2_CH1 Switch", AFE_CONN58,
  816. I_I2S2_CH1, 1, 0),
  817. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH1 Switch", AFE_CONN58,
  818. I_ADDA_UL_CH1, 1, 0),
  819. SOC_DAPM_SINGLE_AUTODISABLE("DL1_CH1 Switch", AFE_CONN58,
  820. I_DL1_CH1, 1, 0),
  821. SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH1 Switch", AFE_CONN58,
  822. I_DL12_CH1, 1, 0),
  823. SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH3 Switch", AFE_CONN58,
  824. I_DL12_CH3, 1, 0),
  825. SOC_DAPM_SINGLE_AUTODISABLE("DL2_CH1 Switch", AFE_CONN58,
  826. I_DL2_CH1, 1, 0),
  827. SOC_DAPM_SINGLE_AUTODISABLE("DL3_CH1 Switch", AFE_CONN58,
  828. I_DL3_CH1, 1, 0),
  829. SOC_DAPM_SINGLE_AUTODISABLE("DL4_CH1 Switch", AFE_CONN58_1,
  830. I_DL4_CH1, 1, 0),
  831. SOC_DAPM_SINGLE_AUTODISABLE("DL5_CH1 Switch", AFE_CONN58_1,
  832. I_DL5_CH1, 1, 0),
  833. SOC_DAPM_SINGLE_AUTODISABLE("HW_SRC1_OUT_CH1 Switch", AFE_CONN58_1,
  834. I_SRC_1_OUT_CH1, 1, 0),
  835. SOC_DAPM_SINGLE_AUTODISABLE("HW_SRC2_OUT_CH1 Switch", AFE_CONN58_1,
  836. I_SRC_2_OUT_CH1, 1, 0),
  837. };
  838. static const struct snd_kcontrol_new hw_cm1_ch2_mix[] = {
  839. SOC_DAPM_SINGLE_AUTODISABLE("TDM_IN_CH2 Switch", AFE_CONN59_1,
  840. I_TDM_IN_CH2, 1, 0),
  841. SOC_DAPM_SINGLE_AUTODISABLE("I2S0_CH2 Switch", AFE_CONN59,
  842. I_I2S0_CH2, 1, 0),
  843. SOC_DAPM_SINGLE_AUTODISABLE("I2S2_CH2 Switch", AFE_CONN59,
  844. I_I2S2_CH2, 1, 0),
  845. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH2 Switch", AFE_CONN59,
  846. I_ADDA_UL_CH2, 1, 0),
  847. SOC_DAPM_SINGLE_AUTODISABLE("DL1_CH2 Switch", AFE_CONN59,
  848. I_DL1_CH2, 1, 0),
  849. SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH2 Switch", AFE_CONN59,
  850. I_DL12_CH2, 1, 0),
  851. SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH4 Switch", AFE_CONN59,
  852. I_DL12_CH4, 1, 0),
  853. SOC_DAPM_SINGLE_AUTODISABLE("DL2_CH2 Switch", AFE_CONN59,
  854. I_DL2_CH2, 1, 0),
  855. SOC_DAPM_SINGLE_AUTODISABLE("DL3_CH2 Switch", AFE_CONN59,
  856. I_DL3_CH2, 1, 0),
  857. SOC_DAPM_SINGLE_AUTODISABLE("DL4_CH2 Switch", AFE_CONN59_1,
  858. I_DL4_CH2, 1, 0),
  859. SOC_DAPM_SINGLE_AUTODISABLE("DL5_CH2 Switch", AFE_CONN59_1,
  860. I_DL5_CH2, 1, 0),
  861. SOC_DAPM_SINGLE_AUTODISABLE("HW_SRC1_OUT_CH2 Switch", AFE_CONN59_1,
  862. I_SRC_1_OUT_CH2, 1, 0),
  863. SOC_DAPM_SINGLE_AUTODISABLE("HW_SRC2_OUT_CH2 Switch", AFE_CONN59_1,
  864. I_SRC_2_OUT_CH2, 1, 0),
  865. };
  866. static const struct snd_kcontrol_new hw_cm1_ch3_mix[] = {
  867. SOC_DAPM_SINGLE_AUTODISABLE("TDM_IN_CH3 Switch", AFE_CONN60_1,
  868. I_TDM_IN_CH3, 1, 0),
  869. SOC_DAPM_SINGLE_AUTODISABLE("I2S0_CH1 Switch", AFE_CONN60,
  870. I_I2S0_CH1, 1, 0),
  871. SOC_DAPM_SINGLE_AUTODISABLE("I2S2_CH1 Switch", AFE_CONN60,
  872. I_I2S2_CH1, 1, 0),
  873. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH1 Switch", AFE_CONN60,
  874. I_ADDA_UL_CH1, 1, 0),
  875. SOC_DAPM_SINGLE_AUTODISABLE("DL1_CH1 Switch", AFE_CONN60,
  876. I_DL1_CH1, 1, 0),
  877. SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH1 Switch", AFE_CONN60,
  878. I_DL12_CH1, 1, 0),
  879. SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH3 Switch", AFE_CONN60,
  880. I_DL12_CH3, 1, 0),
  881. SOC_DAPM_SINGLE_AUTODISABLE("DL2_CH1 Switch", AFE_CONN60,
  882. I_DL2_CH1, 1, 0),
  883. SOC_DAPM_SINGLE_AUTODISABLE("DL3_CH1 Switch", AFE_CONN60,
  884. I_DL3_CH1, 1, 0),
  885. SOC_DAPM_SINGLE_AUTODISABLE("DL4_CH1 Switch", AFE_CONN60_1,
  886. I_DL4_CH1, 1, 0),
  887. SOC_DAPM_SINGLE_AUTODISABLE("DL5_CH1 Switch", AFE_CONN60_1,
  888. I_DL5_CH1, 1, 0),
  889. SOC_DAPM_SINGLE_AUTODISABLE("HW_SRC1_OUT_CH1 Switch", AFE_CONN60_1,
  890. I_SRC_1_OUT_CH1, 1, 0),
  891. SOC_DAPM_SINGLE_AUTODISABLE("HW_SRC2_OUT_CH1 Switch", AFE_CONN60_1,
  892. I_SRC_2_OUT_CH1, 1, 0),
  893. };
  894. static const struct snd_kcontrol_new hw_cm1_ch4_mix[] = {
  895. SOC_DAPM_SINGLE_AUTODISABLE("TDM_IN_CH4 Switch", AFE_CONN61_1,
  896. I_TDM_IN_CH4, 1, 0),
  897. SOC_DAPM_SINGLE_AUTODISABLE("I2S0_CH2 Switch", AFE_CONN61,
  898. I_I2S0_CH2, 1, 0),
  899. SOC_DAPM_SINGLE_AUTODISABLE("I2S2_CH2 Switch", AFE_CONN61,
  900. I_I2S2_CH2, 1, 0),
  901. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH2 Switch", AFE_CONN61,
  902. I_ADDA_UL_CH2, 1, 0),
  903. SOC_DAPM_SINGLE_AUTODISABLE("DL1_CH2 Switch", AFE_CONN61,
  904. I_DL1_CH2, 1, 0),
  905. SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH2 Switch", AFE_CONN61,
  906. I_DL12_CH2, 1, 0),
  907. SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH4 Switch", AFE_CONN61,
  908. I_DL12_CH4, 1, 0),
  909. SOC_DAPM_SINGLE_AUTODISABLE("DL2_CH2 Switch", AFE_CONN61,
  910. I_DL2_CH2, 1, 0),
  911. SOC_DAPM_SINGLE_AUTODISABLE("DL3_CH2 Switch", AFE_CONN61,
  912. I_DL3_CH2, 1, 0),
  913. SOC_DAPM_SINGLE_AUTODISABLE("DL4_CH2 Switch", AFE_CONN61_1,
  914. I_DL4_CH2, 1, 0),
  915. SOC_DAPM_SINGLE_AUTODISABLE("DL5_CH2 Switch", AFE_CONN61_1,
  916. I_DL5_CH2, 1, 0),
  917. SOC_DAPM_SINGLE_AUTODISABLE("HW_SRC1_OUT_CH2 Switch", AFE_CONN61_1,
  918. I_SRC_1_OUT_CH2, 1, 0),
  919. SOC_DAPM_SINGLE_AUTODISABLE("HW_SRC2_OUT_CH2 Switch", AFE_CONN61_1,
  920. I_SRC_2_OUT_CH2, 1, 0),
  921. };
  922. static const struct snd_kcontrol_new hw_cm1_ch5_mix[] = {
  923. SOC_DAPM_SINGLE_AUTODISABLE("TDM_IN_CH5 Switch", AFE_CONN62_1,
  924. I_TDM_IN_CH5, 1, 0),
  925. SOC_DAPM_SINGLE_AUTODISABLE("I2S0_CH1 Switch", AFE_CONN62,
  926. I_I2S0_CH1, 1, 0),
  927. SOC_DAPM_SINGLE_AUTODISABLE("I2S2_CH1 Switch", AFE_CONN62,
  928. I_I2S2_CH1, 1, 0),
  929. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH1 Switch", AFE_CONN62,
  930. I_ADDA_UL_CH1, 1, 0),
  931. SOC_DAPM_SINGLE_AUTODISABLE("DL1_CH1 Switch", AFE_CONN62,
  932. I_DL1_CH1, 1, 0),
  933. SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH1 Switch", AFE_CONN62,
  934. I_DL12_CH1, 1, 0),
  935. SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH3 Switch", AFE_CONN62,
  936. I_DL12_CH3, 1, 0),
  937. SOC_DAPM_SINGLE_AUTODISABLE("DL2_CH1 Switch", AFE_CONN62,
  938. I_DL2_CH1, 1, 0),
  939. SOC_DAPM_SINGLE_AUTODISABLE("DL3_CH1 Switch", AFE_CONN62,
  940. I_DL3_CH1, 1, 0),
  941. SOC_DAPM_SINGLE_AUTODISABLE("DL4_CH1 Switch", AFE_CONN62_1,
  942. I_DL4_CH1, 1, 0),
  943. SOC_DAPM_SINGLE_AUTODISABLE("DL5_CH1 Switch", AFE_CONN62_1,
  944. I_DL5_CH1, 1, 0),
  945. SOC_DAPM_SINGLE_AUTODISABLE("HW_SRC1_OUT_CH1 Switch", AFE_CONN62_1,
  946. I_SRC_1_OUT_CH1, 1, 0),
  947. SOC_DAPM_SINGLE_AUTODISABLE("HW_SRC2_OUT_CH1 Switch", AFE_CONN62_1,
  948. I_SRC_2_OUT_CH1, 1, 0),
  949. };
  950. static const struct snd_kcontrol_new hw_cm1_ch6_mix[] = {
  951. SOC_DAPM_SINGLE_AUTODISABLE("TDM_IN_CH6 Switch", AFE_CONN63_1,
  952. I_TDM_IN_CH6, 1, 0),
  953. SOC_DAPM_SINGLE_AUTODISABLE("I2S0_CH2 Switch", AFE_CONN63,
  954. I_I2S0_CH2, 1, 0),
  955. SOC_DAPM_SINGLE_AUTODISABLE("I2S2_CH2 Switch", AFE_CONN63,
  956. I_I2S2_CH2, 1, 0),
  957. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH2 Switch", AFE_CONN63,
  958. I_ADDA_UL_CH2, 1, 0),
  959. SOC_DAPM_SINGLE_AUTODISABLE("DL1_CH2 Switch", AFE_CONN63,
  960. I_DL1_CH2, 1, 0),
  961. SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH2 Switch", AFE_CONN63,
  962. I_DL12_CH2, 1, 0),
  963. SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH4 Switch", AFE_CONN63,
  964. I_DL12_CH4, 1, 0),
  965. SOC_DAPM_SINGLE_AUTODISABLE("DL2_CH2 Switch", AFE_CONN63,
  966. I_DL2_CH2, 1, 0),
  967. SOC_DAPM_SINGLE_AUTODISABLE("DL3_CH2 Switch", AFE_CONN63,
  968. I_DL3_CH2, 1, 0),
  969. SOC_DAPM_SINGLE_AUTODISABLE("DL4_CH2 Switch", AFE_CONN63_1,
  970. I_DL4_CH2, 1, 0),
  971. SOC_DAPM_SINGLE_AUTODISABLE("DL5_CH2 Switch", AFE_CONN63_1,
  972. I_DL5_CH2, 1, 0),
  973. SOC_DAPM_SINGLE_AUTODISABLE("HW_SRC1_OUT_CH2 Switch", AFE_CONN63_1,
  974. I_SRC_1_OUT_CH2, 1, 0),
  975. SOC_DAPM_SINGLE_AUTODISABLE("HW_SRC2_OUT_CH2 Switch", AFE_CONN63_1,
  976. I_SRC_2_OUT_CH2, 1, 0),
  977. };
  978. static const struct snd_kcontrol_new hw_cm1_ch7_mix[] = {
  979. SOC_DAPM_SINGLE_AUTODISABLE("TDM_IN_CH7 Switch", AFE_CONN64_1,
  980. I_TDM_IN_CH7, 1, 0),
  981. SOC_DAPM_SINGLE_AUTODISABLE("I2S0_CH1 Switch", AFE_CONN64,
  982. I_I2S0_CH1, 1, 0),
  983. SOC_DAPM_SINGLE_AUTODISABLE("I2S2_CH1 Switch", AFE_CONN64,
  984. I_I2S2_CH1, 1, 0),
  985. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH1 Switch", AFE_CONN64,
  986. I_ADDA_UL_CH1, 1, 0),
  987. SOC_DAPM_SINGLE_AUTODISABLE("DL1_CH1 Switch", AFE_CONN64,
  988. I_DL1_CH1, 1, 0),
  989. SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH1v", AFE_CONN64,
  990. I_DL12_CH1, 1, 0),
  991. SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH3 Switch", AFE_CONN64,
  992. I_DL12_CH3, 1, 0),
  993. SOC_DAPM_SINGLE_AUTODISABLE("DL2_CH1 Switch", AFE_CONN64,
  994. I_DL2_CH1, 1, 0),
  995. SOC_DAPM_SINGLE_AUTODISABLE("DL3_CH1 Switch", AFE_CONN64,
  996. I_DL3_CH1, 1, 0),
  997. SOC_DAPM_SINGLE_AUTODISABLE("DL4_CH1 Switch", AFE_CONN64_1,
  998. I_DL4_CH1, 1, 0),
  999. SOC_DAPM_SINGLE_AUTODISABLE("DL5_CH1 Switch", AFE_CONN64_1,
  1000. I_DL5_CH1, 1, 0),
  1001. SOC_DAPM_SINGLE_AUTODISABLE("HW_SRC1_OUT_CH1 Switch", AFE_CONN64_1,
  1002. I_SRC_1_OUT_CH1, 1, 0),
  1003. SOC_DAPM_SINGLE_AUTODISABLE("HW_SRC2_OUT_CH1 Switch", AFE_CONN64_1,
  1004. I_SRC_2_OUT_CH1, 1, 0),
  1005. };
  1006. static const struct snd_kcontrol_new hw_cm1_ch8_mix[] = {
  1007. SOC_DAPM_SINGLE_AUTODISABLE("TDM_IN_CH8 Switch", AFE_CONN65_1,
  1008. I_TDM_IN_CH8, 1, 0),
  1009. SOC_DAPM_SINGLE_AUTODISABLE("I2S0_CH2 Switch", AFE_CONN65,
  1010. I_I2S0_CH2, 1, 0),
  1011. SOC_DAPM_SINGLE_AUTODISABLE("I2S2_CH2 Switch", AFE_CONN65,
  1012. I_I2S2_CH2, 1, 0),
  1013. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH2 Switch", AFE_CONN65,
  1014. I_ADDA_UL_CH2, 1, 0),
  1015. SOC_DAPM_SINGLE_AUTODISABLE("DL1_CH2 Switch", AFE_CONN65,
  1016. I_DL1_CH2, 1, 0),
  1017. SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH2 Switch", AFE_CONN65,
  1018. I_DL12_CH2, 1, 0),
  1019. SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH4 Switch", AFE_CONN65,
  1020. I_DL12_CH4, 1, 0),
  1021. SOC_DAPM_SINGLE_AUTODISABLE("DL2_CH2 Switch", AFE_CONN65,
  1022. I_DL2_CH2, 1, 0),
  1023. SOC_DAPM_SINGLE_AUTODISABLE("DL3_CH2 Switch", AFE_CONN65,
  1024. I_DL3_CH2, 1, 0),
  1025. SOC_DAPM_SINGLE_AUTODISABLE("DL4_CH2 Switch", AFE_CONN65_1,
  1026. I_DL4_CH2, 1, 0),
  1027. SOC_DAPM_SINGLE_AUTODISABLE("DL5_CH2 Switch", AFE_CONN65_1,
  1028. I_DL5_CH2, 1, 0),
  1029. SOC_DAPM_SINGLE_AUTODISABLE("HW_SRC1_OUT_CH2 Switch", AFE_CONN65_1,
  1030. I_SRC_1_OUT_CH2, 1, 0),
  1031. SOC_DAPM_SINGLE_AUTODISABLE("HW_SRC2_OUT_CH2 Switch", AFE_CONN65_1,
  1032. I_SRC_2_OUT_CH2, 1, 0),
  1033. };
  1034. static const struct snd_kcontrol_new hw_cm1_ch9_mix[] = {
  1035. SOC_DAPM_SINGLE_AUTODISABLE("I2S0_CH1 Switch", AFE_CONN66,
  1036. I_I2S0_CH1, 1, 0),
  1037. SOC_DAPM_SINGLE_AUTODISABLE("I2S2_CH1 Switch", AFE_CONN66,
  1038. I_I2S2_CH1, 1, 0),
  1039. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH1 Switch", AFE_CONN66,
  1040. I_ADDA_UL_CH1, 1, 0),
  1041. SOC_DAPM_SINGLE_AUTODISABLE("DL1_CH1 Switch", AFE_CONN66,
  1042. I_DL1_CH1, 1, 0),
  1043. SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH1 Switch", AFE_CONN66,
  1044. I_DL12_CH1, 1, 0),
  1045. SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH3 Switch", AFE_CONN66,
  1046. I_DL12_CH3, 1, 0),
  1047. SOC_DAPM_SINGLE_AUTODISABLE("DL2_CH1 Switch", AFE_CONN66,
  1048. I_DL2_CH1, 1, 0),
  1049. SOC_DAPM_SINGLE_AUTODISABLE("DL3_CH1 Switch", AFE_CONN66,
  1050. I_DL3_CH1, 1, 0),
  1051. SOC_DAPM_SINGLE_AUTODISABLE("DL4_CH1 Switch", AFE_CONN66_1,
  1052. I_DL4_CH1, 1, 0),
  1053. SOC_DAPM_SINGLE_AUTODISABLE("DL5_CH1 Switch", AFE_CONN66_1,
  1054. I_DL5_CH1, 1, 0),
  1055. SOC_DAPM_SINGLE_AUTODISABLE("HW_SRC1_OUT_CH1 Switch", AFE_CONN66_1,
  1056. I_SRC_1_OUT_CH1, 1, 0),
  1057. SOC_DAPM_SINGLE_AUTODISABLE("HW_SRC2_OUT_CH1 Switch", AFE_CONN66_1,
  1058. I_SRC_2_OUT_CH1, 1, 0),
  1059. };
  1060. static const struct snd_kcontrol_new hw_cm1_ch10_mix[] = {
  1061. SOC_DAPM_SINGLE_AUTODISABLE("I2S0_CH2 Switch", AFE_CONN67,
  1062. I_I2S0_CH2, 1, 0),
  1063. SOC_DAPM_SINGLE_AUTODISABLE("I2S2_CH2 Switch", AFE_CONN67,
  1064. I_I2S2_CH2, 1, 0),
  1065. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH2 Switch", AFE_CONN67,
  1066. I_ADDA_UL_CH2, 1, 0),
  1067. SOC_DAPM_SINGLE_AUTODISABLE("DL1_CH2 Switch", AFE_CONN67,
  1068. I_DL1_CH2, 1, 0),
  1069. SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH2 Switch", AFE_CONN67,
  1070. I_DL12_CH2, 1, 0),
  1071. SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH4 Switch", AFE_CONN67,
  1072. I_DL12_CH4, 1, 0),
  1073. SOC_DAPM_SINGLE_AUTODISABLE("DL2_CH2 Switch", AFE_CONN67,
  1074. I_DL2_CH2, 1, 0),
  1075. SOC_DAPM_SINGLE_AUTODISABLE("DL3_CH2 Switch", AFE_CONN67,
  1076. I_DL3_CH2, 1, 0),
  1077. SOC_DAPM_SINGLE_AUTODISABLE("DL4_CH2 Switch", AFE_CONN67_1,
  1078. I_DL4_CH2, 1, 0),
  1079. SOC_DAPM_SINGLE_AUTODISABLE("DL5_CH2 Switch", AFE_CONN67_1,
  1080. I_DL5_CH2, 1, 0),
  1081. SOC_DAPM_SINGLE_AUTODISABLE("HW_SRC1_OUT_CH2 Switch", AFE_CONN67_1,
  1082. I_SRC_1_OUT_CH2, 1, 0),
  1083. SOC_DAPM_SINGLE_AUTODISABLE("HW_SRC2_OUT_CH2 Switch", AFE_CONN67_1,
  1084. I_SRC_2_OUT_CH2, 1, 0),
  1085. };
  1086. static const struct snd_kcontrol_new hw_cm1_ch11_mix[] = {
  1087. SOC_DAPM_SINGLE_AUTODISABLE("I2S0_CH1 Switch", AFE_CONN68,
  1088. I_I2S0_CH1, 1, 0),
  1089. SOC_DAPM_SINGLE_AUTODISABLE("I2S2_CH1 Switch", AFE_CONN68,
  1090. I_I2S2_CH1, 1, 0),
  1091. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH1 Switch", AFE_CONN68,
  1092. I_ADDA_UL_CH1, 1, 0),
  1093. SOC_DAPM_SINGLE_AUTODISABLE("DL1_CH1 Switch", AFE_CONN68,
  1094. I_DL1_CH1, 1, 0),
  1095. SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH1 Switch", AFE_CONN68,
  1096. I_DL12_CH1, 1, 0),
  1097. SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH3 Switch", AFE_CONN68,
  1098. I_DL12_CH3, 1, 0),
  1099. SOC_DAPM_SINGLE_AUTODISABLE("DL2_CH1 Switch", AFE_CONN68,
  1100. I_DL2_CH1, 1, 0),
  1101. SOC_DAPM_SINGLE_AUTODISABLE("DL3_CH1 Switch", AFE_CONN68,
  1102. I_DL3_CH1, 1, 0),
  1103. SOC_DAPM_SINGLE_AUTODISABLE("DL4_CH1 Switch", AFE_CONN68_1,
  1104. I_DL4_CH1, 1, 0),
  1105. SOC_DAPM_SINGLE_AUTODISABLE("DL5_CH1 Switch", AFE_CONN68_1,
  1106. I_DL5_CH1, 1, 0),
  1107. SOC_DAPM_SINGLE_AUTODISABLE("HW_SRC1_OUT_CH1 Switch", AFE_CONN68_1,
  1108. I_SRC_1_OUT_CH1, 1, 0),
  1109. SOC_DAPM_SINGLE_AUTODISABLE("HW_SRC2_OUT_CH1 Switch", AFE_CONN68_1,
  1110. I_SRC_2_OUT_CH1, 1, 0),
  1111. };
  1112. static const struct snd_kcontrol_new hw_cm1_ch12_mix[] = {
  1113. SOC_DAPM_SINGLE_AUTODISABLE("I2S0_CH2 Switch", AFE_CONN69,
  1114. I_I2S0_CH2, 1, 0),
  1115. SOC_DAPM_SINGLE_AUTODISABLE("I2S2_CH2 Switch", AFE_CONN69,
  1116. I_I2S2_CH2, 1, 0),
  1117. SOC_DAPM_SINGLE_AUTODISABLE("ADDA_UL_CH2 Switch", AFE_CONN69,
  1118. I_ADDA_UL_CH2, 1, 0),
  1119. SOC_DAPM_SINGLE_AUTODISABLE("DL1_CH2 Switch", AFE_CONN69,
  1120. I_DL1_CH2, 1, 0),
  1121. SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH2 Switch", AFE_CONN69,
  1122. I_DL12_CH2, 1, 0),
  1123. SOC_DAPM_SINGLE_AUTODISABLE("DL12_CH4 Switch", AFE_CONN69,
  1124. I_DL12_CH4, 1, 0),
  1125. SOC_DAPM_SINGLE_AUTODISABLE("DL2_CH2 Switch", AFE_CONN69,
  1126. I_DL2_CH2, 1, 0),
  1127. SOC_DAPM_SINGLE_AUTODISABLE("DL3_CH2 Switch", AFE_CONN69,
  1128. I_DL3_CH2, 1, 0),
  1129. SOC_DAPM_SINGLE_AUTODISABLE("DL4_CH2 Switch", AFE_CONN69_1,
  1130. I_DL4_CH2, 1, 0),
  1131. SOC_DAPM_SINGLE_AUTODISABLE("DL5_CH2 Switch", AFE_CONN69_1,
  1132. I_DL5_CH2, 1, 0),
  1133. SOC_DAPM_SINGLE_AUTODISABLE("HW_SRC1_OUT_CH2 Switch", AFE_CONN69_1,
  1134. I_SRC_1_OUT_CH2, 1, 0),
  1135. SOC_DAPM_SINGLE_AUTODISABLE("HW_SRC2_OUT_CH2 Switch", AFE_CONN69_1,
  1136. I_SRC_2_OUT_CH2, 1, 0),
  1137. };
  1138. /* ADDA UL MUX */
  1139. enum {
  1140. UL5_IN_MUX_CM1 = 0,
  1141. UL5_IN_MUX_NORMAL,
  1142. UL5_IN_MUX_MASK = 0x1,
  1143. };
  1144. static const char * const ul5_in_mux_map[] = {
  1145. "UL5_IN_FROM_CM1", "UL5_IN_FROM_Normal"
  1146. };
  1147. static int ul5_in_map_value[] = {
  1148. UL5_IN_MUX_CM1,
  1149. UL5_IN_MUX_NORMAL,
  1150. };
  1151. static SOC_VALUE_ENUM_SINGLE_DECL(ul5_in_mux_map_enum,
  1152. AFE_CM1_CON,
  1153. VUL3_BYPASS_CM_SFT,
  1154. VUL3_BYPASS_CM_MASK,
  1155. ul5_in_mux_map,
  1156. ul5_in_map_value);
  1157. static const struct snd_kcontrol_new ul5_in_mux_control =
  1158. SOC_DAPM_ENUM("UL5_IN_MUX Select", ul5_in_mux_map_enum);
  1159. static const struct snd_soc_dapm_widget mt8186_memif_widgets[] = {
  1160. /* inter-connections */
  1161. SND_SOC_DAPM_MIXER("UL1_CH1", SND_SOC_NOPM, 0, 0,
  1162. memif_ul1_ch1_mix, ARRAY_SIZE(memif_ul1_ch1_mix)),
  1163. SND_SOC_DAPM_MIXER("UL1_CH2", SND_SOC_NOPM, 0, 0,
  1164. memif_ul1_ch2_mix, ARRAY_SIZE(memif_ul1_ch2_mix)),
  1165. SND_SOC_DAPM_MIXER("UL1_CH3", SND_SOC_NOPM, 0, 0,
  1166. memif_ul1_ch3_mix, ARRAY_SIZE(memif_ul1_ch3_mix)),
  1167. SND_SOC_DAPM_MIXER("UL1_CH4", SND_SOC_NOPM, 0, 0,
  1168. memif_ul1_ch4_mix, ARRAY_SIZE(memif_ul1_ch4_mix)),
  1169. SND_SOC_DAPM_MIXER("UL2_CH1", SND_SOC_NOPM, 0, 0,
  1170. memif_ul2_ch1_mix, ARRAY_SIZE(memif_ul2_ch1_mix)),
  1171. SND_SOC_DAPM_MIXER("UL2_CH2", SND_SOC_NOPM, 0, 0,
  1172. memif_ul2_ch2_mix, ARRAY_SIZE(memif_ul2_ch2_mix)),
  1173. SND_SOC_DAPM_MIXER("UL3_CH1", SND_SOC_NOPM, 0, 0,
  1174. memif_ul3_ch1_mix, ARRAY_SIZE(memif_ul3_ch1_mix)),
  1175. SND_SOC_DAPM_MIXER("UL3_CH2", SND_SOC_NOPM, 0, 0,
  1176. memif_ul3_ch2_mix, ARRAY_SIZE(memif_ul3_ch2_mix)),
  1177. SND_SOC_DAPM_MIXER("UL4_CH1", SND_SOC_NOPM, 0, 0,
  1178. memif_ul4_ch1_mix, ARRAY_SIZE(memif_ul4_ch1_mix)),
  1179. SND_SOC_DAPM_MIXER("UL4_CH2", SND_SOC_NOPM, 0, 0,
  1180. memif_ul4_ch2_mix, ARRAY_SIZE(memif_ul4_ch2_mix)),
  1181. SND_SOC_DAPM_MIXER("UL5_CH1", SND_SOC_NOPM, 0, 0,
  1182. memif_ul5_ch1_mix, ARRAY_SIZE(memif_ul5_ch1_mix)),
  1183. SND_SOC_DAPM_MIXER("UL5_CH2", SND_SOC_NOPM, 0, 0,
  1184. memif_ul5_ch2_mix, ARRAY_SIZE(memif_ul5_ch2_mix)),
  1185. SND_SOC_DAPM_MIXER("UL6_CH1", SND_SOC_NOPM, 0, 0,
  1186. memif_ul6_ch1_mix, ARRAY_SIZE(memif_ul6_ch1_mix)),
  1187. SND_SOC_DAPM_MIXER("UL6_CH2", SND_SOC_NOPM, 0, 0,
  1188. memif_ul6_ch2_mix, ARRAY_SIZE(memif_ul6_ch2_mix)),
  1189. SND_SOC_DAPM_MIXER("UL7_CH1", SND_SOC_NOPM, 0, 0,
  1190. memif_ul7_ch1_mix, ARRAY_SIZE(memif_ul7_ch1_mix)),
  1191. SND_SOC_DAPM_MIXER("UL7_CH2", SND_SOC_NOPM, 0, 0,
  1192. memif_ul7_ch2_mix, ARRAY_SIZE(memif_ul7_ch2_mix)),
  1193. SND_SOC_DAPM_MIXER("UL8_CH1", SND_SOC_NOPM, 0, 0,
  1194. memif_ul8_ch1_mix, ARRAY_SIZE(memif_ul8_ch1_mix)),
  1195. SND_SOC_DAPM_MIXER("UL8_CH2", SND_SOC_NOPM, 0, 0,
  1196. memif_ul8_ch2_mix, ARRAY_SIZE(memif_ul8_ch2_mix)),
  1197. SND_SOC_DAPM_MIXER("UL5_2CH", SND_SOC_NOPM, 0, 0, NULL, 0),
  1198. SND_SOC_DAPM_MIXER("HW_CM1", SND_SOC_NOPM, 0, 0, NULL, 0),
  1199. /* CM1 en*/
  1200. SND_SOC_DAPM_SUPPLY_S("CM1_EN", 0, AFE_CM1_CON,
  1201. CHANNEL_MERGE0_EN_SFT, 0, NULL,
  1202. SND_SOC_DAPM_PRE_PMU | SND_SOC_DAPM_POST_PMD),
  1203. SND_SOC_DAPM_MIXER("HW_CM1_CH1", SND_SOC_NOPM, 0, 0,
  1204. hw_cm1_ch1_mix, ARRAY_SIZE(hw_cm1_ch1_mix)),
  1205. SND_SOC_DAPM_MIXER("HW_CM1_CH2", SND_SOC_NOPM, 0, 0,
  1206. hw_cm1_ch2_mix, ARRAY_SIZE(hw_cm1_ch2_mix)),
  1207. SND_SOC_DAPM_MIXER("HW_CM1_CH3", SND_SOC_NOPM, 0, 0,
  1208. hw_cm1_ch3_mix, ARRAY_SIZE(hw_cm1_ch3_mix)),
  1209. SND_SOC_DAPM_MIXER("HW_CM1_CH4", SND_SOC_NOPM, 0, 0,
  1210. hw_cm1_ch4_mix, ARRAY_SIZE(hw_cm1_ch4_mix)),
  1211. SND_SOC_DAPM_MIXER("HW_CM1_CH5", SND_SOC_NOPM, 0, 0,
  1212. hw_cm1_ch5_mix, ARRAY_SIZE(hw_cm1_ch5_mix)),
  1213. SND_SOC_DAPM_MIXER("HW_CM1_CH6", SND_SOC_NOPM, 0, 0,
  1214. hw_cm1_ch6_mix, ARRAY_SIZE(hw_cm1_ch6_mix)),
  1215. SND_SOC_DAPM_MIXER("HW_CM1_CH7", SND_SOC_NOPM, 0, 0,
  1216. hw_cm1_ch7_mix, ARRAY_SIZE(hw_cm1_ch7_mix)),
  1217. SND_SOC_DAPM_MIXER("HW_CM1_CH8", SND_SOC_NOPM, 0, 0,
  1218. hw_cm1_ch8_mix, ARRAY_SIZE(hw_cm1_ch8_mix)),
  1219. SND_SOC_DAPM_MIXER("HW_CM1_CH9", SND_SOC_NOPM, 0, 0,
  1220. hw_cm1_ch9_mix, ARRAY_SIZE(hw_cm1_ch9_mix)),
  1221. SND_SOC_DAPM_MIXER("HW_CM1_CH10", SND_SOC_NOPM, 0, 0,
  1222. hw_cm1_ch10_mix, ARRAY_SIZE(hw_cm1_ch10_mix)),
  1223. SND_SOC_DAPM_MIXER("HW_CM1_CH11", SND_SOC_NOPM, 0, 0,
  1224. hw_cm1_ch11_mix, ARRAY_SIZE(hw_cm1_ch11_mix)),
  1225. SND_SOC_DAPM_MIXER("HW_CM1_CH12", SND_SOC_NOPM, 0, 0,
  1226. hw_cm1_ch12_mix, ARRAY_SIZE(hw_cm1_ch12_mix)),
  1227. SND_SOC_DAPM_MUX("UL5_IN_MUX", SND_SOC_NOPM, 0, 0,
  1228. &ul5_in_mux_control),
  1229. SND_SOC_DAPM_MIXER("DSP_DL1_VIRT", SND_SOC_NOPM, 0, 0, NULL, 0),
  1230. SND_SOC_DAPM_MIXER("DSP_DL2_VIRT", SND_SOC_NOPM, 0, 0, NULL, 0),
  1231. SND_SOC_DAPM_INPUT("UL1_VIRTUAL_INPUT"),
  1232. SND_SOC_DAPM_INPUT("UL2_VIRTUAL_INPUT"),
  1233. SND_SOC_DAPM_INPUT("UL3_VIRTUAL_INPUT"),
  1234. SND_SOC_DAPM_INPUT("UL4_VIRTUAL_INPUT"),
  1235. SND_SOC_DAPM_INPUT("UL5_VIRTUAL_INPUT"),
  1236. SND_SOC_DAPM_INPUT("UL6_VIRTUAL_INPUT"),
  1237. };
  1238. static const struct snd_soc_dapm_route mt8186_memif_routes[] = {
  1239. {"UL1", NULL, "UL1_CH1"},
  1240. {"UL1", NULL, "UL1_CH2"},
  1241. {"UL1", NULL, "UL1_CH3"},
  1242. {"UL1", NULL, "UL1_CH4"},
  1243. {"UL1_CH1", "ADDA_UL_CH1 Switch", "ADDA_UL_Mux"},
  1244. {"UL1_CH1", "ADDA_UL_CH2 Switch", "ADDA_UL_Mux"},
  1245. {"UL1_CH2", "ADDA_UL_CH1 Switch", "ADDA_UL_Mux"},
  1246. {"UL1_CH2", "ADDA_UL_CH2 Switch", "ADDA_UL_Mux"},
  1247. {"UL1_CH3", "ADDA_UL_CH1 Switch", "ADDA_UL_Mux"},
  1248. {"UL1_CH3", "ADDA_UL_CH2 Switch", "ADDA_UL_Mux"},
  1249. {"UL1_CH4", "ADDA_UL_CH1 Switch", "ADDA_UL_Mux"},
  1250. {"UL1_CH4", "ADDA_UL_CH2 Switch", "ADDA_UL_Mux"},
  1251. {"UL1_CH1", "TDM_IN_CH1 Switch", "TDM IN"},
  1252. {"UL1_CH2", "TDM_IN_CH2 Switch", "TDM IN"},
  1253. {"UL1_CH3", "TDM_IN_CH3 Switch", "TDM IN"},
  1254. {"UL1_CH4", "TDM_IN_CH4 Switch", "TDM IN"},
  1255. {"UL2", NULL, "UL2_CH1"},
  1256. {"UL2", NULL, "UL2_CH2"},
  1257. /* cannot connect FE to FE directly */
  1258. {"UL2_CH1", "DL1_CH1 Switch", "Hostless_UL2 UL"},
  1259. {"UL2_CH2", "DL1_CH2 Switch", "Hostless_UL2 UL"},
  1260. {"UL2_CH1", "DL12_CH1 Switch", "Hostless_UL2 UL"},
  1261. {"UL2_CH2", "DL12_CH2 Switch", "Hostless_UL2 UL"},
  1262. {"UL2_CH1", "DL6_CH1 Switch", "Hostless_UL2 UL"},
  1263. {"UL2_CH2", "DL6_CH2 Switch", "Hostless_UL2 UL"},
  1264. {"UL2_CH1", "DL2_CH1 Switch", "Hostless_UL2 UL"},
  1265. {"UL2_CH2", "DL2_CH2 Switch", "Hostless_UL2 UL"},
  1266. {"UL2_CH1", "DL3_CH1 Switch", "Hostless_UL2 UL"},
  1267. {"UL2_CH2", "DL3_CH2 Switch", "Hostless_UL2 UL"},
  1268. {"UL2_CH1", "DL4_CH1 Switch", "Hostless_UL2 UL"},
  1269. {"UL2_CH2", "DL4_CH2 Switch", "Hostless_UL2 UL"},
  1270. {"UL2_CH1", "DL5_CH1 Switch", "Hostless_UL2 UL"},
  1271. {"UL2_CH2", "DL5_CH2 Switch", "Hostless_UL2 UL"},
  1272. {"Hostless_UL2 UL", NULL, "UL2_VIRTUAL_INPUT"},
  1273. {"UL2_CH1", "I2S0_CH1 Switch", "I2S0"},
  1274. {"UL2_CH2", "I2S0_CH2 Switch", "I2S0"},
  1275. {"UL2_CH1", "I2S2_CH1 Switch", "I2S2"},
  1276. {"UL2_CH2", "I2S2_CH2 Switch", "I2S2"},
  1277. {"UL2_CH1", "PCM_1_CAP_CH1 Switch", "PCM 1 Capture"},
  1278. {"UL2_CH2", "PCM_1_CAP_CH2 Switch", "PCM 1 Capture"},
  1279. {"UL2_CH1", "CONNSYS_I2S_CH1 Switch", "Connsys I2S"},
  1280. {"UL2_CH2", "CONNSYS_I2S_CH2 Switch", "Connsys I2S"},
  1281. {"UL2_CH1", "SRC_1_OUT_CH1 Switch", "HW_SRC_1_Out"},
  1282. {"UL2_CH2", "SRC_1_OUT_CH2 Switch", "HW_SRC_1_Out"},
  1283. {"UL3", NULL, "UL3_CH1"},
  1284. {"UL3", NULL, "UL3_CH2"},
  1285. {"UL3_CH1", "CONNSYS_I2S_CH1 Switch", "Connsys I2S"},
  1286. {"UL3_CH2", "CONNSYS_I2S_CH2 Switch", "Connsys I2S"},
  1287. {"UL4", NULL, "UL4_CH1"},
  1288. {"UL4", NULL, "UL4_CH2"},
  1289. {"UL4_CH1", "ADDA_UL_CH1 Switch", "ADDA_UL_Mux"},
  1290. {"UL4_CH2", "ADDA_UL_CH2 Switch", "ADDA_UL_Mux"},
  1291. {"UL4_CH1", "I2S0_CH1 Switch", "I2S0"},
  1292. {"UL4_CH2", "I2S0_CH2 Switch", "I2S0"},
  1293. {"UL5", NULL, "UL5_IN_MUX"},
  1294. {"UL5_IN_MUX", "UL5_IN_FROM_Normal", "UL5_2CH"},
  1295. {"UL5_IN_MUX", "UL5_IN_FROM_CM1", "HW_CM1"},
  1296. {"UL5_2CH", NULL, "UL5_CH1"},
  1297. {"UL5_2CH", NULL, "UL5_CH2"},
  1298. {"UL5_CH1", "ADDA_UL_CH1 Switch", "ADDA_UL_Mux"},
  1299. {"UL5_CH2", "ADDA_UL_CH2 Switch", "ADDA_UL_Mux"},
  1300. {"HW_CM1", NULL, "CM1_EN"},
  1301. {"HW_CM1", NULL, "HW_CM1_CH1"},
  1302. {"HW_CM1", NULL, "HW_CM1_CH2"},
  1303. {"HW_CM1", NULL, "HW_CM1_CH3"},
  1304. {"HW_CM1", NULL, "HW_CM1_CH4"},
  1305. {"HW_CM1", NULL, "HW_CM1_CH5"},
  1306. {"HW_CM1", NULL, "HW_CM1_CH6"},
  1307. {"HW_CM1", NULL, "HW_CM1_CH7"},
  1308. {"HW_CM1", NULL, "HW_CM1_CH8"},
  1309. {"HW_CM1", NULL, "HW_CM1_CH9"},
  1310. {"HW_CM1", NULL, "HW_CM1_CH10"},
  1311. {"HW_CM1", NULL, "HW_CM1_CH11"},
  1312. {"HW_CM1", NULL, "HW_CM1_CH12"},
  1313. {"HW_CM1_CH1", "TDM_IN_CH1 Switch", "TDM IN"},
  1314. {"HW_CM1_CH2", "TDM_IN_CH2 Switch", "TDM IN"},
  1315. {"HW_CM1_CH3", "TDM_IN_CH3 Switch", "TDM IN"},
  1316. {"HW_CM1_CH4", "TDM_IN_CH4 Switch", "TDM IN"},
  1317. {"HW_CM1_CH5", "TDM_IN_CH5 Switch", "TDM IN"},
  1318. {"HW_CM1_CH6", "TDM_IN_CH6 Switch", "TDM IN"},
  1319. {"HW_CM1_CH7", "TDM_IN_CH7 Switch", "TDM IN"},
  1320. {"HW_CM1_CH8", "TDM_IN_CH8 Switch", "TDM IN"},
  1321. {"HW_CM1_CH9", "DL1_CH1 Switch", "Hostless_UL5 UL"},
  1322. {"HW_CM1_CH10", "DL1_CH2 Switch", "Hostless_UL5 UL"},
  1323. {"HW_CM1_CH3", "DL1_CH1 Switch", "Hostless_UL5 UL"},
  1324. {"HW_CM1_CH4", "DL1_CH2 Switch", "Hostless_UL5 UL"},
  1325. {"HW_CM1_CH3", "DL3_CH1 Switch", "Hostless_UL5 UL"},
  1326. {"HW_CM1_CH4", "DL3_CH2 Switch", "Hostless_UL5 UL"},
  1327. {"HW_CM1_CH5", "HW_SRC1_OUT_CH1 Switch", "HW_SRC_1_Out"},
  1328. {"HW_CM1_CH6", "HW_SRC1_OUT_CH2 Switch", "HW_SRC_1_Out"},
  1329. {"HW_CM1_CH9", "DL12_CH1 Switch", "Hostless_UL5 UL"},
  1330. {"HW_CM1_CH10", "DL12_CH2 Switch", "Hostless_UL5 UL"},
  1331. {"HW_CM1_CH11", "DL12_CH3 Switch", "Hostless_UL5 UL"},
  1332. {"HW_CM1_CH12", "DL12_CH4 Switch", "Hostless_UL5 UL"},
  1333. {"Hostless_UL5 UL", NULL, "UL5_VIRTUAL_INPUT"},
  1334. {"UL6", NULL, "UL6_CH1"},
  1335. {"UL6", NULL, "UL6_CH2"},
  1336. {"UL6_CH1", "ADDA_UL_CH1 Switch", "ADDA_UL_Mux"},
  1337. {"UL6_CH2", "ADDA_UL_CH2 Switch", "ADDA_UL_Mux"},
  1338. {"UL6_CH1", "DL1_CH1 Switch", "Hostless_UL6 UL"},
  1339. {"UL6_CH2", "DL1_CH2 Switch", "Hostless_UL6 UL"},
  1340. {"UL6_CH1", "DL2_CH1 Switch", "Hostless_UL6 UL"},
  1341. {"UL6_CH2", "DL2_CH2 Switch", "Hostless_UL6 UL"},
  1342. {"UL6_CH1", "DL12_CH1 Switch", "Hostless_UL6 UL"},
  1343. {"UL6_CH2", "DL12_CH2 Switch", "Hostless_UL6 UL"},
  1344. {"UL6_CH1", "DL6_CH1 Switch", "Hostless_UL6 UL"},
  1345. {"UL6_CH2", "DL6_CH2 Switch", "Hostless_UL6 UL"},
  1346. {"UL6_CH1", "DL3_CH1 Switch", "Hostless_UL6 UL"},
  1347. {"UL6_CH2", "DL3_CH2 Switch", "Hostless_UL6 UL"},
  1348. {"UL6_CH1", "DL4_CH1 Switch", "Hostless_UL6 UL"},
  1349. {"UL6_CH2", "DL4_CH2 Switch", "Hostless_UL6 UL"},
  1350. {"Hostless_UL6 UL", NULL, "UL6_VIRTUAL_INPUT"},
  1351. {"UL6_CH1", "PCM_1_CAP_CH1 Switch", "PCM 1 Capture"},
  1352. {"UL6_CH2", "PCM_1_CAP_CH2 Switch", "PCM 1 Capture"},
  1353. {"UL6_CH1", "GAIN1_OUT_CH1 Switch", "HW Gain 1 Out"},
  1354. {"UL6_CH2", "GAIN1_OUT_CH2 Switch", "HW Gain 1 Out"},
  1355. {"UL7", NULL, "UL7_CH1"},
  1356. {"UL7", NULL, "UL7_CH2"},
  1357. {"UL7_CH1", "ADDA_UL_CH1 Switch", "ADDA_UL_Mux"},
  1358. {"UL7_CH2", "ADDA_UL_CH2 Switch", "ADDA_UL_Mux"},
  1359. {"UL7_CH1", "HW_GAIN2_OUT_CH1 Switch", "HW Gain 2 Out"},
  1360. {"UL7_CH2", "HW_GAIN2_OUT_CH2 Switch", "HW Gain 2 Out"},
  1361. {"UL7_CH1", "HW_SRC_2_OUT_CH1 Switch", "HW_SRC_2_Out"},
  1362. {"UL7_CH2", "HW_SRC_2_OUT_CH2 Switch", "HW_SRC_2_Out"},
  1363. {"UL8", NULL, "UL8_CH1"},
  1364. {"UL8", NULL, "UL8_CH2"},
  1365. {"UL8_CH1", "ADDA_UL_CH1 Switch", "ADDA_UL_Mux"},
  1366. {"UL8_CH2", "ADDA_UL_CH2 Switch", "ADDA_UL_Mux"},
  1367. {"HW_GAIN2_IN_CH1", "ADDA_UL_CH1 Switch", "ADDA_UL_Mux"},
  1368. {"HW_GAIN2_IN_CH2", "ADDA_UL_CH2 Switch", "ADDA_UL_Mux"},
  1369. };
  1370. static const struct mtk_base_memif_data memif_data[MT8186_MEMIF_NUM] = {
  1371. [MT8186_MEMIF_DL1] = {
  1372. .name = "DL1",
  1373. .id = MT8186_MEMIF_DL1,
  1374. .reg_ofs_base = AFE_DL1_BASE,
  1375. .reg_ofs_cur = AFE_DL1_CUR,
  1376. .reg_ofs_end = AFE_DL1_END,
  1377. .reg_ofs_base_msb = AFE_DL1_BASE_MSB,
  1378. .reg_ofs_cur_msb = AFE_DL1_CUR_MSB,
  1379. .reg_ofs_end_msb = AFE_DL1_END_MSB,
  1380. .fs_reg = AFE_DL1_CON0,
  1381. .fs_shift = DL1_MODE_SFT,
  1382. .fs_maskbit = DL1_MODE_MASK,
  1383. .mono_reg = AFE_DL1_CON0,
  1384. .mono_shift = DL1_MONO_SFT,
  1385. .enable_reg = AFE_DAC_CON0,
  1386. .enable_shift = DL1_ON_SFT,
  1387. .hd_reg = AFE_DL1_CON0,
  1388. .hd_shift = DL1_HD_MODE_SFT,
  1389. .hd_align_reg = AFE_DL1_CON0,
  1390. .hd_align_mshift = DL1_HALIGN_SFT,
  1391. .agent_disable_reg = -1,
  1392. .agent_disable_shift = -1,
  1393. .msb_reg = -1,
  1394. .msb_shift = -1,
  1395. .pbuf_reg = AFE_DL1_CON0,
  1396. .pbuf_mask = DL1_PBUF_SIZE_MASK,
  1397. .pbuf_shift = DL1_PBUF_SIZE_SFT,
  1398. .minlen_reg = AFE_DL1_CON0,
  1399. .minlen_mask = DL1_MINLEN_MASK,
  1400. .minlen_shift = DL1_MINLEN_SFT,
  1401. },
  1402. [MT8186_MEMIF_DL12] = {
  1403. .name = "DL12",
  1404. .id = MT8186_MEMIF_DL12,
  1405. .reg_ofs_base = AFE_DL12_BASE,
  1406. .reg_ofs_cur = AFE_DL12_CUR,
  1407. .reg_ofs_end = AFE_DL12_END,
  1408. .reg_ofs_base_msb = AFE_DL12_BASE_MSB,
  1409. .reg_ofs_cur_msb = AFE_DL12_CUR_MSB,
  1410. .reg_ofs_end_msb = AFE_DL12_END_MSB,
  1411. .fs_reg = AFE_DL12_CON0,
  1412. .fs_shift = DL12_MODE_SFT,
  1413. .fs_maskbit = DL12_MODE_MASK,
  1414. .mono_reg = AFE_DL12_CON0,
  1415. .mono_shift = DL12_MONO_SFT,
  1416. .quad_ch_reg = AFE_DL12_CON0,
  1417. .quad_ch_mask = DL12_4CH_EN_MASK,
  1418. .quad_ch_shift = DL12_4CH_EN_SFT,
  1419. .enable_reg = AFE_DAC_CON0,
  1420. .enable_shift = DL12_ON_SFT,
  1421. .hd_reg = AFE_DL12_CON0,
  1422. .hd_shift = DL12_HD_MODE_SFT,
  1423. .hd_align_reg = AFE_DL12_CON0,
  1424. .hd_align_mshift = DL12_HALIGN_SFT,
  1425. .agent_disable_reg = -1,
  1426. .agent_disable_shift = -1,
  1427. .msb_reg = -1,
  1428. .msb_shift = -1,
  1429. .pbuf_reg = AFE_DL12_CON0,
  1430. .pbuf_mask = DL12_PBUF_SIZE_MASK,
  1431. .pbuf_shift = DL12_PBUF_SIZE_SFT,
  1432. .minlen_reg = AFE_DL12_CON0,
  1433. .minlen_mask = DL12_MINLEN_MASK,
  1434. .minlen_shift = DL12_MINLEN_SFT,
  1435. },
  1436. [MT8186_MEMIF_DL2] = {
  1437. .name = "DL2",
  1438. .id = MT8186_MEMIF_DL2,
  1439. .reg_ofs_base = AFE_DL2_BASE,
  1440. .reg_ofs_cur = AFE_DL2_CUR,
  1441. .reg_ofs_end = AFE_DL2_END,
  1442. .reg_ofs_base_msb = AFE_DL2_BASE_MSB,
  1443. .reg_ofs_cur_msb = AFE_DL2_CUR_MSB,
  1444. .reg_ofs_end_msb = AFE_DL2_END_MSB,
  1445. .fs_reg = AFE_DL2_CON0,
  1446. .fs_shift = DL2_MODE_SFT,
  1447. .fs_maskbit = DL2_MODE_MASK,
  1448. .mono_reg = AFE_DL2_CON0,
  1449. .mono_shift = DL2_MONO_SFT,
  1450. .enable_reg = AFE_DAC_CON0,
  1451. .enable_shift = DL2_ON_SFT,
  1452. .hd_reg = AFE_DL2_CON0,
  1453. .hd_shift = DL2_HD_MODE_SFT,
  1454. .hd_align_reg = AFE_DL2_CON0,
  1455. .hd_align_mshift = DL2_HALIGN_SFT,
  1456. .agent_disable_reg = -1,
  1457. .agent_disable_shift = -1,
  1458. .msb_reg = -1,
  1459. .msb_shift = -1,
  1460. .pbuf_reg = AFE_DL2_CON0,
  1461. .pbuf_mask = DL2_PBUF_SIZE_MASK,
  1462. .pbuf_shift = DL2_PBUF_SIZE_SFT,
  1463. .minlen_reg = AFE_DL2_CON0,
  1464. .minlen_mask = DL2_MINLEN_MASK,
  1465. .minlen_shift = DL2_MINLEN_SFT,
  1466. },
  1467. [MT8186_MEMIF_DL3] = {
  1468. .name = "DL3",
  1469. .id = MT8186_MEMIF_DL3,
  1470. .reg_ofs_base = AFE_DL3_BASE,
  1471. .reg_ofs_cur = AFE_DL3_CUR,
  1472. .reg_ofs_end = AFE_DL3_END,
  1473. .reg_ofs_base_msb = AFE_DL3_BASE_MSB,
  1474. .reg_ofs_cur_msb = AFE_DL3_CUR_MSB,
  1475. .reg_ofs_end_msb = AFE_DL3_END_MSB,
  1476. .fs_reg = AFE_DL3_CON0,
  1477. .fs_shift = DL3_MODE_SFT,
  1478. .fs_maskbit = DL3_MODE_MASK,
  1479. .mono_reg = AFE_DL3_CON0,
  1480. .mono_shift = DL3_MONO_SFT,
  1481. .enable_reg = AFE_DAC_CON0,
  1482. .enable_shift = DL3_ON_SFT,
  1483. .hd_reg = AFE_DL3_CON0,
  1484. .hd_shift = DL3_HD_MODE_SFT,
  1485. .hd_align_reg = AFE_DL3_CON0,
  1486. .hd_align_mshift = DL3_HALIGN_SFT,
  1487. .agent_disable_reg = -1,
  1488. .agent_disable_shift = -1,
  1489. .msb_reg = -1,
  1490. .msb_shift = -1,
  1491. .pbuf_reg = AFE_DL3_CON0,
  1492. .pbuf_mask = DL3_PBUF_SIZE_MASK,
  1493. .pbuf_shift = DL3_PBUF_SIZE_SFT,
  1494. .minlen_reg = AFE_DL3_CON0,
  1495. .minlen_mask = DL3_MINLEN_MASK,
  1496. .minlen_shift = DL3_MINLEN_SFT,
  1497. },
  1498. [MT8186_MEMIF_DL4] = {
  1499. .name = "DL4",
  1500. .id = MT8186_MEMIF_DL4,
  1501. .reg_ofs_base = AFE_DL4_BASE,
  1502. .reg_ofs_cur = AFE_DL4_CUR,
  1503. .reg_ofs_end = AFE_DL4_END,
  1504. .reg_ofs_base_msb = AFE_DL4_BASE_MSB,
  1505. .reg_ofs_cur_msb = AFE_DL4_CUR_MSB,
  1506. .reg_ofs_end_msb = AFE_DL4_END_MSB,
  1507. .fs_reg = AFE_DL4_CON0,
  1508. .fs_shift = DL4_MODE_SFT,
  1509. .fs_maskbit = DL4_MODE_MASK,
  1510. .mono_reg = AFE_DL4_CON0,
  1511. .mono_shift = DL4_MONO_SFT,
  1512. .enable_reg = AFE_DAC_CON0,
  1513. .enable_shift = DL4_ON_SFT,
  1514. .hd_reg = AFE_DL4_CON0,
  1515. .hd_shift = DL4_HD_MODE_SFT,
  1516. .hd_align_reg = AFE_DL4_CON0,
  1517. .hd_align_mshift = DL4_HALIGN_SFT,
  1518. .agent_disable_reg = -1,
  1519. .agent_disable_shift = -1,
  1520. .msb_reg = -1,
  1521. .msb_shift = -1,
  1522. .pbuf_reg = AFE_DL4_CON0,
  1523. .pbuf_mask = DL4_PBUF_SIZE_MASK,
  1524. .pbuf_shift = DL4_PBUF_SIZE_SFT,
  1525. .minlen_reg = AFE_DL4_CON0,
  1526. .minlen_mask = DL4_MINLEN_MASK,
  1527. .minlen_shift = DL4_MINLEN_SFT,
  1528. },
  1529. [MT8186_MEMIF_DL5] = {
  1530. .name = "DL5",
  1531. .id = MT8186_MEMIF_DL5,
  1532. .reg_ofs_base = AFE_DL5_BASE,
  1533. .reg_ofs_cur = AFE_DL5_CUR,
  1534. .reg_ofs_end = AFE_DL5_END,
  1535. .reg_ofs_base_msb = AFE_DL5_BASE_MSB,
  1536. .reg_ofs_cur_msb = AFE_DL5_CUR_MSB,
  1537. .reg_ofs_end_msb = AFE_DL5_END_MSB,
  1538. .fs_reg = AFE_DL5_CON0,
  1539. .fs_shift = DL5_MODE_SFT,
  1540. .fs_maskbit = DL5_MODE_MASK,
  1541. .mono_reg = AFE_DL5_CON0,
  1542. .mono_shift = DL5_MONO_SFT,
  1543. .enable_reg = AFE_DAC_CON0,
  1544. .enable_shift = DL5_ON_SFT,
  1545. .hd_reg = AFE_DL5_CON0,
  1546. .hd_shift = DL5_HD_MODE_SFT,
  1547. .hd_align_reg = AFE_DL5_CON0,
  1548. .hd_align_mshift = DL5_HALIGN_SFT,
  1549. .agent_disable_reg = -1,
  1550. .agent_disable_shift = -1,
  1551. .msb_reg = -1,
  1552. .msb_shift = -1,
  1553. .pbuf_reg = AFE_DL5_CON0,
  1554. .pbuf_mask = DL5_PBUF_SIZE_MASK,
  1555. .pbuf_shift = DL5_PBUF_SIZE_SFT,
  1556. .minlen_reg = AFE_DL5_CON0,
  1557. .minlen_mask = DL5_MINLEN_MASK,
  1558. .minlen_shift = DL5_MINLEN_SFT,
  1559. },
  1560. [MT8186_MEMIF_DL6] = {
  1561. .name = "DL6",
  1562. .id = MT8186_MEMIF_DL6,
  1563. .reg_ofs_base = AFE_DL6_BASE,
  1564. .reg_ofs_cur = AFE_DL6_CUR,
  1565. .reg_ofs_end = AFE_DL6_END,
  1566. .reg_ofs_base_msb = AFE_DL6_BASE_MSB,
  1567. .reg_ofs_cur_msb = AFE_DL6_CUR_MSB,
  1568. .reg_ofs_end_msb = AFE_DL6_END_MSB,
  1569. .fs_reg = AFE_DL6_CON0,
  1570. .fs_shift = DL6_MODE_SFT,
  1571. .fs_maskbit = DL6_MODE_MASK,
  1572. .mono_reg = AFE_DL6_CON0,
  1573. .mono_shift = DL6_MONO_SFT,
  1574. .enable_reg = AFE_DAC_CON0,
  1575. .enable_shift = DL6_ON_SFT,
  1576. .hd_reg = AFE_DL6_CON0,
  1577. .hd_shift = DL6_HD_MODE_SFT,
  1578. .hd_align_reg = AFE_DL6_CON0,
  1579. .hd_align_mshift = DL6_HALIGN_SFT,
  1580. .agent_disable_reg = -1,
  1581. .agent_disable_shift = -1,
  1582. .msb_reg = -1,
  1583. .msb_shift = -1,
  1584. .pbuf_reg = AFE_DL6_CON0,
  1585. .pbuf_mask = DL6_PBUF_SIZE_MASK,
  1586. .pbuf_shift = DL6_PBUF_SIZE_SFT,
  1587. .minlen_reg = AFE_DL6_CON0,
  1588. .minlen_mask = DL6_MINLEN_MASK,
  1589. .minlen_shift = DL6_MINLEN_SFT,
  1590. },
  1591. [MT8186_MEMIF_DL7] = {
  1592. .name = "DL7",
  1593. .id = MT8186_MEMIF_DL7,
  1594. .reg_ofs_base = AFE_DL7_BASE,
  1595. .reg_ofs_cur = AFE_DL7_CUR,
  1596. .reg_ofs_end = AFE_DL7_END,
  1597. .reg_ofs_base_msb = AFE_DL7_BASE_MSB,
  1598. .reg_ofs_cur_msb = AFE_DL7_CUR_MSB,
  1599. .reg_ofs_end_msb = AFE_DL7_END_MSB,
  1600. .fs_reg = AFE_DL7_CON0,
  1601. .fs_shift = DL7_MODE_SFT,
  1602. .fs_maskbit = DL7_MODE_MASK,
  1603. .mono_reg = AFE_DL7_CON0,
  1604. .mono_shift = DL7_MONO_SFT,
  1605. .enable_reg = AFE_DAC_CON0,
  1606. .enable_shift = DL7_ON_SFT,
  1607. .hd_reg = AFE_DL7_CON0,
  1608. .hd_shift = DL7_HD_MODE_SFT,
  1609. .hd_align_reg = AFE_DL7_CON0,
  1610. .hd_align_mshift = DL7_HALIGN_SFT,
  1611. .agent_disable_reg = -1,
  1612. .agent_disable_shift = -1,
  1613. .msb_reg = -1,
  1614. .msb_shift = -1,
  1615. .pbuf_reg = AFE_DL7_CON0,
  1616. .pbuf_mask = DL7_PBUF_SIZE_MASK,
  1617. .pbuf_shift = DL7_PBUF_SIZE_SFT,
  1618. .minlen_reg = AFE_DL7_CON0,
  1619. .minlen_mask = DL7_MINLEN_MASK,
  1620. .minlen_shift = DL7_MINLEN_SFT,
  1621. },
  1622. [MT8186_MEMIF_DL8] = {
  1623. .name = "DL8",
  1624. .id = MT8186_MEMIF_DL8,
  1625. .reg_ofs_base = AFE_DL8_BASE,
  1626. .reg_ofs_cur = AFE_DL8_CUR,
  1627. .reg_ofs_end = AFE_DL8_END,
  1628. .reg_ofs_base_msb = AFE_DL8_BASE_MSB,
  1629. .reg_ofs_cur_msb = AFE_DL8_CUR_MSB,
  1630. .reg_ofs_end_msb = AFE_DL8_END_MSB,
  1631. .fs_reg = AFE_DL8_CON0,
  1632. .fs_shift = DL8_MODE_SFT,
  1633. .fs_maskbit = DL8_MODE_MASK,
  1634. .mono_reg = AFE_DL8_CON0,
  1635. .mono_shift = DL8_MONO_SFT,
  1636. .enable_reg = AFE_DAC_CON0,
  1637. .enable_shift = DL8_ON_SFT,
  1638. .hd_reg = AFE_DL8_CON0,
  1639. .hd_shift = DL8_HD_MODE_SFT,
  1640. .hd_align_reg = AFE_DL8_CON0,
  1641. .hd_align_mshift = DL8_HALIGN_SFT,
  1642. .agent_disable_reg = -1,
  1643. .agent_disable_shift = -1,
  1644. .msb_reg = -1,
  1645. .msb_shift = -1,
  1646. .pbuf_reg = AFE_DL8_CON0,
  1647. .pbuf_mask = DL8_PBUF_SIZE_MASK,
  1648. .pbuf_shift = DL8_PBUF_SIZE_SFT,
  1649. .minlen_reg = AFE_DL8_CON0,
  1650. .minlen_mask = DL8_MINLEN_MASK,
  1651. .minlen_shift = DL8_MINLEN_SFT,
  1652. },
  1653. [MT8186_MEMIF_VUL12] = {
  1654. .name = "VUL12",
  1655. .id = MT8186_MEMIF_VUL12,
  1656. .reg_ofs_base = AFE_VUL12_BASE,
  1657. .reg_ofs_cur = AFE_VUL12_CUR,
  1658. .reg_ofs_end = AFE_VUL12_END,
  1659. .reg_ofs_base_msb = AFE_VUL12_BASE_MSB,
  1660. .reg_ofs_cur_msb = AFE_VUL12_CUR_MSB,
  1661. .reg_ofs_end_msb = AFE_VUL12_END_MSB,
  1662. .fs_reg = AFE_VUL12_CON0,
  1663. .fs_shift = VUL12_MODE_SFT,
  1664. .fs_maskbit = VUL12_MODE_MASK,
  1665. .mono_reg = AFE_VUL12_CON0,
  1666. .mono_shift = VUL12_MONO_SFT,
  1667. .quad_ch_reg = AFE_VUL12_CON0,
  1668. .quad_ch_mask = VUL12_4CH_EN_MASK,
  1669. .quad_ch_shift = VUL12_4CH_EN_SFT,
  1670. .enable_reg = AFE_DAC_CON0,
  1671. .enable_shift = VUL12_ON_SFT,
  1672. .hd_reg = AFE_VUL12_CON0,
  1673. .hd_shift = VUL12_HD_MODE_SFT,
  1674. .hd_align_reg = AFE_VUL12_CON0,
  1675. .hd_align_mshift = VUL12_HALIGN_SFT,
  1676. .agent_disable_reg = -1,
  1677. .agent_disable_shift = -1,
  1678. .msb_reg = -1,
  1679. .msb_shift = -1,
  1680. },
  1681. [MT8186_MEMIF_VUL2] = {
  1682. .name = "VUL2",
  1683. .id = MT8186_MEMIF_VUL2,
  1684. .reg_ofs_base = AFE_VUL2_BASE,
  1685. .reg_ofs_cur = AFE_VUL2_CUR,
  1686. .reg_ofs_end = AFE_VUL2_END,
  1687. .reg_ofs_base_msb = AFE_VUL2_BASE_MSB,
  1688. .reg_ofs_cur_msb = AFE_VUL2_CUR_MSB,
  1689. .reg_ofs_end_msb = AFE_VUL2_END_MSB,
  1690. .fs_reg = AFE_VUL2_CON0,
  1691. .fs_shift = VUL2_MODE_SFT,
  1692. .fs_maskbit = VUL2_MODE_MASK,
  1693. .mono_reg = AFE_VUL2_CON0,
  1694. .mono_shift = VUL2_MONO_SFT,
  1695. .enable_reg = AFE_DAC_CON0,
  1696. .enable_shift = VUL2_ON_SFT,
  1697. .hd_reg = AFE_VUL2_CON0,
  1698. .hd_shift = VUL2_HD_MODE_SFT,
  1699. .hd_align_reg = AFE_VUL2_CON0,
  1700. .hd_align_mshift = VUL2_HALIGN_SFT,
  1701. .agent_disable_reg = -1,
  1702. .agent_disable_shift = -1,
  1703. .msb_reg = -1,
  1704. .msb_shift = -1,
  1705. },
  1706. [MT8186_MEMIF_AWB] = {
  1707. .name = "AWB",
  1708. .id = MT8186_MEMIF_AWB,
  1709. .reg_ofs_base = AFE_AWB_BASE,
  1710. .reg_ofs_cur = AFE_AWB_CUR,
  1711. .reg_ofs_end = AFE_AWB_END,
  1712. .reg_ofs_base_msb = AFE_AWB_BASE_MSB,
  1713. .reg_ofs_cur_msb = AFE_AWB_CUR_MSB,
  1714. .reg_ofs_end_msb = AFE_AWB_END_MSB,
  1715. .fs_reg = AFE_AWB_CON0,
  1716. .fs_shift = AWB_MODE_SFT,
  1717. .fs_maskbit = AWB_MODE_MASK,
  1718. .mono_reg = AFE_AWB_CON0,
  1719. .mono_shift = AWB_MONO_SFT,
  1720. .enable_reg = AFE_DAC_CON0,
  1721. .enable_shift = AWB_ON_SFT,
  1722. .hd_reg = AFE_AWB_CON0,
  1723. .hd_shift = AWB_HD_MODE_SFT,
  1724. .hd_align_reg = AFE_AWB_CON0,
  1725. .hd_align_mshift = AWB_HALIGN_SFT,
  1726. .agent_disable_reg = -1,
  1727. .agent_disable_shift = -1,
  1728. .msb_reg = -1,
  1729. .msb_shift = -1,
  1730. },
  1731. [MT8186_MEMIF_AWB2] = {
  1732. .name = "AWB2",
  1733. .id = MT8186_MEMIF_AWB2,
  1734. .reg_ofs_base = AFE_AWB2_BASE,
  1735. .reg_ofs_cur = AFE_AWB2_CUR,
  1736. .reg_ofs_end = AFE_AWB2_END,
  1737. .reg_ofs_base_msb = AFE_AWB2_BASE_MSB,
  1738. .reg_ofs_cur_msb = AFE_AWB2_CUR_MSB,
  1739. .reg_ofs_end_msb = AFE_AWB2_END_MSB,
  1740. .fs_reg = AFE_AWB2_CON0,
  1741. .fs_shift = AWB2_MODE_SFT,
  1742. .fs_maskbit = AWB2_MODE_MASK,
  1743. .mono_reg = AFE_AWB2_CON0,
  1744. .mono_shift = AWB2_MONO_SFT,
  1745. .enable_reg = AFE_DAC_CON0,
  1746. .enable_shift = AWB2_ON_SFT,
  1747. .hd_reg = AFE_AWB2_CON0,
  1748. .hd_shift = AWB2_HD_MODE_SFT,
  1749. .hd_align_reg = AFE_AWB2_CON0,
  1750. .hd_align_mshift = AWB2_HALIGN_SFT,
  1751. .agent_disable_reg = -1,
  1752. .agent_disable_shift = -1,
  1753. .msb_reg = -1,
  1754. .msb_shift = -1,
  1755. },
  1756. [MT8186_MEMIF_VUL3] = {
  1757. .name = "VUL3",
  1758. .id = MT8186_MEMIF_VUL3,
  1759. .reg_ofs_base = AFE_VUL3_BASE,
  1760. .reg_ofs_cur = AFE_VUL3_CUR,
  1761. .reg_ofs_end = AFE_VUL3_END,
  1762. .reg_ofs_base_msb = AFE_VUL3_BASE_MSB,
  1763. .reg_ofs_cur_msb = AFE_VUL3_CUR_MSB,
  1764. .reg_ofs_end_msb = AFE_VUL3_END_MSB,
  1765. .fs_reg = AFE_VUL3_CON0,
  1766. .fs_shift = VUL3_MODE_SFT,
  1767. .fs_maskbit = VUL3_MODE_MASK,
  1768. .mono_reg = AFE_VUL3_CON0,
  1769. .mono_shift = VUL3_MONO_SFT,
  1770. .enable_reg = AFE_DAC_CON0,
  1771. .enable_shift = VUL3_ON_SFT,
  1772. .hd_reg = AFE_VUL3_CON0,
  1773. .hd_shift = VUL3_HD_MODE_SFT,
  1774. .hd_align_reg = AFE_VUL3_CON0,
  1775. .hd_align_mshift = VUL3_HALIGN_SFT,
  1776. .agent_disable_reg = -1,
  1777. .agent_disable_shift = -1,
  1778. .msb_reg = -1,
  1779. .msb_shift = -1,
  1780. },
  1781. [MT8186_MEMIF_VUL4] = {
  1782. .name = "VUL4",
  1783. .id = MT8186_MEMIF_VUL4,
  1784. .reg_ofs_base = AFE_VUL4_BASE,
  1785. .reg_ofs_cur = AFE_VUL4_CUR,
  1786. .reg_ofs_end = AFE_VUL4_END,
  1787. .reg_ofs_base_msb = AFE_VUL4_BASE_MSB,
  1788. .reg_ofs_cur_msb = AFE_VUL4_CUR_MSB,
  1789. .reg_ofs_end_msb = AFE_VUL4_END_MSB,
  1790. .fs_reg = AFE_VUL4_CON0,
  1791. .fs_shift = VUL4_MODE_SFT,
  1792. .fs_maskbit = VUL4_MODE_MASK,
  1793. .mono_reg = AFE_VUL4_CON0,
  1794. .mono_shift = VUL4_MONO_SFT,
  1795. .enable_reg = AFE_DAC_CON0,
  1796. .enable_shift = VUL4_ON_SFT,
  1797. .hd_reg = AFE_VUL4_CON0,
  1798. .hd_shift = VUL4_HD_MODE_SFT,
  1799. .hd_align_reg = AFE_VUL4_CON0,
  1800. .hd_align_mshift = VUL4_HALIGN_SFT,
  1801. .agent_disable_reg = -1,
  1802. .agent_disable_shift = -1,
  1803. .msb_reg = -1,
  1804. .msb_shift = -1,
  1805. },
  1806. [MT8186_MEMIF_VUL5] = {
  1807. .name = "VUL5",
  1808. .id = MT8186_MEMIF_VUL5,
  1809. .reg_ofs_base = AFE_VUL5_BASE,
  1810. .reg_ofs_cur = AFE_VUL5_CUR,
  1811. .reg_ofs_end = AFE_VUL5_END,
  1812. .reg_ofs_base_msb = AFE_VUL5_BASE_MSB,
  1813. .reg_ofs_cur_msb = AFE_VUL5_CUR_MSB,
  1814. .reg_ofs_end_msb = AFE_VUL5_END_MSB,
  1815. .fs_reg = AFE_VUL5_CON0,
  1816. .fs_shift = VUL5_MODE_SFT,
  1817. .fs_maskbit = VUL5_MODE_MASK,
  1818. .mono_reg = AFE_VUL5_CON0,
  1819. .mono_shift = VUL5_MONO_SFT,
  1820. .enable_reg = AFE_DAC_CON0,
  1821. .enable_shift = VUL5_ON_SFT,
  1822. .hd_reg = AFE_VUL5_CON0,
  1823. .hd_shift = VUL5_HD_MODE_SFT,
  1824. .hd_align_reg = AFE_VUL5_CON0,
  1825. .hd_align_mshift = VUL5_HALIGN_SFT,
  1826. .agent_disable_reg = -1,
  1827. .agent_disable_shift = -1,
  1828. .msb_reg = -1,
  1829. .msb_shift = -1,
  1830. },
  1831. [MT8186_MEMIF_VUL6] = {
  1832. .name = "VUL6",
  1833. .id = MT8186_MEMIF_VUL6,
  1834. .reg_ofs_base = AFE_VUL6_BASE,
  1835. .reg_ofs_cur = AFE_VUL6_CUR,
  1836. .reg_ofs_end = AFE_VUL6_END,
  1837. .reg_ofs_base_msb = AFE_VUL6_BASE_MSB,
  1838. .reg_ofs_cur_msb = AFE_VUL6_CUR_MSB,
  1839. .reg_ofs_end_msb = AFE_VUL6_END_MSB,
  1840. .fs_reg = AFE_VUL6_CON0,
  1841. .fs_shift = VUL6_MODE_SFT,
  1842. .fs_maskbit = VUL6_MODE_MASK,
  1843. .mono_reg = AFE_VUL6_CON0,
  1844. .mono_shift = VUL6_MONO_SFT,
  1845. .enable_reg = AFE_DAC_CON0,
  1846. .enable_shift = VUL6_ON_SFT,
  1847. .hd_reg = AFE_VUL6_CON0,
  1848. .hd_shift = VUL6_HD_MODE_SFT,
  1849. .hd_align_reg = AFE_VUL6_CON0,
  1850. .hd_align_mshift = VUL6_HALIGN_SFT,
  1851. .agent_disable_reg = -1,
  1852. .agent_disable_shift = -1,
  1853. .msb_reg = -1,
  1854. .msb_shift = -1,
  1855. },
  1856. };
  1857. static const struct mtk_base_irq_data irq_data[MT8186_IRQ_NUM] = {
  1858. [MT8186_IRQ_0] = {
  1859. .id = MT8186_IRQ_0,
  1860. .irq_cnt_reg = AFE_IRQ_MCU_CNT0,
  1861. .irq_cnt_shift = AFE_IRQ_CNT_SHIFT,
  1862. .irq_cnt_maskbit = AFE_IRQ_CNT_MASK,
  1863. .irq_fs_reg = AFE_IRQ_MCU_CON1,
  1864. .irq_fs_shift = IRQ0_MCU_MODE_SFT,
  1865. .irq_fs_maskbit = IRQ0_MCU_MODE_MASK,
  1866. .irq_en_reg = AFE_IRQ_MCU_CON0,
  1867. .irq_en_shift = IRQ0_MCU_ON_SFT,
  1868. .irq_clr_reg = AFE_IRQ_MCU_CLR,
  1869. .irq_clr_shift = IRQ0_MCU_CLR_SFT,
  1870. },
  1871. [MT8186_IRQ_1] = {
  1872. .id = MT8186_IRQ_1,
  1873. .irq_cnt_reg = AFE_IRQ_MCU_CNT1,
  1874. .irq_cnt_shift = AFE_IRQ_CNT_SHIFT,
  1875. .irq_cnt_maskbit = AFE_IRQ_CNT_MASK,
  1876. .irq_fs_reg = AFE_IRQ_MCU_CON1,
  1877. .irq_fs_shift = IRQ1_MCU_MODE_SFT,
  1878. .irq_fs_maskbit = IRQ1_MCU_MODE_MASK,
  1879. .irq_en_reg = AFE_IRQ_MCU_CON0,
  1880. .irq_en_shift = IRQ1_MCU_ON_SFT,
  1881. .irq_clr_reg = AFE_IRQ_MCU_CLR,
  1882. .irq_clr_shift = IRQ1_MCU_CLR_SFT,
  1883. },
  1884. [MT8186_IRQ_2] = {
  1885. .id = MT8186_IRQ_2,
  1886. .irq_cnt_reg = AFE_IRQ_MCU_CNT2,
  1887. .irq_cnt_shift = AFE_IRQ_CNT_SHIFT,
  1888. .irq_cnt_maskbit = AFE_IRQ_CNT_MASK,
  1889. .irq_fs_reg = AFE_IRQ_MCU_CON1,
  1890. .irq_fs_shift = IRQ2_MCU_MODE_SFT,
  1891. .irq_fs_maskbit = IRQ2_MCU_MODE_MASK,
  1892. .irq_en_reg = AFE_IRQ_MCU_CON0,
  1893. .irq_en_shift = IRQ2_MCU_ON_SFT,
  1894. .irq_clr_reg = AFE_IRQ_MCU_CLR,
  1895. .irq_clr_shift = IRQ2_MCU_CLR_SFT,
  1896. },
  1897. [MT8186_IRQ_3] = {
  1898. .id = MT8186_IRQ_3,
  1899. .irq_cnt_reg = AFE_IRQ_MCU_CNT3,
  1900. .irq_cnt_shift = AFE_IRQ_CNT_SHIFT,
  1901. .irq_cnt_maskbit = AFE_IRQ_CNT_MASK,
  1902. .irq_fs_reg = AFE_IRQ_MCU_CON1,
  1903. .irq_fs_shift = IRQ3_MCU_MODE_SFT,
  1904. .irq_fs_maskbit = IRQ3_MCU_MODE_MASK,
  1905. .irq_en_reg = AFE_IRQ_MCU_CON0,
  1906. .irq_en_shift = IRQ3_MCU_ON_SFT,
  1907. .irq_clr_reg = AFE_IRQ_MCU_CLR,
  1908. .irq_clr_shift = IRQ3_MCU_CLR_SFT,
  1909. },
  1910. [MT8186_IRQ_4] = {
  1911. .id = MT8186_IRQ_4,
  1912. .irq_cnt_reg = AFE_IRQ_MCU_CNT4,
  1913. .irq_cnt_shift = AFE_IRQ_CNT_SHIFT,
  1914. .irq_cnt_maskbit = AFE_IRQ_CNT_MASK,
  1915. .irq_fs_reg = AFE_IRQ_MCU_CON1,
  1916. .irq_fs_shift = IRQ4_MCU_MODE_SFT,
  1917. .irq_fs_maskbit = IRQ4_MCU_MODE_MASK,
  1918. .irq_en_reg = AFE_IRQ_MCU_CON0,
  1919. .irq_en_shift = IRQ4_MCU_ON_SFT,
  1920. .irq_clr_reg = AFE_IRQ_MCU_CLR,
  1921. .irq_clr_shift = IRQ4_MCU_CLR_SFT,
  1922. },
  1923. [MT8186_IRQ_5] = {
  1924. .id = MT8186_IRQ_5,
  1925. .irq_cnt_reg = AFE_IRQ_MCU_CNT5,
  1926. .irq_cnt_shift = AFE_IRQ_CNT_SHIFT,
  1927. .irq_cnt_maskbit = AFE_IRQ_CNT_MASK,
  1928. .irq_fs_reg = AFE_IRQ_MCU_CON1,
  1929. .irq_fs_shift = IRQ5_MCU_MODE_SFT,
  1930. .irq_fs_maskbit = IRQ5_MCU_MODE_MASK,
  1931. .irq_en_reg = AFE_IRQ_MCU_CON0,
  1932. .irq_en_shift = IRQ5_MCU_ON_SFT,
  1933. .irq_clr_reg = AFE_IRQ_MCU_CLR,
  1934. .irq_clr_shift = IRQ5_MCU_CLR_SFT,
  1935. },
  1936. [MT8186_IRQ_6] = {
  1937. .id = MT8186_IRQ_6,
  1938. .irq_cnt_reg = AFE_IRQ_MCU_CNT6,
  1939. .irq_cnt_shift = AFE_IRQ_CNT_SHIFT,
  1940. .irq_cnt_maskbit = AFE_IRQ_CNT_MASK,
  1941. .irq_fs_reg = AFE_IRQ_MCU_CON1,
  1942. .irq_fs_shift = IRQ6_MCU_MODE_SFT,
  1943. .irq_fs_maskbit = IRQ6_MCU_MODE_MASK,
  1944. .irq_en_reg = AFE_IRQ_MCU_CON0,
  1945. .irq_en_shift = IRQ6_MCU_ON_SFT,
  1946. .irq_clr_reg = AFE_IRQ_MCU_CLR,
  1947. .irq_clr_shift = IRQ6_MCU_CLR_SFT,
  1948. },
  1949. [MT8186_IRQ_7] = {
  1950. .id = MT8186_IRQ_7,
  1951. .irq_cnt_reg = AFE_IRQ_MCU_CNT7,
  1952. .irq_cnt_shift = AFE_IRQ_CNT_SHIFT,
  1953. .irq_cnt_maskbit = AFE_IRQ_CNT_MASK,
  1954. .irq_fs_reg = AFE_IRQ_MCU_CON1,
  1955. .irq_fs_shift = IRQ7_MCU_MODE_SFT,
  1956. .irq_fs_maskbit = IRQ7_MCU_MODE_MASK,
  1957. .irq_en_reg = AFE_IRQ_MCU_CON0,
  1958. .irq_en_shift = IRQ7_MCU_ON_SFT,
  1959. .irq_clr_reg = AFE_IRQ_MCU_CLR,
  1960. .irq_clr_shift = IRQ7_MCU_CLR_SFT,
  1961. },
  1962. [MT8186_IRQ_8] = {
  1963. .id = MT8186_IRQ_8,
  1964. .irq_cnt_reg = AFE_IRQ_MCU_CNT8,
  1965. .irq_cnt_shift = AFE_IRQ_CNT_SHIFT,
  1966. .irq_cnt_maskbit = AFE_IRQ_CNT_MASK,
  1967. .irq_fs_reg = AFE_IRQ_MCU_CON2,
  1968. .irq_fs_shift = IRQ8_MCU_MODE_SFT,
  1969. .irq_fs_maskbit = IRQ8_MCU_MODE_MASK,
  1970. .irq_en_reg = AFE_IRQ_MCU_CON0,
  1971. .irq_en_shift = IRQ8_MCU_ON_SFT,
  1972. .irq_clr_reg = AFE_IRQ_MCU_CLR,
  1973. .irq_clr_shift = IRQ8_MCU_CLR_SFT,
  1974. },
  1975. [MT8186_IRQ_9] = {
  1976. .id = MT8186_IRQ_9,
  1977. .irq_cnt_reg = AFE_IRQ_MCU_CNT9,
  1978. .irq_cnt_shift = AFE_IRQ_CNT_SHIFT,
  1979. .irq_cnt_maskbit = AFE_IRQ_CNT_MASK,
  1980. .irq_fs_reg = AFE_IRQ_MCU_CON2,
  1981. .irq_fs_shift = IRQ9_MCU_MODE_SFT,
  1982. .irq_fs_maskbit = IRQ9_MCU_MODE_MASK,
  1983. .irq_en_reg = AFE_IRQ_MCU_CON0,
  1984. .irq_en_shift = IRQ9_MCU_ON_SFT,
  1985. .irq_clr_reg = AFE_IRQ_MCU_CLR,
  1986. .irq_clr_shift = IRQ9_MCU_CLR_SFT,
  1987. },
  1988. [MT8186_IRQ_10] = {
  1989. .id = MT8186_IRQ_10,
  1990. .irq_cnt_reg = AFE_IRQ_MCU_CNT10,
  1991. .irq_cnt_shift = AFE_IRQ_CNT_SHIFT,
  1992. .irq_cnt_maskbit = AFE_IRQ_CNT_MASK,
  1993. .irq_fs_reg = AFE_IRQ_MCU_CON2,
  1994. .irq_fs_shift = IRQ10_MCU_MODE_SFT,
  1995. .irq_fs_maskbit = IRQ10_MCU_MODE_MASK,
  1996. .irq_en_reg = AFE_IRQ_MCU_CON0,
  1997. .irq_en_shift = IRQ10_MCU_ON_SFT,
  1998. .irq_clr_reg = AFE_IRQ_MCU_CLR,
  1999. .irq_clr_shift = IRQ10_MCU_CLR_SFT,
  2000. },
  2001. [MT8186_IRQ_11] = {
  2002. .id = MT8186_IRQ_11,
  2003. .irq_cnt_reg = AFE_IRQ_MCU_CNT11,
  2004. .irq_cnt_shift = AFE_IRQ_CNT_SHIFT,
  2005. .irq_cnt_maskbit = AFE_IRQ_CNT_MASK,
  2006. .irq_fs_reg = AFE_IRQ_MCU_CON2,
  2007. .irq_fs_shift = IRQ11_MCU_MODE_SFT,
  2008. .irq_fs_maskbit = IRQ11_MCU_MODE_MASK,
  2009. .irq_en_reg = AFE_IRQ_MCU_CON0,
  2010. .irq_en_shift = IRQ11_MCU_ON_SFT,
  2011. .irq_clr_reg = AFE_IRQ_MCU_CLR,
  2012. .irq_clr_shift = IRQ11_MCU_CLR_SFT,
  2013. },
  2014. [MT8186_IRQ_12] = {
  2015. .id = MT8186_IRQ_12,
  2016. .irq_cnt_reg = AFE_IRQ_MCU_CNT12,
  2017. .irq_cnt_shift = AFE_IRQ_CNT_SHIFT,
  2018. .irq_cnt_maskbit = AFE_IRQ_CNT_MASK,
  2019. .irq_fs_reg = AFE_IRQ_MCU_CON2,
  2020. .irq_fs_shift = IRQ12_MCU_MODE_SFT,
  2021. .irq_fs_maskbit = IRQ12_MCU_MODE_MASK,
  2022. .irq_en_reg = AFE_IRQ_MCU_CON0,
  2023. .irq_en_shift = IRQ12_MCU_ON_SFT,
  2024. .irq_clr_reg = AFE_IRQ_MCU_CLR,
  2025. .irq_clr_shift = IRQ12_MCU_CLR_SFT,
  2026. },
  2027. [MT8186_IRQ_13] = {
  2028. .id = MT8186_IRQ_13,
  2029. .irq_cnt_reg = AFE_IRQ_MCU_CNT13,
  2030. .irq_cnt_shift = AFE_IRQ_CNT_SHIFT,
  2031. .irq_cnt_maskbit = AFE_IRQ_CNT_MASK,
  2032. .irq_fs_reg = AFE_IRQ_MCU_CON2,
  2033. .irq_fs_shift = IRQ13_MCU_MODE_SFT,
  2034. .irq_fs_maskbit = IRQ13_MCU_MODE_MASK,
  2035. .irq_en_reg = AFE_IRQ_MCU_CON0,
  2036. .irq_en_shift = IRQ13_MCU_ON_SFT,
  2037. .irq_clr_reg = AFE_IRQ_MCU_CLR,
  2038. .irq_clr_shift = IRQ13_MCU_CLR_SFT,
  2039. },
  2040. [MT8186_IRQ_14] = {
  2041. .id = MT8186_IRQ_14,
  2042. .irq_cnt_reg = AFE_IRQ_MCU_CNT14,
  2043. .irq_cnt_shift = AFE_IRQ_CNT_SHIFT,
  2044. .irq_cnt_maskbit = AFE_IRQ_CNT_MASK,
  2045. .irq_fs_reg = AFE_IRQ_MCU_CON2,
  2046. .irq_fs_shift = IRQ14_MCU_MODE_SFT,
  2047. .irq_fs_maskbit = IRQ14_MCU_MODE_MASK,
  2048. .irq_en_reg = AFE_IRQ_MCU_CON0,
  2049. .irq_en_shift = IRQ14_MCU_ON_SFT,
  2050. .irq_clr_reg = AFE_IRQ_MCU_CLR,
  2051. .irq_clr_shift = IRQ14_MCU_CLR_SFT,
  2052. },
  2053. [MT8186_IRQ_15] = {
  2054. .id = MT8186_IRQ_15,
  2055. .irq_cnt_reg = AFE_IRQ_MCU_CNT15,
  2056. .irq_cnt_shift = AFE_IRQ_CNT_SHIFT,
  2057. .irq_cnt_maskbit = AFE_IRQ_CNT_MASK,
  2058. .irq_fs_reg = AFE_IRQ_MCU_CON2,
  2059. .irq_fs_shift = IRQ15_MCU_MODE_SFT,
  2060. .irq_fs_maskbit = IRQ15_MCU_MODE_MASK,
  2061. .irq_en_reg = AFE_IRQ_MCU_CON0,
  2062. .irq_en_shift = IRQ15_MCU_ON_SFT,
  2063. .irq_clr_reg = AFE_IRQ_MCU_CLR,
  2064. .irq_clr_shift = IRQ15_MCU_CLR_SFT,
  2065. },
  2066. [MT8186_IRQ_16] = {
  2067. .id = MT8186_IRQ_16,
  2068. .irq_cnt_reg = AFE_IRQ_MCU_CNT16,
  2069. .irq_cnt_shift = AFE_IRQ_CNT_SHIFT,
  2070. .irq_cnt_maskbit = AFE_IRQ_CNT_MASK,
  2071. .irq_fs_reg = AFE_IRQ_MCU_CON3,
  2072. .irq_fs_shift = IRQ16_MCU_MODE_SFT,
  2073. .irq_fs_maskbit = IRQ16_MCU_MODE_MASK,
  2074. .irq_en_reg = AFE_IRQ_MCU_CON0,
  2075. .irq_en_shift = IRQ16_MCU_ON_SFT,
  2076. .irq_clr_reg = AFE_IRQ_MCU_CLR,
  2077. .irq_clr_shift = IRQ16_MCU_CLR_SFT,
  2078. },
  2079. [MT8186_IRQ_17] = {
  2080. .id = MT8186_IRQ_17,
  2081. .irq_cnt_reg = AFE_IRQ_MCU_CNT17,
  2082. .irq_cnt_shift = AFE_IRQ_CNT_SHIFT,
  2083. .irq_cnt_maskbit = AFE_IRQ_CNT_MASK,
  2084. .irq_fs_reg = AFE_IRQ_MCU_CON3,
  2085. .irq_fs_shift = IRQ17_MCU_MODE_SFT,
  2086. .irq_fs_maskbit = IRQ17_MCU_MODE_MASK,
  2087. .irq_en_reg = AFE_IRQ_MCU_CON0,
  2088. .irq_en_shift = IRQ17_MCU_ON_SFT,
  2089. .irq_clr_reg = AFE_IRQ_MCU_CLR,
  2090. .irq_clr_shift = IRQ17_MCU_CLR_SFT,
  2091. },
  2092. [MT8186_IRQ_18] = {
  2093. .id = MT8186_IRQ_18,
  2094. .irq_cnt_reg = AFE_IRQ_MCU_CNT18,
  2095. .irq_cnt_shift = AFE_IRQ_CNT_SHIFT,
  2096. .irq_cnt_maskbit = AFE_IRQ_CNT_MASK,
  2097. .irq_fs_reg = AFE_IRQ_MCU_CON3,
  2098. .irq_fs_shift = IRQ18_MCU_MODE_SFT,
  2099. .irq_fs_maskbit = IRQ18_MCU_MODE_MASK,
  2100. .irq_en_reg = AFE_IRQ_MCU_CON0,
  2101. .irq_en_shift = IRQ18_MCU_ON_SFT,
  2102. .irq_clr_reg = AFE_IRQ_MCU_CLR,
  2103. .irq_clr_shift = IRQ18_MCU_CLR_SFT,
  2104. },
  2105. [MT8186_IRQ_19] = {
  2106. .id = MT8186_IRQ_19,
  2107. .irq_cnt_reg = AFE_IRQ_MCU_CNT19,
  2108. .irq_cnt_shift = AFE_IRQ_CNT_SHIFT,
  2109. .irq_cnt_maskbit = AFE_IRQ_CNT_MASK,
  2110. .irq_fs_reg = AFE_IRQ_MCU_CON3,
  2111. .irq_fs_shift = IRQ19_MCU_MODE_SFT,
  2112. .irq_fs_maskbit = IRQ19_MCU_MODE_MASK,
  2113. .irq_en_reg = AFE_IRQ_MCU_CON0,
  2114. .irq_en_shift = IRQ19_MCU_ON_SFT,
  2115. .irq_clr_reg = AFE_IRQ_MCU_CLR,
  2116. .irq_clr_shift = IRQ19_MCU_CLR_SFT,
  2117. },
  2118. [MT8186_IRQ_20] = {
  2119. .id = MT8186_IRQ_20,
  2120. .irq_cnt_reg = AFE_IRQ_MCU_CNT20,
  2121. .irq_cnt_shift = AFE_IRQ_CNT_SHIFT,
  2122. .irq_cnt_maskbit = AFE_IRQ_CNT_MASK,
  2123. .irq_fs_reg = AFE_IRQ_MCU_CON3,
  2124. .irq_fs_shift = IRQ20_MCU_MODE_SFT,
  2125. .irq_fs_maskbit = IRQ20_MCU_MODE_MASK,
  2126. .irq_en_reg = AFE_IRQ_MCU_CON0,
  2127. .irq_en_shift = IRQ20_MCU_ON_SFT,
  2128. .irq_clr_reg = AFE_IRQ_MCU_CLR,
  2129. .irq_clr_shift = IRQ20_MCU_CLR_SFT,
  2130. },
  2131. [MT8186_IRQ_21] = {
  2132. .id = MT8186_IRQ_21,
  2133. .irq_cnt_reg = AFE_IRQ_MCU_CNT21,
  2134. .irq_cnt_shift = AFE_IRQ_CNT_SHIFT,
  2135. .irq_cnt_maskbit = AFE_IRQ_CNT_MASK,
  2136. .irq_fs_reg = AFE_IRQ_MCU_CON3,
  2137. .irq_fs_shift = IRQ21_MCU_MODE_SFT,
  2138. .irq_fs_maskbit = IRQ21_MCU_MODE_MASK,
  2139. .irq_en_reg = AFE_IRQ_MCU_CON0,
  2140. .irq_en_shift = IRQ21_MCU_ON_SFT,
  2141. .irq_clr_reg = AFE_IRQ_MCU_CLR,
  2142. .irq_clr_shift = IRQ21_MCU_CLR_SFT,
  2143. },
  2144. [MT8186_IRQ_22] = {
  2145. .id = MT8186_IRQ_22,
  2146. .irq_cnt_reg = AFE_IRQ_MCU_CNT22,
  2147. .irq_cnt_shift = AFE_IRQ_CNT_SHIFT,
  2148. .irq_cnt_maskbit = AFE_IRQ_CNT_MASK,
  2149. .irq_fs_reg = AFE_IRQ_MCU_CON3,
  2150. .irq_fs_shift = IRQ22_MCU_MODE_SFT,
  2151. .irq_fs_maskbit = IRQ22_MCU_MODE_MASK,
  2152. .irq_en_reg = AFE_IRQ_MCU_CON0,
  2153. .irq_en_shift = IRQ22_MCU_ON_SFT,
  2154. .irq_clr_reg = AFE_IRQ_MCU_CLR,
  2155. .irq_clr_shift = IRQ22_MCU_CLR_SFT,
  2156. },
  2157. [MT8186_IRQ_23] = {
  2158. .id = MT8186_IRQ_23,
  2159. .irq_cnt_reg = AFE_IRQ_MCU_CNT23,
  2160. .irq_cnt_shift = AFE_IRQ_CNT_SHIFT,
  2161. .irq_cnt_maskbit = AFE_IRQ_CNT_MASK,
  2162. .irq_fs_reg = AFE_IRQ_MCU_CON3,
  2163. .irq_fs_shift = IRQ23_MCU_MODE_SFT,
  2164. .irq_fs_maskbit = IRQ23_MCU_MODE_MASK,
  2165. .irq_en_reg = AFE_IRQ_MCU_CON0,
  2166. .irq_en_shift = IRQ23_MCU_ON_SFT,
  2167. .irq_clr_reg = AFE_IRQ_MCU_CLR,
  2168. .irq_clr_shift = IRQ23_MCU_CLR_SFT,
  2169. },
  2170. [MT8186_IRQ_24] = {
  2171. .id = MT8186_IRQ_24,
  2172. .irq_cnt_reg = AFE_IRQ_MCU_CNT24,
  2173. .irq_cnt_shift = AFE_IRQ_CNT_SHIFT,
  2174. .irq_cnt_maskbit = AFE_IRQ_CNT_MASK,
  2175. .irq_fs_reg = AFE_IRQ_MCU_CON4,
  2176. .irq_fs_shift = IRQ24_MCU_MODE_SFT,
  2177. .irq_fs_maskbit = IRQ24_MCU_MODE_MASK,
  2178. .irq_en_reg = AFE_IRQ_MCU_CON0,
  2179. .irq_en_shift = IRQ24_MCU_ON_SFT,
  2180. .irq_clr_reg = AFE_IRQ_MCU_CLR,
  2181. .irq_clr_shift = IRQ24_MCU_CLR_SFT,
  2182. },
  2183. [MT8186_IRQ_25] = {
  2184. .id = MT8186_IRQ_25,
  2185. .irq_cnt_reg = AFE_IRQ_MCU_CNT25,
  2186. .irq_cnt_shift = AFE_IRQ_CNT_SHIFT,
  2187. .irq_cnt_maskbit = AFE_IRQ_CNT_MASK,
  2188. .irq_fs_reg = AFE_IRQ_MCU_CON4,
  2189. .irq_fs_shift = IRQ25_MCU_MODE_SFT,
  2190. .irq_fs_maskbit = IRQ25_MCU_MODE_MASK,
  2191. .irq_en_reg = AFE_IRQ_MCU_CON0,
  2192. .irq_en_shift = IRQ25_MCU_ON_SFT,
  2193. .irq_clr_reg = AFE_IRQ_MCU_CLR,
  2194. .irq_clr_shift = IRQ25_MCU_CLR_SFT,
  2195. },
  2196. [MT8186_IRQ_26] = {
  2197. .id = MT8186_IRQ_26,
  2198. .irq_cnt_reg = AFE_IRQ_MCU_CNT26,
  2199. .irq_cnt_shift = AFE_IRQ_CNT_SHIFT,
  2200. .irq_cnt_maskbit = AFE_IRQ_CNT_MASK,
  2201. .irq_fs_reg = AFE_IRQ_MCU_CON4,
  2202. .irq_fs_shift = IRQ26_MCU_MODE_SFT,
  2203. .irq_fs_maskbit = IRQ26_MCU_MODE_MASK,
  2204. .irq_en_reg = AFE_IRQ_MCU_CON0,
  2205. .irq_en_shift = IRQ26_MCU_ON_SFT,
  2206. .irq_clr_reg = AFE_IRQ_MCU_CLR,
  2207. .irq_clr_shift = IRQ26_MCU_CLR_SFT,
  2208. },
  2209. };
  2210. static const int memif_irq_usage[MT8186_MEMIF_NUM] = {
  2211. /* TODO: verify each memif & irq */
  2212. [MT8186_MEMIF_DL1] = MT8186_IRQ_0,
  2213. [MT8186_MEMIF_DL2] = MT8186_IRQ_1,
  2214. [MT8186_MEMIF_DL3] = MT8186_IRQ_2,
  2215. [MT8186_MEMIF_DL4] = MT8186_IRQ_3,
  2216. [MT8186_MEMIF_DL5] = MT8186_IRQ_4,
  2217. [MT8186_MEMIF_DL6] = MT8186_IRQ_5,
  2218. [MT8186_MEMIF_DL7] = MT8186_IRQ_6,
  2219. [MT8186_MEMIF_DL8] = MT8186_IRQ_7,
  2220. [MT8186_MEMIF_DL12] = MT8186_IRQ_9,
  2221. [MT8186_MEMIF_VUL12] = MT8186_IRQ_10,
  2222. [MT8186_MEMIF_VUL2] = MT8186_IRQ_11,
  2223. [MT8186_MEMIF_AWB] = MT8186_IRQ_12,
  2224. [MT8186_MEMIF_AWB2] = MT8186_IRQ_13,
  2225. [MT8186_MEMIF_VUL3] = MT8186_IRQ_14,
  2226. [MT8186_MEMIF_VUL4] = MT8186_IRQ_15,
  2227. [MT8186_MEMIF_VUL5] = MT8186_IRQ_16,
  2228. [MT8186_MEMIF_VUL6] = MT8186_IRQ_17,
  2229. };
  2230. static bool mt8186_is_volatile_reg(struct device *dev, unsigned int reg)
  2231. {
  2232. /* these auto-gen reg has read-only bit, so put it as volatile */
  2233. /* volatile reg cannot be cached, so cannot be set when power off */
  2234. switch (reg) {
  2235. case AUDIO_TOP_CON0: /* reg bit controlled by CCF */
  2236. case AUDIO_TOP_CON1: /* reg bit controlled by CCF */
  2237. case AUDIO_TOP_CON2:
  2238. case AUDIO_TOP_CON3:
  2239. case AFE_DL1_CUR_MSB:
  2240. case AFE_DL1_CUR:
  2241. case AFE_DL1_END:
  2242. case AFE_DL2_CUR_MSB:
  2243. case AFE_DL2_CUR:
  2244. case AFE_DL2_END:
  2245. case AFE_DL3_CUR_MSB:
  2246. case AFE_DL3_CUR:
  2247. case AFE_DL3_END:
  2248. case AFE_DL4_CUR_MSB:
  2249. case AFE_DL4_CUR:
  2250. case AFE_DL4_END:
  2251. case AFE_DL12_CUR_MSB:
  2252. case AFE_DL12_CUR:
  2253. case AFE_DL12_END:
  2254. case AFE_ADDA_SRC_DEBUG_MON0:
  2255. case AFE_ADDA_SRC_DEBUG_MON1:
  2256. case AFE_ADDA_UL_SRC_MON0:
  2257. case AFE_ADDA_UL_SRC_MON1:
  2258. case AFE_SECURE_CON0:
  2259. case AFE_SRAM_BOUND:
  2260. case AFE_SECURE_CON1:
  2261. case AFE_VUL_CUR_MSB:
  2262. case AFE_VUL_CUR:
  2263. case AFE_VUL_END:
  2264. case AFE_SIDETONE_MON:
  2265. case AFE_SIDETONE_CON0:
  2266. case AFE_SIDETONE_COEFF:
  2267. case AFE_VUL2_CUR_MSB:
  2268. case AFE_VUL2_CUR:
  2269. case AFE_VUL2_END:
  2270. case AFE_VUL3_CUR_MSB:
  2271. case AFE_VUL3_CUR:
  2272. case AFE_VUL3_END:
  2273. case AFE_I2S_MON:
  2274. case AFE_DAC_MON:
  2275. case AFE_IRQ0_MCU_CNT_MON:
  2276. case AFE_IRQ6_MCU_CNT_MON:
  2277. case AFE_VUL4_CUR_MSB:
  2278. case AFE_VUL4_CUR:
  2279. case AFE_VUL4_END:
  2280. case AFE_VUL12_CUR_MSB:
  2281. case AFE_VUL12_CUR:
  2282. case AFE_VUL12_END:
  2283. case AFE_IRQ3_MCU_CNT_MON:
  2284. case AFE_IRQ4_MCU_CNT_MON:
  2285. case AFE_IRQ_MCU_STATUS:
  2286. case AFE_IRQ_MCU_CLR:
  2287. case AFE_IRQ_MCU_MON2:
  2288. case AFE_IRQ1_MCU_CNT_MON:
  2289. case AFE_IRQ2_MCU_CNT_MON:
  2290. case AFE_IRQ5_MCU_CNT_MON:
  2291. case AFE_IRQ7_MCU_CNT_MON:
  2292. case AFE_IRQ_MCU_MISS_CLR:
  2293. case AFE_GAIN1_CUR:
  2294. case AFE_GAIN2_CUR:
  2295. case AFE_SRAM_DELSEL_CON1:
  2296. case PCM_INTF_CON2:
  2297. case FPGA_CFG0:
  2298. case FPGA_CFG1:
  2299. case FPGA_CFG2:
  2300. case FPGA_CFG3:
  2301. case AUDIO_TOP_DBG_MON0:
  2302. case AUDIO_TOP_DBG_MON1:
  2303. case AFE_IRQ8_MCU_CNT_MON:
  2304. case AFE_IRQ11_MCU_CNT_MON:
  2305. case AFE_IRQ12_MCU_CNT_MON:
  2306. case AFE_IRQ9_MCU_CNT_MON:
  2307. case AFE_IRQ10_MCU_CNT_MON:
  2308. case AFE_IRQ13_MCU_CNT_MON:
  2309. case AFE_IRQ14_MCU_CNT_MON:
  2310. case AFE_IRQ15_MCU_CNT_MON:
  2311. case AFE_IRQ16_MCU_CNT_MON:
  2312. case AFE_IRQ17_MCU_CNT_MON:
  2313. case AFE_IRQ18_MCU_CNT_MON:
  2314. case AFE_IRQ19_MCU_CNT_MON:
  2315. case AFE_IRQ20_MCU_CNT_MON:
  2316. case AFE_IRQ21_MCU_CNT_MON:
  2317. case AFE_IRQ22_MCU_CNT_MON:
  2318. case AFE_IRQ23_MCU_CNT_MON:
  2319. case AFE_IRQ24_MCU_CNT_MON:
  2320. case AFE_IRQ25_MCU_CNT_MON:
  2321. case AFE_IRQ26_MCU_CNT_MON:
  2322. case AFE_IRQ31_MCU_CNT_MON:
  2323. case AFE_CBIP_MON0:
  2324. case AFE_CBIP_SLV_MUX_MON0:
  2325. case AFE_CBIP_SLV_DECODER_MON0:
  2326. case AFE_ADDA6_MTKAIF_MON0:
  2327. case AFE_ADDA6_MTKAIF_MON1:
  2328. case AFE_AWB_CUR_MSB:
  2329. case AFE_AWB_CUR:
  2330. case AFE_AWB_END:
  2331. case AFE_AWB2_CUR_MSB:
  2332. case AFE_AWB2_CUR:
  2333. case AFE_AWB2_END:
  2334. case AFE_DAI_CUR_MSB:
  2335. case AFE_DAI_CUR:
  2336. case AFE_DAI_END:
  2337. case AFE_DAI2_CUR_MSB:
  2338. case AFE_DAI2_CUR:
  2339. case AFE_DAI2_END:
  2340. case AFE_ADDA6_SRC_DEBUG_MON0:
  2341. case AFE_ADD6A_UL_SRC_MON0:
  2342. case AFE_ADDA6_UL_SRC_MON1:
  2343. case AFE_MOD_DAI_CUR_MSB:
  2344. case AFE_MOD_DAI_CUR:
  2345. case AFE_MOD_DAI_END:
  2346. case AFE_AWB_RCH_MON:
  2347. case AFE_AWB_LCH_MON:
  2348. case AFE_VUL_RCH_MON:
  2349. case AFE_VUL_LCH_MON:
  2350. case AFE_VUL12_RCH_MON:
  2351. case AFE_VUL12_LCH_MON:
  2352. case AFE_VUL2_RCH_MON:
  2353. case AFE_VUL2_LCH_MON:
  2354. case AFE_DAI_DATA_MON:
  2355. case AFE_MOD_DAI_DATA_MON:
  2356. case AFE_DAI2_DATA_MON:
  2357. case AFE_AWB2_RCH_MON:
  2358. case AFE_AWB2_LCH_MON:
  2359. case AFE_VUL3_RCH_MON:
  2360. case AFE_VUL3_LCH_MON:
  2361. case AFE_VUL4_RCH_MON:
  2362. case AFE_VUL4_LCH_MON:
  2363. case AFE_VUL5_RCH_MON:
  2364. case AFE_VUL5_LCH_MON:
  2365. case AFE_VUL6_RCH_MON:
  2366. case AFE_VUL6_LCH_MON:
  2367. case AFE_DL1_RCH_MON:
  2368. case AFE_DL1_LCH_MON:
  2369. case AFE_DL2_RCH_MON:
  2370. case AFE_DL2_LCH_MON:
  2371. case AFE_DL12_RCH1_MON:
  2372. case AFE_DL12_LCH1_MON:
  2373. case AFE_DL12_RCH2_MON:
  2374. case AFE_DL12_LCH2_MON:
  2375. case AFE_DL3_RCH_MON:
  2376. case AFE_DL3_LCH_MON:
  2377. case AFE_DL4_RCH_MON:
  2378. case AFE_DL4_LCH_MON:
  2379. case AFE_DL5_RCH_MON:
  2380. case AFE_DL5_LCH_MON:
  2381. case AFE_DL6_RCH_MON:
  2382. case AFE_DL6_LCH_MON:
  2383. case AFE_DL7_RCH_MON:
  2384. case AFE_DL7_LCH_MON:
  2385. case AFE_DL8_RCH_MON:
  2386. case AFE_DL8_LCH_MON:
  2387. case AFE_VUL5_CUR_MSB:
  2388. case AFE_VUL5_CUR:
  2389. case AFE_VUL5_END:
  2390. case AFE_VUL6_CUR_MSB:
  2391. case AFE_VUL6_CUR:
  2392. case AFE_VUL6_END:
  2393. case AFE_ADDA_DL_SDM_FIFO_MON:
  2394. case AFE_ADDA_DL_SRC_LCH_MON:
  2395. case AFE_ADDA_DL_SRC_RCH_MON:
  2396. case AFE_ADDA_DL_SDM_OUT_MON:
  2397. case AFE_CONNSYS_I2S_MON:
  2398. case AFE_ASRC_2CH_CON0:
  2399. case AFE_ASRC_2CH_CON2:
  2400. case AFE_ASRC_2CH_CON3:
  2401. case AFE_ASRC_2CH_CON4:
  2402. case AFE_ASRC_2CH_CON5:
  2403. case AFE_ASRC_2CH_CON7:
  2404. case AFE_ASRC_2CH_CON8:
  2405. case AFE_ASRC_2CH_CON12:
  2406. case AFE_ASRC_2CH_CON13:
  2407. case AFE_ADDA_MTKAIF_MON0:
  2408. case AFE_ADDA_MTKAIF_MON1:
  2409. case AFE_AUD_PAD_TOP:
  2410. case AFE_DL_NLE_R_MON0:
  2411. case AFE_DL_NLE_R_MON1:
  2412. case AFE_DL_NLE_R_MON2:
  2413. case AFE_DL_NLE_L_MON0:
  2414. case AFE_DL_NLE_L_MON1:
  2415. case AFE_DL_NLE_L_MON2:
  2416. case AFE_GENERAL1_ASRC_2CH_CON0:
  2417. case AFE_GENERAL1_ASRC_2CH_CON2:
  2418. case AFE_GENERAL1_ASRC_2CH_CON3:
  2419. case AFE_GENERAL1_ASRC_2CH_CON4:
  2420. case AFE_GENERAL1_ASRC_2CH_CON5:
  2421. case AFE_GENERAL1_ASRC_2CH_CON7:
  2422. case AFE_GENERAL1_ASRC_2CH_CON8:
  2423. case AFE_GENERAL1_ASRC_2CH_CON12:
  2424. case AFE_GENERAL1_ASRC_2CH_CON13:
  2425. case AFE_GENERAL2_ASRC_2CH_CON0:
  2426. case AFE_GENERAL2_ASRC_2CH_CON2:
  2427. case AFE_GENERAL2_ASRC_2CH_CON3:
  2428. case AFE_GENERAL2_ASRC_2CH_CON4:
  2429. case AFE_GENERAL2_ASRC_2CH_CON5:
  2430. case AFE_GENERAL2_ASRC_2CH_CON7:
  2431. case AFE_GENERAL2_ASRC_2CH_CON8:
  2432. case AFE_GENERAL2_ASRC_2CH_CON12:
  2433. case AFE_GENERAL2_ASRC_2CH_CON13:
  2434. case AFE_DL5_CUR_MSB:
  2435. case AFE_DL5_CUR:
  2436. case AFE_DL5_END:
  2437. case AFE_DL6_CUR_MSB:
  2438. case AFE_DL6_CUR:
  2439. case AFE_DL6_END:
  2440. case AFE_DL7_CUR_MSB:
  2441. case AFE_DL7_CUR:
  2442. case AFE_DL7_END:
  2443. case AFE_DL8_CUR_MSB:
  2444. case AFE_DL8_CUR:
  2445. case AFE_DL8_END:
  2446. case AFE_PROT_SIDEBAND_MON:
  2447. case AFE_DOMAIN_SIDEBAND0_MON:
  2448. case AFE_DOMAIN_SIDEBAND1_MON:
  2449. case AFE_DOMAIN_SIDEBAND2_MON:
  2450. case AFE_DOMAIN_SIDEBAND3_MON:
  2451. case AFE_APLL1_TUNER_CFG: /* [20:31] is monitor */
  2452. case AFE_APLL2_TUNER_CFG: /* [20:31] is monitor */
  2453. return true;
  2454. default:
  2455. return false;
  2456. };
  2457. }
  2458. static const struct regmap_config mt8186_afe_regmap_config = {
  2459. .reg_bits = 32,
  2460. .reg_stride = 4,
  2461. .val_bits = 32,
  2462. .volatile_reg = mt8186_is_volatile_reg,
  2463. .max_register = AFE_MAX_REGISTER,
  2464. .num_reg_defaults_raw = AFE_MAX_REGISTER,
  2465. .cache_type = REGCACHE_FLAT,
  2466. };
  2467. static irqreturn_t mt8186_afe_irq_handler(int irq_id, void *dev)
  2468. {
  2469. struct mtk_base_afe *afe = dev;
  2470. struct mtk_base_afe_irq *irq;
  2471. unsigned int status;
  2472. unsigned int status_mcu;
  2473. unsigned int mcu_en;
  2474. int ret;
  2475. int i;
  2476. /* get irq that is sent to MCU */
  2477. ret = regmap_read(afe->regmap, AFE_IRQ_MCU_EN, &mcu_en);
  2478. if (ret) {
  2479. dev_err(afe->dev, "%s, get irq direction fail, ret %d", __func__, ret);
  2480. return ret;
  2481. }
  2482. ret = regmap_read(afe->regmap, AFE_IRQ_MCU_STATUS, &status);
  2483. /* only care IRQ which is sent to MCU */
  2484. status_mcu = status & mcu_en & AFE_IRQ_STATUS_BITS;
  2485. if (ret || status_mcu == 0) {
  2486. dev_err(afe->dev, "%s(), irq status err, ret %d, status 0x%x, mcu_en 0x%x\n",
  2487. __func__, ret, status, mcu_en);
  2488. goto err_irq;
  2489. }
  2490. for (i = 0; i < MT8186_MEMIF_NUM; i++) {
  2491. struct mtk_base_afe_memif *memif = &afe->memif[i];
  2492. if (!memif->substream)
  2493. continue;
  2494. if (memif->irq_usage < 0)
  2495. continue;
  2496. irq = &afe->irqs[memif->irq_usage];
  2497. if (status_mcu & (1 << irq->irq_data->irq_en_shift))
  2498. snd_pcm_period_elapsed(memif->substream);
  2499. }
  2500. err_irq:
  2501. /* clear irq */
  2502. regmap_write(afe->regmap, AFE_IRQ_MCU_CLR, status_mcu);
  2503. return IRQ_HANDLED;
  2504. }
  2505. static int mt8186_afe_runtime_suspend(struct device *dev)
  2506. {
  2507. struct mtk_base_afe *afe = dev_get_drvdata(dev);
  2508. struct mt8186_afe_private *afe_priv = afe->platform_priv;
  2509. unsigned int value = 0;
  2510. int ret;
  2511. if (!afe->regmap || afe_priv->pm_runtime_bypass_reg_ctl)
  2512. goto skip_regmap;
  2513. /* disable AFE */
  2514. regmap_update_bits(afe->regmap, AFE_DAC_CON0, 0x1, 0x0);
  2515. ret = regmap_read_poll_timeout(afe->regmap,
  2516. AFE_DAC_MON,
  2517. value,
  2518. (value & AFE_ON_RETM_MASK_SFT) == 0,
  2519. 20,
  2520. 1 * 1000 * 1000);
  2521. if (ret) {
  2522. dev_err(afe->dev, "%s(), ret %d\n", __func__, ret);
  2523. return ret;
  2524. }
  2525. /* make sure all irq status are cleared */
  2526. regmap_write(afe->regmap, AFE_IRQ_MCU_CLR, 0xffffffff);
  2527. regmap_write(afe->regmap, AFE_IRQ_MCU_CLR, 0xffffffff);
  2528. /* reset sgen */
  2529. regmap_write(afe->regmap, AFE_SINEGEN_CON0, 0x0);
  2530. regmap_update_bits(afe->regmap, AFE_SINEGEN_CON2,
  2531. INNER_LOOP_BACK_MODE_MASK_SFT,
  2532. 0x3f << INNER_LOOP_BACK_MODE_SFT);
  2533. /* cache only */
  2534. regcache_cache_only(afe->regmap, true);
  2535. regcache_mark_dirty(afe->regmap);
  2536. skip_regmap:
  2537. mt8186_afe_disable_cgs(afe);
  2538. mt8186_afe_disable_clock(afe);
  2539. return 0;
  2540. }
  2541. static int mt8186_afe_runtime_resume(struct device *dev)
  2542. {
  2543. struct mtk_base_afe *afe = dev_get_drvdata(dev);
  2544. struct mt8186_afe_private *afe_priv = afe->platform_priv;
  2545. int ret;
  2546. ret = mt8186_afe_enable_clock(afe);
  2547. if (ret)
  2548. return ret;
  2549. ret = mt8186_afe_enable_cgs(afe);
  2550. if (ret)
  2551. return ret;
  2552. if (!afe->regmap || afe_priv->pm_runtime_bypass_reg_ctl)
  2553. goto skip_regmap;
  2554. regcache_cache_only(afe->regmap, false);
  2555. regcache_sync(afe->regmap);
  2556. /* enable audio sys DCM for power saving */
  2557. regmap_update_bits(afe_priv->infracfg, PERI_BUS_DCM_CTRL, BIT(29), BIT(29));
  2558. regmap_update_bits(afe->regmap, AUDIO_TOP_CON0, BIT(29), BIT(29));
  2559. /* force cpu use 8_24 format when writing 32bit data */
  2560. regmap_update_bits(afe->regmap, AFE_MEMIF_CON0, CPU_HD_ALIGN_MASK_SFT, 0);
  2561. /* set all output port to 24bit */
  2562. regmap_write(afe->regmap, AFE_CONN_24BIT, 0xffffffff);
  2563. regmap_write(afe->regmap, AFE_CONN_24BIT_1, 0xffffffff);
  2564. /* enable AFE */
  2565. regmap_update_bits(afe->regmap, AFE_DAC_CON0, AUDIO_AFE_ON_MASK_SFT, BIT(0));
  2566. skip_regmap:
  2567. return 0;
  2568. }
  2569. static int mt8186_afe_component_probe(struct snd_soc_component *component)
  2570. {
  2571. mtk_afe_add_sub_dai_control(component);
  2572. mt8186_add_misc_control(component);
  2573. return 0;
  2574. }
  2575. static const struct snd_soc_component_driver mt8186_afe_component = {
  2576. .name = AFE_PCM_NAME,
  2577. .pcm_construct = mtk_afe_pcm_new,
  2578. .pointer = mtk_afe_pcm_pointer,
  2579. .probe = mt8186_afe_component_probe,
  2580. };
  2581. static int mt8186_dai_memif_register(struct mtk_base_afe *afe)
  2582. {
  2583. struct mtk_base_afe_dai *dai;
  2584. dai = devm_kzalloc(afe->dev, sizeof(*dai), GFP_KERNEL);
  2585. if (!dai)
  2586. return -ENOMEM;
  2587. list_add(&dai->list, &afe->sub_dais);
  2588. dai->dai_drivers = mt8186_memif_dai_driver;
  2589. dai->num_dai_drivers = ARRAY_SIZE(mt8186_memif_dai_driver);
  2590. dai->controls = mt8186_pcm_kcontrols;
  2591. dai->num_controls = ARRAY_SIZE(mt8186_pcm_kcontrols);
  2592. dai->dapm_widgets = mt8186_memif_widgets;
  2593. dai->num_dapm_widgets = ARRAY_SIZE(mt8186_memif_widgets);
  2594. dai->dapm_routes = mt8186_memif_routes;
  2595. dai->num_dapm_routes = ARRAY_SIZE(mt8186_memif_routes);
  2596. return 0;
  2597. }
  2598. typedef int (*dai_register_cb)(struct mtk_base_afe *);
  2599. static const dai_register_cb dai_register_cbs[] = {
  2600. mt8186_dai_adda_register,
  2601. mt8186_dai_i2s_register,
  2602. mt8186_dai_tdm_register,
  2603. mt8186_dai_hw_gain_register,
  2604. mt8186_dai_src_register,
  2605. mt8186_dai_pcm_register,
  2606. mt8186_dai_hostless_register,
  2607. mt8186_dai_memif_register,
  2608. };
  2609. static int mt8186_afe_pcm_dev_probe(struct platform_device *pdev)
  2610. {
  2611. struct mtk_base_afe *afe;
  2612. struct mt8186_afe_private *afe_priv;
  2613. struct resource *res;
  2614. struct reset_control *rstc;
  2615. struct device *dev = &pdev->dev;
  2616. int i, ret, irq_id;
  2617. ret = dma_set_mask_and_coherent(dev, DMA_BIT_MASK(34));
  2618. if (ret)
  2619. return ret;
  2620. afe = devm_kzalloc(dev, sizeof(*afe), GFP_KERNEL);
  2621. if (!afe)
  2622. return -ENOMEM;
  2623. platform_set_drvdata(pdev, afe);
  2624. afe->platform_priv = devm_kzalloc(dev, sizeof(*afe_priv), GFP_KERNEL);
  2625. if (!afe->platform_priv)
  2626. return -ENOMEM;
  2627. afe_priv = afe->platform_priv;
  2628. afe->dev = &pdev->dev;
  2629. res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
  2630. afe->base_addr = devm_ioremap_resource(dev, res);
  2631. if (IS_ERR(afe->base_addr))
  2632. return PTR_ERR(afe->base_addr);
  2633. /* init audio related clock */
  2634. ret = mt8186_init_clock(afe);
  2635. if (ret) {
  2636. dev_err(dev, "init clock error, ret %d\n", ret);
  2637. return ret;
  2638. }
  2639. /* init memif */
  2640. afe->memif_32bit_supported = 0;
  2641. afe->memif_size = MT8186_MEMIF_NUM;
  2642. afe->memif = devm_kcalloc(dev, afe->memif_size, sizeof(*afe->memif), GFP_KERNEL);
  2643. if (!afe->memif)
  2644. return -ENOMEM;
  2645. for (i = 0; i < afe->memif_size; i++) {
  2646. afe->memif[i].data = &memif_data[i];
  2647. afe->memif[i].irq_usage = memif_irq_usage[i];
  2648. afe->memif[i].const_irq = 1;
  2649. }
  2650. mutex_init(&afe->irq_alloc_lock); /* needed when dynamic irq */
  2651. /* init irq */
  2652. afe->irqs_size = MT8186_IRQ_NUM;
  2653. afe->irqs = devm_kcalloc(dev, afe->irqs_size, sizeof(*afe->irqs),
  2654. GFP_KERNEL);
  2655. if (!afe->irqs)
  2656. return -ENOMEM;
  2657. for (i = 0; i < afe->irqs_size; i++)
  2658. afe->irqs[i].irq_data = &irq_data[i];
  2659. /* request irq */
  2660. irq_id = platform_get_irq(pdev, 0);
  2661. if (irq_id <= 0)
  2662. return dev_err_probe(dev, irq_id < 0 ? irq_id : -ENXIO,
  2663. "no irq found");
  2664. ret = devm_request_irq(dev, irq_id, mt8186_afe_irq_handler,
  2665. IRQF_TRIGGER_NONE,
  2666. "Afe_ISR_Handle", (void *)afe);
  2667. if (ret)
  2668. return dev_err_probe(dev, ret, "could not request_irq for Afe_ISR_Handle\n");
  2669. ret = enable_irq_wake(irq_id);
  2670. if (ret < 0)
  2671. return dev_err_probe(dev, ret, "enable_irq_wake %d\n", irq_id);
  2672. /* init sub_dais */
  2673. INIT_LIST_HEAD(&afe->sub_dais);
  2674. for (i = 0; i < ARRAY_SIZE(dai_register_cbs); i++) {
  2675. ret = dai_register_cbs[i](afe);
  2676. if (ret)
  2677. return dev_err_probe(dev, ret, "dai register i %d fail\n", i);
  2678. }
  2679. /* init dai_driver and component_driver */
  2680. ret = mtk_afe_combine_sub_dai(afe);
  2681. if (ret)
  2682. return dev_err_probe(dev, ret, "mtk_afe_combine_sub_dai fail\n");
  2683. /* reset controller to reset audio regs before regmap cache */
  2684. rstc = devm_reset_control_get_exclusive(dev, "audiosys");
  2685. if (IS_ERR(rstc))
  2686. return dev_err_probe(dev, PTR_ERR(rstc), "could not get audiosys reset\n");
  2687. ret = reset_control_reset(rstc);
  2688. if (ret)
  2689. return dev_err_probe(dev, ret, "failed to trigger audio reset\n");
  2690. /* enable clock for regcache get default value from hw */
  2691. afe_priv->pm_runtime_bypass_reg_ctl = true;
  2692. ret = devm_pm_runtime_enable(dev);
  2693. if (ret)
  2694. return ret;
  2695. ret = pm_runtime_resume_and_get(dev);
  2696. if (ret)
  2697. return dev_err_probe(dev, ret, "failed to resume device\n");
  2698. afe->regmap = devm_regmap_init_mmio(dev, afe->base_addr,
  2699. &mt8186_afe_regmap_config);
  2700. if (IS_ERR(afe->regmap)) {
  2701. ret = PTR_ERR(afe->regmap);
  2702. goto err_pm_disable;
  2703. }
  2704. /* others */
  2705. afe->mtk_afe_hardware = &mt8186_afe_hardware;
  2706. afe->memif_fs = mt8186_memif_fs;
  2707. afe->irq_fs = mt8186_irq_fs;
  2708. afe->get_dai_fs = mt8186_get_dai_fs;
  2709. afe->get_memif_pbuf_size = mt8186_get_memif_pbuf_size;
  2710. afe->runtime_resume = mt8186_afe_runtime_resume;
  2711. afe->runtime_suspend = mt8186_afe_runtime_suspend;
  2712. /* register platform */
  2713. dev_dbg(dev, "%s(), devm_snd_soc_register_component\n", __func__);
  2714. ret = devm_snd_soc_register_component(dev,
  2715. &mt8186_afe_component,
  2716. afe->dai_drivers,
  2717. afe->num_dai_drivers);
  2718. if (ret) {
  2719. dev_err(dev, "err_dai_component\n");
  2720. goto err_pm_disable;
  2721. }
  2722. ret = pm_runtime_put_sync(dev);
  2723. if (ret) {
  2724. pm_runtime_get_noresume(dev);
  2725. dev_err(dev, "failed to suspend device: %d\n", ret);
  2726. goto err_pm_disable;
  2727. }
  2728. afe_priv->pm_runtime_bypass_reg_ctl = false;
  2729. regcache_cache_only(afe->regmap, true);
  2730. regcache_mark_dirty(afe->regmap);
  2731. return 0;
  2732. err_pm_disable:
  2733. pm_runtime_put_noidle(dev);
  2734. pm_runtime_set_suspended(dev);
  2735. return ret;
  2736. }
  2737. static const struct of_device_id mt8186_afe_pcm_dt_match[] = {
  2738. { .compatible = "mediatek,mt8186-sound", },
  2739. {},
  2740. };
  2741. MODULE_DEVICE_TABLE(of, mt8186_afe_pcm_dt_match);
  2742. static const struct dev_pm_ops mt8186_afe_pm_ops = {
  2743. SET_RUNTIME_PM_OPS(mt8186_afe_runtime_suspend,
  2744. mt8186_afe_runtime_resume, NULL)
  2745. };
  2746. static struct platform_driver mt8186_afe_pcm_driver = {
  2747. .driver = {
  2748. .name = "mt8186-audio",
  2749. .of_match_table = mt8186_afe_pcm_dt_match,
  2750. .pm = &mt8186_afe_pm_ops,
  2751. },
  2752. .probe = mt8186_afe_pcm_dev_probe,
  2753. };
  2754. module_platform_driver(mt8186_afe_pcm_driver);
  2755. MODULE_DESCRIPTION("Mediatek ALSA SoC AFE platform driver for 8186");
  2756. MODULE_AUTHOR("Jiaxin Yu <[email protected]>");
  2757. MODULE_LICENSE("GPL v2");