mmcc-msm8998.c 75 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * Copyright (c) 2019, 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-msm8998.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_GPLL0,
  25. P_GPLL0_DIV,
  26. P_MMPLL0_OUT_EVEN,
  27. P_MMPLL1_OUT_EVEN,
  28. P_MMPLL3_OUT_EVEN,
  29. P_MMPLL4_OUT_EVEN,
  30. P_MMPLL5_OUT_EVEN,
  31. P_MMPLL6_OUT_EVEN,
  32. P_MMPLL7_OUT_EVEN,
  33. P_MMPLL10_OUT_EVEN,
  34. P_DSI0PLL,
  35. P_DSI1PLL,
  36. P_DSI0PLL_BYTE,
  37. P_DSI1PLL_BYTE,
  38. P_HDMIPLL,
  39. P_DPVCO,
  40. P_DPLINK,
  41. };
  42. static const struct clk_div_table post_div_table_fabia_even[] = {
  43. { 0x0, 1 },
  44. { 0x1, 2 },
  45. { 0x3, 4 },
  46. { 0x7, 8 },
  47. { }
  48. };
  49. static struct clk_alpha_pll mmpll0 = {
  50. .offset = 0xc000,
  51. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA],
  52. .clkr = {
  53. .enable_reg = 0x1e0,
  54. .enable_mask = BIT(0),
  55. .hw.init = &(struct clk_init_data){
  56. .name = "mmpll0",
  57. .parent_data = &(const struct clk_parent_data){
  58. .fw_name = "xo"
  59. },
  60. .num_parents = 1,
  61. .ops = &clk_alpha_pll_fixed_fabia_ops,
  62. },
  63. },
  64. };
  65. static struct clk_alpha_pll_postdiv mmpll0_out_even = {
  66. .offset = 0xc000,
  67. .post_div_shift = 8,
  68. .post_div_table = post_div_table_fabia_even,
  69. .num_post_div = ARRAY_SIZE(post_div_table_fabia_even),
  70. .width = 4,
  71. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA],
  72. .clkr.hw.init = &(struct clk_init_data){
  73. .name = "mmpll0_out_even",
  74. .parent_hws = (const struct clk_hw *[]){ &mmpll0.clkr.hw },
  75. .num_parents = 1,
  76. .ops = &clk_alpha_pll_postdiv_fabia_ops,
  77. },
  78. };
  79. static struct clk_alpha_pll mmpll1 = {
  80. .offset = 0xc050,
  81. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA],
  82. .clkr = {
  83. .enable_reg = 0x1e0,
  84. .enable_mask = BIT(1),
  85. .hw.init = &(struct clk_init_data){
  86. .name = "mmpll1",
  87. .parent_data = &(const struct clk_parent_data){
  88. .fw_name = "xo"
  89. },
  90. .num_parents = 1,
  91. .ops = &clk_alpha_pll_fixed_fabia_ops,
  92. },
  93. },
  94. };
  95. static struct clk_alpha_pll_postdiv mmpll1_out_even = {
  96. .offset = 0xc050,
  97. .post_div_shift = 8,
  98. .post_div_table = post_div_table_fabia_even,
  99. .num_post_div = ARRAY_SIZE(post_div_table_fabia_even),
  100. .width = 4,
  101. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA],
  102. .clkr.hw.init = &(struct clk_init_data){
  103. .name = "mmpll1_out_even",
  104. .parent_hws = (const struct clk_hw *[]){ &mmpll1.clkr.hw },
  105. .num_parents = 1,
  106. .ops = &clk_alpha_pll_postdiv_fabia_ops,
  107. },
  108. };
  109. static struct clk_alpha_pll mmpll3 = {
  110. .offset = 0x0,
  111. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA],
  112. .clkr.hw.init = &(struct clk_init_data){
  113. .name = "mmpll3",
  114. .parent_data = &(const struct clk_parent_data){
  115. .fw_name = "xo"
  116. },
  117. .num_parents = 1,
  118. .ops = &clk_alpha_pll_fixed_fabia_ops,
  119. },
  120. };
  121. static struct clk_alpha_pll_postdiv mmpll3_out_even = {
  122. .offset = 0x0,
  123. .post_div_shift = 8,
  124. .post_div_table = post_div_table_fabia_even,
  125. .num_post_div = ARRAY_SIZE(post_div_table_fabia_even),
  126. .width = 4,
  127. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA],
  128. .clkr.hw.init = &(struct clk_init_data){
  129. .name = "mmpll3_out_even",
  130. .parent_hws = (const struct clk_hw *[]){ &mmpll3.clkr.hw },
  131. .num_parents = 1,
  132. .ops = &clk_alpha_pll_postdiv_fabia_ops,
  133. },
  134. };
  135. static struct clk_alpha_pll mmpll4 = {
  136. .offset = 0x50,
  137. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA],
  138. .clkr.hw.init = &(struct clk_init_data){
  139. .name = "mmpll4",
  140. .parent_data = &(const struct clk_parent_data){
  141. .fw_name = "xo"
  142. },
  143. .num_parents = 1,
  144. .ops = &clk_alpha_pll_fixed_fabia_ops,
  145. },
  146. };
  147. static struct clk_alpha_pll_postdiv mmpll4_out_even = {
  148. .offset = 0x50,
  149. .post_div_shift = 8,
  150. .post_div_table = post_div_table_fabia_even,
  151. .num_post_div = ARRAY_SIZE(post_div_table_fabia_even),
  152. .width = 4,
  153. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA],
  154. .clkr.hw.init = &(struct clk_init_data){
  155. .name = "mmpll4_out_even",
  156. .parent_hws = (const struct clk_hw *[]){ &mmpll4.clkr.hw },
  157. .num_parents = 1,
  158. .ops = &clk_alpha_pll_postdiv_fabia_ops,
  159. },
  160. };
  161. static struct clk_alpha_pll mmpll5 = {
  162. .offset = 0xa0,
  163. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA],
  164. .clkr.hw.init = &(struct clk_init_data){
  165. .name = "mmpll5",
  166. .parent_data = &(const struct clk_parent_data){
  167. .fw_name = "xo"
  168. },
  169. .num_parents = 1,
  170. .ops = &clk_alpha_pll_fixed_fabia_ops,
  171. },
  172. };
  173. static struct clk_alpha_pll_postdiv mmpll5_out_even = {
  174. .offset = 0xa0,
  175. .post_div_shift = 8,
  176. .post_div_table = post_div_table_fabia_even,
  177. .num_post_div = ARRAY_SIZE(post_div_table_fabia_even),
  178. .width = 4,
  179. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA],
  180. .clkr.hw.init = &(struct clk_init_data){
  181. .name = "mmpll5_out_even",
  182. .parent_hws = (const struct clk_hw *[]){ &mmpll5.clkr.hw },
  183. .num_parents = 1,
  184. .ops = &clk_alpha_pll_postdiv_fabia_ops,
  185. },
  186. };
  187. static struct clk_alpha_pll mmpll6 = {
  188. .offset = 0xf0,
  189. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA],
  190. .clkr.hw.init = &(struct clk_init_data){
  191. .name = "mmpll6",
  192. .parent_data = &(const struct clk_parent_data){
  193. .fw_name = "xo"
  194. },
  195. .num_parents = 1,
  196. .ops = &clk_alpha_pll_fixed_fabia_ops,
  197. },
  198. };
  199. static struct clk_alpha_pll_postdiv mmpll6_out_even = {
  200. .offset = 0xf0,
  201. .post_div_shift = 8,
  202. .post_div_table = post_div_table_fabia_even,
  203. .num_post_div = ARRAY_SIZE(post_div_table_fabia_even),
  204. .width = 4,
  205. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA],
  206. .clkr.hw.init = &(struct clk_init_data){
  207. .name = "mmpll6_out_even",
  208. .parent_hws = (const struct clk_hw *[]){ &mmpll6.clkr.hw },
  209. .num_parents = 1,
  210. .ops = &clk_alpha_pll_postdiv_fabia_ops,
  211. },
  212. };
  213. static struct clk_alpha_pll mmpll7 = {
  214. .offset = 0x140,
  215. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA],
  216. .clkr.hw.init = &(struct clk_init_data){
  217. .name = "mmpll7",
  218. .parent_data = &(const struct clk_parent_data){
  219. .fw_name = "xo"
  220. },
  221. .num_parents = 1,
  222. .ops = &clk_alpha_pll_fixed_fabia_ops,
  223. },
  224. };
  225. static struct clk_alpha_pll_postdiv mmpll7_out_even = {
  226. .offset = 0x140,
  227. .post_div_shift = 8,
  228. .post_div_table = post_div_table_fabia_even,
  229. .num_post_div = ARRAY_SIZE(post_div_table_fabia_even),
  230. .width = 4,
  231. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA],
  232. .clkr.hw.init = &(struct clk_init_data){
  233. .name = "mmpll7_out_even",
  234. .parent_hws = (const struct clk_hw *[]){ &mmpll7.clkr.hw },
  235. .num_parents = 1,
  236. .ops = &clk_alpha_pll_postdiv_fabia_ops,
  237. },
  238. };
  239. static struct clk_alpha_pll mmpll10 = {
  240. .offset = 0x190,
  241. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA],
  242. .clkr.hw.init = &(struct clk_init_data){
  243. .name = "mmpll10",
  244. .parent_data = &(const struct clk_parent_data){
  245. .fw_name = "xo"
  246. },
  247. .num_parents = 1,
  248. .ops = &clk_alpha_pll_fixed_fabia_ops,
  249. },
  250. };
  251. static struct clk_alpha_pll_postdiv mmpll10_out_even = {
  252. .offset = 0x190,
  253. .post_div_shift = 8,
  254. .post_div_table = post_div_table_fabia_even,
  255. .num_post_div = ARRAY_SIZE(post_div_table_fabia_even),
  256. .width = 4,
  257. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_FABIA],
  258. .clkr.hw.init = &(struct clk_init_data){
  259. .name = "mmpll10_out_even",
  260. .parent_hws = (const struct clk_hw *[]){ &mmpll10.clkr.hw },
  261. .num_parents = 1,
  262. .ops = &clk_alpha_pll_postdiv_fabia_ops,
  263. },
  264. };
  265. static const struct parent_map mmss_xo_hdmi_map[] = {
  266. { P_XO, 0 },
  267. { P_HDMIPLL, 1 },
  268. };
  269. static const struct clk_parent_data mmss_xo_hdmi[] = {
  270. { .fw_name = "xo" },
  271. { .fw_name = "hdmipll" },
  272. };
  273. static const struct parent_map mmss_xo_dsi0pll_dsi1pll_map[] = {
  274. { P_XO, 0 },
  275. { P_DSI0PLL, 1 },
  276. { P_DSI1PLL, 2 },
  277. };
  278. static const struct clk_parent_data mmss_xo_dsi0pll_dsi1pll[] = {
  279. { .fw_name = "xo" },
  280. { .fw_name = "dsi0dsi" },
  281. { .fw_name = "dsi1dsi" },
  282. };
  283. static const struct parent_map mmss_xo_dsibyte_map[] = {
  284. { P_XO, 0 },
  285. { P_DSI0PLL_BYTE, 1 },
  286. { P_DSI1PLL_BYTE, 2 },
  287. };
  288. static const struct clk_parent_data mmss_xo_dsibyte[] = {
  289. { .fw_name = "xo" },
  290. { .fw_name = "dsi0byte" },
  291. { .fw_name = "dsi1byte" },
  292. };
  293. static const struct parent_map mmss_xo_dp_map[] = {
  294. { P_XO, 0 },
  295. { P_DPLINK, 1 },
  296. { P_DPVCO, 2 },
  297. };
  298. static const struct clk_parent_data mmss_xo_dp[] = {
  299. { .fw_name = "xo" },
  300. { .fw_name = "dplink" },
  301. { .fw_name = "dpvco" },
  302. };
  303. static const struct parent_map mmss_xo_gpll0_gpll0_div_map[] = {
  304. { P_XO, 0 },
  305. { P_GPLL0, 5 },
  306. { P_GPLL0_DIV, 6 },
  307. };
  308. static const struct clk_parent_data mmss_xo_gpll0_gpll0_div[] = {
  309. { .fw_name = "xo" },
  310. { .fw_name = "gpll0" },
  311. { .fw_name = "gpll0_div", .name = "gcc_mmss_gpll0_div_clk" },
  312. };
  313. static const struct parent_map mmss_xo_mmpll0_gpll0_gpll0_div_map[] = {
  314. { P_XO, 0 },
  315. { P_MMPLL0_OUT_EVEN, 1 },
  316. { P_GPLL0, 5 },
  317. { P_GPLL0_DIV, 6 },
  318. };
  319. static const struct clk_parent_data mmss_xo_mmpll0_gpll0_gpll0_div[] = {
  320. { .fw_name = "xo" },
  321. { .hw = &mmpll0_out_even.clkr.hw },
  322. { .fw_name = "gpll0" },
  323. { .fw_name = "gpll0_div", .name = "gcc_mmss_gpll0_div_clk" },
  324. };
  325. static const struct parent_map mmss_xo_mmpll0_mmpll1_gpll0_gpll0_div_map[] = {
  326. { P_XO, 0 },
  327. { P_MMPLL0_OUT_EVEN, 1 },
  328. { P_MMPLL1_OUT_EVEN, 2 },
  329. { P_GPLL0, 5 },
  330. { P_GPLL0_DIV, 6 },
  331. };
  332. static const struct clk_parent_data mmss_xo_mmpll0_mmpll1_gpll0_gpll0_div[] = {
  333. { .fw_name = "xo" },
  334. { .hw = &mmpll0_out_even.clkr.hw },
  335. { .hw = &mmpll1_out_even.clkr.hw },
  336. { .fw_name = "gpll0" },
  337. { .fw_name = "gpll0_div", .name = "gcc_mmss_gpll0_div_clk" },
  338. };
  339. static const struct parent_map mmss_xo_mmpll0_mmpll5_gpll0_gpll0_div_map[] = {
  340. { P_XO, 0 },
  341. { P_MMPLL0_OUT_EVEN, 1 },
  342. { P_MMPLL5_OUT_EVEN, 2 },
  343. { P_GPLL0, 5 },
  344. { P_GPLL0_DIV, 6 },
  345. };
  346. static const struct clk_parent_data mmss_xo_mmpll0_mmpll5_gpll0_gpll0_div[] = {
  347. { .fw_name = "xo" },
  348. { .hw = &mmpll0_out_even.clkr.hw },
  349. { .hw = &mmpll5_out_even.clkr.hw },
  350. { .fw_name = "gpll0" },
  351. { .fw_name = "gpll0_div", .name = "gcc_mmss_gpll0_div_clk" },
  352. };
  353. static const struct parent_map mmss_xo_mmpll0_mmpll3_mmpll6_gpll0_gpll0_div_map[] = {
  354. { P_XO, 0 },
  355. { P_MMPLL0_OUT_EVEN, 1 },
  356. { P_MMPLL3_OUT_EVEN, 3 },
  357. { P_MMPLL6_OUT_EVEN, 4 },
  358. { P_GPLL0, 5 },
  359. { P_GPLL0_DIV, 6 },
  360. };
  361. static const struct clk_parent_data mmss_xo_mmpll0_mmpll3_mmpll6_gpll0_gpll0_div[] = {
  362. { .fw_name = "xo" },
  363. { .hw = &mmpll0_out_even.clkr.hw },
  364. { .hw = &mmpll3_out_even.clkr.hw },
  365. { .hw = &mmpll6_out_even.clkr.hw },
  366. { .fw_name = "gpll0" },
  367. { .fw_name = "gpll0_div", .name = "gcc_mmss_gpll0_div_clk" },
  368. };
  369. static const struct parent_map mmss_xo_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div_map[] = {
  370. { P_XO, 0 },
  371. { P_MMPLL4_OUT_EVEN, 1 },
  372. { P_MMPLL7_OUT_EVEN, 2 },
  373. { P_MMPLL10_OUT_EVEN, 3 },
  374. { P_GPLL0, 5 },
  375. { P_GPLL0_DIV, 6 },
  376. };
  377. static const struct clk_parent_data mmss_xo_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div[] = {
  378. { .fw_name = "xo" },
  379. { .hw = &mmpll4_out_even.clkr.hw },
  380. { .hw = &mmpll7_out_even.clkr.hw },
  381. { .hw = &mmpll10_out_even.clkr.hw },
  382. { .fw_name = "gpll0" },
  383. { .fw_name = "gpll0_div", .name = "gcc_mmss_gpll0_div_clk" },
  384. };
  385. static const struct parent_map mmss_xo_mmpll0_mmpll7_mmpll10_gpll0_gpll0_div_map[] = {
  386. { P_XO, 0 },
  387. { P_MMPLL0_OUT_EVEN, 1 },
  388. { P_MMPLL7_OUT_EVEN, 2 },
  389. { P_MMPLL10_OUT_EVEN, 3 },
  390. { P_GPLL0, 5 },
  391. { P_GPLL0_DIV, 6 },
  392. };
  393. static const struct clk_parent_data mmss_xo_mmpll0_mmpll7_mmpll10_gpll0_gpll0_div[] = {
  394. { .fw_name = "xo" },
  395. { .hw = &mmpll0_out_even.clkr.hw },
  396. { .hw = &mmpll7_out_even.clkr.hw },
  397. { .hw = &mmpll10_out_even.clkr.hw },
  398. { .fw_name = "gpll0" },
  399. { .fw_name = "gpll0_div", .name = "gcc_mmss_gpll0_div_clk" },
  400. };
  401. static const struct parent_map mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div_map[] = {
  402. { P_XO, 0 },
  403. { P_MMPLL0_OUT_EVEN, 1 },
  404. { P_MMPLL4_OUT_EVEN, 2 },
  405. { P_MMPLL7_OUT_EVEN, 3 },
  406. { P_MMPLL10_OUT_EVEN, 4 },
  407. { P_GPLL0, 5 },
  408. { P_GPLL0_DIV, 6 },
  409. };
  410. static const struct clk_parent_data mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div[] = {
  411. { .fw_name = "xo" },
  412. { .hw = &mmpll0_out_even.clkr.hw },
  413. { .hw = &mmpll4_out_even.clkr.hw },
  414. { .hw = &mmpll7_out_even.clkr.hw },
  415. { .hw = &mmpll10_out_even.clkr.hw },
  416. { .fw_name = "gpll0" },
  417. { .fw_name = "gpll0_div", .name = "gcc_mmss_gpll0_div_clk" },
  418. };
  419. static struct clk_rcg2 byte0_clk_src = {
  420. .cmd_rcgr = 0x2120,
  421. .hid_width = 5,
  422. .parent_map = mmss_xo_dsibyte_map,
  423. .clkr.hw.init = &(struct clk_init_data){
  424. .name = "byte0_clk_src",
  425. .parent_data = mmss_xo_dsibyte,
  426. .num_parents = ARRAY_SIZE(mmss_xo_dsibyte),
  427. .ops = &clk_byte2_ops,
  428. .flags = CLK_SET_RATE_PARENT,
  429. },
  430. };
  431. static struct clk_rcg2 byte1_clk_src = {
  432. .cmd_rcgr = 0x2140,
  433. .hid_width = 5,
  434. .parent_map = mmss_xo_dsibyte_map,
  435. .clkr.hw.init = &(struct clk_init_data){
  436. .name = "byte1_clk_src",
  437. .parent_data = mmss_xo_dsibyte,
  438. .num_parents = ARRAY_SIZE(mmss_xo_dsibyte),
  439. .ops = &clk_byte2_ops,
  440. .flags = CLK_SET_RATE_PARENT,
  441. },
  442. };
  443. static const struct freq_tbl ftbl_cci_clk_src[] = {
  444. F(37500000, P_GPLL0, 16, 0, 0),
  445. F(50000000, P_GPLL0, 12, 0, 0),
  446. F(100000000, P_GPLL0, 6, 0, 0),
  447. { }
  448. };
  449. static struct clk_rcg2 cci_clk_src = {
  450. .cmd_rcgr = 0x3300,
  451. .hid_width = 5,
  452. .parent_map = mmss_xo_mmpll0_mmpll7_mmpll10_gpll0_gpll0_div_map,
  453. .freq_tbl = ftbl_cci_clk_src,
  454. .clkr.hw.init = &(struct clk_init_data){
  455. .name = "cci_clk_src",
  456. .parent_data = mmss_xo_mmpll0_mmpll7_mmpll10_gpll0_gpll0_div,
  457. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll7_mmpll10_gpll0_gpll0_div),
  458. .ops = &clk_rcg2_ops,
  459. },
  460. };
  461. static const struct freq_tbl ftbl_cpp_clk_src[] = {
  462. F(100000000, P_GPLL0, 6, 0, 0),
  463. F(200000000, P_GPLL0, 3, 0, 0),
  464. F(384000000, P_MMPLL4_OUT_EVEN, 2, 0, 0),
  465. F(404000000, P_MMPLL0_OUT_EVEN, 2, 0, 0),
  466. F(480000000, P_MMPLL7_OUT_EVEN, 2, 0, 0),
  467. F(576000000, P_MMPLL10_OUT_EVEN, 1, 0, 0),
  468. F(600000000, P_GPLL0, 1, 0, 0),
  469. { }
  470. };
  471. static struct clk_rcg2 cpp_clk_src = {
  472. .cmd_rcgr = 0x3640,
  473. .hid_width = 5,
  474. .parent_map = mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div_map,
  475. .freq_tbl = ftbl_cpp_clk_src,
  476. .clkr.hw.init = &(struct clk_init_data){
  477. .name = "cpp_clk_src",
  478. .parent_data = mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div,
  479. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div),
  480. .ops = &clk_rcg2_ops,
  481. },
  482. };
  483. static const struct freq_tbl ftbl_csi_clk_src[] = {
  484. F(164571429, P_MMPLL10_OUT_EVEN, 3.5, 0, 0),
  485. F(256000000, P_MMPLL4_OUT_EVEN, 3, 0, 0),
  486. F(274290000, P_MMPLL7_OUT_EVEN, 3.5, 0, 0),
  487. F(300000000, P_GPLL0, 2, 0, 0),
  488. F(384000000, P_MMPLL4_OUT_EVEN, 2, 0, 0),
  489. F(576000000, P_MMPLL10_OUT_EVEN, 1, 0, 0),
  490. { }
  491. };
  492. static struct clk_rcg2 csi0_clk_src = {
  493. .cmd_rcgr = 0x3090,
  494. .hid_width = 5,
  495. .parent_map = mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div_map,
  496. .freq_tbl = ftbl_csi_clk_src,
  497. .clkr.hw.init = &(struct clk_init_data){
  498. .name = "csi0_clk_src",
  499. .parent_data = mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div,
  500. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div),
  501. .ops = &clk_rcg2_ops,
  502. },
  503. };
  504. static struct clk_rcg2 csi1_clk_src = {
  505. .cmd_rcgr = 0x3100,
  506. .hid_width = 5,
  507. .parent_map = mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div_map,
  508. .freq_tbl = ftbl_csi_clk_src,
  509. .clkr.hw.init = &(struct clk_init_data){
  510. .name = "csi1_clk_src",
  511. .parent_data = mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div,
  512. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div),
  513. .ops = &clk_rcg2_ops,
  514. },
  515. };
  516. static struct clk_rcg2 csi2_clk_src = {
  517. .cmd_rcgr = 0x3160,
  518. .hid_width = 5,
  519. .parent_map = mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div_map,
  520. .freq_tbl = ftbl_csi_clk_src,
  521. .clkr.hw.init = &(struct clk_init_data){
  522. .name = "csi2_clk_src",
  523. .parent_data = mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div,
  524. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div),
  525. .ops = &clk_rcg2_ops,
  526. },
  527. };
  528. static struct clk_rcg2 csi3_clk_src = {
  529. .cmd_rcgr = 0x31c0,
  530. .hid_width = 5,
  531. .parent_map = mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div_map,
  532. .freq_tbl = ftbl_csi_clk_src,
  533. .clkr.hw.init = &(struct clk_init_data){
  534. .name = "csi3_clk_src",
  535. .parent_data = mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div,
  536. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div),
  537. .ops = &clk_rcg2_ops,
  538. },
  539. };
  540. static const struct freq_tbl ftbl_csiphy_clk_src[] = {
  541. F(164571429, P_MMPLL10_OUT_EVEN, 3.5, 0, 0),
  542. F(256000000, P_MMPLL4_OUT_EVEN, 3, 0, 0),
  543. F(274290000, P_MMPLL7_OUT_EVEN, 3.5, 0, 0),
  544. F(300000000, P_GPLL0, 2, 0, 0),
  545. F(384000000, P_MMPLL4_OUT_EVEN, 2, 0, 0),
  546. { }
  547. };
  548. static struct clk_rcg2 csiphy_clk_src = {
  549. .cmd_rcgr = 0x3800,
  550. .hid_width = 5,
  551. .parent_map = mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div_map,
  552. .freq_tbl = ftbl_csiphy_clk_src,
  553. .clkr.hw.init = &(struct clk_init_data){
  554. .name = "csiphy_clk_src",
  555. .parent_data = mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div,
  556. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div),
  557. .ops = &clk_rcg2_ops,
  558. },
  559. };
  560. static const struct freq_tbl ftbl_csiphytimer_clk_src[] = {
  561. F(200000000, P_GPLL0, 3, 0, 0),
  562. F(269333333, P_MMPLL0_OUT_EVEN, 3, 0, 0),
  563. { }
  564. };
  565. static struct clk_rcg2 csi0phytimer_clk_src = {
  566. .cmd_rcgr = 0x3000,
  567. .hid_width = 5,
  568. .parent_map = mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div_map,
  569. .freq_tbl = ftbl_csiphytimer_clk_src,
  570. .clkr.hw.init = &(struct clk_init_data){
  571. .name = "csi0phytimer_clk_src",
  572. .parent_data = mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div,
  573. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div),
  574. .ops = &clk_rcg2_ops,
  575. },
  576. };
  577. static struct clk_rcg2 csi1phytimer_clk_src = {
  578. .cmd_rcgr = 0x3030,
  579. .hid_width = 5,
  580. .parent_map = mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div_map,
  581. .freq_tbl = ftbl_csiphytimer_clk_src,
  582. .clkr.hw.init = &(struct clk_init_data){
  583. .name = "csi1phytimer_clk_src",
  584. .parent_data = mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div,
  585. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div),
  586. .ops = &clk_rcg2_ops,
  587. },
  588. };
  589. static struct clk_rcg2 csi2phytimer_clk_src = {
  590. .cmd_rcgr = 0x3060,
  591. .hid_width = 5,
  592. .parent_map = mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div_map,
  593. .freq_tbl = ftbl_csiphytimer_clk_src,
  594. .clkr.hw.init = &(struct clk_init_data){
  595. .name = "csi2phytimer_clk_src",
  596. .parent_data = mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div,
  597. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div),
  598. .ops = &clk_rcg2_ops,
  599. },
  600. };
  601. static const struct freq_tbl ftbl_dp_aux_clk_src[] = {
  602. F(19200000, P_XO, 1, 0, 0),
  603. { }
  604. };
  605. static struct clk_rcg2 dp_aux_clk_src = {
  606. .cmd_rcgr = 0x2260,
  607. .hid_width = 5,
  608. .parent_map = mmss_xo_gpll0_gpll0_div_map,
  609. .freq_tbl = ftbl_dp_aux_clk_src,
  610. .clkr.hw.init = &(struct clk_init_data){
  611. .name = "dp_aux_clk_src",
  612. .parent_data = mmss_xo_gpll0_gpll0_div,
  613. .num_parents = ARRAY_SIZE(mmss_xo_gpll0_gpll0_div),
  614. .ops = &clk_rcg2_ops,
  615. },
  616. };
  617. static const struct freq_tbl ftbl_dp_crypto_clk_src[] = {
  618. F(101250, P_DPLINK, 1, 5, 16),
  619. F(168750, P_DPLINK, 1, 5, 16),
  620. F(337500, P_DPLINK, 1, 5, 16),
  621. { }
  622. };
  623. static struct clk_rcg2 dp_crypto_clk_src = {
  624. .cmd_rcgr = 0x2220,
  625. .hid_width = 5,
  626. .parent_map = mmss_xo_dp_map,
  627. .freq_tbl = ftbl_dp_crypto_clk_src,
  628. .clkr.hw.init = &(struct clk_init_data){
  629. .name = "dp_crypto_clk_src",
  630. .parent_data = mmss_xo_dp,
  631. .num_parents = ARRAY_SIZE(mmss_xo_dp),
  632. .ops = &clk_rcg2_ops,
  633. },
  634. };
  635. static const struct freq_tbl ftbl_dp_link_clk_src[] = {
  636. F(162000, P_DPLINK, 2, 0, 0),
  637. F(270000, P_DPLINK, 2, 0, 0),
  638. F(540000, P_DPLINK, 2, 0, 0),
  639. { }
  640. };
  641. static struct clk_rcg2 dp_link_clk_src = {
  642. .cmd_rcgr = 0x2200,
  643. .hid_width = 5,
  644. .parent_map = mmss_xo_dp_map,
  645. .freq_tbl = ftbl_dp_link_clk_src,
  646. .clkr.hw.init = &(struct clk_init_data){
  647. .name = "dp_link_clk_src",
  648. .parent_data = mmss_xo_dp,
  649. .num_parents = ARRAY_SIZE(mmss_xo_dp),
  650. .ops = &clk_rcg2_ops,
  651. },
  652. };
  653. static const struct freq_tbl ftbl_dp_pixel_clk_src[] = {
  654. F(154000000, P_DPVCO, 1, 0, 0),
  655. F(337500000, P_DPVCO, 2, 0, 0),
  656. F(675000000, P_DPVCO, 2, 0, 0),
  657. { }
  658. };
  659. static struct clk_rcg2 dp_pixel_clk_src = {
  660. .cmd_rcgr = 0x2240,
  661. .hid_width = 5,
  662. .parent_map = mmss_xo_dp_map,
  663. .freq_tbl = ftbl_dp_pixel_clk_src,
  664. .clkr.hw.init = &(struct clk_init_data){
  665. .name = "dp_pixel_clk_src",
  666. .parent_data = mmss_xo_dp,
  667. .num_parents = ARRAY_SIZE(mmss_xo_dp),
  668. .ops = &clk_rcg2_ops,
  669. },
  670. };
  671. static const struct freq_tbl ftbl_esc_clk_src[] = {
  672. F(19200000, P_XO, 1, 0, 0),
  673. { }
  674. };
  675. static struct clk_rcg2 esc0_clk_src = {
  676. .cmd_rcgr = 0x2160,
  677. .hid_width = 5,
  678. .parent_map = mmss_xo_dsibyte_map,
  679. .freq_tbl = ftbl_esc_clk_src,
  680. .clkr.hw.init = &(struct clk_init_data){
  681. .name = "esc0_clk_src",
  682. .parent_data = mmss_xo_dsibyte,
  683. .num_parents = ARRAY_SIZE(mmss_xo_dsibyte),
  684. .ops = &clk_rcg2_ops,
  685. },
  686. };
  687. static struct clk_rcg2 esc1_clk_src = {
  688. .cmd_rcgr = 0x2180,
  689. .hid_width = 5,
  690. .parent_map = mmss_xo_dsibyte_map,
  691. .freq_tbl = ftbl_esc_clk_src,
  692. .clkr.hw.init = &(struct clk_init_data){
  693. .name = "esc1_clk_src",
  694. .parent_data = mmss_xo_dsibyte,
  695. .num_parents = ARRAY_SIZE(mmss_xo_dsibyte),
  696. .ops = &clk_rcg2_ops,
  697. },
  698. };
  699. static const struct freq_tbl ftbl_extpclk_clk_src[] = {
  700. { .src = P_HDMIPLL },
  701. { }
  702. };
  703. static struct clk_rcg2 extpclk_clk_src = {
  704. .cmd_rcgr = 0x2060,
  705. .hid_width = 5,
  706. .parent_map = mmss_xo_hdmi_map,
  707. .freq_tbl = ftbl_extpclk_clk_src,
  708. .clkr.hw.init = &(struct clk_init_data){
  709. .name = "extpclk_clk_src",
  710. .parent_data = mmss_xo_hdmi,
  711. .num_parents = ARRAY_SIZE(mmss_xo_hdmi),
  712. .ops = &clk_byte_ops,
  713. .flags = CLK_SET_RATE_PARENT,
  714. },
  715. };
  716. static const struct freq_tbl ftbl_fd_core_clk_src[] = {
  717. F(100000000, P_GPLL0, 6, 0, 0),
  718. F(200000000, P_GPLL0, 3, 0, 0),
  719. F(404000000, P_MMPLL0_OUT_EVEN, 2, 0, 0),
  720. F(480000000, P_MMPLL7_OUT_EVEN, 2, 0, 0),
  721. F(576000000, P_MMPLL10_OUT_EVEN, 1, 0, 0),
  722. { }
  723. };
  724. static struct clk_rcg2 fd_core_clk_src = {
  725. .cmd_rcgr = 0x3b00,
  726. .hid_width = 5,
  727. .parent_map = mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div_map,
  728. .freq_tbl = ftbl_fd_core_clk_src,
  729. .clkr.hw.init = &(struct clk_init_data){
  730. .name = "fd_core_clk_src",
  731. .parent_data = mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div,
  732. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div),
  733. .ops = &clk_rcg2_ops,
  734. },
  735. };
  736. static const struct freq_tbl ftbl_hdmi_clk_src[] = {
  737. F(19200000, P_XO, 1, 0, 0),
  738. { }
  739. };
  740. static struct clk_rcg2 hdmi_clk_src = {
  741. .cmd_rcgr = 0x2100,
  742. .hid_width = 5,
  743. .parent_map = mmss_xo_gpll0_gpll0_div_map,
  744. .freq_tbl = ftbl_hdmi_clk_src,
  745. .clkr.hw.init = &(struct clk_init_data){
  746. .name = "hdmi_clk_src",
  747. .parent_data = mmss_xo_gpll0_gpll0_div,
  748. .num_parents = ARRAY_SIZE(mmss_xo_gpll0_gpll0_div),
  749. .ops = &clk_rcg2_ops,
  750. },
  751. };
  752. static const struct freq_tbl ftbl_jpeg0_clk_src[] = {
  753. F(75000000, P_GPLL0, 8, 0, 0),
  754. F(150000000, P_GPLL0, 4, 0, 0),
  755. F(320000000, P_MMPLL7_OUT_EVEN, 3, 0, 0),
  756. F(480000000, P_MMPLL7_OUT_EVEN, 2, 0, 0),
  757. { }
  758. };
  759. static struct clk_rcg2 jpeg0_clk_src = {
  760. .cmd_rcgr = 0x3500,
  761. .hid_width = 5,
  762. .parent_map = mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div_map,
  763. .freq_tbl = ftbl_jpeg0_clk_src,
  764. .clkr.hw.init = &(struct clk_init_data){
  765. .name = "jpeg0_clk_src",
  766. .parent_data = mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div,
  767. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div),
  768. .ops = &clk_rcg2_ops,
  769. },
  770. };
  771. static const struct freq_tbl ftbl_maxi_clk_src[] = {
  772. F(19200000, P_XO, 1, 0, 0),
  773. F(75000000, P_GPLL0_DIV, 4, 0, 0),
  774. F(171428571, P_GPLL0, 3.5, 0, 0),
  775. F(323200000, P_MMPLL0_OUT_EVEN, 2.5, 0, 0),
  776. F(406000000, P_MMPLL1_OUT_EVEN, 2, 0, 0),
  777. { }
  778. };
  779. static struct clk_rcg2 maxi_clk_src = {
  780. .cmd_rcgr = 0xf020,
  781. .hid_width = 5,
  782. .parent_map = mmss_xo_mmpll0_mmpll1_gpll0_gpll0_div_map,
  783. .freq_tbl = ftbl_maxi_clk_src,
  784. .clkr.hw.init = &(struct clk_init_data){
  785. .name = "maxi_clk_src",
  786. .parent_data = mmss_xo_mmpll0_mmpll1_gpll0_gpll0_div,
  787. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_gpll0_gpll0_div),
  788. .ops = &clk_rcg2_ops,
  789. },
  790. };
  791. static const struct freq_tbl ftbl_mclk_clk_src[] = {
  792. F(4800000, P_XO, 4, 0, 0),
  793. F(6000000, P_GPLL0_DIV, 10, 1, 5),
  794. F(8000000, P_GPLL0_DIV, 1, 2, 75),
  795. F(9600000, P_XO, 2, 0, 0),
  796. F(16666667, P_GPLL0_DIV, 2, 1, 9),
  797. F(19200000, P_XO, 1, 0, 0),
  798. F(24000000, P_GPLL0_DIV, 1, 2, 25),
  799. F(33333333, P_GPLL0_DIV, 1, 2, 9),
  800. F(48000000, P_GPLL0, 1, 2, 25),
  801. F(66666667, P_GPLL0, 1, 2, 9),
  802. { }
  803. };
  804. static struct clk_rcg2 mclk0_clk_src = {
  805. .cmd_rcgr = 0x3360,
  806. .hid_width = 5,
  807. .parent_map = mmss_xo_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div_map,
  808. .freq_tbl = ftbl_mclk_clk_src,
  809. .clkr.hw.init = &(struct clk_init_data){
  810. .name = "mclk0_clk_src",
  811. .parent_data = mmss_xo_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div,
  812. .num_parents = ARRAY_SIZE(mmss_xo_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div),
  813. .ops = &clk_rcg2_ops,
  814. },
  815. };
  816. static struct clk_rcg2 mclk1_clk_src = {
  817. .cmd_rcgr = 0x3390,
  818. .hid_width = 5,
  819. .parent_map = mmss_xo_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div_map,
  820. .freq_tbl = ftbl_mclk_clk_src,
  821. .clkr.hw.init = &(struct clk_init_data){
  822. .name = "mclk1_clk_src",
  823. .parent_data = mmss_xo_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div,
  824. .num_parents = ARRAY_SIZE(mmss_xo_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div),
  825. .ops = &clk_rcg2_ops,
  826. },
  827. };
  828. static struct clk_rcg2 mclk2_clk_src = {
  829. .cmd_rcgr = 0x33c0,
  830. .hid_width = 5,
  831. .parent_map = mmss_xo_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div_map,
  832. .freq_tbl = ftbl_mclk_clk_src,
  833. .clkr.hw.init = &(struct clk_init_data){
  834. .name = "mclk2_clk_src",
  835. .parent_data = mmss_xo_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div,
  836. .num_parents = ARRAY_SIZE(mmss_xo_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div),
  837. .ops = &clk_rcg2_ops,
  838. },
  839. };
  840. static struct clk_rcg2 mclk3_clk_src = {
  841. .cmd_rcgr = 0x33f0,
  842. .hid_width = 5,
  843. .parent_map = mmss_xo_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div_map,
  844. .freq_tbl = ftbl_mclk_clk_src,
  845. .clkr.hw.init = &(struct clk_init_data){
  846. .name = "mclk3_clk_src",
  847. .parent_data = mmss_xo_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div,
  848. .num_parents = ARRAY_SIZE(mmss_xo_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div),
  849. .ops = &clk_rcg2_ops,
  850. },
  851. };
  852. static const struct freq_tbl ftbl_mdp_clk_src[] = {
  853. F(85714286, P_GPLL0, 7, 0, 0),
  854. F(100000000, P_GPLL0, 6, 0, 0),
  855. F(150000000, P_GPLL0, 4, 0, 0),
  856. F(171428571, P_GPLL0, 3.5, 0, 0),
  857. F(200000000, P_GPLL0, 3, 0, 0),
  858. F(275000000, P_MMPLL5_OUT_EVEN, 3, 0, 0),
  859. F(300000000, P_GPLL0, 2, 0, 0),
  860. F(330000000, P_MMPLL5_OUT_EVEN, 2.5, 0, 0),
  861. F(412500000, P_MMPLL5_OUT_EVEN, 2, 0, 0),
  862. { }
  863. };
  864. static struct clk_rcg2 mdp_clk_src = {
  865. .cmd_rcgr = 0x2040,
  866. .hid_width = 5,
  867. .parent_map = mmss_xo_mmpll0_mmpll5_gpll0_gpll0_div_map,
  868. .freq_tbl = ftbl_mdp_clk_src,
  869. .clkr.hw.init = &(struct clk_init_data){
  870. .name = "mdp_clk_src",
  871. .parent_data = mmss_xo_mmpll0_mmpll5_gpll0_gpll0_div,
  872. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll5_gpll0_gpll0_div),
  873. .ops = &clk_rcg2_ops,
  874. },
  875. };
  876. static const struct freq_tbl ftbl_vsync_clk_src[] = {
  877. F(19200000, P_XO, 1, 0, 0),
  878. { }
  879. };
  880. static struct clk_rcg2 vsync_clk_src = {
  881. .cmd_rcgr = 0x2080,
  882. .hid_width = 5,
  883. .parent_map = mmss_xo_gpll0_gpll0_div_map,
  884. .freq_tbl = ftbl_vsync_clk_src,
  885. .clkr.hw.init = &(struct clk_init_data){
  886. .name = "vsync_clk_src",
  887. .parent_data = mmss_xo_gpll0_gpll0_div,
  888. .num_parents = ARRAY_SIZE(mmss_xo_gpll0_gpll0_div),
  889. .ops = &clk_rcg2_ops,
  890. },
  891. };
  892. static const struct freq_tbl ftbl_ahb_clk_src[] = {
  893. F(19200000, P_XO, 1, 0, 0),
  894. F(40000000, P_GPLL0, 15, 0, 0),
  895. F(80800000, P_MMPLL0_OUT_EVEN, 10, 0, 0),
  896. { }
  897. };
  898. static struct clk_rcg2 ahb_clk_src = {
  899. .cmd_rcgr = 0x5000,
  900. .hid_width = 5,
  901. .parent_map = mmss_xo_mmpll0_gpll0_gpll0_div_map,
  902. .freq_tbl = ftbl_ahb_clk_src,
  903. .clkr.hw.init = &(struct clk_init_data){
  904. .name = "ahb_clk_src",
  905. .parent_data = mmss_xo_mmpll0_gpll0_gpll0_div,
  906. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_gpll0_gpll0_div),
  907. .ops = &clk_rcg2_ops,
  908. },
  909. };
  910. static const struct freq_tbl ftbl_axi_clk_src[] = {
  911. F(75000000, P_GPLL0, 8, 0, 0),
  912. F(171428571, P_GPLL0, 3.5, 0, 0),
  913. F(240000000, P_GPLL0, 2.5, 0, 0),
  914. F(323200000, P_MMPLL0_OUT_EVEN, 2.5, 0, 0),
  915. F(406000000, P_MMPLL0_OUT_EVEN, 2, 0, 0),
  916. { }
  917. };
  918. /* RO to linux */
  919. static struct clk_rcg2 axi_clk_src = {
  920. .cmd_rcgr = 0xd000,
  921. .hid_width = 5,
  922. .parent_map = mmss_xo_mmpll0_mmpll1_gpll0_gpll0_div_map,
  923. .freq_tbl = ftbl_axi_clk_src,
  924. .clkr.hw.init = &(struct clk_init_data){
  925. .name = "axi_clk_src",
  926. .parent_data = mmss_xo_mmpll0_mmpll1_gpll0_gpll0_div,
  927. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll1_gpll0_gpll0_div),
  928. .ops = &clk_rcg2_ops,
  929. },
  930. };
  931. static struct clk_rcg2 pclk0_clk_src = {
  932. .cmd_rcgr = 0x2000,
  933. .mnd_width = 8,
  934. .hid_width = 5,
  935. .parent_map = mmss_xo_dsi0pll_dsi1pll_map,
  936. .clkr.hw.init = &(struct clk_init_data){
  937. .name = "pclk0_clk_src",
  938. .parent_data = mmss_xo_dsi0pll_dsi1pll,
  939. .num_parents = ARRAY_SIZE(mmss_xo_dsi0pll_dsi1pll),
  940. .ops = &clk_pixel_ops,
  941. .flags = CLK_SET_RATE_PARENT,
  942. },
  943. };
  944. static struct clk_rcg2 pclk1_clk_src = {
  945. .cmd_rcgr = 0x2020,
  946. .mnd_width = 8,
  947. .hid_width = 5,
  948. .parent_map = mmss_xo_dsi0pll_dsi1pll_map,
  949. .clkr.hw.init = &(struct clk_init_data){
  950. .name = "pclk1_clk_src",
  951. .parent_data = mmss_xo_dsi0pll_dsi1pll,
  952. .num_parents = ARRAY_SIZE(mmss_xo_dsi0pll_dsi1pll),
  953. .ops = &clk_pixel_ops,
  954. .flags = CLK_SET_RATE_PARENT,
  955. },
  956. };
  957. static const struct freq_tbl ftbl_rot_clk_src[] = {
  958. F(171428571, P_GPLL0, 3.5, 0, 0),
  959. F(275000000, P_MMPLL5_OUT_EVEN, 3, 0, 0),
  960. F(330000000, P_MMPLL5_OUT_EVEN, 2.5, 0, 0),
  961. F(412500000, P_MMPLL5_OUT_EVEN, 2, 0, 0),
  962. { }
  963. };
  964. static struct clk_rcg2 rot_clk_src = {
  965. .cmd_rcgr = 0x21a0,
  966. .hid_width = 5,
  967. .parent_map = mmss_xo_mmpll0_mmpll5_gpll0_gpll0_div_map,
  968. .freq_tbl = ftbl_rot_clk_src,
  969. .clkr.hw.init = &(struct clk_init_data){
  970. .name = "rot_clk_src",
  971. .parent_data = mmss_xo_mmpll0_mmpll5_gpll0_gpll0_div,
  972. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll5_gpll0_gpll0_div),
  973. .ops = &clk_rcg2_ops,
  974. },
  975. };
  976. static const struct freq_tbl ftbl_video_core_clk_src[] = {
  977. F(200000000, P_GPLL0, 3, 0, 0),
  978. F(269330000, P_MMPLL0_OUT_EVEN, 3, 0, 0),
  979. F(355200000, P_MMPLL6_OUT_EVEN, 2.5, 0, 0),
  980. F(444000000, P_MMPLL6_OUT_EVEN, 2, 0, 0),
  981. F(533000000, P_MMPLL3_OUT_EVEN, 2, 0, 0),
  982. { }
  983. };
  984. static struct clk_rcg2 video_core_clk_src = {
  985. .cmd_rcgr = 0x1000,
  986. .hid_width = 5,
  987. .parent_map = mmss_xo_mmpll0_mmpll3_mmpll6_gpll0_gpll0_div_map,
  988. .freq_tbl = ftbl_video_core_clk_src,
  989. .clkr.hw.init = &(struct clk_init_data){
  990. .name = "video_core_clk_src",
  991. .parent_data = mmss_xo_mmpll0_mmpll3_mmpll6_gpll0_gpll0_div,
  992. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll3_mmpll6_gpll0_gpll0_div),
  993. .ops = &clk_rcg2_ops,
  994. },
  995. };
  996. static struct clk_rcg2 video_subcore0_clk_src = {
  997. .cmd_rcgr = 0x1060,
  998. .hid_width = 5,
  999. .parent_map = mmss_xo_mmpll0_mmpll3_mmpll6_gpll0_gpll0_div_map,
  1000. .freq_tbl = ftbl_video_core_clk_src,
  1001. .clkr.hw.init = &(struct clk_init_data){
  1002. .name = "video_subcore0_clk_src",
  1003. .parent_data = mmss_xo_mmpll0_mmpll3_mmpll6_gpll0_gpll0_div,
  1004. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll3_mmpll6_gpll0_gpll0_div),
  1005. .ops = &clk_rcg2_ops,
  1006. },
  1007. };
  1008. static struct clk_rcg2 video_subcore1_clk_src = {
  1009. .cmd_rcgr = 0x1080,
  1010. .hid_width = 5,
  1011. .parent_map = mmss_xo_mmpll0_mmpll3_mmpll6_gpll0_gpll0_div_map,
  1012. .freq_tbl = ftbl_video_core_clk_src,
  1013. .clkr.hw.init = &(struct clk_init_data){
  1014. .name = "video_subcore1_clk_src",
  1015. .parent_data = mmss_xo_mmpll0_mmpll3_mmpll6_gpll0_gpll0_div,
  1016. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll3_mmpll6_gpll0_gpll0_div),
  1017. .ops = &clk_rcg2_ops,
  1018. },
  1019. };
  1020. static const struct freq_tbl ftbl_vfe_clk_src[] = {
  1021. F(200000000, P_GPLL0, 3, 0, 0),
  1022. F(300000000, P_GPLL0, 2, 0, 0),
  1023. F(320000000, P_MMPLL7_OUT_EVEN, 3, 0, 0),
  1024. F(384000000, P_MMPLL4_OUT_EVEN, 2, 0, 0),
  1025. F(404000000, P_MMPLL0_OUT_EVEN, 2, 0, 0),
  1026. F(480000000, P_MMPLL7_OUT_EVEN, 2, 0, 0),
  1027. F(576000000, P_MMPLL10_OUT_EVEN, 1, 0, 0),
  1028. F(600000000, P_GPLL0, 1, 0, 0),
  1029. { }
  1030. };
  1031. static struct clk_rcg2 vfe0_clk_src = {
  1032. .cmd_rcgr = 0x3600,
  1033. .hid_width = 5,
  1034. .parent_map = mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div_map,
  1035. .freq_tbl = ftbl_vfe_clk_src,
  1036. .clkr.hw.init = &(struct clk_init_data){
  1037. .name = "vfe0_clk_src",
  1038. .parent_data = mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div,
  1039. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div),
  1040. .ops = &clk_rcg2_ops,
  1041. },
  1042. };
  1043. static struct clk_rcg2 vfe1_clk_src = {
  1044. .cmd_rcgr = 0x3620,
  1045. .hid_width = 5,
  1046. .parent_map = mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div_map,
  1047. .freq_tbl = ftbl_vfe_clk_src,
  1048. .clkr.hw.init = &(struct clk_init_data){
  1049. .name = "vfe1_clk_src",
  1050. .parent_data = mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div,
  1051. .num_parents = ARRAY_SIZE(mmss_xo_mmpll0_mmpll4_mmpll7_mmpll10_gpll0_gpll0_div),
  1052. .ops = &clk_rcg2_ops,
  1053. },
  1054. };
  1055. static struct clk_branch misc_ahb_clk = {
  1056. .halt_reg = 0x328,
  1057. .hwcg_reg = 0x328,
  1058. .hwcg_bit = 1,
  1059. .clkr = {
  1060. .enable_reg = 0x328,
  1061. .enable_mask = BIT(0),
  1062. .hw.init = &(struct clk_init_data){
  1063. .name = "misc_ahb_clk",
  1064. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1065. .num_parents = 1,
  1066. .ops = &clk_branch2_ops,
  1067. .flags = CLK_SET_RATE_PARENT,
  1068. },
  1069. },
  1070. };
  1071. static struct clk_branch video_core_clk = {
  1072. .halt_reg = 0x1028,
  1073. .clkr = {
  1074. .enable_reg = 0x1028,
  1075. .enable_mask = BIT(0),
  1076. .hw.init = &(struct clk_init_data){
  1077. .name = "video_core_clk",
  1078. .parent_hws = (const struct clk_hw *[]){ &video_core_clk_src.clkr.hw },
  1079. .num_parents = 1,
  1080. .ops = &clk_branch2_ops,
  1081. .flags = CLK_SET_RATE_PARENT,
  1082. },
  1083. },
  1084. };
  1085. static struct clk_branch video_ahb_clk = {
  1086. .halt_reg = 0x1030,
  1087. .hwcg_reg = 0x1030,
  1088. .hwcg_bit = 1,
  1089. .clkr = {
  1090. .enable_reg = 0x1030,
  1091. .enable_mask = BIT(0),
  1092. .hw.init = &(struct clk_init_data){
  1093. .name = "video_ahb_clk",
  1094. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1095. .num_parents = 1,
  1096. .ops = &clk_branch2_ops,
  1097. .flags = CLK_SET_RATE_PARENT,
  1098. },
  1099. },
  1100. };
  1101. static struct clk_branch video_axi_clk = {
  1102. .halt_reg = 0x1034,
  1103. .clkr = {
  1104. .enable_reg = 0x1034,
  1105. .enable_mask = BIT(0),
  1106. .hw.init = &(struct clk_init_data){
  1107. .name = "video_axi_clk",
  1108. .parent_hws = (const struct clk_hw *[]){ &axi_clk_src.clkr.hw },
  1109. .num_parents = 1,
  1110. .ops = &clk_branch2_ops,
  1111. },
  1112. },
  1113. };
  1114. static struct clk_branch video_maxi_clk = {
  1115. .halt_reg = 0x1038,
  1116. .clkr = {
  1117. .enable_reg = 0x1038,
  1118. .enable_mask = BIT(0),
  1119. .hw.init = &(struct clk_init_data){
  1120. .name = "video_maxi_clk",
  1121. .parent_hws = (const struct clk_hw *[]){ &maxi_clk_src.clkr.hw },
  1122. .num_parents = 1,
  1123. .ops = &clk_branch2_ops,
  1124. .flags = CLK_SET_RATE_PARENT,
  1125. },
  1126. },
  1127. };
  1128. static struct clk_branch video_subcore0_clk = {
  1129. .halt_reg = 0x1048,
  1130. .clkr = {
  1131. .enable_reg = 0x1048,
  1132. .enable_mask = BIT(0),
  1133. .hw.init = &(struct clk_init_data){
  1134. .name = "video_subcore0_clk",
  1135. .parent_hws = (const struct clk_hw *[]){ &video_subcore0_clk_src.clkr.hw },
  1136. .num_parents = 1,
  1137. .ops = &clk_branch2_ops,
  1138. .flags = CLK_SET_RATE_PARENT,
  1139. },
  1140. },
  1141. };
  1142. static struct clk_branch video_subcore1_clk = {
  1143. .halt_reg = 0x104c,
  1144. .clkr = {
  1145. .enable_reg = 0x104c,
  1146. .enable_mask = BIT(0),
  1147. .hw.init = &(struct clk_init_data){
  1148. .name = "video_subcore1_clk",
  1149. .parent_hws = (const struct clk_hw *[]){ &video_subcore1_clk_src.clkr.hw },
  1150. .num_parents = 1,
  1151. .ops = &clk_branch2_ops,
  1152. .flags = CLK_SET_RATE_PARENT,
  1153. },
  1154. },
  1155. };
  1156. static struct clk_branch mdss_ahb_clk = {
  1157. .halt_reg = 0x2308,
  1158. .hwcg_reg = 0x2308,
  1159. .hwcg_bit = 1,
  1160. .clkr = {
  1161. .enable_reg = 0x2308,
  1162. .enable_mask = BIT(0),
  1163. .hw.init = &(struct clk_init_data){
  1164. .name = "mdss_ahb_clk",
  1165. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1166. .num_parents = 1,
  1167. .ops = &clk_branch2_ops,
  1168. .flags = CLK_SET_RATE_PARENT,
  1169. },
  1170. },
  1171. };
  1172. static struct clk_branch mdss_hdmi_dp_ahb_clk = {
  1173. .halt_reg = 0x230c,
  1174. .clkr = {
  1175. .enable_reg = 0x230c,
  1176. .enable_mask = BIT(0),
  1177. .hw.init = &(struct clk_init_data){
  1178. .name = "mdss_hdmi_dp_ahb_clk",
  1179. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1180. .num_parents = 1,
  1181. .ops = &clk_branch2_ops,
  1182. .flags = CLK_SET_RATE_PARENT,
  1183. },
  1184. },
  1185. };
  1186. static struct clk_branch mdss_axi_clk = {
  1187. .halt_reg = 0x2310,
  1188. .clkr = {
  1189. .enable_reg = 0x2310,
  1190. .enable_mask = BIT(0),
  1191. .hw.init = &(struct clk_init_data){
  1192. .name = "mdss_axi_clk",
  1193. .parent_hws = (const struct clk_hw *[]){ &axi_clk_src.clkr.hw },
  1194. .num_parents = 1,
  1195. .ops = &clk_branch2_ops,
  1196. },
  1197. },
  1198. };
  1199. static struct clk_branch mdss_pclk0_clk = {
  1200. .halt_reg = 0x2314,
  1201. .clkr = {
  1202. .enable_reg = 0x2314,
  1203. .enable_mask = BIT(0),
  1204. .hw.init = &(struct clk_init_data){
  1205. .name = "mdss_pclk0_clk",
  1206. .parent_hws = (const struct clk_hw *[]){ &pclk0_clk_src.clkr.hw },
  1207. .num_parents = 1,
  1208. .ops = &clk_branch2_ops,
  1209. .flags = CLK_SET_RATE_PARENT,
  1210. },
  1211. },
  1212. };
  1213. static struct clk_branch mdss_pclk1_clk = {
  1214. .halt_reg = 0x2318,
  1215. .clkr = {
  1216. .enable_reg = 0x2318,
  1217. .enable_mask = BIT(0),
  1218. .hw.init = &(struct clk_init_data){
  1219. .name = "mdss_pclk1_clk",
  1220. .parent_hws = (const struct clk_hw *[]){ &pclk1_clk_src.clkr.hw },
  1221. .num_parents = 1,
  1222. .ops = &clk_branch2_ops,
  1223. .flags = CLK_SET_RATE_PARENT,
  1224. },
  1225. },
  1226. };
  1227. static struct clk_branch mdss_mdp_clk = {
  1228. .halt_reg = 0x231c,
  1229. .clkr = {
  1230. .enable_reg = 0x231c,
  1231. .enable_mask = BIT(0),
  1232. .hw.init = &(struct clk_init_data){
  1233. .name = "mdss_mdp_clk",
  1234. .parent_hws = (const struct clk_hw *[]){ &mdp_clk_src.clkr.hw },
  1235. .num_parents = 1,
  1236. .ops = &clk_branch2_ops,
  1237. .flags = CLK_SET_RATE_PARENT,
  1238. },
  1239. },
  1240. };
  1241. static struct clk_branch mdss_mdp_lut_clk = {
  1242. .halt_reg = 0x2320,
  1243. .clkr = {
  1244. .enable_reg = 0x2320,
  1245. .enable_mask = BIT(0),
  1246. .hw.init = &(struct clk_init_data){
  1247. .name = "mdss_mdp_lut_clk",
  1248. .parent_hws = (const struct clk_hw *[]){ &mdp_clk_src.clkr.hw },
  1249. .num_parents = 1,
  1250. .ops = &clk_branch2_ops,
  1251. .flags = CLK_SET_RATE_PARENT,
  1252. },
  1253. },
  1254. };
  1255. static struct clk_branch mdss_extpclk_clk = {
  1256. .halt_reg = 0x2324,
  1257. .clkr = {
  1258. .enable_reg = 0x2324,
  1259. .enable_mask = BIT(0),
  1260. .hw.init = &(struct clk_init_data){
  1261. .name = "mdss_extpclk_clk",
  1262. .parent_hws = (const struct clk_hw *[]){ &extpclk_clk_src.clkr.hw },
  1263. .num_parents = 1,
  1264. .ops = &clk_branch2_ops,
  1265. .flags = CLK_SET_RATE_PARENT,
  1266. },
  1267. },
  1268. };
  1269. static struct clk_branch mdss_vsync_clk = {
  1270. .halt_reg = 0x2328,
  1271. .clkr = {
  1272. .enable_reg = 0x2328,
  1273. .enable_mask = BIT(0),
  1274. .hw.init = &(struct clk_init_data){
  1275. .name = "mdss_vsync_clk",
  1276. .parent_hws = (const struct clk_hw *[]){ &vsync_clk_src.clkr.hw },
  1277. .num_parents = 1,
  1278. .ops = &clk_branch2_ops,
  1279. .flags = CLK_SET_RATE_PARENT,
  1280. },
  1281. },
  1282. };
  1283. static struct clk_branch mdss_hdmi_clk = {
  1284. .halt_reg = 0x2338,
  1285. .clkr = {
  1286. .enable_reg = 0x2338,
  1287. .enable_mask = BIT(0),
  1288. .hw.init = &(struct clk_init_data){
  1289. .name = "mdss_hdmi_clk",
  1290. .parent_hws = (const struct clk_hw *[]){ &hdmi_clk_src.clkr.hw },
  1291. .num_parents = 1,
  1292. .ops = &clk_branch2_ops,
  1293. .flags = CLK_SET_RATE_PARENT,
  1294. },
  1295. },
  1296. };
  1297. static struct clk_branch mdss_byte0_clk = {
  1298. .halt_reg = 0x233c,
  1299. .clkr = {
  1300. .enable_reg = 0x233c,
  1301. .enable_mask = BIT(0),
  1302. .hw.init = &(struct clk_init_data){
  1303. .name = "mdss_byte0_clk",
  1304. .parent_hws = (const struct clk_hw *[]){ &byte0_clk_src.clkr.hw },
  1305. .num_parents = 1,
  1306. .ops = &clk_branch2_ops,
  1307. .flags = CLK_SET_RATE_PARENT,
  1308. },
  1309. },
  1310. };
  1311. static struct clk_branch mdss_byte1_clk = {
  1312. .halt_reg = 0x2340,
  1313. .clkr = {
  1314. .enable_reg = 0x2340,
  1315. .enable_mask = BIT(0),
  1316. .hw.init = &(struct clk_init_data){
  1317. .name = "mdss_byte1_clk",
  1318. .parent_hws = (const struct clk_hw *[]){ &byte1_clk_src.clkr.hw },
  1319. .num_parents = 1,
  1320. .ops = &clk_branch2_ops,
  1321. .flags = CLK_SET_RATE_PARENT,
  1322. },
  1323. },
  1324. };
  1325. static struct clk_branch mdss_esc0_clk = {
  1326. .halt_reg = 0x2344,
  1327. .clkr = {
  1328. .enable_reg = 0x2344,
  1329. .enable_mask = BIT(0),
  1330. .hw.init = &(struct clk_init_data){
  1331. .name = "mdss_esc0_clk",
  1332. .parent_hws = (const struct clk_hw *[]){ &esc0_clk_src.clkr.hw },
  1333. .num_parents = 1,
  1334. .ops = &clk_branch2_ops,
  1335. .flags = CLK_SET_RATE_PARENT,
  1336. },
  1337. },
  1338. };
  1339. static struct clk_branch mdss_esc1_clk = {
  1340. .halt_reg = 0x2348,
  1341. .clkr = {
  1342. .enable_reg = 0x2348,
  1343. .enable_mask = BIT(0),
  1344. .hw.init = &(struct clk_init_data){
  1345. .name = "mdss_esc1_clk",
  1346. .parent_hws = (const struct clk_hw *[]){ &esc1_clk_src.clkr.hw },
  1347. .num_parents = 1,
  1348. .ops = &clk_branch2_ops,
  1349. .flags = CLK_SET_RATE_PARENT,
  1350. },
  1351. },
  1352. };
  1353. static struct clk_branch mdss_rot_clk = {
  1354. .halt_reg = 0x2350,
  1355. .clkr = {
  1356. .enable_reg = 0x2350,
  1357. .enable_mask = BIT(0),
  1358. .hw.init = &(struct clk_init_data){
  1359. .name = "mdss_rot_clk",
  1360. .parent_hws = (const struct clk_hw *[]){ &rot_clk_src.clkr.hw },
  1361. .num_parents = 1,
  1362. .ops = &clk_branch2_ops,
  1363. .flags = CLK_SET_RATE_PARENT,
  1364. },
  1365. },
  1366. };
  1367. static struct clk_branch mdss_dp_link_clk = {
  1368. .halt_reg = 0x2354,
  1369. .clkr = {
  1370. .enable_reg = 0x2354,
  1371. .enable_mask = BIT(0),
  1372. .hw.init = &(struct clk_init_data){
  1373. .name = "mdss_dp_link_clk",
  1374. .parent_hws = (const struct clk_hw *[]){ &dp_link_clk_src.clkr.hw },
  1375. .num_parents = 1,
  1376. .ops = &clk_branch2_ops,
  1377. .flags = CLK_SET_RATE_PARENT,
  1378. },
  1379. },
  1380. };
  1381. static struct clk_branch mdss_dp_link_intf_clk = {
  1382. .halt_reg = 0x2358,
  1383. .clkr = {
  1384. .enable_reg = 0x2358,
  1385. .enable_mask = BIT(0),
  1386. .hw.init = &(struct clk_init_data){
  1387. .name = "mdss_dp_link_intf_clk",
  1388. .parent_hws = (const struct clk_hw *[]){ &dp_link_clk_src.clkr.hw },
  1389. .num_parents = 1,
  1390. .ops = &clk_branch2_ops,
  1391. .flags = CLK_SET_RATE_PARENT,
  1392. },
  1393. },
  1394. };
  1395. static struct clk_branch mdss_dp_crypto_clk = {
  1396. .halt_reg = 0x235c,
  1397. .clkr = {
  1398. .enable_reg = 0x235c,
  1399. .enable_mask = BIT(0),
  1400. .hw.init = &(struct clk_init_data){
  1401. .name = "mdss_dp_crypto_clk",
  1402. .parent_hws = (const struct clk_hw *[]){ &dp_crypto_clk_src.clkr.hw },
  1403. .num_parents = 1,
  1404. .ops = &clk_branch2_ops,
  1405. .flags = CLK_SET_RATE_PARENT,
  1406. },
  1407. },
  1408. };
  1409. static struct clk_branch mdss_dp_pixel_clk = {
  1410. .halt_reg = 0x2360,
  1411. .clkr = {
  1412. .enable_reg = 0x2360,
  1413. .enable_mask = BIT(0),
  1414. .hw.init = &(struct clk_init_data){
  1415. .name = "mdss_dp_pixel_clk",
  1416. .parent_hws = (const struct clk_hw *[]){ &dp_pixel_clk_src.clkr.hw },
  1417. .num_parents = 1,
  1418. .ops = &clk_branch2_ops,
  1419. .flags = CLK_SET_RATE_PARENT,
  1420. },
  1421. },
  1422. };
  1423. static struct clk_branch mdss_dp_aux_clk = {
  1424. .halt_reg = 0x2364,
  1425. .clkr = {
  1426. .enable_reg = 0x2364,
  1427. .enable_mask = BIT(0),
  1428. .hw.init = &(struct clk_init_data){
  1429. .name = "mdss_dp_aux_clk",
  1430. .parent_hws = (const struct clk_hw *[]){ &dp_aux_clk_src.clkr.hw },
  1431. .num_parents = 1,
  1432. .ops = &clk_branch2_ops,
  1433. .flags = CLK_SET_RATE_PARENT,
  1434. },
  1435. },
  1436. };
  1437. static struct clk_branch mdss_byte0_intf_clk = {
  1438. .halt_reg = 0x2374,
  1439. .clkr = {
  1440. .enable_reg = 0x2374,
  1441. .enable_mask = BIT(0),
  1442. .hw.init = &(struct clk_init_data){
  1443. .name = "mdss_byte0_intf_clk",
  1444. .parent_hws = (const struct clk_hw *[]){ &byte0_clk_src.clkr.hw },
  1445. .num_parents = 1,
  1446. .ops = &clk_branch2_ops,
  1447. .flags = CLK_SET_RATE_PARENT,
  1448. },
  1449. },
  1450. };
  1451. static struct clk_branch mdss_byte1_intf_clk = {
  1452. .halt_reg = 0x2378,
  1453. .clkr = {
  1454. .enable_reg = 0x2378,
  1455. .enable_mask = BIT(0),
  1456. .hw.init = &(struct clk_init_data){
  1457. .name = "mdss_byte1_intf_clk",
  1458. .parent_hws = (const struct clk_hw *[]){ &byte1_clk_src.clkr.hw },
  1459. .num_parents = 1,
  1460. .ops = &clk_branch2_ops,
  1461. .flags = CLK_SET_RATE_PARENT,
  1462. },
  1463. },
  1464. };
  1465. static struct clk_branch camss_csi0phytimer_clk = {
  1466. .halt_reg = 0x3024,
  1467. .clkr = {
  1468. .enable_reg = 0x3024,
  1469. .enable_mask = BIT(0),
  1470. .hw.init = &(struct clk_init_data){
  1471. .name = "camss_csi0phytimer_clk",
  1472. .parent_hws = (const struct clk_hw *[]){ &csi0phytimer_clk_src.clkr.hw },
  1473. .num_parents = 1,
  1474. .ops = &clk_branch2_ops,
  1475. .flags = CLK_SET_RATE_PARENT,
  1476. },
  1477. },
  1478. };
  1479. static struct clk_branch camss_csi1phytimer_clk = {
  1480. .halt_reg = 0x3054,
  1481. .clkr = {
  1482. .enable_reg = 0x3054,
  1483. .enable_mask = BIT(0),
  1484. .hw.init = &(struct clk_init_data){
  1485. .name = "camss_csi1phytimer_clk",
  1486. .parent_hws = (const struct clk_hw *[]){ &csi1phytimer_clk_src.clkr.hw },
  1487. .num_parents = 1,
  1488. .ops = &clk_branch2_ops,
  1489. .flags = CLK_SET_RATE_PARENT,
  1490. },
  1491. },
  1492. };
  1493. static struct clk_branch camss_csi2phytimer_clk = {
  1494. .halt_reg = 0x3084,
  1495. .clkr = {
  1496. .enable_reg = 0x3084,
  1497. .enable_mask = BIT(0),
  1498. .hw.init = &(struct clk_init_data){
  1499. .name = "camss_csi2phytimer_clk",
  1500. .parent_hws = (const struct clk_hw *[]){ &csi2phytimer_clk_src.clkr.hw },
  1501. .num_parents = 1,
  1502. .ops = &clk_branch2_ops,
  1503. .flags = CLK_SET_RATE_PARENT,
  1504. },
  1505. },
  1506. };
  1507. static struct clk_branch camss_csi0_clk = {
  1508. .halt_reg = 0x30b4,
  1509. .clkr = {
  1510. .enable_reg = 0x30b4,
  1511. .enable_mask = BIT(0),
  1512. .hw.init = &(struct clk_init_data){
  1513. .name = "camss_csi0_clk",
  1514. .parent_hws = (const struct clk_hw *[]){ &csi0_clk_src.clkr.hw },
  1515. .num_parents = 1,
  1516. .ops = &clk_branch2_ops,
  1517. .flags = CLK_SET_RATE_PARENT,
  1518. },
  1519. },
  1520. };
  1521. static struct clk_branch camss_csi0_ahb_clk = {
  1522. .halt_reg = 0x30bc,
  1523. .clkr = {
  1524. .enable_reg = 0x30bc,
  1525. .enable_mask = BIT(0),
  1526. .hw.init = &(struct clk_init_data){
  1527. .name = "camss_csi0_ahb_clk",
  1528. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1529. .num_parents = 1,
  1530. .ops = &clk_branch2_ops,
  1531. .flags = CLK_SET_RATE_PARENT,
  1532. },
  1533. },
  1534. };
  1535. static struct clk_branch camss_csi0rdi_clk = {
  1536. .halt_reg = 0x30d4,
  1537. .clkr = {
  1538. .enable_reg = 0x30d4,
  1539. .enable_mask = BIT(0),
  1540. .hw.init = &(struct clk_init_data){
  1541. .name = "camss_csi0rdi_clk",
  1542. .parent_hws = (const struct clk_hw *[]){ &csi0_clk_src.clkr.hw },
  1543. .num_parents = 1,
  1544. .ops = &clk_branch2_ops,
  1545. .flags = CLK_SET_RATE_PARENT,
  1546. },
  1547. },
  1548. };
  1549. static struct clk_branch camss_csi0pix_clk = {
  1550. .halt_reg = 0x30e4,
  1551. .clkr = {
  1552. .enable_reg = 0x30e4,
  1553. .enable_mask = BIT(0),
  1554. .hw.init = &(struct clk_init_data){
  1555. .name = "camss_csi0pix_clk",
  1556. .parent_hws = (const struct clk_hw *[]){ &csi0_clk_src.clkr.hw },
  1557. .num_parents = 1,
  1558. .ops = &clk_branch2_ops,
  1559. .flags = CLK_SET_RATE_PARENT,
  1560. },
  1561. },
  1562. };
  1563. static struct clk_branch camss_csi1_clk = {
  1564. .halt_reg = 0x3124,
  1565. .clkr = {
  1566. .enable_reg = 0x3124,
  1567. .enable_mask = BIT(0),
  1568. .hw.init = &(struct clk_init_data){
  1569. .name = "camss_csi1_clk",
  1570. .parent_hws = (const struct clk_hw *[]){ &csi1_clk_src.clkr.hw },
  1571. .num_parents = 1,
  1572. .ops = &clk_branch2_ops,
  1573. .flags = CLK_SET_RATE_PARENT,
  1574. },
  1575. },
  1576. };
  1577. static struct clk_branch camss_csi1_ahb_clk = {
  1578. .halt_reg = 0x3128,
  1579. .clkr = {
  1580. .enable_reg = 0x3128,
  1581. .enable_mask = BIT(0),
  1582. .hw.init = &(struct clk_init_data){
  1583. .name = "camss_csi1_ahb_clk",
  1584. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1585. .num_parents = 1,
  1586. .ops = &clk_branch2_ops,
  1587. .flags = CLK_SET_RATE_PARENT,
  1588. },
  1589. },
  1590. };
  1591. static struct clk_branch camss_csi1rdi_clk = {
  1592. .halt_reg = 0x3144,
  1593. .clkr = {
  1594. .enable_reg = 0x3144,
  1595. .enable_mask = BIT(0),
  1596. .hw.init = &(struct clk_init_data){
  1597. .name = "camss_csi1rdi_clk",
  1598. .parent_hws = (const struct clk_hw *[]){ &csi1_clk_src.clkr.hw },
  1599. .num_parents = 1,
  1600. .ops = &clk_branch2_ops,
  1601. .flags = CLK_SET_RATE_PARENT,
  1602. },
  1603. },
  1604. };
  1605. static struct clk_branch camss_csi1pix_clk = {
  1606. .halt_reg = 0x3154,
  1607. .clkr = {
  1608. .enable_reg = 0x3154,
  1609. .enable_mask = BIT(0),
  1610. .hw.init = &(struct clk_init_data){
  1611. .name = "camss_csi1pix_clk",
  1612. .parent_hws = (const struct clk_hw *[]){ &csi1_clk_src.clkr.hw },
  1613. .num_parents = 1,
  1614. .ops = &clk_branch2_ops,
  1615. .flags = CLK_SET_RATE_PARENT,
  1616. },
  1617. },
  1618. };
  1619. static struct clk_branch camss_csi2_clk = {
  1620. .halt_reg = 0x3184,
  1621. .clkr = {
  1622. .enable_reg = 0x3184,
  1623. .enable_mask = BIT(0),
  1624. .hw.init = &(struct clk_init_data){
  1625. .name = "camss_csi2_clk",
  1626. .parent_hws = (const struct clk_hw *[]){ &csi2_clk_src.clkr.hw },
  1627. .num_parents = 1,
  1628. .ops = &clk_branch2_ops,
  1629. .flags = CLK_SET_RATE_PARENT,
  1630. },
  1631. },
  1632. };
  1633. static struct clk_branch camss_csi2_ahb_clk = {
  1634. .halt_reg = 0x3188,
  1635. .clkr = {
  1636. .enable_reg = 0x3188,
  1637. .enable_mask = BIT(0),
  1638. .hw.init = &(struct clk_init_data){
  1639. .name = "camss_csi2_ahb_clk",
  1640. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1641. .num_parents = 1,
  1642. .ops = &clk_branch2_ops,
  1643. .flags = CLK_SET_RATE_PARENT,
  1644. },
  1645. },
  1646. };
  1647. static struct clk_branch camss_csi2rdi_clk = {
  1648. .halt_reg = 0x31a4,
  1649. .clkr = {
  1650. .enable_reg = 0x31a4,
  1651. .enable_mask = BIT(0),
  1652. .hw.init = &(struct clk_init_data){
  1653. .name = "camss_csi2rdi_clk",
  1654. .parent_hws = (const struct clk_hw *[]){ &csi2_clk_src.clkr.hw },
  1655. .num_parents = 1,
  1656. .ops = &clk_branch2_ops,
  1657. .flags = CLK_SET_RATE_PARENT,
  1658. },
  1659. },
  1660. };
  1661. static struct clk_branch camss_csi2pix_clk = {
  1662. .halt_reg = 0x31b4,
  1663. .clkr = {
  1664. .enable_reg = 0x31b4,
  1665. .enable_mask = BIT(0),
  1666. .hw.init = &(struct clk_init_data){
  1667. .name = "camss_csi2pix_clk",
  1668. .parent_hws = (const struct clk_hw *[]){ &csi2_clk_src.clkr.hw },
  1669. .num_parents = 1,
  1670. .ops = &clk_branch2_ops,
  1671. .flags = CLK_SET_RATE_PARENT,
  1672. },
  1673. },
  1674. };
  1675. static struct clk_branch camss_csi3_clk = {
  1676. .halt_reg = 0x31e4,
  1677. .clkr = {
  1678. .enable_reg = 0x31e4,
  1679. .enable_mask = BIT(0),
  1680. .hw.init = &(struct clk_init_data){
  1681. .name = "camss_csi3_clk",
  1682. .parent_hws = (const struct clk_hw *[]){ &csi3_clk_src.clkr.hw },
  1683. .num_parents = 1,
  1684. .ops = &clk_branch2_ops,
  1685. .flags = CLK_SET_RATE_PARENT,
  1686. },
  1687. },
  1688. };
  1689. static struct clk_branch camss_csi3_ahb_clk = {
  1690. .halt_reg = 0x31e8,
  1691. .clkr = {
  1692. .enable_reg = 0x31e8,
  1693. .enable_mask = BIT(0),
  1694. .hw.init = &(struct clk_init_data){
  1695. .name = "camss_csi3_ahb_clk",
  1696. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1697. .num_parents = 1,
  1698. .ops = &clk_branch2_ops,
  1699. .flags = CLK_SET_RATE_PARENT,
  1700. },
  1701. },
  1702. };
  1703. static struct clk_branch camss_csi3rdi_clk = {
  1704. .halt_reg = 0x3204,
  1705. .clkr = {
  1706. .enable_reg = 0x3204,
  1707. .enable_mask = BIT(0),
  1708. .hw.init = &(struct clk_init_data){
  1709. .name = "camss_csi3rdi_clk",
  1710. .parent_hws = (const struct clk_hw *[]){ &csi3_clk_src.clkr.hw },
  1711. .num_parents = 1,
  1712. .ops = &clk_branch2_ops,
  1713. .flags = CLK_SET_RATE_PARENT,
  1714. },
  1715. },
  1716. };
  1717. static struct clk_branch camss_csi3pix_clk = {
  1718. .halt_reg = 0x3214,
  1719. .clkr = {
  1720. .enable_reg = 0x3214,
  1721. .enable_mask = BIT(0),
  1722. .hw.init = &(struct clk_init_data){
  1723. .name = "camss_csi3pix_clk",
  1724. .parent_hws = (const struct clk_hw *[]){ &csi3_clk_src.clkr.hw },
  1725. .num_parents = 1,
  1726. .ops = &clk_branch2_ops,
  1727. .flags = CLK_SET_RATE_PARENT,
  1728. },
  1729. },
  1730. };
  1731. static struct clk_branch camss_ispif_ahb_clk = {
  1732. .halt_reg = 0x3224,
  1733. .clkr = {
  1734. .enable_reg = 0x3224,
  1735. .enable_mask = BIT(0),
  1736. .hw.init = &(struct clk_init_data){
  1737. .name = "camss_ispif_ahb_clk",
  1738. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1739. .num_parents = 1,
  1740. .ops = &clk_branch2_ops,
  1741. .flags = CLK_SET_RATE_PARENT,
  1742. },
  1743. },
  1744. };
  1745. static struct clk_branch camss_cci_clk = {
  1746. .halt_reg = 0x3344,
  1747. .clkr = {
  1748. .enable_reg = 0x3344,
  1749. .enable_mask = BIT(0),
  1750. .hw.init = &(struct clk_init_data){
  1751. .name = "camss_cci_clk",
  1752. .parent_hws = (const struct clk_hw *[]){ &cci_clk_src.clkr.hw },
  1753. .num_parents = 1,
  1754. .ops = &clk_branch2_ops,
  1755. .flags = CLK_SET_RATE_PARENT,
  1756. },
  1757. },
  1758. };
  1759. static struct clk_branch camss_cci_ahb_clk = {
  1760. .halt_reg = 0x3348,
  1761. .clkr = {
  1762. .enable_reg = 0x3348,
  1763. .enable_mask = BIT(0),
  1764. .hw.init = &(struct clk_init_data){
  1765. .name = "camss_cci_ahb_clk",
  1766. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1767. .num_parents = 1,
  1768. .ops = &clk_branch2_ops,
  1769. .flags = CLK_SET_RATE_PARENT,
  1770. },
  1771. },
  1772. };
  1773. static struct clk_branch camss_mclk0_clk = {
  1774. .halt_reg = 0x3384,
  1775. .clkr = {
  1776. .enable_reg = 0x3384,
  1777. .enable_mask = BIT(0),
  1778. .hw.init = &(struct clk_init_data){
  1779. .name = "camss_mclk0_clk",
  1780. .parent_hws = (const struct clk_hw *[]){ &mclk0_clk_src.clkr.hw },
  1781. .num_parents = 1,
  1782. .ops = &clk_branch2_ops,
  1783. .flags = CLK_SET_RATE_PARENT,
  1784. },
  1785. },
  1786. };
  1787. static struct clk_branch camss_mclk1_clk = {
  1788. .halt_reg = 0x33b4,
  1789. .clkr = {
  1790. .enable_reg = 0x33b4,
  1791. .enable_mask = BIT(0),
  1792. .hw.init = &(struct clk_init_data){
  1793. .name = "camss_mclk1_clk",
  1794. .parent_hws = (const struct clk_hw *[]){ &mclk1_clk_src.clkr.hw },
  1795. .num_parents = 1,
  1796. .ops = &clk_branch2_ops,
  1797. .flags = CLK_SET_RATE_PARENT,
  1798. },
  1799. },
  1800. };
  1801. static struct clk_branch camss_mclk2_clk = {
  1802. .halt_reg = 0x33e4,
  1803. .clkr = {
  1804. .enable_reg = 0x33e4,
  1805. .enable_mask = BIT(0),
  1806. .hw.init = &(struct clk_init_data){
  1807. .name = "camss_mclk2_clk",
  1808. .parent_hws = (const struct clk_hw *[]){ &mclk2_clk_src.clkr.hw },
  1809. .num_parents = 1,
  1810. .ops = &clk_branch2_ops,
  1811. .flags = CLK_SET_RATE_PARENT,
  1812. },
  1813. },
  1814. };
  1815. static struct clk_branch camss_mclk3_clk = {
  1816. .halt_reg = 0x3414,
  1817. .clkr = {
  1818. .enable_reg = 0x3414,
  1819. .enable_mask = BIT(0),
  1820. .hw.init = &(struct clk_init_data){
  1821. .name = "camss_mclk3_clk",
  1822. .parent_hws = (const struct clk_hw *[]){ &mclk3_clk_src.clkr.hw },
  1823. .num_parents = 1,
  1824. .ops = &clk_branch2_ops,
  1825. .flags = CLK_SET_RATE_PARENT,
  1826. },
  1827. },
  1828. };
  1829. static struct clk_branch camss_top_ahb_clk = {
  1830. .halt_reg = 0x3484,
  1831. .clkr = {
  1832. .enable_reg = 0x3484,
  1833. .enable_mask = BIT(0),
  1834. .hw.init = &(struct clk_init_data){
  1835. .name = "camss_top_ahb_clk",
  1836. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1837. .num_parents = 1,
  1838. .ops = &clk_branch2_ops,
  1839. .flags = CLK_SET_RATE_PARENT,
  1840. },
  1841. },
  1842. };
  1843. static struct clk_branch camss_ahb_clk = {
  1844. .halt_reg = 0x348c,
  1845. .clkr = {
  1846. .enable_reg = 0x348c,
  1847. .enable_mask = BIT(0),
  1848. .hw.init = &(struct clk_init_data){
  1849. .name = "camss_ahb_clk",
  1850. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1851. .num_parents = 1,
  1852. .ops = &clk_branch2_ops,
  1853. .flags = CLK_SET_RATE_PARENT,
  1854. },
  1855. },
  1856. };
  1857. static struct clk_branch camss_micro_ahb_clk = {
  1858. .halt_reg = 0x3494,
  1859. .clkr = {
  1860. .enable_reg = 0x3494,
  1861. .enable_mask = BIT(0),
  1862. .hw.init = &(struct clk_init_data){
  1863. .name = "camss_micro_ahb_clk",
  1864. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1865. .num_parents = 1,
  1866. .ops = &clk_branch2_ops,
  1867. .flags = CLK_SET_RATE_PARENT,
  1868. },
  1869. },
  1870. };
  1871. static struct clk_branch camss_jpeg0_clk = {
  1872. .halt_reg = 0x35a8,
  1873. .clkr = {
  1874. .enable_reg = 0x35a8,
  1875. .enable_mask = BIT(0),
  1876. .hw.init = &(struct clk_init_data){
  1877. .name = "camss_jpeg0_clk",
  1878. .parent_hws = (const struct clk_hw *[]){ &jpeg0_clk_src.clkr.hw },
  1879. .num_parents = 1,
  1880. .ops = &clk_branch2_ops,
  1881. .flags = CLK_SET_RATE_PARENT,
  1882. },
  1883. },
  1884. };
  1885. static struct clk_branch camss_jpeg_ahb_clk = {
  1886. .halt_reg = 0x35b4,
  1887. .clkr = {
  1888. .enable_reg = 0x35b4,
  1889. .enable_mask = BIT(0),
  1890. .hw.init = &(struct clk_init_data){
  1891. .name = "camss_jpeg_ahb_clk",
  1892. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1893. .num_parents = 1,
  1894. .ops = &clk_branch2_ops,
  1895. .flags = CLK_SET_RATE_PARENT,
  1896. },
  1897. },
  1898. };
  1899. static struct clk_branch camss_jpeg_axi_clk = {
  1900. .halt_reg = 0x35b8,
  1901. .clkr = {
  1902. .enable_reg = 0x35b8,
  1903. .enable_mask = BIT(0),
  1904. .hw.init = &(struct clk_init_data){
  1905. .name = "camss_jpeg_axi_clk",
  1906. .parent_hws = (const struct clk_hw *[]){ &axi_clk_src.clkr.hw },
  1907. .num_parents = 1,
  1908. .ops = &clk_branch2_ops,
  1909. },
  1910. },
  1911. };
  1912. static struct clk_branch camss_vfe0_ahb_clk = {
  1913. .halt_reg = 0x3668,
  1914. .clkr = {
  1915. .enable_reg = 0x3668,
  1916. .enable_mask = BIT(0),
  1917. .hw.init = &(struct clk_init_data){
  1918. .name = "camss_vfe0_ahb_clk",
  1919. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1920. .num_parents = 1,
  1921. .ops = &clk_branch2_ops,
  1922. .flags = CLK_SET_RATE_PARENT,
  1923. },
  1924. },
  1925. };
  1926. static struct clk_branch camss_vfe1_ahb_clk = {
  1927. .halt_reg = 0x3678,
  1928. .clkr = {
  1929. .enable_reg = 0x3678,
  1930. .enable_mask = BIT(0),
  1931. .hw.init = &(struct clk_init_data){
  1932. .name = "camss_vfe1_ahb_clk",
  1933. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1934. .num_parents = 1,
  1935. .ops = &clk_branch2_ops,
  1936. .flags = CLK_SET_RATE_PARENT,
  1937. },
  1938. },
  1939. };
  1940. static struct clk_branch camss_vfe0_clk = {
  1941. .halt_reg = 0x36a8,
  1942. .clkr = {
  1943. .enable_reg = 0x36a8,
  1944. .enable_mask = BIT(0),
  1945. .hw.init = &(struct clk_init_data){
  1946. .name = "camss_vfe0_clk",
  1947. .parent_hws = (const struct clk_hw *[]){ &vfe0_clk_src.clkr.hw },
  1948. .num_parents = 1,
  1949. .ops = &clk_branch2_ops,
  1950. .flags = CLK_SET_RATE_PARENT,
  1951. },
  1952. },
  1953. };
  1954. static struct clk_branch camss_vfe1_clk = {
  1955. .halt_reg = 0x36ac,
  1956. .clkr = {
  1957. .enable_reg = 0x36ac,
  1958. .enable_mask = BIT(0),
  1959. .hw.init = &(struct clk_init_data){
  1960. .name = "camss_vfe1_clk",
  1961. .parent_hws = (const struct clk_hw *[]){ &vfe1_clk_src.clkr.hw },
  1962. .num_parents = 1,
  1963. .ops = &clk_branch2_ops,
  1964. .flags = CLK_SET_RATE_PARENT,
  1965. },
  1966. },
  1967. };
  1968. static struct clk_branch camss_cpp_clk = {
  1969. .halt_reg = 0x36b0,
  1970. .clkr = {
  1971. .enable_reg = 0x36b0,
  1972. .enable_mask = BIT(0),
  1973. .hw.init = &(struct clk_init_data){
  1974. .name = "camss_cpp_clk",
  1975. .parent_hws = (const struct clk_hw *[]){ &cpp_clk_src.clkr.hw },
  1976. .num_parents = 1,
  1977. .ops = &clk_branch2_ops,
  1978. .flags = CLK_SET_RATE_PARENT,
  1979. },
  1980. },
  1981. };
  1982. static struct clk_branch camss_cpp_ahb_clk = {
  1983. .halt_reg = 0x36b4,
  1984. .clkr = {
  1985. .enable_reg = 0x36b4,
  1986. .enable_mask = BIT(0),
  1987. .hw.init = &(struct clk_init_data){
  1988. .name = "camss_cpp_ahb_clk",
  1989. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1990. .num_parents = 1,
  1991. .ops = &clk_branch2_ops,
  1992. .flags = CLK_SET_RATE_PARENT,
  1993. },
  1994. },
  1995. };
  1996. static struct clk_branch camss_vfe_vbif_ahb_clk = {
  1997. .halt_reg = 0x36b8,
  1998. .clkr = {
  1999. .enable_reg = 0x36b8,
  2000. .enable_mask = BIT(0),
  2001. .hw.init = &(struct clk_init_data){
  2002. .name = "camss_vfe_vbif_ahb_clk",
  2003. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  2004. .num_parents = 1,
  2005. .ops = &clk_branch2_ops,
  2006. .flags = CLK_SET_RATE_PARENT,
  2007. },
  2008. },
  2009. };
  2010. static struct clk_branch camss_vfe_vbif_axi_clk = {
  2011. .halt_reg = 0x36bc,
  2012. .clkr = {
  2013. .enable_reg = 0x36bc,
  2014. .enable_mask = BIT(0),
  2015. .hw.init = &(struct clk_init_data){
  2016. .name = "camss_vfe_vbif_axi_clk",
  2017. .parent_hws = (const struct clk_hw *[]){ &axi_clk_src.clkr.hw },
  2018. .num_parents = 1,
  2019. .ops = &clk_branch2_ops,
  2020. },
  2021. },
  2022. };
  2023. static struct clk_branch camss_cpp_axi_clk = {
  2024. .halt_reg = 0x36c4,
  2025. .clkr = {
  2026. .enable_reg = 0x36c4,
  2027. .enable_mask = BIT(0),
  2028. .hw.init = &(struct clk_init_data){
  2029. .name = "camss_cpp_axi_clk",
  2030. .parent_hws = (const struct clk_hw *[]){ &axi_clk_src.clkr.hw },
  2031. .num_parents = 1,
  2032. .ops = &clk_branch2_ops,
  2033. },
  2034. },
  2035. };
  2036. static struct clk_branch camss_cpp_vbif_ahb_clk = {
  2037. .halt_reg = 0x36c8,
  2038. .clkr = {
  2039. .enable_reg = 0x36c8,
  2040. .enable_mask = BIT(0),
  2041. .hw.init = &(struct clk_init_data){
  2042. .name = "camss_cpp_vbif_ahb_clk",
  2043. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  2044. .num_parents = 1,
  2045. .ops = &clk_branch2_ops,
  2046. .flags = CLK_SET_RATE_PARENT,
  2047. },
  2048. },
  2049. };
  2050. static struct clk_branch camss_csi_vfe0_clk = {
  2051. .halt_reg = 0x3704,
  2052. .clkr = {
  2053. .enable_reg = 0x3704,
  2054. .enable_mask = BIT(0),
  2055. .hw.init = &(struct clk_init_data){
  2056. .name = "camss_csi_vfe0_clk",
  2057. .parent_hws = (const struct clk_hw *[]){ &vfe0_clk_src.clkr.hw },
  2058. .num_parents = 1,
  2059. .ops = &clk_branch2_ops,
  2060. .flags = CLK_SET_RATE_PARENT,
  2061. },
  2062. },
  2063. };
  2064. static struct clk_branch camss_csi_vfe1_clk = {
  2065. .halt_reg = 0x3714,
  2066. .clkr = {
  2067. .enable_reg = 0x3714,
  2068. .enable_mask = BIT(0),
  2069. .hw.init = &(struct clk_init_data){
  2070. .name = "camss_csi_vfe1_clk",
  2071. .parent_hws = (const struct clk_hw *[]){ &vfe1_clk_src.clkr.hw },
  2072. .num_parents = 1,
  2073. .ops = &clk_branch2_ops,
  2074. .flags = CLK_SET_RATE_PARENT,
  2075. },
  2076. },
  2077. };
  2078. static struct clk_branch camss_vfe0_stream_clk = {
  2079. .halt_reg = 0x3720,
  2080. .clkr = {
  2081. .enable_reg = 0x3720,
  2082. .enable_mask = BIT(0),
  2083. .hw.init = &(struct clk_init_data){
  2084. .name = "camss_vfe0_stream_clk",
  2085. .parent_hws = (const struct clk_hw *[]){ &vfe0_clk_src.clkr.hw },
  2086. .num_parents = 1,
  2087. .ops = &clk_branch2_ops,
  2088. .flags = CLK_SET_RATE_PARENT,
  2089. },
  2090. },
  2091. };
  2092. static struct clk_branch camss_vfe1_stream_clk = {
  2093. .halt_reg = 0x3724,
  2094. .clkr = {
  2095. .enable_reg = 0x3724,
  2096. .enable_mask = BIT(0),
  2097. .hw.init = &(struct clk_init_data){
  2098. .name = "camss_vfe1_stream_clk",
  2099. .parent_hws = (const struct clk_hw *[]){ &vfe1_clk_src.clkr.hw },
  2100. .num_parents = 1,
  2101. .ops = &clk_branch2_ops,
  2102. .flags = CLK_SET_RATE_PARENT,
  2103. },
  2104. },
  2105. };
  2106. static struct clk_branch camss_cphy_csid0_clk = {
  2107. .halt_reg = 0x3730,
  2108. .clkr = {
  2109. .enable_reg = 0x3730,
  2110. .enable_mask = BIT(0),
  2111. .hw.init = &(struct clk_init_data){
  2112. .name = "camss_cphy_csid0_clk",
  2113. .parent_hws = (const struct clk_hw *[]){ &csiphy_clk_src.clkr.hw },
  2114. .num_parents = 1,
  2115. .ops = &clk_branch2_ops,
  2116. .flags = CLK_SET_RATE_PARENT,
  2117. },
  2118. },
  2119. };
  2120. static struct clk_branch camss_cphy_csid1_clk = {
  2121. .halt_reg = 0x3734,
  2122. .clkr = {
  2123. .enable_reg = 0x3734,
  2124. .enable_mask = BIT(0),
  2125. .hw.init = &(struct clk_init_data){
  2126. .name = "camss_cphy_csid1_clk",
  2127. .parent_hws = (const struct clk_hw *[]){ &csiphy_clk_src.clkr.hw },
  2128. .num_parents = 1,
  2129. .ops = &clk_branch2_ops,
  2130. .flags = CLK_SET_RATE_PARENT,
  2131. },
  2132. },
  2133. };
  2134. static struct clk_branch camss_cphy_csid2_clk = {
  2135. .halt_reg = 0x3738,
  2136. .clkr = {
  2137. .enable_reg = 0x3738,
  2138. .enable_mask = BIT(0),
  2139. .hw.init = &(struct clk_init_data){
  2140. .name = "camss_cphy_csid2_clk",
  2141. .parent_hws = (const struct clk_hw *[]){ &csiphy_clk_src.clkr.hw },
  2142. .num_parents = 1,
  2143. .ops = &clk_branch2_ops,
  2144. .flags = CLK_SET_RATE_PARENT,
  2145. },
  2146. },
  2147. };
  2148. static struct clk_branch camss_cphy_csid3_clk = {
  2149. .halt_reg = 0x373c,
  2150. .clkr = {
  2151. .enable_reg = 0x373c,
  2152. .enable_mask = BIT(0),
  2153. .hw.init = &(struct clk_init_data){
  2154. .name = "camss_cphy_csid3_clk",
  2155. .parent_hws = (const struct clk_hw *[]){ &csiphy_clk_src.clkr.hw },
  2156. .num_parents = 1,
  2157. .ops = &clk_branch2_ops,
  2158. .flags = CLK_SET_RATE_PARENT,
  2159. },
  2160. },
  2161. };
  2162. static struct clk_branch camss_csiphy0_clk = {
  2163. .halt_reg = 0x3740,
  2164. .clkr = {
  2165. .enable_reg = 0x3740,
  2166. .enable_mask = BIT(0),
  2167. .hw.init = &(struct clk_init_data){
  2168. .name = "camss_csiphy0_clk",
  2169. .parent_hws = (const struct clk_hw *[]){ &csiphy_clk_src.clkr.hw },
  2170. .num_parents = 1,
  2171. .ops = &clk_branch2_ops,
  2172. .flags = CLK_SET_RATE_PARENT,
  2173. },
  2174. },
  2175. };
  2176. static struct clk_branch camss_csiphy1_clk = {
  2177. .halt_reg = 0x3744,
  2178. .clkr = {
  2179. .enable_reg = 0x3744,
  2180. .enable_mask = BIT(0),
  2181. .hw.init = &(struct clk_init_data){
  2182. .name = "camss_csiphy1_clk",
  2183. .parent_hws = (const struct clk_hw *[]){ &csiphy_clk_src.clkr.hw },
  2184. .num_parents = 1,
  2185. .ops = &clk_branch2_ops,
  2186. .flags = CLK_SET_RATE_PARENT,
  2187. },
  2188. },
  2189. };
  2190. static struct clk_branch camss_csiphy2_clk = {
  2191. .halt_reg = 0x3748,
  2192. .clkr = {
  2193. .enable_reg = 0x3748,
  2194. .enable_mask = BIT(0),
  2195. .hw.init = &(struct clk_init_data){
  2196. .name = "camss_csiphy2_clk",
  2197. .parent_hws = (const struct clk_hw *[]){ &csiphy_clk_src.clkr.hw },
  2198. .num_parents = 1,
  2199. .ops = &clk_branch2_ops,
  2200. .flags = CLK_SET_RATE_PARENT,
  2201. },
  2202. },
  2203. };
  2204. static struct clk_branch fd_core_clk = {
  2205. .halt_reg = 0x3b68,
  2206. .clkr = {
  2207. .enable_reg = 0x3b68,
  2208. .enable_mask = BIT(0),
  2209. .hw.init = &(struct clk_init_data){
  2210. .name = "fd_core_clk",
  2211. .parent_hws = (const struct clk_hw *[]){ &fd_core_clk_src.clkr.hw },
  2212. .num_parents = 1,
  2213. .ops = &clk_branch2_ops,
  2214. .flags = CLK_SET_RATE_PARENT,
  2215. },
  2216. },
  2217. };
  2218. static struct clk_branch fd_core_uar_clk = {
  2219. .halt_reg = 0x3b6c,
  2220. .clkr = {
  2221. .enable_reg = 0x3b6c,
  2222. .enable_mask = BIT(0),
  2223. .hw.init = &(struct clk_init_data){
  2224. .name = "fd_core_uar_clk",
  2225. .parent_hws = (const struct clk_hw *[]){ &fd_core_clk_src.clkr.hw },
  2226. .num_parents = 1,
  2227. .ops = &clk_branch2_ops,
  2228. .flags = CLK_SET_RATE_PARENT,
  2229. },
  2230. },
  2231. };
  2232. static struct clk_branch fd_ahb_clk = {
  2233. .halt_reg = 0x3b74,
  2234. .clkr = {
  2235. .enable_reg = 0x3b74,
  2236. .enable_mask = BIT(0),
  2237. .hw.init = &(struct clk_init_data){
  2238. .name = "fd_ahb_clk",
  2239. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  2240. .num_parents = 1,
  2241. .ops = &clk_branch2_ops,
  2242. .flags = CLK_SET_RATE_PARENT,
  2243. },
  2244. },
  2245. };
  2246. static struct clk_branch mnoc_ahb_clk = {
  2247. .halt_reg = 0x5024,
  2248. .halt_check = BRANCH_HALT_SKIP,
  2249. .clkr = {
  2250. .enable_reg = 0x5024,
  2251. .enable_mask = BIT(0),
  2252. .hw.init = &(struct clk_init_data){
  2253. .name = "mnoc_ahb_clk",
  2254. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  2255. .num_parents = 1,
  2256. .ops = &clk_branch2_ops,
  2257. .flags = CLK_SET_RATE_PARENT,
  2258. },
  2259. },
  2260. };
  2261. static struct clk_branch bimc_smmu_ahb_clk = {
  2262. .halt_reg = 0xe004,
  2263. .halt_check = BRANCH_HALT_SKIP,
  2264. .hwcg_reg = 0xe004,
  2265. .hwcg_bit = 1,
  2266. .clkr = {
  2267. .enable_reg = 0xe004,
  2268. .enable_mask = BIT(0),
  2269. .hw.init = &(struct clk_init_data){
  2270. .name = "bimc_smmu_ahb_clk",
  2271. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  2272. .num_parents = 1,
  2273. .ops = &clk_branch2_ops,
  2274. .flags = CLK_SET_RATE_PARENT,
  2275. },
  2276. },
  2277. };
  2278. static struct clk_branch bimc_smmu_axi_clk = {
  2279. .halt_reg = 0xe008,
  2280. .halt_check = BRANCH_HALT_SKIP,
  2281. .hwcg_reg = 0xe008,
  2282. .hwcg_bit = 1,
  2283. .clkr = {
  2284. .enable_reg = 0xe008,
  2285. .enable_mask = BIT(0),
  2286. .hw.init = &(struct clk_init_data){
  2287. .name = "bimc_smmu_axi_clk",
  2288. .parent_hws = (const struct clk_hw *[]){ &axi_clk_src.clkr.hw },
  2289. .num_parents = 1,
  2290. .ops = &clk_branch2_ops,
  2291. },
  2292. },
  2293. };
  2294. static struct clk_branch mnoc_maxi_clk = {
  2295. .halt_reg = 0xf004,
  2296. .clkr = {
  2297. .enable_reg = 0xf004,
  2298. .enable_mask = BIT(0),
  2299. .hw.init = &(struct clk_init_data){
  2300. .name = "mnoc_maxi_clk",
  2301. .parent_hws = (const struct clk_hw *[]){ &maxi_clk_src.clkr.hw },
  2302. .num_parents = 1,
  2303. .ops = &clk_branch2_ops,
  2304. .flags = CLK_SET_RATE_PARENT,
  2305. },
  2306. },
  2307. };
  2308. static struct clk_branch vmem_maxi_clk = {
  2309. .halt_reg = 0xf064,
  2310. .clkr = {
  2311. .enable_reg = 0xf064,
  2312. .enable_mask = BIT(0),
  2313. .hw.init = &(struct clk_init_data){
  2314. .name = "vmem_maxi_clk",
  2315. .parent_hws = (const struct clk_hw *[]){ &maxi_clk_src.clkr.hw },
  2316. .num_parents = 1,
  2317. .ops = &clk_branch2_ops,
  2318. .flags = CLK_SET_RATE_PARENT,
  2319. },
  2320. },
  2321. };
  2322. static struct clk_branch vmem_ahb_clk = {
  2323. .halt_reg = 0xf068,
  2324. .clkr = {
  2325. .enable_reg = 0xf068,
  2326. .enable_mask = BIT(0),
  2327. .hw.init = &(struct clk_init_data){
  2328. .name = "vmem_ahb_clk",
  2329. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  2330. .num_parents = 1,
  2331. .ops = &clk_branch2_ops,
  2332. .flags = CLK_SET_RATE_PARENT,
  2333. },
  2334. },
  2335. };
  2336. static struct gdsc video_top_gdsc = {
  2337. .gdscr = 0x1024,
  2338. .cxcs = (unsigned int []){ 0x1028, 0x1034, 0x1038 },
  2339. .cxc_count = 3,
  2340. .pd = {
  2341. .name = "video_top",
  2342. },
  2343. .pwrsts = PWRSTS_OFF_ON,
  2344. };
  2345. static struct gdsc video_subcore0_gdsc = {
  2346. .gdscr = 0x1040,
  2347. .cxcs = (unsigned int []){ 0x1048 },
  2348. .cxc_count = 1,
  2349. .pd = {
  2350. .name = "video_subcore0",
  2351. },
  2352. .parent = &video_top_gdsc.pd,
  2353. .pwrsts = PWRSTS_OFF_ON,
  2354. .flags = HW_CTRL,
  2355. };
  2356. static struct gdsc video_subcore1_gdsc = {
  2357. .gdscr = 0x1044,
  2358. .cxcs = (unsigned int []){ 0x104c },
  2359. .cxc_count = 1,
  2360. .pd = {
  2361. .name = "video_subcore1",
  2362. },
  2363. .parent = &video_top_gdsc.pd,
  2364. .pwrsts = PWRSTS_OFF_ON,
  2365. .flags = HW_CTRL,
  2366. };
  2367. static struct gdsc mdss_gdsc = {
  2368. .gdscr = 0x2304,
  2369. .cxcs = (unsigned int []){ 0x2310, 0x2350, 0x231c, 0x2320 },
  2370. .cxc_count = 4,
  2371. .pd = {
  2372. .name = "mdss",
  2373. },
  2374. .pwrsts = PWRSTS_OFF_ON,
  2375. };
  2376. static struct gdsc camss_top_gdsc = {
  2377. .gdscr = 0x34a0,
  2378. .cxcs = (unsigned int []){ 0x35b8, 0x36c4, 0x3704, 0x3714, 0x3494,
  2379. 0x35a8, 0x3868 },
  2380. .cxc_count = 7,
  2381. .pd = {
  2382. .name = "camss_top",
  2383. },
  2384. .pwrsts = PWRSTS_OFF_ON,
  2385. };
  2386. static struct gdsc camss_vfe0_gdsc = {
  2387. .gdscr = 0x3664,
  2388. .pd = {
  2389. .name = "camss_vfe0",
  2390. },
  2391. .parent = &camss_top_gdsc.pd,
  2392. .pwrsts = PWRSTS_OFF_ON,
  2393. };
  2394. static struct gdsc camss_vfe1_gdsc = {
  2395. .gdscr = 0x3674,
  2396. .pd = {
  2397. .name = "camss_vfe1_gdsc",
  2398. },
  2399. .parent = &camss_top_gdsc.pd,
  2400. .pwrsts = PWRSTS_OFF_ON,
  2401. };
  2402. static struct gdsc camss_cpp_gdsc = {
  2403. .gdscr = 0x36d4,
  2404. .pd = {
  2405. .name = "camss_cpp",
  2406. },
  2407. .parent = &camss_top_gdsc.pd,
  2408. .pwrsts = PWRSTS_OFF_ON,
  2409. };
  2410. static struct gdsc bimc_smmu_gdsc = {
  2411. .gdscr = 0xe020,
  2412. .gds_hw_ctrl = 0xe024,
  2413. .cxcs = (unsigned int []){ 0xe008 },
  2414. .cxc_count = 1,
  2415. .pd = {
  2416. .name = "bimc_smmu",
  2417. },
  2418. .pwrsts = PWRSTS_OFF_ON,
  2419. .flags = VOTABLE,
  2420. };
  2421. static struct clk_regmap *mmcc_msm8998_clocks[] = {
  2422. [MMPLL0] = &mmpll0.clkr,
  2423. [MMPLL0_OUT_EVEN] = &mmpll0_out_even.clkr,
  2424. [MMPLL1] = &mmpll1.clkr,
  2425. [MMPLL1_OUT_EVEN] = &mmpll1_out_even.clkr,
  2426. [MMPLL3] = &mmpll3.clkr,
  2427. [MMPLL3_OUT_EVEN] = &mmpll3_out_even.clkr,
  2428. [MMPLL4] = &mmpll4.clkr,
  2429. [MMPLL4_OUT_EVEN] = &mmpll4_out_even.clkr,
  2430. [MMPLL5] = &mmpll5.clkr,
  2431. [MMPLL5_OUT_EVEN] = &mmpll5_out_even.clkr,
  2432. [MMPLL6] = &mmpll6.clkr,
  2433. [MMPLL6_OUT_EVEN] = &mmpll6_out_even.clkr,
  2434. [MMPLL7] = &mmpll7.clkr,
  2435. [MMPLL7_OUT_EVEN] = &mmpll7_out_even.clkr,
  2436. [MMPLL10] = &mmpll10.clkr,
  2437. [MMPLL10_OUT_EVEN] = &mmpll10_out_even.clkr,
  2438. [BYTE0_CLK_SRC] = &byte0_clk_src.clkr,
  2439. [BYTE1_CLK_SRC] = &byte1_clk_src.clkr,
  2440. [CCI_CLK_SRC] = &cci_clk_src.clkr,
  2441. [CPP_CLK_SRC] = &cpp_clk_src.clkr,
  2442. [CSI0_CLK_SRC] = &csi0_clk_src.clkr,
  2443. [CSI1_CLK_SRC] = &csi1_clk_src.clkr,
  2444. [CSI2_CLK_SRC] = &csi2_clk_src.clkr,
  2445. [CSI3_CLK_SRC] = &csi3_clk_src.clkr,
  2446. [CSIPHY_CLK_SRC] = &csiphy_clk_src.clkr,
  2447. [CSI0PHYTIMER_CLK_SRC] = &csi0phytimer_clk_src.clkr,
  2448. [CSI1PHYTIMER_CLK_SRC] = &csi1phytimer_clk_src.clkr,
  2449. [CSI2PHYTIMER_CLK_SRC] = &csi2phytimer_clk_src.clkr,
  2450. [DP_AUX_CLK_SRC] = &dp_aux_clk_src.clkr,
  2451. [DP_CRYPTO_CLK_SRC] = &dp_crypto_clk_src.clkr,
  2452. [DP_LINK_CLK_SRC] = &dp_link_clk_src.clkr,
  2453. [DP_PIXEL_CLK_SRC] = &dp_pixel_clk_src.clkr,
  2454. [ESC0_CLK_SRC] = &esc0_clk_src.clkr,
  2455. [ESC1_CLK_SRC] = &esc1_clk_src.clkr,
  2456. [EXTPCLK_CLK_SRC] = &extpclk_clk_src.clkr,
  2457. [FD_CORE_CLK_SRC] = &fd_core_clk_src.clkr,
  2458. [HDMI_CLK_SRC] = &hdmi_clk_src.clkr,
  2459. [JPEG0_CLK_SRC] = &jpeg0_clk_src.clkr,
  2460. [MAXI_CLK_SRC] = &maxi_clk_src.clkr,
  2461. [MCLK0_CLK_SRC] = &mclk0_clk_src.clkr,
  2462. [MCLK1_CLK_SRC] = &mclk1_clk_src.clkr,
  2463. [MCLK2_CLK_SRC] = &mclk2_clk_src.clkr,
  2464. [MCLK3_CLK_SRC] = &mclk3_clk_src.clkr,
  2465. [MDP_CLK_SRC] = &mdp_clk_src.clkr,
  2466. [VSYNC_CLK_SRC] = &vsync_clk_src.clkr,
  2467. [AHB_CLK_SRC] = &ahb_clk_src.clkr,
  2468. [AXI_CLK_SRC] = &axi_clk_src.clkr,
  2469. [PCLK0_CLK_SRC] = &pclk0_clk_src.clkr,
  2470. [PCLK1_CLK_SRC] = &pclk1_clk_src.clkr,
  2471. [ROT_CLK_SRC] = &rot_clk_src.clkr,
  2472. [VIDEO_CORE_CLK_SRC] = &video_core_clk_src.clkr,
  2473. [VIDEO_SUBCORE0_CLK_SRC] = &video_subcore0_clk_src.clkr,
  2474. [VIDEO_SUBCORE1_CLK_SRC] = &video_subcore1_clk_src.clkr,
  2475. [VFE0_CLK_SRC] = &vfe0_clk_src.clkr,
  2476. [VFE1_CLK_SRC] = &vfe1_clk_src.clkr,
  2477. [MISC_AHB_CLK] = &misc_ahb_clk.clkr,
  2478. [VIDEO_CORE_CLK] = &video_core_clk.clkr,
  2479. [VIDEO_AHB_CLK] = &video_ahb_clk.clkr,
  2480. [VIDEO_AXI_CLK] = &video_axi_clk.clkr,
  2481. [VIDEO_MAXI_CLK] = &video_maxi_clk.clkr,
  2482. [VIDEO_SUBCORE0_CLK] = &video_subcore0_clk.clkr,
  2483. [VIDEO_SUBCORE1_CLK] = &video_subcore1_clk.clkr,
  2484. [MDSS_AHB_CLK] = &mdss_ahb_clk.clkr,
  2485. [MDSS_HDMI_DP_AHB_CLK] = &mdss_hdmi_dp_ahb_clk.clkr,
  2486. [MDSS_AXI_CLK] = &mdss_axi_clk.clkr,
  2487. [MDSS_PCLK0_CLK] = &mdss_pclk0_clk.clkr,
  2488. [MDSS_PCLK1_CLK] = &mdss_pclk1_clk.clkr,
  2489. [MDSS_MDP_CLK] = &mdss_mdp_clk.clkr,
  2490. [MDSS_MDP_LUT_CLK] = &mdss_mdp_lut_clk.clkr,
  2491. [MDSS_EXTPCLK_CLK] = &mdss_extpclk_clk.clkr,
  2492. [MDSS_VSYNC_CLK] = &mdss_vsync_clk.clkr,
  2493. [MDSS_HDMI_CLK] = &mdss_hdmi_clk.clkr,
  2494. [MDSS_BYTE0_CLK] = &mdss_byte0_clk.clkr,
  2495. [MDSS_BYTE1_CLK] = &mdss_byte1_clk.clkr,
  2496. [MDSS_ESC0_CLK] = &mdss_esc0_clk.clkr,
  2497. [MDSS_ESC1_CLK] = &mdss_esc1_clk.clkr,
  2498. [MDSS_ROT_CLK] = &mdss_rot_clk.clkr,
  2499. [MDSS_DP_LINK_CLK] = &mdss_dp_link_clk.clkr,
  2500. [MDSS_DP_LINK_INTF_CLK] = &mdss_dp_link_intf_clk.clkr,
  2501. [MDSS_DP_CRYPTO_CLK] = &mdss_dp_crypto_clk.clkr,
  2502. [MDSS_DP_PIXEL_CLK] = &mdss_dp_pixel_clk.clkr,
  2503. [MDSS_DP_AUX_CLK] = &mdss_dp_aux_clk.clkr,
  2504. [MDSS_BYTE0_INTF_CLK] = &mdss_byte0_intf_clk.clkr,
  2505. [MDSS_BYTE1_INTF_CLK] = &mdss_byte1_intf_clk.clkr,
  2506. [CAMSS_CSI0PHYTIMER_CLK] = &camss_csi0phytimer_clk.clkr,
  2507. [CAMSS_CSI1PHYTIMER_CLK] = &camss_csi1phytimer_clk.clkr,
  2508. [CAMSS_CSI2PHYTIMER_CLK] = &camss_csi2phytimer_clk.clkr,
  2509. [CAMSS_CSI0_CLK] = &camss_csi0_clk.clkr,
  2510. [CAMSS_CSI0_AHB_CLK] = &camss_csi0_ahb_clk.clkr,
  2511. [CAMSS_CSI0RDI_CLK] = &camss_csi0rdi_clk.clkr,
  2512. [CAMSS_CSI0PIX_CLK] = &camss_csi0pix_clk.clkr,
  2513. [CAMSS_CSI1_CLK] = &camss_csi1_clk.clkr,
  2514. [CAMSS_CSI1_AHB_CLK] = &camss_csi1_ahb_clk.clkr,
  2515. [CAMSS_CSI1RDI_CLK] = &camss_csi1rdi_clk.clkr,
  2516. [CAMSS_CSI1PIX_CLK] = &camss_csi1pix_clk.clkr,
  2517. [CAMSS_CSI2_CLK] = &camss_csi2_clk.clkr,
  2518. [CAMSS_CSI2_AHB_CLK] = &camss_csi2_ahb_clk.clkr,
  2519. [CAMSS_CSI2RDI_CLK] = &camss_csi2rdi_clk.clkr,
  2520. [CAMSS_CSI2PIX_CLK] = &camss_csi2pix_clk.clkr,
  2521. [CAMSS_CSI3_CLK] = &camss_csi3_clk.clkr,
  2522. [CAMSS_CSI3_AHB_CLK] = &camss_csi3_ahb_clk.clkr,
  2523. [CAMSS_CSI3RDI_CLK] = &camss_csi3rdi_clk.clkr,
  2524. [CAMSS_CSI3PIX_CLK] = &camss_csi3pix_clk.clkr,
  2525. [CAMSS_ISPIF_AHB_CLK] = &camss_ispif_ahb_clk.clkr,
  2526. [CAMSS_CCI_CLK] = &camss_cci_clk.clkr,
  2527. [CAMSS_CCI_AHB_CLK] = &camss_cci_ahb_clk.clkr,
  2528. [CAMSS_MCLK0_CLK] = &camss_mclk0_clk.clkr,
  2529. [CAMSS_MCLK1_CLK] = &camss_mclk1_clk.clkr,
  2530. [CAMSS_MCLK2_CLK] = &camss_mclk2_clk.clkr,
  2531. [CAMSS_MCLK3_CLK] = &camss_mclk3_clk.clkr,
  2532. [CAMSS_TOP_AHB_CLK] = &camss_top_ahb_clk.clkr,
  2533. [CAMSS_AHB_CLK] = &camss_ahb_clk.clkr,
  2534. [CAMSS_MICRO_AHB_CLK] = &camss_micro_ahb_clk.clkr,
  2535. [CAMSS_JPEG0_CLK] = &camss_jpeg0_clk.clkr,
  2536. [CAMSS_JPEG_AHB_CLK] = &camss_jpeg_ahb_clk.clkr,
  2537. [CAMSS_JPEG_AXI_CLK] = &camss_jpeg_axi_clk.clkr,
  2538. [CAMSS_VFE0_AHB_CLK] = &camss_vfe0_ahb_clk.clkr,
  2539. [CAMSS_VFE1_AHB_CLK] = &camss_vfe1_ahb_clk.clkr,
  2540. [CAMSS_VFE0_CLK] = &camss_vfe0_clk.clkr,
  2541. [CAMSS_VFE1_CLK] = &camss_vfe1_clk.clkr,
  2542. [CAMSS_CPP_CLK] = &camss_cpp_clk.clkr,
  2543. [CAMSS_CPP_AHB_CLK] = &camss_cpp_ahb_clk.clkr,
  2544. [CAMSS_VFE_VBIF_AHB_CLK] = &camss_vfe_vbif_ahb_clk.clkr,
  2545. [CAMSS_VFE_VBIF_AXI_CLK] = &camss_vfe_vbif_axi_clk.clkr,
  2546. [CAMSS_CPP_AXI_CLK] = &camss_cpp_axi_clk.clkr,
  2547. [CAMSS_CPP_VBIF_AHB_CLK] = &camss_cpp_vbif_ahb_clk.clkr,
  2548. [CAMSS_CSI_VFE0_CLK] = &camss_csi_vfe0_clk.clkr,
  2549. [CAMSS_CSI_VFE1_CLK] = &camss_csi_vfe1_clk.clkr,
  2550. [CAMSS_VFE0_STREAM_CLK] = &camss_vfe0_stream_clk.clkr,
  2551. [CAMSS_VFE1_STREAM_CLK] = &camss_vfe1_stream_clk.clkr,
  2552. [CAMSS_CPHY_CSID0_CLK] = &camss_cphy_csid0_clk.clkr,
  2553. [CAMSS_CPHY_CSID1_CLK] = &camss_cphy_csid1_clk.clkr,
  2554. [CAMSS_CPHY_CSID2_CLK] = &camss_cphy_csid2_clk.clkr,
  2555. [CAMSS_CPHY_CSID3_CLK] = &camss_cphy_csid3_clk.clkr,
  2556. [CAMSS_CSIPHY0_CLK] = &camss_csiphy0_clk.clkr,
  2557. [CAMSS_CSIPHY1_CLK] = &camss_csiphy1_clk.clkr,
  2558. [CAMSS_CSIPHY2_CLK] = &camss_csiphy2_clk.clkr,
  2559. [FD_CORE_CLK] = &fd_core_clk.clkr,
  2560. [FD_CORE_UAR_CLK] = &fd_core_uar_clk.clkr,
  2561. [FD_AHB_CLK] = &fd_ahb_clk.clkr,
  2562. [MNOC_AHB_CLK] = &mnoc_ahb_clk.clkr,
  2563. [BIMC_SMMU_AHB_CLK] = &bimc_smmu_ahb_clk.clkr,
  2564. [BIMC_SMMU_AXI_CLK] = &bimc_smmu_axi_clk.clkr,
  2565. [MNOC_MAXI_CLK] = &mnoc_maxi_clk.clkr,
  2566. [VMEM_MAXI_CLK] = &vmem_maxi_clk.clkr,
  2567. [VMEM_AHB_CLK] = &vmem_ahb_clk.clkr,
  2568. };
  2569. static struct gdsc *mmcc_msm8998_gdscs[] = {
  2570. [VIDEO_TOP_GDSC] = &video_top_gdsc,
  2571. [VIDEO_SUBCORE0_GDSC] = &video_subcore0_gdsc,
  2572. [VIDEO_SUBCORE1_GDSC] = &video_subcore1_gdsc,
  2573. [MDSS_GDSC] = &mdss_gdsc,
  2574. [CAMSS_TOP_GDSC] = &camss_top_gdsc,
  2575. [CAMSS_VFE0_GDSC] = &camss_vfe0_gdsc,
  2576. [CAMSS_VFE1_GDSC] = &camss_vfe1_gdsc,
  2577. [CAMSS_CPP_GDSC] = &camss_cpp_gdsc,
  2578. [BIMC_SMMU_GDSC] = &bimc_smmu_gdsc,
  2579. };
  2580. static const struct qcom_reset_map mmcc_msm8998_resets[] = {
  2581. [SPDM_BCR] = { 0x200 },
  2582. [SPDM_RM_BCR] = { 0x300 },
  2583. [MISC_BCR] = { 0x320 },
  2584. [VIDEO_TOP_BCR] = { 0x1020 },
  2585. [THROTTLE_VIDEO_BCR] = { 0x1180 },
  2586. [MDSS_BCR] = { 0x2300 },
  2587. [THROTTLE_MDSS_BCR] = { 0x2460 },
  2588. [CAMSS_PHY0_BCR] = { 0x3020 },
  2589. [CAMSS_PHY1_BCR] = { 0x3050 },
  2590. [CAMSS_PHY2_BCR] = { 0x3080 },
  2591. [CAMSS_CSI0_BCR] = { 0x30b0 },
  2592. [CAMSS_CSI0RDI_BCR] = { 0x30d0 },
  2593. [CAMSS_CSI0PIX_BCR] = { 0x30e0 },
  2594. [CAMSS_CSI1_BCR] = { 0x3120 },
  2595. [CAMSS_CSI1RDI_BCR] = { 0x3140 },
  2596. [CAMSS_CSI1PIX_BCR] = { 0x3150 },
  2597. [CAMSS_CSI2_BCR] = { 0x3180 },
  2598. [CAMSS_CSI2RDI_BCR] = { 0x31a0 },
  2599. [CAMSS_CSI2PIX_BCR] = { 0x31b0 },
  2600. [CAMSS_CSI3_BCR] = { 0x31e0 },
  2601. [CAMSS_CSI3RDI_BCR] = { 0x3200 },
  2602. [CAMSS_CSI3PIX_BCR] = { 0x3210 },
  2603. [CAMSS_ISPIF_BCR] = { 0x3220 },
  2604. [CAMSS_CCI_BCR] = { 0x3340 },
  2605. [CAMSS_TOP_BCR] = { 0x3480 },
  2606. [CAMSS_AHB_BCR] = { 0x3488 },
  2607. [CAMSS_MICRO_BCR] = { 0x3490 },
  2608. [CAMSS_JPEG_BCR] = { 0x35a0 },
  2609. [CAMSS_VFE0_BCR] = { 0x3660 },
  2610. [CAMSS_VFE1_BCR] = { 0x3670 },
  2611. [CAMSS_VFE_VBIF_BCR] = { 0x36a0 },
  2612. [CAMSS_CPP_TOP_BCR] = { 0x36c0 },
  2613. [CAMSS_CPP_BCR] = { 0x36d0 },
  2614. [CAMSS_CSI_VFE0_BCR] = { 0x3700 },
  2615. [CAMSS_CSI_VFE1_BCR] = { 0x3710 },
  2616. [CAMSS_FD_BCR] = { 0x3b60 },
  2617. [THROTTLE_CAMSS_BCR] = { 0x3c30 },
  2618. [MNOCAHB_BCR] = { 0x5020 },
  2619. [MNOCAXI_BCR] = { 0xd020 },
  2620. [BMIC_SMMU_BCR] = { 0xe000 },
  2621. [MNOC_MAXI_BCR] = { 0xf000 },
  2622. [VMEM_BCR] = { 0xf060 },
  2623. [BTO_BCR] = { 0x10004 },
  2624. };
  2625. static const struct regmap_config mmcc_msm8998_regmap_config = {
  2626. .reg_bits = 32,
  2627. .reg_stride = 4,
  2628. .val_bits = 32,
  2629. .max_register = 0x10004,
  2630. .fast_io = true,
  2631. };
  2632. static const struct qcom_cc_desc mmcc_msm8998_desc = {
  2633. .config = &mmcc_msm8998_regmap_config,
  2634. .clks = mmcc_msm8998_clocks,
  2635. .num_clks = ARRAY_SIZE(mmcc_msm8998_clocks),
  2636. .resets = mmcc_msm8998_resets,
  2637. .num_resets = ARRAY_SIZE(mmcc_msm8998_resets),
  2638. .gdscs = mmcc_msm8998_gdscs,
  2639. .num_gdscs = ARRAY_SIZE(mmcc_msm8998_gdscs),
  2640. };
  2641. static const struct of_device_id mmcc_msm8998_match_table[] = {
  2642. { .compatible = "qcom,mmcc-msm8998" },
  2643. { }
  2644. };
  2645. MODULE_DEVICE_TABLE(of, mmcc_msm8998_match_table);
  2646. static int mmcc_msm8998_probe(struct platform_device *pdev)
  2647. {
  2648. struct regmap *regmap;
  2649. regmap = qcom_cc_map(pdev, &mmcc_msm8998_desc);
  2650. if (IS_ERR(regmap))
  2651. return PTR_ERR(regmap);
  2652. return qcom_cc_really_probe(&pdev->dev, &mmcc_msm8998_desc, regmap);
  2653. }
  2654. static struct platform_driver mmcc_msm8998_driver = {
  2655. .probe = mmcc_msm8998_probe,
  2656. .driver = {
  2657. .name = "mmcc-msm8998",
  2658. .of_match_table = mmcc_msm8998_match_table,
  2659. },
  2660. };
  2661. module_platform_driver(mmcc_msm8998_driver);
  2662. MODULE_DESCRIPTION("QCOM MMCC MSM8998 Driver");
  2663. MODULE_LICENSE("GPL v2");