mmcc-msm8996.c 89 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*x
  3. * Copyright (c) 2015, The Linux Foundation. All rights reserved.
  4. */
  5. #include <linux/kernel.h>
  6. #include <linux/bitops.h>
  7. #include <linux/err.h>
  8. #include <linux/platform_device.h>
  9. #include <linux/mod_devicetable.h>
  10. #include <linux/module.h>
  11. #include <linux/clk-provider.h>
  12. #include <linux/regmap.h>
  13. #include <dt-bindings/clock/qcom,mmcc-msm8996.h>
  14. #include "common.h"
  15. #include "clk-regmap.h"
  16. #include "clk-regmap-divider.h"
  17. #include "clk-alpha-pll.h"
  18. #include "clk-rcg.h"
  19. #include "clk-branch.h"
  20. #include "reset.h"
  21. #include "gdsc.h"
  22. enum {
  23. P_XO,
  24. P_MMPLL0,
  25. P_GPLL0,
  26. P_GPLL0_DIV,
  27. P_MMPLL1,
  28. P_MMPLL9,
  29. P_MMPLL2,
  30. P_MMPLL8,
  31. P_MMPLL3,
  32. P_DSI0PLL,
  33. P_DSI1PLL,
  34. P_MMPLL5,
  35. P_HDMIPLL,
  36. P_DSI0PLL_BYTE,
  37. P_DSI1PLL_BYTE,
  38. P_MMPLL4,
  39. };
  40. static struct clk_fixed_factor gpll0_div = {
  41. .mult = 1,
  42. .div = 2,
  43. .hw.init = &(struct clk_init_data){
  44. .name = "gpll0_div",
  45. .parent_data = (const struct clk_parent_data[]){
  46. { .fw_name = "gpll0", .name = "gpll0" },
  47. },
  48. .num_parents = 1,
  49. .ops = &clk_fixed_factor_ops,
  50. },
  51. };
  52. static const struct pll_vco mmpll_p_vco[] = {
  53. { 250000000, 500000000, 3 },
  54. { 500000000, 1000000000, 2 },
  55. { 1000000000, 1500000000, 1 },
  56. { 1500000000, 2000000000, 0 },
  57. };
  58. static const struct pll_vco mmpll_gfx_vco[] = {
  59. { 400000000, 1000000000, 2 },
  60. { 1000000000, 1500000000, 1 },
  61. { 1500000000, 2000000000, 0 },
  62. };
  63. static const struct pll_vco mmpll_t_vco[] = {
  64. { 500000000, 1500000000, 0 },
  65. };
  66. static struct clk_alpha_pll mmpll0_early = {
  67. .offset = 0x0,
  68. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
  69. .vco_table = mmpll_p_vco,
  70. .num_vco = ARRAY_SIZE(mmpll_p_vco),
  71. .clkr = {
  72. .enable_reg = 0x100,
  73. .enable_mask = BIT(0),
  74. .hw.init = &(struct clk_init_data){
  75. .name = "mmpll0_early",
  76. .parent_data = (const struct clk_parent_data[]){
  77. { .fw_name = "xo", .name = "xo_board" },
  78. },
  79. .num_parents = 1,
  80. .ops = &clk_alpha_pll_ops,
  81. },
  82. },
  83. };
  84. static struct clk_alpha_pll_postdiv mmpll0 = {
  85. .offset = 0x0,
  86. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
  87. .width = 4,
  88. .clkr.hw.init = &(struct clk_init_data){
  89. .name = "mmpll0",
  90. .parent_hws = (const struct clk_hw*[]){
  91. &mmpll0_early.clkr.hw
  92. },
  93. .num_parents = 1,
  94. .ops = &clk_alpha_pll_postdiv_ops,
  95. .flags = CLK_SET_RATE_PARENT,
  96. },
  97. };
  98. static struct clk_alpha_pll mmpll1_early = {
  99. .offset = 0x30,
  100. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
  101. .vco_table = mmpll_p_vco,
  102. .num_vco = ARRAY_SIZE(mmpll_p_vco),
  103. .clkr = {
  104. .enable_reg = 0x100,
  105. .enable_mask = BIT(1),
  106. .hw.init = &(struct clk_init_data){
  107. .name = "mmpll1_early",
  108. .parent_data = (const struct clk_parent_data[]){
  109. { .fw_name = "xo", .name = "xo_board" },
  110. },
  111. .num_parents = 1,
  112. .ops = &clk_alpha_pll_ops,
  113. }
  114. },
  115. };
  116. static struct clk_alpha_pll_postdiv mmpll1 = {
  117. .offset = 0x30,
  118. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
  119. .width = 4,
  120. .clkr.hw.init = &(struct clk_init_data){
  121. .name = "mmpll1",
  122. .parent_hws = (const struct clk_hw*[]){
  123. &mmpll1_early.clkr.hw
  124. },
  125. .num_parents = 1,
  126. .ops = &clk_alpha_pll_postdiv_ops,
  127. .flags = CLK_SET_RATE_PARENT,
  128. },
  129. };
  130. static struct clk_alpha_pll mmpll2_early = {
  131. .offset = 0x4100,
  132. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
  133. .vco_table = mmpll_gfx_vco,
  134. .num_vco = ARRAY_SIZE(mmpll_gfx_vco),
  135. .clkr.hw.init = &(struct clk_init_data){
  136. .name = "mmpll2_early",
  137. .parent_data = (const struct clk_parent_data[]){
  138. { .fw_name = "xo", .name = "xo_board" },
  139. },
  140. .num_parents = 1,
  141. .ops = &clk_alpha_pll_ops,
  142. },
  143. };
  144. static struct clk_alpha_pll_postdiv mmpll2 = {
  145. .offset = 0x4100,
  146. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
  147. .width = 4,
  148. .clkr.hw.init = &(struct clk_init_data){
  149. .name = "mmpll2",
  150. .parent_hws = (const struct clk_hw*[]){
  151. &mmpll2_early.clkr.hw
  152. },
  153. .num_parents = 1,
  154. .ops = &clk_alpha_pll_postdiv_ops,
  155. .flags = CLK_SET_RATE_PARENT,
  156. },
  157. };
  158. static struct clk_alpha_pll mmpll3_early = {
  159. .offset = 0x60,
  160. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
  161. .vco_table = mmpll_p_vco,
  162. .num_vco = ARRAY_SIZE(mmpll_p_vco),
  163. .clkr.hw.init = &(struct clk_init_data){
  164. .name = "mmpll3_early",
  165. .parent_data = (const struct clk_parent_data[]){
  166. { .fw_name = "xo", .name = "xo_board" },
  167. },
  168. .num_parents = 1,
  169. .ops = &clk_alpha_pll_ops,
  170. },
  171. };
  172. static struct clk_alpha_pll_postdiv mmpll3 = {
  173. .offset = 0x60,
  174. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
  175. .width = 4,
  176. .clkr.hw.init = &(struct clk_init_data){
  177. .name = "mmpll3",
  178. .parent_hws = (const struct clk_hw*[]){
  179. &mmpll3_early.clkr.hw
  180. },
  181. .num_parents = 1,
  182. .ops = &clk_alpha_pll_postdiv_ops,
  183. .flags = CLK_SET_RATE_PARENT,
  184. },
  185. };
  186. static struct clk_alpha_pll mmpll4_early = {
  187. .offset = 0x90,
  188. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
  189. .vco_table = mmpll_t_vco,
  190. .num_vco = ARRAY_SIZE(mmpll_t_vco),
  191. .clkr.hw.init = &(struct clk_init_data){
  192. .name = "mmpll4_early",
  193. .parent_data = (const struct clk_parent_data[]){
  194. { .fw_name = "xo", .name = "xo_board" },
  195. },
  196. .num_parents = 1,
  197. .ops = &clk_alpha_pll_ops,
  198. },
  199. };
  200. static struct clk_alpha_pll_postdiv mmpll4 = {
  201. .offset = 0x90,
  202. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
  203. .width = 2,
  204. .clkr.hw.init = &(struct clk_init_data){
  205. .name = "mmpll4",
  206. .parent_hws = (const struct clk_hw*[]){
  207. &mmpll4_early.clkr.hw
  208. },
  209. .num_parents = 1,
  210. .ops = &clk_alpha_pll_postdiv_ops,
  211. .flags = CLK_SET_RATE_PARENT,
  212. },
  213. };
  214. static struct clk_alpha_pll mmpll5_early = {
  215. .offset = 0xc0,
  216. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
  217. .vco_table = mmpll_p_vco,
  218. .num_vco = ARRAY_SIZE(mmpll_p_vco),
  219. .clkr.hw.init = &(struct clk_init_data){
  220. .name = "mmpll5_early",
  221. .parent_data = (const struct clk_parent_data[]){
  222. { .fw_name = "xo", .name = "xo_board" },
  223. },
  224. .num_parents = 1,
  225. .ops = &clk_alpha_pll_ops,
  226. },
  227. };
  228. static struct clk_alpha_pll_postdiv mmpll5 = {
  229. .offset = 0xc0,
  230. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
  231. .width = 4,
  232. .clkr.hw.init = &(struct clk_init_data){
  233. .name = "mmpll5",
  234. .parent_hws = (const struct clk_hw*[]){
  235. &mmpll5_early.clkr.hw
  236. },
  237. .num_parents = 1,
  238. .ops = &clk_alpha_pll_postdiv_ops,
  239. .flags = CLK_SET_RATE_PARENT,
  240. },
  241. };
  242. static struct clk_alpha_pll mmpll8_early = {
  243. .offset = 0x4130,
  244. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
  245. .vco_table = mmpll_gfx_vco,
  246. .num_vco = ARRAY_SIZE(mmpll_gfx_vco),
  247. .clkr.hw.init = &(struct clk_init_data){
  248. .name = "mmpll8_early",
  249. .parent_data = (const struct clk_parent_data[]){
  250. { .fw_name = "xo", .name = "xo_board" },
  251. },
  252. .num_parents = 1,
  253. .ops = &clk_alpha_pll_ops,
  254. },
  255. };
  256. static struct clk_alpha_pll_postdiv mmpll8 = {
  257. .offset = 0x4130,
  258. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
  259. .width = 4,
  260. .clkr.hw.init = &(struct clk_init_data){
  261. .name = "mmpll8",
  262. .parent_hws = (const struct clk_hw*[]){
  263. &mmpll8_early.clkr.hw
  264. },
  265. .num_parents = 1,
  266. .ops = &clk_alpha_pll_postdiv_ops,
  267. .flags = CLK_SET_RATE_PARENT,
  268. },
  269. };
  270. static struct clk_alpha_pll mmpll9_early = {
  271. .offset = 0x4200,
  272. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
  273. .vco_table = mmpll_t_vco,
  274. .num_vco = ARRAY_SIZE(mmpll_t_vco),
  275. .clkr.hw.init = &(struct clk_init_data){
  276. .name = "mmpll9_early",
  277. .parent_data = (const struct clk_parent_data[]){
  278. { .fw_name = "xo", .name = "xo_board" },
  279. },
  280. .num_parents = 1,
  281. .ops = &clk_alpha_pll_ops,
  282. },
  283. };
  284. static struct clk_alpha_pll_postdiv mmpll9 = {
  285. .offset = 0x4200,
  286. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
  287. .width = 2,
  288. .clkr.hw.init = &(struct clk_init_data){
  289. .name = "mmpll9",
  290. .parent_hws = (const struct clk_hw*[]){
  291. &mmpll9_early.clkr.hw
  292. },
  293. .num_parents = 1,
  294. .ops = &clk_alpha_pll_postdiv_ops,
  295. .flags = CLK_SET_RATE_PARENT,
  296. },
  297. };
  298. static const struct parent_map mmss_xo_hdmi_map[] = {
  299. { P_XO, 0 },
  300. { P_HDMIPLL, 1 }
  301. };
  302. static const struct clk_parent_data mmss_xo_hdmi[] = {
  303. { .fw_name = "xo", .name = "xo_board" },
  304. { .fw_name = "hdmipll", .name = "hdmipll" }
  305. };
  306. static const struct parent_map mmss_xo_dsi0pll_dsi1pll_map[] = {
  307. { P_XO, 0 },
  308. { P_DSI0PLL, 1 },
  309. { P_DSI1PLL, 2 }
  310. };
  311. static const struct clk_parent_data mmss_xo_dsi0pll_dsi1pll[] = {
  312. { .fw_name = "xo", .name = "xo_board" },
  313. { .fw_name = "dsi0pll", .name = "dsi0pll" },
  314. { .fw_name = "dsi1pll", .name = "dsi1pll" }
  315. };
  316. static const struct parent_map mmss_xo_gpll0_gpll0_div_map[] = {
  317. { P_XO, 0 },
  318. { P_GPLL0, 5 },
  319. { P_GPLL0_DIV, 6 }
  320. };
  321. static const struct clk_parent_data mmss_xo_gpll0_gpll0_div[] = {
  322. { .fw_name = "xo", .name = "xo_board" },
  323. { .fw_name = "gpll0", .name = "gpll0" },
  324. { .hw = &gpll0_div.hw }
  325. };
  326. static const struct parent_map mmss_xo_dsibyte_map[] = {
  327. { P_XO, 0 },
  328. { P_DSI0PLL_BYTE, 1 },
  329. { P_DSI1PLL_BYTE, 2 }
  330. };
  331. static const struct clk_parent_data mmss_xo_dsibyte[] = {
  332. { .fw_name = "xo", .name = "xo_board" },
  333. { .fw_name = "dsi0pllbyte", .name = "dsi0pllbyte" },
  334. { .fw_name = "dsi1pllbyte", .name = "dsi1pllbyte" }
  335. };
  336. static const struct parent_map mmss_xo_mmpll0_gpll0_gpll0_div_map[] = {
  337. { P_XO, 0 },
  338. { P_MMPLL0, 1 },
  339. { P_GPLL0, 5 },
  340. { P_GPLL0_DIV, 6 }
  341. };
  342. static const struct clk_parent_data mmss_xo_mmpll0_gpll0_gpll0_div[] = {
  343. { .fw_name = "xo", .name = "xo_board" },
  344. { .hw = &mmpll0.clkr.hw },
  345. { .fw_name = "gpll0", .name = "gpll0" },
  346. { .hw = &gpll0_div.hw }
  347. };
  348. static const struct parent_map mmss_xo_mmpll0_mmpll1_gpll0_gpll0_div_map[] = {
  349. { P_XO, 0 },
  350. { P_MMPLL0, 1 },
  351. { P_MMPLL1, 2 },
  352. { P_GPLL0, 5 },
  353. { P_GPLL0_DIV, 6 }
  354. };
  355. static const struct clk_parent_data mmss_xo_mmpll0_mmpll1_gpll0_gpll0_div[] = {
  356. { .fw_name = "xo", .name = "xo_board" },
  357. { .hw = &mmpll0.clkr.hw },
  358. { .hw = &mmpll1.clkr.hw },
  359. { .fw_name = "gpll0", .name = "gpll0" },
  360. { .hw = &gpll0_div.hw }
  361. };
  362. static const struct parent_map mmss_xo_mmpll0_mmpll3_gpll0_gpll0_div_map[] = {
  363. { P_XO, 0 },
  364. { P_MMPLL0, 1 },
  365. { P_MMPLL3, 3 },
  366. { P_GPLL0, 5 },
  367. { P_GPLL0_DIV, 6 }
  368. };
  369. static const struct clk_parent_data mmss_xo_mmpll0_mmpll3_gpll0_gpll0_div[] = {
  370. { .fw_name = "xo", .name = "xo_board" },
  371. { .hw = &mmpll0.clkr.hw },
  372. { .hw = &mmpll3.clkr.hw },
  373. { .fw_name = "gpll0", .name = "gpll0" },
  374. { .hw = &gpll0_div.hw }
  375. };
  376. static const struct parent_map mmss_xo_mmpll0_mmpll5_gpll0_gpll0_div_map[] = {
  377. { P_XO, 0 },
  378. { P_MMPLL0, 1 },
  379. { P_MMPLL5, 2 },
  380. { P_GPLL0, 5 },
  381. { P_GPLL0_DIV, 6 }
  382. };
  383. static const struct clk_parent_data mmss_xo_mmpll0_mmpll5_gpll0_gpll0_div[] = {
  384. { .fw_name = "xo", .name = "xo_board" },
  385. { .hw = &mmpll0.clkr.hw },
  386. { .hw = &mmpll5.clkr.hw },
  387. { .fw_name = "gpll0", .name = "gpll0" },
  388. { .hw = &gpll0_div.hw }
  389. };
  390. static const struct parent_map mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div_map[] = {
  391. { P_XO, 0 },
  392. { P_MMPLL0, 1 },
  393. { P_MMPLL4, 3 },
  394. { P_GPLL0, 5 },
  395. { P_GPLL0_DIV, 6 }
  396. };
  397. static const struct clk_parent_data mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div[] = {
  398. { .fw_name = "xo", .name = "xo_board" },
  399. { .hw = &mmpll0.clkr.hw },
  400. { .hw = &mmpll4.clkr.hw },
  401. { .fw_name = "gpll0", .name = "gpll0" },
  402. { .hw = &gpll0_div.hw }
  403. };
  404. static const struct parent_map mmss_xo_mmpll0_mmpll9_mmpll2_mmpll8_gpll0_map[] = {
  405. { P_XO, 0 },
  406. { P_MMPLL0, 1 },
  407. { P_MMPLL9, 2 },
  408. { P_MMPLL2, 3 },
  409. { P_MMPLL8, 4 },
  410. { P_GPLL0, 5 }
  411. };
  412. static const struct clk_parent_data mmss_xo_mmpll0_mmpll9_mmpll2_mmpll8_gpll0[] = {
  413. { .fw_name = "xo", .name = "xo_board" },
  414. { .hw = &mmpll0.clkr.hw },
  415. { .hw = &mmpll9.clkr.hw },
  416. { .hw = &mmpll2.clkr.hw },
  417. { .hw = &mmpll8.clkr.hw },
  418. { .fw_name = "gpll0", .name = "gpll0" },
  419. };
  420. static const struct parent_map mmss_xo_mmpll0_mmpll9_mmpll2_mmpll8_gpll0_gpll0_div_map[] = {
  421. { P_XO, 0 },
  422. { P_MMPLL0, 1 },
  423. { P_MMPLL9, 2 },
  424. { P_MMPLL2, 3 },
  425. { P_MMPLL8, 4 },
  426. { P_GPLL0, 5 },
  427. { P_GPLL0_DIV, 6 }
  428. };
  429. static const struct clk_parent_data mmss_xo_mmpll0_mmpll9_mmpll2_mmpll8_gpll0_gpll0_div[] = {
  430. { .fw_name = "xo", .name = "xo_board" },
  431. { .hw = &mmpll0.clkr.hw },
  432. { .hw = &mmpll9.clkr.hw },
  433. { .hw = &mmpll2.clkr.hw },
  434. { .hw = &mmpll8.clkr.hw },
  435. { .fw_name = "gpll0", .name = "gpll0" },
  436. { .hw = &gpll0_div.hw }
  437. };
  438. static const struct parent_map mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map[] = {
  439. { P_XO, 0 },
  440. { P_MMPLL0, 1 },
  441. { P_MMPLL1, 2 },
  442. { P_MMPLL4, 3 },
  443. { P_MMPLL3, 4 },
  444. { P_GPLL0, 5 },
  445. { P_GPLL0_DIV, 6 }
  446. };
  447. static const struct clk_parent_data mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div[] = {
  448. { .fw_name = "xo", .name = "xo_board" },
  449. { .hw = &mmpll0.clkr.hw },
  450. { .hw = &mmpll1.clkr.hw },
  451. { .hw = &mmpll4.clkr.hw },
  452. { .hw = &mmpll3.clkr.hw },
  453. { .fw_name = "gpll0", .name = "gpll0" },
  454. { .hw = &gpll0_div.hw }
  455. };
  456. static const struct freq_tbl ftbl_ahb_clk_src[] = {
  457. F(19200000, P_XO, 1, 0, 0),
  458. F(40000000, P_GPLL0_DIV, 7.5, 0, 0),
  459. F(80000000, P_MMPLL0, 10, 0, 0),
  460. { }
  461. };
  462. static struct clk_rcg2 ahb_clk_src = {
  463. .cmd_rcgr = 0x5000,
  464. .hid_width = 5,
  465. .parent_map = mmss_xo_mmpll0_gpll0_gpll0_div_map,
  466. .freq_tbl = ftbl_ahb_clk_src,
  467. .clkr.hw.init = &(struct clk_init_data){
  468. .name = "ahb_clk_src",
  469. .parent_data = mmss_xo_mmpll0_gpll0_gpll0_div,
  470. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_gpll0_gpll0_div),
  471. .ops = &clk_rcg2_ops,
  472. },
  473. };
  474. static const struct freq_tbl ftbl_axi_clk_src[] = {
  475. F(19200000, P_XO, 1, 0, 0),
  476. F(75000000, P_GPLL0_DIV, 4, 0, 0),
  477. F(100000000, P_GPLL0, 6, 0, 0),
  478. F(171430000, P_GPLL0, 3.5, 0, 0),
  479. F(200000000, P_GPLL0, 3, 0, 0),
  480. F(320000000, P_MMPLL0, 2.5, 0, 0),
  481. F(400000000, P_MMPLL0, 2, 0, 0),
  482. { }
  483. };
  484. static struct clk_rcg2 axi_clk_src = {
  485. .cmd_rcgr = 0x5040,
  486. .hid_width = 5,
  487. .parent_map = mmss_xo_mmpll0_mmpll1_gpll0_gpll0_div_map,
  488. .freq_tbl = ftbl_axi_clk_src,
  489. .clkr.hw.init = &(struct clk_init_data){
  490. .name = "axi_clk_src",
  491. .parent_data = mmss_xo_mmpll0_mmpll1_gpll0_gpll0_div,
  492. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_gpll0_gpll0_div),
  493. .ops = &clk_rcg2_ops,
  494. },
  495. };
  496. static struct clk_rcg2 maxi_clk_src = {
  497. .cmd_rcgr = 0x5090,
  498. .hid_width = 5,
  499. .parent_map = mmss_xo_mmpll0_mmpll1_gpll0_gpll0_div_map,
  500. .freq_tbl = ftbl_axi_clk_src,
  501. .clkr.hw.init = &(struct clk_init_data){
  502. .name = "maxi_clk_src",
  503. .parent_data = mmss_xo_mmpll0_mmpll1_gpll0_gpll0_div,
  504. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_gpll0_gpll0_div),
  505. .ops = &clk_rcg2_ops,
  506. },
  507. };
  508. static struct clk_rcg2_gfx3d gfx3d_clk_src = {
  509. .rcg = {
  510. .cmd_rcgr = 0x4000,
  511. .hid_width = 5,
  512. .parent_map = mmss_xo_mmpll0_mmpll9_mmpll2_mmpll8_gpll0_map,
  513. .clkr.hw.init = &(struct clk_init_data){
  514. .name = "gfx3d_clk_src",
  515. .parent_data = mmss_xo_mmpll0_mmpll9_mmpll2_mmpll8_gpll0,
  516. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll9_mmpll2_mmpll8_gpll0),
  517. .ops = &clk_gfx3d_ops,
  518. .flags = CLK_SET_RATE_PARENT,
  519. },
  520. },
  521. .hws = (struct clk_hw*[]) {
  522. &mmpll9.clkr.hw,
  523. &mmpll2.clkr.hw,
  524. &mmpll8.clkr.hw
  525. },
  526. };
  527. static const struct freq_tbl ftbl_rbbmtimer_clk_src[] = {
  528. F(19200000, P_XO, 1, 0, 0),
  529. { }
  530. };
  531. static struct clk_rcg2 rbbmtimer_clk_src = {
  532. .cmd_rcgr = 0x4090,
  533. .hid_width = 5,
  534. .parent_map = mmss_xo_mmpll0_gpll0_gpll0_div_map,
  535. .freq_tbl = ftbl_rbbmtimer_clk_src,
  536. .clkr.hw.init = &(struct clk_init_data){
  537. .name = "rbbmtimer_clk_src",
  538. .parent_data = mmss_xo_mmpll0_gpll0_gpll0_div,
  539. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_gpll0_gpll0_div),
  540. .ops = &clk_rcg2_ops,
  541. },
  542. };
  543. static struct clk_rcg2 isense_clk_src = {
  544. .cmd_rcgr = 0x4010,
  545. .hid_width = 5,
  546. .parent_map = mmss_xo_mmpll0_mmpll9_mmpll2_mmpll8_gpll0_gpll0_div_map,
  547. .clkr.hw.init = &(struct clk_init_data){
  548. .name = "isense_clk_src",
  549. .parent_data = mmss_xo_mmpll0_mmpll9_mmpll2_mmpll8_gpll0_gpll0_div,
  550. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll9_mmpll2_mmpll8_gpll0_gpll0_div),
  551. .ops = &clk_rcg2_ops,
  552. },
  553. };
  554. static const struct freq_tbl ftbl_rbcpr_clk_src[] = {
  555. F(19200000, P_XO, 1, 0, 0),
  556. F(50000000, P_GPLL0, 12, 0, 0),
  557. { }
  558. };
  559. static struct clk_rcg2 rbcpr_clk_src = {
  560. .cmd_rcgr = 0x4060,
  561. .hid_width = 5,
  562. .parent_map = mmss_xo_mmpll0_gpll0_gpll0_div_map,
  563. .freq_tbl = ftbl_rbcpr_clk_src,
  564. .clkr.hw.init = &(struct clk_init_data){
  565. .name = "rbcpr_clk_src",
  566. .parent_data = mmss_xo_mmpll0_gpll0_gpll0_div,
  567. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_gpll0_gpll0_div),
  568. .ops = &clk_rcg2_ops,
  569. },
  570. };
  571. static const struct freq_tbl ftbl_video_core_clk_src[] = {
  572. F(75000000, P_GPLL0_DIV, 4, 0, 0),
  573. F(150000000, P_GPLL0, 4, 0, 0),
  574. F(346666667, P_MMPLL3, 3, 0, 0),
  575. F(520000000, P_MMPLL3, 2, 0, 0),
  576. { }
  577. };
  578. static struct clk_rcg2 video_core_clk_src = {
  579. .cmd_rcgr = 0x1000,
  580. .mnd_width = 8,
  581. .hid_width = 5,
  582. .parent_map = mmss_xo_mmpll0_mmpll3_gpll0_gpll0_div_map,
  583. .freq_tbl = ftbl_video_core_clk_src,
  584. .clkr.hw.init = &(struct clk_init_data){
  585. .name = "video_core_clk_src",
  586. .parent_data = mmss_xo_mmpll0_mmpll3_gpll0_gpll0_div,
  587. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll3_gpll0_gpll0_div),
  588. .ops = &clk_rcg2_ops,
  589. },
  590. };
  591. static struct clk_rcg2 video_subcore0_clk_src = {
  592. .cmd_rcgr = 0x1060,
  593. .mnd_width = 8,
  594. .hid_width = 5,
  595. .parent_map = mmss_xo_mmpll0_mmpll3_gpll0_gpll0_div_map,
  596. .freq_tbl = ftbl_video_core_clk_src,
  597. .clkr.hw.init = &(struct clk_init_data){
  598. .name = "video_subcore0_clk_src",
  599. .parent_data = mmss_xo_mmpll0_mmpll3_gpll0_gpll0_div,
  600. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll3_gpll0_gpll0_div),
  601. .ops = &clk_rcg2_ops,
  602. },
  603. };
  604. static struct clk_rcg2 video_subcore1_clk_src = {
  605. .cmd_rcgr = 0x1080,
  606. .mnd_width = 8,
  607. .hid_width = 5,
  608. .parent_map = mmss_xo_mmpll0_mmpll3_gpll0_gpll0_div_map,
  609. .freq_tbl = ftbl_video_core_clk_src,
  610. .clkr.hw.init = &(struct clk_init_data){
  611. .name = "video_subcore1_clk_src",
  612. .parent_data = mmss_xo_mmpll0_mmpll3_gpll0_gpll0_div,
  613. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll3_gpll0_gpll0_div),
  614. .ops = &clk_rcg2_ops,
  615. },
  616. };
  617. static struct clk_rcg2 pclk0_clk_src = {
  618. .cmd_rcgr = 0x2000,
  619. .mnd_width = 8,
  620. .hid_width = 5,
  621. .parent_map = mmss_xo_dsi0pll_dsi1pll_map,
  622. .clkr.hw.init = &(struct clk_init_data){
  623. .name = "pclk0_clk_src",
  624. .parent_data = mmss_xo_dsi0pll_dsi1pll,
  625. .num_parents = ARRAY_SIZE(mmss_xo_dsi0pll_dsi1pll),
  626. .ops = &clk_pixel_ops,
  627. .flags = CLK_SET_RATE_PARENT,
  628. },
  629. };
  630. static struct clk_rcg2 pclk1_clk_src = {
  631. .cmd_rcgr = 0x2020,
  632. .mnd_width = 8,
  633. .hid_width = 5,
  634. .parent_map = mmss_xo_dsi0pll_dsi1pll_map,
  635. .clkr.hw.init = &(struct clk_init_data){
  636. .name = "pclk1_clk_src",
  637. .parent_data = mmss_xo_dsi0pll_dsi1pll,
  638. .num_parents = ARRAY_SIZE(mmss_xo_dsi0pll_dsi1pll),
  639. .ops = &clk_pixel_ops,
  640. .flags = CLK_SET_RATE_PARENT,
  641. },
  642. };
  643. static const struct freq_tbl ftbl_mdp_clk_src[] = {
  644. F(85714286, P_GPLL0, 7, 0, 0),
  645. F(100000000, P_GPLL0, 6, 0, 0),
  646. F(150000000, P_GPLL0, 4, 0, 0),
  647. F(171428571, P_GPLL0, 3.5, 0, 0),
  648. F(200000000, P_GPLL0, 3, 0, 0),
  649. F(275000000, P_MMPLL5, 3, 0, 0),
  650. F(300000000, P_GPLL0, 2, 0, 0),
  651. F(330000000, P_MMPLL5, 2.5, 0, 0),
  652. F(412500000, P_MMPLL5, 2, 0, 0),
  653. { }
  654. };
  655. static struct clk_rcg2 mdp_clk_src = {
  656. .cmd_rcgr = 0x2040,
  657. .hid_width = 5,
  658. .parent_map = mmss_xo_mmpll0_mmpll5_gpll0_gpll0_div_map,
  659. .freq_tbl = ftbl_mdp_clk_src,
  660. .clkr.hw.init = &(struct clk_init_data){
  661. .name = "mdp_clk_src",
  662. .parent_data = mmss_xo_mmpll0_mmpll5_gpll0_gpll0_div,
  663. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll5_gpll0_gpll0_div),
  664. .ops = &clk_rcg2_ops,
  665. },
  666. };
  667. static const struct freq_tbl extpclk_freq_tbl[] = {
  668. { .src = P_HDMIPLL },
  669. { }
  670. };
  671. static struct clk_rcg2 extpclk_clk_src = {
  672. .cmd_rcgr = 0x2060,
  673. .hid_width = 5,
  674. .parent_map = mmss_xo_hdmi_map,
  675. .freq_tbl = extpclk_freq_tbl,
  676. .clkr.hw.init = &(struct clk_init_data){
  677. .name = "extpclk_clk_src",
  678. .parent_data = mmss_xo_hdmi,
  679. .num_parents = ARRAY_SIZE(mmss_xo_hdmi),
  680. .ops = &clk_byte_ops,
  681. .flags = CLK_SET_RATE_PARENT,
  682. },
  683. };
  684. static const struct freq_tbl ftbl_mdss_vsync_clk[] = {
  685. F(19200000, P_XO, 1, 0, 0),
  686. { }
  687. };
  688. static struct clk_rcg2 vsync_clk_src = {
  689. .cmd_rcgr = 0x2080,
  690. .hid_width = 5,
  691. .parent_map = mmss_xo_gpll0_gpll0_div_map,
  692. .freq_tbl = ftbl_mdss_vsync_clk,
  693. .clkr.hw.init = &(struct clk_init_data){
  694. .name = "vsync_clk_src",
  695. .parent_data = mmss_xo_gpll0_gpll0_div,
  696. .num_parents = ARRAY_SIZE(mmss_xo_gpll0_gpll0_div),
  697. .ops = &clk_rcg2_ops,
  698. },
  699. };
  700. static const struct freq_tbl ftbl_mdss_hdmi_clk[] = {
  701. F(19200000, P_XO, 1, 0, 0),
  702. { }
  703. };
  704. static struct clk_rcg2 hdmi_clk_src = {
  705. .cmd_rcgr = 0x2100,
  706. .hid_width = 5,
  707. .parent_map = mmss_xo_gpll0_gpll0_div_map,
  708. .freq_tbl = ftbl_mdss_hdmi_clk,
  709. .clkr.hw.init = &(struct clk_init_data){
  710. .name = "hdmi_clk_src",
  711. .parent_data = mmss_xo_gpll0_gpll0_div,
  712. .num_parents = ARRAY_SIZE(mmss_xo_gpll0_gpll0_div),
  713. .ops = &clk_rcg2_ops,
  714. },
  715. };
  716. static struct clk_rcg2 byte0_clk_src = {
  717. .cmd_rcgr = 0x2120,
  718. .hid_width = 5,
  719. .parent_map = mmss_xo_dsibyte_map,
  720. .clkr.hw.init = &(struct clk_init_data){
  721. .name = "byte0_clk_src",
  722. .parent_data = mmss_xo_dsibyte,
  723. .num_parents = ARRAY_SIZE(mmss_xo_dsibyte),
  724. .ops = &clk_byte2_ops,
  725. .flags = CLK_SET_RATE_PARENT,
  726. },
  727. };
  728. static struct clk_rcg2 byte1_clk_src = {
  729. .cmd_rcgr = 0x2140,
  730. .hid_width = 5,
  731. .parent_map = mmss_xo_dsibyte_map,
  732. .clkr.hw.init = &(struct clk_init_data){
  733. .name = "byte1_clk_src",
  734. .parent_data = mmss_xo_dsibyte,
  735. .num_parents = ARRAY_SIZE(mmss_xo_dsibyte),
  736. .ops = &clk_byte2_ops,
  737. .flags = CLK_SET_RATE_PARENT,
  738. },
  739. };
  740. static const struct freq_tbl ftbl_mdss_esc0_1_clk[] = {
  741. F(19200000, P_XO, 1, 0, 0),
  742. { }
  743. };
  744. static struct clk_rcg2 esc0_clk_src = {
  745. .cmd_rcgr = 0x2160,
  746. .hid_width = 5,
  747. .parent_map = mmss_xo_dsibyte_map,
  748. .freq_tbl = ftbl_mdss_esc0_1_clk,
  749. .clkr.hw.init = &(struct clk_init_data){
  750. .name = "esc0_clk_src",
  751. .parent_data = mmss_xo_dsibyte,
  752. .num_parents = ARRAY_SIZE(mmss_xo_dsibyte),
  753. .ops = &clk_rcg2_ops,
  754. },
  755. };
  756. static struct clk_rcg2 esc1_clk_src = {
  757. .cmd_rcgr = 0x2180,
  758. .hid_width = 5,
  759. .parent_map = mmss_xo_dsibyte_map,
  760. .freq_tbl = ftbl_mdss_esc0_1_clk,
  761. .clkr.hw.init = &(struct clk_init_data){
  762. .name = "esc1_clk_src",
  763. .parent_data = mmss_xo_dsibyte,
  764. .num_parents = ARRAY_SIZE(mmss_xo_dsibyte),
  765. .ops = &clk_rcg2_ops,
  766. },
  767. };
  768. static const struct freq_tbl ftbl_camss_gp0_clk_src[] = {
  769. F(10000, P_XO, 16, 1, 120),
  770. F(24000, P_XO, 16, 1, 50),
  771. F(6000000, P_GPLL0_DIV, 10, 1, 5),
  772. F(12000000, P_GPLL0_DIV, 1, 1, 25),
  773. F(13000000, P_GPLL0_DIV, 2, 13, 150),
  774. F(24000000, P_GPLL0_DIV, 1, 2, 25),
  775. { }
  776. };
  777. static struct clk_rcg2 camss_gp0_clk_src = {
  778. .cmd_rcgr = 0x3420,
  779. .mnd_width = 8,
  780. .hid_width = 5,
  781. .parent_map = mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div_map,
  782. .freq_tbl = ftbl_camss_gp0_clk_src,
  783. .clkr.hw.init = &(struct clk_init_data){
  784. .name = "camss_gp0_clk_src",
  785. .parent_data = mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div,
  786. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div),
  787. .ops = &clk_rcg2_ops,
  788. },
  789. };
  790. static struct clk_rcg2 camss_gp1_clk_src = {
  791. .cmd_rcgr = 0x3450,
  792. .mnd_width = 8,
  793. .hid_width = 5,
  794. .parent_map = mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div_map,
  795. .freq_tbl = ftbl_camss_gp0_clk_src,
  796. .clkr.hw.init = &(struct clk_init_data){
  797. .name = "camss_gp1_clk_src",
  798. .parent_data = mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div,
  799. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div),
  800. .ops = &clk_rcg2_ops,
  801. },
  802. };
  803. static const struct freq_tbl ftbl_mclk0_clk_src[] = {
  804. F(4800000, P_XO, 4, 0, 0),
  805. F(6000000, P_GPLL0_DIV, 10, 1, 5),
  806. F(8000000, P_GPLL0_DIV, 1, 2, 75),
  807. F(9600000, P_XO, 2, 0, 0),
  808. F(16666667, P_GPLL0_DIV, 2, 1, 9),
  809. F(19200000, P_XO, 1, 0, 0),
  810. F(24000000, P_GPLL0_DIV, 1, 2, 25),
  811. F(33333333, P_GPLL0_DIV, 1, 1, 9),
  812. F(48000000, P_GPLL0, 1, 2, 25),
  813. F(66666667, P_GPLL0, 1, 1, 9),
  814. { }
  815. };
  816. static struct clk_rcg2 mclk0_clk_src = {
  817. .cmd_rcgr = 0x3360,
  818. .mnd_width = 8,
  819. .hid_width = 5,
  820. .parent_map = mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div_map,
  821. .freq_tbl = ftbl_mclk0_clk_src,
  822. .clkr.hw.init = &(struct clk_init_data){
  823. .name = "mclk0_clk_src",
  824. .parent_data = mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div,
  825. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div),
  826. .ops = &clk_rcg2_ops,
  827. },
  828. };
  829. static struct clk_rcg2 mclk1_clk_src = {
  830. .cmd_rcgr = 0x3390,
  831. .mnd_width = 8,
  832. .hid_width = 5,
  833. .parent_map = mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div_map,
  834. .freq_tbl = ftbl_mclk0_clk_src,
  835. .clkr.hw.init = &(struct clk_init_data){
  836. .name = "mclk1_clk_src",
  837. .parent_data = mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div,
  838. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div),
  839. .ops = &clk_rcg2_ops,
  840. },
  841. };
  842. static struct clk_rcg2 mclk2_clk_src = {
  843. .cmd_rcgr = 0x33c0,
  844. .mnd_width = 8,
  845. .hid_width = 5,
  846. .parent_map = mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div_map,
  847. .freq_tbl = ftbl_mclk0_clk_src,
  848. .clkr.hw.init = &(struct clk_init_data){
  849. .name = "mclk2_clk_src",
  850. .parent_data = mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div,
  851. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div),
  852. .ops = &clk_rcg2_ops,
  853. },
  854. };
  855. static struct clk_rcg2 mclk3_clk_src = {
  856. .cmd_rcgr = 0x33f0,
  857. .mnd_width = 8,
  858. .hid_width = 5,
  859. .parent_map = mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div_map,
  860. .freq_tbl = ftbl_mclk0_clk_src,
  861. .clkr.hw.init = &(struct clk_init_data){
  862. .name = "mclk3_clk_src",
  863. .parent_data = mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div,
  864. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div),
  865. .ops = &clk_rcg2_ops,
  866. },
  867. };
  868. static const struct freq_tbl ftbl_cci_clk_src[] = {
  869. F(19200000, P_XO, 1, 0, 0),
  870. F(37500000, P_GPLL0, 16, 0, 0),
  871. F(50000000, P_GPLL0, 12, 0, 0),
  872. F(100000000, P_GPLL0, 6, 0, 0),
  873. { }
  874. };
  875. static struct clk_rcg2 cci_clk_src = {
  876. .cmd_rcgr = 0x3300,
  877. .mnd_width = 8,
  878. .hid_width = 5,
  879. .parent_map = mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div_map,
  880. .freq_tbl = ftbl_cci_clk_src,
  881. .clkr.hw.init = &(struct clk_init_data){
  882. .name = "cci_clk_src",
  883. .parent_data = mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div,
  884. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div),
  885. .ops = &clk_rcg2_ops,
  886. },
  887. };
  888. static const struct freq_tbl ftbl_csi0phytimer_clk_src[] = {
  889. F(100000000, P_GPLL0_DIV, 3, 0, 0),
  890. F(200000000, P_GPLL0, 3, 0, 0),
  891. F(266666667, P_MMPLL0, 3, 0, 0),
  892. { }
  893. };
  894. static struct clk_rcg2 csi0phytimer_clk_src = {
  895. .cmd_rcgr = 0x3000,
  896. .hid_width = 5,
  897. .parent_map = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map,
  898. .freq_tbl = ftbl_csi0phytimer_clk_src,
  899. .clkr.hw.init = &(struct clk_init_data){
  900. .name = "csi0phytimer_clk_src",
  901. .parent_data = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div,
  902. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div),
  903. .ops = &clk_rcg2_ops,
  904. },
  905. };
  906. static struct clk_rcg2 csi1phytimer_clk_src = {
  907. .cmd_rcgr = 0x3030,
  908. .hid_width = 5,
  909. .parent_map = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map,
  910. .freq_tbl = ftbl_csi0phytimer_clk_src,
  911. .clkr.hw.init = &(struct clk_init_data){
  912. .name = "csi1phytimer_clk_src",
  913. .parent_data = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div,
  914. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div),
  915. .ops = &clk_rcg2_ops,
  916. },
  917. };
  918. static struct clk_rcg2 csi2phytimer_clk_src = {
  919. .cmd_rcgr = 0x3060,
  920. .hid_width = 5,
  921. .parent_map = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map,
  922. .freq_tbl = ftbl_csi0phytimer_clk_src,
  923. .clkr.hw.init = &(struct clk_init_data){
  924. .name = "csi2phytimer_clk_src",
  925. .parent_data = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div,
  926. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div),
  927. .ops = &clk_rcg2_ops,
  928. },
  929. };
  930. static const struct freq_tbl ftbl_csiphy0_3p_clk_src[] = {
  931. F(100000000, P_GPLL0_DIV, 3, 0, 0),
  932. F(200000000, P_GPLL0, 3, 0, 0),
  933. F(320000000, P_MMPLL4, 3, 0, 0),
  934. F(384000000, P_MMPLL4, 2.5, 0, 0),
  935. { }
  936. };
  937. static struct clk_rcg2 csiphy0_3p_clk_src = {
  938. .cmd_rcgr = 0x3240,
  939. .hid_width = 5,
  940. .parent_map = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map,
  941. .freq_tbl = ftbl_csiphy0_3p_clk_src,
  942. .clkr.hw.init = &(struct clk_init_data){
  943. .name = "csiphy0_3p_clk_src",
  944. .parent_data = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div,
  945. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div),
  946. .ops = &clk_rcg2_ops,
  947. },
  948. };
  949. static struct clk_rcg2 csiphy1_3p_clk_src = {
  950. .cmd_rcgr = 0x3260,
  951. .hid_width = 5,
  952. .parent_map = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map,
  953. .freq_tbl = ftbl_csiphy0_3p_clk_src,
  954. .clkr.hw.init = &(struct clk_init_data){
  955. .name = "csiphy1_3p_clk_src",
  956. .parent_data = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div,
  957. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div),
  958. .ops = &clk_rcg2_ops,
  959. },
  960. };
  961. static struct clk_rcg2 csiphy2_3p_clk_src = {
  962. .cmd_rcgr = 0x3280,
  963. .hid_width = 5,
  964. .parent_map = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map,
  965. .freq_tbl = ftbl_csiphy0_3p_clk_src,
  966. .clkr.hw.init = &(struct clk_init_data){
  967. .name = "csiphy2_3p_clk_src",
  968. .parent_data = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div,
  969. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div),
  970. .ops = &clk_rcg2_ops,
  971. },
  972. };
  973. static const struct freq_tbl ftbl_jpeg0_clk_src[] = {
  974. F(75000000, P_GPLL0_DIV, 4, 0, 0),
  975. F(150000000, P_GPLL0, 4, 0, 0),
  976. F(228571429, P_MMPLL0, 3.5, 0, 0),
  977. F(266666667, P_MMPLL0, 3, 0, 0),
  978. F(320000000, P_MMPLL0, 2.5, 0, 0),
  979. F(480000000, P_MMPLL4, 2, 0, 0),
  980. { }
  981. };
  982. static struct clk_rcg2 jpeg0_clk_src = {
  983. .cmd_rcgr = 0x3500,
  984. .hid_width = 5,
  985. .parent_map = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map,
  986. .freq_tbl = ftbl_jpeg0_clk_src,
  987. .clkr.hw.init = &(struct clk_init_data){
  988. .name = "jpeg0_clk_src",
  989. .parent_data = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div,
  990. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div),
  991. .ops = &clk_rcg2_ops,
  992. },
  993. };
  994. static const struct freq_tbl ftbl_jpeg2_clk_src[] = {
  995. F(75000000, P_GPLL0_DIV, 4, 0, 0),
  996. F(150000000, P_GPLL0, 4, 0, 0),
  997. F(228571429, P_MMPLL0, 3.5, 0, 0),
  998. F(266666667, P_MMPLL0, 3, 0, 0),
  999. F(320000000, P_MMPLL0, 2.5, 0, 0),
  1000. { }
  1001. };
  1002. static struct clk_rcg2 jpeg2_clk_src = {
  1003. .cmd_rcgr = 0x3540,
  1004. .hid_width = 5,
  1005. .parent_map = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map,
  1006. .freq_tbl = ftbl_jpeg2_clk_src,
  1007. .clkr.hw.init = &(struct clk_init_data){
  1008. .name = "jpeg2_clk_src",
  1009. .parent_data = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div,
  1010. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div),
  1011. .ops = &clk_rcg2_ops,
  1012. },
  1013. };
  1014. static struct clk_rcg2 jpeg_dma_clk_src = {
  1015. .cmd_rcgr = 0x3560,
  1016. .hid_width = 5,
  1017. .parent_map = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map,
  1018. .freq_tbl = ftbl_jpeg0_clk_src,
  1019. .clkr.hw.init = &(struct clk_init_data){
  1020. .name = "jpeg_dma_clk_src",
  1021. .parent_data = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div,
  1022. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div),
  1023. .ops = &clk_rcg2_ops,
  1024. },
  1025. };
  1026. static const struct freq_tbl ftbl_vfe0_clk_src[] = {
  1027. F(75000000, P_GPLL0_DIV, 4, 0, 0),
  1028. F(100000000, P_GPLL0_DIV, 3, 0, 0),
  1029. F(300000000, P_GPLL0, 2, 0, 0),
  1030. F(320000000, P_MMPLL0, 2.5, 0, 0),
  1031. F(480000000, P_MMPLL4, 2, 0, 0),
  1032. F(600000000, P_GPLL0, 1, 0, 0),
  1033. { }
  1034. };
  1035. static struct clk_rcg2 vfe0_clk_src = {
  1036. .cmd_rcgr = 0x3600,
  1037. .hid_width = 5,
  1038. .parent_map = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map,
  1039. .freq_tbl = ftbl_vfe0_clk_src,
  1040. .clkr.hw.init = &(struct clk_init_data){
  1041. .name = "vfe0_clk_src",
  1042. .parent_data = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div,
  1043. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div),
  1044. .ops = &clk_rcg2_ops,
  1045. },
  1046. };
  1047. static struct clk_rcg2 vfe1_clk_src = {
  1048. .cmd_rcgr = 0x3620,
  1049. .hid_width = 5,
  1050. .parent_map = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map,
  1051. .freq_tbl = ftbl_vfe0_clk_src,
  1052. .clkr.hw.init = &(struct clk_init_data){
  1053. .name = "vfe1_clk_src",
  1054. .parent_data = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div,
  1055. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div),
  1056. .ops = &clk_rcg2_ops,
  1057. },
  1058. };
  1059. static const struct freq_tbl ftbl_cpp_clk_src[] = {
  1060. F(100000000, P_GPLL0_DIV, 3, 0, 0),
  1061. F(200000000, P_GPLL0, 3, 0, 0),
  1062. F(320000000, P_MMPLL0, 2.5, 0, 0),
  1063. F(480000000, P_MMPLL4, 2, 0, 0),
  1064. F(640000000, P_MMPLL4, 1.5, 0, 0),
  1065. { }
  1066. };
  1067. static struct clk_rcg2 cpp_clk_src = {
  1068. .cmd_rcgr = 0x3640,
  1069. .hid_width = 5,
  1070. .parent_map = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map,
  1071. .freq_tbl = ftbl_cpp_clk_src,
  1072. .clkr.hw.init = &(struct clk_init_data){
  1073. .name = "cpp_clk_src",
  1074. .parent_data = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div,
  1075. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div),
  1076. .ops = &clk_rcg2_ops,
  1077. },
  1078. };
  1079. static const struct freq_tbl ftbl_csi0_clk_src[] = {
  1080. F(100000000, P_GPLL0_DIV, 3, 0, 0),
  1081. F(200000000, P_GPLL0, 3, 0, 0),
  1082. F(266666667, P_MMPLL0, 3, 0, 0),
  1083. F(480000000, P_MMPLL4, 2, 0, 0),
  1084. F(600000000, P_GPLL0, 1, 0, 0),
  1085. { }
  1086. };
  1087. static struct clk_rcg2 csi0_clk_src = {
  1088. .cmd_rcgr = 0x3090,
  1089. .hid_width = 5,
  1090. .parent_map = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map,
  1091. .freq_tbl = ftbl_csi0_clk_src,
  1092. .clkr.hw.init = &(struct clk_init_data){
  1093. .name = "csi0_clk_src",
  1094. .parent_data = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div,
  1095. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div),
  1096. .ops = &clk_rcg2_ops,
  1097. },
  1098. };
  1099. static struct clk_rcg2 csi1_clk_src = {
  1100. .cmd_rcgr = 0x3100,
  1101. .hid_width = 5,
  1102. .parent_map = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map,
  1103. .freq_tbl = ftbl_csi0_clk_src,
  1104. .clkr.hw.init = &(struct clk_init_data){
  1105. .name = "csi1_clk_src",
  1106. .parent_data = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div,
  1107. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div),
  1108. .ops = &clk_rcg2_ops,
  1109. },
  1110. };
  1111. static struct clk_rcg2 csi2_clk_src = {
  1112. .cmd_rcgr = 0x3160,
  1113. .hid_width = 5,
  1114. .parent_map = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map,
  1115. .freq_tbl = ftbl_csi0_clk_src,
  1116. .clkr.hw.init = &(struct clk_init_data){
  1117. .name = "csi2_clk_src",
  1118. .parent_data = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div,
  1119. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div),
  1120. .ops = &clk_rcg2_ops,
  1121. },
  1122. };
  1123. static struct clk_rcg2 csi3_clk_src = {
  1124. .cmd_rcgr = 0x31c0,
  1125. .hid_width = 5,
  1126. .parent_map = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div_map,
  1127. .freq_tbl = ftbl_csi0_clk_src,
  1128. .clkr.hw.init = &(struct clk_init_data){
  1129. .name = "csi3_clk_src",
  1130. .parent_data = mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div,
  1131. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_mmpll4_mmpll3_gpll0_gpll0_div),
  1132. .ops = &clk_rcg2_ops,
  1133. },
  1134. };
  1135. static const struct freq_tbl ftbl_fd_core_clk_src[] = {
  1136. F(100000000, P_GPLL0_DIV, 3, 0, 0),
  1137. F(200000000, P_GPLL0, 3, 0, 0),
  1138. F(400000000, P_MMPLL0, 2, 0, 0),
  1139. { }
  1140. };
  1141. static struct clk_rcg2 fd_core_clk_src = {
  1142. .cmd_rcgr = 0x3b00,
  1143. .hid_width = 5,
  1144. .parent_map = mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div_map,
  1145. .freq_tbl = ftbl_fd_core_clk_src,
  1146. .clkr.hw.init = &(struct clk_init_data){
  1147. .name = "fd_core_clk_src",
  1148. .parent_data = mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div,
  1149. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll4_gpll0_gpll0_div),
  1150. .ops = &clk_rcg2_ops,
  1151. },
  1152. };
  1153. static struct clk_branch mmss_mmagic_ahb_clk = {
  1154. .halt_reg = 0x5024,
  1155. .clkr = {
  1156. .enable_reg = 0x5024,
  1157. .enable_mask = BIT(0),
  1158. .hw.init = &(struct clk_init_data){
  1159. .name = "mmss_mmagic_ahb_clk",
  1160. .parent_hws = (const struct clk_hw*[]){
  1161. &ahb_clk_src.clkr.hw
  1162. },
  1163. .num_parents = 1,
  1164. .flags = CLK_SET_RATE_PARENT | CLK_IS_CRITICAL,
  1165. .ops = &clk_branch2_ops,
  1166. },
  1167. },
  1168. };
  1169. static struct clk_branch mmss_mmagic_cfg_ahb_clk = {
  1170. .halt_reg = 0x5054,
  1171. .clkr = {
  1172. .enable_reg = 0x5054,
  1173. .enable_mask = BIT(0),
  1174. .hw.init = &(struct clk_init_data){
  1175. .name = "mmss_mmagic_cfg_ahb_clk",
  1176. .parent_hws = (const struct clk_hw*[]){
  1177. &ahb_clk_src.clkr.hw
  1178. },
  1179. .num_parents = 1,
  1180. .flags = CLK_SET_RATE_PARENT | CLK_IS_CRITICAL,
  1181. .ops = &clk_branch2_ops,
  1182. },
  1183. },
  1184. };
  1185. static struct clk_branch mmss_misc_ahb_clk = {
  1186. .halt_reg = 0x5018,
  1187. .clkr = {
  1188. .enable_reg = 0x5018,
  1189. .enable_mask = BIT(0),
  1190. .hw.init = &(struct clk_init_data){
  1191. .name = "mmss_misc_ahb_clk",
  1192. .parent_hws = (const struct clk_hw*[]){
  1193. &ahb_clk_src.clkr.hw
  1194. },
  1195. .num_parents = 1,
  1196. .flags = CLK_SET_RATE_PARENT,
  1197. .ops = &clk_branch2_ops,
  1198. },
  1199. },
  1200. };
  1201. static struct clk_branch mmss_misc_cxo_clk = {
  1202. .halt_reg = 0x5014,
  1203. .clkr = {
  1204. .enable_reg = 0x5014,
  1205. .enable_mask = BIT(0),
  1206. .hw.init = &(struct clk_init_data){
  1207. .name = "mmss_misc_cxo_clk",
  1208. .parent_data = (const struct clk_parent_data[]){
  1209. { .fw_name = "xo", .name = "xo_board" },
  1210. },
  1211. .num_parents = 1,
  1212. .ops = &clk_branch2_ops,
  1213. },
  1214. },
  1215. };
  1216. static struct clk_branch mmss_mmagic_maxi_clk = {
  1217. .halt_reg = 0x5074,
  1218. .clkr = {
  1219. .enable_reg = 0x5074,
  1220. .enable_mask = BIT(0),
  1221. .hw.init = &(struct clk_init_data){
  1222. .name = "mmss_mmagic_maxi_clk",
  1223. .parent_hws = (const struct clk_hw*[]){
  1224. &maxi_clk_src.clkr.hw
  1225. },
  1226. .num_parents = 1,
  1227. .flags = CLK_SET_RATE_PARENT,
  1228. .ops = &clk_branch2_ops,
  1229. },
  1230. },
  1231. };
  1232. static struct clk_branch mmagic_camss_axi_clk = {
  1233. .halt_reg = 0x3c44,
  1234. .clkr = {
  1235. .enable_reg = 0x3c44,
  1236. .enable_mask = BIT(0),
  1237. .hw.init = &(struct clk_init_data){
  1238. .name = "mmagic_camss_axi_clk",
  1239. .parent_hws = (const struct clk_hw*[]){
  1240. &axi_clk_src.clkr.hw
  1241. },
  1242. .num_parents = 1,
  1243. .flags = CLK_SET_RATE_PARENT | CLK_IS_CRITICAL,
  1244. .ops = &clk_branch2_ops,
  1245. },
  1246. },
  1247. };
  1248. static struct clk_branch mmagic_camss_noc_cfg_ahb_clk = {
  1249. .halt_reg = 0x3c48,
  1250. .clkr = {
  1251. .enable_reg = 0x3c48,
  1252. .enable_mask = BIT(0),
  1253. .hw.init = &(struct clk_init_data){
  1254. .name = "mmagic_camss_noc_cfg_ahb_clk",
  1255. .parent_data = (const struct clk_parent_data[]){
  1256. { .fw_name = "gcc_mmss_noc_cfg_ahb_clk", .name = "gcc_mmss_noc_cfg_ahb_clk" },
  1257. },
  1258. .num_parents = 1,
  1259. .flags = CLK_SET_RATE_PARENT | CLK_IS_CRITICAL,
  1260. .ops = &clk_branch2_ops,
  1261. },
  1262. },
  1263. };
  1264. static struct clk_branch smmu_vfe_ahb_clk = {
  1265. .halt_reg = 0x3c04,
  1266. .clkr = {
  1267. .enable_reg = 0x3c04,
  1268. .enable_mask = BIT(0),
  1269. .hw.init = &(struct clk_init_data){
  1270. .name = "smmu_vfe_ahb_clk",
  1271. .parent_hws = (const struct clk_hw*[]){
  1272. &ahb_clk_src.clkr.hw
  1273. },
  1274. .num_parents = 1,
  1275. .flags = CLK_SET_RATE_PARENT,
  1276. .ops = &clk_branch2_ops,
  1277. },
  1278. },
  1279. };
  1280. static struct clk_branch smmu_vfe_axi_clk = {
  1281. .halt_reg = 0x3c08,
  1282. .clkr = {
  1283. .enable_reg = 0x3c08,
  1284. .enable_mask = BIT(0),
  1285. .hw.init = &(struct clk_init_data){
  1286. .name = "smmu_vfe_axi_clk",
  1287. .parent_hws = (const struct clk_hw*[]){
  1288. &axi_clk_src.clkr.hw
  1289. },
  1290. .num_parents = 1,
  1291. .flags = CLK_SET_RATE_PARENT,
  1292. .ops = &clk_branch2_ops,
  1293. },
  1294. },
  1295. };
  1296. static struct clk_branch smmu_cpp_ahb_clk = {
  1297. .halt_reg = 0x3c14,
  1298. .clkr = {
  1299. .enable_reg = 0x3c14,
  1300. .enable_mask = BIT(0),
  1301. .hw.init = &(struct clk_init_data){
  1302. .name = "smmu_cpp_ahb_clk",
  1303. .parent_hws = (const struct clk_hw*[]){
  1304. &ahb_clk_src.clkr.hw
  1305. },
  1306. .num_parents = 1,
  1307. .flags = CLK_SET_RATE_PARENT,
  1308. .ops = &clk_branch2_ops,
  1309. },
  1310. },
  1311. };
  1312. static struct clk_branch smmu_cpp_axi_clk = {
  1313. .halt_reg = 0x3c18,
  1314. .clkr = {
  1315. .enable_reg = 0x3c18,
  1316. .enable_mask = BIT(0),
  1317. .hw.init = &(struct clk_init_data){
  1318. .name = "smmu_cpp_axi_clk",
  1319. .parent_hws = (const struct clk_hw*[]){
  1320. &axi_clk_src.clkr.hw
  1321. },
  1322. .num_parents = 1,
  1323. .flags = CLK_SET_RATE_PARENT,
  1324. .ops = &clk_branch2_ops,
  1325. },
  1326. },
  1327. };
  1328. static struct clk_branch smmu_jpeg_ahb_clk = {
  1329. .halt_reg = 0x3c24,
  1330. .clkr = {
  1331. .enable_reg = 0x3c24,
  1332. .enable_mask = BIT(0),
  1333. .hw.init = &(struct clk_init_data){
  1334. .name = "smmu_jpeg_ahb_clk",
  1335. .parent_hws = (const struct clk_hw*[]){
  1336. &ahb_clk_src.clkr.hw
  1337. },
  1338. .num_parents = 1,
  1339. .flags = CLK_SET_RATE_PARENT,
  1340. .ops = &clk_branch2_ops,
  1341. },
  1342. },
  1343. };
  1344. static struct clk_branch smmu_jpeg_axi_clk = {
  1345. .halt_reg = 0x3c28,
  1346. .clkr = {
  1347. .enable_reg = 0x3c28,
  1348. .enable_mask = BIT(0),
  1349. .hw.init = &(struct clk_init_data){
  1350. .name = "smmu_jpeg_axi_clk",
  1351. .parent_hws = (const struct clk_hw*[]){
  1352. &axi_clk_src.clkr.hw
  1353. },
  1354. .num_parents = 1,
  1355. .flags = CLK_SET_RATE_PARENT,
  1356. .ops = &clk_branch2_ops,
  1357. },
  1358. },
  1359. };
  1360. static struct clk_branch mmagic_mdss_axi_clk = {
  1361. .halt_reg = 0x2474,
  1362. .clkr = {
  1363. .enable_reg = 0x2474,
  1364. .enable_mask = BIT(0),
  1365. .hw.init = &(struct clk_init_data){
  1366. .name = "mmagic_mdss_axi_clk",
  1367. .parent_hws = (const struct clk_hw*[]){
  1368. &axi_clk_src.clkr.hw
  1369. },
  1370. .num_parents = 1,
  1371. .flags = CLK_SET_RATE_PARENT | CLK_IS_CRITICAL,
  1372. .ops = &clk_branch2_ops,
  1373. },
  1374. },
  1375. };
  1376. static struct clk_branch mmagic_mdss_noc_cfg_ahb_clk = {
  1377. .halt_reg = 0x2478,
  1378. .clkr = {
  1379. .enable_reg = 0x2478,
  1380. .enable_mask = BIT(0),
  1381. .hw.init = &(struct clk_init_data){
  1382. .name = "mmagic_mdss_noc_cfg_ahb_clk",
  1383. .parent_data = (const struct clk_parent_data[]){
  1384. { .fw_name = "gcc_mmss_noc_cfg_ahb_clk", .name = "gcc_mmss_noc_cfg_ahb_clk" },
  1385. },
  1386. .num_parents = 1,
  1387. .flags = CLK_SET_RATE_PARENT | CLK_IS_CRITICAL,
  1388. .ops = &clk_branch2_ops,
  1389. },
  1390. },
  1391. };
  1392. static struct clk_branch smmu_rot_ahb_clk = {
  1393. .halt_reg = 0x2444,
  1394. .clkr = {
  1395. .enable_reg = 0x2444,
  1396. .enable_mask = BIT(0),
  1397. .hw.init = &(struct clk_init_data){
  1398. .name = "smmu_rot_ahb_clk",
  1399. .parent_hws = (const struct clk_hw*[]){
  1400. &ahb_clk_src.clkr.hw
  1401. },
  1402. .num_parents = 1,
  1403. .flags = CLK_SET_RATE_PARENT,
  1404. .ops = &clk_branch2_ops,
  1405. },
  1406. },
  1407. };
  1408. static struct clk_branch smmu_rot_axi_clk = {
  1409. .halt_reg = 0x2448,
  1410. .clkr = {
  1411. .enable_reg = 0x2448,
  1412. .enable_mask = BIT(0),
  1413. .hw.init = &(struct clk_init_data){
  1414. .name = "smmu_rot_axi_clk",
  1415. .parent_hws = (const struct clk_hw*[]){
  1416. &axi_clk_src.clkr.hw
  1417. },
  1418. .num_parents = 1,
  1419. .flags = CLK_SET_RATE_PARENT,
  1420. .ops = &clk_branch2_ops,
  1421. },
  1422. },
  1423. };
  1424. static struct clk_branch smmu_mdp_ahb_clk = {
  1425. .halt_reg = 0x2454,
  1426. .clkr = {
  1427. .enable_reg = 0x2454,
  1428. .enable_mask = BIT(0),
  1429. .hw.init = &(struct clk_init_data){
  1430. .name = "smmu_mdp_ahb_clk",
  1431. .parent_hws = (const struct clk_hw*[]){
  1432. &ahb_clk_src.clkr.hw
  1433. },
  1434. .num_parents = 1,
  1435. .flags = CLK_SET_RATE_PARENT,
  1436. .ops = &clk_branch2_ops,
  1437. },
  1438. },
  1439. };
  1440. static struct clk_branch smmu_mdp_axi_clk = {
  1441. .halt_reg = 0x2458,
  1442. .clkr = {
  1443. .enable_reg = 0x2458,
  1444. .enable_mask = BIT(0),
  1445. .hw.init = &(struct clk_init_data){
  1446. .name = "smmu_mdp_axi_clk",
  1447. .parent_hws = (const struct clk_hw*[]){
  1448. &axi_clk_src.clkr.hw
  1449. },
  1450. .num_parents = 1,
  1451. .flags = CLK_SET_RATE_PARENT,
  1452. .ops = &clk_branch2_ops,
  1453. },
  1454. },
  1455. };
  1456. static struct clk_branch mmagic_video_axi_clk = {
  1457. .halt_reg = 0x1194,
  1458. .clkr = {
  1459. .enable_reg = 0x1194,
  1460. .enable_mask = BIT(0),
  1461. .hw.init = &(struct clk_init_data){
  1462. .name = "mmagic_video_axi_clk",
  1463. .parent_hws = (const struct clk_hw*[]){
  1464. &axi_clk_src.clkr.hw
  1465. },
  1466. .num_parents = 1,
  1467. .flags = CLK_SET_RATE_PARENT | CLK_IS_CRITICAL,
  1468. .ops = &clk_branch2_ops,
  1469. },
  1470. },
  1471. };
  1472. static struct clk_branch mmagic_video_noc_cfg_ahb_clk = {
  1473. .halt_reg = 0x1198,
  1474. .clkr = {
  1475. .enable_reg = 0x1198,
  1476. .enable_mask = BIT(0),
  1477. .hw.init = &(struct clk_init_data){
  1478. .name = "mmagic_video_noc_cfg_ahb_clk",
  1479. .parent_data = (const struct clk_parent_data[]){
  1480. { .fw_name = "gcc_mmss_noc_cfg_ahb_clk", .name = "gcc_mmss_noc_cfg_ahb_clk" },
  1481. },
  1482. .num_parents = 1,
  1483. .flags = CLK_SET_RATE_PARENT | CLK_IS_CRITICAL,
  1484. .ops = &clk_branch2_ops,
  1485. },
  1486. },
  1487. };
  1488. static struct clk_branch smmu_video_ahb_clk = {
  1489. .halt_reg = 0x1174,
  1490. .clkr = {
  1491. .enable_reg = 0x1174,
  1492. .enable_mask = BIT(0),
  1493. .hw.init = &(struct clk_init_data){
  1494. .name = "smmu_video_ahb_clk",
  1495. .parent_hws = (const struct clk_hw*[]){
  1496. &ahb_clk_src.clkr.hw
  1497. },
  1498. .num_parents = 1,
  1499. .flags = CLK_SET_RATE_PARENT,
  1500. .ops = &clk_branch2_ops,
  1501. },
  1502. },
  1503. };
  1504. static struct clk_branch smmu_video_axi_clk = {
  1505. .halt_reg = 0x1178,
  1506. .clkr = {
  1507. .enable_reg = 0x1178,
  1508. .enable_mask = BIT(0),
  1509. .hw.init = &(struct clk_init_data){
  1510. .name = "smmu_video_axi_clk",
  1511. .parent_hws = (const struct clk_hw*[]){
  1512. &axi_clk_src.clkr.hw
  1513. },
  1514. .num_parents = 1,
  1515. .flags = CLK_SET_RATE_PARENT,
  1516. .ops = &clk_branch2_ops,
  1517. },
  1518. },
  1519. };
  1520. static struct clk_branch mmagic_bimc_noc_cfg_ahb_clk = {
  1521. .halt_reg = 0x5298,
  1522. .clkr = {
  1523. .enable_reg = 0x5298,
  1524. .enable_mask = BIT(0),
  1525. .hw.init = &(struct clk_init_data){
  1526. .name = "mmagic_bimc_noc_cfg_ahb_clk",
  1527. .parent_data = (const struct clk_parent_data[]){
  1528. { .fw_name = "gcc_mmss_noc_cfg_ahb_clk", .name = "gcc_mmss_noc_cfg_ahb_clk" },
  1529. },
  1530. .num_parents = 1,
  1531. .flags = CLK_SET_RATE_PARENT,
  1532. .ops = &clk_branch2_ops,
  1533. },
  1534. },
  1535. };
  1536. static struct clk_branch gpu_gx_gfx3d_clk = {
  1537. .halt_reg = 0x4028,
  1538. .clkr = {
  1539. .enable_reg = 0x4028,
  1540. .enable_mask = BIT(0),
  1541. .hw.init = &(struct clk_init_data){
  1542. .name = "gpu_gx_gfx3d_clk",
  1543. .parent_hws = (const struct clk_hw*[]){
  1544. &gfx3d_clk_src.rcg.clkr.hw
  1545. },
  1546. .num_parents = 1,
  1547. .flags = CLK_SET_RATE_PARENT,
  1548. .ops = &clk_branch2_ops,
  1549. },
  1550. },
  1551. };
  1552. static struct clk_branch gpu_gx_rbbmtimer_clk = {
  1553. .halt_reg = 0x40b0,
  1554. .clkr = {
  1555. .enable_reg = 0x40b0,
  1556. .enable_mask = BIT(0),
  1557. .hw.init = &(struct clk_init_data){
  1558. .name = "gpu_gx_rbbmtimer_clk",
  1559. .parent_hws = (const struct clk_hw*[]){
  1560. &rbbmtimer_clk_src.clkr.hw
  1561. },
  1562. .num_parents = 1,
  1563. .flags = CLK_SET_RATE_PARENT,
  1564. .ops = &clk_branch2_ops,
  1565. },
  1566. },
  1567. };
  1568. static struct clk_branch gpu_ahb_clk = {
  1569. .halt_reg = 0x403c,
  1570. .clkr = {
  1571. .enable_reg = 0x403c,
  1572. .enable_mask = BIT(0),
  1573. .hw.init = &(struct clk_init_data){
  1574. .name = "gpu_ahb_clk",
  1575. .parent_hws = (const struct clk_hw*[]){
  1576. &ahb_clk_src.clkr.hw
  1577. },
  1578. .num_parents = 1,
  1579. .flags = CLK_SET_RATE_PARENT,
  1580. .ops = &clk_branch2_ops,
  1581. },
  1582. },
  1583. };
  1584. static struct clk_branch gpu_aon_isense_clk = {
  1585. .halt_reg = 0x4044,
  1586. .clkr = {
  1587. .enable_reg = 0x4044,
  1588. .enable_mask = BIT(0),
  1589. .hw.init = &(struct clk_init_data){
  1590. .name = "gpu_aon_isense_clk",
  1591. .parent_hws = (const struct clk_hw*[]){
  1592. &isense_clk_src.clkr.hw
  1593. },
  1594. .num_parents = 1,
  1595. .flags = CLK_SET_RATE_PARENT,
  1596. .ops = &clk_branch2_ops,
  1597. },
  1598. },
  1599. };
  1600. static struct clk_branch vmem_maxi_clk = {
  1601. .halt_reg = 0x1204,
  1602. .clkr = {
  1603. .enable_reg = 0x1204,
  1604. .enable_mask = BIT(0),
  1605. .hw.init = &(struct clk_init_data){
  1606. .name = "vmem_maxi_clk",
  1607. .parent_hws = (const struct clk_hw*[]){
  1608. &maxi_clk_src.clkr.hw
  1609. },
  1610. .num_parents = 1,
  1611. .flags = CLK_SET_RATE_PARENT,
  1612. .ops = &clk_branch2_ops,
  1613. },
  1614. },
  1615. };
  1616. static struct clk_branch vmem_ahb_clk = {
  1617. .halt_reg = 0x1208,
  1618. .clkr = {
  1619. .enable_reg = 0x1208,
  1620. .enable_mask = BIT(0),
  1621. .hw.init = &(struct clk_init_data){
  1622. .name = "vmem_ahb_clk",
  1623. .parent_hws = (const struct clk_hw*[]){
  1624. &ahb_clk_src.clkr.hw
  1625. },
  1626. .num_parents = 1,
  1627. .flags = CLK_SET_RATE_PARENT,
  1628. .ops = &clk_branch2_ops,
  1629. },
  1630. },
  1631. };
  1632. static struct clk_branch mmss_rbcpr_clk = {
  1633. .halt_reg = 0x4084,
  1634. .clkr = {
  1635. .enable_reg = 0x4084,
  1636. .enable_mask = BIT(0),
  1637. .hw.init = &(struct clk_init_data){
  1638. .name = "mmss_rbcpr_clk",
  1639. .parent_hws = (const struct clk_hw*[]){
  1640. &rbcpr_clk_src.clkr.hw
  1641. },
  1642. .num_parents = 1,
  1643. .flags = CLK_SET_RATE_PARENT,
  1644. .ops = &clk_branch2_ops,
  1645. },
  1646. },
  1647. };
  1648. static struct clk_branch mmss_rbcpr_ahb_clk = {
  1649. .halt_reg = 0x4088,
  1650. .clkr = {
  1651. .enable_reg = 0x4088,
  1652. .enable_mask = BIT(0),
  1653. .hw.init = &(struct clk_init_data){
  1654. .name = "mmss_rbcpr_ahb_clk",
  1655. .parent_hws = (const struct clk_hw*[]){
  1656. &ahb_clk_src.clkr.hw
  1657. },
  1658. .num_parents = 1,
  1659. .flags = CLK_SET_RATE_PARENT,
  1660. .ops = &clk_branch2_ops,
  1661. },
  1662. },
  1663. };
  1664. static struct clk_branch video_core_clk = {
  1665. .halt_reg = 0x1028,
  1666. .clkr = {
  1667. .enable_reg = 0x1028,
  1668. .enable_mask = BIT(0),
  1669. .hw.init = &(struct clk_init_data){
  1670. .name = "video_core_clk",
  1671. .parent_hws = (const struct clk_hw*[]){
  1672. &video_core_clk_src.clkr.hw
  1673. },
  1674. .num_parents = 1,
  1675. .flags = CLK_SET_RATE_PARENT,
  1676. .ops = &clk_branch2_ops,
  1677. },
  1678. },
  1679. };
  1680. static struct clk_branch video_axi_clk = {
  1681. .halt_reg = 0x1034,
  1682. .clkr = {
  1683. .enable_reg = 0x1034,
  1684. .enable_mask = BIT(0),
  1685. .hw.init = &(struct clk_init_data){
  1686. .name = "video_axi_clk",
  1687. .parent_hws = (const struct clk_hw*[]){
  1688. &axi_clk_src.clkr.hw
  1689. },
  1690. .num_parents = 1,
  1691. .flags = CLK_SET_RATE_PARENT,
  1692. .ops = &clk_branch2_ops,
  1693. },
  1694. },
  1695. };
  1696. static struct clk_branch video_maxi_clk = {
  1697. .halt_reg = 0x1038,
  1698. .clkr = {
  1699. .enable_reg = 0x1038,
  1700. .enable_mask = BIT(0),
  1701. .hw.init = &(struct clk_init_data){
  1702. .name = "video_maxi_clk",
  1703. .parent_hws = (const struct clk_hw*[]){
  1704. &maxi_clk_src.clkr.hw
  1705. },
  1706. .num_parents = 1,
  1707. .flags = CLK_SET_RATE_PARENT,
  1708. .ops = &clk_branch2_ops,
  1709. },
  1710. },
  1711. };
  1712. static struct clk_branch video_ahb_clk = {
  1713. .halt_reg = 0x1030,
  1714. .clkr = {
  1715. .enable_reg = 0x1030,
  1716. .enable_mask = BIT(0),
  1717. .hw.init = &(struct clk_init_data){
  1718. .name = "video_ahb_clk",
  1719. .parent_hws = (const struct clk_hw*[]){
  1720. &ahb_clk_src.clkr.hw
  1721. },
  1722. .num_parents = 1,
  1723. .flags = CLK_SET_RATE_PARENT,
  1724. .ops = &clk_branch2_ops,
  1725. },
  1726. },
  1727. };
  1728. static struct clk_branch video_subcore0_clk = {
  1729. .halt_reg = 0x1048,
  1730. .clkr = {
  1731. .enable_reg = 0x1048,
  1732. .enable_mask = BIT(0),
  1733. .hw.init = &(struct clk_init_data){
  1734. .name = "video_subcore0_clk",
  1735. .parent_hws = (const struct clk_hw*[]){
  1736. &video_subcore0_clk_src.clkr.hw
  1737. },
  1738. .num_parents = 1,
  1739. .flags = CLK_SET_RATE_PARENT,
  1740. .ops = &clk_branch2_ops,
  1741. },
  1742. },
  1743. };
  1744. static struct clk_branch video_subcore1_clk = {
  1745. .halt_reg = 0x104c,
  1746. .clkr = {
  1747. .enable_reg = 0x104c,
  1748. .enable_mask = BIT(0),
  1749. .hw.init = &(struct clk_init_data){
  1750. .name = "video_subcore1_clk",
  1751. .parent_hws = (const struct clk_hw*[]){
  1752. &video_subcore1_clk_src.clkr.hw
  1753. },
  1754. .num_parents = 1,
  1755. .flags = CLK_SET_RATE_PARENT,
  1756. .ops = &clk_branch2_ops,
  1757. },
  1758. },
  1759. };
  1760. static struct clk_branch mdss_ahb_clk = {
  1761. .halt_reg = 0x2308,
  1762. .clkr = {
  1763. .enable_reg = 0x2308,
  1764. .enable_mask = BIT(0),
  1765. .hw.init = &(struct clk_init_data){
  1766. .name = "mdss_ahb_clk",
  1767. .parent_hws = (const struct clk_hw*[]){
  1768. &ahb_clk_src.clkr.hw
  1769. },
  1770. .num_parents = 1,
  1771. .flags = CLK_SET_RATE_PARENT,
  1772. .ops = &clk_branch2_ops,
  1773. },
  1774. },
  1775. };
  1776. static struct clk_branch mdss_hdmi_ahb_clk = {
  1777. .halt_reg = 0x230c,
  1778. .clkr = {
  1779. .enable_reg = 0x230c,
  1780. .enable_mask = BIT(0),
  1781. .hw.init = &(struct clk_init_data){
  1782. .name = "mdss_hdmi_ahb_clk",
  1783. .parent_hws = (const struct clk_hw*[]){
  1784. &ahb_clk_src.clkr.hw
  1785. },
  1786. .num_parents = 1,
  1787. .flags = CLK_SET_RATE_PARENT,
  1788. .ops = &clk_branch2_ops,
  1789. },
  1790. },
  1791. };
  1792. static struct clk_branch mdss_axi_clk = {
  1793. .halt_reg = 0x2310,
  1794. .clkr = {
  1795. .enable_reg = 0x2310,
  1796. .enable_mask = BIT(0),
  1797. .hw.init = &(struct clk_init_data){
  1798. .name = "mdss_axi_clk",
  1799. .parent_hws = (const struct clk_hw*[]){
  1800. &axi_clk_src.clkr.hw
  1801. },
  1802. .num_parents = 1,
  1803. .flags = CLK_SET_RATE_PARENT,
  1804. .ops = &clk_branch2_ops,
  1805. },
  1806. },
  1807. };
  1808. static struct clk_branch mdss_pclk0_clk = {
  1809. .halt_reg = 0x2314,
  1810. .clkr = {
  1811. .enable_reg = 0x2314,
  1812. .enable_mask = BIT(0),
  1813. .hw.init = &(struct clk_init_data){
  1814. .name = "mdss_pclk0_clk",
  1815. .parent_hws = (const struct clk_hw*[]){
  1816. &pclk0_clk_src.clkr.hw
  1817. },
  1818. .num_parents = 1,
  1819. .flags = CLK_SET_RATE_PARENT,
  1820. .ops = &clk_branch2_ops,
  1821. },
  1822. },
  1823. };
  1824. static struct clk_branch mdss_pclk1_clk = {
  1825. .halt_reg = 0x2318,
  1826. .clkr = {
  1827. .enable_reg = 0x2318,
  1828. .enable_mask = BIT(0),
  1829. .hw.init = &(struct clk_init_data){
  1830. .name = "mdss_pclk1_clk",
  1831. .parent_hws = (const struct clk_hw*[]){
  1832. &pclk1_clk_src.clkr.hw
  1833. },
  1834. .num_parents = 1,
  1835. .flags = CLK_SET_RATE_PARENT,
  1836. .ops = &clk_branch2_ops,
  1837. },
  1838. },
  1839. };
  1840. static struct clk_branch mdss_mdp_clk = {
  1841. .halt_reg = 0x231c,
  1842. .clkr = {
  1843. .enable_reg = 0x231c,
  1844. .enable_mask = BIT(0),
  1845. .hw.init = &(struct clk_init_data){
  1846. .name = "mdss_mdp_clk",
  1847. .parent_hws = (const struct clk_hw*[]){
  1848. &mdp_clk_src.clkr.hw
  1849. },
  1850. .num_parents = 1,
  1851. .flags = CLK_SET_RATE_PARENT,
  1852. .ops = &clk_branch2_ops,
  1853. },
  1854. },
  1855. };
  1856. static struct clk_branch mdss_extpclk_clk = {
  1857. .halt_reg = 0x2324,
  1858. .clkr = {
  1859. .enable_reg = 0x2324,
  1860. .enable_mask = BIT(0),
  1861. .hw.init = &(struct clk_init_data){
  1862. .name = "mdss_extpclk_clk",
  1863. .parent_hws = (const struct clk_hw*[]){
  1864. &extpclk_clk_src.clkr.hw
  1865. },
  1866. .num_parents = 1,
  1867. .flags = CLK_SET_RATE_PARENT,
  1868. .ops = &clk_branch2_ops,
  1869. },
  1870. },
  1871. };
  1872. static struct clk_branch mdss_vsync_clk = {
  1873. .halt_reg = 0x2328,
  1874. .clkr = {
  1875. .enable_reg = 0x2328,
  1876. .enable_mask = BIT(0),
  1877. .hw.init = &(struct clk_init_data){
  1878. .name = "mdss_vsync_clk",
  1879. .parent_hws = (const struct clk_hw*[]){
  1880. &vsync_clk_src.clkr.hw
  1881. },
  1882. .num_parents = 1,
  1883. .flags = CLK_SET_RATE_PARENT,
  1884. .ops = &clk_branch2_ops,
  1885. },
  1886. },
  1887. };
  1888. static struct clk_branch mdss_hdmi_clk = {
  1889. .halt_reg = 0x2338,
  1890. .clkr = {
  1891. .enable_reg = 0x2338,
  1892. .enable_mask = BIT(0),
  1893. .hw.init = &(struct clk_init_data){
  1894. .name = "mdss_hdmi_clk",
  1895. .parent_hws = (const struct clk_hw*[]){
  1896. &hdmi_clk_src.clkr.hw
  1897. },
  1898. .num_parents = 1,
  1899. .flags = CLK_SET_RATE_PARENT,
  1900. .ops = &clk_branch2_ops,
  1901. },
  1902. },
  1903. };
  1904. static struct clk_branch mdss_byte0_clk = {
  1905. .halt_reg = 0x233c,
  1906. .clkr = {
  1907. .enable_reg = 0x233c,
  1908. .enable_mask = BIT(0),
  1909. .hw.init = &(struct clk_init_data){
  1910. .name = "mdss_byte0_clk",
  1911. .parent_hws = (const struct clk_hw*[]){
  1912. &byte0_clk_src.clkr.hw
  1913. },
  1914. .num_parents = 1,
  1915. .flags = CLK_SET_RATE_PARENT,
  1916. .ops = &clk_branch2_ops,
  1917. },
  1918. },
  1919. };
  1920. static struct clk_branch mdss_byte1_clk = {
  1921. .halt_reg = 0x2340,
  1922. .clkr = {
  1923. .enable_reg = 0x2340,
  1924. .enable_mask = BIT(0),
  1925. .hw.init = &(struct clk_init_data){
  1926. .name = "mdss_byte1_clk",
  1927. .parent_hws = (const struct clk_hw*[]){
  1928. &byte1_clk_src.clkr.hw
  1929. },
  1930. .num_parents = 1,
  1931. .flags = CLK_SET_RATE_PARENT,
  1932. .ops = &clk_branch2_ops,
  1933. },
  1934. },
  1935. };
  1936. static struct clk_branch mdss_esc0_clk = {
  1937. .halt_reg = 0x2344,
  1938. .clkr = {
  1939. .enable_reg = 0x2344,
  1940. .enable_mask = BIT(0),
  1941. .hw.init = &(struct clk_init_data){
  1942. .name = "mdss_esc0_clk",
  1943. .parent_hws = (const struct clk_hw*[]){
  1944. &esc0_clk_src.clkr.hw
  1945. },
  1946. .num_parents = 1,
  1947. .flags = CLK_SET_RATE_PARENT,
  1948. .ops = &clk_branch2_ops,
  1949. },
  1950. },
  1951. };
  1952. static struct clk_branch mdss_esc1_clk = {
  1953. .halt_reg = 0x2348,
  1954. .clkr = {
  1955. .enable_reg = 0x2348,
  1956. .enable_mask = BIT(0),
  1957. .hw.init = &(struct clk_init_data){
  1958. .name = "mdss_esc1_clk",
  1959. .parent_hws = (const struct clk_hw*[]){
  1960. &esc1_clk_src.clkr.hw
  1961. },
  1962. .num_parents = 1,
  1963. .flags = CLK_SET_RATE_PARENT,
  1964. .ops = &clk_branch2_ops,
  1965. },
  1966. },
  1967. };
  1968. static struct clk_branch camss_top_ahb_clk = {
  1969. .halt_reg = 0x3484,
  1970. .clkr = {
  1971. .enable_reg = 0x3484,
  1972. .enable_mask = BIT(0),
  1973. .hw.init = &(struct clk_init_data){
  1974. .name = "camss_top_ahb_clk",
  1975. .parent_hws = (const struct clk_hw*[]){
  1976. &ahb_clk_src.clkr.hw
  1977. },
  1978. .num_parents = 1,
  1979. .flags = CLK_SET_RATE_PARENT,
  1980. .ops = &clk_branch2_ops,
  1981. },
  1982. },
  1983. };
  1984. static struct clk_branch camss_ahb_clk = {
  1985. .halt_reg = 0x348c,
  1986. .clkr = {
  1987. .enable_reg = 0x348c,
  1988. .enable_mask = BIT(0),
  1989. .hw.init = &(struct clk_init_data){
  1990. .name = "camss_ahb_clk",
  1991. .parent_hws = (const struct clk_hw*[]){
  1992. &ahb_clk_src.clkr.hw
  1993. },
  1994. .num_parents = 1,
  1995. .flags = CLK_SET_RATE_PARENT,
  1996. .ops = &clk_branch2_ops,
  1997. },
  1998. },
  1999. };
  2000. static struct clk_branch camss_micro_ahb_clk = {
  2001. .halt_reg = 0x3494,
  2002. .clkr = {
  2003. .enable_reg = 0x3494,
  2004. .enable_mask = BIT(0),
  2005. .hw.init = &(struct clk_init_data){
  2006. .name = "camss_micro_ahb_clk",
  2007. .parent_hws = (const struct clk_hw*[]){
  2008. &ahb_clk_src.clkr.hw
  2009. },
  2010. .num_parents = 1,
  2011. .flags = CLK_SET_RATE_PARENT,
  2012. .ops = &clk_branch2_ops,
  2013. },
  2014. },
  2015. };
  2016. static struct clk_branch camss_gp0_clk = {
  2017. .halt_reg = 0x3444,
  2018. .clkr = {
  2019. .enable_reg = 0x3444,
  2020. .enable_mask = BIT(0),
  2021. .hw.init = &(struct clk_init_data){
  2022. .name = "camss_gp0_clk",
  2023. .parent_hws = (const struct clk_hw*[]){
  2024. &camss_gp0_clk_src.clkr.hw
  2025. },
  2026. .num_parents = 1,
  2027. .flags = CLK_SET_RATE_PARENT,
  2028. .ops = &clk_branch2_ops,
  2029. },
  2030. },
  2031. };
  2032. static struct clk_branch camss_gp1_clk = {
  2033. .halt_reg = 0x3474,
  2034. .clkr = {
  2035. .enable_reg = 0x3474,
  2036. .enable_mask = BIT(0),
  2037. .hw.init = &(struct clk_init_data){
  2038. .name = "camss_gp1_clk",
  2039. .parent_hws = (const struct clk_hw*[]){
  2040. &camss_gp1_clk_src.clkr.hw
  2041. },
  2042. .num_parents = 1,
  2043. .flags = CLK_SET_RATE_PARENT,
  2044. .ops = &clk_branch2_ops,
  2045. },
  2046. },
  2047. };
  2048. static struct clk_branch camss_mclk0_clk = {
  2049. .halt_reg = 0x3384,
  2050. .clkr = {
  2051. .enable_reg = 0x3384,
  2052. .enable_mask = BIT(0),
  2053. .hw.init = &(struct clk_init_data){
  2054. .name = "camss_mclk0_clk",
  2055. .parent_hws = (const struct clk_hw*[]){
  2056. &mclk0_clk_src.clkr.hw
  2057. },
  2058. .num_parents = 1,
  2059. .flags = CLK_SET_RATE_PARENT,
  2060. .ops = &clk_branch2_ops,
  2061. },
  2062. },
  2063. };
  2064. static struct clk_branch camss_mclk1_clk = {
  2065. .halt_reg = 0x33b4,
  2066. .clkr = {
  2067. .enable_reg = 0x33b4,
  2068. .enable_mask = BIT(0),
  2069. .hw.init = &(struct clk_init_data){
  2070. .name = "camss_mclk1_clk",
  2071. .parent_hws = (const struct clk_hw*[]){
  2072. &mclk1_clk_src.clkr.hw
  2073. },
  2074. .num_parents = 1,
  2075. .flags = CLK_SET_RATE_PARENT,
  2076. .ops = &clk_branch2_ops,
  2077. },
  2078. },
  2079. };
  2080. static struct clk_branch camss_mclk2_clk = {
  2081. .halt_reg = 0x33e4,
  2082. .clkr = {
  2083. .enable_reg = 0x33e4,
  2084. .enable_mask = BIT(0),
  2085. .hw.init = &(struct clk_init_data){
  2086. .name = "camss_mclk2_clk",
  2087. .parent_hws = (const struct clk_hw*[]){
  2088. &mclk2_clk_src.clkr.hw
  2089. },
  2090. .num_parents = 1,
  2091. .flags = CLK_SET_RATE_PARENT,
  2092. .ops = &clk_branch2_ops,
  2093. },
  2094. },
  2095. };
  2096. static struct clk_branch camss_mclk3_clk = {
  2097. .halt_reg = 0x3414,
  2098. .clkr = {
  2099. .enable_reg = 0x3414,
  2100. .enable_mask = BIT(0),
  2101. .hw.init = &(struct clk_init_data){
  2102. .name = "camss_mclk3_clk",
  2103. .parent_hws = (const struct clk_hw*[]){
  2104. &mclk3_clk_src.clkr.hw
  2105. },
  2106. .num_parents = 1,
  2107. .flags = CLK_SET_RATE_PARENT,
  2108. .ops = &clk_branch2_ops,
  2109. },
  2110. },
  2111. };
  2112. static struct clk_branch camss_cci_clk = {
  2113. .halt_reg = 0x3344,
  2114. .clkr = {
  2115. .enable_reg = 0x3344,
  2116. .enable_mask = BIT(0),
  2117. .hw.init = &(struct clk_init_data){
  2118. .name = "camss_cci_clk",
  2119. .parent_hws = (const struct clk_hw*[]){
  2120. &cci_clk_src.clkr.hw
  2121. },
  2122. .num_parents = 1,
  2123. .flags = CLK_SET_RATE_PARENT,
  2124. .ops = &clk_branch2_ops,
  2125. },
  2126. },
  2127. };
  2128. static struct clk_branch camss_cci_ahb_clk = {
  2129. .halt_reg = 0x3348,
  2130. .clkr = {
  2131. .enable_reg = 0x3348,
  2132. .enable_mask = BIT(0),
  2133. .hw.init = &(struct clk_init_data){
  2134. .name = "camss_cci_ahb_clk",
  2135. .parent_hws = (const struct clk_hw*[]){
  2136. &ahb_clk_src.clkr.hw
  2137. },
  2138. .num_parents = 1,
  2139. .flags = CLK_SET_RATE_PARENT,
  2140. .ops = &clk_branch2_ops,
  2141. },
  2142. },
  2143. };
  2144. static struct clk_branch camss_csi0phytimer_clk = {
  2145. .halt_reg = 0x3024,
  2146. .clkr = {
  2147. .enable_reg = 0x3024,
  2148. .enable_mask = BIT(0),
  2149. .hw.init = &(struct clk_init_data){
  2150. .name = "camss_csi0phytimer_clk",
  2151. .parent_hws = (const struct clk_hw*[]){
  2152. &csi0phytimer_clk_src.clkr.hw
  2153. },
  2154. .num_parents = 1,
  2155. .flags = CLK_SET_RATE_PARENT,
  2156. .ops = &clk_branch2_ops,
  2157. },
  2158. },
  2159. };
  2160. static struct clk_branch camss_csi1phytimer_clk = {
  2161. .halt_reg = 0x3054,
  2162. .clkr = {
  2163. .enable_reg = 0x3054,
  2164. .enable_mask = BIT(0),
  2165. .hw.init = &(struct clk_init_data){
  2166. .name = "camss_csi1phytimer_clk",
  2167. .parent_hws = (const struct clk_hw*[]){
  2168. &csi1phytimer_clk_src.clkr.hw
  2169. },
  2170. .num_parents = 1,
  2171. .flags = CLK_SET_RATE_PARENT,
  2172. .ops = &clk_branch2_ops,
  2173. },
  2174. },
  2175. };
  2176. static struct clk_branch camss_csi2phytimer_clk = {
  2177. .halt_reg = 0x3084,
  2178. .clkr = {
  2179. .enable_reg = 0x3084,
  2180. .enable_mask = BIT(0),
  2181. .hw.init = &(struct clk_init_data){
  2182. .name = "camss_csi2phytimer_clk",
  2183. .parent_hws = (const struct clk_hw*[]){
  2184. &csi2phytimer_clk_src.clkr.hw
  2185. },
  2186. .num_parents = 1,
  2187. .flags = CLK_SET_RATE_PARENT,
  2188. .ops = &clk_branch2_ops,
  2189. },
  2190. },
  2191. };
  2192. static struct clk_branch camss_csiphy0_3p_clk = {
  2193. .halt_reg = 0x3234,
  2194. .clkr = {
  2195. .enable_reg = 0x3234,
  2196. .enable_mask = BIT(0),
  2197. .hw.init = &(struct clk_init_data){
  2198. .name = "camss_csiphy0_3p_clk",
  2199. .parent_hws = (const struct clk_hw*[]){
  2200. &csiphy0_3p_clk_src.clkr.hw
  2201. },
  2202. .num_parents = 1,
  2203. .flags = CLK_SET_RATE_PARENT,
  2204. .ops = &clk_branch2_ops,
  2205. },
  2206. },
  2207. };
  2208. static struct clk_branch camss_csiphy1_3p_clk = {
  2209. .halt_reg = 0x3254,
  2210. .clkr = {
  2211. .enable_reg = 0x3254,
  2212. .enable_mask = BIT(0),
  2213. .hw.init = &(struct clk_init_data){
  2214. .name = "camss_csiphy1_3p_clk",
  2215. .parent_hws = (const struct clk_hw*[]){
  2216. &csiphy1_3p_clk_src.clkr.hw
  2217. },
  2218. .num_parents = 1,
  2219. .flags = CLK_SET_RATE_PARENT,
  2220. .ops = &clk_branch2_ops,
  2221. },
  2222. },
  2223. };
  2224. static struct clk_branch camss_csiphy2_3p_clk = {
  2225. .halt_reg = 0x3274,
  2226. .clkr = {
  2227. .enable_reg = 0x3274,
  2228. .enable_mask = BIT(0),
  2229. .hw.init = &(struct clk_init_data){
  2230. .name = "camss_csiphy2_3p_clk",
  2231. .parent_hws = (const struct clk_hw*[]){
  2232. &csiphy2_3p_clk_src.clkr.hw
  2233. },
  2234. .num_parents = 1,
  2235. .flags = CLK_SET_RATE_PARENT,
  2236. .ops = &clk_branch2_ops,
  2237. },
  2238. },
  2239. };
  2240. static struct clk_branch camss_jpeg0_clk = {
  2241. .halt_reg = 0x35a8,
  2242. .clkr = {
  2243. .enable_reg = 0x35a8,
  2244. .enable_mask = BIT(0),
  2245. .hw.init = &(struct clk_init_data){
  2246. .name = "camss_jpeg0_clk",
  2247. .parent_hws = (const struct clk_hw*[]){
  2248. &jpeg0_clk_src.clkr.hw
  2249. },
  2250. .num_parents = 1,
  2251. .flags = CLK_SET_RATE_PARENT,
  2252. .ops = &clk_branch2_ops,
  2253. },
  2254. },
  2255. };
  2256. static struct clk_branch camss_jpeg2_clk = {
  2257. .halt_reg = 0x35b0,
  2258. .clkr = {
  2259. .enable_reg = 0x35b0,
  2260. .enable_mask = BIT(0),
  2261. .hw.init = &(struct clk_init_data){
  2262. .name = "camss_jpeg2_clk",
  2263. .parent_hws = (const struct clk_hw*[]){
  2264. &jpeg2_clk_src.clkr.hw
  2265. },
  2266. .num_parents = 1,
  2267. .flags = CLK_SET_RATE_PARENT,
  2268. .ops = &clk_branch2_ops,
  2269. },
  2270. },
  2271. };
  2272. static struct clk_branch camss_jpeg_dma_clk = {
  2273. .halt_reg = 0x35c0,
  2274. .clkr = {
  2275. .enable_reg = 0x35c0,
  2276. .enable_mask = BIT(0),
  2277. .hw.init = &(struct clk_init_data){
  2278. .name = "camss_jpeg_dma_clk",
  2279. .parent_hws = (const struct clk_hw*[]){
  2280. &jpeg_dma_clk_src.clkr.hw
  2281. },
  2282. .num_parents = 1,
  2283. .flags = CLK_SET_RATE_PARENT,
  2284. .ops = &clk_branch2_ops,
  2285. },
  2286. },
  2287. };
  2288. static struct clk_branch camss_jpeg_ahb_clk = {
  2289. .halt_reg = 0x35b4,
  2290. .clkr = {
  2291. .enable_reg = 0x35b4,
  2292. .enable_mask = BIT(0),
  2293. .hw.init = &(struct clk_init_data){
  2294. .name = "camss_jpeg_ahb_clk",
  2295. .parent_hws = (const struct clk_hw*[]){
  2296. &ahb_clk_src.clkr.hw
  2297. },
  2298. .num_parents = 1,
  2299. .flags = CLK_SET_RATE_PARENT,
  2300. .ops = &clk_branch2_ops,
  2301. },
  2302. },
  2303. };
  2304. static struct clk_branch camss_jpeg_axi_clk = {
  2305. .halt_reg = 0x35b8,
  2306. .clkr = {
  2307. .enable_reg = 0x35b8,
  2308. .enable_mask = BIT(0),
  2309. .hw.init = &(struct clk_init_data){
  2310. .name = "camss_jpeg_axi_clk",
  2311. .parent_hws = (const struct clk_hw*[]){
  2312. &axi_clk_src.clkr.hw
  2313. },
  2314. .num_parents = 1,
  2315. .flags = CLK_SET_RATE_PARENT,
  2316. .ops = &clk_branch2_ops,
  2317. },
  2318. },
  2319. };
  2320. static struct clk_branch camss_vfe_ahb_clk = {
  2321. .halt_reg = 0x36b8,
  2322. .clkr = {
  2323. .enable_reg = 0x36b8,
  2324. .enable_mask = BIT(0),
  2325. .hw.init = &(struct clk_init_data){
  2326. .name = "camss_vfe_ahb_clk",
  2327. .parent_hws = (const struct clk_hw*[]){
  2328. &ahb_clk_src.clkr.hw
  2329. },
  2330. .num_parents = 1,
  2331. .flags = CLK_SET_RATE_PARENT,
  2332. .ops = &clk_branch2_ops,
  2333. },
  2334. },
  2335. };
  2336. static struct clk_branch camss_vfe_axi_clk = {
  2337. .halt_reg = 0x36bc,
  2338. .clkr = {
  2339. .enable_reg = 0x36bc,
  2340. .enable_mask = BIT(0),
  2341. .hw.init = &(struct clk_init_data){
  2342. .name = "camss_vfe_axi_clk",
  2343. .parent_hws = (const struct clk_hw*[]){
  2344. &axi_clk_src.clkr.hw
  2345. },
  2346. .num_parents = 1,
  2347. .flags = CLK_SET_RATE_PARENT,
  2348. .ops = &clk_branch2_ops,
  2349. },
  2350. },
  2351. };
  2352. static struct clk_branch camss_vfe0_clk = {
  2353. .halt_reg = 0x36a8,
  2354. .clkr = {
  2355. .enable_reg = 0x36a8,
  2356. .enable_mask = BIT(0),
  2357. .hw.init = &(struct clk_init_data){
  2358. .name = "camss_vfe0_clk",
  2359. .parent_hws = (const struct clk_hw*[]){
  2360. &vfe0_clk_src.clkr.hw
  2361. },
  2362. .num_parents = 1,
  2363. .flags = CLK_SET_RATE_PARENT,
  2364. .ops = &clk_branch2_ops,
  2365. },
  2366. },
  2367. };
  2368. static struct clk_branch camss_vfe0_stream_clk = {
  2369. .halt_reg = 0x3720,
  2370. .clkr = {
  2371. .enable_reg = 0x3720,
  2372. .enable_mask = BIT(0),
  2373. .hw.init = &(struct clk_init_data){
  2374. .name = "camss_vfe0_stream_clk",
  2375. .parent_hws = (const struct clk_hw*[]){
  2376. &vfe0_clk_src.clkr.hw
  2377. },
  2378. .num_parents = 1,
  2379. .flags = CLK_SET_RATE_PARENT,
  2380. .ops = &clk_branch2_ops,
  2381. },
  2382. },
  2383. };
  2384. static struct clk_branch camss_vfe0_ahb_clk = {
  2385. .halt_reg = 0x3668,
  2386. .clkr = {
  2387. .enable_reg = 0x3668,
  2388. .enable_mask = BIT(0),
  2389. .hw.init = &(struct clk_init_data){
  2390. .name = "camss_vfe0_ahb_clk",
  2391. .parent_hws = (const struct clk_hw*[]){
  2392. &ahb_clk_src.clkr.hw
  2393. },
  2394. .num_parents = 1,
  2395. .flags = CLK_SET_RATE_PARENT,
  2396. .ops = &clk_branch2_ops,
  2397. },
  2398. },
  2399. };
  2400. static struct clk_branch camss_vfe1_clk = {
  2401. .halt_reg = 0x36ac,
  2402. .clkr = {
  2403. .enable_reg = 0x36ac,
  2404. .enable_mask = BIT(0),
  2405. .hw.init = &(struct clk_init_data){
  2406. .name = "camss_vfe1_clk",
  2407. .parent_hws = (const struct clk_hw*[]){
  2408. &vfe1_clk_src.clkr.hw
  2409. },
  2410. .num_parents = 1,
  2411. .flags = CLK_SET_RATE_PARENT,
  2412. .ops = &clk_branch2_ops,
  2413. },
  2414. },
  2415. };
  2416. static struct clk_branch camss_vfe1_stream_clk = {
  2417. .halt_reg = 0x3724,
  2418. .clkr = {
  2419. .enable_reg = 0x3724,
  2420. .enable_mask = BIT(0),
  2421. .hw.init = &(struct clk_init_data){
  2422. .name = "camss_vfe1_stream_clk",
  2423. .parent_hws = (const struct clk_hw*[]){
  2424. &vfe1_clk_src.clkr.hw
  2425. },
  2426. .num_parents = 1,
  2427. .flags = CLK_SET_RATE_PARENT,
  2428. .ops = &clk_branch2_ops,
  2429. },
  2430. },
  2431. };
  2432. static struct clk_branch camss_vfe1_ahb_clk = {
  2433. .halt_reg = 0x3678,
  2434. .clkr = {
  2435. .enable_reg = 0x3678,
  2436. .enable_mask = BIT(0),
  2437. .hw.init = &(struct clk_init_data){
  2438. .name = "camss_vfe1_ahb_clk",
  2439. .parent_hws = (const struct clk_hw*[]){
  2440. &ahb_clk_src.clkr.hw
  2441. },
  2442. .num_parents = 1,
  2443. .flags = CLK_SET_RATE_PARENT,
  2444. .ops = &clk_branch2_ops,
  2445. },
  2446. },
  2447. };
  2448. static struct clk_branch camss_csi_vfe0_clk = {
  2449. .halt_reg = 0x3704,
  2450. .clkr = {
  2451. .enable_reg = 0x3704,
  2452. .enable_mask = BIT(0),
  2453. .hw.init = &(struct clk_init_data){
  2454. .name = "camss_csi_vfe0_clk",
  2455. .parent_hws = (const struct clk_hw*[]){
  2456. &vfe0_clk_src.clkr.hw
  2457. },
  2458. .num_parents = 1,
  2459. .flags = CLK_SET_RATE_PARENT,
  2460. .ops = &clk_branch2_ops,
  2461. },
  2462. },
  2463. };
  2464. static struct clk_branch camss_csi_vfe1_clk = {
  2465. .halt_reg = 0x3714,
  2466. .clkr = {
  2467. .enable_reg = 0x3714,
  2468. .enable_mask = BIT(0),
  2469. .hw.init = &(struct clk_init_data){
  2470. .name = "camss_csi_vfe1_clk",
  2471. .parent_hws = (const struct clk_hw*[]){
  2472. &vfe1_clk_src.clkr.hw
  2473. },
  2474. .num_parents = 1,
  2475. .flags = CLK_SET_RATE_PARENT,
  2476. .ops = &clk_branch2_ops,
  2477. },
  2478. },
  2479. };
  2480. static struct clk_branch camss_cpp_vbif_ahb_clk = {
  2481. .halt_reg = 0x36c8,
  2482. .clkr = {
  2483. .enable_reg = 0x36c8,
  2484. .enable_mask = BIT(0),
  2485. .hw.init = &(struct clk_init_data){
  2486. .name = "camss_cpp_vbif_ahb_clk",
  2487. .parent_hws = (const struct clk_hw*[]){
  2488. &ahb_clk_src.clkr.hw
  2489. },
  2490. .num_parents = 1,
  2491. .flags = CLK_SET_RATE_PARENT,
  2492. .ops = &clk_branch2_ops,
  2493. },
  2494. },
  2495. };
  2496. static struct clk_branch camss_cpp_axi_clk = {
  2497. .halt_reg = 0x36c4,
  2498. .clkr = {
  2499. .enable_reg = 0x36c4,
  2500. .enable_mask = BIT(0),
  2501. .hw.init = &(struct clk_init_data){
  2502. .name = "camss_cpp_axi_clk",
  2503. .parent_hws = (const struct clk_hw*[]){
  2504. &axi_clk_src.clkr.hw
  2505. },
  2506. .num_parents = 1,
  2507. .flags = CLK_SET_RATE_PARENT,
  2508. .ops = &clk_branch2_ops,
  2509. },
  2510. },
  2511. };
  2512. static struct clk_branch camss_cpp_clk = {
  2513. .halt_reg = 0x36b0,
  2514. .clkr = {
  2515. .enable_reg = 0x36b0,
  2516. .enable_mask = BIT(0),
  2517. .hw.init = &(struct clk_init_data){
  2518. .name = "camss_cpp_clk",
  2519. .parent_hws = (const struct clk_hw*[]){
  2520. &cpp_clk_src.clkr.hw
  2521. },
  2522. .num_parents = 1,
  2523. .flags = CLK_SET_RATE_PARENT,
  2524. .ops = &clk_branch2_ops,
  2525. },
  2526. },
  2527. };
  2528. static struct clk_branch camss_cpp_ahb_clk = {
  2529. .halt_reg = 0x36b4,
  2530. .clkr = {
  2531. .enable_reg = 0x36b4,
  2532. .enable_mask = BIT(0),
  2533. .hw.init = &(struct clk_init_data){
  2534. .name = "camss_cpp_ahb_clk",
  2535. .parent_hws = (const struct clk_hw*[]){
  2536. &ahb_clk_src.clkr.hw
  2537. },
  2538. .num_parents = 1,
  2539. .flags = CLK_SET_RATE_PARENT,
  2540. .ops = &clk_branch2_ops,
  2541. },
  2542. },
  2543. };
  2544. static struct clk_branch camss_csi0_clk = {
  2545. .halt_reg = 0x30b4,
  2546. .clkr = {
  2547. .enable_reg = 0x30b4,
  2548. .enable_mask = BIT(0),
  2549. .hw.init = &(struct clk_init_data){
  2550. .name = "camss_csi0_clk",
  2551. .parent_hws = (const struct clk_hw*[]){
  2552. &csi0_clk_src.clkr.hw
  2553. },
  2554. .num_parents = 1,
  2555. .flags = CLK_SET_RATE_PARENT,
  2556. .ops = &clk_branch2_ops,
  2557. },
  2558. },
  2559. };
  2560. static struct clk_branch camss_csi0_ahb_clk = {
  2561. .halt_reg = 0x30bc,
  2562. .clkr = {
  2563. .enable_reg = 0x30bc,
  2564. .enable_mask = BIT(0),
  2565. .hw.init = &(struct clk_init_data){
  2566. .name = "camss_csi0_ahb_clk",
  2567. .parent_hws = (const struct clk_hw*[]){
  2568. &ahb_clk_src.clkr.hw
  2569. },
  2570. .num_parents = 1,
  2571. .flags = CLK_SET_RATE_PARENT,
  2572. .ops = &clk_branch2_ops,
  2573. },
  2574. },
  2575. };
  2576. static struct clk_branch camss_csi0phy_clk = {
  2577. .halt_reg = 0x30c4,
  2578. .clkr = {
  2579. .enable_reg = 0x30c4,
  2580. .enable_mask = BIT(0),
  2581. .hw.init = &(struct clk_init_data){
  2582. .name = "camss_csi0phy_clk",
  2583. .parent_hws = (const struct clk_hw*[]){
  2584. &csi0_clk_src.clkr.hw
  2585. },
  2586. .num_parents = 1,
  2587. .flags = CLK_SET_RATE_PARENT,
  2588. .ops = &clk_branch2_ops,
  2589. },
  2590. },
  2591. };
  2592. static struct clk_branch camss_csi0rdi_clk = {
  2593. .halt_reg = 0x30d4,
  2594. .clkr = {
  2595. .enable_reg = 0x30d4,
  2596. .enable_mask = BIT(0),
  2597. .hw.init = &(struct clk_init_data){
  2598. .name = "camss_csi0rdi_clk",
  2599. .parent_hws = (const struct clk_hw*[]){
  2600. &csi0_clk_src.clkr.hw
  2601. },
  2602. .num_parents = 1,
  2603. .flags = CLK_SET_RATE_PARENT,
  2604. .ops = &clk_branch2_ops,
  2605. },
  2606. },
  2607. };
  2608. static struct clk_branch camss_csi0pix_clk = {
  2609. .halt_reg = 0x30e4,
  2610. .clkr = {
  2611. .enable_reg = 0x30e4,
  2612. .enable_mask = BIT(0),
  2613. .hw.init = &(struct clk_init_data){
  2614. .name = "camss_csi0pix_clk",
  2615. .parent_hws = (const struct clk_hw*[]){
  2616. &csi0_clk_src.clkr.hw
  2617. },
  2618. .num_parents = 1,
  2619. .flags = CLK_SET_RATE_PARENT,
  2620. .ops = &clk_branch2_ops,
  2621. },
  2622. },
  2623. };
  2624. static struct clk_branch camss_csi1_clk = {
  2625. .halt_reg = 0x3124,
  2626. .clkr = {
  2627. .enable_reg = 0x3124,
  2628. .enable_mask = BIT(0),
  2629. .hw.init = &(struct clk_init_data){
  2630. .name = "camss_csi1_clk",
  2631. .parent_hws = (const struct clk_hw*[]){
  2632. &csi1_clk_src.clkr.hw
  2633. },
  2634. .num_parents = 1,
  2635. .flags = CLK_SET_RATE_PARENT,
  2636. .ops = &clk_branch2_ops,
  2637. },
  2638. },
  2639. };
  2640. static struct clk_branch camss_csi1_ahb_clk = {
  2641. .halt_reg = 0x3128,
  2642. .clkr = {
  2643. .enable_reg = 0x3128,
  2644. .enable_mask = BIT(0),
  2645. .hw.init = &(struct clk_init_data){
  2646. .name = "camss_csi1_ahb_clk",
  2647. .parent_hws = (const struct clk_hw*[]){
  2648. &ahb_clk_src.clkr.hw
  2649. },
  2650. .num_parents = 1,
  2651. .flags = CLK_SET_RATE_PARENT,
  2652. .ops = &clk_branch2_ops,
  2653. },
  2654. },
  2655. };
  2656. static struct clk_branch camss_csi1phy_clk = {
  2657. .halt_reg = 0x3134,
  2658. .clkr = {
  2659. .enable_reg = 0x3134,
  2660. .enable_mask = BIT(0),
  2661. .hw.init = &(struct clk_init_data){
  2662. .name = "camss_csi1phy_clk",
  2663. .parent_hws = (const struct clk_hw*[]){
  2664. &csi1_clk_src.clkr.hw
  2665. },
  2666. .num_parents = 1,
  2667. .flags = CLK_SET_RATE_PARENT,
  2668. .ops = &clk_branch2_ops,
  2669. },
  2670. },
  2671. };
  2672. static struct clk_branch camss_csi1rdi_clk = {
  2673. .halt_reg = 0x3144,
  2674. .clkr = {
  2675. .enable_reg = 0x3144,
  2676. .enable_mask = BIT(0),
  2677. .hw.init = &(struct clk_init_data){
  2678. .name = "camss_csi1rdi_clk",
  2679. .parent_hws = (const struct clk_hw*[]){
  2680. &csi1_clk_src.clkr.hw
  2681. },
  2682. .num_parents = 1,
  2683. .flags = CLK_SET_RATE_PARENT,
  2684. .ops = &clk_branch2_ops,
  2685. },
  2686. },
  2687. };
  2688. static struct clk_branch camss_csi1pix_clk = {
  2689. .halt_reg = 0x3154,
  2690. .clkr = {
  2691. .enable_reg = 0x3154,
  2692. .enable_mask = BIT(0),
  2693. .hw.init = &(struct clk_init_data){
  2694. .name = "camss_csi1pix_clk",
  2695. .parent_hws = (const struct clk_hw*[]){
  2696. &csi1_clk_src.clkr.hw
  2697. },
  2698. .num_parents = 1,
  2699. .flags = CLK_SET_RATE_PARENT,
  2700. .ops = &clk_branch2_ops,
  2701. },
  2702. },
  2703. };
  2704. static struct clk_branch camss_csi2_clk = {
  2705. .halt_reg = 0x3184,
  2706. .clkr = {
  2707. .enable_reg = 0x3184,
  2708. .enable_mask = BIT(0),
  2709. .hw.init = &(struct clk_init_data){
  2710. .name = "camss_csi2_clk",
  2711. .parent_hws = (const struct clk_hw*[]){
  2712. &csi2_clk_src.clkr.hw
  2713. },
  2714. .num_parents = 1,
  2715. .flags = CLK_SET_RATE_PARENT,
  2716. .ops = &clk_branch2_ops,
  2717. },
  2718. },
  2719. };
  2720. static struct clk_branch camss_csi2_ahb_clk = {
  2721. .halt_reg = 0x3188,
  2722. .clkr = {
  2723. .enable_reg = 0x3188,
  2724. .enable_mask = BIT(0),
  2725. .hw.init = &(struct clk_init_data){
  2726. .name = "camss_csi2_ahb_clk",
  2727. .parent_hws = (const struct clk_hw*[]){
  2728. &ahb_clk_src.clkr.hw
  2729. },
  2730. .num_parents = 1,
  2731. .flags = CLK_SET_RATE_PARENT,
  2732. .ops = &clk_branch2_ops,
  2733. },
  2734. },
  2735. };
  2736. static struct clk_branch camss_csi2phy_clk = {
  2737. .halt_reg = 0x3194,
  2738. .clkr = {
  2739. .enable_reg = 0x3194,
  2740. .enable_mask = BIT(0),
  2741. .hw.init = &(struct clk_init_data){
  2742. .name = "camss_csi2phy_clk",
  2743. .parent_hws = (const struct clk_hw*[]){
  2744. &csi2_clk_src.clkr.hw
  2745. },
  2746. .num_parents = 1,
  2747. .flags = CLK_SET_RATE_PARENT,
  2748. .ops = &clk_branch2_ops,
  2749. },
  2750. },
  2751. };
  2752. static struct clk_branch camss_csi2rdi_clk = {
  2753. .halt_reg = 0x31a4,
  2754. .clkr = {
  2755. .enable_reg = 0x31a4,
  2756. .enable_mask = BIT(0),
  2757. .hw.init = &(struct clk_init_data){
  2758. .name = "camss_csi2rdi_clk",
  2759. .parent_hws = (const struct clk_hw*[]){
  2760. &csi2_clk_src.clkr.hw
  2761. },
  2762. .num_parents = 1,
  2763. .flags = CLK_SET_RATE_PARENT,
  2764. .ops = &clk_branch2_ops,
  2765. },
  2766. },
  2767. };
  2768. static struct clk_branch camss_csi2pix_clk = {
  2769. .halt_reg = 0x31b4,
  2770. .clkr = {
  2771. .enable_reg = 0x31b4,
  2772. .enable_mask = BIT(0),
  2773. .hw.init = &(struct clk_init_data){
  2774. .name = "camss_csi2pix_clk",
  2775. .parent_hws = (const struct clk_hw*[]){
  2776. &csi2_clk_src.clkr.hw
  2777. },
  2778. .num_parents = 1,
  2779. .flags = CLK_SET_RATE_PARENT,
  2780. .ops = &clk_branch2_ops,
  2781. },
  2782. },
  2783. };
  2784. static struct clk_branch camss_csi3_clk = {
  2785. .halt_reg = 0x31e4,
  2786. .clkr = {
  2787. .enable_reg = 0x31e4,
  2788. .enable_mask = BIT(0),
  2789. .hw.init = &(struct clk_init_data){
  2790. .name = "camss_csi3_clk",
  2791. .parent_hws = (const struct clk_hw*[]){
  2792. &csi3_clk_src.clkr.hw
  2793. },
  2794. .num_parents = 1,
  2795. .flags = CLK_SET_RATE_PARENT,
  2796. .ops = &clk_branch2_ops,
  2797. },
  2798. },
  2799. };
  2800. static struct clk_branch camss_csi3_ahb_clk = {
  2801. .halt_reg = 0x31e8,
  2802. .clkr = {
  2803. .enable_reg = 0x31e8,
  2804. .enable_mask = BIT(0),
  2805. .hw.init = &(struct clk_init_data){
  2806. .name = "camss_csi3_ahb_clk",
  2807. .parent_hws = (const struct clk_hw*[]){
  2808. &ahb_clk_src.clkr.hw
  2809. },
  2810. .num_parents = 1,
  2811. .flags = CLK_SET_RATE_PARENT,
  2812. .ops = &clk_branch2_ops,
  2813. },
  2814. },
  2815. };
  2816. static struct clk_branch camss_csi3phy_clk = {
  2817. .halt_reg = 0x31f4,
  2818. .clkr = {
  2819. .enable_reg = 0x31f4,
  2820. .enable_mask = BIT(0),
  2821. .hw.init = &(struct clk_init_data){
  2822. .name = "camss_csi3phy_clk",
  2823. .parent_hws = (const struct clk_hw*[]){
  2824. &csi3_clk_src.clkr.hw
  2825. },
  2826. .num_parents = 1,
  2827. .flags = CLK_SET_RATE_PARENT,
  2828. .ops = &clk_branch2_ops,
  2829. },
  2830. },
  2831. };
  2832. static struct clk_branch camss_csi3rdi_clk = {
  2833. .halt_reg = 0x3204,
  2834. .clkr = {
  2835. .enable_reg = 0x3204,
  2836. .enable_mask = BIT(0),
  2837. .hw.init = &(struct clk_init_data){
  2838. .name = "camss_csi3rdi_clk",
  2839. .parent_hws = (const struct clk_hw*[]){
  2840. &csi3_clk_src.clkr.hw
  2841. },
  2842. .num_parents = 1,
  2843. .flags = CLK_SET_RATE_PARENT,
  2844. .ops = &clk_branch2_ops,
  2845. },
  2846. },
  2847. };
  2848. static struct clk_branch camss_csi3pix_clk = {
  2849. .halt_reg = 0x3214,
  2850. .clkr = {
  2851. .enable_reg = 0x3214,
  2852. .enable_mask = BIT(0),
  2853. .hw.init = &(struct clk_init_data){
  2854. .name = "camss_csi3pix_clk",
  2855. .parent_hws = (const struct clk_hw*[]){
  2856. &csi3_clk_src.clkr.hw
  2857. },
  2858. .num_parents = 1,
  2859. .flags = CLK_SET_RATE_PARENT,
  2860. .ops = &clk_branch2_ops,
  2861. },
  2862. },
  2863. };
  2864. static struct clk_branch camss_ispif_ahb_clk = {
  2865. .halt_reg = 0x3224,
  2866. .clkr = {
  2867. .enable_reg = 0x3224,
  2868. .enable_mask = BIT(0),
  2869. .hw.init = &(struct clk_init_data){
  2870. .name = "camss_ispif_ahb_clk",
  2871. .parent_hws = (const struct clk_hw*[]){
  2872. &ahb_clk_src.clkr.hw
  2873. },
  2874. .num_parents = 1,
  2875. .flags = CLK_SET_RATE_PARENT,
  2876. .ops = &clk_branch2_ops,
  2877. },
  2878. },
  2879. };
  2880. static struct clk_branch fd_core_clk = {
  2881. .halt_reg = 0x3b68,
  2882. .clkr = {
  2883. .enable_reg = 0x3b68,
  2884. .enable_mask = BIT(0),
  2885. .hw.init = &(struct clk_init_data){
  2886. .name = "fd_core_clk",
  2887. .parent_hws = (const struct clk_hw*[]){
  2888. &fd_core_clk_src.clkr.hw
  2889. },
  2890. .num_parents = 1,
  2891. .flags = CLK_SET_RATE_PARENT,
  2892. .ops = &clk_branch2_ops,
  2893. },
  2894. },
  2895. };
  2896. static struct clk_branch fd_core_uar_clk = {
  2897. .halt_reg = 0x3b6c,
  2898. .clkr = {
  2899. .enable_reg = 0x3b6c,
  2900. .enable_mask = BIT(0),
  2901. .hw.init = &(struct clk_init_data){
  2902. .name = "fd_core_uar_clk",
  2903. .parent_hws = (const struct clk_hw*[]){
  2904. &fd_core_clk_src.clkr.hw
  2905. },
  2906. .num_parents = 1,
  2907. .flags = CLK_SET_RATE_PARENT,
  2908. .ops = &clk_branch2_ops,
  2909. },
  2910. },
  2911. };
  2912. static struct clk_branch fd_ahb_clk = {
  2913. .halt_reg = 0x3ba74,
  2914. .clkr = {
  2915. .enable_reg = 0x3ba74,
  2916. .enable_mask = BIT(0),
  2917. .hw.init = &(struct clk_init_data){
  2918. .name = "fd_ahb_clk",
  2919. .parent_hws = (const struct clk_hw*[]){
  2920. &ahb_clk_src.clkr.hw
  2921. },
  2922. .num_parents = 1,
  2923. .flags = CLK_SET_RATE_PARENT,
  2924. .ops = &clk_branch2_ops,
  2925. },
  2926. },
  2927. };
  2928. static struct clk_hw *mmcc_msm8996_hws[] = {
  2929. &gpll0_div.hw,
  2930. };
  2931. static struct gdsc mmagic_bimc_gdsc = {
  2932. .gdscr = 0x529c,
  2933. .pd = {
  2934. .name = "mmagic_bimc",
  2935. },
  2936. .pwrsts = PWRSTS_OFF_ON,
  2937. .flags = ALWAYS_ON,
  2938. };
  2939. static struct gdsc mmagic_video_gdsc = {
  2940. .gdscr = 0x119c,
  2941. .gds_hw_ctrl = 0x120c,
  2942. .pd = {
  2943. .name = "mmagic_video",
  2944. },
  2945. .pwrsts = PWRSTS_OFF_ON,
  2946. .flags = VOTABLE | ALWAYS_ON,
  2947. };
  2948. static struct gdsc mmagic_mdss_gdsc = {
  2949. .gdscr = 0x247c,
  2950. .gds_hw_ctrl = 0x2480,
  2951. .pd = {
  2952. .name = "mmagic_mdss",
  2953. },
  2954. .pwrsts = PWRSTS_OFF_ON,
  2955. .flags = VOTABLE | ALWAYS_ON,
  2956. };
  2957. static struct gdsc mmagic_camss_gdsc = {
  2958. .gdscr = 0x3c4c,
  2959. .gds_hw_ctrl = 0x3c50,
  2960. .pd = {
  2961. .name = "mmagic_camss",
  2962. },
  2963. .pwrsts = PWRSTS_OFF_ON,
  2964. .flags = VOTABLE | ALWAYS_ON,
  2965. };
  2966. static struct gdsc venus_gdsc = {
  2967. .gdscr = 0x1024,
  2968. .cxcs = (unsigned int []){ 0x1028, 0x1034, 0x1038 },
  2969. .cxc_count = 3,
  2970. .pd = {
  2971. .name = "venus",
  2972. },
  2973. .parent = &mmagic_video_gdsc.pd,
  2974. .pwrsts = PWRSTS_OFF_ON,
  2975. };
  2976. static struct gdsc venus_core0_gdsc = {
  2977. .gdscr = 0x1040,
  2978. .cxcs = (unsigned int []){ 0x1048 },
  2979. .cxc_count = 1,
  2980. .pd = {
  2981. .name = "venus_core0",
  2982. },
  2983. .parent = &venus_gdsc.pd,
  2984. .pwrsts = PWRSTS_OFF_ON,
  2985. .flags = HW_CTRL,
  2986. };
  2987. static struct gdsc venus_core1_gdsc = {
  2988. .gdscr = 0x1044,
  2989. .cxcs = (unsigned int []){ 0x104c },
  2990. .cxc_count = 1,
  2991. .pd = {
  2992. .name = "venus_core1",
  2993. },
  2994. .parent = &venus_gdsc.pd,
  2995. .pwrsts = PWRSTS_OFF_ON,
  2996. .flags = HW_CTRL,
  2997. };
  2998. static struct gdsc camss_gdsc = {
  2999. .gdscr = 0x34a0,
  3000. .cxcs = (unsigned int []){ 0x36bc, 0x36c4 },
  3001. .cxc_count = 2,
  3002. .pd = {
  3003. .name = "camss",
  3004. },
  3005. .parent = &mmagic_camss_gdsc.pd,
  3006. .pwrsts = PWRSTS_OFF_ON,
  3007. };
  3008. static struct gdsc vfe0_gdsc = {
  3009. .gdscr = 0x3664,
  3010. .cxcs = (unsigned int []){ 0x36a8 },
  3011. .cxc_count = 1,
  3012. .pd = {
  3013. .name = "vfe0",
  3014. },
  3015. .parent = &camss_gdsc.pd,
  3016. .pwrsts = PWRSTS_OFF_ON,
  3017. };
  3018. static struct gdsc vfe1_gdsc = {
  3019. .gdscr = 0x3674,
  3020. .cxcs = (unsigned int []){ 0x36ac },
  3021. .cxc_count = 1,
  3022. .pd = {
  3023. .name = "vfe1",
  3024. },
  3025. .parent = &camss_gdsc.pd,
  3026. .pwrsts = PWRSTS_OFF_ON,
  3027. };
  3028. static struct gdsc jpeg_gdsc = {
  3029. .gdscr = 0x35a4,
  3030. .cxcs = (unsigned int []){ 0x35a8, 0x35b0, 0x35c0, 0x35b8 },
  3031. .cxc_count = 4,
  3032. .pd = {
  3033. .name = "jpeg",
  3034. },
  3035. .parent = &camss_gdsc.pd,
  3036. .pwrsts = PWRSTS_OFF_ON,
  3037. };
  3038. static struct gdsc cpp_gdsc = {
  3039. .gdscr = 0x36d4,
  3040. .cxcs = (unsigned int []){ 0x36b0 },
  3041. .cxc_count = 1,
  3042. .pd = {
  3043. .name = "cpp",
  3044. },
  3045. .parent = &camss_gdsc.pd,
  3046. .pwrsts = PWRSTS_OFF_ON,
  3047. };
  3048. static struct gdsc fd_gdsc = {
  3049. .gdscr = 0x3b64,
  3050. .cxcs = (unsigned int []){ 0x3b68, 0x3b6c },
  3051. .cxc_count = 2,
  3052. .pd = {
  3053. .name = "fd",
  3054. },
  3055. .parent = &camss_gdsc.pd,
  3056. .pwrsts = PWRSTS_OFF_ON,
  3057. };
  3058. static struct gdsc mdss_gdsc = {
  3059. .gdscr = 0x2304,
  3060. .cxcs = (unsigned int []){ 0x2310, 0x231c },
  3061. .cxc_count = 2,
  3062. .pd = {
  3063. .name = "mdss",
  3064. },
  3065. .parent = &mmagic_mdss_gdsc.pd,
  3066. .pwrsts = PWRSTS_OFF_ON,
  3067. };
  3068. static struct gdsc gpu_gdsc = {
  3069. .gdscr = 0x4034,
  3070. .gds_hw_ctrl = 0x4038,
  3071. .pd = {
  3072. .name = "gpu",
  3073. },
  3074. .pwrsts = PWRSTS_OFF_ON,
  3075. .flags = VOTABLE,
  3076. };
  3077. static struct gdsc gpu_gx_gdsc = {
  3078. .gdscr = 0x4024,
  3079. .clamp_io_ctrl = 0x4300,
  3080. .cxcs = (unsigned int []){ 0x4028 },
  3081. .cxc_count = 1,
  3082. .pd = {
  3083. .name = "gpu_gx",
  3084. },
  3085. .pwrsts = PWRSTS_OFF_ON,
  3086. .parent = &gpu_gdsc.pd,
  3087. .flags = CLAMP_IO,
  3088. .supply = "vdd-gfx",
  3089. };
  3090. static struct clk_regmap *mmcc_msm8996_clocks[] = {
  3091. [MMPLL0_EARLY] = &mmpll0_early.clkr,
  3092. [MMPLL0_PLL] = &mmpll0.clkr,
  3093. [MMPLL1_EARLY] = &mmpll1_early.clkr,
  3094. [MMPLL1_PLL] = &mmpll1.clkr,
  3095. [MMPLL2_EARLY] = &mmpll2_early.clkr,
  3096. [MMPLL2_PLL] = &mmpll2.clkr,
  3097. [MMPLL3_EARLY] = &mmpll3_early.clkr,
  3098. [MMPLL3_PLL] = &mmpll3.clkr,
  3099. [MMPLL4_EARLY] = &mmpll4_early.clkr,
  3100. [MMPLL4_PLL] = &mmpll4.clkr,
  3101. [MMPLL5_EARLY] = &mmpll5_early.clkr,
  3102. [MMPLL5_PLL] = &mmpll5.clkr,
  3103. [MMPLL8_EARLY] = &mmpll8_early.clkr,
  3104. [MMPLL8_PLL] = &mmpll8.clkr,
  3105. [MMPLL9_EARLY] = &mmpll9_early.clkr,
  3106. [MMPLL9_PLL] = &mmpll9.clkr,
  3107. [AHB_CLK_SRC] = &ahb_clk_src.clkr,
  3108. [AXI_CLK_SRC] = &axi_clk_src.clkr,
  3109. [MAXI_CLK_SRC] = &maxi_clk_src.clkr,
  3110. [GFX3D_CLK_SRC] = &gfx3d_clk_src.rcg.clkr,
  3111. [RBBMTIMER_CLK_SRC] = &rbbmtimer_clk_src.clkr,
  3112. [ISENSE_CLK_SRC] = &isense_clk_src.clkr,
  3113. [RBCPR_CLK_SRC] = &rbcpr_clk_src.clkr,
  3114. [VIDEO_CORE_CLK_SRC] = &video_core_clk_src.clkr,
  3115. [VIDEO_SUBCORE0_CLK_SRC] = &video_subcore0_clk_src.clkr,
  3116. [VIDEO_SUBCORE1_CLK_SRC] = &video_subcore1_clk_src.clkr,
  3117. [PCLK0_CLK_SRC] = &pclk0_clk_src.clkr,
  3118. [PCLK1_CLK_SRC] = &pclk1_clk_src.clkr,
  3119. [MDP_CLK_SRC] = &mdp_clk_src.clkr,
  3120. [EXTPCLK_CLK_SRC] = &extpclk_clk_src.clkr,
  3121. [VSYNC_CLK_SRC] = &vsync_clk_src.clkr,
  3122. [HDMI_CLK_SRC] = &hdmi_clk_src.clkr,
  3123. [BYTE0_CLK_SRC] = &byte0_clk_src.clkr,
  3124. [BYTE1_CLK_SRC] = &byte1_clk_src.clkr,
  3125. [ESC0_CLK_SRC] = &esc0_clk_src.clkr,
  3126. [ESC1_CLK_SRC] = &esc1_clk_src.clkr,
  3127. [CAMSS_GP0_CLK_SRC] = &camss_gp0_clk_src.clkr,
  3128. [CAMSS_GP1_CLK_SRC] = &camss_gp1_clk_src.clkr,
  3129. [MCLK0_CLK_SRC] = &mclk0_clk_src.clkr,
  3130. [MCLK1_CLK_SRC] = &mclk1_clk_src.clkr,
  3131. [MCLK2_CLK_SRC] = &mclk2_clk_src.clkr,
  3132. [MCLK3_CLK_SRC] = &mclk3_clk_src.clkr,
  3133. [CCI_CLK_SRC] = &cci_clk_src.clkr,
  3134. [CSI0PHYTIMER_CLK_SRC] = &csi0phytimer_clk_src.clkr,
  3135. [CSI1PHYTIMER_CLK_SRC] = &csi1phytimer_clk_src.clkr,
  3136. [CSI2PHYTIMER_CLK_SRC] = &csi2phytimer_clk_src.clkr,
  3137. [CSIPHY0_3P_CLK_SRC] = &csiphy0_3p_clk_src.clkr,
  3138. [CSIPHY1_3P_CLK_SRC] = &csiphy1_3p_clk_src.clkr,
  3139. [CSIPHY2_3P_CLK_SRC] = &csiphy2_3p_clk_src.clkr,
  3140. [JPEG0_CLK_SRC] = &jpeg0_clk_src.clkr,
  3141. [JPEG2_CLK_SRC] = &jpeg2_clk_src.clkr,
  3142. [JPEG_DMA_CLK_SRC] = &jpeg_dma_clk_src.clkr,
  3143. [VFE0_CLK_SRC] = &vfe0_clk_src.clkr,
  3144. [VFE1_CLK_SRC] = &vfe1_clk_src.clkr,
  3145. [CPP_CLK_SRC] = &cpp_clk_src.clkr,
  3146. [CSI0_CLK_SRC] = &csi0_clk_src.clkr,
  3147. [CSI1_CLK_SRC] = &csi1_clk_src.clkr,
  3148. [CSI2_CLK_SRC] = &csi2_clk_src.clkr,
  3149. [CSI3_CLK_SRC] = &csi3_clk_src.clkr,
  3150. [FD_CORE_CLK_SRC] = &fd_core_clk_src.clkr,
  3151. [MMSS_MMAGIC_AHB_CLK] = &mmss_mmagic_ahb_clk.clkr,
  3152. [MMSS_MMAGIC_CFG_AHB_CLK] = &mmss_mmagic_cfg_ahb_clk.clkr,
  3153. [MMSS_MISC_AHB_CLK] = &mmss_misc_ahb_clk.clkr,
  3154. [MMSS_MISC_CXO_CLK] = &mmss_misc_cxo_clk.clkr,
  3155. [MMSS_MMAGIC_MAXI_CLK] = &mmss_mmagic_maxi_clk.clkr,
  3156. [MMAGIC_CAMSS_AXI_CLK] = &mmagic_camss_axi_clk.clkr,
  3157. [MMAGIC_CAMSS_NOC_CFG_AHB_CLK] = &mmagic_camss_noc_cfg_ahb_clk.clkr,
  3158. [SMMU_VFE_AHB_CLK] = &smmu_vfe_ahb_clk.clkr,
  3159. [SMMU_VFE_AXI_CLK] = &smmu_vfe_axi_clk.clkr,
  3160. [SMMU_CPP_AHB_CLK] = &smmu_cpp_ahb_clk.clkr,
  3161. [SMMU_CPP_AXI_CLK] = &smmu_cpp_axi_clk.clkr,
  3162. [SMMU_JPEG_AHB_CLK] = &smmu_jpeg_ahb_clk.clkr,
  3163. [SMMU_JPEG_AXI_CLK] = &smmu_jpeg_axi_clk.clkr,
  3164. [MMAGIC_MDSS_AXI_CLK] = &mmagic_mdss_axi_clk.clkr,
  3165. [MMAGIC_MDSS_NOC_CFG_AHB_CLK] = &mmagic_mdss_noc_cfg_ahb_clk.clkr,
  3166. [SMMU_ROT_AHB_CLK] = &smmu_rot_ahb_clk.clkr,
  3167. [SMMU_ROT_AXI_CLK] = &smmu_rot_axi_clk.clkr,
  3168. [SMMU_MDP_AHB_CLK] = &smmu_mdp_ahb_clk.clkr,
  3169. [SMMU_MDP_AXI_CLK] = &smmu_mdp_axi_clk.clkr,
  3170. [MMAGIC_VIDEO_AXI_CLK] = &mmagic_video_axi_clk.clkr,
  3171. [MMAGIC_VIDEO_NOC_CFG_AHB_CLK] = &mmagic_video_noc_cfg_ahb_clk.clkr,
  3172. [SMMU_VIDEO_AHB_CLK] = &smmu_video_ahb_clk.clkr,
  3173. [SMMU_VIDEO_AXI_CLK] = &smmu_video_axi_clk.clkr,
  3174. [MMAGIC_BIMC_NOC_CFG_AHB_CLK] = &mmagic_bimc_noc_cfg_ahb_clk.clkr,
  3175. [GPU_GX_GFX3D_CLK] = &gpu_gx_gfx3d_clk.clkr,
  3176. [GPU_GX_RBBMTIMER_CLK] = &gpu_gx_rbbmtimer_clk.clkr,
  3177. [GPU_AHB_CLK] = &gpu_ahb_clk.clkr,
  3178. [GPU_AON_ISENSE_CLK] = &gpu_aon_isense_clk.clkr,
  3179. [VMEM_MAXI_CLK] = &vmem_maxi_clk.clkr,
  3180. [VMEM_AHB_CLK] = &vmem_ahb_clk.clkr,
  3181. [MMSS_RBCPR_CLK] = &mmss_rbcpr_clk.clkr,
  3182. [MMSS_RBCPR_AHB_CLK] = &mmss_rbcpr_ahb_clk.clkr,
  3183. [VIDEO_CORE_CLK] = &video_core_clk.clkr,
  3184. [VIDEO_AXI_CLK] = &video_axi_clk.clkr,
  3185. [VIDEO_MAXI_CLK] = &video_maxi_clk.clkr,
  3186. [VIDEO_AHB_CLK] = &video_ahb_clk.clkr,
  3187. [VIDEO_SUBCORE0_CLK] = &video_subcore0_clk.clkr,
  3188. [VIDEO_SUBCORE1_CLK] = &video_subcore1_clk.clkr,
  3189. [MDSS_AHB_CLK] = &mdss_ahb_clk.clkr,
  3190. [MDSS_HDMI_AHB_CLK] = &mdss_hdmi_ahb_clk.clkr,
  3191. [MDSS_AXI_CLK] = &mdss_axi_clk.clkr,
  3192. [MDSS_PCLK0_CLK] = &mdss_pclk0_clk.clkr,
  3193. [MDSS_PCLK1_CLK] = &mdss_pclk1_clk.clkr,
  3194. [MDSS_MDP_CLK] = &mdss_mdp_clk.clkr,
  3195. [MDSS_EXTPCLK_CLK] = &mdss_extpclk_clk.clkr,
  3196. [MDSS_VSYNC_CLK] = &mdss_vsync_clk.clkr,
  3197. [MDSS_HDMI_CLK] = &mdss_hdmi_clk.clkr,
  3198. [MDSS_BYTE0_CLK] = &mdss_byte0_clk.clkr,
  3199. [MDSS_BYTE1_CLK] = &mdss_byte1_clk.clkr,
  3200. [MDSS_ESC0_CLK] = &mdss_esc0_clk.clkr,
  3201. [MDSS_ESC1_CLK] = &mdss_esc1_clk.clkr,
  3202. [CAMSS_TOP_AHB_CLK] = &camss_top_ahb_clk.clkr,
  3203. [CAMSS_AHB_CLK] = &camss_ahb_clk.clkr,
  3204. [CAMSS_MICRO_AHB_CLK] = &camss_micro_ahb_clk.clkr,
  3205. [CAMSS_GP0_CLK] = &camss_gp0_clk.clkr,
  3206. [CAMSS_GP1_CLK] = &camss_gp1_clk.clkr,
  3207. [CAMSS_MCLK0_CLK] = &camss_mclk0_clk.clkr,
  3208. [CAMSS_MCLK1_CLK] = &camss_mclk1_clk.clkr,
  3209. [CAMSS_MCLK2_CLK] = &camss_mclk2_clk.clkr,
  3210. [CAMSS_MCLK3_CLK] = &camss_mclk3_clk.clkr,
  3211. [CAMSS_CCI_CLK] = &camss_cci_clk.clkr,
  3212. [CAMSS_CCI_AHB_CLK] = &camss_cci_ahb_clk.clkr,
  3213. [CAMSS_CSI0PHYTIMER_CLK] = &camss_csi0phytimer_clk.clkr,
  3214. [CAMSS_CSI1PHYTIMER_CLK] = &camss_csi1phytimer_clk.clkr,
  3215. [CAMSS_CSI2PHYTIMER_CLK] = &camss_csi2phytimer_clk.clkr,
  3216. [CAMSS_CSIPHY0_3P_CLK] = &camss_csiphy0_3p_clk.clkr,
  3217. [CAMSS_CSIPHY1_3P_CLK] = &camss_csiphy1_3p_clk.clkr,
  3218. [CAMSS_CSIPHY2_3P_CLK] = &camss_csiphy2_3p_clk.clkr,
  3219. [CAMSS_JPEG0_CLK] = &camss_jpeg0_clk.clkr,
  3220. [CAMSS_JPEG2_CLK] = &camss_jpeg2_clk.clkr,
  3221. [CAMSS_JPEG_DMA_CLK] = &camss_jpeg_dma_clk.clkr,
  3222. [CAMSS_JPEG_AHB_CLK] = &camss_jpeg_ahb_clk.clkr,
  3223. [CAMSS_JPEG_AXI_CLK] = &camss_jpeg_axi_clk.clkr,
  3224. [CAMSS_VFE_AHB_CLK] = &camss_vfe_ahb_clk.clkr,
  3225. [CAMSS_VFE_AXI_CLK] = &camss_vfe_axi_clk.clkr,
  3226. [CAMSS_VFE0_CLK] = &camss_vfe0_clk.clkr,
  3227. [CAMSS_VFE0_STREAM_CLK] = &camss_vfe0_stream_clk.clkr,
  3228. [CAMSS_VFE0_AHB_CLK] = &camss_vfe0_ahb_clk.clkr,
  3229. [CAMSS_VFE1_CLK] = &camss_vfe1_clk.clkr,
  3230. [CAMSS_VFE1_STREAM_CLK] = &camss_vfe1_stream_clk.clkr,
  3231. [CAMSS_VFE1_AHB_CLK] = &camss_vfe1_ahb_clk.clkr,
  3232. [CAMSS_CSI_VFE0_CLK] = &camss_csi_vfe0_clk.clkr,
  3233. [CAMSS_CSI_VFE1_CLK] = &camss_csi_vfe1_clk.clkr,
  3234. [CAMSS_CPP_VBIF_AHB_CLK] = &camss_cpp_vbif_ahb_clk.clkr,
  3235. [CAMSS_CPP_AXI_CLK] = &camss_cpp_axi_clk.clkr,
  3236. [CAMSS_CPP_CLK] = &camss_cpp_clk.clkr,
  3237. [CAMSS_CPP_AHB_CLK] = &camss_cpp_ahb_clk.clkr,
  3238. [CAMSS_CSI0_CLK] = &camss_csi0_clk.clkr,
  3239. [CAMSS_CSI0_AHB_CLK] = &camss_csi0_ahb_clk.clkr,
  3240. [CAMSS_CSI0PHY_CLK] = &camss_csi0phy_clk.clkr,
  3241. [CAMSS_CSI0RDI_CLK] = &camss_csi0rdi_clk.clkr,
  3242. [CAMSS_CSI0PIX_CLK] = &camss_csi0pix_clk.clkr,
  3243. [CAMSS_CSI1_CLK] = &camss_csi1_clk.clkr,
  3244. [CAMSS_CSI1_AHB_CLK] = &camss_csi1_ahb_clk.clkr,
  3245. [CAMSS_CSI1PHY_CLK] = &camss_csi1phy_clk.clkr,
  3246. [CAMSS_CSI1RDI_CLK] = &camss_csi1rdi_clk.clkr,
  3247. [CAMSS_CSI1PIX_CLK] = &camss_csi1pix_clk.clkr,
  3248. [CAMSS_CSI2_CLK] = &camss_csi2_clk.clkr,
  3249. [CAMSS_CSI2_AHB_CLK] = &camss_csi2_ahb_clk.clkr,
  3250. [CAMSS_CSI2PHY_CLK] = &camss_csi2phy_clk.clkr,
  3251. [CAMSS_CSI2RDI_CLK] = &camss_csi2rdi_clk.clkr,
  3252. [CAMSS_CSI2PIX_CLK] = &camss_csi2pix_clk.clkr,
  3253. [CAMSS_CSI3_CLK] = &camss_csi3_clk.clkr,
  3254. [CAMSS_CSI3_AHB_CLK] = &camss_csi3_ahb_clk.clkr,
  3255. [CAMSS_CSI3PHY_CLK] = &camss_csi3phy_clk.clkr,
  3256. [CAMSS_CSI3RDI_CLK] = &camss_csi3rdi_clk.clkr,
  3257. [CAMSS_CSI3PIX_CLK] = &camss_csi3pix_clk.clkr,
  3258. [CAMSS_ISPIF_AHB_CLK] = &camss_ispif_ahb_clk.clkr,
  3259. [FD_CORE_CLK] = &fd_core_clk.clkr,
  3260. [FD_CORE_UAR_CLK] = &fd_core_uar_clk.clkr,
  3261. [FD_AHB_CLK] = &fd_ahb_clk.clkr,
  3262. };
  3263. static struct gdsc *mmcc_msm8996_gdscs[] = {
  3264. [MMAGIC_BIMC_GDSC] = &mmagic_bimc_gdsc,
  3265. [MMAGIC_VIDEO_GDSC] = &mmagic_video_gdsc,
  3266. [MMAGIC_MDSS_GDSC] = &mmagic_mdss_gdsc,
  3267. [MMAGIC_CAMSS_GDSC] = &mmagic_camss_gdsc,
  3268. [VENUS_GDSC] = &venus_gdsc,
  3269. [VENUS_CORE0_GDSC] = &venus_core0_gdsc,
  3270. [VENUS_CORE1_GDSC] = &venus_core1_gdsc,
  3271. [CAMSS_GDSC] = &camss_gdsc,
  3272. [VFE0_GDSC] = &vfe0_gdsc,
  3273. [VFE1_GDSC] = &vfe1_gdsc,
  3274. [JPEG_GDSC] = &jpeg_gdsc,
  3275. [CPP_GDSC] = &cpp_gdsc,
  3276. [FD_GDSC] = &fd_gdsc,
  3277. [MDSS_GDSC] = &mdss_gdsc,
  3278. [GPU_GDSC] = &gpu_gdsc,
  3279. [GPU_GX_GDSC] = &gpu_gx_gdsc,
  3280. };
  3281. static const struct qcom_reset_map mmcc_msm8996_resets[] = {
  3282. [MMAGICAHB_BCR] = { 0x5020 },
  3283. [MMAGIC_CFG_BCR] = { 0x5050 },
  3284. [MISC_BCR] = { 0x5010 },
  3285. [BTO_BCR] = { 0x5030 },
  3286. [MMAGICAXI_BCR] = { 0x5060 },
  3287. [MMAGICMAXI_BCR] = { 0x5070 },
  3288. [DSA_BCR] = { 0x50a0 },
  3289. [MMAGIC_CAMSS_BCR] = { 0x3c40 },
  3290. [THROTTLE_CAMSS_BCR] = { 0x3c30 },
  3291. [SMMU_VFE_BCR] = { 0x3c00 },
  3292. [SMMU_CPP_BCR] = { 0x3c10 },
  3293. [SMMU_JPEG_BCR] = { 0x3c20 },
  3294. [MMAGIC_MDSS_BCR] = { 0x2470 },
  3295. [THROTTLE_MDSS_BCR] = { 0x2460 },
  3296. [SMMU_ROT_BCR] = { 0x2440 },
  3297. [SMMU_MDP_BCR] = { 0x2450 },
  3298. [MMAGIC_VIDEO_BCR] = { 0x1190 },
  3299. [THROTTLE_VIDEO_BCR] = { 0x1180 },
  3300. [SMMU_VIDEO_BCR] = { 0x1170 },
  3301. [MMAGIC_BIMC_BCR] = { 0x5290 },
  3302. [GPU_GX_BCR] = { 0x4020 },
  3303. [GPU_BCR] = { 0x4030 },
  3304. [GPU_AON_BCR] = { 0x4040 },
  3305. [VMEM_BCR] = { 0x1200 },
  3306. [MMSS_RBCPR_BCR] = { 0x4080 },
  3307. [VIDEO_BCR] = { 0x1020 },
  3308. [MDSS_BCR] = { 0x2300 },
  3309. [CAMSS_TOP_BCR] = { 0x3480 },
  3310. [CAMSS_AHB_BCR] = { 0x3488 },
  3311. [CAMSS_MICRO_BCR] = { 0x3490 },
  3312. [CAMSS_CCI_BCR] = { 0x3340 },
  3313. [CAMSS_PHY0_BCR] = { 0x3020 },
  3314. [CAMSS_PHY1_BCR] = { 0x3050 },
  3315. [CAMSS_PHY2_BCR] = { 0x3080 },
  3316. [CAMSS_CSIPHY0_3P_BCR] = { 0x3230 },
  3317. [CAMSS_CSIPHY1_3P_BCR] = { 0x3250 },
  3318. [CAMSS_CSIPHY2_3P_BCR] = { 0x3270 },
  3319. [CAMSS_JPEG_BCR] = { 0x35a0 },
  3320. [CAMSS_VFE_BCR] = { 0x36a0 },
  3321. [CAMSS_VFE0_BCR] = { 0x3660 },
  3322. [CAMSS_VFE1_BCR] = { 0x3670 },
  3323. [CAMSS_CSI_VFE0_BCR] = { 0x3700 },
  3324. [CAMSS_CSI_VFE1_BCR] = { 0x3710 },
  3325. [CAMSS_CPP_TOP_BCR] = { 0x36c0 },
  3326. [CAMSS_CPP_BCR] = { 0x36d0 },
  3327. [CAMSS_CSI0_BCR] = { 0x30b0 },
  3328. [CAMSS_CSI0RDI_BCR] = { 0x30d0 },
  3329. [CAMSS_CSI0PIX_BCR] = { 0x30e0 },
  3330. [CAMSS_CSI1_BCR] = { 0x3120 },
  3331. [CAMSS_CSI1RDI_BCR] = { 0x3140 },
  3332. [CAMSS_CSI1PIX_BCR] = { 0x3150 },
  3333. [CAMSS_CSI2_BCR] = { 0x3180 },
  3334. [CAMSS_CSI2RDI_BCR] = { 0x31a0 },
  3335. [CAMSS_CSI2PIX_BCR] = { 0x31b0 },
  3336. [CAMSS_CSI3_BCR] = { 0x31e0 },
  3337. [CAMSS_CSI3RDI_BCR] = { 0x3200 },
  3338. [CAMSS_CSI3PIX_BCR] = { 0x3210 },
  3339. [CAMSS_ISPIF_BCR] = { 0x3220 },
  3340. [FD_BCR] = { 0x3b60 },
  3341. [MMSS_SPDM_RM_BCR] = { 0x300 },
  3342. };
  3343. static const struct regmap_config mmcc_msm8996_regmap_config = {
  3344. .reg_bits = 32,
  3345. .reg_stride = 4,
  3346. .val_bits = 32,
  3347. .max_register = 0xb008,
  3348. .fast_io = true,
  3349. };
  3350. static const struct qcom_cc_desc mmcc_msm8996_desc = {
  3351. .config = &mmcc_msm8996_regmap_config,
  3352. .clks = mmcc_msm8996_clocks,
  3353. .num_clks = ARRAY_SIZE(mmcc_msm8996_clocks),
  3354. .resets = mmcc_msm8996_resets,
  3355. .num_resets = ARRAY_SIZE(mmcc_msm8996_resets),
  3356. .gdscs = mmcc_msm8996_gdscs,
  3357. .num_gdscs = ARRAY_SIZE(mmcc_msm8996_gdscs),
  3358. .clk_hws = mmcc_msm8996_hws,
  3359. .num_clk_hws = ARRAY_SIZE(mmcc_msm8996_hws),
  3360. };
  3361. static const struct of_device_id mmcc_msm8996_match_table[] = {
  3362. { .compatible = "qcom,mmcc-msm8996" },
  3363. { }
  3364. };
  3365. MODULE_DEVICE_TABLE(of, mmcc_msm8996_match_table);
  3366. static int mmcc_msm8996_probe(struct platform_device *pdev)
  3367. {
  3368. struct regmap *regmap;
  3369. regmap = qcom_cc_map(pdev, &mmcc_msm8996_desc);
  3370. if (IS_ERR(regmap))
  3371. return PTR_ERR(regmap);
  3372. /* Disable the AHB DCD */
  3373. regmap_update_bits(regmap, 0x50d8, BIT(31), 0);
  3374. /* Disable the NoC FSM for mmss_mmagic_cfg_ahb_clk */
  3375. regmap_update_bits(regmap, 0x5054, BIT(15), 0);
  3376. return qcom_cc_really_probe(&pdev->dev, &mmcc_msm8996_desc, regmap);
  3377. }
  3378. static struct platform_driver mmcc_msm8996_driver = {
  3379. .probe = mmcc_msm8996_probe,
  3380. .driver = {
  3381. .name = "mmcc-msm8996",
  3382. .of_match_table = mmcc_msm8996_match_table,
  3383. },
  3384. };
  3385. module_platform_driver(mmcc_msm8996_driver);
  3386. MODULE_DESCRIPTION("QCOM MMCC MSM8996 Driver");
  3387. MODULE_LICENSE("GPL v2");
  3388. MODULE_ALIAS("platform:mmcc-msm8996");