mmcc-msm8974.c 70 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * Copyright (c) 2013, 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/module.h>
  10. #include <linux/of.h>
  11. #include <linux/clk-provider.h>
  12. #include <linux/regmap.h>
  13. #include <linux/reset-controller.h>
  14. #include <dt-bindings/clock/qcom,mmcc-msm8974.h>
  15. #include <dt-bindings/reset/qcom,mmcc-msm8974.h>
  16. #include "common.h"
  17. #include "clk-regmap.h"
  18. #include "clk-pll.h"
  19. #include "clk-rcg.h"
  20. #include "clk-branch.h"
  21. #include "reset.h"
  22. #include "gdsc.h"
  23. enum {
  24. P_XO,
  25. P_MMPLL0,
  26. P_EDPLINK,
  27. P_MMPLL1,
  28. P_HDMIPLL,
  29. P_GPLL0,
  30. P_EDPVCO,
  31. P_GPLL1,
  32. P_DSI0PLL,
  33. P_DSI0PLL_BYTE,
  34. P_MMPLL2,
  35. P_MMPLL3,
  36. P_DSI1PLL,
  37. P_DSI1PLL_BYTE,
  38. };
  39. static struct clk_pll mmpll0 = {
  40. .l_reg = 0x0004,
  41. .m_reg = 0x0008,
  42. .n_reg = 0x000c,
  43. .config_reg = 0x0014,
  44. .mode_reg = 0x0000,
  45. .status_reg = 0x001c,
  46. .status_bit = 17,
  47. .clkr.hw.init = &(struct clk_init_data){
  48. .name = "mmpll0",
  49. .parent_data = (const struct clk_parent_data[]){
  50. { .fw_name = "xo", .name = "xo_board" },
  51. },
  52. .num_parents = 1,
  53. .ops = &clk_pll_ops,
  54. },
  55. };
  56. static struct clk_regmap mmpll0_vote = {
  57. .enable_reg = 0x0100,
  58. .enable_mask = BIT(0),
  59. .hw.init = &(struct clk_init_data){
  60. .name = "mmpll0_vote",
  61. .parent_hws = (const struct clk_hw*[]){
  62. &mmpll0.clkr.hw
  63. },
  64. .num_parents = 1,
  65. .ops = &clk_pll_vote_ops,
  66. },
  67. };
  68. static struct clk_pll mmpll1 = {
  69. .l_reg = 0x0044,
  70. .m_reg = 0x0048,
  71. .n_reg = 0x004c,
  72. .config_reg = 0x0050,
  73. .mode_reg = 0x0040,
  74. .status_reg = 0x005c,
  75. .status_bit = 17,
  76. .clkr.hw.init = &(struct clk_init_data){
  77. .name = "mmpll1",
  78. .parent_data = (const struct clk_parent_data[]){
  79. { .fw_name = "xo", .name = "xo_board" },
  80. },
  81. .num_parents = 1,
  82. .ops = &clk_pll_ops,
  83. },
  84. };
  85. static struct clk_regmap mmpll1_vote = {
  86. .enable_reg = 0x0100,
  87. .enable_mask = BIT(1),
  88. .hw.init = &(struct clk_init_data){
  89. .name = "mmpll1_vote",
  90. .parent_hws = (const struct clk_hw*[]){
  91. &mmpll1.clkr.hw
  92. },
  93. .num_parents = 1,
  94. .ops = &clk_pll_vote_ops,
  95. },
  96. };
  97. static struct clk_pll mmpll2 = {
  98. .l_reg = 0x4104,
  99. .m_reg = 0x4108,
  100. .n_reg = 0x410c,
  101. .config_reg = 0x4110,
  102. .mode_reg = 0x4100,
  103. .status_reg = 0x411c,
  104. .clkr.hw.init = &(struct clk_init_data){
  105. .name = "mmpll2",
  106. .parent_data = (const struct clk_parent_data[]){
  107. { .fw_name = "xo", .name = "xo_board" },
  108. },
  109. .num_parents = 1,
  110. .ops = &clk_pll_ops,
  111. },
  112. };
  113. static struct clk_pll mmpll3 = {
  114. .l_reg = 0x0084,
  115. .m_reg = 0x0088,
  116. .n_reg = 0x008c,
  117. .config_reg = 0x0090,
  118. .mode_reg = 0x0080,
  119. .status_reg = 0x009c,
  120. .status_bit = 17,
  121. .clkr.hw.init = &(struct clk_init_data){
  122. .name = "mmpll3",
  123. .parent_data = (const struct clk_parent_data[]){
  124. { .fw_name = "xo", .name = "xo_board" },
  125. },
  126. .num_parents = 1,
  127. .ops = &clk_pll_ops,
  128. },
  129. };
  130. static const struct parent_map mmcc_xo_mmpll0_mmpll1_gpll0_map[] = {
  131. { P_XO, 0 },
  132. { P_MMPLL0, 1 },
  133. { P_MMPLL1, 2 },
  134. { P_GPLL0, 5 }
  135. };
  136. static const struct clk_parent_data mmcc_xo_mmpll0_mmpll1_gpll0[] = {
  137. { .fw_name = "xo", .name = "xo_board" },
  138. { .hw = &mmpll0_vote.hw },
  139. { .hw = &mmpll1_vote.hw },
  140. { .fw_name = "mmss_gpll0_vote", .name = "mmss_gpll0_vote" },
  141. };
  142. static const struct parent_map mmcc_xo_mmpll0_dsi_hdmi_gpll0_map[] = {
  143. { P_XO, 0 },
  144. { P_MMPLL0, 1 },
  145. { P_HDMIPLL, 4 },
  146. { P_GPLL0, 5 },
  147. { P_DSI0PLL, 2 },
  148. { P_DSI1PLL, 3 }
  149. };
  150. static const struct clk_parent_data mmcc_xo_mmpll0_dsi_hdmi_gpll0[] = {
  151. { .fw_name = "xo", .name = "xo_board" },
  152. { .hw = &mmpll0_vote.hw },
  153. { .fw_name = "hdmipll", .name = "hdmipll" },
  154. { .fw_name = "mmss_gpll0_vote", .name = "mmss_gpll0_vote" },
  155. { .fw_name = "dsi0pll", .name = "dsi0pll" },
  156. { .fw_name = "dsi1pll", .name = "dsi1pll" },
  157. };
  158. static const struct parent_map mmcc_xo_mmpll0_1_3_gpll0_map[] = {
  159. { P_XO, 0 },
  160. { P_MMPLL0, 1 },
  161. { P_MMPLL1, 2 },
  162. { P_GPLL0, 5 },
  163. { P_MMPLL3, 3 }
  164. };
  165. static const struct clk_parent_data mmcc_xo_mmpll0_1_3_gpll0[] = {
  166. { .fw_name = "xo", .name = "xo_board" },
  167. { .hw = &mmpll0_vote.hw },
  168. { .hw = &mmpll1_vote.hw },
  169. { .fw_name = "mmss_gpll0_vote", .name = "mmss_gpll0_vote" },
  170. { .hw = &mmpll3.clkr.hw },
  171. };
  172. static const struct parent_map mmcc_xo_mmpll0_1_gpll1_0_map[] = {
  173. { P_XO, 0 },
  174. { P_MMPLL0, 1 },
  175. { P_MMPLL1, 2 },
  176. { P_GPLL0, 5 },
  177. { P_GPLL1, 4 }
  178. };
  179. static const struct clk_parent_data mmcc_xo_mmpll0_1_gpll1_0[] = {
  180. { .fw_name = "xo", .name = "xo_board" },
  181. { .hw = &mmpll0_vote.hw },
  182. { .hw = &mmpll1_vote.hw },
  183. { .fw_name = "mmss_gpll0_vote", .name = "mmss_gpll0_vote" },
  184. { .fw_name = "gpll1_vote", .name = "gpll1_vote" },
  185. };
  186. static const struct parent_map mmcc_xo_dsi_hdmi_edp_map[] = {
  187. { P_XO, 0 },
  188. { P_EDPLINK, 4 },
  189. { P_HDMIPLL, 3 },
  190. { P_EDPVCO, 5 },
  191. { P_DSI0PLL, 1 },
  192. { P_DSI1PLL, 2 }
  193. };
  194. static const struct clk_parent_data mmcc_xo_dsi_hdmi_edp[] = {
  195. { .fw_name = "xo", .name = "xo_board" },
  196. { .fw_name = "edp_link_clk", .name = "edp_link_clk" },
  197. { .fw_name = "hdmipll", .name = "hdmipll" },
  198. { .fw_name = "edp_vco_div", .name = "edp_vco_div" },
  199. { .fw_name = "dsi0pll", .name = "dsi0pll" },
  200. { .fw_name = "dsi1pll", .name = "dsi1pll" },
  201. };
  202. static const struct parent_map mmcc_xo_dsi_hdmi_edp_gpll0_map[] = {
  203. { P_XO, 0 },
  204. { P_EDPLINK, 4 },
  205. { P_HDMIPLL, 3 },
  206. { P_GPLL0, 5 },
  207. { P_DSI0PLL, 1 },
  208. { P_DSI1PLL, 2 }
  209. };
  210. static const struct clk_parent_data mmcc_xo_dsi_hdmi_edp_gpll0[] = {
  211. { .fw_name = "xo", .name = "xo_board" },
  212. { .fw_name = "edp_link_clk", .name = "edp_link_clk" },
  213. { .fw_name = "hdmipll", .name = "hdmipll" },
  214. { .fw_name = "gpll0_vote", .name = "gpll0_vote" },
  215. { .fw_name = "dsi0pll", .name = "dsi0pll" },
  216. { .fw_name = "dsi1pll", .name = "dsi1pll" },
  217. };
  218. static const struct parent_map mmcc_xo_dsibyte_hdmi_edp_gpll0_map[] = {
  219. { P_XO, 0 },
  220. { P_EDPLINK, 4 },
  221. { P_HDMIPLL, 3 },
  222. { P_GPLL0, 5 },
  223. { P_DSI0PLL_BYTE, 1 },
  224. { P_DSI1PLL_BYTE, 2 }
  225. };
  226. static const struct clk_parent_data mmcc_xo_dsibyte_hdmi_edp_gpll0[] = {
  227. { .fw_name = "xo", .name = "xo_board" },
  228. { .fw_name = "edp_link_clk", .name = "edp_link_clk" },
  229. { .fw_name = "hdmipll", .name = "hdmipll" },
  230. { .fw_name = "gpll0_vote", .name = "gpll0_vote" },
  231. { .fw_name = "dsi0pllbyte", .name = "dsi0pllbyte" },
  232. { .fw_name = "dsi1pllbyte", .name = "dsi1pllbyte" },
  233. };
  234. static struct clk_rcg2 mmss_ahb_clk_src = {
  235. .cmd_rcgr = 0x5000,
  236. .hid_width = 5,
  237. .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
  238. .clkr.hw.init = &(struct clk_init_data){
  239. .name = "mmss_ahb_clk_src",
  240. .parent_data = mmcc_xo_mmpll0_mmpll1_gpll0,
  241. .num_parents = ARRAY_SIZE(mmcc_xo_mmpll0_mmpll1_gpll0),
  242. .ops = &clk_rcg2_ops,
  243. },
  244. };
  245. static const struct freq_tbl ftbl_mmss_axi_clk_msm8226[] = {
  246. F(19200000, P_XO, 1, 0, 0),
  247. F(37500000, P_GPLL0, 16, 0, 0),
  248. F(50000000, P_GPLL0, 12, 0, 0),
  249. F(75000000, P_GPLL0, 8, 0, 0),
  250. F(100000000, P_GPLL0, 6, 0, 0),
  251. F(150000000, P_GPLL0, 4, 0, 0),
  252. F(200000000, P_MMPLL0, 4, 0, 0),
  253. F(266666666, P_MMPLL0, 3, 0, 0),
  254. { }
  255. };
  256. static const struct freq_tbl ftbl_mmss_axi_clk[] = {
  257. F( 19200000, P_XO, 1, 0, 0),
  258. F( 37500000, P_GPLL0, 16, 0, 0),
  259. F( 50000000, P_GPLL0, 12, 0, 0),
  260. F( 75000000, P_GPLL0, 8, 0, 0),
  261. F(100000000, P_GPLL0, 6, 0, 0),
  262. F(150000000, P_GPLL0, 4, 0, 0),
  263. F(291750000, P_MMPLL1, 4, 0, 0),
  264. F(400000000, P_MMPLL0, 2, 0, 0),
  265. F(466800000, P_MMPLL1, 2.5, 0, 0),
  266. { }
  267. };
  268. static struct clk_rcg2 mmss_axi_clk_src = {
  269. .cmd_rcgr = 0x5040,
  270. .hid_width = 5,
  271. .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
  272. .freq_tbl = ftbl_mmss_axi_clk,
  273. .clkr.hw.init = &(struct clk_init_data){
  274. .name = "mmss_axi_clk_src",
  275. .parent_data = mmcc_xo_mmpll0_mmpll1_gpll0,
  276. .num_parents = ARRAY_SIZE(mmcc_xo_mmpll0_mmpll1_gpll0),
  277. .ops = &clk_rcg2_ops,
  278. },
  279. };
  280. static const struct freq_tbl ftbl_ocmemnoc_clk[] = {
  281. F( 19200000, P_XO, 1, 0, 0),
  282. F( 37500000, P_GPLL0, 16, 0, 0),
  283. F( 50000000, P_GPLL0, 12, 0, 0),
  284. F( 75000000, P_GPLL0, 8, 0, 0),
  285. F(100000000, P_GPLL0, 6, 0, 0),
  286. F(150000000, P_GPLL0, 4, 0, 0),
  287. F(291750000, P_MMPLL1, 4, 0, 0),
  288. F(400000000, P_MMPLL0, 2, 0, 0),
  289. { }
  290. };
  291. static struct clk_rcg2 ocmemnoc_clk_src = {
  292. .cmd_rcgr = 0x5090,
  293. .hid_width = 5,
  294. .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
  295. .freq_tbl = ftbl_ocmemnoc_clk,
  296. .clkr.hw.init = &(struct clk_init_data){
  297. .name = "ocmemnoc_clk_src",
  298. .parent_data = mmcc_xo_mmpll0_mmpll1_gpll0,
  299. .num_parents = ARRAY_SIZE(mmcc_xo_mmpll0_mmpll1_gpll0),
  300. .ops = &clk_rcg2_ops,
  301. },
  302. };
  303. static const struct freq_tbl ftbl_camss_csi0_3_clk[] = {
  304. F(100000000, P_GPLL0, 6, 0, 0),
  305. F(200000000, P_MMPLL0, 4, 0, 0),
  306. { }
  307. };
  308. static struct clk_rcg2 csi0_clk_src = {
  309. .cmd_rcgr = 0x3090,
  310. .hid_width = 5,
  311. .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
  312. .freq_tbl = ftbl_camss_csi0_3_clk,
  313. .clkr.hw.init = &(struct clk_init_data){
  314. .name = "csi0_clk_src",
  315. .parent_data = mmcc_xo_mmpll0_mmpll1_gpll0,
  316. .num_parents = ARRAY_SIZE(mmcc_xo_mmpll0_mmpll1_gpll0),
  317. .ops = &clk_rcg2_ops,
  318. },
  319. };
  320. static struct clk_rcg2 csi1_clk_src = {
  321. .cmd_rcgr = 0x3100,
  322. .hid_width = 5,
  323. .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
  324. .freq_tbl = ftbl_camss_csi0_3_clk,
  325. .clkr.hw.init = &(struct clk_init_data){
  326. .name = "csi1_clk_src",
  327. .parent_data = mmcc_xo_mmpll0_mmpll1_gpll0,
  328. .num_parents = ARRAY_SIZE(mmcc_xo_mmpll0_mmpll1_gpll0),
  329. .ops = &clk_rcg2_ops,
  330. },
  331. };
  332. static struct clk_rcg2 csi2_clk_src = {
  333. .cmd_rcgr = 0x3160,
  334. .hid_width = 5,
  335. .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
  336. .freq_tbl = ftbl_camss_csi0_3_clk,
  337. .clkr.hw.init = &(struct clk_init_data){
  338. .name = "csi2_clk_src",
  339. .parent_data = mmcc_xo_mmpll0_mmpll1_gpll0,
  340. .num_parents = ARRAY_SIZE(mmcc_xo_mmpll0_mmpll1_gpll0),
  341. .ops = &clk_rcg2_ops,
  342. },
  343. };
  344. static struct clk_rcg2 csi3_clk_src = {
  345. .cmd_rcgr = 0x31c0,
  346. .hid_width = 5,
  347. .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
  348. .freq_tbl = ftbl_camss_csi0_3_clk,
  349. .clkr.hw.init = &(struct clk_init_data){
  350. .name = "csi3_clk_src",
  351. .parent_data = mmcc_xo_mmpll0_mmpll1_gpll0,
  352. .num_parents = ARRAY_SIZE(mmcc_xo_mmpll0_mmpll1_gpll0),
  353. .ops = &clk_rcg2_ops,
  354. },
  355. };
  356. static const struct freq_tbl ftbl_camss_vfe_vfe0_clk_msm8226[] = {
  357. F(37500000, P_GPLL0, 16, 0, 0),
  358. F(50000000, P_GPLL0, 12, 0, 0),
  359. F(60000000, P_GPLL0, 10, 0, 0),
  360. F(80000000, P_GPLL0, 7.5, 0, 0),
  361. F(100000000, P_GPLL0, 6, 0, 0),
  362. F(109090000, P_GPLL0, 5.5, 0, 0),
  363. F(133330000, P_GPLL0, 4.5, 0, 0),
  364. F(150000000, P_GPLL0, 4, 0, 0),
  365. F(200000000, P_GPLL0, 3, 0, 0),
  366. F(228570000, P_MMPLL0, 3.5, 0, 0),
  367. F(266670000, P_MMPLL0, 3, 0, 0),
  368. F(320000000, P_MMPLL0, 2.5, 0, 0),
  369. F(400000000, P_MMPLL0, 2, 0, 0),
  370. { }
  371. };
  372. static const struct freq_tbl ftbl_camss_vfe_vfe0_1_clk[] = {
  373. F(37500000, P_GPLL0, 16, 0, 0),
  374. F(50000000, P_GPLL0, 12, 0, 0),
  375. F(60000000, P_GPLL0, 10, 0, 0),
  376. F(80000000, P_GPLL0, 7.5, 0, 0),
  377. F(100000000, P_GPLL0, 6, 0, 0),
  378. F(109090000, P_GPLL0, 5.5, 0, 0),
  379. F(133330000, P_GPLL0, 4.5, 0, 0),
  380. F(200000000, P_GPLL0, 3, 0, 0),
  381. F(228570000, P_MMPLL0, 3.5, 0, 0),
  382. F(266670000, P_MMPLL0, 3, 0, 0),
  383. F(320000000, P_MMPLL0, 2.5, 0, 0),
  384. F(400000000, P_MMPLL0, 2, 0, 0),
  385. F(465000000, P_MMPLL3, 2, 0, 0),
  386. { }
  387. };
  388. static struct clk_rcg2 vfe0_clk_src = {
  389. .cmd_rcgr = 0x3600,
  390. .hid_width = 5,
  391. .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
  392. .freq_tbl = ftbl_camss_vfe_vfe0_1_clk,
  393. .clkr.hw.init = &(struct clk_init_data){
  394. .name = "vfe0_clk_src",
  395. .parent_data = mmcc_xo_mmpll0_mmpll1_gpll0,
  396. .num_parents = ARRAY_SIZE(mmcc_xo_mmpll0_mmpll1_gpll0),
  397. .ops = &clk_rcg2_ops,
  398. },
  399. };
  400. static struct clk_rcg2 vfe1_clk_src = {
  401. .cmd_rcgr = 0x3620,
  402. .hid_width = 5,
  403. .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
  404. .freq_tbl = ftbl_camss_vfe_vfe0_1_clk,
  405. .clkr.hw.init = &(struct clk_init_data){
  406. .name = "vfe1_clk_src",
  407. .parent_data = mmcc_xo_mmpll0_mmpll1_gpll0,
  408. .num_parents = ARRAY_SIZE(mmcc_xo_mmpll0_mmpll1_gpll0),
  409. .ops = &clk_rcg2_ops,
  410. },
  411. };
  412. static const struct freq_tbl ftbl_mdss_mdp_clk_msm8226[] = {
  413. F(37500000, P_GPLL0, 16, 0, 0),
  414. F(60000000, P_GPLL0, 10, 0, 0),
  415. F(75000000, P_GPLL0, 8, 0, 0),
  416. F(92310000, P_GPLL0, 6.5, 0, 0),
  417. F(100000000, P_GPLL0, 6, 0, 0),
  418. F(133330000, P_MMPLL0, 6, 0, 0),
  419. F(177780000, P_MMPLL0, 4.5, 0, 0),
  420. F(200000000, P_MMPLL0, 4, 0, 0),
  421. { }
  422. };
  423. static const struct freq_tbl ftbl_mdss_mdp_clk[] = {
  424. F(37500000, P_GPLL0, 16, 0, 0),
  425. F(60000000, P_GPLL0, 10, 0, 0),
  426. F(75000000, P_GPLL0, 8, 0, 0),
  427. F(85710000, P_GPLL0, 7, 0, 0),
  428. F(100000000, P_GPLL0, 6, 0, 0),
  429. F(133330000, P_MMPLL0, 6, 0, 0),
  430. F(160000000, P_MMPLL0, 5, 0, 0),
  431. F(200000000, P_MMPLL0, 4, 0, 0),
  432. F(228570000, P_MMPLL0, 3.5, 0, 0),
  433. F(240000000, P_GPLL0, 2.5, 0, 0),
  434. F(266670000, P_MMPLL0, 3, 0, 0),
  435. F(320000000, P_MMPLL0, 2.5, 0, 0),
  436. { }
  437. };
  438. static struct clk_rcg2 mdp_clk_src = {
  439. .cmd_rcgr = 0x2040,
  440. .hid_width = 5,
  441. .parent_map = mmcc_xo_mmpll0_dsi_hdmi_gpll0_map,
  442. .freq_tbl = ftbl_mdss_mdp_clk,
  443. .clkr.hw.init = &(struct clk_init_data){
  444. .name = "mdp_clk_src",
  445. .parent_data = mmcc_xo_mmpll0_dsi_hdmi_gpll0,
  446. .num_parents = ARRAY_SIZE(mmcc_xo_mmpll0_dsi_hdmi_gpll0),
  447. .ops = &clk_rcg2_shared_ops,
  448. },
  449. };
  450. static const struct freq_tbl ftbl_camss_jpeg_jpeg0_2_clk[] = {
  451. F(75000000, P_GPLL0, 8, 0, 0),
  452. F(133330000, P_GPLL0, 4.5, 0, 0),
  453. F(200000000, P_GPLL0, 3, 0, 0),
  454. F(228570000, P_MMPLL0, 3.5, 0, 0),
  455. F(266670000, P_MMPLL0, 3, 0, 0),
  456. F(320000000, P_MMPLL0, 2.5, 0, 0),
  457. { }
  458. };
  459. static struct clk_rcg2 jpeg0_clk_src = {
  460. .cmd_rcgr = 0x3500,
  461. .hid_width = 5,
  462. .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
  463. .freq_tbl = ftbl_camss_jpeg_jpeg0_2_clk,
  464. .clkr.hw.init = &(struct clk_init_data){
  465. .name = "jpeg0_clk_src",
  466. .parent_data = mmcc_xo_mmpll0_mmpll1_gpll0,
  467. .num_parents = ARRAY_SIZE(mmcc_xo_mmpll0_mmpll1_gpll0),
  468. .ops = &clk_rcg2_ops,
  469. },
  470. };
  471. static struct clk_rcg2 jpeg1_clk_src = {
  472. .cmd_rcgr = 0x3520,
  473. .hid_width = 5,
  474. .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
  475. .freq_tbl = ftbl_camss_jpeg_jpeg0_2_clk,
  476. .clkr.hw.init = &(struct clk_init_data){
  477. .name = "jpeg1_clk_src",
  478. .parent_data = mmcc_xo_mmpll0_mmpll1_gpll0,
  479. .num_parents = ARRAY_SIZE(mmcc_xo_mmpll0_mmpll1_gpll0),
  480. .ops = &clk_rcg2_ops,
  481. },
  482. };
  483. static struct clk_rcg2 jpeg2_clk_src = {
  484. .cmd_rcgr = 0x3540,
  485. .hid_width = 5,
  486. .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
  487. .freq_tbl = ftbl_camss_jpeg_jpeg0_2_clk,
  488. .clkr.hw.init = &(struct clk_init_data){
  489. .name = "jpeg2_clk_src",
  490. .parent_data = mmcc_xo_mmpll0_mmpll1_gpll0,
  491. .num_parents = ARRAY_SIZE(mmcc_xo_mmpll0_mmpll1_gpll0),
  492. .ops = &clk_rcg2_ops,
  493. },
  494. };
  495. static struct clk_rcg2 pclk0_clk_src = {
  496. .cmd_rcgr = 0x2000,
  497. .mnd_width = 8,
  498. .hid_width = 5,
  499. .parent_map = mmcc_xo_dsi_hdmi_edp_gpll0_map,
  500. .clkr.hw.init = &(struct clk_init_data){
  501. .name = "pclk0_clk_src",
  502. .parent_data = mmcc_xo_dsi_hdmi_edp_gpll0,
  503. .num_parents = ARRAY_SIZE(mmcc_xo_dsi_hdmi_edp_gpll0),
  504. .ops = &clk_pixel_ops,
  505. .flags = CLK_SET_RATE_PARENT,
  506. },
  507. };
  508. static struct clk_rcg2 pclk1_clk_src = {
  509. .cmd_rcgr = 0x2020,
  510. .mnd_width = 8,
  511. .hid_width = 5,
  512. .parent_map = mmcc_xo_dsi_hdmi_edp_gpll0_map,
  513. .clkr.hw.init = &(struct clk_init_data){
  514. .name = "pclk1_clk_src",
  515. .parent_data = mmcc_xo_dsi_hdmi_edp_gpll0,
  516. .num_parents = ARRAY_SIZE(mmcc_xo_dsi_hdmi_edp_gpll0),
  517. .ops = &clk_pixel_ops,
  518. .flags = CLK_SET_RATE_PARENT,
  519. },
  520. };
  521. static const struct freq_tbl ftbl_venus0_vcodec0_clk_msm8226[] = {
  522. F(66700000, P_GPLL0, 9, 0, 0),
  523. F(100000000, P_GPLL0, 6, 0, 0),
  524. F(133330000, P_MMPLL0, 6, 0, 0),
  525. F(160000000, P_MMPLL0, 5, 0, 0),
  526. { }
  527. };
  528. static const struct freq_tbl ftbl_venus0_vcodec0_clk[] = {
  529. F(50000000, P_GPLL0, 12, 0, 0),
  530. F(100000000, P_GPLL0, 6, 0, 0),
  531. F(133330000, P_MMPLL0, 6, 0, 0),
  532. F(200000000, P_MMPLL0, 4, 0, 0),
  533. F(266670000, P_MMPLL0, 3, 0, 0),
  534. F(465000000, P_MMPLL3, 2, 0, 0),
  535. { }
  536. };
  537. static struct clk_rcg2 vcodec0_clk_src = {
  538. .cmd_rcgr = 0x1000,
  539. .mnd_width = 8,
  540. .hid_width = 5,
  541. .parent_map = mmcc_xo_mmpll0_1_3_gpll0_map,
  542. .freq_tbl = ftbl_venus0_vcodec0_clk,
  543. .clkr.hw.init = &(struct clk_init_data){
  544. .name = "vcodec0_clk_src",
  545. .parent_data = mmcc_xo_mmpll0_1_3_gpll0,
  546. .num_parents = ARRAY_SIZE(mmcc_xo_mmpll0_1_3_gpll0),
  547. .ops = &clk_rcg2_ops,
  548. },
  549. };
  550. static const struct freq_tbl ftbl_camss_cci_cci_clk[] = {
  551. F(19200000, P_XO, 1, 0, 0),
  552. { }
  553. };
  554. static struct clk_rcg2 cci_clk_src = {
  555. .cmd_rcgr = 0x3300,
  556. .hid_width = 5,
  557. .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
  558. .freq_tbl = ftbl_camss_cci_cci_clk,
  559. .clkr.hw.init = &(struct clk_init_data){
  560. .name = "cci_clk_src",
  561. .parent_data = mmcc_xo_mmpll0_mmpll1_gpll0,
  562. .num_parents = ARRAY_SIZE(mmcc_xo_mmpll0_mmpll1_gpll0),
  563. .ops = &clk_rcg2_ops,
  564. },
  565. };
  566. static const struct freq_tbl ftbl_camss_gp0_1_clk[] = {
  567. F(10000, P_XO, 16, 1, 120),
  568. F(24000, P_XO, 16, 1, 50),
  569. F(6000000, P_GPLL0, 10, 1, 10),
  570. F(12000000, P_GPLL0, 10, 1, 5),
  571. F(13000000, P_GPLL0, 4, 13, 150),
  572. F(24000000, P_GPLL0, 5, 1, 5),
  573. { }
  574. };
  575. static struct clk_rcg2 camss_gp0_clk_src = {
  576. .cmd_rcgr = 0x3420,
  577. .mnd_width = 8,
  578. .hid_width = 5,
  579. .parent_map = mmcc_xo_mmpll0_1_gpll1_0_map,
  580. .freq_tbl = ftbl_camss_gp0_1_clk,
  581. .clkr.hw.init = &(struct clk_init_data){
  582. .name = "camss_gp0_clk_src",
  583. .parent_data = mmcc_xo_mmpll0_1_gpll1_0,
  584. .num_parents = ARRAY_SIZE(mmcc_xo_mmpll0_1_gpll1_0),
  585. .ops = &clk_rcg2_ops,
  586. },
  587. };
  588. static struct clk_rcg2 camss_gp1_clk_src = {
  589. .cmd_rcgr = 0x3450,
  590. .mnd_width = 8,
  591. .hid_width = 5,
  592. .parent_map = mmcc_xo_mmpll0_1_gpll1_0_map,
  593. .freq_tbl = ftbl_camss_gp0_1_clk,
  594. .clkr.hw.init = &(struct clk_init_data){
  595. .name = "camss_gp1_clk_src",
  596. .parent_data = mmcc_xo_mmpll0_1_gpll1_0,
  597. .num_parents = ARRAY_SIZE(mmcc_xo_mmpll0_1_gpll1_0),
  598. .ops = &clk_rcg2_ops,
  599. },
  600. };
  601. static const struct freq_tbl ftbl_camss_mclk0_3_clk_msm8226[] = {
  602. F(19200000, P_XO, 1, 0, 0),
  603. F(24000000, P_GPLL0, 5, 1, 5),
  604. F(66670000, P_GPLL0, 9, 0, 0),
  605. { }
  606. };
  607. static const struct freq_tbl ftbl_camss_mclk0_3_clk[] = {
  608. F(4800000, P_XO, 4, 0, 0),
  609. F(6000000, P_GPLL0, 10, 1, 10),
  610. F(8000000, P_GPLL0, 15, 1, 5),
  611. F(9600000, P_XO, 2, 0, 0),
  612. F(16000000, P_GPLL0, 12.5, 1, 3),
  613. F(19200000, P_XO, 1, 0, 0),
  614. F(24000000, P_GPLL0, 5, 1, 5),
  615. F(32000000, P_MMPLL0, 5, 1, 5),
  616. F(48000000, P_GPLL0, 12.5, 0, 0),
  617. F(64000000, P_MMPLL0, 12.5, 0, 0),
  618. F(66670000, P_GPLL0, 9, 0, 0),
  619. { }
  620. };
  621. static struct clk_rcg2 mclk0_clk_src = {
  622. .cmd_rcgr = 0x3360,
  623. .hid_width = 5,
  624. .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
  625. .freq_tbl = ftbl_camss_mclk0_3_clk,
  626. .clkr.hw.init = &(struct clk_init_data){
  627. .name = "mclk0_clk_src",
  628. .parent_data = mmcc_xo_mmpll0_mmpll1_gpll0,
  629. .num_parents = ARRAY_SIZE(mmcc_xo_mmpll0_mmpll1_gpll0),
  630. .ops = &clk_rcg2_ops,
  631. },
  632. };
  633. static struct clk_rcg2 mclk1_clk_src = {
  634. .cmd_rcgr = 0x3390,
  635. .hid_width = 5,
  636. .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
  637. .freq_tbl = ftbl_camss_mclk0_3_clk,
  638. .clkr.hw.init = &(struct clk_init_data){
  639. .name = "mclk1_clk_src",
  640. .parent_data = mmcc_xo_mmpll0_mmpll1_gpll0,
  641. .num_parents = ARRAY_SIZE(mmcc_xo_mmpll0_mmpll1_gpll0),
  642. .ops = &clk_rcg2_ops,
  643. },
  644. };
  645. static struct clk_rcg2 mclk2_clk_src = {
  646. .cmd_rcgr = 0x33c0,
  647. .hid_width = 5,
  648. .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
  649. .freq_tbl = ftbl_camss_mclk0_3_clk,
  650. .clkr.hw.init = &(struct clk_init_data){
  651. .name = "mclk2_clk_src",
  652. .parent_data = mmcc_xo_mmpll0_mmpll1_gpll0,
  653. .num_parents = ARRAY_SIZE(mmcc_xo_mmpll0_mmpll1_gpll0),
  654. .ops = &clk_rcg2_ops,
  655. },
  656. };
  657. static struct clk_rcg2 mclk3_clk_src = {
  658. .cmd_rcgr = 0x33f0,
  659. .hid_width = 5,
  660. .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
  661. .freq_tbl = ftbl_camss_mclk0_3_clk,
  662. .clkr.hw.init = &(struct clk_init_data){
  663. .name = "mclk3_clk_src",
  664. .parent_data = mmcc_xo_mmpll0_mmpll1_gpll0,
  665. .num_parents = ARRAY_SIZE(mmcc_xo_mmpll0_mmpll1_gpll0),
  666. .ops = &clk_rcg2_ops,
  667. },
  668. };
  669. static const struct freq_tbl ftbl_camss_phy0_2_csi0_2phytimer_clk[] = {
  670. F(100000000, P_GPLL0, 6, 0, 0),
  671. F(200000000, P_MMPLL0, 4, 0, 0),
  672. { }
  673. };
  674. static struct clk_rcg2 csi0phytimer_clk_src = {
  675. .cmd_rcgr = 0x3000,
  676. .hid_width = 5,
  677. .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
  678. .freq_tbl = ftbl_camss_phy0_2_csi0_2phytimer_clk,
  679. .clkr.hw.init = &(struct clk_init_data){
  680. .name = "csi0phytimer_clk_src",
  681. .parent_data = mmcc_xo_mmpll0_mmpll1_gpll0,
  682. .num_parents = ARRAY_SIZE(mmcc_xo_mmpll0_mmpll1_gpll0),
  683. .ops = &clk_rcg2_ops,
  684. },
  685. };
  686. static struct clk_rcg2 csi1phytimer_clk_src = {
  687. .cmd_rcgr = 0x3030,
  688. .hid_width = 5,
  689. .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
  690. .freq_tbl = ftbl_camss_phy0_2_csi0_2phytimer_clk,
  691. .clkr.hw.init = &(struct clk_init_data){
  692. .name = "csi1phytimer_clk_src",
  693. .parent_data = mmcc_xo_mmpll0_mmpll1_gpll0,
  694. .num_parents = ARRAY_SIZE(mmcc_xo_mmpll0_mmpll1_gpll0),
  695. .ops = &clk_rcg2_ops,
  696. },
  697. };
  698. static struct clk_rcg2 csi2phytimer_clk_src = {
  699. .cmd_rcgr = 0x3060,
  700. .hid_width = 5,
  701. .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
  702. .freq_tbl = ftbl_camss_phy0_2_csi0_2phytimer_clk,
  703. .clkr.hw.init = &(struct clk_init_data){
  704. .name = "csi2phytimer_clk_src",
  705. .parent_data = mmcc_xo_mmpll0_mmpll1_gpll0,
  706. .num_parents = ARRAY_SIZE(mmcc_xo_mmpll0_mmpll1_gpll0),
  707. .ops = &clk_rcg2_ops,
  708. },
  709. };
  710. static const struct freq_tbl ftbl_camss_vfe_cpp_clk_msm8226[] = {
  711. F(133330000, P_GPLL0, 4.5, 0, 0),
  712. F(150000000, P_GPLL0, 4, 0, 0),
  713. F(266670000, P_MMPLL0, 3, 0, 0),
  714. F(320000000, P_MMPLL0, 2.5, 0, 0),
  715. F(400000000, P_MMPLL0, 2, 0, 0),
  716. { }
  717. };
  718. static const struct freq_tbl ftbl_camss_vfe_cpp_clk[] = {
  719. F(133330000, P_GPLL0, 4.5, 0, 0),
  720. F(266670000, P_MMPLL0, 3, 0, 0),
  721. F(320000000, P_MMPLL0, 2.5, 0, 0),
  722. F(400000000, P_MMPLL0, 2, 0, 0),
  723. F(465000000, P_MMPLL3, 2, 0, 0),
  724. { }
  725. };
  726. static struct clk_rcg2 cpp_clk_src = {
  727. .cmd_rcgr = 0x3640,
  728. .hid_width = 5,
  729. .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
  730. .freq_tbl = ftbl_camss_vfe_cpp_clk,
  731. .clkr.hw.init = &(struct clk_init_data){
  732. .name = "cpp_clk_src",
  733. .parent_data = mmcc_xo_mmpll0_mmpll1_gpll0,
  734. .num_parents = ARRAY_SIZE(mmcc_xo_mmpll0_mmpll1_gpll0),
  735. .ops = &clk_rcg2_ops,
  736. },
  737. };
  738. static const struct freq_tbl byte_freq_tbl[] = {
  739. { .src = P_DSI0PLL_BYTE },
  740. { }
  741. };
  742. static struct clk_rcg2 byte0_clk_src = {
  743. .cmd_rcgr = 0x2120,
  744. .hid_width = 5,
  745. .parent_map = mmcc_xo_dsibyte_hdmi_edp_gpll0_map,
  746. .freq_tbl = byte_freq_tbl,
  747. .clkr.hw.init = &(struct clk_init_data){
  748. .name = "byte0_clk_src",
  749. .parent_data = mmcc_xo_dsibyte_hdmi_edp_gpll0,
  750. .num_parents = ARRAY_SIZE(mmcc_xo_dsibyte_hdmi_edp_gpll0),
  751. .ops = &clk_byte2_ops,
  752. .flags = CLK_SET_RATE_PARENT,
  753. },
  754. };
  755. static struct clk_rcg2 byte1_clk_src = {
  756. .cmd_rcgr = 0x2140,
  757. .hid_width = 5,
  758. .parent_map = mmcc_xo_dsibyte_hdmi_edp_gpll0_map,
  759. .freq_tbl = byte_freq_tbl,
  760. .clkr.hw.init = &(struct clk_init_data){
  761. .name = "byte1_clk_src",
  762. .parent_data = mmcc_xo_dsibyte_hdmi_edp_gpll0,
  763. .num_parents = ARRAY_SIZE(mmcc_xo_dsibyte_hdmi_edp_gpll0),
  764. .ops = &clk_byte2_ops,
  765. .flags = CLK_SET_RATE_PARENT,
  766. },
  767. };
  768. static const struct freq_tbl ftbl_mdss_edpaux_clk[] = {
  769. F(19200000, P_XO, 1, 0, 0),
  770. { }
  771. };
  772. static struct clk_rcg2 edpaux_clk_src = {
  773. .cmd_rcgr = 0x20e0,
  774. .hid_width = 5,
  775. .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
  776. .freq_tbl = ftbl_mdss_edpaux_clk,
  777. .clkr.hw.init = &(struct clk_init_data){
  778. .name = "edpaux_clk_src",
  779. .parent_data = mmcc_xo_mmpll0_mmpll1_gpll0,
  780. .num_parents = ARRAY_SIZE(mmcc_xo_mmpll0_mmpll1_gpll0),
  781. .ops = &clk_rcg2_ops,
  782. },
  783. };
  784. static const struct freq_tbl ftbl_mdss_edplink_clk[] = {
  785. F(135000000, P_EDPLINK, 2, 0, 0),
  786. F(270000000, P_EDPLINK, 11, 0, 0),
  787. { }
  788. };
  789. static struct clk_rcg2 edplink_clk_src = {
  790. .cmd_rcgr = 0x20c0,
  791. .hid_width = 5,
  792. .parent_map = mmcc_xo_dsi_hdmi_edp_gpll0_map,
  793. .freq_tbl = ftbl_mdss_edplink_clk,
  794. .clkr.hw.init = &(struct clk_init_data){
  795. .name = "edplink_clk_src",
  796. .parent_data = mmcc_xo_dsi_hdmi_edp_gpll0,
  797. .num_parents = ARRAY_SIZE(mmcc_xo_dsi_hdmi_edp_gpll0),
  798. .ops = &clk_rcg2_ops,
  799. .flags = CLK_SET_RATE_PARENT,
  800. },
  801. };
  802. static const struct freq_tbl edp_pixel_freq_tbl[] = {
  803. { .src = P_EDPVCO },
  804. { }
  805. };
  806. static struct clk_rcg2 edppixel_clk_src = {
  807. .cmd_rcgr = 0x20a0,
  808. .mnd_width = 8,
  809. .hid_width = 5,
  810. .parent_map = mmcc_xo_dsi_hdmi_edp_map,
  811. .freq_tbl = edp_pixel_freq_tbl,
  812. .clkr.hw.init = &(struct clk_init_data){
  813. .name = "edppixel_clk_src",
  814. .parent_data = mmcc_xo_dsi_hdmi_edp,
  815. .num_parents = ARRAY_SIZE(mmcc_xo_dsi_hdmi_edp),
  816. .ops = &clk_edp_pixel_ops,
  817. },
  818. };
  819. static const struct freq_tbl ftbl_mdss_esc0_1_clk[] = {
  820. F(19200000, P_XO, 1, 0, 0),
  821. { }
  822. };
  823. static struct clk_rcg2 esc0_clk_src = {
  824. .cmd_rcgr = 0x2160,
  825. .hid_width = 5,
  826. .parent_map = mmcc_xo_dsibyte_hdmi_edp_gpll0_map,
  827. .freq_tbl = ftbl_mdss_esc0_1_clk,
  828. .clkr.hw.init = &(struct clk_init_data){
  829. .name = "esc0_clk_src",
  830. .parent_data = mmcc_xo_dsibyte_hdmi_edp_gpll0,
  831. .num_parents = ARRAY_SIZE(mmcc_xo_dsibyte_hdmi_edp_gpll0),
  832. .ops = &clk_rcg2_ops,
  833. },
  834. };
  835. static struct clk_rcg2 esc1_clk_src = {
  836. .cmd_rcgr = 0x2180,
  837. .hid_width = 5,
  838. .parent_map = mmcc_xo_dsibyte_hdmi_edp_gpll0_map,
  839. .freq_tbl = ftbl_mdss_esc0_1_clk,
  840. .clkr.hw.init = &(struct clk_init_data){
  841. .name = "esc1_clk_src",
  842. .parent_data = mmcc_xo_dsibyte_hdmi_edp_gpll0,
  843. .num_parents = ARRAY_SIZE(mmcc_xo_dsibyte_hdmi_edp_gpll0),
  844. .ops = &clk_rcg2_ops,
  845. },
  846. };
  847. static const struct freq_tbl extpclk_freq_tbl[] = {
  848. { .src = P_HDMIPLL },
  849. { }
  850. };
  851. static struct clk_rcg2 extpclk_clk_src = {
  852. .cmd_rcgr = 0x2060,
  853. .hid_width = 5,
  854. .parent_map = mmcc_xo_dsi_hdmi_edp_gpll0_map,
  855. .freq_tbl = extpclk_freq_tbl,
  856. .clkr.hw.init = &(struct clk_init_data){
  857. .name = "extpclk_clk_src",
  858. .parent_data = mmcc_xo_dsi_hdmi_edp_gpll0,
  859. .num_parents = ARRAY_SIZE(mmcc_xo_dsi_hdmi_edp_gpll0),
  860. .ops = &clk_byte_ops,
  861. .flags = CLK_SET_RATE_PARENT,
  862. },
  863. };
  864. static const struct freq_tbl ftbl_mdss_hdmi_clk[] = {
  865. F(19200000, P_XO, 1, 0, 0),
  866. { }
  867. };
  868. static struct clk_rcg2 hdmi_clk_src = {
  869. .cmd_rcgr = 0x2100,
  870. .hid_width = 5,
  871. .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
  872. .freq_tbl = ftbl_mdss_hdmi_clk,
  873. .clkr.hw.init = &(struct clk_init_data){
  874. .name = "hdmi_clk_src",
  875. .parent_data = mmcc_xo_mmpll0_mmpll1_gpll0,
  876. .num_parents = ARRAY_SIZE(mmcc_xo_mmpll0_mmpll1_gpll0),
  877. .ops = &clk_rcg2_ops,
  878. },
  879. };
  880. static const struct freq_tbl ftbl_mdss_vsync_clk[] = {
  881. F(19200000, P_XO, 1, 0, 0),
  882. { }
  883. };
  884. static struct clk_rcg2 vsync_clk_src = {
  885. .cmd_rcgr = 0x2080,
  886. .hid_width = 5,
  887. .parent_map = mmcc_xo_mmpll0_mmpll1_gpll0_map,
  888. .freq_tbl = ftbl_mdss_vsync_clk,
  889. .clkr.hw.init = &(struct clk_init_data){
  890. .name = "vsync_clk_src",
  891. .parent_data = mmcc_xo_mmpll0_mmpll1_gpll0,
  892. .num_parents = ARRAY_SIZE(mmcc_xo_mmpll0_mmpll1_gpll0),
  893. .ops = &clk_rcg2_ops,
  894. },
  895. };
  896. static struct clk_branch camss_cci_cci_ahb_clk = {
  897. .halt_reg = 0x3348,
  898. .clkr = {
  899. .enable_reg = 0x3348,
  900. .enable_mask = BIT(0),
  901. .hw.init = &(struct clk_init_data){
  902. .name = "camss_cci_cci_ahb_clk",
  903. .parent_hws = (const struct clk_hw*[]){
  904. &mmss_ahb_clk_src.clkr.hw
  905. },
  906. .num_parents = 1,
  907. .ops = &clk_branch2_ops,
  908. },
  909. },
  910. };
  911. static struct clk_branch camss_cci_cci_clk = {
  912. .halt_reg = 0x3344,
  913. .clkr = {
  914. .enable_reg = 0x3344,
  915. .enable_mask = BIT(0),
  916. .hw.init = &(struct clk_init_data){
  917. .name = "camss_cci_cci_clk",
  918. .parent_hws = (const struct clk_hw*[]){
  919. &cci_clk_src.clkr.hw
  920. },
  921. .num_parents = 1,
  922. .flags = CLK_SET_RATE_PARENT,
  923. .ops = &clk_branch2_ops,
  924. },
  925. },
  926. };
  927. static struct clk_branch camss_csi0_ahb_clk = {
  928. .halt_reg = 0x30bc,
  929. .clkr = {
  930. .enable_reg = 0x30bc,
  931. .enable_mask = BIT(0),
  932. .hw.init = &(struct clk_init_data){
  933. .name = "camss_csi0_ahb_clk",
  934. .parent_hws = (const struct clk_hw*[]){
  935. &mmss_ahb_clk_src.clkr.hw
  936. },
  937. .num_parents = 1,
  938. .ops = &clk_branch2_ops,
  939. },
  940. },
  941. };
  942. static struct clk_branch camss_csi0_clk = {
  943. .halt_reg = 0x30b4,
  944. .clkr = {
  945. .enable_reg = 0x30b4,
  946. .enable_mask = BIT(0),
  947. .hw.init = &(struct clk_init_data){
  948. .name = "camss_csi0_clk",
  949. .parent_hws = (const struct clk_hw*[]){
  950. &csi0_clk_src.clkr.hw
  951. },
  952. .num_parents = 1,
  953. .flags = CLK_SET_RATE_PARENT,
  954. .ops = &clk_branch2_ops,
  955. },
  956. },
  957. };
  958. static struct clk_branch camss_csi0phy_clk = {
  959. .halt_reg = 0x30c4,
  960. .clkr = {
  961. .enable_reg = 0x30c4,
  962. .enable_mask = BIT(0),
  963. .hw.init = &(struct clk_init_data){
  964. .name = "camss_csi0phy_clk",
  965. .parent_hws = (const struct clk_hw*[]){
  966. &csi0_clk_src.clkr.hw
  967. },
  968. .num_parents = 1,
  969. .flags = CLK_SET_RATE_PARENT,
  970. .ops = &clk_branch2_ops,
  971. },
  972. },
  973. };
  974. static struct clk_branch camss_csi0pix_clk = {
  975. .halt_reg = 0x30e4,
  976. .clkr = {
  977. .enable_reg = 0x30e4,
  978. .enable_mask = BIT(0),
  979. .hw.init = &(struct clk_init_data){
  980. .name = "camss_csi0pix_clk",
  981. .parent_hws = (const struct clk_hw*[]){
  982. &csi0_clk_src.clkr.hw
  983. },
  984. .num_parents = 1,
  985. .flags = CLK_SET_RATE_PARENT,
  986. .ops = &clk_branch2_ops,
  987. },
  988. },
  989. };
  990. static struct clk_branch camss_csi0rdi_clk = {
  991. .halt_reg = 0x30d4,
  992. .clkr = {
  993. .enable_reg = 0x30d4,
  994. .enable_mask = BIT(0),
  995. .hw.init = &(struct clk_init_data){
  996. .name = "camss_csi0rdi_clk",
  997. .parent_hws = (const struct clk_hw*[]){
  998. &csi0_clk_src.clkr.hw
  999. },
  1000. .num_parents = 1,
  1001. .flags = CLK_SET_RATE_PARENT,
  1002. .ops = &clk_branch2_ops,
  1003. },
  1004. },
  1005. };
  1006. static struct clk_branch camss_csi1_ahb_clk = {
  1007. .halt_reg = 0x3128,
  1008. .clkr = {
  1009. .enable_reg = 0x3128,
  1010. .enable_mask = BIT(0),
  1011. .hw.init = &(struct clk_init_data){
  1012. .name = "camss_csi1_ahb_clk",
  1013. .parent_hws = (const struct clk_hw*[]){
  1014. &mmss_ahb_clk_src.clkr.hw
  1015. },
  1016. .num_parents = 1,
  1017. .ops = &clk_branch2_ops,
  1018. },
  1019. },
  1020. };
  1021. static struct clk_branch camss_csi1_clk = {
  1022. .halt_reg = 0x3124,
  1023. .clkr = {
  1024. .enable_reg = 0x3124,
  1025. .enable_mask = BIT(0),
  1026. .hw.init = &(struct clk_init_data){
  1027. .name = "camss_csi1_clk",
  1028. .parent_hws = (const struct clk_hw*[]){
  1029. &csi1_clk_src.clkr.hw
  1030. },
  1031. .num_parents = 1,
  1032. .flags = CLK_SET_RATE_PARENT,
  1033. .ops = &clk_branch2_ops,
  1034. },
  1035. },
  1036. };
  1037. static struct clk_branch camss_csi1phy_clk = {
  1038. .halt_reg = 0x3134,
  1039. .clkr = {
  1040. .enable_reg = 0x3134,
  1041. .enable_mask = BIT(0),
  1042. .hw.init = &(struct clk_init_data){
  1043. .name = "camss_csi1phy_clk",
  1044. .parent_hws = (const struct clk_hw*[]){
  1045. &csi1_clk_src.clkr.hw
  1046. },
  1047. .num_parents = 1,
  1048. .flags = CLK_SET_RATE_PARENT,
  1049. .ops = &clk_branch2_ops,
  1050. },
  1051. },
  1052. };
  1053. static struct clk_branch camss_csi1pix_clk = {
  1054. .halt_reg = 0x3154,
  1055. .clkr = {
  1056. .enable_reg = 0x3154,
  1057. .enable_mask = BIT(0),
  1058. .hw.init = &(struct clk_init_data){
  1059. .name = "camss_csi1pix_clk",
  1060. .parent_hws = (const struct clk_hw*[]){
  1061. &csi1_clk_src.clkr.hw
  1062. },
  1063. .num_parents = 1,
  1064. .flags = CLK_SET_RATE_PARENT,
  1065. .ops = &clk_branch2_ops,
  1066. },
  1067. },
  1068. };
  1069. static struct clk_branch camss_csi1rdi_clk = {
  1070. .halt_reg = 0x3144,
  1071. .clkr = {
  1072. .enable_reg = 0x3144,
  1073. .enable_mask = BIT(0),
  1074. .hw.init = &(struct clk_init_data){
  1075. .name = "camss_csi1rdi_clk",
  1076. .parent_hws = (const struct clk_hw*[]){
  1077. &csi1_clk_src.clkr.hw
  1078. },
  1079. .num_parents = 1,
  1080. .flags = CLK_SET_RATE_PARENT,
  1081. .ops = &clk_branch2_ops,
  1082. },
  1083. },
  1084. };
  1085. static struct clk_branch camss_csi2_ahb_clk = {
  1086. .halt_reg = 0x3188,
  1087. .clkr = {
  1088. .enable_reg = 0x3188,
  1089. .enable_mask = BIT(0),
  1090. .hw.init = &(struct clk_init_data){
  1091. .name = "camss_csi2_ahb_clk",
  1092. .parent_hws = (const struct clk_hw*[]){
  1093. &mmss_ahb_clk_src.clkr.hw
  1094. },
  1095. .num_parents = 1,
  1096. .ops = &clk_branch2_ops,
  1097. },
  1098. },
  1099. };
  1100. static struct clk_branch camss_csi2_clk = {
  1101. .halt_reg = 0x3184,
  1102. .clkr = {
  1103. .enable_reg = 0x3184,
  1104. .enable_mask = BIT(0),
  1105. .hw.init = &(struct clk_init_data){
  1106. .name = "camss_csi2_clk",
  1107. .parent_hws = (const struct clk_hw*[]){
  1108. &csi2_clk_src.clkr.hw
  1109. },
  1110. .num_parents = 1,
  1111. .flags = CLK_SET_RATE_PARENT,
  1112. .ops = &clk_branch2_ops,
  1113. },
  1114. },
  1115. };
  1116. static struct clk_branch camss_csi2phy_clk = {
  1117. .halt_reg = 0x3194,
  1118. .clkr = {
  1119. .enable_reg = 0x3194,
  1120. .enable_mask = BIT(0),
  1121. .hw.init = &(struct clk_init_data){
  1122. .name = "camss_csi2phy_clk",
  1123. .parent_hws = (const struct clk_hw*[]){
  1124. &csi2_clk_src.clkr.hw
  1125. },
  1126. .num_parents = 1,
  1127. .flags = CLK_SET_RATE_PARENT,
  1128. .ops = &clk_branch2_ops,
  1129. },
  1130. },
  1131. };
  1132. static struct clk_branch camss_csi2pix_clk = {
  1133. .halt_reg = 0x31b4,
  1134. .clkr = {
  1135. .enable_reg = 0x31b4,
  1136. .enable_mask = BIT(0),
  1137. .hw.init = &(struct clk_init_data){
  1138. .name = "camss_csi2pix_clk",
  1139. .parent_hws = (const struct clk_hw*[]){
  1140. &csi2_clk_src.clkr.hw
  1141. },
  1142. .num_parents = 1,
  1143. .flags = CLK_SET_RATE_PARENT,
  1144. .ops = &clk_branch2_ops,
  1145. },
  1146. },
  1147. };
  1148. static struct clk_branch camss_csi2rdi_clk = {
  1149. .halt_reg = 0x31a4,
  1150. .clkr = {
  1151. .enable_reg = 0x31a4,
  1152. .enable_mask = BIT(0),
  1153. .hw.init = &(struct clk_init_data){
  1154. .name = "camss_csi2rdi_clk",
  1155. .parent_hws = (const struct clk_hw*[]){
  1156. &csi2_clk_src.clkr.hw
  1157. },
  1158. .num_parents = 1,
  1159. .flags = CLK_SET_RATE_PARENT,
  1160. .ops = &clk_branch2_ops,
  1161. },
  1162. },
  1163. };
  1164. static struct clk_branch camss_csi3_ahb_clk = {
  1165. .halt_reg = 0x31e8,
  1166. .clkr = {
  1167. .enable_reg = 0x31e8,
  1168. .enable_mask = BIT(0),
  1169. .hw.init = &(struct clk_init_data){
  1170. .name = "camss_csi3_ahb_clk",
  1171. .parent_hws = (const struct clk_hw*[]){
  1172. &mmss_ahb_clk_src.clkr.hw
  1173. },
  1174. .num_parents = 1,
  1175. .ops = &clk_branch2_ops,
  1176. },
  1177. },
  1178. };
  1179. static struct clk_branch camss_csi3_clk = {
  1180. .halt_reg = 0x31e4,
  1181. .clkr = {
  1182. .enable_reg = 0x31e4,
  1183. .enable_mask = BIT(0),
  1184. .hw.init = &(struct clk_init_data){
  1185. .name = "camss_csi3_clk",
  1186. .parent_hws = (const struct clk_hw*[]){
  1187. &csi3_clk_src.clkr.hw
  1188. },
  1189. .num_parents = 1,
  1190. .flags = CLK_SET_RATE_PARENT,
  1191. .ops = &clk_branch2_ops,
  1192. },
  1193. },
  1194. };
  1195. static struct clk_branch camss_csi3phy_clk = {
  1196. .halt_reg = 0x31f4,
  1197. .clkr = {
  1198. .enable_reg = 0x31f4,
  1199. .enable_mask = BIT(0),
  1200. .hw.init = &(struct clk_init_data){
  1201. .name = "camss_csi3phy_clk",
  1202. .parent_hws = (const struct clk_hw*[]){
  1203. &csi3_clk_src.clkr.hw
  1204. },
  1205. .num_parents = 1,
  1206. .flags = CLK_SET_RATE_PARENT,
  1207. .ops = &clk_branch2_ops,
  1208. },
  1209. },
  1210. };
  1211. static struct clk_branch camss_csi3pix_clk = {
  1212. .halt_reg = 0x3214,
  1213. .clkr = {
  1214. .enable_reg = 0x3214,
  1215. .enable_mask = BIT(0),
  1216. .hw.init = &(struct clk_init_data){
  1217. .name = "camss_csi3pix_clk",
  1218. .parent_hws = (const struct clk_hw*[]){
  1219. &csi3_clk_src.clkr.hw
  1220. },
  1221. .num_parents = 1,
  1222. .flags = CLK_SET_RATE_PARENT,
  1223. .ops = &clk_branch2_ops,
  1224. },
  1225. },
  1226. };
  1227. static struct clk_branch camss_csi3rdi_clk = {
  1228. .halt_reg = 0x3204,
  1229. .clkr = {
  1230. .enable_reg = 0x3204,
  1231. .enable_mask = BIT(0),
  1232. .hw.init = &(struct clk_init_data){
  1233. .name = "camss_csi3rdi_clk",
  1234. .parent_hws = (const struct clk_hw*[]){
  1235. &csi3_clk_src.clkr.hw
  1236. },
  1237. .num_parents = 1,
  1238. .flags = CLK_SET_RATE_PARENT,
  1239. .ops = &clk_branch2_ops,
  1240. },
  1241. },
  1242. };
  1243. static struct clk_branch camss_csi_vfe0_clk = {
  1244. .halt_reg = 0x3704,
  1245. .clkr = {
  1246. .enable_reg = 0x3704,
  1247. .enable_mask = BIT(0),
  1248. .hw.init = &(struct clk_init_data){
  1249. .name = "camss_csi_vfe0_clk",
  1250. .parent_hws = (const struct clk_hw*[]){
  1251. &vfe0_clk_src.clkr.hw
  1252. },
  1253. .num_parents = 1,
  1254. .flags = CLK_SET_RATE_PARENT,
  1255. .ops = &clk_branch2_ops,
  1256. },
  1257. },
  1258. };
  1259. static struct clk_branch camss_csi_vfe1_clk = {
  1260. .halt_reg = 0x3714,
  1261. .clkr = {
  1262. .enable_reg = 0x3714,
  1263. .enable_mask = BIT(0),
  1264. .hw.init = &(struct clk_init_data){
  1265. .name = "camss_csi_vfe1_clk",
  1266. .parent_hws = (const struct clk_hw*[]){
  1267. &vfe1_clk_src.clkr.hw
  1268. },
  1269. .num_parents = 1,
  1270. .flags = CLK_SET_RATE_PARENT,
  1271. .ops = &clk_branch2_ops,
  1272. },
  1273. },
  1274. };
  1275. static struct clk_branch camss_gp0_clk = {
  1276. .halt_reg = 0x3444,
  1277. .clkr = {
  1278. .enable_reg = 0x3444,
  1279. .enable_mask = BIT(0),
  1280. .hw.init = &(struct clk_init_data){
  1281. .name = "camss_gp0_clk",
  1282. .parent_hws = (const struct clk_hw*[]){
  1283. &camss_gp0_clk_src.clkr.hw
  1284. },
  1285. .num_parents = 1,
  1286. .flags = CLK_SET_RATE_PARENT,
  1287. .ops = &clk_branch2_ops,
  1288. },
  1289. },
  1290. };
  1291. static struct clk_branch camss_gp1_clk = {
  1292. .halt_reg = 0x3474,
  1293. .clkr = {
  1294. .enable_reg = 0x3474,
  1295. .enable_mask = BIT(0),
  1296. .hw.init = &(struct clk_init_data){
  1297. .name = "camss_gp1_clk",
  1298. .parent_hws = (const struct clk_hw*[]){
  1299. &camss_gp1_clk_src.clkr.hw
  1300. },
  1301. .num_parents = 1,
  1302. .flags = CLK_SET_RATE_PARENT,
  1303. .ops = &clk_branch2_ops,
  1304. },
  1305. },
  1306. };
  1307. static struct clk_branch camss_ispif_ahb_clk = {
  1308. .halt_reg = 0x3224,
  1309. .clkr = {
  1310. .enable_reg = 0x3224,
  1311. .enable_mask = BIT(0),
  1312. .hw.init = &(struct clk_init_data){
  1313. .name = "camss_ispif_ahb_clk",
  1314. .parent_hws = (const struct clk_hw*[]){
  1315. &mmss_ahb_clk_src.clkr.hw
  1316. },
  1317. .num_parents = 1,
  1318. .ops = &clk_branch2_ops,
  1319. },
  1320. },
  1321. };
  1322. static struct clk_branch camss_jpeg_jpeg0_clk = {
  1323. .halt_reg = 0x35a8,
  1324. .clkr = {
  1325. .enable_reg = 0x35a8,
  1326. .enable_mask = BIT(0),
  1327. .hw.init = &(struct clk_init_data){
  1328. .name = "camss_jpeg_jpeg0_clk",
  1329. .parent_hws = (const struct clk_hw*[]){
  1330. &jpeg0_clk_src.clkr.hw
  1331. },
  1332. .num_parents = 1,
  1333. .flags = CLK_SET_RATE_PARENT,
  1334. .ops = &clk_branch2_ops,
  1335. },
  1336. },
  1337. };
  1338. static struct clk_branch camss_jpeg_jpeg1_clk = {
  1339. .halt_reg = 0x35ac,
  1340. .clkr = {
  1341. .enable_reg = 0x35ac,
  1342. .enable_mask = BIT(0),
  1343. .hw.init = &(struct clk_init_data){
  1344. .name = "camss_jpeg_jpeg1_clk",
  1345. .parent_hws = (const struct clk_hw*[]){
  1346. &jpeg1_clk_src.clkr.hw
  1347. },
  1348. .num_parents = 1,
  1349. .flags = CLK_SET_RATE_PARENT,
  1350. .ops = &clk_branch2_ops,
  1351. },
  1352. },
  1353. };
  1354. static struct clk_branch camss_jpeg_jpeg2_clk = {
  1355. .halt_reg = 0x35b0,
  1356. .clkr = {
  1357. .enable_reg = 0x35b0,
  1358. .enable_mask = BIT(0),
  1359. .hw.init = &(struct clk_init_data){
  1360. .name = "camss_jpeg_jpeg2_clk",
  1361. .parent_hws = (const struct clk_hw*[]){
  1362. &jpeg2_clk_src.clkr.hw
  1363. },
  1364. .num_parents = 1,
  1365. .flags = CLK_SET_RATE_PARENT,
  1366. .ops = &clk_branch2_ops,
  1367. },
  1368. },
  1369. };
  1370. static struct clk_branch camss_jpeg_jpeg_ahb_clk = {
  1371. .halt_reg = 0x35b4,
  1372. .clkr = {
  1373. .enable_reg = 0x35b4,
  1374. .enable_mask = BIT(0),
  1375. .hw.init = &(struct clk_init_data){
  1376. .name = "camss_jpeg_jpeg_ahb_clk",
  1377. .parent_hws = (const struct clk_hw*[]){
  1378. &mmss_ahb_clk_src.clkr.hw
  1379. },
  1380. .num_parents = 1,
  1381. .ops = &clk_branch2_ops,
  1382. },
  1383. },
  1384. };
  1385. static struct clk_branch camss_jpeg_jpeg_axi_clk = {
  1386. .halt_reg = 0x35b8,
  1387. .clkr = {
  1388. .enable_reg = 0x35b8,
  1389. .enable_mask = BIT(0),
  1390. .hw.init = &(struct clk_init_data){
  1391. .name = "camss_jpeg_jpeg_axi_clk",
  1392. .parent_hws = (const struct clk_hw*[]){
  1393. &mmss_axi_clk_src.clkr.hw
  1394. },
  1395. .num_parents = 1,
  1396. .ops = &clk_branch2_ops,
  1397. },
  1398. },
  1399. };
  1400. static struct clk_branch camss_jpeg_jpeg_ocmemnoc_clk = {
  1401. .halt_reg = 0x35bc,
  1402. .clkr = {
  1403. .enable_reg = 0x35bc,
  1404. .enable_mask = BIT(0),
  1405. .hw.init = &(struct clk_init_data){
  1406. .name = "camss_jpeg_jpeg_ocmemnoc_clk",
  1407. .parent_hws = (const struct clk_hw*[]){
  1408. &ocmemnoc_clk_src.clkr.hw
  1409. },
  1410. .num_parents = 1,
  1411. .flags = CLK_SET_RATE_PARENT,
  1412. .ops = &clk_branch2_ops,
  1413. },
  1414. },
  1415. };
  1416. static struct clk_branch camss_mclk0_clk = {
  1417. .halt_reg = 0x3384,
  1418. .clkr = {
  1419. .enable_reg = 0x3384,
  1420. .enable_mask = BIT(0),
  1421. .hw.init = &(struct clk_init_data){
  1422. .name = "camss_mclk0_clk",
  1423. .parent_hws = (const struct clk_hw*[]){
  1424. &mclk0_clk_src.clkr.hw
  1425. },
  1426. .num_parents = 1,
  1427. .flags = CLK_SET_RATE_PARENT,
  1428. .ops = &clk_branch2_ops,
  1429. },
  1430. },
  1431. };
  1432. static struct clk_branch camss_mclk1_clk = {
  1433. .halt_reg = 0x33b4,
  1434. .clkr = {
  1435. .enable_reg = 0x33b4,
  1436. .enable_mask = BIT(0),
  1437. .hw.init = &(struct clk_init_data){
  1438. .name = "camss_mclk1_clk",
  1439. .parent_hws = (const struct clk_hw*[]){
  1440. &mclk1_clk_src.clkr.hw
  1441. },
  1442. .num_parents = 1,
  1443. .flags = CLK_SET_RATE_PARENT,
  1444. .ops = &clk_branch2_ops,
  1445. },
  1446. },
  1447. };
  1448. static struct clk_branch camss_mclk2_clk = {
  1449. .halt_reg = 0x33e4,
  1450. .clkr = {
  1451. .enable_reg = 0x33e4,
  1452. .enable_mask = BIT(0),
  1453. .hw.init = &(struct clk_init_data){
  1454. .name = "camss_mclk2_clk",
  1455. .parent_hws = (const struct clk_hw*[]){
  1456. &mclk2_clk_src.clkr.hw
  1457. },
  1458. .num_parents = 1,
  1459. .flags = CLK_SET_RATE_PARENT,
  1460. .ops = &clk_branch2_ops,
  1461. },
  1462. },
  1463. };
  1464. static struct clk_branch camss_mclk3_clk = {
  1465. .halt_reg = 0x3414,
  1466. .clkr = {
  1467. .enable_reg = 0x3414,
  1468. .enable_mask = BIT(0),
  1469. .hw.init = &(struct clk_init_data){
  1470. .name = "camss_mclk3_clk",
  1471. .parent_hws = (const struct clk_hw*[]){
  1472. &mclk3_clk_src.clkr.hw
  1473. },
  1474. .num_parents = 1,
  1475. .flags = CLK_SET_RATE_PARENT,
  1476. .ops = &clk_branch2_ops,
  1477. },
  1478. },
  1479. };
  1480. static struct clk_branch camss_micro_ahb_clk = {
  1481. .halt_reg = 0x3494,
  1482. .clkr = {
  1483. .enable_reg = 0x3494,
  1484. .enable_mask = BIT(0),
  1485. .hw.init = &(struct clk_init_data){
  1486. .name = "camss_micro_ahb_clk",
  1487. .parent_hws = (const struct clk_hw*[]){
  1488. &mmss_ahb_clk_src.clkr.hw
  1489. },
  1490. .num_parents = 1,
  1491. .ops = &clk_branch2_ops,
  1492. },
  1493. },
  1494. };
  1495. static struct clk_branch camss_phy0_csi0phytimer_clk = {
  1496. .halt_reg = 0x3024,
  1497. .clkr = {
  1498. .enable_reg = 0x3024,
  1499. .enable_mask = BIT(0),
  1500. .hw.init = &(struct clk_init_data){
  1501. .name = "camss_phy0_csi0phytimer_clk",
  1502. .parent_hws = (const struct clk_hw*[]){
  1503. &csi0phytimer_clk_src.clkr.hw
  1504. },
  1505. .num_parents = 1,
  1506. .flags = CLK_SET_RATE_PARENT,
  1507. .ops = &clk_branch2_ops,
  1508. },
  1509. },
  1510. };
  1511. static struct clk_branch camss_phy1_csi1phytimer_clk = {
  1512. .halt_reg = 0x3054,
  1513. .clkr = {
  1514. .enable_reg = 0x3054,
  1515. .enable_mask = BIT(0),
  1516. .hw.init = &(struct clk_init_data){
  1517. .name = "camss_phy1_csi1phytimer_clk",
  1518. .parent_hws = (const struct clk_hw*[]){
  1519. &csi1phytimer_clk_src.clkr.hw
  1520. },
  1521. .num_parents = 1,
  1522. .flags = CLK_SET_RATE_PARENT,
  1523. .ops = &clk_branch2_ops,
  1524. },
  1525. },
  1526. };
  1527. static struct clk_branch camss_phy2_csi2phytimer_clk = {
  1528. .halt_reg = 0x3084,
  1529. .clkr = {
  1530. .enable_reg = 0x3084,
  1531. .enable_mask = BIT(0),
  1532. .hw.init = &(struct clk_init_data){
  1533. .name = "camss_phy2_csi2phytimer_clk",
  1534. .parent_hws = (const struct clk_hw*[]){
  1535. &csi2phytimer_clk_src.clkr.hw
  1536. },
  1537. .num_parents = 1,
  1538. .flags = CLK_SET_RATE_PARENT,
  1539. .ops = &clk_branch2_ops,
  1540. },
  1541. },
  1542. };
  1543. static struct clk_branch camss_top_ahb_clk = {
  1544. .halt_reg = 0x3484,
  1545. .clkr = {
  1546. .enable_reg = 0x3484,
  1547. .enable_mask = BIT(0),
  1548. .hw.init = &(struct clk_init_data){
  1549. .name = "camss_top_ahb_clk",
  1550. .parent_hws = (const struct clk_hw*[]){
  1551. &mmss_ahb_clk_src.clkr.hw
  1552. },
  1553. .num_parents = 1,
  1554. .ops = &clk_branch2_ops,
  1555. },
  1556. },
  1557. };
  1558. static struct clk_branch camss_vfe_cpp_ahb_clk = {
  1559. .halt_reg = 0x36b4,
  1560. .clkr = {
  1561. .enable_reg = 0x36b4,
  1562. .enable_mask = BIT(0),
  1563. .hw.init = &(struct clk_init_data){
  1564. .name = "camss_vfe_cpp_ahb_clk",
  1565. .parent_hws = (const struct clk_hw*[]){
  1566. &mmss_ahb_clk_src.clkr.hw
  1567. },
  1568. .num_parents = 1,
  1569. .ops = &clk_branch2_ops,
  1570. },
  1571. },
  1572. };
  1573. static struct clk_branch camss_vfe_cpp_clk = {
  1574. .halt_reg = 0x36b0,
  1575. .clkr = {
  1576. .enable_reg = 0x36b0,
  1577. .enable_mask = BIT(0),
  1578. .hw.init = &(struct clk_init_data){
  1579. .name = "camss_vfe_cpp_clk",
  1580. .parent_hws = (const struct clk_hw*[]){
  1581. &cpp_clk_src.clkr.hw
  1582. },
  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*[]){
  1597. &vfe0_clk_src.clkr.hw
  1598. },
  1599. .num_parents = 1,
  1600. .flags = CLK_SET_RATE_PARENT,
  1601. .ops = &clk_branch2_ops,
  1602. },
  1603. },
  1604. };
  1605. static struct clk_branch camss_vfe_vfe1_clk = {
  1606. .halt_reg = 0x36ac,
  1607. .clkr = {
  1608. .enable_reg = 0x36ac,
  1609. .enable_mask = BIT(0),
  1610. .hw.init = &(struct clk_init_data){
  1611. .name = "camss_vfe_vfe1_clk",
  1612. .parent_hws = (const struct clk_hw*[]){
  1613. &vfe1_clk_src.clkr.hw
  1614. },
  1615. .num_parents = 1,
  1616. .flags = CLK_SET_RATE_PARENT,
  1617. .ops = &clk_branch2_ops,
  1618. },
  1619. },
  1620. };
  1621. static struct clk_branch camss_vfe_vfe_ahb_clk = {
  1622. .halt_reg = 0x36b8,
  1623. .clkr = {
  1624. .enable_reg = 0x36b8,
  1625. .enable_mask = BIT(0),
  1626. .hw.init = &(struct clk_init_data){
  1627. .name = "camss_vfe_vfe_ahb_clk",
  1628. .parent_hws = (const struct clk_hw*[]){
  1629. &mmss_ahb_clk_src.clkr.hw
  1630. },
  1631. .num_parents = 1,
  1632. .ops = &clk_branch2_ops,
  1633. },
  1634. },
  1635. };
  1636. static struct clk_branch camss_vfe_vfe_axi_clk = {
  1637. .halt_reg = 0x36bc,
  1638. .clkr = {
  1639. .enable_reg = 0x36bc,
  1640. .enable_mask = BIT(0),
  1641. .hw.init = &(struct clk_init_data){
  1642. .name = "camss_vfe_vfe_axi_clk",
  1643. .parent_hws = (const struct clk_hw*[]){
  1644. &mmss_axi_clk_src.clkr.hw
  1645. },
  1646. .num_parents = 1,
  1647. .ops = &clk_branch2_ops,
  1648. },
  1649. },
  1650. };
  1651. static struct clk_branch camss_vfe_vfe_ocmemnoc_clk = {
  1652. .halt_reg = 0x36c0,
  1653. .clkr = {
  1654. .enable_reg = 0x36c0,
  1655. .enable_mask = BIT(0),
  1656. .hw.init = &(struct clk_init_data){
  1657. .name = "camss_vfe_vfe_ocmemnoc_clk",
  1658. .parent_hws = (const struct clk_hw*[]){
  1659. &ocmemnoc_clk_src.clkr.hw
  1660. },
  1661. .num_parents = 1,
  1662. .flags = CLK_SET_RATE_PARENT,
  1663. .ops = &clk_branch2_ops,
  1664. },
  1665. },
  1666. };
  1667. static struct clk_branch mdss_ahb_clk = {
  1668. .halt_reg = 0x2308,
  1669. .clkr = {
  1670. .enable_reg = 0x2308,
  1671. .enable_mask = BIT(0),
  1672. .hw.init = &(struct clk_init_data){
  1673. .name = "mdss_ahb_clk",
  1674. .parent_hws = (const struct clk_hw*[]){
  1675. &mmss_ahb_clk_src.clkr.hw
  1676. },
  1677. .num_parents = 1,
  1678. .ops = &clk_branch2_ops,
  1679. },
  1680. },
  1681. };
  1682. static struct clk_branch mdss_axi_clk = {
  1683. .halt_reg = 0x2310,
  1684. .clkr = {
  1685. .enable_reg = 0x2310,
  1686. .enable_mask = BIT(0),
  1687. .hw.init = &(struct clk_init_data){
  1688. .name = "mdss_axi_clk",
  1689. .parent_hws = (const struct clk_hw*[]){
  1690. &mmss_axi_clk_src.clkr.hw
  1691. },
  1692. .num_parents = 1,
  1693. .flags = CLK_SET_RATE_PARENT,
  1694. .ops = &clk_branch2_ops,
  1695. },
  1696. },
  1697. };
  1698. static struct clk_branch mdss_byte0_clk = {
  1699. .halt_reg = 0x233c,
  1700. .clkr = {
  1701. .enable_reg = 0x233c,
  1702. .enable_mask = BIT(0),
  1703. .hw.init = &(struct clk_init_data){
  1704. .name = "mdss_byte0_clk",
  1705. .parent_hws = (const struct clk_hw*[]){
  1706. &byte0_clk_src.clkr.hw
  1707. },
  1708. .num_parents = 1,
  1709. .flags = CLK_SET_RATE_PARENT,
  1710. .ops = &clk_branch2_ops,
  1711. },
  1712. },
  1713. };
  1714. static struct clk_branch mdss_byte1_clk = {
  1715. .halt_reg = 0x2340,
  1716. .clkr = {
  1717. .enable_reg = 0x2340,
  1718. .enable_mask = BIT(0),
  1719. .hw.init = &(struct clk_init_data){
  1720. .name = "mdss_byte1_clk",
  1721. .parent_hws = (const struct clk_hw*[]){
  1722. &byte1_clk_src.clkr.hw
  1723. },
  1724. .num_parents = 1,
  1725. .flags = CLK_SET_RATE_PARENT,
  1726. .ops = &clk_branch2_ops,
  1727. },
  1728. },
  1729. };
  1730. static struct clk_branch mdss_edpaux_clk = {
  1731. .halt_reg = 0x2334,
  1732. .clkr = {
  1733. .enable_reg = 0x2334,
  1734. .enable_mask = BIT(0),
  1735. .hw.init = &(struct clk_init_data){
  1736. .name = "mdss_edpaux_clk",
  1737. .parent_hws = (const struct clk_hw*[]){
  1738. &edpaux_clk_src.clkr.hw
  1739. },
  1740. .num_parents = 1,
  1741. .flags = CLK_SET_RATE_PARENT,
  1742. .ops = &clk_branch2_ops,
  1743. },
  1744. },
  1745. };
  1746. static struct clk_branch mdss_edplink_clk = {
  1747. .halt_reg = 0x2330,
  1748. .clkr = {
  1749. .enable_reg = 0x2330,
  1750. .enable_mask = BIT(0),
  1751. .hw.init = &(struct clk_init_data){
  1752. .name = "mdss_edplink_clk",
  1753. .parent_hws = (const struct clk_hw*[]){
  1754. &edplink_clk_src.clkr.hw
  1755. },
  1756. .num_parents = 1,
  1757. .flags = CLK_SET_RATE_PARENT,
  1758. .ops = &clk_branch2_ops,
  1759. },
  1760. },
  1761. };
  1762. static struct clk_branch mdss_edppixel_clk = {
  1763. .halt_reg = 0x232c,
  1764. .clkr = {
  1765. .enable_reg = 0x232c,
  1766. .enable_mask = BIT(0),
  1767. .hw.init = &(struct clk_init_data){
  1768. .name = "mdss_edppixel_clk",
  1769. .parent_hws = (const struct clk_hw*[]){
  1770. &edppixel_clk_src.clkr.hw
  1771. },
  1772. .num_parents = 1,
  1773. .flags = CLK_SET_RATE_PARENT,
  1774. .ops = &clk_branch2_ops,
  1775. },
  1776. },
  1777. };
  1778. static struct clk_branch mdss_esc0_clk = {
  1779. .halt_reg = 0x2344,
  1780. .clkr = {
  1781. .enable_reg = 0x2344,
  1782. .enable_mask = BIT(0),
  1783. .hw.init = &(struct clk_init_data){
  1784. .name = "mdss_esc0_clk",
  1785. .parent_hws = (const struct clk_hw*[]){
  1786. &esc0_clk_src.clkr.hw
  1787. },
  1788. .num_parents = 1,
  1789. .flags = CLK_SET_RATE_PARENT,
  1790. .ops = &clk_branch2_ops,
  1791. },
  1792. },
  1793. };
  1794. static struct clk_branch mdss_esc1_clk = {
  1795. .halt_reg = 0x2348,
  1796. .clkr = {
  1797. .enable_reg = 0x2348,
  1798. .enable_mask = BIT(0),
  1799. .hw.init = &(struct clk_init_data){
  1800. .name = "mdss_esc1_clk",
  1801. .parent_hws = (const struct clk_hw*[]){
  1802. &esc1_clk_src.clkr.hw
  1803. },
  1804. .num_parents = 1,
  1805. .flags = CLK_SET_RATE_PARENT,
  1806. .ops = &clk_branch2_ops,
  1807. },
  1808. },
  1809. };
  1810. static struct clk_branch mdss_extpclk_clk = {
  1811. .halt_reg = 0x2324,
  1812. .clkr = {
  1813. .enable_reg = 0x2324,
  1814. .enable_mask = BIT(0),
  1815. .hw.init = &(struct clk_init_data){
  1816. .name = "mdss_extpclk_clk",
  1817. .parent_hws = (const struct clk_hw*[]){
  1818. &extpclk_clk_src.clkr.hw
  1819. },
  1820. .num_parents = 1,
  1821. .flags = CLK_SET_RATE_PARENT,
  1822. .ops = &clk_branch2_ops,
  1823. },
  1824. },
  1825. };
  1826. static struct clk_branch mdss_hdmi_ahb_clk = {
  1827. .halt_reg = 0x230c,
  1828. .clkr = {
  1829. .enable_reg = 0x230c,
  1830. .enable_mask = BIT(0),
  1831. .hw.init = &(struct clk_init_data){
  1832. .name = "mdss_hdmi_ahb_clk",
  1833. .parent_hws = (const struct clk_hw*[]){
  1834. &mmss_ahb_clk_src.clkr.hw
  1835. },
  1836. .num_parents = 1,
  1837. .ops = &clk_branch2_ops,
  1838. },
  1839. },
  1840. };
  1841. static struct clk_branch mdss_hdmi_clk = {
  1842. .halt_reg = 0x2338,
  1843. .clkr = {
  1844. .enable_reg = 0x2338,
  1845. .enable_mask = BIT(0),
  1846. .hw.init = &(struct clk_init_data){
  1847. .name = "mdss_hdmi_clk",
  1848. .parent_hws = (const struct clk_hw*[]){
  1849. &hdmi_clk_src.clkr.hw
  1850. },
  1851. .num_parents = 1,
  1852. .flags = CLK_SET_RATE_PARENT,
  1853. .ops = &clk_branch2_ops,
  1854. },
  1855. },
  1856. };
  1857. static struct clk_branch mdss_mdp_clk = {
  1858. .halt_reg = 0x231c,
  1859. .clkr = {
  1860. .enable_reg = 0x231c,
  1861. .enable_mask = BIT(0),
  1862. .hw.init = &(struct clk_init_data){
  1863. .name = "mdss_mdp_clk",
  1864. .parent_hws = (const struct clk_hw*[]){
  1865. &mdp_clk_src.clkr.hw
  1866. },
  1867. .num_parents = 1,
  1868. .flags = CLK_SET_RATE_PARENT,
  1869. .ops = &clk_branch2_ops,
  1870. },
  1871. },
  1872. };
  1873. static struct clk_branch mdss_mdp_lut_clk = {
  1874. .halt_reg = 0x2320,
  1875. .clkr = {
  1876. .enable_reg = 0x2320,
  1877. .enable_mask = BIT(0),
  1878. .hw.init = &(struct clk_init_data){
  1879. .name = "mdss_mdp_lut_clk",
  1880. .parent_hws = (const struct clk_hw*[]){
  1881. &mdp_clk_src.clkr.hw
  1882. },
  1883. .num_parents = 1,
  1884. .flags = CLK_SET_RATE_PARENT,
  1885. .ops = &clk_branch2_ops,
  1886. },
  1887. },
  1888. };
  1889. static struct clk_branch mdss_pclk0_clk = {
  1890. .halt_reg = 0x2314,
  1891. .clkr = {
  1892. .enable_reg = 0x2314,
  1893. .enable_mask = BIT(0),
  1894. .hw.init = &(struct clk_init_data){
  1895. .name = "mdss_pclk0_clk",
  1896. .parent_hws = (const struct clk_hw*[]){
  1897. &pclk0_clk_src.clkr.hw
  1898. },
  1899. .num_parents = 1,
  1900. .flags = CLK_SET_RATE_PARENT,
  1901. .ops = &clk_branch2_ops,
  1902. },
  1903. },
  1904. };
  1905. static struct clk_branch mdss_pclk1_clk = {
  1906. .halt_reg = 0x2318,
  1907. .clkr = {
  1908. .enable_reg = 0x2318,
  1909. .enable_mask = BIT(0),
  1910. .hw.init = &(struct clk_init_data){
  1911. .name = "mdss_pclk1_clk",
  1912. .parent_hws = (const struct clk_hw*[]){
  1913. &pclk1_clk_src.clkr.hw
  1914. },
  1915. .num_parents = 1,
  1916. .flags = CLK_SET_RATE_PARENT,
  1917. .ops = &clk_branch2_ops,
  1918. },
  1919. },
  1920. };
  1921. static struct clk_branch mdss_vsync_clk = {
  1922. .halt_reg = 0x2328,
  1923. .clkr = {
  1924. .enable_reg = 0x2328,
  1925. .enable_mask = BIT(0),
  1926. .hw.init = &(struct clk_init_data){
  1927. .name = "mdss_vsync_clk",
  1928. .parent_hws = (const struct clk_hw*[]){
  1929. &vsync_clk_src.clkr.hw
  1930. },
  1931. .num_parents = 1,
  1932. .flags = CLK_SET_RATE_PARENT,
  1933. .ops = &clk_branch2_ops,
  1934. },
  1935. },
  1936. };
  1937. static struct clk_branch mmss_misc_ahb_clk = {
  1938. .halt_reg = 0x502c,
  1939. .clkr = {
  1940. .enable_reg = 0x502c,
  1941. .enable_mask = BIT(0),
  1942. .hw.init = &(struct clk_init_data){
  1943. .name = "mmss_misc_ahb_clk",
  1944. .parent_hws = (const struct clk_hw*[]){
  1945. &mmss_ahb_clk_src.clkr.hw
  1946. },
  1947. .num_parents = 1,
  1948. .ops = &clk_branch2_ops,
  1949. },
  1950. },
  1951. };
  1952. static struct clk_branch mmss_mmssnoc_ahb_clk = {
  1953. .halt_reg = 0x5024,
  1954. .clkr = {
  1955. .enable_reg = 0x5024,
  1956. .enable_mask = BIT(0),
  1957. .hw.init = &(struct clk_init_data){
  1958. .name = "mmss_mmssnoc_ahb_clk",
  1959. .parent_hws = (const struct clk_hw*[]){
  1960. &mmss_ahb_clk_src.clkr.hw
  1961. },
  1962. .num_parents = 1,
  1963. .ops = &clk_branch2_ops,
  1964. .flags = CLK_IGNORE_UNUSED,
  1965. },
  1966. },
  1967. };
  1968. static struct clk_branch mmss_mmssnoc_bto_ahb_clk = {
  1969. .halt_reg = 0x5028,
  1970. .clkr = {
  1971. .enable_reg = 0x5028,
  1972. .enable_mask = BIT(0),
  1973. .hw.init = &(struct clk_init_data){
  1974. .name = "mmss_mmssnoc_bto_ahb_clk",
  1975. .parent_hws = (const struct clk_hw*[]){
  1976. &mmss_ahb_clk_src.clkr.hw
  1977. },
  1978. .num_parents = 1,
  1979. .ops = &clk_branch2_ops,
  1980. .flags = CLK_IGNORE_UNUSED,
  1981. },
  1982. },
  1983. };
  1984. static struct clk_branch mmss_mmssnoc_axi_clk = {
  1985. .halt_reg = 0x506c,
  1986. .clkr = {
  1987. .enable_reg = 0x506c,
  1988. .enable_mask = BIT(0),
  1989. .hw.init = &(struct clk_init_data){
  1990. .name = "mmss_mmssnoc_axi_clk",
  1991. .parent_hws = (const struct clk_hw*[]){
  1992. &mmss_axi_clk_src.clkr.hw
  1993. },
  1994. .num_parents = 1,
  1995. .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
  1996. .ops = &clk_branch2_ops,
  1997. },
  1998. },
  1999. };
  2000. static struct clk_branch mmss_s0_axi_clk = {
  2001. .halt_reg = 0x5064,
  2002. .clkr = {
  2003. .enable_reg = 0x5064,
  2004. .enable_mask = BIT(0),
  2005. .hw.init = &(struct clk_init_data){
  2006. .name = "mmss_s0_axi_clk",
  2007. .parent_hws = (const struct clk_hw*[]){
  2008. &mmss_axi_clk_src.clkr.hw
  2009. },
  2010. .num_parents = 1,
  2011. .ops = &clk_branch2_ops,
  2012. .flags = CLK_IGNORE_UNUSED,
  2013. },
  2014. },
  2015. };
  2016. static struct clk_branch ocmemcx_ocmemnoc_clk = {
  2017. .halt_reg = 0x4058,
  2018. .clkr = {
  2019. .enable_reg = 0x4058,
  2020. .enable_mask = BIT(0),
  2021. .hw.init = &(struct clk_init_data){
  2022. .name = "ocmemcx_ocmemnoc_clk",
  2023. .parent_hws = (const struct clk_hw*[]){
  2024. &ocmemnoc_clk_src.clkr.hw
  2025. },
  2026. .num_parents = 1,
  2027. .flags = CLK_SET_RATE_PARENT,
  2028. .ops = &clk_branch2_ops,
  2029. },
  2030. },
  2031. };
  2032. static struct clk_branch ocmemnoc_clk = {
  2033. .halt_reg = 0x50b4,
  2034. .clkr = {
  2035. .enable_reg = 0x50b4,
  2036. .enable_mask = BIT(0),
  2037. .hw.init = &(struct clk_init_data){
  2038. .name = "ocmemnoc_clk",
  2039. .parent_hws = (const struct clk_hw*[]){
  2040. &ocmemnoc_clk_src.clkr.hw
  2041. },
  2042. .num_parents = 1,
  2043. .flags = CLK_SET_RATE_PARENT,
  2044. .ops = &clk_branch2_ops,
  2045. },
  2046. },
  2047. };
  2048. static struct clk_branch oxili_gfx3d_clk = {
  2049. .halt_reg = 0x4028,
  2050. .clkr = {
  2051. .enable_reg = 0x4028,
  2052. .enable_mask = BIT(0),
  2053. .hw.init = &(struct clk_init_data){
  2054. .name = "oxili_gfx3d_clk",
  2055. .parent_data = (const struct clk_parent_data[]){
  2056. { .fw_name = "gfx3d_clk_src", .name = "gfx3d_clk_src" },
  2057. },
  2058. .num_parents = 1,
  2059. .flags = CLK_SET_RATE_PARENT,
  2060. .ops = &clk_branch2_ops,
  2061. },
  2062. },
  2063. };
  2064. static struct clk_branch oxilicx_ahb_clk = {
  2065. .halt_reg = 0x403c,
  2066. .clkr = {
  2067. .enable_reg = 0x403c,
  2068. .enable_mask = BIT(0),
  2069. .hw.init = &(struct clk_init_data){
  2070. .name = "oxilicx_ahb_clk",
  2071. .parent_hws = (const struct clk_hw*[]){
  2072. &mmss_ahb_clk_src.clkr.hw
  2073. },
  2074. .num_parents = 1,
  2075. .ops = &clk_branch2_ops,
  2076. },
  2077. },
  2078. };
  2079. static struct clk_branch oxilicx_axi_clk = {
  2080. .halt_reg = 0x4038,
  2081. .clkr = {
  2082. .enable_reg = 0x4038,
  2083. .enable_mask = BIT(0),
  2084. .hw.init = &(struct clk_init_data){
  2085. .name = "oxilicx_axi_clk",
  2086. .parent_hws = (const struct clk_hw*[]){
  2087. &mmss_axi_clk_src.clkr.hw
  2088. },
  2089. .num_parents = 1,
  2090. .ops = &clk_branch2_ops,
  2091. },
  2092. },
  2093. };
  2094. static struct clk_branch venus0_ahb_clk = {
  2095. .halt_reg = 0x1030,
  2096. .clkr = {
  2097. .enable_reg = 0x1030,
  2098. .enable_mask = BIT(0),
  2099. .hw.init = &(struct clk_init_data){
  2100. .name = "venus0_ahb_clk",
  2101. .parent_hws = (const struct clk_hw*[]){
  2102. &mmss_ahb_clk_src.clkr.hw
  2103. },
  2104. .num_parents = 1,
  2105. .ops = &clk_branch2_ops,
  2106. },
  2107. },
  2108. };
  2109. static struct clk_branch venus0_axi_clk = {
  2110. .halt_reg = 0x1034,
  2111. .clkr = {
  2112. .enable_reg = 0x1034,
  2113. .enable_mask = BIT(0),
  2114. .hw.init = &(struct clk_init_data){
  2115. .name = "venus0_axi_clk",
  2116. .parent_hws = (const struct clk_hw*[]){
  2117. &mmss_axi_clk_src.clkr.hw
  2118. },
  2119. .num_parents = 1,
  2120. .ops = &clk_branch2_ops,
  2121. },
  2122. },
  2123. };
  2124. static struct clk_branch venus0_ocmemnoc_clk = {
  2125. .halt_reg = 0x1038,
  2126. .clkr = {
  2127. .enable_reg = 0x1038,
  2128. .enable_mask = BIT(0),
  2129. .hw.init = &(struct clk_init_data){
  2130. .name = "venus0_ocmemnoc_clk",
  2131. .parent_hws = (const struct clk_hw*[]){
  2132. &ocmemnoc_clk_src.clkr.hw
  2133. },
  2134. .num_parents = 1,
  2135. .flags = CLK_SET_RATE_PARENT,
  2136. .ops = &clk_branch2_ops,
  2137. },
  2138. },
  2139. };
  2140. static struct clk_branch venus0_vcodec0_clk = {
  2141. .halt_reg = 0x1028,
  2142. .clkr = {
  2143. .enable_reg = 0x1028,
  2144. .enable_mask = BIT(0),
  2145. .hw.init = &(struct clk_init_data){
  2146. .name = "venus0_vcodec0_clk",
  2147. .parent_hws = (const struct clk_hw*[]){
  2148. &vcodec0_clk_src.clkr.hw
  2149. },
  2150. .num_parents = 1,
  2151. .flags = CLK_SET_RATE_PARENT,
  2152. .ops = &clk_branch2_ops,
  2153. },
  2154. },
  2155. };
  2156. static const struct pll_config mmpll1_config = {
  2157. .l = 60,
  2158. .m = 25,
  2159. .n = 32,
  2160. .vco_val = 0x0,
  2161. .vco_mask = 0x3 << 20,
  2162. .pre_div_val = 0x0,
  2163. .pre_div_mask = 0x7 << 12,
  2164. .post_div_val = 0x0,
  2165. .post_div_mask = 0x3 << 8,
  2166. .mn_ena_mask = BIT(24),
  2167. .main_output_mask = BIT(0),
  2168. };
  2169. static struct pll_config mmpll3_config = {
  2170. .l = 48,
  2171. .m = 7,
  2172. .n = 16,
  2173. .vco_val = 0x0,
  2174. .vco_mask = 0x3 << 20,
  2175. .pre_div_val = 0x0,
  2176. .pre_div_mask = 0x7 << 12,
  2177. .post_div_val = 0x0,
  2178. .post_div_mask = 0x3 << 8,
  2179. .mn_ena_mask = BIT(24),
  2180. .main_output_mask = BIT(0),
  2181. .aux_output_mask = BIT(1),
  2182. };
  2183. static struct gdsc venus0_gdsc = {
  2184. .gdscr = 0x1024,
  2185. .cxcs = (unsigned int []){ 0x1028 },
  2186. .cxc_count = 1,
  2187. .resets = (unsigned int []){ VENUS0_RESET },
  2188. .reset_count = 1,
  2189. .pd = {
  2190. .name = "venus0",
  2191. },
  2192. .pwrsts = PWRSTS_ON,
  2193. };
  2194. static struct gdsc mdss_gdsc = {
  2195. .gdscr = 0x2304,
  2196. .cxcs = (unsigned int []){ 0x231c, 0x2320 },
  2197. .cxc_count = 2,
  2198. .pd = {
  2199. .name = "mdss",
  2200. },
  2201. .pwrsts = PWRSTS_OFF_ON,
  2202. };
  2203. static struct gdsc camss_jpeg_gdsc = {
  2204. .gdscr = 0x35a4,
  2205. .cxcs = (unsigned int []){ 0x35a8, 0x35ac, 0x35b0 },
  2206. .cxc_count = 3,
  2207. .pd = {
  2208. .name = "camss_jpeg",
  2209. },
  2210. .pwrsts = PWRSTS_OFF_ON,
  2211. };
  2212. static struct gdsc camss_vfe_gdsc = {
  2213. .gdscr = 0x36a4,
  2214. .cxcs = (unsigned int []){ 0x36a8, 0x36ac, 0x3704, 0x3714, 0x36b0 },
  2215. .cxc_count = 5,
  2216. .pd = {
  2217. .name = "camss_vfe",
  2218. },
  2219. .pwrsts = PWRSTS_OFF_ON,
  2220. };
  2221. static struct gdsc oxili_gdsc = {
  2222. .gdscr = 0x4024,
  2223. .cxcs = (unsigned int []){ 0x4028 },
  2224. .cxc_count = 1,
  2225. .pd = {
  2226. .name = "oxili",
  2227. },
  2228. .pwrsts = PWRSTS_OFF_ON,
  2229. };
  2230. static struct gdsc oxilicx_gdsc = {
  2231. .gdscr = 0x4034,
  2232. .pd = {
  2233. .name = "oxilicx",
  2234. },
  2235. .parent = &oxili_gdsc.pd,
  2236. .pwrsts = PWRSTS_OFF_ON,
  2237. };
  2238. static struct gdsc oxili_cx_gdsc_msm8226 = {
  2239. .gdscr = 0x4034,
  2240. .cxcs = (unsigned int []){ 0x4028 },
  2241. .cxc_count = 1,
  2242. .pd = {
  2243. .name = "oxili_cx",
  2244. },
  2245. .pwrsts = PWRSTS_OFF_ON,
  2246. };
  2247. static struct clk_regmap *mmcc_msm8226_clocks[] = {
  2248. [MMSS_AHB_CLK_SRC] = &mmss_ahb_clk_src.clkr,
  2249. [MMSS_AXI_CLK_SRC] = &mmss_axi_clk_src.clkr,
  2250. [MMPLL0] = &mmpll0.clkr,
  2251. [MMPLL0_VOTE] = &mmpll0_vote,
  2252. [MMPLL1] = &mmpll1.clkr,
  2253. [MMPLL1_VOTE] = &mmpll1_vote,
  2254. [CSI0_CLK_SRC] = &csi0_clk_src.clkr,
  2255. [CSI1_CLK_SRC] = &csi1_clk_src.clkr,
  2256. [VFE0_CLK_SRC] = &vfe0_clk_src.clkr,
  2257. [MDP_CLK_SRC] = &mdp_clk_src.clkr,
  2258. [JPEG0_CLK_SRC] = &jpeg0_clk_src.clkr,
  2259. [PCLK0_CLK_SRC] = &pclk0_clk_src.clkr,
  2260. [VCODEC0_CLK_SRC] = &vcodec0_clk_src.clkr,
  2261. [CCI_CLK_SRC] = &cci_clk_src.clkr,
  2262. [CAMSS_GP0_CLK_SRC] = &camss_gp0_clk_src.clkr,
  2263. [CAMSS_GP1_CLK_SRC] = &camss_gp1_clk_src.clkr,
  2264. [MCLK0_CLK_SRC] = &mclk0_clk_src.clkr,
  2265. [MCLK1_CLK_SRC] = &mclk1_clk_src.clkr,
  2266. [CSI0PHYTIMER_CLK_SRC] = &csi0phytimer_clk_src.clkr,
  2267. [CSI1PHYTIMER_CLK_SRC] = &csi1phytimer_clk_src.clkr,
  2268. [CPP_CLK_SRC] = &cpp_clk_src.clkr,
  2269. [BYTE0_CLK_SRC] = &byte0_clk_src.clkr,
  2270. [ESC0_CLK_SRC] = &esc0_clk_src.clkr,
  2271. [VSYNC_CLK_SRC] = &vsync_clk_src.clkr,
  2272. [CAMSS_CCI_CCI_AHB_CLK] = &camss_cci_cci_ahb_clk.clkr,
  2273. [CAMSS_CCI_CCI_CLK] = &camss_cci_cci_clk.clkr,
  2274. [CAMSS_CSI0_AHB_CLK] = &camss_csi0_ahb_clk.clkr,
  2275. [CAMSS_CSI0_CLK] = &camss_csi0_clk.clkr,
  2276. [CAMSS_CSI0PHY_CLK] = &camss_csi0phy_clk.clkr,
  2277. [CAMSS_CSI0PIX_CLK] = &camss_csi0pix_clk.clkr,
  2278. [CAMSS_CSI0RDI_CLK] = &camss_csi0rdi_clk.clkr,
  2279. [CAMSS_CSI1_AHB_CLK] = &camss_csi1_ahb_clk.clkr,
  2280. [CAMSS_CSI1_CLK] = &camss_csi1_clk.clkr,
  2281. [CAMSS_CSI1PHY_CLK] = &camss_csi1phy_clk.clkr,
  2282. [CAMSS_CSI1PIX_CLK] = &camss_csi1pix_clk.clkr,
  2283. [CAMSS_CSI1RDI_CLK] = &camss_csi1rdi_clk.clkr,
  2284. [CAMSS_CSI_VFE0_CLK] = &camss_csi_vfe0_clk.clkr,
  2285. [CAMSS_GP0_CLK] = &camss_gp0_clk.clkr,
  2286. [CAMSS_GP1_CLK] = &camss_gp1_clk.clkr,
  2287. [CAMSS_ISPIF_AHB_CLK] = &camss_ispif_ahb_clk.clkr,
  2288. [CAMSS_JPEG_JPEG0_CLK] = &camss_jpeg_jpeg0_clk.clkr,
  2289. [CAMSS_JPEG_JPEG_AHB_CLK] = &camss_jpeg_jpeg_ahb_clk.clkr,
  2290. [CAMSS_JPEG_JPEG_AXI_CLK] = &camss_jpeg_jpeg_axi_clk.clkr,
  2291. [CAMSS_MCLK0_CLK] = &camss_mclk0_clk.clkr,
  2292. [CAMSS_MCLK1_CLK] = &camss_mclk1_clk.clkr,
  2293. [CAMSS_MICRO_AHB_CLK] = &camss_micro_ahb_clk.clkr,
  2294. [CAMSS_PHY0_CSI0PHYTIMER_CLK] = &camss_phy0_csi0phytimer_clk.clkr,
  2295. [CAMSS_PHY1_CSI1PHYTIMER_CLK] = &camss_phy1_csi1phytimer_clk.clkr,
  2296. [CAMSS_TOP_AHB_CLK] = &camss_top_ahb_clk.clkr,
  2297. [CAMSS_VFE_CPP_AHB_CLK] = &camss_vfe_cpp_ahb_clk.clkr,
  2298. [CAMSS_VFE_CPP_CLK] = &camss_vfe_cpp_clk.clkr,
  2299. [CAMSS_VFE_VFE0_CLK] = &camss_vfe_vfe0_clk.clkr,
  2300. [CAMSS_VFE_VFE_AHB_CLK] = &camss_vfe_vfe_ahb_clk.clkr,
  2301. [CAMSS_VFE_VFE_AXI_CLK] = &camss_vfe_vfe_axi_clk.clkr,
  2302. [MDSS_AHB_CLK] = &mdss_ahb_clk.clkr,
  2303. [MDSS_AXI_CLK] = &mdss_axi_clk.clkr,
  2304. [MDSS_BYTE0_CLK] = &mdss_byte0_clk.clkr,
  2305. [MDSS_ESC0_CLK] = &mdss_esc0_clk.clkr,
  2306. [MDSS_MDP_CLK] = &mdss_mdp_clk.clkr,
  2307. [MDSS_MDP_LUT_CLK] = &mdss_mdp_lut_clk.clkr,
  2308. [MDSS_PCLK0_CLK] = &mdss_pclk0_clk.clkr,
  2309. [MDSS_VSYNC_CLK] = &mdss_vsync_clk.clkr,
  2310. [MMSS_MISC_AHB_CLK] = &mmss_misc_ahb_clk.clkr,
  2311. [MMSS_MMSSNOC_AHB_CLK] = &mmss_mmssnoc_ahb_clk.clkr,
  2312. [MMSS_MMSSNOC_BTO_AHB_CLK] = &mmss_mmssnoc_bto_ahb_clk.clkr,
  2313. [MMSS_MMSSNOC_AXI_CLK] = &mmss_mmssnoc_axi_clk.clkr,
  2314. [MMSS_S0_AXI_CLK] = &mmss_s0_axi_clk.clkr,
  2315. [OXILI_GFX3D_CLK] = &oxili_gfx3d_clk.clkr,
  2316. [OXILICX_AHB_CLK] = &oxilicx_ahb_clk.clkr,
  2317. [OXILICX_AXI_CLK] = &oxilicx_axi_clk.clkr,
  2318. [VENUS0_AHB_CLK] = &venus0_ahb_clk.clkr,
  2319. [VENUS0_AXI_CLK] = &venus0_axi_clk.clkr,
  2320. [VENUS0_VCODEC0_CLK] = &venus0_vcodec0_clk.clkr,
  2321. };
  2322. static const struct qcom_reset_map mmcc_msm8226_resets[] = {
  2323. [SPDM_RESET] = { 0x0200 },
  2324. [SPDM_RM_RESET] = { 0x0300 },
  2325. [VENUS0_RESET] = { 0x1020 },
  2326. [MDSS_RESET] = { 0x2300 },
  2327. };
  2328. static struct gdsc *mmcc_msm8226_gdscs[] = {
  2329. [VENUS0_GDSC] = &venus0_gdsc,
  2330. [MDSS_GDSC] = &mdss_gdsc,
  2331. [CAMSS_JPEG_GDSC] = &camss_jpeg_gdsc,
  2332. [CAMSS_VFE_GDSC] = &camss_vfe_gdsc,
  2333. [OXILICX_GDSC] = &oxili_cx_gdsc_msm8226,
  2334. };
  2335. static const struct regmap_config mmcc_msm8226_regmap_config = {
  2336. .reg_bits = 32,
  2337. .reg_stride = 4,
  2338. .val_bits = 32,
  2339. .max_register = 0x5104,
  2340. .fast_io = true,
  2341. };
  2342. static const struct qcom_cc_desc mmcc_msm8226_desc = {
  2343. .config = &mmcc_msm8226_regmap_config,
  2344. .clks = mmcc_msm8226_clocks,
  2345. .num_clks = ARRAY_SIZE(mmcc_msm8226_clocks),
  2346. .resets = mmcc_msm8226_resets,
  2347. .num_resets = ARRAY_SIZE(mmcc_msm8226_resets),
  2348. .gdscs = mmcc_msm8226_gdscs,
  2349. .num_gdscs = ARRAY_SIZE(mmcc_msm8226_gdscs),
  2350. };
  2351. static struct clk_regmap *mmcc_msm8974_clocks[] = {
  2352. [MMSS_AHB_CLK_SRC] = &mmss_ahb_clk_src.clkr,
  2353. [MMSS_AXI_CLK_SRC] = &mmss_axi_clk_src.clkr,
  2354. [OCMEMNOC_CLK_SRC] = &ocmemnoc_clk_src.clkr,
  2355. [MMPLL0] = &mmpll0.clkr,
  2356. [MMPLL0_VOTE] = &mmpll0_vote,
  2357. [MMPLL1] = &mmpll1.clkr,
  2358. [MMPLL1_VOTE] = &mmpll1_vote,
  2359. [MMPLL2] = &mmpll2.clkr,
  2360. [MMPLL3] = &mmpll3.clkr,
  2361. [CSI0_CLK_SRC] = &csi0_clk_src.clkr,
  2362. [CSI1_CLK_SRC] = &csi1_clk_src.clkr,
  2363. [CSI2_CLK_SRC] = &csi2_clk_src.clkr,
  2364. [CSI3_CLK_SRC] = &csi3_clk_src.clkr,
  2365. [VFE0_CLK_SRC] = &vfe0_clk_src.clkr,
  2366. [VFE1_CLK_SRC] = &vfe1_clk_src.clkr,
  2367. [MDP_CLK_SRC] = &mdp_clk_src.clkr,
  2368. [JPEG0_CLK_SRC] = &jpeg0_clk_src.clkr,
  2369. [JPEG1_CLK_SRC] = &jpeg1_clk_src.clkr,
  2370. [JPEG2_CLK_SRC] = &jpeg2_clk_src.clkr,
  2371. [PCLK0_CLK_SRC] = &pclk0_clk_src.clkr,
  2372. [PCLK1_CLK_SRC] = &pclk1_clk_src.clkr,
  2373. [VCODEC0_CLK_SRC] = &vcodec0_clk_src.clkr,
  2374. [CCI_CLK_SRC] = &cci_clk_src.clkr,
  2375. [CAMSS_GP0_CLK_SRC] = &camss_gp0_clk_src.clkr,
  2376. [CAMSS_GP1_CLK_SRC] = &camss_gp1_clk_src.clkr,
  2377. [MCLK0_CLK_SRC] = &mclk0_clk_src.clkr,
  2378. [MCLK1_CLK_SRC] = &mclk1_clk_src.clkr,
  2379. [MCLK2_CLK_SRC] = &mclk2_clk_src.clkr,
  2380. [MCLK3_CLK_SRC] = &mclk3_clk_src.clkr,
  2381. [CSI0PHYTIMER_CLK_SRC] = &csi0phytimer_clk_src.clkr,
  2382. [CSI1PHYTIMER_CLK_SRC] = &csi1phytimer_clk_src.clkr,
  2383. [CSI2PHYTIMER_CLK_SRC] = &csi2phytimer_clk_src.clkr,
  2384. [CPP_CLK_SRC] = &cpp_clk_src.clkr,
  2385. [BYTE0_CLK_SRC] = &byte0_clk_src.clkr,
  2386. [BYTE1_CLK_SRC] = &byte1_clk_src.clkr,
  2387. [EDPAUX_CLK_SRC] = &edpaux_clk_src.clkr,
  2388. [EDPLINK_CLK_SRC] = &edplink_clk_src.clkr,
  2389. [EDPPIXEL_CLK_SRC] = &edppixel_clk_src.clkr,
  2390. [ESC0_CLK_SRC] = &esc0_clk_src.clkr,
  2391. [ESC1_CLK_SRC] = &esc1_clk_src.clkr,
  2392. [EXTPCLK_CLK_SRC] = &extpclk_clk_src.clkr,
  2393. [HDMI_CLK_SRC] = &hdmi_clk_src.clkr,
  2394. [VSYNC_CLK_SRC] = &vsync_clk_src.clkr,
  2395. [CAMSS_CCI_CCI_AHB_CLK] = &camss_cci_cci_ahb_clk.clkr,
  2396. [CAMSS_CCI_CCI_CLK] = &camss_cci_cci_clk.clkr,
  2397. [CAMSS_CSI0_AHB_CLK] = &camss_csi0_ahb_clk.clkr,
  2398. [CAMSS_CSI0_CLK] = &camss_csi0_clk.clkr,
  2399. [CAMSS_CSI0PHY_CLK] = &camss_csi0phy_clk.clkr,
  2400. [CAMSS_CSI0PIX_CLK] = &camss_csi0pix_clk.clkr,
  2401. [CAMSS_CSI0RDI_CLK] = &camss_csi0rdi_clk.clkr,
  2402. [CAMSS_CSI1_AHB_CLK] = &camss_csi1_ahb_clk.clkr,
  2403. [CAMSS_CSI1_CLK] = &camss_csi1_clk.clkr,
  2404. [CAMSS_CSI1PHY_CLK] = &camss_csi1phy_clk.clkr,
  2405. [CAMSS_CSI1PIX_CLK] = &camss_csi1pix_clk.clkr,
  2406. [CAMSS_CSI1RDI_CLK] = &camss_csi1rdi_clk.clkr,
  2407. [CAMSS_CSI2_AHB_CLK] = &camss_csi2_ahb_clk.clkr,
  2408. [CAMSS_CSI2_CLK] = &camss_csi2_clk.clkr,
  2409. [CAMSS_CSI2PHY_CLK] = &camss_csi2phy_clk.clkr,
  2410. [CAMSS_CSI2PIX_CLK] = &camss_csi2pix_clk.clkr,
  2411. [CAMSS_CSI2RDI_CLK] = &camss_csi2rdi_clk.clkr,
  2412. [CAMSS_CSI3_AHB_CLK] = &camss_csi3_ahb_clk.clkr,
  2413. [CAMSS_CSI3_CLK] = &camss_csi3_clk.clkr,
  2414. [CAMSS_CSI3PHY_CLK] = &camss_csi3phy_clk.clkr,
  2415. [CAMSS_CSI3PIX_CLK] = &camss_csi3pix_clk.clkr,
  2416. [CAMSS_CSI3RDI_CLK] = &camss_csi3rdi_clk.clkr,
  2417. [CAMSS_CSI_VFE0_CLK] = &camss_csi_vfe0_clk.clkr,
  2418. [CAMSS_CSI_VFE1_CLK] = &camss_csi_vfe1_clk.clkr,
  2419. [CAMSS_GP0_CLK] = &camss_gp0_clk.clkr,
  2420. [CAMSS_GP1_CLK] = &camss_gp1_clk.clkr,
  2421. [CAMSS_ISPIF_AHB_CLK] = &camss_ispif_ahb_clk.clkr,
  2422. [CAMSS_JPEG_JPEG0_CLK] = &camss_jpeg_jpeg0_clk.clkr,
  2423. [CAMSS_JPEG_JPEG1_CLK] = &camss_jpeg_jpeg1_clk.clkr,
  2424. [CAMSS_JPEG_JPEG2_CLK] = &camss_jpeg_jpeg2_clk.clkr,
  2425. [CAMSS_JPEG_JPEG_AHB_CLK] = &camss_jpeg_jpeg_ahb_clk.clkr,
  2426. [CAMSS_JPEG_JPEG_AXI_CLK] = &camss_jpeg_jpeg_axi_clk.clkr,
  2427. [CAMSS_JPEG_JPEG_OCMEMNOC_CLK] = &camss_jpeg_jpeg_ocmemnoc_clk.clkr,
  2428. [CAMSS_MCLK0_CLK] = &camss_mclk0_clk.clkr,
  2429. [CAMSS_MCLK1_CLK] = &camss_mclk1_clk.clkr,
  2430. [CAMSS_MCLK2_CLK] = &camss_mclk2_clk.clkr,
  2431. [CAMSS_MCLK3_CLK] = &camss_mclk3_clk.clkr,
  2432. [CAMSS_MICRO_AHB_CLK] = &camss_micro_ahb_clk.clkr,
  2433. [CAMSS_PHY0_CSI0PHYTIMER_CLK] = &camss_phy0_csi0phytimer_clk.clkr,
  2434. [CAMSS_PHY1_CSI1PHYTIMER_CLK] = &camss_phy1_csi1phytimer_clk.clkr,
  2435. [CAMSS_PHY2_CSI2PHYTIMER_CLK] = &camss_phy2_csi2phytimer_clk.clkr,
  2436. [CAMSS_TOP_AHB_CLK] = &camss_top_ahb_clk.clkr,
  2437. [CAMSS_VFE_CPP_AHB_CLK] = &camss_vfe_cpp_ahb_clk.clkr,
  2438. [CAMSS_VFE_CPP_CLK] = &camss_vfe_cpp_clk.clkr,
  2439. [CAMSS_VFE_VFE0_CLK] = &camss_vfe_vfe0_clk.clkr,
  2440. [CAMSS_VFE_VFE1_CLK] = &camss_vfe_vfe1_clk.clkr,
  2441. [CAMSS_VFE_VFE_AHB_CLK] = &camss_vfe_vfe_ahb_clk.clkr,
  2442. [CAMSS_VFE_VFE_AXI_CLK] = &camss_vfe_vfe_axi_clk.clkr,
  2443. [CAMSS_VFE_VFE_OCMEMNOC_CLK] = &camss_vfe_vfe_ocmemnoc_clk.clkr,
  2444. [MDSS_AHB_CLK] = &mdss_ahb_clk.clkr,
  2445. [MDSS_AXI_CLK] = &mdss_axi_clk.clkr,
  2446. [MDSS_BYTE0_CLK] = &mdss_byte0_clk.clkr,
  2447. [MDSS_BYTE1_CLK] = &mdss_byte1_clk.clkr,
  2448. [MDSS_EDPAUX_CLK] = &mdss_edpaux_clk.clkr,
  2449. [MDSS_EDPLINK_CLK] = &mdss_edplink_clk.clkr,
  2450. [MDSS_EDPPIXEL_CLK] = &mdss_edppixel_clk.clkr,
  2451. [MDSS_ESC0_CLK] = &mdss_esc0_clk.clkr,
  2452. [MDSS_ESC1_CLK] = &mdss_esc1_clk.clkr,
  2453. [MDSS_EXTPCLK_CLK] = &mdss_extpclk_clk.clkr,
  2454. [MDSS_HDMI_AHB_CLK] = &mdss_hdmi_ahb_clk.clkr,
  2455. [MDSS_HDMI_CLK] = &mdss_hdmi_clk.clkr,
  2456. [MDSS_MDP_CLK] = &mdss_mdp_clk.clkr,
  2457. [MDSS_MDP_LUT_CLK] = &mdss_mdp_lut_clk.clkr,
  2458. [MDSS_PCLK0_CLK] = &mdss_pclk0_clk.clkr,
  2459. [MDSS_PCLK1_CLK] = &mdss_pclk1_clk.clkr,
  2460. [MDSS_VSYNC_CLK] = &mdss_vsync_clk.clkr,
  2461. [MMSS_MISC_AHB_CLK] = &mmss_misc_ahb_clk.clkr,
  2462. [MMSS_MMSSNOC_AHB_CLK] = &mmss_mmssnoc_ahb_clk.clkr,
  2463. [MMSS_MMSSNOC_BTO_AHB_CLK] = &mmss_mmssnoc_bto_ahb_clk.clkr,
  2464. [MMSS_MMSSNOC_AXI_CLK] = &mmss_mmssnoc_axi_clk.clkr,
  2465. [MMSS_S0_AXI_CLK] = &mmss_s0_axi_clk.clkr,
  2466. [OCMEMCX_OCMEMNOC_CLK] = &ocmemcx_ocmemnoc_clk.clkr,
  2467. [OCMEMNOC_CLK] = &ocmemnoc_clk.clkr,
  2468. [OXILI_GFX3D_CLK] = &oxili_gfx3d_clk.clkr,
  2469. [OXILICX_AHB_CLK] = &oxilicx_ahb_clk.clkr,
  2470. [OXILICX_AXI_CLK] = &oxilicx_axi_clk.clkr,
  2471. [VENUS0_AHB_CLK] = &venus0_ahb_clk.clkr,
  2472. [VENUS0_AXI_CLK] = &venus0_axi_clk.clkr,
  2473. [VENUS0_OCMEMNOC_CLK] = &venus0_ocmemnoc_clk.clkr,
  2474. [VENUS0_VCODEC0_CLK] = &venus0_vcodec0_clk.clkr,
  2475. };
  2476. static const struct qcom_reset_map mmcc_msm8974_resets[] = {
  2477. [SPDM_RESET] = { 0x0200 },
  2478. [SPDM_RM_RESET] = { 0x0300 },
  2479. [VENUS0_RESET] = { 0x1020 },
  2480. [MDSS_RESET] = { 0x2300 },
  2481. [CAMSS_PHY0_RESET] = { 0x3020 },
  2482. [CAMSS_PHY1_RESET] = { 0x3050 },
  2483. [CAMSS_PHY2_RESET] = { 0x3080 },
  2484. [CAMSS_CSI0_RESET] = { 0x30b0 },
  2485. [CAMSS_CSI0PHY_RESET] = { 0x30c0 },
  2486. [CAMSS_CSI0RDI_RESET] = { 0x30d0 },
  2487. [CAMSS_CSI0PIX_RESET] = { 0x30e0 },
  2488. [CAMSS_CSI1_RESET] = { 0x3120 },
  2489. [CAMSS_CSI1PHY_RESET] = { 0x3130 },
  2490. [CAMSS_CSI1RDI_RESET] = { 0x3140 },
  2491. [CAMSS_CSI1PIX_RESET] = { 0x3150 },
  2492. [CAMSS_CSI2_RESET] = { 0x3180 },
  2493. [CAMSS_CSI2PHY_RESET] = { 0x3190 },
  2494. [CAMSS_CSI2RDI_RESET] = { 0x31a0 },
  2495. [CAMSS_CSI2PIX_RESET] = { 0x31b0 },
  2496. [CAMSS_CSI3_RESET] = { 0x31e0 },
  2497. [CAMSS_CSI3PHY_RESET] = { 0x31f0 },
  2498. [CAMSS_CSI3RDI_RESET] = { 0x3200 },
  2499. [CAMSS_CSI3PIX_RESET] = { 0x3210 },
  2500. [CAMSS_ISPIF_RESET] = { 0x3220 },
  2501. [CAMSS_CCI_RESET] = { 0x3340 },
  2502. [CAMSS_MCLK0_RESET] = { 0x3380 },
  2503. [CAMSS_MCLK1_RESET] = { 0x33b0 },
  2504. [CAMSS_MCLK2_RESET] = { 0x33e0 },
  2505. [CAMSS_MCLK3_RESET] = { 0x3410 },
  2506. [CAMSS_GP0_RESET] = { 0x3440 },
  2507. [CAMSS_GP1_RESET] = { 0x3470 },
  2508. [CAMSS_TOP_RESET] = { 0x3480 },
  2509. [CAMSS_MICRO_RESET] = { 0x3490 },
  2510. [CAMSS_JPEG_RESET] = { 0x35a0 },
  2511. [CAMSS_VFE_RESET] = { 0x36a0 },
  2512. [CAMSS_CSI_VFE0_RESET] = { 0x3700 },
  2513. [CAMSS_CSI_VFE1_RESET] = { 0x3710 },
  2514. [OXILI_RESET] = { 0x4020 },
  2515. [OXILICX_RESET] = { 0x4030 },
  2516. [OCMEMCX_RESET] = { 0x4050 },
  2517. [MMSS_RBCRP_RESET] = { 0x4080 },
  2518. [MMSSNOCAHB_RESET] = { 0x5020 },
  2519. [MMSSNOCAXI_RESET] = { 0x5060 },
  2520. [OCMEMNOC_RESET] = { 0x50b0 },
  2521. };
  2522. static struct gdsc *mmcc_msm8974_gdscs[] = {
  2523. [VENUS0_GDSC] = &venus0_gdsc,
  2524. [MDSS_GDSC] = &mdss_gdsc,
  2525. [CAMSS_JPEG_GDSC] = &camss_jpeg_gdsc,
  2526. [CAMSS_VFE_GDSC] = &camss_vfe_gdsc,
  2527. [OXILI_GDSC] = &oxili_gdsc,
  2528. [OXILICX_GDSC] = &oxilicx_gdsc,
  2529. };
  2530. static const struct regmap_config mmcc_msm8974_regmap_config = {
  2531. .reg_bits = 32,
  2532. .reg_stride = 4,
  2533. .val_bits = 32,
  2534. .max_register = 0x5104,
  2535. .fast_io = true,
  2536. };
  2537. static const struct qcom_cc_desc mmcc_msm8974_desc = {
  2538. .config = &mmcc_msm8974_regmap_config,
  2539. .clks = mmcc_msm8974_clocks,
  2540. .num_clks = ARRAY_SIZE(mmcc_msm8974_clocks),
  2541. .resets = mmcc_msm8974_resets,
  2542. .num_resets = ARRAY_SIZE(mmcc_msm8974_resets),
  2543. .gdscs = mmcc_msm8974_gdscs,
  2544. .num_gdscs = ARRAY_SIZE(mmcc_msm8974_gdscs),
  2545. };
  2546. static const struct of_device_id mmcc_msm8974_match_table[] = {
  2547. { .compatible = "qcom,mmcc-msm8226", .data = &mmcc_msm8226_desc },
  2548. { .compatible = "qcom,mmcc-msm8974", .data = &mmcc_msm8974_desc },
  2549. { }
  2550. };
  2551. MODULE_DEVICE_TABLE(of, mmcc_msm8974_match_table);
  2552. static void msm8226_clock_override(void)
  2553. {
  2554. mmss_axi_clk_src.freq_tbl = ftbl_mmss_axi_clk_msm8226;
  2555. vfe0_clk_src.freq_tbl = ftbl_camss_vfe_vfe0_clk_msm8226;
  2556. mdp_clk_src.freq_tbl = ftbl_mdss_mdp_clk_msm8226;
  2557. vcodec0_clk_src.freq_tbl = ftbl_venus0_vcodec0_clk_msm8226;
  2558. mclk0_clk_src.freq_tbl = ftbl_camss_mclk0_3_clk_msm8226;
  2559. mclk1_clk_src.freq_tbl = ftbl_camss_mclk0_3_clk_msm8226;
  2560. cpp_clk_src.freq_tbl = ftbl_camss_vfe_cpp_clk_msm8226;
  2561. }
  2562. static int mmcc_msm8974_probe(struct platform_device *pdev)
  2563. {
  2564. struct regmap *regmap;
  2565. const struct qcom_cc_desc *desc;
  2566. desc = of_device_get_match_data(&pdev->dev);
  2567. if (!desc)
  2568. return -EINVAL;
  2569. regmap = qcom_cc_map(pdev, desc);
  2570. if (IS_ERR(regmap))
  2571. return PTR_ERR(regmap);
  2572. if (desc == &mmcc_msm8974_desc) {
  2573. clk_pll_configure_sr_hpm_lp(&mmpll1, regmap, &mmpll1_config, true);
  2574. clk_pll_configure_sr_hpm_lp(&mmpll3, regmap, &mmpll3_config, false);
  2575. } else {
  2576. msm8226_clock_override();
  2577. }
  2578. return qcom_cc_really_probe(&pdev->dev, desc, regmap);
  2579. }
  2580. static struct platform_driver mmcc_msm8974_driver = {
  2581. .probe = mmcc_msm8974_probe,
  2582. .driver = {
  2583. .name = "mmcc-msm8974",
  2584. .of_match_table = mmcc_msm8974_match_table,
  2585. },
  2586. };
  2587. module_platform_driver(mmcc_msm8974_driver);
  2588. MODULE_DESCRIPTION("QCOM MMCC MSM8974 Driver");
  2589. MODULE_LICENSE("GPL v2");
  2590. MODULE_ALIAS("platform:mmcc-msm8974");