mmcc-msm8994.c 66 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * Copyright (c) 2021, Konrad Dybcio <[email protected]>
  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/module.h>
  10. #include <linux/of.h>
  11. #include <linux/of_device.h>
  12. #include <linux/clk-provider.h>
  13. #include <linux/regmap.h>
  14. #include <linux/reset-controller.h>
  15. #include <linux/clk.h>
  16. #include <dt-bindings/clock/qcom,mmcc-msm8994.h>
  17. #include "common.h"
  18. #include "clk-regmap.h"
  19. #include "clk-regmap-divider.h"
  20. #include "clk-alpha-pll.h"
  21. #include "clk-rcg.h"
  22. #include "clk-branch.h"
  23. #include "reset.h"
  24. #include "gdsc.h"
  25. enum {
  26. P_XO,
  27. P_GPLL0,
  28. P_MMPLL0,
  29. P_MMPLL1,
  30. P_MMPLL3,
  31. P_MMPLL4,
  32. P_MMPLL5, /* Is this one even used by anything? Downstream doesn't tell. */
  33. P_DSI0PLL,
  34. P_DSI1PLL,
  35. P_DSI0PLL_BYTE,
  36. P_DSI1PLL_BYTE,
  37. P_HDMIPLL,
  38. };
  39. static const struct parent_map mmcc_xo_gpll0_map[] = {
  40. { P_XO, 0 },
  41. { P_GPLL0, 5 }
  42. };
  43. static const struct clk_parent_data mmcc_xo_gpll0[] = {
  44. { .fw_name = "xo" },
  45. { .fw_name = "gpll0" },
  46. };
  47. static const struct parent_map mmss_xo_hdmi_map[] = {
  48. { P_XO, 0 },
  49. { P_HDMIPLL, 3 }
  50. };
  51. static const struct clk_parent_data mmss_xo_hdmi[] = {
  52. { .fw_name = "xo" },
  53. { .fw_name = "hdmipll" },
  54. };
  55. static const struct parent_map mmcc_xo_dsi0pll_dsi1pll_map[] = {
  56. { P_XO, 0 },
  57. { P_DSI0PLL, 1 },
  58. { P_DSI1PLL, 2 }
  59. };
  60. static const struct clk_parent_data mmcc_xo_dsi0pll_dsi1pll[] = {
  61. { .fw_name = "xo" },
  62. { .fw_name = "dsi0pll" },
  63. { .fw_name = "dsi1pll" },
  64. };
  65. static const struct parent_map mmcc_xo_dsibyte_map[] = {
  66. { P_XO, 0 },
  67. { P_DSI0PLL_BYTE, 1 },
  68. { P_DSI1PLL_BYTE, 2 }
  69. };
  70. static const struct clk_parent_data mmcc_xo_dsibyte[] = {
  71. { .fw_name = "xo" },
  72. { .fw_name = "dsi0pllbyte" },
  73. { .fw_name = "dsi1pllbyte" },
  74. };
  75. static struct pll_vco mmpll_p_vco[] = {
  76. { 250000000, 500000000, 3 },
  77. { 500000000, 1000000000, 2 },
  78. { 1000000000, 1500000000, 1 },
  79. { 1500000000, 2000000000, 0 },
  80. };
  81. static struct pll_vco mmpll_t_vco[] = {
  82. { 500000000, 1500000000, 0 },
  83. };
  84. static const struct alpha_pll_config mmpll_p_config = {
  85. .post_div_mask = 0xf00,
  86. };
  87. static struct clk_alpha_pll mmpll0_early = {
  88. .offset = 0x0,
  89. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
  90. .vco_table = mmpll_p_vco,
  91. .num_vco = ARRAY_SIZE(mmpll_p_vco),
  92. .clkr = {
  93. .enable_reg = 0x100,
  94. .enable_mask = BIT(0),
  95. .hw.init = &(struct clk_init_data){
  96. .name = "mmpll0_early",
  97. .parent_data = &(const struct clk_parent_data){
  98. .fw_name = "xo",
  99. },
  100. .num_parents = 1,
  101. .ops = &clk_alpha_pll_ops,
  102. },
  103. },
  104. };
  105. static struct clk_alpha_pll_postdiv mmpll0 = {
  106. .offset = 0x0,
  107. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
  108. .width = 4,
  109. .clkr.hw.init = &(struct clk_init_data){
  110. .name = "mmpll0",
  111. .parent_hws = (const struct clk_hw *[]){ &mmpll0_early.clkr.hw },
  112. .num_parents = 1,
  113. .ops = &clk_alpha_pll_postdiv_ops,
  114. .flags = CLK_SET_RATE_PARENT,
  115. },
  116. };
  117. static struct clk_alpha_pll mmpll1_early = {
  118. .offset = 0x30,
  119. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
  120. .vco_table = mmpll_p_vco,
  121. .num_vco = ARRAY_SIZE(mmpll_p_vco),
  122. .clkr = {
  123. .enable_reg = 0x100,
  124. .enable_mask = BIT(1),
  125. .hw.init = &(struct clk_init_data){
  126. .name = "mmpll1_early",
  127. .parent_data = &(const struct clk_parent_data){
  128. .fw_name = "xo",
  129. },
  130. .num_parents = 1,
  131. .ops = &clk_alpha_pll_ops,
  132. }
  133. },
  134. };
  135. static struct clk_alpha_pll_postdiv mmpll1 = {
  136. .offset = 0x30,
  137. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
  138. .width = 4,
  139. .clkr.hw.init = &(struct clk_init_data){
  140. .name = "mmpll1",
  141. .parent_hws = (const struct clk_hw *[]){ &mmpll1_early.clkr.hw },
  142. .num_parents = 1,
  143. .ops = &clk_alpha_pll_postdiv_ops,
  144. .flags = CLK_SET_RATE_PARENT,
  145. },
  146. };
  147. static struct clk_alpha_pll mmpll3_early = {
  148. .offset = 0x60,
  149. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
  150. .vco_table = mmpll_p_vco,
  151. .num_vco = ARRAY_SIZE(mmpll_p_vco),
  152. .clkr.hw.init = &(struct clk_init_data){
  153. .name = "mmpll3_early",
  154. .parent_data = &(const struct clk_parent_data){
  155. .fw_name = "xo",
  156. },
  157. .num_parents = 1,
  158. .ops = &clk_alpha_pll_ops,
  159. },
  160. };
  161. static struct clk_alpha_pll_postdiv mmpll3 = {
  162. .offset = 0x60,
  163. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
  164. .width = 4,
  165. .clkr.hw.init = &(struct clk_init_data){
  166. .name = "mmpll3",
  167. .parent_hws = (const struct clk_hw *[]){ &mmpll3_early.clkr.hw },
  168. .num_parents = 1,
  169. .ops = &clk_alpha_pll_postdiv_ops,
  170. .flags = CLK_SET_RATE_PARENT,
  171. },
  172. };
  173. static struct clk_alpha_pll mmpll4_early = {
  174. .offset = 0x90,
  175. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
  176. .vco_table = mmpll_t_vco,
  177. .num_vco = ARRAY_SIZE(mmpll_t_vco),
  178. .clkr.hw.init = &(struct clk_init_data){
  179. .name = "mmpll4_early",
  180. .parent_data = &(const struct clk_parent_data){
  181. .fw_name = "xo",
  182. },
  183. .num_parents = 1,
  184. .ops = &clk_alpha_pll_ops,
  185. },
  186. };
  187. static struct clk_alpha_pll_postdiv mmpll4 = {
  188. .offset = 0x90,
  189. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
  190. .width = 2,
  191. .clkr.hw.init = &(struct clk_init_data){
  192. .name = "mmpll4",
  193. .parent_hws = (const struct clk_hw *[]){ &mmpll4_early.clkr.hw },
  194. .num_parents = 1,
  195. .ops = &clk_alpha_pll_postdiv_ops,
  196. .flags = CLK_SET_RATE_PARENT,
  197. },
  198. };
  199. static const struct parent_map mmcc_xo_gpll0_mmpll1_map[] = {
  200. { P_XO, 0 },
  201. { P_GPLL0, 5 },
  202. { P_MMPLL1, 2 }
  203. };
  204. static const struct clk_parent_data mmcc_xo_gpll0_mmpll1[] = {
  205. { .fw_name = "xo" },
  206. { .fw_name = "gpll0" },
  207. { .hw = &mmpll1.clkr.hw },
  208. };
  209. static const struct parent_map mmcc_xo_gpll0_mmpll0_map[] = {
  210. { P_XO, 0 },
  211. { P_GPLL0, 5 },
  212. { P_MMPLL0, 1 }
  213. };
  214. static const struct clk_parent_data mmcc_xo_gpll0_mmpll0[] = {
  215. { .fw_name = "xo" },
  216. { .fw_name = "gpll0" },
  217. { .hw = &mmpll0.clkr.hw },
  218. };
  219. static const struct parent_map mmcc_xo_gpll0_mmpll0_mmpll3_map[] = {
  220. { P_XO, 0 },
  221. { P_GPLL0, 5 },
  222. { P_MMPLL0, 1 },
  223. { P_MMPLL3, 3 }
  224. };
  225. static const struct clk_parent_data mmcc_xo_gpll0_mmpll0_mmpll3[] = {
  226. { .fw_name = "xo" },
  227. { .fw_name = "gpll0" },
  228. { .hw = &mmpll0.clkr.hw },
  229. { .hw = &mmpll3.clkr.hw },
  230. };
  231. static const struct parent_map mmcc_xo_gpll0_mmpll0_mmpll4_map[] = {
  232. { P_XO, 0 },
  233. { P_GPLL0, 5 },
  234. { P_MMPLL0, 1 },
  235. { P_MMPLL4, 3 }
  236. };
  237. static const struct clk_parent_data mmcc_xo_gpll0_mmpll0_mmpll4[] = {
  238. { .fw_name = "xo" },
  239. { .fw_name = "gpll0" },
  240. { .hw = &mmpll0.clkr.hw },
  241. { .hw = &mmpll4.clkr.hw },
  242. };
  243. static struct clk_alpha_pll mmpll5_early = {
  244. .offset = 0xc0,
  245. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
  246. .vco_table = mmpll_p_vco,
  247. .num_vco = ARRAY_SIZE(mmpll_p_vco),
  248. .clkr.hw.init = &(struct clk_init_data){
  249. .name = "mmpll5_early",
  250. .parent_data = &(const struct clk_parent_data){
  251. .fw_name = "xo",
  252. },
  253. .num_parents = 1,
  254. .ops = &clk_alpha_pll_ops,
  255. },
  256. };
  257. static struct clk_alpha_pll_postdiv mmpll5 = {
  258. .offset = 0xc0,
  259. .regs = clk_alpha_pll_regs[CLK_ALPHA_PLL_TYPE_DEFAULT],
  260. .width = 4,
  261. .clkr.hw.init = &(struct clk_init_data){
  262. .name = "mmpll5",
  263. .parent_hws = (const struct clk_hw *[]){ &mmpll5_early.clkr.hw },
  264. .num_parents = 1,
  265. .ops = &clk_alpha_pll_postdiv_ops,
  266. .flags = CLK_SET_RATE_PARENT,
  267. },
  268. };
  269. static const struct freq_tbl ftbl_ahb_clk_src[] = {
  270. /* Note: There might be more frequencies desired here. */
  271. F(19200000, P_XO, 1, 0, 0),
  272. F(40000000, P_GPLL0, 15, 0, 0),
  273. F(80000000, P_MMPLL0, 10, 0, 0),
  274. { }
  275. };
  276. static struct clk_rcg2 ahb_clk_src = {
  277. .cmd_rcgr = 0x5000,
  278. .hid_width = 5,
  279. .parent_map = mmcc_xo_gpll0_mmpll0_map,
  280. .freq_tbl = ftbl_ahb_clk_src,
  281. .clkr.hw.init = &(struct clk_init_data){
  282. .name = "ahb_clk_src",
  283. .parent_data = mmcc_xo_gpll0_mmpll0,
  284. .num_parents = ARRAY_SIZE(mmcc_xo_gpll0_mmpll0),
  285. .ops = &clk_rcg2_ops,
  286. },
  287. };
  288. static const struct freq_tbl ftbl_axi_clk_src[] = {
  289. F(75000000, P_GPLL0, 8, 0, 0),
  290. F(150000000, P_GPLL0, 4, 0, 0),
  291. F(333430000, P_MMPLL1, 3.5, 0, 0),
  292. F(466800000, P_MMPLL1, 2.5, 0, 0),
  293. { }
  294. };
  295. static const struct freq_tbl ftbl_axi_clk_src_8992[] = {
  296. F(75000000, P_GPLL0, 8, 0, 0),
  297. F(150000000, P_GPLL0, 4, 0, 0),
  298. F(300000000, P_GPLL0, 2, 0, 0),
  299. F(404000000, P_MMPLL1, 2, 0, 0),
  300. { }
  301. };
  302. static struct clk_rcg2 axi_clk_src = {
  303. .cmd_rcgr = 0x5040,
  304. .hid_width = 5,
  305. .parent_map = mmcc_xo_gpll0_mmpll1_map,
  306. .freq_tbl = ftbl_axi_clk_src,
  307. .clkr.hw.init = &(struct clk_init_data){
  308. .name = "axi_clk_src",
  309. .parent_data = mmcc_xo_gpll0_mmpll1,
  310. .num_parents = ARRAY_SIZE(mmcc_xo_gpll0_mmpll1),
  311. .ops = &clk_rcg2_ops,
  312. },
  313. };
  314. static const struct freq_tbl ftbl_csi0_1_2_3_clk_src[] = {
  315. F(100000000, P_GPLL0, 6, 0, 0),
  316. F(240000000, P_GPLL0, 2.5, 0, 0),
  317. F(266670000, P_MMPLL0, 3, 0, 0),
  318. { }
  319. };
  320. static const struct freq_tbl ftbl_csi0_1_2_3_clk_src_8992[] = {
  321. F(100000000, P_GPLL0, 6, 0, 0),
  322. F(266670000, P_MMPLL0, 3, 0, 0),
  323. { }
  324. };
  325. static struct clk_rcg2 csi0_clk_src = {
  326. .cmd_rcgr = 0x3090,
  327. .hid_width = 5,
  328. .parent_map = mmcc_xo_gpll0_mmpll0_map,
  329. .freq_tbl = ftbl_csi0_1_2_3_clk_src,
  330. .clkr.hw.init = &(struct clk_init_data){
  331. .name = "csi0_clk_src",
  332. .parent_data = mmcc_xo_gpll0_mmpll0,
  333. .num_parents = ARRAY_SIZE(mmcc_xo_gpll0_mmpll0),
  334. .ops = &clk_rcg2_ops,
  335. },
  336. };
  337. static const struct freq_tbl ftbl_vcodec0_clk_src[] = {
  338. F(66670000, P_GPLL0, 9, 0, 0),
  339. F(100000000, P_GPLL0, 6, 0, 0),
  340. F(133330000, P_GPLL0, 4.5, 0, 0),
  341. F(150000000, P_GPLL0, 4, 0, 0),
  342. F(200000000, P_MMPLL0, 4, 0, 0),
  343. F(240000000, P_GPLL0, 2.5, 0, 0),
  344. F(266670000, P_MMPLL0, 3, 0, 0),
  345. F(320000000, P_MMPLL0, 2.5, 0, 0),
  346. F(510000000, P_MMPLL3, 2, 0, 0),
  347. { }
  348. };
  349. static const struct freq_tbl ftbl_vcodec0_clk_src_8992[] = {
  350. F(66670000, P_GPLL0, 9, 0, 0),
  351. F(100000000, P_GPLL0, 6, 0, 0),
  352. F(133330000, P_GPLL0, 4.5, 0, 0),
  353. F(200000000, P_MMPLL0, 4, 0, 0),
  354. F(320000000, P_MMPLL0, 2.5, 0, 0),
  355. F(510000000, P_MMPLL3, 2, 0, 0),
  356. { }
  357. };
  358. static struct clk_rcg2 vcodec0_clk_src = {
  359. .cmd_rcgr = 0x1000,
  360. .mnd_width = 8,
  361. .hid_width = 5,
  362. .parent_map = mmcc_xo_gpll0_mmpll0_mmpll3_map,
  363. .freq_tbl = ftbl_vcodec0_clk_src,
  364. .clkr.hw.init = &(struct clk_init_data){
  365. .name = "vcodec0_clk_src",
  366. .parent_data = mmcc_xo_gpll0_mmpll0_mmpll3,
  367. .num_parents = ARRAY_SIZE(mmcc_xo_gpll0_mmpll0_mmpll3),
  368. .ops = &clk_rcg2_ops,
  369. },
  370. };
  371. static struct clk_rcg2 csi1_clk_src = {
  372. .cmd_rcgr = 0x3100,
  373. .hid_width = 5,
  374. .parent_map = mmcc_xo_gpll0_mmpll0_map,
  375. .freq_tbl = ftbl_csi0_1_2_3_clk_src,
  376. .clkr.hw.init = &(struct clk_init_data){
  377. .name = "csi1_clk_src",
  378. .parent_data = mmcc_xo_gpll0_mmpll0,
  379. .num_parents = ARRAY_SIZE(mmcc_xo_gpll0_mmpll0),
  380. .ops = &clk_rcg2_ops,
  381. },
  382. };
  383. static struct clk_rcg2 csi2_clk_src = {
  384. .cmd_rcgr = 0x3160,
  385. .hid_width = 5,
  386. .parent_map = mmcc_xo_gpll0_mmpll0_map,
  387. .freq_tbl = ftbl_csi0_1_2_3_clk_src,
  388. .clkr.hw.init = &(struct clk_init_data){
  389. .name = "csi2_clk_src",
  390. .parent_data = mmcc_xo_gpll0_mmpll0,
  391. .num_parents = ARRAY_SIZE(mmcc_xo_gpll0_mmpll0),
  392. .ops = &clk_rcg2_ops,
  393. },
  394. };
  395. static struct clk_rcg2 csi3_clk_src = {
  396. .cmd_rcgr = 0x31c0,
  397. .hid_width = 5,
  398. .parent_map = mmcc_xo_gpll0_mmpll0_map,
  399. .freq_tbl = ftbl_csi0_1_2_3_clk_src,
  400. .clkr.hw.init = &(struct clk_init_data){
  401. .name = "csi3_clk_src",
  402. .parent_data = mmcc_xo_gpll0_mmpll0,
  403. .num_parents = ARRAY_SIZE(mmcc_xo_gpll0_mmpll0),
  404. .ops = &clk_rcg2_ops,
  405. },
  406. };
  407. static const struct freq_tbl ftbl_vfe0_clk_src[] = {
  408. F(80000000, P_GPLL0, 7.5, 0, 0),
  409. F(100000000, P_GPLL0, 6, 0, 0),
  410. F(200000000, P_GPLL0, 3, 0, 0),
  411. F(320000000, P_MMPLL0, 2.5, 0, 0),
  412. F(400000000, P_MMPLL0, 2, 0, 0),
  413. F(480000000, P_MMPLL4, 2, 0, 0),
  414. F(533330000, P_MMPLL0, 1.5, 0, 0),
  415. F(600000000, P_GPLL0, 1, 0, 0),
  416. { }
  417. };
  418. static const struct freq_tbl ftbl_vfe0_1_clk_src_8992[] = {
  419. F(80000000, P_GPLL0, 7.5, 0, 0),
  420. F(100000000, P_GPLL0, 6, 0, 0),
  421. F(200000000, P_GPLL0, 3, 0, 0),
  422. F(320000000, P_MMPLL0, 2.5, 0, 0),
  423. F(480000000, P_MMPLL4, 2, 0, 0),
  424. F(600000000, P_GPLL0, 1, 0, 0),
  425. { }
  426. };
  427. static struct clk_rcg2 vfe0_clk_src = {
  428. .cmd_rcgr = 0x3600,
  429. .hid_width = 5,
  430. .parent_map = mmcc_xo_gpll0_mmpll0_mmpll4_map,
  431. .freq_tbl = ftbl_vfe0_clk_src,
  432. .clkr.hw.init = &(struct clk_init_data){
  433. .name = "vfe0_clk_src",
  434. .parent_data = mmcc_xo_gpll0_mmpll0_mmpll4,
  435. .num_parents = ARRAY_SIZE(mmcc_xo_gpll0_mmpll0_mmpll4),
  436. .ops = &clk_rcg2_ops,
  437. },
  438. };
  439. static const struct freq_tbl ftbl_vfe1_clk_src[] = {
  440. F(80000000, P_GPLL0, 7.5, 0, 0),
  441. F(100000000, P_GPLL0, 6, 0, 0),
  442. F(200000000, P_GPLL0, 3, 0, 0),
  443. F(320000000, P_MMPLL0, 2.5, 0, 0),
  444. F(400000000, P_MMPLL0, 2, 0, 0),
  445. F(533330000, P_MMPLL0, 1.5, 0, 0),
  446. { }
  447. };
  448. static struct clk_rcg2 vfe1_clk_src = {
  449. .cmd_rcgr = 0x3620,
  450. .hid_width = 5,
  451. .parent_map = mmcc_xo_gpll0_mmpll0_mmpll4_map,
  452. .freq_tbl = ftbl_vfe1_clk_src,
  453. .clkr.hw.init = &(struct clk_init_data){
  454. .name = "vfe1_clk_src",
  455. .parent_data = mmcc_xo_gpll0_mmpll0_mmpll4,
  456. .num_parents = ARRAY_SIZE(mmcc_xo_gpll0_mmpll0_mmpll4),
  457. .ops = &clk_rcg2_ops,
  458. },
  459. };
  460. static const struct freq_tbl ftbl_cpp_clk_src[] = {
  461. F(100000000, P_GPLL0, 6, 0, 0),
  462. F(200000000, P_GPLL0, 3, 0, 0),
  463. F(320000000, P_MMPLL0, 2.5, 0, 0),
  464. F(480000000, P_MMPLL4, 2, 0, 0),
  465. F(600000000, P_GPLL0, 1, 0, 0),
  466. F(640000000, P_MMPLL4, 1.5, 0, 0),
  467. { }
  468. };
  469. static const struct freq_tbl ftbl_cpp_clk_src_8992[] = {
  470. F(100000000, P_GPLL0, 6, 0, 0),
  471. F(200000000, P_GPLL0, 3, 0, 0),
  472. F(320000000, P_MMPLL0, 2.5, 0, 0),
  473. F(480000000, P_MMPLL4, 2, 0, 0),
  474. F(640000000, P_MMPLL4, 1.5, 0, 0),
  475. { }
  476. };
  477. static struct clk_rcg2 cpp_clk_src = {
  478. .cmd_rcgr = 0x3640,
  479. .hid_width = 5,
  480. .parent_map = mmcc_xo_gpll0_mmpll0_mmpll4_map,
  481. .freq_tbl = ftbl_cpp_clk_src,
  482. .clkr.hw.init = &(struct clk_init_data){
  483. .name = "cpp_clk_src",
  484. .parent_data = mmcc_xo_gpll0_mmpll0_mmpll4,
  485. .num_parents = ARRAY_SIZE(mmcc_xo_gpll0_mmpll0_mmpll4),
  486. .ops = &clk_rcg2_ops,
  487. },
  488. };
  489. static const struct freq_tbl ftbl_jpeg0_1_clk_src[] = {
  490. F(75000000, P_GPLL0, 8, 0, 0),
  491. F(150000000, P_GPLL0, 4, 0, 0),
  492. F(228570000, P_MMPLL0, 3.5, 0, 0),
  493. F(266670000, P_MMPLL0, 3, 0, 0),
  494. F(320000000, P_MMPLL0, 2.5, 0, 0),
  495. F(480000000, P_MMPLL4, 2, 0, 0),
  496. { }
  497. };
  498. static struct clk_rcg2 jpeg1_clk_src = {
  499. .cmd_rcgr = 0x3520,
  500. .hid_width = 5,
  501. .parent_map = mmcc_xo_gpll0_mmpll0_mmpll4_map,
  502. .freq_tbl = ftbl_jpeg0_1_clk_src,
  503. .clkr.hw.init = &(struct clk_init_data){
  504. .name = "jpeg1_clk_src",
  505. .parent_data = mmcc_xo_gpll0_mmpll0_mmpll4,
  506. .num_parents = ARRAY_SIZE(mmcc_xo_gpll0_mmpll0_mmpll4),
  507. .ops = &clk_rcg2_ops,
  508. },
  509. };
  510. static const struct freq_tbl ftbl_jpeg2_clk_src[] = {
  511. F(75000000, P_GPLL0, 8, 0, 0),
  512. F(133330000, P_GPLL0, 4.5, 0, 0),
  513. F(150000000, P_GPLL0, 4, 0, 0),
  514. F(228570000, P_MMPLL0, 3.5, 0, 0),
  515. F(266670000, P_MMPLL0, 3, 0, 0),
  516. F(320000000, P_MMPLL0, 2.5, 0, 0),
  517. { }
  518. };
  519. static struct clk_rcg2 jpeg2_clk_src = {
  520. .cmd_rcgr = 0x3540,
  521. .hid_width = 5,
  522. .parent_map = mmcc_xo_gpll0_mmpll0_map,
  523. .freq_tbl = ftbl_jpeg2_clk_src,
  524. .clkr.hw.init = &(struct clk_init_data){
  525. .name = "jpeg2_clk_src",
  526. .parent_data = mmcc_xo_gpll0_mmpll0,
  527. .num_parents = ARRAY_SIZE(mmcc_xo_gpll0_mmpll0),
  528. .ops = &clk_rcg2_ops,
  529. },
  530. };
  531. static const struct freq_tbl ftbl_csi2phytimer_clk_src[] = {
  532. F(50000000, P_GPLL0, 12, 0, 0),
  533. F(100000000, P_GPLL0, 6, 0, 0),
  534. F(200000000, P_MMPLL0, 4, 0, 0),
  535. { }
  536. };
  537. static struct clk_rcg2 csi2phytimer_clk_src = {
  538. .cmd_rcgr = 0x3060,
  539. .hid_width = 5,
  540. .parent_map = mmcc_xo_gpll0_mmpll0_map,
  541. .freq_tbl = ftbl_csi2phytimer_clk_src,
  542. .clkr.hw.init = &(struct clk_init_data){
  543. .name = "csi2phytimer_clk_src",
  544. .parent_data = mmcc_xo_gpll0_mmpll0,
  545. .num_parents = ARRAY_SIZE(mmcc_xo_gpll0_mmpll0),
  546. .ops = &clk_rcg2_ops,
  547. },
  548. };
  549. static const struct freq_tbl ftbl_fd_core_clk_src[] = {
  550. F(60000000, P_GPLL0, 10, 0, 0),
  551. F(200000000, P_GPLL0, 3, 0, 0),
  552. F(320000000, P_MMPLL0, 2.5, 0, 0),
  553. F(400000000, P_MMPLL0, 2, 0, 0),
  554. { }
  555. };
  556. static struct clk_rcg2 fd_core_clk_src = {
  557. .cmd_rcgr = 0x3b00,
  558. .hid_width = 5,
  559. .parent_map = mmcc_xo_gpll0_mmpll0_map,
  560. .freq_tbl = ftbl_fd_core_clk_src,
  561. .clkr.hw.init = &(struct clk_init_data){
  562. .name = "fd_core_clk_src",
  563. .parent_data = mmcc_xo_gpll0_mmpll0,
  564. .num_parents = ARRAY_SIZE(mmcc_xo_gpll0_mmpll0),
  565. .ops = &clk_rcg2_ops,
  566. },
  567. };
  568. static const struct freq_tbl ftbl_mdp_clk_src[] = {
  569. F(85710000, P_GPLL0, 7, 0, 0),
  570. F(100000000, P_GPLL0, 6, 0, 0),
  571. F(120000000, P_GPLL0, 5, 0, 0),
  572. F(150000000, P_GPLL0, 4, 0, 0),
  573. F(171430000, P_GPLL0, 3.5, 0, 0),
  574. F(200000000, P_GPLL0, 3, 0, 0),
  575. F(240000000, P_GPLL0, 2.5, 0, 0),
  576. F(266670000, P_MMPLL0, 3, 0, 0),
  577. F(300000000, P_GPLL0, 2, 0, 0),
  578. F(320000000, P_MMPLL0, 2.5, 0, 0),
  579. F(400000000, P_MMPLL0, 2, 0, 0),
  580. { }
  581. };
  582. static const struct freq_tbl ftbl_mdp_clk_src_8992[] = {
  583. F(85710000, P_GPLL0, 7, 0, 0),
  584. F(171430000, P_GPLL0, 3.5, 0, 0),
  585. F(200000000, P_GPLL0, 3, 0, 0),
  586. F(240000000, P_GPLL0, 2.5, 0, 0),
  587. F(266670000, P_MMPLL0, 3, 0, 0),
  588. F(320000000, P_MMPLL0, 2.5, 0, 0),
  589. F(400000000, P_MMPLL0, 2, 0, 0),
  590. { }
  591. };
  592. static struct clk_rcg2 mdp_clk_src = {
  593. .cmd_rcgr = 0x2040,
  594. .hid_width = 5,
  595. .parent_map = mmcc_xo_gpll0_mmpll0_map,
  596. .freq_tbl = ftbl_mdp_clk_src,
  597. .clkr.hw.init = &(struct clk_init_data){
  598. .name = "mdp_clk_src",
  599. .parent_data = mmcc_xo_gpll0_mmpll0,
  600. .num_parents = ARRAY_SIZE(mmcc_xo_gpll0_mmpll0),
  601. .ops = &clk_rcg2_ops,
  602. },
  603. };
  604. static struct clk_rcg2 pclk0_clk_src = {
  605. .cmd_rcgr = 0x2000,
  606. .mnd_width = 8,
  607. .hid_width = 5,
  608. .parent_map = mmcc_xo_dsi0pll_dsi1pll_map,
  609. .clkr.hw.init = &(struct clk_init_data){
  610. .name = "pclk0_clk_src",
  611. .parent_data = mmcc_xo_dsi0pll_dsi1pll,
  612. .num_parents = ARRAY_SIZE(mmcc_xo_dsi0pll_dsi1pll),
  613. .ops = &clk_pixel_ops,
  614. .flags = CLK_SET_RATE_PARENT | CLK_GET_RATE_NOCACHE,
  615. },
  616. };
  617. static struct clk_rcg2 pclk1_clk_src = {
  618. .cmd_rcgr = 0x2020,
  619. .mnd_width = 8,
  620. .hid_width = 5,
  621. .parent_map = mmcc_xo_dsi0pll_dsi1pll_map,
  622. .clkr.hw.init = &(struct clk_init_data){
  623. .name = "pclk1_clk_src",
  624. .parent_data = mmcc_xo_dsi0pll_dsi1pll,
  625. .num_parents = ARRAY_SIZE(mmcc_xo_dsi0pll_dsi1pll),
  626. .ops = &clk_pixel_ops,
  627. .flags = CLK_SET_RATE_PARENT | CLK_GET_RATE_NOCACHE,
  628. },
  629. };
  630. static const struct freq_tbl ftbl_ocmemnoc_clk_src[] = {
  631. F(19200000, P_XO, 1, 0, 0),
  632. F(75000000, P_GPLL0, 8, 0, 0),
  633. F(100000000, P_GPLL0, 6, 0, 0),
  634. F(150000000, P_GPLL0, 4, 0, 0),
  635. F(228570000, P_MMPLL0, 3.5, 0, 0),
  636. F(266670000, P_MMPLL0, 3, 0, 0),
  637. F(320000000, P_MMPLL0, 2.5, 0, 0),
  638. F(400000000, P_MMPLL0, 2, 0, 0),
  639. { }
  640. };
  641. static const struct freq_tbl ftbl_ocmemnoc_clk_src_8992[] = {
  642. F(19200000, P_XO, 1, 0, 0),
  643. F(75000000, P_GPLL0, 8, 0, 0),
  644. F(100000000, P_GPLL0, 6, 0, 0),
  645. F(150000000, P_GPLL0, 4, 0, 0),
  646. F(320000000, P_MMPLL0, 2.5, 0, 0),
  647. F(400000000, P_MMPLL0, 2, 0, 0),
  648. { }
  649. };
  650. static struct clk_rcg2 ocmemnoc_clk_src = {
  651. .cmd_rcgr = 0x5090,
  652. .hid_width = 5,
  653. .parent_map = mmcc_xo_gpll0_mmpll0_map,
  654. .freq_tbl = ftbl_ocmemnoc_clk_src,
  655. .clkr.hw.init = &(struct clk_init_data){
  656. .name = "ocmemnoc_clk_src",
  657. .parent_data = mmcc_xo_gpll0_mmpll0,
  658. .num_parents = ARRAY_SIZE(mmcc_xo_gpll0_mmpll0),
  659. .ops = &clk_rcg2_ops,
  660. },
  661. };
  662. static const struct freq_tbl ftbl_cci_clk_src[] = {
  663. F(19200000, P_XO, 1, 0, 0),
  664. F(37500000, P_GPLL0, 16, 0, 0),
  665. F(50000000, P_GPLL0, 12, 0, 0),
  666. F(100000000, P_GPLL0, 6, 0, 0),
  667. { }
  668. };
  669. static struct clk_rcg2 cci_clk_src = {
  670. .cmd_rcgr = 0x3300,
  671. .mnd_width = 8,
  672. .hid_width = 5,
  673. .parent_map = mmcc_xo_gpll0_map,
  674. .freq_tbl = ftbl_cci_clk_src,
  675. .clkr.hw.init = &(struct clk_init_data){
  676. .name = "cci_clk_src",
  677. .parent_data = mmcc_xo_gpll0,
  678. .num_parents = ARRAY_SIZE(mmcc_xo_gpll0),
  679. .ops = &clk_rcg2_ops,
  680. },
  681. };
  682. static const struct freq_tbl ftbl_mmss_gp0_1_clk_src[] = {
  683. F(10000, P_XO, 16, 10, 120),
  684. F(24000, P_GPLL0, 16, 1, 50),
  685. F(6000000, P_GPLL0, 10, 1, 10),
  686. F(12000000, P_GPLL0, 10, 1, 5),
  687. F(13000000, P_GPLL0, 4, 13, 150),
  688. F(24000000, P_GPLL0, 5, 1, 5),
  689. { }
  690. };
  691. static struct clk_rcg2 mmss_gp0_clk_src = {
  692. .cmd_rcgr = 0x3420,
  693. .mnd_width = 8,
  694. .hid_width = 5,
  695. .parent_map = mmcc_xo_gpll0_map,
  696. .freq_tbl = ftbl_mmss_gp0_1_clk_src,
  697. .clkr.hw.init = &(struct clk_init_data){
  698. .name = "mmss_gp0_clk_src",
  699. .parent_data = mmcc_xo_gpll0,
  700. .num_parents = ARRAY_SIZE(mmcc_xo_gpll0),
  701. .ops = &clk_rcg2_ops,
  702. },
  703. };
  704. static struct clk_rcg2 mmss_gp1_clk_src = {
  705. .cmd_rcgr = 0x3450,
  706. .mnd_width = 8,
  707. .hid_width = 5,
  708. .parent_map = mmcc_xo_gpll0_map,
  709. .freq_tbl = ftbl_mmss_gp0_1_clk_src,
  710. .clkr.hw.init = &(struct clk_init_data){
  711. .name = "mmss_gp1_clk_src",
  712. .parent_data = mmcc_xo_gpll0,
  713. .num_parents = ARRAY_SIZE(mmcc_xo_gpll0),
  714. .ops = &clk_rcg2_ops,
  715. },
  716. };
  717. static struct clk_rcg2 jpeg0_clk_src = {
  718. .cmd_rcgr = 0x3500,
  719. .hid_width = 5,
  720. .parent_map = mmcc_xo_gpll0_mmpll0_mmpll4_map,
  721. .freq_tbl = ftbl_jpeg0_1_clk_src,
  722. .clkr.hw.init = &(struct clk_init_data){
  723. .name = "jpeg0_clk_src",
  724. .parent_data = mmcc_xo_gpll0_mmpll0_mmpll4,
  725. .num_parents = ARRAY_SIZE(mmcc_xo_gpll0_mmpll0_mmpll4),
  726. .ops = &clk_rcg2_ops,
  727. },
  728. };
  729. static struct clk_rcg2 jpeg_dma_clk_src = {
  730. .cmd_rcgr = 0x3560,
  731. .hid_width = 5,
  732. .parent_map = mmcc_xo_gpll0_mmpll0_mmpll4_map,
  733. .freq_tbl = ftbl_jpeg0_1_clk_src,
  734. .clkr.hw.init = &(struct clk_init_data){
  735. .name = "jpeg_dma_clk_src",
  736. .parent_data = mmcc_xo_gpll0_mmpll0_mmpll4,
  737. .num_parents = ARRAY_SIZE(mmcc_xo_gpll0_mmpll0_mmpll4),
  738. .ops = &clk_rcg2_ops,
  739. },
  740. };
  741. static const struct freq_tbl ftbl_mclk0_1_2_3_clk_src[] = {
  742. F(4800000, P_XO, 4, 0, 0),
  743. F(6000000, P_GPLL0, 10, 1, 10),
  744. F(8000000, P_GPLL0, 15, 1, 5),
  745. F(9600000, P_XO, 2, 0, 0),
  746. F(16000000, P_MMPLL0, 10, 1, 5),
  747. F(19200000, P_XO, 1, 0, 0),
  748. F(24000000, P_GPLL0, 5, 1, 5),
  749. F(32000000, P_MMPLL0, 5, 1, 5),
  750. F(48000000, P_GPLL0, 12.5, 0, 0),
  751. F(64000000, P_MMPLL0, 12.5, 0, 0),
  752. { }
  753. };
  754. static const struct freq_tbl ftbl_mclk0_clk_src_8992[] = {
  755. F(4800000, P_XO, 4, 0, 0),
  756. F(6000000, P_MMPLL4, 10, 1, 16),
  757. F(8000000, P_MMPLL4, 10, 1, 12),
  758. F(9600000, P_XO, 2, 0, 0),
  759. F(12000000, P_MMPLL4, 10, 1, 8),
  760. F(16000000, P_MMPLL4, 10, 1, 6),
  761. F(19200000, P_XO, 1, 0, 0),
  762. F(24000000, P_MMPLL4, 10, 1, 4),
  763. F(32000000, P_MMPLL4, 10, 1, 3),
  764. F(48000000, P_MMPLL4, 10, 1, 2),
  765. F(64000000, P_MMPLL4, 15, 0, 0),
  766. { }
  767. };
  768. static const struct freq_tbl ftbl_mclk1_2_3_clk_src_8992[] = {
  769. F(4800000, P_XO, 4, 0, 0),
  770. F(6000000, P_MMPLL4, 10, 1, 16),
  771. F(8000000, P_MMPLL4, 10, 1, 12),
  772. F(9600000, P_XO, 2, 0, 0),
  773. F(16000000, P_MMPLL4, 10, 1, 6),
  774. F(19200000, P_XO, 1, 0, 0),
  775. F(24000000, P_MMPLL4, 10, 1, 4),
  776. F(32000000, P_MMPLL4, 10, 1, 3),
  777. F(48000000, P_MMPLL4, 10, 1, 2),
  778. F(64000000, P_MMPLL4, 15, 0, 0),
  779. { }
  780. };
  781. static struct clk_rcg2 mclk0_clk_src = {
  782. .cmd_rcgr = 0x3360,
  783. .mnd_width = 8,
  784. .hid_width = 5,
  785. .parent_map = mmcc_xo_gpll0_mmpll0_map,
  786. .freq_tbl = ftbl_mclk0_1_2_3_clk_src,
  787. .clkr.hw.init = &(struct clk_init_data){
  788. .name = "mclk0_clk_src",
  789. .parent_data = mmcc_xo_gpll0_mmpll0,
  790. .num_parents = ARRAY_SIZE(mmcc_xo_gpll0_mmpll0),
  791. .ops = &clk_rcg2_ops,
  792. },
  793. };
  794. static struct clk_rcg2 mclk1_clk_src = {
  795. .cmd_rcgr = 0x3390,
  796. .mnd_width = 8,
  797. .hid_width = 5,
  798. .parent_map = mmcc_xo_gpll0_mmpll0_map,
  799. .freq_tbl = ftbl_mclk0_1_2_3_clk_src,
  800. .clkr.hw.init = &(struct clk_init_data){
  801. .name = "mclk1_clk_src",
  802. .parent_data = mmcc_xo_gpll0_mmpll0,
  803. .num_parents = ARRAY_SIZE(mmcc_xo_gpll0_mmpll0),
  804. .ops = &clk_rcg2_ops,
  805. },
  806. };
  807. static struct clk_rcg2 mclk2_clk_src = {
  808. .cmd_rcgr = 0x33c0,
  809. .mnd_width = 8,
  810. .hid_width = 5,
  811. .parent_map = mmcc_xo_gpll0_mmpll0_map,
  812. .freq_tbl = ftbl_mclk0_1_2_3_clk_src,
  813. .clkr.hw.init = &(struct clk_init_data){
  814. .name = "mclk2_clk_src",
  815. .parent_data = mmcc_xo_gpll0_mmpll0,
  816. .num_parents = ARRAY_SIZE(mmcc_xo_gpll0_mmpll0),
  817. .ops = &clk_rcg2_ops,
  818. },
  819. };
  820. static struct clk_rcg2 mclk3_clk_src = {
  821. .cmd_rcgr = 0x33f0,
  822. .mnd_width = 8,
  823. .hid_width = 5,
  824. .parent_map = mmcc_xo_gpll0_mmpll0_map,
  825. .freq_tbl = ftbl_mclk0_1_2_3_clk_src,
  826. .clkr.hw.init = &(struct clk_init_data){
  827. .name = "mclk3_clk_src",
  828. .parent_data = mmcc_xo_gpll0_mmpll0,
  829. .num_parents = ARRAY_SIZE(mmcc_xo_gpll0_mmpll0),
  830. .ops = &clk_rcg2_ops,
  831. },
  832. };
  833. static const struct freq_tbl ftbl_csi0_1phytimer_clk_src[] = {
  834. F(50000000, P_GPLL0, 12, 0, 0),
  835. F(100000000, P_GPLL0, 6, 0, 0),
  836. F(200000000, P_MMPLL0, 4, 0, 0),
  837. { }
  838. };
  839. static struct clk_rcg2 csi0phytimer_clk_src = {
  840. .cmd_rcgr = 0x3000,
  841. .hid_width = 5,
  842. .parent_map = mmcc_xo_gpll0_mmpll0_map,
  843. .freq_tbl = ftbl_csi0_1phytimer_clk_src,
  844. .clkr.hw.init = &(struct clk_init_data){
  845. .name = "csi0phytimer_clk_src",
  846. .parent_data = mmcc_xo_gpll0_mmpll0,
  847. .num_parents = ARRAY_SIZE(mmcc_xo_gpll0_mmpll0),
  848. .ops = &clk_rcg2_ops,
  849. },
  850. };
  851. static struct clk_rcg2 csi1phytimer_clk_src = {
  852. .cmd_rcgr = 0x3030,
  853. .hid_width = 5,
  854. .parent_map = mmcc_xo_gpll0_mmpll0_map,
  855. .freq_tbl = ftbl_csi0_1phytimer_clk_src,
  856. .clkr.hw.init = &(struct clk_init_data){
  857. .name = "csi1phytimer_clk_src",
  858. .parent_data = mmcc_xo_gpll0_mmpll0,
  859. .num_parents = ARRAY_SIZE(mmcc_xo_gpll0_mmpll0),
  860. .ops = &clk_rcg2_ops,
  861. },
  862. };
  863. static struct clk_rcg2 byte0_clk_src = {
  864. .cmd_rcgr = 0x2120,
  865. .hid_width = 5,
  866. .parent_map = mmcc_xo_dsibyte_map,
  867. .clkr.hw.init = &(struct clk_init_data){
  868. .name = "byte0_clk_src",
  869. .parent_data = mmcc_xo_dsibyte,
  870. .num_parents = ARRAY_SIZE(mmcc_xo_dsibyte),
  871. .ops = &clk_byte2_ops,
  872. .flags = CLK_SET_RATE_PARENT | CLK_GET_RATE_NOCACHE,
  873. },
  874. };
  875. static struct clk_rcg2 byte1_clk_src = {
  876. .cmd_rcgr = 0x2140,
  877. .hid_width = 5,
  878. .parent_map = mmcc_xo_dsibyte_map,
  879. .clkr.hw.init = &(struct clk_init_data){
  880. .name = "byte1_clk_src",
  881. .parent_data = mmcc_xo_dsibyte,
  882. .num_parents = ARRAY_SIZE(mmcc_xo_dsibyte),
  883. .ops = &clk_byte2_ops,
  884. .flags = CLK_SET_RATE_PARENT | CLK_GET_RATE_NOCACHE,
  885. },
  886. };
  887. static struct freq_tbl ftbl_mdss_esc0_1_clk[] = {
  888. F(19200000, P_XO, 1, 0, 0),
  889. { }
  890. };
  891. static struct clk_rcg2 esc0_clk_src = {
  892. .cmd_rcgr = 0x2160,
  893. .hid_width = 5,
  894. .parent_map = mmcc_xo_dsibyte_map,
  895. .freq_tbl = ftbl_mdss_esc0_1_clk,
  896. .clkr.hw.init = &(struct clk_init_data){
  897. .name = "esc0_clk_src",
  898. .parent_data = mmcc_xo_dsibyte,
  899. .num_parents = ARRAY_SIZE(mmcc_xo_dsibyte),
  900. .ops = &clk_rcg2_ops,
  901. },
  902. };
  903. static struct clk_rcg2 esc1_clk_src = {
  904. .cmd_rcgr = 0x2180,
  905. .hid_width = 5,
  906. .parent_map = mmcc_xo_dsibyte_map,
  907. .freq_tbl = ftbl_mdss_esc0_1_clk,
  908. .clkr.hw.init = &(struct clk_init_data){
  909. .name = "esc1_clk_src",
  910. .parent_data = mmcc_xo_dsibyte,
  911. .num_parents = ARRAY_SIZE(mmcc_xo_dsibyte),
  912. .ops = &clk_rcg2_ops,
  913. },
  914. };
  915. static struct freq_tbl extpclk_freq_tbl[] = {
  916. { .src = P_HDMIPLL },
  917. { }
  918. };
  919. static struct clk_rcg2 extpclk_clk_src = {
  920. .cmd_rcgr = 0x2060,
  921. .hid_width = 5,
  922. .parent_map = mmss_xo_hdmi_map,
  923. .freq_tbl = extpclk_freq_tbl,
  924. .clkr.hw.init = &(struct clk_init_data){
  925. .name = "extpclk_clk_src",
  926. .parent_data = mmss_xo_hdmi,
  927. .num_parents = ARRAY_SIZE(mmss_xo_hdmi),
  928. .ops = &clk_rcg2_ops,
  929. .flags = CLK_SET_RATE_PARENT,
  930. },
  931. };
  932. static struct freq_tbl ftbl_hdmi_clk_src[] = {
  933. F(19200000, P_XO, 1, 0, 0),
  934. { }
  935. };
  936. static struct clk_rcg2 hdmi_clk_src = {
  937. .cmd_rcgr = 0x2100,
  938. .hid_width = 5,
  939. .parent_map = mmcc_xo_gpll0_map,
  940. .freq_tbl = ftbl_hdmi_clk_src,
  941. .clkr.hw.init = &(struct clk_init_data){
  942. .name = "hdmi_clk_src",
  943. .parent_data = mmcc_xo_gpll0,
  944. .num_parents = ARRAY_SIZE(mmcc_xo_gpll0),
  945. .ops = &clk_rcg2_ops,
  946. },
  947. };
  948. static struct freq_tbl ftbl_mdss_vsync_clk[] = {
  949. F(19200000, P_XO, 1, 0, 0),
  950. { }
  951. };
  952. static struct clk_rcg2 vsync_clk_src = {
  953. .cmd_rcgr = 0x2080,
  954. .hid_width = 5,
  955. .parent_map = mmcc_xo_gpll0_map,
  956. .freq_tbl = ftbl_mdss_vsync_clk,
  957. .clkr.hw.init = &(struct clk_init_data){
  958. .name = "vsync_clk_src",
  959. .parent_data = mmcc_xo_gpll0,
  960. .num_parents = ARRAY_SIZE(mmcc_xo_gpll0),
  961. .ops = &clk_rcg2_ops,
  962. },
  963. };
  964. static const struct freq_tbl ftbl_rbbmtimer_clk_src[] = {
  965. F(19200000, P_XO, 1, 0, 0),
  966. { }
  967. };
  968. static struct clk_rcg2 rbbmtimer_clk_src = {
  969. .cmd_rcgr = 0x4090,
  970. .hid_width = 5,
  971. .parent_map = mmcc_xo_gpll0_map,
  972. .freq_tbl = ftbl_rbbmtimer_clk_src,
  973. .clkr.hw.init = &(struct clk_init_data){
  974. .name = "rbbmtimer_clk_src",
  975. .parent_data = mmcc_xo_gpll0,
  976. .num_parents = ARRAY_SIZE(mmcc_xo_gpll0),
  977. .ops = &clk_rcg2_ops,
  978. },
  979. };
  980. static struct clk_branch camss_ahb_clk = {
  981. .halt_reg = 0x348c,
  982. .clkr = {
  983. .enable_reg = 0x348c,
  984. .enable_mask = BIT(0),
  985. .hw.init = &(struct clk_init_data){
  986. .name = "camss_ahb_clk",
  987. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  988. .num_parents = 1,
  989. .flags = CLK_SET_RATE_PARENT,
  990. .ops = &clk_branch2_ops,
  991. },
  992. },
  993. };
  994. static struct clk_branch camss_cci_cci_ahb_clk = {
  995. .halt_reg = 0x3348,
  996. .clkr = {
  997. .enable_reg = 0x3348,
  998. .enable_mask = BIT(0),
  999. .hw.init = &(struct clk_init_data){
  1000. .name = "camss_cci_cci_ahb_clk",
  1001. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1002. .num_parents = 1,
  1003. .flags = CLK_SET_RATE_PARENT,
  1004. .ops = &clk_branch2_ops,
  1005. },
  1006. },
  1007. };
  1008. static struct clk_branch camss_cci_cci_clk = {
  1009. .halt_reg = 0x3344,
  1010. .clkr = {
  1011. .enable_reg = 0x3344,
  1012. .enable_mask = BIT(0),
  1013. .hw.init = &(struct clk_init_data){
  1014. .name = "camss_cci_cci_clk",
  1015. .parent_hws = (const struct clk_hw *[]){ &cci_clk_src.clkr.hw },
  1016. .num_parents = 1,
  1017. .ops = &clk_branch2_ops,
  1018. },
  1019. },
  1020. };
  1021. static struct clk_branch camss_vfe_cpp_ahb_clk = {
  1022. .halt_reg = 0x36b4,
  1023. .clkr = {
  1024. .enable_reg = 0x36b4,
  1025. .enable_mask = BIT(0),
  1026. .hw.init = &(struct clk_init_data){
  1027. .name = "camss_vfe_cpp_ahb_clk",
  1028. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1029. .num_parents = 1,
  1030. .flags = CLK_SET_RATE_PARENT,
  1031. .ops = &clk_branch2_ops,
  1032. },
  1033. },
  1034. };
  1035. static struct clk_branch camss_vfe_cpp_axi_clk = {
  1036. .halt_reg = 0x36c4,
  1037. .clkr = {
  1038. .enable_reg = 0x36c4,
  1039. .enable_mask = BIT(0),
  1040. .hw.init = &(struct clk_init_data){
  1041. .name = "camss_vfe_cpp_axi_clk",
  1042. .parent_hws = (const struct clk_hw *[]){ &axi_clk_src.clkr.hw },
  1043. .num_parents = 1,
  1044. .ops = &clk_branch2_ops,
  1045. },
  1046. },
  1047. };
  1048. static struct clk_branch camss_vfe_cpp_clk = {
  1049. .halt_reg = 0x36b0,
  1050. .clkr = {
  1051. .enable_reg = 0x36b0,
  1052. .enable_mask = BIT(0),
  1053. .hw.init = &(struct clk_init_data){
  1054. .name = "camss_vfe_cpp_clk",
  1055. .parent_hws = (const struct clk_hw *[]){ &cpp_clk_src.clkr.hw },
  1056. .num_parents = 1,
  1057. .ops = &clk_branch2_ops,
  1058. },
  1059. },
  1060. };
  1061. static struct clk_branch camss_csi0_ahb_clk = {
  1062. .halt_reg = 0x30bc,
  1063. .clkr = {
  1064. .enable_reg = 0x30bc,
  1065. .enable_mask = BIT(0),
  1066. .hw.init = &(struct clk_init_data){
  1067. .name = "camss_csi0_ahb_clk",
  1068. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1069. .num_parents = 1,
  1070. .flags = CLK_SET_RATE_PARENT,
  1071. .ops = &clk_branch2_ops,
  1072. },
  1073. },
  1074. };
  1075. static struct clk_branch camss_csi0_clk = {
  1076. .halt_reg = 0x30b4,
  1077. .clkr = {
  1078. .enable_reg = 0x30b4,
  1079. .enable_mask = BIT(0),
  1080. .hw.init = &(struct clk_init_data){
  1081. .name = "camss_csi0_clk",
  1082. .parent_hws = (const struct clk_hw *[]){ &csi0_clk_src.clkr.hw },
  1083. .num_parents = 1,
  1084. .ops = &clk_branch2_ops,
  1085. },
  1086. },
  1087. };
  1088. static struct clk_branch camss_csi0phy_clk = {
  1089. .halt_reg = 0x30c4,
  1090. .clkr = {
  1091. .enable_reg = 0x30c4,
  1092. .enable_mask = BIT(0),
  1093. .hw.init = &(struct clk_init_data){
  1094. .name = "camss_csi0phy_clk",
  1095. .parent_hws = (const struct clk_hw *[]){ &csi0_clk_src.clkr.hw },
  1096. .num_parents = 1,
  1097. .ops = &clk_branch2_ops,
  1098. },
  1099. },
  1100. };
  1101. static struct clk_branch camss_csi0pix_clk = {
  1102. .halt_reg = 0x30e4,
  1103. .clkr = {
  1104. .enable_reg = 0x30e4,
  1105. .enable_mask = BIT(0),
  1106. .hw.init = &(struct clk_init_data){
  1107. .name = "camss_csi0pix_clk",
  1108. .parent_hws = (const struct clk_hw *[]){ &csi0_clk_src.clkr.hw },
  1109. .num_parents = 1,
  1110. .ops = &clk_branch2_ops,
  1111. },
  1112. },
  1113. };
  1114. static struct clk_branch camss_csi0rdi_clk = {
  1115. .halt_reg = 0x30d4,
  1116. .clkr = {
  1117. .enable_reg = 0x30d4,
  1118. .enable_mask = BIT(0),
  1119. .hw.init = &(struct clk_init_data){
  1120. .name = "camss_csi0rdi_clk",
  1121. .parent_hws = (const struct clk_hw *[]){ &csi0_clk_src.clkr.hw },
  1122. .num_parents = 1,
  1123. .ops = &clk_branch2_ops,
  1124. },
  1125. },
  1126. };
  1127. static struct clk_branch camss_csi1_ahb_clk = {
  1128. .halt_reg = 0x3128,
  1129. .clkr = {
  1130. .enable_reg = 0x3128,
  1131. .enable_mask = BIT(0),
  1132. .hw.init = &(struct clk_init_data){
  1133. .name = "camss_csi1_ahb_clk",
  1134. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1135. .num_parents = 1,
  1136. .flags = CLK_SET_RATE_PARENT,
  1137. .ops = &clk_branch2_ops,
  1138. },
  1139. },
  1140. };
  1141. static struct clk_branch camss_csi1_clk = {
  1142. .halt_reg = 0x3124,
  1143. .clkr = {
  1144. .enable_reg = 0x3124,
  1145. .enable_mask = BIT(0),
  1146. .hw.init = &(struct clk_init_data){
  1147. .name = "camss_csi1_clk",
  1148. .parent_hws = (const struct clk_hw *[]){ &csi1_clk_src.clkr.hw },
  1149. .num_parents = 1,
  1150. .ops = &clk_branch2_ops,
  1151. },
  1152. },
  1153. };
  1154. static struct clk_branch camss_csi1phy_clk = {
  1155. .halt_reg = 0x3134,
  1156. .clkr = {
  1157. .enable_reg = 0x3134,
  1158. .enable_mask = BIT(0),
  1159. .hw.init = &(struct clk_init_data){
  1160. .name = "camss_csi1phy_clk",
  1161. .parent_hws = (const struct clk_hw *[]){ &csi1_clk_src.clkr.hw },
  1162. .num_parents = 1,
  1163. .ops = &clk_branch2_ops,
  1164. },
  1165. },
  1166. };
  1167. static struct clk_branch camss_csi1pix_clk = {
  1168. .halt_reg = 0x3154,
  1169. .clkr = {
  1170. .enable_reg = 0x3154,
  1171. .enable_mask = BIT(0),
  1172. .hw.init = &(struct clk_init_data){
  1173. .name = "camss_csi1pix_clk",
  1174. .parent_hws = (const struct clk_hw *[]){ &csi1_clk_src.clkr.hw },
  1175. .num_parents = 1,
  1176. .ops = &clk_branch2_ops,
  1177. },
  1178. },
  1179. };
  1180. static struct clk_branch camss_csi1rdi_clk = {
  1181. .halt_reg = 0x3144,
  1182. .clkr = {
  1183. .enable_reg = 0x3144,
  1184. .enable_mask = BIT(0),
  1185. .hw.init = &(struct clk_init_data){
  1186. .name = "camss_csi1rdi_clk",
  1187. .parent_hws = (const struct clk_hw *[]){ &csi1_clk_src.clkr.hw },
  1188. .num_parents = 1,
  1189. .ops = &clk_branch2_ops,
  1190. },
  1191. },
  1192. };
  1193. static struct clk_branch camss_csi2_ahb_clk = {
  1194. .halt_reg = 0x3188,
  1195. .clkr = {
  1196. .enable_reg = 0x3188,
  1197. .enable_mask = BIT(0),
  1198. .hw.init = &(struct clk_init_data){
  1199. .name = "camss_csi2_ahb_clk",
  1200. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1201. .num_parents = 1,
  1202. .flags = CLK_SET_RATE_PARENT,
  1203. .ops = &clk_branch2_ops,
  1204. },
  1205. },
  1206. };
  1207. static struct clk_branch camss_csi2_clk = {
  1208. .halt_reg = 0x3184,
  1209. .clkr = {
  1210. .enable_reg = 0x3184,
  1211. .enable_mask = BIT(0),
  1212. .hw.init = &(struct clk_init_data){
  1213. .name = "camss_csi2_clk",
  1214. .parent_hws = (const struct clk_hw *[]){ &csi1_clk_src.clkr.hw },
  1215. .num_parents = 1,
  1216. .ops = &clk_branch2_ops,
  1217. },
  1218. },
  1219. };
  1220. static struct clk_branch camss_csi2phy_clk = {
  1221. .halt_reg = 0x3194,
  1222. .clkr = {
  1223. .enable_reg = 0x3194,
  1224. .enable_mask = BIT(0),
  1225. .hw.init = &(struct clk_init_data){
  1226. .name = "camss_csi2phy_clk",
  1227. .parent_hws = (const struct clk_hw *[]){ &csi1_clk_src.clkr.hw },
  1228. .num_parents = 1,
  1229. .ops = &clk_branch2_ops,
  1230. },
  1231. },
  1232. };
  1233. static struct clk_branch camss_csi2pix_clk = {
  1234. .halt_reg = 0x31b4,
  1235. .clkr = {
  1236. .enable_reg = 0x31b4,
  1237. .enable_mask = BIT(0),
  1238. .hw.init = &(struct clk_init_data){
  1239. .name = "camss_csi2pix_clk",
  1240. .parent_hws = (const struct clk_hw *[]){ &csi1_clk_src.clkr.hw },
  1241. .num_parents = 1,
  1242. .ops = &clk_branch2_ops,
  1243. },
  1244. },
  1245. };
  1246. static struct clk_branch camss_csi2rdi_clk = {
  1247. .halt_reg = 0x31a4,
  1248. .clkr = {
  1249. .enable_reg = 0x31a4,
  1250. .enable_mask = BIT(0),
  1251. .hw.init = &(struct clk_init_data){
  1252. .name = "camss_csi2rdi_clk",
  1253. .parent_hws = (const struct clk_hw *[]){ &csi1_clk_src.clkr.hw },
  1254. .num_parents = 1,
  1255. .ops = &clk_branch2_ops,
  1256. },
  1257. },
  1258. };
  1259. static struct clk_branch camss_csi3_ahb_clk = {
  1260. .halt_reg = 0x31e8,
  1261. .clkr = {
  1262. .enable_reg = 0x31e8,
  1263. .enable_mask = BIT(0),
  1264. .hw.init = &(struct clk_init_data){
  1265. .name = "camss_csi3_ahb_clk",
  1266. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1267. .num_parents = 1,
  1268. .flags = CLK_SET_RATE_PARENT,
  1269. .ops = &clk_branch2_ops,
  1270. },
  1271. },
  1272. };
  1273. static struct clk_branch camss_csi3_clk = {
  1274. .halt_reg = 0x31e4,
  1275. .clkr = {
  1276. .enable_reg = 0x31e4,
  1277. .enable_mask = BIT(0),
  1278. .hw.init = &(struct clk_init_data){
  1279. .name = "camss_csi3_clk",
  1280. .parent_hws = (const struct clk_hw *[]){ &csi1_clk_src.clkr.hw },
  1281. .num_parents = 1,
  1282. .ops = &clk_branch2_ops,
  1283. },
  1284. },
  1285. };
  1286. static struct clk_branch camss_csi3phy_clk = {
  1287. .halt_reg = 0x31f4,
  1288. .clkr = {
  1289. .enable_reg = 0x31f4,
  1290. .enable_mask = BIT(0),
  1291. .hw.init = &(struct clk_init_data){
  1292. .name = "camss_csi3phy_clk",
  1293. .parent_hws = (const struct clk_hw *[]){ &csi1_clk_src.clkr.hw },
  1294. .num_parents = 1,
  1295. .ops = &clk_branch2_ops,
  1296. },
  1297. },
  1298. };
  1299. static struct clk_branch camss_csi3pix_clk = {
  1300. .halt_reg = 0x3214,
  1301. .clkr = {
  1302. .enable_reg = 0x3214,
  1303. .enable_mask = BIT(0),
  1304. .hw.init = &(struct clk_init_data){
  1305. .name = "camss_csi3pix_clk",
  1306. .parent_hws = (const struct clk_hw *[]){ &csi1_clk_src.clkr.hw },
  1307. .num_parents = 1,
  1308. .ops = &clk_branch2_ops,
  1309. },
  1310. },
  1311. };
  1312. static struct clk_branch camss_csi3rdi_clk = {
  1313. .halt_reg = 0x3204,
  1314. .clkr = {
  1315. .enable_reg = 0x3204,
  1316. .enable_mask = BIT(0),
  1317. .hw.init = &(struct clk_init_data){
  1318. .name = "camss_csi3rdi_clk",
  1319. .parent_hws = (const struct clk_hw *[]){ &csi1_clk_src.clkr.hw },
  1320. .num_parents = 1,
  1321. .ops = &clk_branch2_ops,
  1322. },
  1323. },
  1324. };
  1325. static struct clk_branch camss_csi_vfe0_clk = {
  1326. .halt_reg = 0x3704,
  1327. .clkr = {
  1328. .enable_reg = 0x3704,
  1329. .enable_mask = BIT(0),
  1330. .hw.init = &(struct clk_init_data){
  1331. .name = "camss_csi_vfe0_clk",
  1332. .parent_hws = (const struct clk_hw *[]){ &vfe0_clk_src.clkr.hw },
  1333. .num_parents = 1,
  1334. .ops = &clk_branch2_ops,
  1335. },
  1336. },
  1337. };
  1338. static struct clk_branch camss_csi_vfe1_clk = {
  1339. .halt_reg = 0x3714,
  1340. .clkr = {
  1341. .enable_reg = 0x3714,
  1342. .enable_mask = BIT(0),
  1343. .hw.init = &(struct clk_init_data){
  1344. .name = "camss_csi_vfe1_clk",
  1345. .parent_hws = (const struct clk_hw *[]){ &vfe1_clk_src.clkr.hw },
  1346. .num_parents = 1,
  1347. .ops = &clk_branch2_ops,
  1348. },
  1349. },
  1350. };
  1351. static struct clk_branch camss_gp0_clk = {
  1352. .halt_reg = 0x3444,
  1353. .clkr = {
  1354. .enable_reg = 0x3444,
  1355. .enable_mask = BIT(0),
  1356. .hw.init = &(struct clk_init_data){
  1357. .name = "camss_gp0_clk",
  1358. .parent_hws = (const struct clk_hw *[]){ &mmss_gp0_clk_src.clkr.hw },
  1359. .num_parents = 1,
  1360. .ops = &clk_branch2_ops,
  1361. },
  1362. },
  1363. };
  1364. static struct clk_branch camss_gp1_clk = {
  1365. .halt_reg = 0x3474,
  1366. .clkr = {
  1367. .enable_reg = 0x3474,
  1368. .enable_mask = BIT(0),
  1369. .hw.init = &(struct clk_init_data){
  1370. .name = "camss_gp1_clk",
  1371. .parent_hws = (const struct clk_hw *[]){ &mmss_gp1_clk_src.clkr.hw },
  1372. .num_parents = 1,
  1373. .ops = &clk_branch2_ops,
  1374. },
  1375. },
  1376. };
  1377. static struct clk_branch camss_ispif_ahb_clk = {
  1378. .halt_reg = 0x3224,
  1379. .clkr = {
  1380. .enable_reg = 0x3224,
  1381. .enable_mask = BIT(0),
  1382. .hw.init = &(struct clk_init_data){
  1383. .name = "camss_ispif_ahb_clk",
  1384. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1385. .num_parents = 1,
  1386. .flags = CLK_SET_RATE_PARENT,
  1387. .ops = &clk_branch2_ops,
  1388. },
  1389. },
  1390. };
  1391. static struct clk_branch camss_jpeg_dma_clk = {
  1392. .halt_reg = 0x35c0,
  1393. .clkr = {
  1394. .enable_reg = 0x35c0,
  1395. .enable_mask = BIT(0),
  1396. .hw.init = &(struct clk_init_data){
  1397. .name = "camss_jpeg_dma_clk",
  1398. .parent_hws = (const struct clk_hw *[]){ &jpeg_dma_clk_src.clkr.hw },
  1399. .num_parents = 1,
  1400. .ops = &clk_branch2_ops,
  1401. },
  1402. },
  1403. };
  1404. static struct clk_branch camss_jpeg_jpeg0_clk = {
  1405. .halt_reg = 0x35a8,
  1406. .clkr = {
  1407. .enable_reg = 0x35a8,
  1408. .enable_mask = BIT(0),
  1409. .hw.init = &(struct clk_init_data){
  1410. .name = "camss_jpeg_jpeg0_clk",
  1411. .parent_hws = (const struct clk_hw *[]){ &jpeg0_clk_src.clkr.hw },
  1412. .num_parents = 1,
  1413. .ops = &clk_branch2_ops,
  1414. },
  1415. },
  1416. };
  1417. static struct clk_branch camss_jpeg_jpeg1_clk = {
  1418. .halt_reg = 0x35ac,
  1419. .clkr = {
  1420. .enable_reg = 0x35ac,
  1421. .enable_mask = BIT(0),
  1422. .hw.init = &(struct clk_init_data){
  1423. .name = "camss_jpeg_jpeg1_clk",
  1424. .parent_hws = (const struct clk_hw *[]){ &jpeg1_clk_src.clkr.hw },
  1425. .num_parents = 1,
  1426. .ops = &clk_branch2_ops,
  1427. },
  1428. },
  1429. };
  1430. static struct clk_branch camss_jpeg_jpeg2_clk = {
  1431. .halt_reg = 0x35b0,
  1432. .clkr = {
  1433. .enable_reg = 0x35b0,
  1434. .enable_mask = BIT(0),
  1435. .hw.init = &(struct clk_init_data){
  1436. .name = "camss_jpeg_jpeg2_clk",
  1437. .parent_hws = (const struct clk_hw *[]){ &jpeg2_clk_src.clkr.hw },
  1438. .num_parents = 1,
  1439. .ops = &clk_branch2_ops,
  1440. },
  1441. },
  1442. };
  1443. static struct clk_branch camss_jpeg_jpeg_ahb_clk = {
  1444. .halt_reg = 0x35b4,
  1445. .clkr = {
  1446. .enable_reg = 0x35b4,
  1447. .enable_mask = BIT(0),
  1448. .hw.init = &(struct clk_init_data){
  1449. .name = "camss_jpeg_jpeg_ahb_clk",
  1450. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1451. .num_parents = 1,
  1452. .flags = CLK_SET_RATE_PARENT,
  1453. .ops = &clk_branch2_ops,
  1454. },
  1455. },
  1456. };
  1457. static struct clk_branch camss_jpeg_jpeg_axi_clk = {
  1458. .halt_reg = 0x35b8,
  1459. .clkr = {
  1460. .enable_reg = 0x35b8,
  1461. .enable_mask = BIT(0),
  1462. .hw.init = &(struct clk_init_data){
  1463. .name = "camss_jpeg_jpeg_axi_clk",
  1464. .parent_hws = (const struct clk_hw *[]){ &axi_clk_src.clkr.hw },
  1465. .num_parents = 1,
  1466. .ops = &clk_branch2_ops,
  1467. },
  1468. },
  1469. };
  1470. static struct clk_branch camss_mclk0_clk = {
  1471. .halt_reg = 0x3384,
  1472. .clkr = {
  1473. .enable_reg = 0x3384,
  1474. .enable_mask = BIT(0),
  1475. .hw.init = &(struct clk_init_data){
  1476. .name = "camss_mclk0_clk",
  1477. .parent_hws = (const struct clk_hw *[]){ &mclk0_clk_src.clkr.hw },
  1478. .num_parents = 1,
  1479. .ops = &clk_branch2_ops,
  1480. },
  1481. },
  1482. };
  1483. static struct clk_branch camss_mclk1_clk = {
  1484. .halt_reg = 0x33b4,
  1485. .clkr = {
  1486. .enable_reg = 0x33b4,
  1487. .enable_mask = BIT(0),
  1488. .hw.init = &(struct clk_init_data){
  1489. .name = "camss_mclk1_clk",
  1490. .parent_hws = (const struct clk_hw *[]){ &mclk1_clk_src.clkr.hw },
  1491. .num_parents = 1,
  1492. .ops = &clk_branch2_ops,
  1493. },
  1494. },
  1495. };
  1496. static struct clk_branch camss_mclk2_clk = {
  1497. .halt_reg = 0x33e4,
  1498. .clkr = {
  1499. .enable_reg = 0x33e4,
  1500. .enable_mask = BIT(0),
  1501. .hw.init = &(struct clk_init_data){
  1502. .name = "camss_mclk2_clk",
  1503. .parent_hws = (const struct clk_hw *[]){ &mclk2_clk_src.clkr.hw },
  1504. .num_parents = 1,
  1505. .ops = &clk_branch2_ops,
  1506. },
  1507. },
  1508. };
  1509. static struct clk_branch camss_mclk3_clk = {
  1510. .halt_reg = 0x3414,
  1511. .clkr = {
  1512. .enable_reg = 0x3414,
  1513. .enable_mask = BIT(0),
  1514. .hw.init = &(struct clk_init_data){
  1515. .name = "camss_mclk3_clk",
  1516. .parent_hws = (const struct clk_hw *[]){ &mclk3_clk_src.clkr.hw },
  1517. .num_parents = 1,
  1518. .ops = &clk_branch2_ops,
  1519. },
  1520. },
  1521. };
  1522. static struct clk_branch camss_micro_ahb_clk = {
  1523. .halt_reg = 0x3494,
  1524. .clkr = {
  1525. .enable_reg = 0x3494,
  1526. .enable_mask = BIT(0),
  1527. .hw.init = &(struct clk_init_data){
  1528. .name = "camss_micro_ahb_clk",
  1529. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1530. .num_parents = 1,
  1531. .flags = CLK_SET_RATE_PARENT,
  1532. .ops = &clk_branch2_ops,
  1533. },
  1534. },
  1535. };
  1536. static struct clk_branch camss_phy0_csi0phytimer_clk = {
  1537. .halt_reg = 0x3024,
  1538. .clkr = {
  1539. .enable_reg = 0x3024,
  1540. .enable_mask = BIT(0),
  1541. .hw.init = &(struct clk_init_data){
  1542. .name = "camss_phy0_csi0phytimer_clk",
  1543. .parent_hws = (const struct clk_hw *[]){ &csi0phytimer_clk_src.clkr.hw },
  1544. .num_parents = 1,
  1545. .ops = &clk_branch2_ops,
  1546. },
  1547. },
  1548. };
  1549. static struct clk_branch camss_phy1_csi1phytimer_clk = {
  1550. .halt_reg = 0x3054,
  1551. .clkr = {
  1552. .enable_reg = 0x3054,
  1553. .enable_mask = BIT(0),
  1554. .hw.init = &(struct clk_init_data){
  1555. .name = "camss_phy1_csi1phytimer_clk",
  1556. .parent_hws = (const struct clk_hw *[]){ &csi1phytimer_clk_src.clkr.hw },
  1557. .num_parents = 1,
  1558. .ops = &clk_branch2_ops,
  1559. },
  1560. },
  1561. };
  1562. static struct clk_branch camss_phy2_csi2phytimer_clk = {
  1563. .halt_reg = 0x3084,
  1564. .clkr = {
  1565. .enable_reg = 0x3084,
  1566. .enable_mask = BIT(0),
  1567. .hw.init = &(struct clk_init_data){
  1568. .name = "camss_phy2_csi2phytimer_clk",
  1569. .parent_hws = (const struct clk_hw *[]){ &csi2phytimer_clk_src.clkr.hw },
  1570. .num_parents = 1,
  1571. .ops = &clk_branch2_ops,
  1572. },
  1573. },
  1574. };
  1575. static struct clk_branch camss_top_ahb_clk = {
  1576. .halt_reg = 0x3484,
  1577. .clkr = {
  1578. .enable_reg = 0x3484,
  1579. .enable_mask = BIT(0),
  1580. .hw.init = &(struct clk_init_data){
  1581. .name = "camss_top_ahb_clk",
  1582. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1583. .num_parents = 1,
  1584. .flags = CLK_SET_RATE_PARENT,
  1585. .ops = &clk_branch2_ops,
  1586. },
  1587. },
  1588. };
  1589. static struct clk_branch camss_vfe_vfe0_clk = {
  1590. .halt_reg = 0x36a8,
  1591. .clkr = {
  1592. .enable_reg = 0x36a8,
  1593. .enable_mask = BIT(0),
  1594. .hw.init = &(struct clk_init_data){
  1595. .name = "camss_vfe_vfe0_clk",
  1596. .parent_hws = (const struct clk_hw *[]){ &vfe0_clk_src.clkr.hw },
  1597. .num_parents = 1,
  1598. .ops = &clk_branch2_ops,
  1599. },
  1600. },
  1601. };
  1602. static struct clk_branch camss_vfe_vfe1_clk = {
  1603. .halt_reg = 0x36ac,
  1604. .clkr = {
  1605. .enable_reg = 0x36ac,
  1606. .enable_mask = BIT(0),
  1607. .hw.init = &(struct clk_init_data){
  1608. .name = "camss_vfe_vfe1_clk",
  1609. .parent_hws = (const struct clk_hw *[]){ &vfe1_clk_src.clkr.hw },
  1610. .num_parents = 1,
  1611. .ops = &clk_branch2_ops,
  1612. },
  1613. },
  1614. };
  1615. static struct clk_branch camss_vfe_vfe_ahb_clk = {
  1616. .halt_reg = 0x36b8,
  1617. .clkr = {
  1618. .enable_reg = 0x36b8,
  1619. .enable_mask = BIT(0),
  1620. .hw.init = &(struct clk_init_data){
  1621. .name = "camss_vfe_vfe_ahb_clk",
  1622. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1623. .num_parents = 1,
  1624. .flags = CLK_SET_RATE_PARENT,
  1625. .ops = &clk_branch2_ops,
  1626. },
  1627. },
  1628. };
  1629. static struct clk_branch camss_vfe_vfe_axi_clk = {
  1630. .halt_reg = 0x36bc,
  1631. .clkr = {
  1632. .enable_reg = 0x36bc,
  1633. .enable_mask = BIT(0),
  1634. .hw.init = &(struct clk_init_data){
  1635. .name = "camss_vfe_vfe_axi_clk",
  1636. .parent_hws = (const struct clk_hw *[]){ &axi_clk_src.clkr.hw },
  1637. .num_parents = 1,
  1638. .ops = &clk_branch2_ops,
  1639. },
  1640. },
  1641. };
  1642. static struct clk_branch fd_ahb_clk = {
  1643. .halt_reg = 0x3b74,
  1644. .clkr = {
  1645. .enable_reg = 0x3b74,
  1646. .enable_mask = BIT(0),
  1647. .hw.init = &(struct clk_init_data){
  1648. .name = "fd_ahb_clk",
  1649. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1650. .num_parents = 1,
  1651. .ops = &clk_branch2_ops,
  1652. },
  1653. },
  1654. };
  1655. static struct clk_branch fd_axi_clk = {
  1656. .halt_reg = 0x3b70,
  1657. .clkr = {
  1658. .enable_reg = 0x3b70,
  1659. .enable_mask = BIT(0),
  1660. .hw.init = &(struct clk_init_data){
  1661. .name = "fd_axi_clk",
  1662. .parent_hws = (const struct clk_hw *[]){ &axi_clk_src.clkr.hw },
  1663. .num_parents = 1,
  1664. .ops = &clk_branch2_ops,
  1665. },
  1666. },
  1667. };
  1668. static struct clk_branch fd_core_clk = {
  1669. .halt_reg = 0x3b68,
  1670. .clkr = {
  1671. .enable_reg = 0x3b68,
  1672. .enable_mask = BIT(0),
  1673. .hw.init = &(struct clk_init_data){
  1674. .name = "fd_core_clk",
  1675. .parent_hws = (const struct clk_hw *[]){ &fd_core_clk_src.clkr.hw },
  1676. .num_parents = 1,
  1677. .ops = &clk_branch2_ops,
  1678. },
  1679. },
  1680. };
  1681. static struct clk_branch fd_core_uar_clk = {
  1682. .halt_reg = 0x3b6c,
  1683. .clkr = {
  1684. .enable_reg = 0x3b6c,
  1685. .enable_mask = BIT(0),
  1686. .hw.init = &(struct clk_init_data){
  1687. .name = "fd_core_uar_clk",
  1688. .parent_hws = (const struct clk_hw *[]){ &fd_core_clk_src.clkr.hw },
  1689. .num_parents = 1,
  1690. .ops = &clk_branch2_ops,
  1691. },
  1692. },
  1693. };
  1694. static struct clk_branch mdss_ahb_clk = {
  1695. .halt_reg = 0x2308,
  1696. .halt_check = BRANCH_HALT,
  1697. .clkr = {
  1698. .enable_reg = 0x2308,
  1699. .enable_mask = BIT(0),
  1700. .hw.init = &(struct clk_init_data){
  1701. .name = "mdss_ahb_clk",
  1702. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1703. .num_parents = 1,
  1704. .flags = CLK_SET_RATE_PARENT,
  1705. .ops = &clk_branch2_ops,
  1706. },
  1707. },
  1708. };
  1709. static struct clk_branch mdss_axi_clk = {
  1710. .halt_reg = 0x2310,
  1711. .clkr = {
  1712. .enable_reg = 0x2310,
  1713. .enable_mask = BIT(0),
  1714. .hw.init = &(struct clk_init_data){
  1715. .name = "mdss_axi_clk",
  1716. .parent_hws = (const struct clk_hw *[]){ &axi_clk_src.clkr.hw },
  1717. .num_parents = 1,
  1718. .flags = CLK_SET_RATE_PARENT,
  1719. .ops = &clk_branch2_ops,
  1720. },
  1721. },
  1722. };
  1723. static struct clk_branch mdss_byte0_clk = {
  1724. .halt_reg = 0x233c,
  1725. .clkr = {
  1726. .enable_reg = 0x233c,
  1727. .enable_mask = BIT(0),
  1728. .hw.init = &(struct clk_init_data){
  1729. .name = "mdss_byte0_clk",
  1730. .parent_hws = (const struct clk_hw *[]){ &byte0_clk_src.clkr.hw },
  1731. .num_parents = 1,
  1732. .flags = CLK_SET_RATE_PARENT,
  1733. .ops = &clk_branch2_ops,
  1734. },
  1735. },
  1736. };
  1737. static struct clk_branch mdss_byte1_clk = {
  1738. .halt_reg = 0x2340,
  1739. .clkr = {
  1740. .enable_reg = 0x2340,
  1741. .enable_mask = BIT(0),
  1742. .hw.init = &(struct clk_init_data){
  1743. .name = "mdss_byte1_clk",
  1744. .parent_hws = (const struct clk_hw *[]){ &byte1_clk_src.clkr.hw },
  1745. .num_parents = 1,
  1746. .flags = CLK_SET_RATE_PARENT,
  1747. .ops = &clk_branch2_ops,
  1748. },
  1749. },
  1750. };
  1751. static struct clk_branch mdss_esc0_clk = {
  1752. .halt_reg = 0x2344,
  1753. .clkr = {
  1754. .enable_reg = 0x2344,
  1755. .enable_mask = BIT(0),
  1756. .hw.init = &(struct clk_init_data){
  1757. .name = "mdss_esc0_clk",
  1758. .parent_hws = (const struct clk_hw *[]){ &esc0_clk_src.clkr.hw },
  1759. .num_parents = 1,
  1760. .flags = CLK_SET_RATE_PARENT,
  1761. .ops = &clk_branch2_ops,
  1762. },
  1763. },
  1764. };
  1765. static struct clk_branch mdss_esc1_clk = {
  1766. .halt_reg = 0x2348,
  1767. .clkr = {
  1768. .enable_reg = 0x2348,
  1769. .enable_mask = BIT(0),
  1770. .hw.init = &(struct clk_init_data){
  1771. .name = "mdss_esc1_clk",
  1772. .parent_hws = (const struct clk_hw *[]){ &esc1_clk_src.clkr.hw },
  1773. .num_parents = 1,
  1774. .flags = CLK_SET_RATE_PARENT,
  1775. .ops = &clk_branch2_ops,
  1776. },
  1777. },
  1778. };
  1779. static struct clk_branch mdss_extpclk_clk = {
  1780. .halt_reg = 0x2324,
  1781. .clkr = {
  1782. .enable_reg = 0x2324,
  1783. .enable_mask = BIT(0),
  1784. .hw.init = &(struct clk_init_data){
  1785. .name = "mdss_extpclk_clk",
  1786. .parent_hws = (const struct clk_hw *[]){ &extpclk_clk_src.clkr.hw },
  1787. .num_parents = 1,
  1788. .flags = CLK_SET_RATE_PARENT,
  1789. .ops = &clk_branch2_ops,
  1790. },
  1791. },
  1792. };
  1793. static struct clk_branch mdss_hdmi_ahb_clk = {
  1794. .halt_reg = 0x230c,
  1795. .clkr = {
  1796. .enable_reg = 0x230c,
  1797. .enable_mask = BIT(0),
  1798. .hw.init = &(struct clk_init_data){
  1799. .name = "mdss_hdmi_ahb_clk",
  1800. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1801. .num_parents = 1,
  1802. .flags = CLK_SET_RATE_PARENT,
  1803. .ops = &clk_branch2_ops,
  1804. },
  1805. },
  1806. };
  1807. static struct clk_branch mdss_hdmi_clk = {
  1808. .halt_reg = 0x2338,
  1809. .clkr = {
  1810. .enable_reg = 0x2338,
  1811. .enable_mask = BIT(0),
  1812. .hw.init = &(struct clk_init_data){
  1813. .name = "mdss_hdmi_clk",
  1814. .parent_hws = (const struct clk_hw *[]){ &hdmi_clk_src.clkr.hw },
  1815. .num_parents = 1,
  1816. .flags = CLK_SET_RATE_PARENT,
  1817. .ops = &clk_branch2_ops,
  1818. },
  1819. },
  1820. };
  1821. static struct clk_branch mdss_mdp_clk = {
  1822. .halt_reg = 0x231c,
  1823. .clkr = {
  1824. .enable_reg = 0x231c,
  1825. .enable_mask = BIT(0),
  1826. .hw.init = &(struct clk_init_data){
  1827. .name = "mdss_mdp_clk",
  1828. .parent_hws = (const struct clk_hw *[]){ &mdp_clk_src.clkr.hw },
  1829. .num_parents = 1,
  1830. .flags = CLK_SET_RATE_PARENT,
  1831. .ops = &clk_branch2_ops,
  1832. },
  1833. },
  1834. };
  1835. static struct clk_branch mdss_pclk0_clk = {
  1836. .halt_reg = 0x2314,
  1837. .clkr = {
  1838. .enable_reg = 0x2314,
  1839. .enable_mask = BIT(0),
  1840. .hw.init = &(struct clk_init_data){
  1841. .name = "mdss_pclk0_clk",
  1842. .parent_hws = (const struct clk_hw *[]){ &pclk0_clk_src.clkr.hw },
  1843. .num_parents = 1,
  1844. .flags = CLK_SET_RATE_PARENT,
  1845. .ops = &clk_branch2_ops,
  1846. },
  1847. },
  1848. };
  1849. static struct clk_branch mdss_pclk1_clk = {
  1850. .halt_reg = 0x2318,
  1851. .clkr = {
  1852. .enable_reg = 0x2318,
  1853. .enable_mask = BIT(0),
  1854. .hw.init = &(struct clk_init_data){
  1855. .name = "mdss_pclk1_clk",
  1856. .parent_hws = (const struct clk_hw *[]){ &pclk1_clk_src.clkr.hw },
  1857. .num_parents = 1,
  1858. .flags = CLK_SET_RATE_PARENT,
  1859. .ops = &clk_branch2_ops,
  1860. },
  1861. },
  1862. };
  1863. static struct clk_branch mdss_vsync_clk = {
  1864. .halt_reg = 0x2328,
  1865. .clkr = {
  1866. .enable_reg = 0x2328,
  1867. .enable_mask = BIT(0),
  1868. .hw.init = &(struct clk_init_data){
  1869. .name = "mdss_vsync_clk",
  1870. .parent_hws = (const struct clk_hw *[]){ &vsync_clk_src.clkr.hw },
  1871. .num_parents = 1,
  1872. .flags = CLK_SET_RATE_PARENT,
  1873. .ops = &clk_branch2_ops,
  1874. },
  1875. },
  1876. };
  1877. static struct clk_branch mmss_misc_ahb_clk = {
  1878. .halt_reg = 0x502c,
  1879. .clkr = {
  1880. .enable_reg = 0x502c,
  1881. .enable_mask = BIT(0),
  1882. .hw.init = &(struct clk_init_data){
  1883. .name = "mmss_misc_ahb_clk",
  1884. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1885. .num_parents = 1,
  1886. .flags = CLK_SET_RATE_PARENT,
  1887. .ops = &clk_branch2_ops,
  1888. },
  1889. },
  1890. };
  1891. static struct clk_branch mmss_mmssnoc_axi_clk = {
  1892. .halt_reg = 0x506c,
  1893. .clkr = {
  1894. .enable_reg = 0x506c,
  1895. .enable_mask = BIT(0),
  1896. .hw.init = &(struct clk_init_data){
  1897. .name = "mmss_mmssnoc_axi_clk",
  1898. .parent_hws = (const struct clk_hw *[]){ &axi_clk_src.clkr.hw },
  1899. .num_parents = 1,
  1900. /* Gating this clock will wreck havoc among MMSS! */
  1901. .flags = CLK_SET_RATE_PARENT | CLK_IS_CRITICAL,
  1902. .ops = &clk_branch2_ops,
  1903. },
  1904. },
  1905. };
  1906. static struct clk_branch mmss_s0_axi_clk = {
  1907. .halt_reg = 0x5064,
  1908. .clkr = {
  1909. .enable_reg = 0x5064,
  1910. .enable_mask = BIT(0),
  1911. .hw.init = &(struct clk_init_data){
  1912. .name = "mmss_s0_axi_clk",
  1913. .parent_hws = (const struct clk_hw *[]){ &axi_clk_src.clkr.hw, },
  1914. .num_parents = 1,
  1915. .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
  1916. .ops = &clk_branch2_ops,
  1917. },
  1918. },
  1919. };
  1920. static struct clk_branch ocmemcx_ocmemnoc_clk = {
  1921. .halt_reg = 0x4058,
  1922. .clkr = {
  1923. .enable_reg = 0x4058,
  1924. .enable_mask = BIT(0),
  1925. .hw.init = &(struct clk_init_data){
  1926. .name = "ocmemcx_ocmemnoc_clk",
  1927. .parent_hws = (const struct clk_hw *[]){ &ocmemnoc_clk_src.clkr.hw },
  1928. .num_parents = 1,
  1929. .flags = CLK_SET_RATE_PARENT,
  1930. .ops = &clk_branch2_ops,
  1931. },
  1932. },
  1933. };
  1934. static struct clk_branch oxili_gfx3d_clk = {
  1935. .halt_reg = 0x4028,
  1936. .clkr = {
  1937. .enable_reg = 0x4028,
  1938. .enable_mask = BIT(0),
  1939. .hw.init = &(struct clk_init_data){
  1940. .name = "oxili_gfx3d_clk",
  1941. .parent_data = &(const struct clk_parent_data){
  1942. .fw_name = "oxili_gfx3d_clk_src",
  1943. .name = "oxili_gfx3d_clk_src"
  1944. },
  1945. .num_parents = 1,
  1946. .flags = CLK_SET_RATE_PARENT,
  1947. .ops = &clk_branch2_ops,
  1948. },
  1949. },
  1950. };
  1951. static struct clk_branch oxili_rbbmtimer_clk = {
  1952. .halt_reg = 0x40b0,
  1953. .clkr = {
  1954. .enable_reg = 0x40b0,
  1955. .enable_mask = BIT(0),
  1956. .hw.init = &(struct clk_init_data){
  1957. .name = "oxili_rbbmtimer_clk",
  1958. .parent_hws = (const struct clk_hw *[]){ &rbbmtimer_clk_src.clkr.hw },
  1959. .num_parents = 1,
  1960. .flags = CLK_SET_RATE_PARENT,
  1961. .ops = &clk_branch2_ops,
  1962. },
  1963. },
  1964. };
  1965. static struct clk_branch oxilicx_ahb_clk = {
  1966. .halt_reg = 0x403c,
  1967. .clkr = {
  1968. .enable_reg = 0x403c,
  1969. .enable_mask = BIT(0),
  1970. .hw.init = &(struct clk_init_data){
  1971. .name = "oxilicx_ahb_clk",
  1972. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1973. .num_parents = 1,
  1974. .flags = CLK_SET_RATE_PARENT,
  1975. .ops = &clk_branch2_ops,
  1976. },
  1977. },
  1978. };
  1979. static struct clk_branch venus0_ahb_clk = {
  1980. .halt_reg = 0x1030,
  1981. .clkr = {
  1982. .enable_reg = 0x1030,
  1983. .enable_mask = BIT(0),
  1984. .hw.init = &(struct clk_init_data){
  1985. .name = "venus0_ahb_clk",
  1986. .parent_hws = (const struct clk_hw *[]){ &ahb_clk_src.clkr.hw },
  1987. .num_parents = 1,
  1988. .flags = CLK_SET_RATE_PARENT,
  1989. .ops = &clk_branch2_ops,
  1990. },
  1991. },
  1992. };
  1993. static struct clk_branch venus0_axi_clk = {
  1994. .halt_reg = 0x1034,
  1995. .clkr = {
  1996. .enable_reg = 0x1034,
  1997. .enable_mask = BIT(0),
  1998. .hw.init = &(struct clk_init_data){
  1999. .name = "venus0_axi_clk",
  2000. .parent_hws = (const struct clk_hw *[]){ &axi_clk_src.clkr.hw },
  2001. .num_parents = 1,
  2002. .ops = &clk_branch2_ops,
  2003. },
  2004. },
  2005. };
  2006. static struct clk_branch venus0_ocmemnoc_clk = {
  2007. .halt_reg = 0x1038,
  2008. .clkr = {
  2009. .enable_reg = 0x1038,
  2010. .enable_mask = BIT(0),
  2011. .hw.init = &(struct clk_init_data){
  2012. .name = "venus0_ocmemnoc_clk",
  2013. .parent_hws = (const struct clk_hw *[]){ &ocmemnoc_clk_src.clkr.hw },
  2014. .num_parents = 1,
  2015. .flags = CLK_SET_RATE_PARENT,
  2016. .ops = &clk_branch2_ops,
  2017. },
  2018. },
  2019. };
  2020. static struct clk_branch venus0_vcodec0_clk = {
  2021. .halt_reg = 0x1028,
  2022. .clkr = {
  2023. .enable_reg = 0x1028,
  2024. .enable_mask = BIT(0),
  2025. .hw.init = &(struct clk_init_data){
  2026. .name = "venus0_vcodec0_clk",
  2027. .parent_hws = (const struct clk_hw *[]){ &vcodec0_clk_src.clkr.hw },
  2028. .num_parents = 1,
  2029. .flags = CLK_SET_RATE_PARENT,
  2030. .ops = &clk_branch2_ops,
  2031. },
  2032. },
  2033. };
  2034. static struct clk_branch venus0_core0_vcodec_clk = {
  2035. .halt_reg = 0x1048,
  2036. .clkr = {
  2037. .enable_reg = 0x1048,
  2038. .enable_mask = BIT(0),
  2039. .hw.init = &(struct clk_init_data){
  2040. .name = "venus0_core0_vcodec_clk",
  2041. .parent_hws = (const struct clk_hw *[]){ &vcodec0_clk_src.clkr.hw },
  2042. .num_parents = 1,
  2043. .flags = CLK_SET_RATE_PARENT,
  2044. .ops = &clk_branch2_ops,
  2045. },
  2046. },
  2047. };
  2048. static struct clk_branch venus0_core1_vcodec_clk = {
  2049. .halt_reg = 0x104c,
  2050. .clkr = {
  2051. .enable_reg = 0x104c,
  2052. .enable_mask = BIT(0),
  2053. .hw.init = &(struct clk_init_data){
  2054. .name = "venus0_core1_vcodec_clk",
  2055. .parent_hws = (const struct clk_hw *[]){ &vcodec0_clk_src.clkr.hw },
  2056. .num_parents = 1,
  2057. .flags = CLK_SET_RATE_PARENT,
  2058. .ops = &clk_branch2_ops,
  2059. },
  2060. },
  2061. };
  2062. static struct clk_branch venus0_core2_vcodec_clk = {
  2063. .halt_reg = 0x1054,
  2064. .clkr = {
  2065. .enable_reg = 0x1054,
  2066. .enable_mask = BIT(0),
  2067. .hw.init = &(struct clk_init_data){
  2068. .name = "venus0_core2_vcodec_clk",
  2069. .parent_hws = (const struct clk_hw *[]){ &vcodec0_clk_src.clkr.hw },
  2070. .num_parents = 1,
  2071. .flags = CLK_SET_RATE_PARENT,
  2072. .ops = &clk_branch2_ops,
  2073. },
  2074. },
  2075. };
  2076. static struct gdsc venus_gdsc = {
  2077. .gdscr = 0x1024,
  2078. .cxcs = (unsigned int []){ 0x1038, 0x1034, 0x1048 },
  2079. .cxc_count = 3,
  2080. .pd = {
  2081. .name = "venus_gdsc",
  2082. },
  2083. .pwrsts = PWRSTS_OFF_ON,
  2084. };
  2085. static struct gdsc venus_core0_gdsc = {
  2086. .gdscr = 0x1040,
  2087. .cxcs = (unsigned int []){ 0x1048 },
  2088. .cxc_count = 1,
  2089. .pd = {
  2090. .name = "venus_core0_gdsc",
  2091. },
  2092. .pwrsts = PWRSTS_OFF_ON,
  2093. .flags = HW_CTRL,
  2094. };
  2095. static struct gdsc venus_core1_gdsc = {
  2096. .gdscr = 0x1044,
  2097. .cxcs = (unsigned int []){ 0x104c },
  2098. .cxc_count = 1,
  2099. .pd = {
  2100. .name = "venus_core1_gdsc",
  2101. },
  2102. .pwrsts = PWRSTS_OFF_ON,
  2103. .flags = HW_CTRL,
  2104. };
  2105. static struct gdsc venus_core2_gdsc = {
  2106. .gdscr = 0x1050,
  2107. .cxcs = (unsigned int []){ 0x1054 },
  2108. .cxc_count = 1,
  2109. .pd = {
  2110. .name = "venus_core2_gdsc",
  2111. },
  2112. .pwrsts = PWRSTS_OFF_ON,
  2113. .flags = HW_CTRL,
  2114. };
  2115. static struct gdsc mdss_gdsc = {
  2116. .gdscr = 0x2304,
  2117. .cxcs = (unsigned int []){ 0x2310, 0x231c },
  2118. .cxc_count = 2,
  2119. .pd = {
  2120. .name = "mdss_gdsc",
  2121. },
  2122. .pwrsts = PWRSTS_OFF_ON,
  2123. };
  2124. static struct gdsc camss_top_gdsc = {
  2125. .gdscr = 0x34a0,
  2126. .cxcs = (unsigned int []){ 0x3704, 0x3714, 0x3494 },
  2127. .cxc_count = 3,
  2128. .pd = {
  2129. .name = "camss_top_gdsc",
  2130. },
  2131. .pwrsts = PWRSTS_OFF_ON,
  2132. };
  2133. static struct gdsc jpeg_gdsc = {
  2134. .gdscr = 0x35a4,
  2135. .cxcs = (unsigned int []){ 0x35a8 },
  2136. .cxc_count = 1,
  2137. .pd = {
  2138. .name = "jpeg_gdsc",
  2139. },
  2140. .parent = &camss_top_gdsc.pd,
  2141. .pwrsts = PWRSTS_OFF_ON,
  2142. };
  2143. static struct gdsc vfe_gdsc = {
  2144. .gdscr = 0x36a4,
  2145. .cxcs = (unsigned int []){ 0x36bc },
  2146. .cxc_count = 1,
  2147. .pd = {
  2148. .name = "vfe_gdsc",
  2149. },
  2150. .parent = &camss_top_gdsc.pd,
  2151. .pwrsts = PWRSTS_OFF_ON,
  2152. };
  2153. static struct gdsc cpp_gdsc = {
  2154. .gdscr = 0x36d4,
  2155. .cxcs = (unsigned int []){ 0x36c4, 0x36b0 },
  2156. .cxc_count = 2,
  2157. .pd = {
  2158. .name = "cpp_gdsc",
  2159. },
  2160. .parent = &camss_top_gdsc.pd,
  2161. .pwrsts = PWRSTS_OFF_ON,
  2162. };
  2163. static struct gdsc fd_gdsc = {
  2164. .gdscr = 0x3b64,
  2165. .cxcs = (unsigned int []){ 0x3b70, 0x3b68 },
  2166. .pd = {
  2167. .name = "fd_gdsc",
  2168. },
  2169. .pwrsts = PWRSTS_OFF_ON,
  2170. };
  2171. static struct gdsc oxili_cx_gdsc = {
  2172. .gdscr = 0x4034,
  2173. .pd = {
  2174. .name = "oxili_cx_gdsc",
  2175. },
  2176. .pwrsts = PWRSTS_OFF_ON,
  2177. .flags = VOTABLE,
  2178. };
  2179. static struct gdsc oxili_gx_gdsc = {
  2180. .gdscr = 0x4024,
  2181. .cxcs = (unsigned int []){ 0x4028 },
  2182. .cxc_count = 1,
  2183. .pd = {
  2184. .name = "oxili_gx_gdsc",
  2185. },
  2186. .pwrsts = PWRSTS_OFF_ON,
  2187. .parent = &oxili_cx_gdsc.pd,
  2188. .flags = CLAMP_IO,
  2189. .supply = "VDD_GFX",
  2190. };
  2191. static struct clk_regmap *mmcc_msm8994_clocks[] = {
  2192. [MMPLL0_EARLY] = &mmpll0_early.clkr,
  2193. [MMPLL0_PLL] = &mmpll0.clkr,
  2194. [MMPLL1_EARLY] = &mmpll1_early.clkr,
  2195. [MMPLL1_PLL] = &mmpll1.clkr,
  2196. [MMPLL3_EARLY] = &mmpll3_early.clkr,
  2197. [MMPLL3_PLL] = &mmpll3.clkr,
  2198. [MMPLL4_EARLY] = &mmpll4_early.clkr,
  2199. [MMPLL4_PLL] = &mmpll4.clkr,
  2200. [MMPLL5_EARLY] = &mmpll5_early.clkr,
  2201. [MMPLL5_PLL] = &mmpll5.clkr,
  2202. [AHB_CLK_SRC] = &ahb_clk_src.clkr,
  2203. [AXI_CLK_SRC] = &axi_clk_src.clkr,
  2204. [CSI0_CLK_SRC] = &csi0_clk_src.clkr,
  2205. [CSI1_CLK_SRC] = &csi1_clk_src.clkr,
  2206. [CSI2_CLK_SRC] = &csi2_clk_src.clkr,
  2207. [CSI3_CLK_SRC] = &csi3_clk_src.clkr,
  2208. [VFE0_CLK_SRC] = &vfe0_clk_src.clkr,
  2209. [VFE1_CLK_SRC] = &vfe1_clk_src.clkr,
  2210. [CPP_CLK_SRC] = &cpp_clk_src.clkr,
  2211. [JPEG0_CLK_SRC] = &jpeg0_clk_src.clkr,
  2212. [JPEG1_CLK_SRC] = &jpeg1_clk_src.clkr,
  2213. [JPEG2_CLK_SRC] = &jpeg2_clk_src.clkr,
  2214. [CSI2PHYTIMER_CLK_SRC] = &csi2phytimer_clk_src.clkr,
  2215. [FD_CORE_CLK_SRC] = &fd_core_clk_src.clkr,
  2216. [MDP_CLK_SRC] = &mdp_clk_src.clkr,
  2217. [PCLK0_CLK_SRC] = &pclk0_clk_src.clkr,
  2218. [PCLK1_CLK_SRC] = &pclk1_clk_src.clkr,
  2219. [OCMEMNOC_CLK_SRC] = &ocmemnoc_clk_src.clkr,
  2220. [CCI_CLK_SRC] = &cci_clk_src.clkr,
  2221. [MMSS_GP0_CLK_SRC] = &mmss_gp0_clk_src.clkr,
  2222. [MMSS_GP1_CLK_SRC] = &mmss_gp1_clk_src.clkr,
  2223. [JPEG_DMA_CLK_SRC] = &jpeg_dma_clk_src.clkr,
  2224. [MCLK0_CLK_SRC] = &mclk0_clk_src.clkr,
  2225. [MCLK1_CLK_SRC] = &mclk1_clk_src.clkr,
  2226. [MCLK2_CLK_SRC] = &mclk2_clk_src.clkr,
  2227. [MCLK3_CLK_SRC] = &mclk3_clk_src.clkr,
  2228. [CSI0PHYTIMER_CLK_SRC] = &csi0phytimer_clk_src.clkr,
  2229. [CSI1PHYTIMER_CLK_SRC] = &csi1phytimer_clk_src.clkr,
  2230. [BYTE0_CLK_SRC] = &byte0_clk_src.clkr,
  2231. [BYTE1_CLK_SRC] = &byte1_clk_src.clkr,
  2232. [ESC0_CLK_SRC] = &esc0_clk_src.clkr,
  2233. [ESC1_CLK_SRC] = &esc1_clk_src.clkr,
  2234. [MDSS_ESC0_CLK] = &mdss_esc0_clk.clkr,
  2235. [MDSS_ESC1_CLK] = &mdss_esc1_clk.clkr,
  2236. [EXTPCLK_CLK_SRC] = &extpclk_clk_src.clkr,
  2237. [HDMI_CLK_SRC] = &hdmi_clk_src.clkr,
  2238. [VSYNC_CLK_SRC] = &vsync_clk_src.clkr,
  2239. [RBBMTIMER_CLK_SRC] = &rbbmtimer_clk_src.clkr,
  2240. [CAMSS_AHB_CLK] = &camss_ahb_clk.clkr,
  2241. [CAMSS_CCI_CCI_AHB_CLK] = &camss_cci_cci_ahb_clk.clkr,
  2242. [CAMSS_CCI_CCI_CLK] = &camss_cci_cci_clk.clkr,
  2243. [CAMSS_VFE_CPP_AHB_CLK] = &camss_vfe_cpp_ahb_clk.clkr,
  2244. [CAMSS_VFE_CPP_AXI_CLK] = &camss_vfe_cpp_axi_clk.clkr,
  2245. [CAMSS_VFE_CPP_CLK] = &camss_vfe_cpp_clk.clkr,
  2246. [CAMSS_CSI0_AHB_CLK] = &camss_csi0_ahb_clk.clkr,
  2247. [CAMSS_CSI0_CLK] = &camss_csi0_clk.clkr,
  2248. [CAMSS_CSI0PHY_CLK] = &camss_csi0phy_clk.clkr,
  2249. [CAMSS_CSI0PIX_CLK] = &camss_csi0pix_clk.clkr,
  2250. [CAMSS_CSI0RDI_CLK] = &camss_csi0rdi_clk.clkr,
  2251. [CAMSS_CSI1_AHB_CLK] = &camss_csi1_ahb_clk.clkr,
  2252. [CAMSS_CSI1_CLK] = &camss_csi1_clk.clkr,
  2253. [CAMSS_CSI1PHY_CLK] = &camss_csi1phy_clk.clkr,
  2254. [CAMSS_CSI1PIX_CLK] = &camss_csi1pix_clk.clkr,
  2255. [CAMSS_CSI1RDI_CLK] = &camss_csi1rdi_clk.clkr,
  2256. [CAMSS_CSI2_AHB_CLK] = &camss_csi2_ahb_clk.clkr,
  2257. [CAMSS_CSI2_CLK] = &camss_csi2_clk.clkr,
  2258. [CAMSS_CSI2PHY_CLK] = &camss_csi2phy_clk.clkr,
  2259. [CAMSS_CSI2PIX_CLK] = &camss_csi2pix_clk.clkr,
  2260. [CAMSS_CSI2RDI_CLK] = &camss_csi2rdi_clk.clkr,
  2261. [CAMSS_CSI3_AHB_CLK] = &camss_csi3_ahb_clk.clkr,
  2262. [CAMSS_CSI3_CLK] = &camss_csi3_clk.clkr,
  2263. [CAMSS_CSI3PHY_CLK] = &camss_csi3phy_clk.clkr,
  2264. [CAMSS_CSI3PIX_CLK] = &camss_csi3pix_clk.clkr,
  2265. [CAMSS_CSI3RDI_CLK] = &camss_csi3rdi_clk.clkr,
  2266. [CAMSS_CSI_VFE0_CLK] = &camss_csi_vfe0_clk.clkr,
  2267. [CAMSS_CSI_VFE1_CLK] = &camss_csi_vfe1_clk.clkr,
  2268. [CAMSS_GP0_CLK] = &camss_gp0_clk.clkr,
  2269. [CAMSS_GP1_CLK] = &camss_gp1_clk.clkr,
  2270. [CAMSS_ISPIF_AHB_CLK] = &camss_ispif_ahb_clk.clkr,
  2271. [CAMSS_JPEG_DMA_CLK] = &camss_jpeg_dma_clk.clkr,
  2272. [CAMSS_JPEG_JPEG0_CLK] = &camss_jpeg_jpeg0_clk.clkr,
  2273. [CAMSS_JPEG_JPEG1_CLK] = &camss_jpeg_jpeg1_clk.clkr,
  2274. [CAMSS_JPEG_JPEG2_CLK] = &camss_jpeg_jpeg2_clk.clkr,
  2275. [CAMSS_JPEG_JPEG_AHB_CLK] = &camss_jpeg_jpeg_ahb_clk.clkr,
  2276. [CAMSS_JPEG_JPEG_AXI_CLK] = &camss_jpeg_jpeg_axi_clk.clkr,
  2277. [CAMSS_MCLK0_CLK] = &camss_mclk0_clk.clkr,
  2278. [CAMSS_MCLK1_CLK] = &camss_mclk1_clk.clkr,
  2279. [CAMSS_MCLK2_CLK] = &camss_mclk2_clk.clkr,
  2280. [CAMSS_MCLK3_CLK] = &camss_mclk3_clk.clkr,
  2281. [CAMSS_MICRO_AHB_CLK] = &camss_micro_ahb_clk.clkr,
  2282. [CAMSS_PHY0_CSI0PHYTIMER_CLK] = &camss_phy0_csi0phytimer_clk.clkr,
  2283. [CAMSS_PHY1_CSI1PHYTIMER_CLK] = &camss_phy1_csi1phytimer_clk.clkr,
  2284. [CAMSS_PHY2_CSI2PHYTIMER_CLK] = &camss_phy2_csi2phytimer_clk.clkr,
  2285. [CAMSS_TOP_AHB_CLK] = &camss_top_ahb_clk.clkr,
  2286. [CAMSS_VFE_VFE0_CLK] = &camss_vfe_vfe0_clk.clkr,
  2287. [CAMSS_VFE_VFE1_CLK] = &camss_vfe_vfe1_clk.clkr,
  2288. [CAMSS_VFE_VFE_AHB_CLK] = &camss_vfe_vfe_ahb_clk.clkr,
  2289. [CAMSS_VFE_VFE_AXI_CLK] = &camss_vfe_vfe_axi_clk.clkr,
  2290. [FD_AHB_CLK] = &fd_ahb_clk.clkr,
  2291. [FD_AXI_CLK] = &fd_axi_clk.clkr,
  2292. [FD_CORE_CLK] = &fd_core_clk.clkr,
  2293. [FD_CORE_UAR_CLK] = &fd_core_uar_clk.clkr,
  2294. [MDSS_AHB_CLK] = &mdss_ahb_clk.clkr,
  2295. [MDSS_AXI_CLK] = &mdss_axi_clk.clkr,
  2296. [MDSS_BYTE0_CLK] = &mdss_byte0_clk.clkr,
  2297. [MDSS_BYTE1_CLK] = &mdss_byte1_clk.clkr,
  2298. [MDSS_EXTPCLK_CLK] = &mdss_extpclk_clk.clkr,
  2299. [MDSS_HDMI_AHB_CLK] = &mdss_hdmi_ahb_clk.clkr,
  2300. [MDSS_HDMI_CLK] = &mdss_hdmi_clk.clkr,
  2301. [MDSS_MDP_CLK] = &mdss_mdp_clk.clkr,
  2302. [MDSS_PCLK0_CLK] = &mdss_pclk0_clk.clkr,
  2303. [MDSS_PCLK1_CLK] = &mdss_pclk1_clk.clkr,
  2304. [MDSS_VSYNC_CLK] = &mdss_vsync_clk.clkr,
  2305. [MMSS_MISC_AHB_CLK] = &mmss_misc_ahb_clk.clkr,
  2306. [MMSS_MMSSNOC_AXI_CLK] = &mmss_mmssnoc_axi_clk.clkr,
  2307. [MMSS_S0_AXI_CLK] = &mmss_s0_axi_clk.clkr,
  2308. [OCMEMCX_OCMEMNOC_CLK] = &ocmemcx_ocmemnoc_clk.clkr,
  2309. [OXILI_GFX3D_CLK] = &oxili_gfx3d_clk.clkr,
  2310. [OXILI_RBBMTIMER_CLK] = &oxili_rbbmtimer_clk.clkr,
  2311. [OXILICX_AHB_CLK] = &oxilicx_ahb_clk.clkr,
  2312. [VENUS0_AHB_CLK] = &venus0_ahb_clk.clkr,
  2313. [VENUS0_AXI_CLK] = &venus0_axi_clk.clkr,
  2314. [VENUS0_OCMEMNOC_CLK] = &venus0_ocmemnoc_clk.clkr,
  2315. [VENUS0_VCODEC0_CLK] = &venus0_vcodec0_clk.clkr,
  2316. [VENUS0_CORE0_VCODEC_CLK] = &venus0_core0_vcodec_clk.clkr,
  2317. [VENUS0_CORE1_VCODEC_CLK] = &venus0_core1_vcodec_clk.clkr,
  2318. [VENUS0_CORE2_VCODEC_CLK] = &venus0_core2_vcodec_clk.clkr,
  2319. };
  2320. static struct gdsc *mmcc_msm8994_gdscs[] = {
  2321. [VENUS_GDSC] = &venus_gdsc,
  2322. [VENUS_CORE0_GDSC] = &venus_core0_gdsc,
  2323. [VENUS_CORE1_GDSC] = &venus_core1_gdsc,
  2324. [VENUS_CORE2_GDSC] = &venus_core2_gdsc,
  2325. [CAMSS_TOP_GDSC] = &camss_top_gdsc,
  2326. [MDSS_GDSC] = &mdss_gdsc,
  2327. [JPEG_GDSC] = &jpeg_gdsc,
  2328. [VFE_GDSC] = &vfe_gdsc,
  2329. [CPP_GDSC] = &cpp_gdsc,
  2330. [OXILI_GX_GDSC] = &oxili_gx_gdsc,
  2331. [OXILI_CX_GDSC] = &oxili_cx_gdsc,
  2332. [FD_GDSC] = &fd_gdsc,
  2333. };
  2334. static const struct qcom_reset_map mmcc_msm8994_resets[] = {
  2335. [CAMSS_MICRO_BCR] = { 0x3490 },
  2336. };
  2337. static const struct regmap_config mmcc_msm8994_regmap_config = {
  2338. .reg_bits = 32,
  2339. .reg_stride = 4,
  2340. .val_bits = 32,
  2341. .max_register = 0x5200,
  2342. .fast_io = true,
  2343. };
  2344. static const struct qcom_cc_desc mmcc_msm8994_desc = {
  2345. .config = &mmcc_msm8994_regmap_config,
  2346. .clks = mmcc_msm8994_clocks,
  2347. .num_clks = ARRAY_SIZE(mmcc_msm8994_clocks),
  2348. .resets = mmcc_msm8994_resets,
  2349. .num_resets = ARRAY_SIZE(mmcc_msm8994_resets),
  2350. .gdscs = mmcc_msm8994_gdscs,
  2351. .num_gdscs = ARRAY_SIZE(mmcc_msm8994_gdscs),
  2352. };
  2353. static const struct of_device_id mmcc_msm8994_match_table[] = {
  2354. { .compatible = "qcom,mmcc-msm8992" },
  2355. { .compatible = "qcom,mmcc-msm8994" }, /* V2 and V2.1 */
  2356. { }
  2357. };
  2358. MODULE_DEVICE_TABLE(of, mmcc_msm8994_match_table);
  2359. static int mmcc_msm8994_probe(struct platform_device *pdev)
  2360. {
  2361. struct regmap *regmap;
  2362. if (of_device_is_compatible(pdev->dev.of_node, "qcom,mmcc-msm8992")) {
  2363. /* MSM8992 features less clocks and some have different freq tables */
  2364. mmcc_msm8994_desc.clks[CAMSS_JPEG_JPEG1_CLK] = NULL;
  2365. mmcc_msm8994_desc.clks[CAMSS_JPEG_JPEG2_CLK] = NULL;
  2366. mmcc_msm8994_desc.clks[FD_CORE_CLK_SRC] = NULL;
  2367. mmcc_msm8994_desc.clks[FD_CORE_CLK] = NULL;
  2368. mmcc_msm8994_desc.clks[FD_CORE_UAR_CLK] = NULL;
  2369. mmcc_msm8994_desc.clks[FD_AXI_CLK] = NULL;
  2370. mmcc_msm8994_desc.clks[FD_AHB_CLK] = NULL;
  2371. mmcc_msm8994_desc.clks[JPEG1_CLK_SRC] = NULL;
  2372. mmcc_msm8994_desc.clks[JPEG2_CLK_SRC] = NULL;
  2373. mmcc_msm8994_desc.clks[VENUS0_CORE2_VCODEC_CLK] = NULL;
  2374. mmcc_msm8994_desc.gdscs[FD_GDSC] = NULL;
  2375. mmcc_msm8994_desc.gdscs[VENUS_CORE2_GDSC] = NULL;
  2376. axi_clk_src.freq_tbl = ftbl_axi_clk_src_8992;
  2377. cpp_clk_src.freq_tbl = ftbl_cpp_clk_src_8992;
  2378. csi0_clk_src.freq_tbl = ftbl_csi0_1_2_3_clk_src_8992;
  2379. csi1_clk_src.freq_tbl = ftbl_csi0_1_2_3_clk_src_8992;
  2380. csi2_clk_src.freq_tbl = ftbl_csi0_1_2_3_clk_src_8992;
  2381. csi3_clk_src.freq_tbl = ftbl_csi0_1_2_3_clk_src_8992;
  2382. mclk0_clk_src.freq_tbl = ftbl_mclk0_clk_src_8992;
  2383. mclk1_clk_src.freq_tbl = ftbl_mclk1_2_3_clk_src_8992;
  2384. mclk2_clk_src.freq_tbl = ftbl_mclk1_2_3_clk_src_8992;
  2385. mclk3_clk_src.freq_tbl = ftbl_mclk1_2_3_clk_src_8992;
  2386. mdp_clk_src.freq_tbl = ftbl_mdp_clk_src_8992;
  2387. ocmemnoc_clk_src.freq_tbl = ftbl_ocmemnoc_clk_src_8992;
  2388. vcodec0_clk_src.freq_tbl = ftbl_vcodec0_clk_src_8992;
  2389. vfe0_clk_src.freq_tbl = ftbl_vfe0_1_clk_src_8992;
  2390. vfe1_clk_src.freq_tbl = ftbl_vfe0_1_clk_src_8992;
  2391. }
  2392. regmap = qcom_cc_map(pdev, &mmcc_msm8994_desc);
  2393. if (IS_ERR(regmap))
  2394. return PTR_ERR(regmap);
  2395. clk_alpha_pll_configure(&mmpll0_early, regmap, &mmpll_p_config);
  2396. clk_alpha_pll_configure(&mmpll1_early, regmap, &mmpll_p_config);
  2397. clk_alpha_pll_configure(&mmpll3_early, regmap, &mmpll_p_config);
  2398. clk_alpha_pll_configure(&mmpll5_early, regmap, &mmpll_p_config);
  2399. return qcom_cc_really_probe(pdev, &mmcc_msm8994_desc, regmap);
  2400. }
  2401. static struct platform_driver mmcc_msm8994_driver = {
  2402. .probe = mmcc_msm8994_probe,
  2403. .driver = {
  2404. .name = "mmcc-msm8994",
  2405. .of_match_table = mmcc_msm8994_match_table,
  2406. },
  2407. };
  2408. module_platform_driver(mmcc_msm8994_driver);
  2409. MODULE_DESCRIPTION("QCOM MMCC MSM8994 Driver");
  2410. MODULE_LICENSE("GPL v2");
  2411. MODULE_ALIAS("platform:mmcc-msm8994");