gxbb.c 92 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575257625772578257925802581258225832584258525862587258825892590259125922593259425952596259725982599260026012602260326042605260626072608260926102611261226132614261526162617261826192620262126222623262426252626262726282629263026312632263326342635263626372638263926402641264226432644264526462647264826492650265126522653265426552656265726582659266026612662266326642665266626672668266926702671267226732674267526762677267826792680268126822683268426852686268726882689269026912692269326942695269626972698269927002701270227032704270527062707270827092710271127122713271427152716271727182719272027212722272327242725272627272728272927302731273227332734273527362737273827392740274127422743274427452746274727482749275027512752275327542755275627572758275927602761276227632764276527662767276827692770277127722773277427752776277727782779278027812782278327842785278627872788278927902791279227932794279527962797279827992800280128022803280428052806280728082809281028112812281328142815281628172818281928202821282228232824282528262827282828292830283128322833283428352836283728382839284028412842284328442845284628472848284928502851285228532854285528562857285828592860286128622863286428652866286728682869287028712872287328742875287628772878287928802881288228832884288528862887288828892890289128922893289428952896289728982899290029012902290329042905290629072908290929102911291229132914291529162917291829192920292129222923292429252926292729282929293029312932293329342935293629372938293929402941294229432944294529462947294829492950295129522953295429552956295729582959296029612962296329642965296629672968296929702971297229732974297529762977297829792980298129822983298429852986298729882989299029912992299329942995299629972998299930003001300230033004300530063007300830093010301130123013301430153016301730183019302030213022302330243025302630273028302930303031303230333034303530363037303830393040304130423043304430453046304730483049305030513052305330543055305630573058305930603061306230633064306530663067306830693070307130723073307430753076307730783079308030813082308330843085308630873088308930903091309230933094309530963097309830993100310131023103310431053106310731083109311031113112311331143115311631173118311931203121312231233124312531263127312831293130313131323133313431353136313731383139314031413142314331443145314631473148314931503151315231533154315531563157315831593160316131623163316431653166316731683169317031713172317331743175317631773178317931803181318231833184318531863187318831893190319131923193319431953196319731983199320032013202320332043205320632073208320932103211321232133214321532163217321832193220322132223223322432253226322732283229323032313232323332343235323632373238323932403241324232433244324532463247324832493250325132523253325432553256325732583259326032613262326332643265326632673268326932703271327232733274327532763277327832793280328132823283328432853286328732883289329032913292329332943295329632973298329933003301330233033304330533063307330833093310331133123313331433153316331733183319332033213322332333243325332633273328332933303331333233333334333533363337333833393340334133423343334433453346334733483349335033513352335333543355335633573358335933603361336233633364336533663367336833693370337133723373337433753376337733783379338033813382338333843385338633873388338933903391339233933394339533963397339833993400340134023403340434053406340734083409341034113412341334143415341634173418341934203421342234233424342534263427342834293430343134323433343434353436343734383439344034413442344334443445344634473448344934503451345234533454345534563457345834593460346134623463346434653466346734683469347034713472347334743475347634773478347934803481348234833484348534863487348834893490349134923493349434953496349734983499350035013502350335043505350635073508350935103511351235133514351535163517351835193520352135223523352435253526352735283529353035313532353335343535353635373538353935403541354235433544354535463547354835493550355135523553355435553556355735583559356035613562356335643565356635673568356935703571357235733574
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * Copyright (c) 2016 AmLogic, Inc.
  4. * Michael Turquette <mturquette@baylibre.com>
  5. */
  6. #include <linux/clk-provider.h>
  7. #include <linux/init.h>
  8. #include <linux/mod_devicetable.h>
  9. #include <linux/platform_device.h>
  10. #include <linux/module.h>
  11. #include "gxbb.h"
  12. #include "clk-regmap.h"
  13. #include "clk-pll.h"
  14. #include "clk-mpll.h"
  15. #include "meson-eeclk.h"
  16. #include "vid-pll-div.h"
  17. #include <dt-bindings/clock/gxbb-clkc.h>
  18. static DEFINE_SPINLOCK(meson_clk_lock);
  19. static const struct pll_params_table gxbb_gp0_pll_params_table[] = {
  20. PLL_PARAMS(32, 1),
  21. PLL_PARAMS(33, 1),
  22. PLL_PARAMS(34, 1),
  23. PLL_PARAMS(35, 1),
  24. PLL_PARAMS(36, 1),
  25. PLL_PARAMS(37, 1),
  26. PLL_PARAMS(38, 1),
  27. PLL_PARAMS(39, 1),
  28. PLL_PARAMS(40, 1),
  29. PLL_PARAMS(41, 1),
  30. PLL_PARAMS(42, 1),
  31. PLL_PARAMS(43, 1),
  32. PLL_PARAMS(44, 1),
  33. PLL_PARAMS(45, 1),
  34. PLL_PARAMS(46, 1),
  35. PLL_PARAMS(47, 1),
  36. PLL_PARAMS(48, 1),
  37. PLL_PARAMS(49, 1),
  38. PLL_PARAMS(50, 1),
  39. PLL_PARAMS(51, 1),
  40. PLL_PARAMS(52, 1),
  41. PLL_PARAMS(53, 1),
  42. PLL_PARAMS(54, 1),
  43. PLL_PARAMS(55, 1),
  44. PLL_PARAMS(56, 1),
  45. PLL_PARAMS(57, 1),
  46. PLL_PARAMS(58, 1),
  47. PLL_PARAMS(59, 1),
  48. PLL_PARAMS(60, 1),
  49. PLL_PARAMS(61, 1),
  50. PLL_PARAMS(62, 1),
  51. { /* sentinel */ },
  52. };
  53. static const struct pll_params_table gxl_gp0_pll_params_table[] = {
  54. PLL_PARAMS(42, 1),
  55. PLL_PARAMS(43, 1),
  56. PLL_PARAMS(44, 1),
  57. PLL_PARAMS(45, 1),
  58. PLL_PARAMS(46, 1),
  59. PLL_PARAMS(47, 1),
  60. PLL_PARAMS(48, 1),
  61. PLL_PARAMS(49, 1),
  62. PLL_PARAMS(50, 1),
  63. PLL_PARAMS(51, 1),
  64. PLL_PARAMS(52, 1),
  65. PLL_PARAMS(53, 1),
  66. PLL_PARAMS(54, 1),
  67. PLL_PARAMS(55, 1),
  68. PLL_PARAMS(56, 1),
  69. PLL_PARAMS(57, 1),
  70. PLL_PARAMS(58, 1),
  71. PLL_PARAMS(59, 1),
  72. PLL_PARAMS(60, 1),
  73. PLL_PARAMS(61, 1),
  74. PLL_PARAMS(62, 1),
  75. PLL_PARAMS(63, 1),
  76. PLL_PARAMS(64, 1),
  77. PLL_PARAMS(65, 1),
  78. PLL_PARAMS(66, 1),
  79. { /* sentinel */ },
  80. };
  81. static struct clk_regmap gxbb_fixed_pll_dco = {
  82. .data = &(struct meson_clk_pll_data){
  83. .en = {
  84. .reg_off = HHI_MPLL_CNTL,
  85. .shift = 30,
  86. .width = 1,
  87. },
  88. .m = {
  89. .reg_off = HHI_MPLL_CNTL,
  90. .shift = 0,
  91. .width = 9,
  92. },
  93. .n = {
  94. .reg_off = HHI_MPLL_CNTL,
  95. .shift = 9,
  96. .width = 5,
  97. },
  98. .frac = {
  99. .reg_off = HHI_MPLL_CNTL2,
  100. .shift = 0,
  101. .width = 12,
  102. },
  103. .l = {
  104. .reg_off = HHI_MPLL_CNTL,
  105. .shift = 31,
  106. .width = 1,
  107. },
  108. .rst = {
  109. .reg_off = HHI_MPLL_CNTL,
  110. .shift = 29,
  111. .width = 1,
  112. },
  113. },
  114. .hw.init = &(struct clk_init_data){
  115. .name = "fixed_pll_dco",
  116. .ops = &meson_clk_pll_ro_ops,
  117. .parent_data = &(const struct clk_parent_data) {
  118. .fw_name = "xtal",
  119. },
  120. .num_parents = 1,
  121. },
  122. };
  123. static struct clk_regmap gxbb_fixed_pll = {
  124. .data = &(struct clk_regmap_div_data){
  125. .offset = HHI_MPLL_CNTL,
  126. .shift = 16,
  127. .width = 2,
  128. .flags = CLK_DIVIDER_POWER_OF_TWO,
  129. },
  130. .hw.init = &(struct clk_init_data){
  131. .name = "fixed_pll",
  132. .ops = &clk_regmap_divider_ro_ops,
  133. .parent_hws = (const struct clk_hw *[]) {
  134. &gxbb_fixed_pll_dco.hw
  135. },
  136. .num_parents = 1,
  137. /*
  138. * This clock won't ever change at runtime so
  139. * CLK_SET_RATE_PARENT is not required
  140. */
  141. },
  142. };
  143. static struct clk_fixed_factor gxbb_hdmi_pll_pre_mult = {
  144. .mult = 2,
  145. .div = 1,
  146. .hw.init = &(struct clk_init_data){
  147. .name = "hdmi_pll_pre_mult",
  148. .ops = &clk_fixed_factor_ops,
  149. .parent_data = &(const struct clk_parent_data) {
  150. .fw_name = "xtal",
  151. },
  152. .num_parents = 1,
  153. },
  154. };
  155. static struct clk_regmap gxbb_hdmi_pll_dco = {
  156. .data = &(struct meson_clk_pll_data){
  157. .en = {
  158. .reg_off = HHI_HDMI_PLL_CNTL,
  159. .shift = 30,
  160. .width = 1,
  161. },
  162. .m = {
  163. .reg_off = HHI_HDMI_PLL_CNTL,
  164. .shift = 0,
  165. .width = 9,
  166. },
  167. .n = {
  168. .reg_off = HHI_HDMI_PLL_CNTL,
  169. .shift = 9,
  170. .width = 5,
  171. },
  172. .frac = {
  173. .reg_off = HHI_HDMI_PLL_CNTL2,
  174. .shift = 0,
  175. .width = 12,
  176. },
  177. .l = {
  178. .reg_off = HHI_HDMI_PLL_CNTL,
  179. .shift = 31,
  180. .width = 1,
  181. },
  182. .rst = {
  183. .reg_off = HHI_HDMI_PLL_CNTL,
  184. .shift = 28,
  185. .width = 1,
  186. },
  187. },
  188. .hw.init = &(struct clk_init_data){
  189. .name = "hdmi_pll_dco",
  190. .ops = &meson_clk_pll_ro_ops,
  191. .parent_hws = (const struct clk_hw *[]) {
  192. &gxbb_hdmi_pll_pre_mult.hw
  193. },
  194. .num_parents = 1,
  195. /*
  196. * Display directly handle hdmi pll registers ATM, we need
  197. * NOCACHE to keep our view of the clock as accurate as possible
  198. */
  199. .flags = CLK_GET_RATE_NOCACHE,
  200. },
  201. };
  202. static struct clk_regmap gxl_hdmi_pll_dco = {
  203. .data = &(struct meson_clk_pll_data){
  204. .en = {
  205. .reg_off = HHI_HDMI_PLL_CNTL,
  206. .shift = 30,
  207. .width = 1,
  208. },
  209. .m = {
  210. .reg_off = HHI_HDMI_PLL_CNTL,
  211. .shift = 0,
  212. .width = 9,
  213. },
  214. .n = {
  215. .reg_off = HHI_HDMI_PLL_CNTL,
  216. .shift = 9,
  217. .width = 5,
  218. },
  219. /*
  220. * On gxl, there is a register shift due to
  221. * HHI_HDMI_PLL_CNTL1 which does not exist on gxbb,
  222. * so we use the HHI_HDMI_PLL_CNTL2 define from GXBB
  223. * instead which is defined at the same offset.
  224. */
  225. .frac = {
  226. .reg_off = HHI_HDMI_PLL_CNTL2,
  227. .shift = 0,
  228. .width = 10,
  229. },
  230. .l = {
  231. .reg_off = HHI_HDMI_PLL_CNTL,
  232. .shift = 31,
  233. .width = 1,
  234. },
  235. .rst = {
  236. .reg_off = HHI_HDMI_PLL_CNTL,
  237. .shift = 28,
  238. .width = 1,
  239. },
  240. },
  241. .hw.init = &(struct clk_init_data){
  242. .name = "hdmi_pll_dco",
  243. .ops = &meson_clk_pll_ro_ops,
  244. .parent_data = &(const struct clk_parent_data) {
  245. .fw_name = "xtal",
  246. },
  247. .num_parents = 1,
  248. /*
  249. * Display directly handle hdmi pll registers ATM, we need
  250. * NOCACHE to keep our view of the clock as accurate as possible
  251. */
  252. .flags = CLK_GET_RATE_NOCACHE,
  253. },
  254. };
  255. static struct clk_regmap gxbb_hdmi_pll_od = {
  256. .data = &(struct clk_regmap_div_data){
  257. .offset = HHI_HDMI_PLL_CNTL2,
  258. .shift = 16,
  259. .width = 2,
  260. .flags = CLK_DIVIDER_POWER_OF_TWO,
  261. },
  262. .hw.init = &(struct clk_init_data){
  263. .name = "hdmi_pll_od",
  264. .ops = &clk_regmap_divider_ro_ops,
  265. .parent_hws = (const struct clk_hw *[]) {
  266. &gxbb_hdmi_pll_dco.hw
  267. },
  268. .num_parents = 1,
  269. .flags = CLK_GET_RATE_NOCACHE | CLK_SET_RATE_PARENT,
  270. },
  271. };
  272. static struct clk_regmap gxbb_hdmi_pll_od2 = {
  273. .data = &(struct clk_regmap_div_data){
  274. .offset = HHI_HDMI_PLL_CNTL2,
  275. .shift = 22,
  276. .width = 2,
  277. .flags = CLK_DIVIDER_POWER_OF_TWO,
  278. },
  279. .hw.init = &(struct clk_init_data){
  280. .name = "hdmi_pll_od2",
  281. .ops = &clk_regmap_divider_ro_ops,
  282. .parent_hws = (const struct clk_hw *[]) {
  283. &gxbb_hdmi_pll_od.hw
  284. },
  285. .num_parents = 1,
  286. .flags = CLK_GET_RATE_NOCACHE | CLK_SET_RATE_PARENT,
  287. },
  288. };
  289. static struct clk_regmap gxbb_hdmi_pll = {
  290. .data = &(struct clk_regmap_div_data){
  291. .offset = HHI_HDMI_PLL_CNTL2,
  292. .shift = 18,
  293. .width = 2,
  294. .flags = CLK_DIVIDER_POWER_OF_TWO,
  295. },
  296. .hw.init = &(struct clk_init_data){
  297. .name = "hdmi_pll",
  298. .ops = &clk_regmap_divider_ro_ops,
  299. .parent_hws = (const struct clk_hw *[]) {
  300. &gxbb_hdmi_pll_od2.hw
  301. },
  302. .num_parents = 1,
  303. .flags = CLK_GET_RATE_NOCACHE | CLK_SET_RATE_PARENT,
  304. },
  305. };
  306. static struct clk_regmap gxl_hdmi_pll_od = {
  307. .data = &(struct clk_regmap_div_data){
  308. .offset = HHI_HDMI_PLL_CNTL + 8,
  309. .shift = 21,
  310. .width = 2,
  311. .flags = CLK_DIVIDER_POWER_OF_TWO,
  312. },
  313. .hw.init = &(struct clk_init_data){
  314. .name = "hdmi_pll_od",
  315. .ops = &clk_regmap_divider_ro_ops,
  316. .parent_hws = (const struct clk_hw *[]) {
  317. &gxl_hdmi_pll_dco.hw
  318. },
  319. .num_parents = 1,
  320. .flags = CLK_GET_RATE_NOCACHE | CLK_SET_RATE_PARENT,
  321. },
  322. };
  323. static struct clk_regmap gxl_hdmi_pll_od2 = {
  324. .data = &(struct clk_regmap_div_data){
  325. .offset = HHI_HDMI_PLL_CNTL + 8,
  326. .shift = 23,
  327. .width = 2,
  328. .flags = CLK_DIVIDER_POWER_OF_TWO,
  329. },
  330. .hw.init = &(struct clk_init_data){
  331. .name = "hdmi_pll_od2",
  332. .ops = &clk_regmap_divider_ro_ops,
  333. .parent_hws = (const struct clk_hw *[]) {
  334. &gxl_hdmi_pll_od.hw
  335. },
  336. .num_parents = 1,
  337. .flags = CLK_GET_RATE_NOCACHE | CLK_SET_RATE_PARENT,
  338. },
  339. };
  340. static struct clk_regmap gxl_hdmi_pll = {
  341. .data = &(struct clk_regmap_div_data){
  342. .offset = HHI_HDMI_PLL_CNTL + 8,
  343. .shift = 19,
  344. .width = 2,
  345. .flags = CLK_DIVIDER_POWER_OF_TWO,
  346. },
  347. .hw.init = &(struct clk_init_data){
  348. .name = "hdmi_pll",
  349. .ops = &clk_regmap_divider_ro_ops,
  350. .parent_hws = (const struct clk_hw *[]) {
  351. &gxl_hdmi_pll_od2.hw
  352. },
  353. .num_parents = 1,
  354. .flags = CLK_GET_RATE_NOCACHE | CLK_SET_RATE_PARENT,
  355. },
  356. };
  357. static struct clk_regmap gxbb_sys_pll_dco = {
  358. .data = &(struct meson_clk_pll_data){
  359. .en = {
  360. .reg_off = HHI_SYS_PLL_CNTL,
  361. .shift = 30,
  362. .width = 1,
  363. },
  364. .m = {
  365. .reg_off = HHI_SYS_PLL_CNTL,
  366. .shift = 0,
  367. .width = 9,
  368. },
  369. .n = {
  370. .reg_off = HHI_SYS_PLL_CNTL,
  371. .shift = 9,
  372. .width = 5,
  373. },
  374. .l = {
  375. .reg_off = HHI_SYS_PLL_CNTL,
  376. .shift = 31,
  377. .width = 1,
  378. },
  379. .rst = {
  380. .reg_off = HHI_SYS_PLL_CNTL,
  381. .shift = 29,
  382. .width = 1,
  383. },
  384. },
  385. .hw.init = &(struct clk_init_data){
  386. .name = "sys_pll_dco",
  387. .ops = &meson_clk_pll_ro_ops,
  388. .parent_data = &(const struct clk_parent_data) {
  389. .fw_name = "xtal",
  390. },
  391. .num_parents = 1,
  392. },
  393. };
  394. static struct clk_regmap gxbb_sys_pll = {
  395. .data = &(struct clk_regmap_div_data){
  396. .offset = HHI_SYS_PLL_CNTL,
  397. .shift = 10,
  398. .width = 2,
  399. .flags = CLK_DIVIDER_POWER_OF_TWO,
  400. },
  401. .hw.init = &(struct clk_init_data){
  402. .name = "sys_pll",
  403. .ops = &clk_regmap_divider_ro_ops,
  404. .parent_hws = (const struct clk_hw *[]) {
  405. &gxbb_sys_pll_dco.hw
  406. },
  407. .num_parents = 1,
  408. .flags = CLK_SET_RATE_PARENT,
  409. },
  410. };
  411. static const struct reg_sequence gxbb_gp0_init_regs[] = {
  412. { .reg = HHI_GP0_PLL_CNTL2, .def = 0x69c80000 },
  413. { .reg = HHI_GP0_PLL_CNTL3, .def = 0x0a5590c4 },
  414. { .reg = HHI_GP0_PLL_CNTL4, .def = 0x0000500d },
  415. };
  416. static struct clk_regmap gxbb_gp0_pll_dco = {
  417. .data = &(struct meson_clk_pll_data){
  418. .en = {
  419. .reg_off = HHI_GP0_PLL_CNTL,
  420. .shift = 30,
  421. .width = 1,
  422. },
  423. .m = {
  424. .reg_off = HHI_GP0_PLL_CNTL,
  425. .shift = 0,
  426. .width = 9,
  427. },
  428. .n = {
  429. .reg_off = HHI_GP0_PLL_CNTL,
  430. .shift = 9,
  431. .width = 5,
  432. },
  433. .l = {
  434. .reg_off = HHI_GP0_PLL_CNTL,
  435. .shift = 31,
  436. .width = 1,
  437. },
  438. .rst = {
  439. .reg_off = HHI_GP0_PLL_CNTL,
  440. .shift = 29,
  441. .width = 1,
  442. },
  443. .table = gxbb_gp0_pll_params_table,
  444. .init_regs = gxbb_gp0_init_regs,
  445. .init_count = ARRAY_SIZE(gxbb_gp0_init_regs),
  446. },
  447. .hw.init = &(struct clk_init_data){
  448. .name = "gp0_pll_dco",
  449. .ops = &meson_clk_pll_ops,
  450. .parent_data = &(const struct clk_parent_data) {
  451. .fw_name = "xtal",
  452. },
  453. .num_parents = 1,
  454. },
  455. };
  456. static const struct reg_sequence gxl_gp0_init_regs[] = {
  457. { .reg = HHI_GP0_PLL_CNTL1, .def = 0xc084b000 },
  458. { .reg = HHI_GP0_PLL_CNTL2, .def = 0xb75020be },
  459. { .reg = HHI_GP0_PLL_CNTL3, .def = 0x0a59a288 },
  460. { .reg = HHI_GP0_PLL_CNTL4, .def = 0xc000004d },
  461. { .reg = HHI_GP0_PLL_CNTL5, .def = 0x00078000 },
  462. };
  463. static struct clk_regmap gxl_gp0_pll_dco = {
  464. .data = &(struct meson_clk_pll_data){
  465. .en = {
  466. .reg_off = HHI_GP0_PLL_CNTL,
  467. .shift = 30,
  468. .width = 1,
  469. },
  470. .m = {
  471. .reg_off = HHI_GP0_PLL_CNTL,
  472. .shift = 0,
  473. .width = 9,
  474. },
  475. .n = {
  476. .reg_off = HHI_GP0_PLL_CNTL,
  477. .shift = 9,
  478. .width = 5,
  479. },
  480. .frac = {
  481. .reg_off = HHI_GP0_PLL_CNTL1,
  482. .shift = 0,
  483. .width = 10,
  484. },
  485. .l = {
  486. .reg_off = HHI_GP0_PLL_CNTL,
  487. .shift = 31,
  488. .width = 1,
  489. },
  490. .rst = {
  491. .reg_off = HHI_GP0_PLL_CNTL,
  492. .shift = 29,
  493. .width = 1,
  494. },
  495. .table = gxl_gp0_pll_params_table,
  496. .init_regs = gxl_gp0_init_regs,
  497. .init_count = ARRAY_SIZE(gxl_gp0_init_regs),
  498. },
  499. .hw.init = &(struct clk_init_data){
  500. .name = "gp0_pll_dco",
  501. .ops = &meson_clk_pll_ops,
  502. .parent_data = &(const struct clk_parent_data) {
  503. .fw_name = "xtal",
  504. },
  505. .num_parents = 1,
  506. },
  507. };
  508. static struct clk_regmap gxbb_gp0_pll = {
  509. .data = &(struct clk_regmap_div_data){
  510. .offset = HHI_GP0_PLL_CNTL,
  511. .shift = 16,
  512. .width = 2,
  513. .flags = CLK_DIVIDER_POWER_OF_TWO,
  514. },
  515. .hw.init = &(struct clk_init_data){
  516. .name = "gp0_pll",
  517. .ops = &clk_regmap_divider_ops,
  518. .parent_data = &(const struct clk_parent_data) {
  519. /*
  520. * Note:
  521. * GXL and GXBB have different gp0_pll_dco (with
  522. * different struct clk_hw). We fallback to the global
  523. * naming string mechanism so gp0_pll picks up the
  524. * appropriate one.
  525. */
  526. .name = "gp0_pll_dco",
  527. .index = -1,
  528. },
  529. .num_parents = 1,
  530. .flags = CLK_SET_RATE_PARENT,
  531. },
  532. };
  533. static struct clk_fixed_factor gxbb_fclk_div2_div = {
  534. .mult = 1,
  535. .div = 2,
  536. .hw.init = &(struct clk_init_data){
  537. .name = "fclk_div2_div",
  538. .ops = &clk_fixed_factor_ops,
  539. .parent_hws = (const struct clk_hw *[]) {
  540. &gxbb_fixed_pll.hw
  541. },
  542. .num_parents = 1,
  543. },
  544. };
  545. static struct clk_regmap gxbb_fclk_div2 = {
  546. .data = &(struct clk_regmap_gate_data){
  547. .offset = HHI_MPLL_CNTL6,
  548. .bit_idx = 27,
  549. },
  550. .hw.init = &(struct clk_init_data){
  551. .name = "fclk_div2",
  552. .ops = &clk_regmap_gate_ops,
  553. .parent_hws = (const struct clk_hw *[]) {
  554. &gxbb_fclk_div2_div.hw
  555. },
  556. .num_parents = 1,
  557. .flags = CLK_IS_CRITICAL,
  558. },
  559. };
  560. static struct clk_fixed_factor gxbb_fclk_div3_div = {
  561. .mult = 1,
  562. .div = 3,
  563. .hw.init = &(struct clk_init_data){
  564. .name = "fclk_div3_div",
  565. .ops = &clk_fixed_factor_ops,
  566. .parent_hws = (const struct clk_hw *[]) { &gxbb_fixed_pll.hw },
  567. .num_parents = 1,
  568. },
  569. };
  570. static struct clk_regmap gxbb_fclk_div3 = {
  571. .data = &(struct clk_regmap_gate_data){
  572. .offset = HHI_MPLL_CNTL6,
  573. .bit_idx = 28,
  574. },
  575. .hw.init = &(struct clk_init_data){
  576. .name = "fclk_div3",
  577. .ops = &clk_regmap_gate_ops,
  578. .parent_hws = (const struct clk_hw *[]) {
  579. &gxbb_fclk_div3_div.hw
  580. },
  581. .num_parents = 1,
  582. /*
  583. * FIXME:
  584. * This clock, as fdiv2, is used by the SCPI FW and is required
  585. * by the platform to operate correctly.
  586. * Until the following condition are met, we need this clock to
  587. * be marked as critical:
  588. * a) The SCPI generic driver claims and enable all the clocks
  589. * it needs
  590. * b) CCF has a clock hand-off mechanism to make the sure the
  591. * clock stays on until the proper driver comes along
  592. */
  593. .flags = CLK_IS_CRITICAL,
  594. },
  595. };
  596. static struct clk_fixed_factor gxbb_fclk_div4_div = {
  597. .mult = 1,
  598. .div = 4,
  599. .hw.init = &(struct clk_init_data){
  600. .name = "fclk_div4_div",
  601. .ops = &clk_fixed_factor_ops,
  602. .parent_hws = (const struct clk_hw *[]) { &gxbb_fixed_pll.hw },
  603. .num_parents = 1,
  604. },
  605. };
  606. static struct clk_regmap gxbb_fclk_div4 = {
  607. .data = &(struct clk_regmap_gate_data){
  608. .offset = HHI_MPLL_CNTL6,
  609. .bit_idx = 29,
  610. },
  611. .hw.init = &(struct clk_init_data){
  612. .name = "fclk_div4",
  613. .ops = &clk_regmap_gate_ops,
  614. .parent_hws = (const struct clk_hw *[]) {
  615. &gxbb_fclk_div4_div.hw
  616. },
  617. .num_parents = 1,
  618. },
  619. };
  620. static struct clk_fixed_factor gxbb_fclk_div5_div = {
  621. .mult = 1,
  622. .div = 5,
  623. .hw.init = &(struct clk_init_data){
  624. .name = "fclk_div5_div",
  625. .ops = &clk_fixed_factor_ops,
  626. .parent_hws = (const struct clk_hw *[]) { &gxbb_fixed_pll.hw },
  627. .num_parents = 1,
  628. },
  629. };
  630. static struct clk_regmap gxbb_fclk_div5 = {
  631. .data = &(struct clk_regmap_gate_data){
  632. .offset = HHI_MPLL_CNTL6,
  633. .bit_idx = 30,
  634. },
  635. .hw.init = &(struct clk_init_data){
  636. .name = "fclk_div5",
  637. .ops = &clk_regmap_gate_ops,
  638. .parent_hws = (const struct clk_hw *[]) {
  639. &gxbb_fclk_div5_div.hw
  640. },
  641. .num_parents = 1,
  642. },
  643. };
  644. static struct clk_fixed_factor gxbb_fclk_div7_div = {
  645. .mult = 1,
  646. .div = 7,
  647. .hw.init = &(struct clk_init_data){
  648. .name = "fclk_div7_div",
  649. .ops = &clk_fixed_factor_ops,
  650. .parent_hws = (const struct clk_hw *[]) { &gxbb_fixed_pll.hw },
  651. .num_parents = 1,
  652. },
  653. };
  654. static struct clk_regmap gxbb_fclk_div7 = {
  655. .data = &(struct clk_regmap_gate_data){
  656. .offset = HHI_MPLL_CNTL6,
  657. .bit_idx = 31,
  658. },
  659. .hw.init = &(struct clk_init_data){
  660. .name = "fclk_div7",
  661. .ops = &clk_regmap_gate_ops,
  662. .parent_hws = (const struct clk_hw *[]) {
  663. &gxbb_fclk_div7_div.hw
  664. },
  665. .num_parents = 1,
  666. },
  667. };
  668. static struct clk_regmap gxbb_mpll_prediv = {
  669. .data = &(struct clk_regmap_div_data){
  670. .offset = HHI_MPLL_CNTL5,
  671. .shift = 12,
  672. .width = 1,
  673. },
  674. .hw.init = &(struct clk_init_data){
  675. .name = "mpll_prediv",
  676. .ops = &clk_regmap_divider_ro_ops,
  677. .parent_hws = (const struct clk_hw *[]) { &gxbb_fixed_pll.hw },
  678. .num_parents = 1,
  679. },
  680. };
  681. static struct clk_regmap gxbb_mpll0_div = {
  682. .data = &(struct meson_clk_mpll_data){
  683. .sdm = {
  684. .reg_off = HHI_MPLL_CNTL7,
  685. .shift = 0,
  686. .width = 14,
  687. },
  688. .sdm_en = {
  689. .reg_off = HHI_MPLL_CNTL,
  690. .shift = 25,
  691. .width = 1,
  692. },
  693. .n2 = {
  694. .reg_off = HHI_MPLL_CNTL7,
  695. .shift = 16,
  696. .width = 9,
  697. },
  698. .lock = &meson_clk_lock,
  699. },
  700. .hw.init = &(struct clk_init_data){
  701. .name = "mpll0_div",
  702. .ops = &meson_clk_mpll_ops,
  703. .parent_hws = (const struct clk_hw *[]) {
  704. &gxbb_mpll_prediv.hw
  705. },
  706. .num_parents = 1,
  707. },
  708. };
  709. static struct clk_regmap gxl_mpll0_div = {
  710. .data = &(struct meson_clk_mpll_data){
  711. .sdm = {
  712. .reg_off = HHI_MPLL_CNTL7,
  713. .shift = 0,
  714. .width = 14,
  715. },
  716. .sdm_en = {
  717. .reg_off = HHI_MPLL_CNTL7,
  718. .shift = 15,
  719. .width = 1,
  720. },
  721. .n2 = {
  722. .reg_off = HHI_MPLL_CNTL7,
  723. .shift = 16,
  724. .width = 9,
  725. },
  726. .lock = &meson_clk_lock,
  727. },
  728. .hw.init = &(struct clk_init_data){
  729. .name = "mpll0_div",
  730. .ops = &meson_clk_mpll_ops,
  731. .parent_hws = (const struct clk_hw *[]) {
  732. &gxbb_mpll_prediv.hw
  733. },
  734. .num_parents = 1,
  735. },
  736. };
  737. static struct clk_regmap gxbb_mpll0 = {
  738. .data = &(struct clk_regmap_gate_data){
  739. .offset = HHI_MPLL_CNTL7,
  740. .bit_idx = 14,
  741. },
  742. .hw.init = &(struct clk_init_data){
  743. .name = "mpll0",
  744. .ops = &clk_regmap_gate_ops,
  745. .parent_data = &(const struct clk_parent_data) {
  746. /*
  747. * Note:
  748. * GXL and GXBB have different SDM_EN registers. We
  749. * fallback to the global naming string mechanism so
  750. * mpll0_div picks up the appropriate one.
  751. */
  752. .name = "mpll0_div",
  753. .index = -1,
  754. },
  755. .num_parents = 1,
  756. .flags = CLK_SET_RATE_PARENT,
  757. },
  758. };
  759. static struct clk_regmap gxbb_mpll1_div = {
  760. .data = &(struct meson_clk_mpll_data){
  761. .sdm = {
  762. .reg_off = HHI_MPLL_CNTL8,
  763. .shift = 0,
  764. .width = 14,
  765. },
  766. .sdm_en = {
  767. .reg_off = HHI_MPLL_CNTL8,
  768. .shift = 15,
  769. .width = 1,
  770. },
  771. .n2 = {
  772. .reg_off = HHI_MPLL_CNTL8,
  773. .shift = 16,
  774. .width = 9,
  775. },
  776. .lock = &meson_clk_lock,
  777. },
  778. .hw.init = &(struct clk_init_data){
  779. .name = "mpll1_div",
  780. .ops = &meson_clk_mpll_ops,
  781. .parent_hws = (const struct clk_hw *[]) {
  782. &gxbb_mpll_prediv.hw
  783. },
  784. .num_parents = 1,
  785. },
  786. };
  787. static struct clk_regmap gxbb_mpll1 = {
  788. .data = &(struct clk_regmap_gate_data){
  789. .offset = HHI_MPLL_CNTL8,
  790. .bit_idx = 14,
  791. },
  792. .hw.init = &(struct clk_init_data){
  793. .name = "mpll1",
  794. .ops = &clk_regmap_gate_ops,
  795. .parent_hws = (const struct clk_hw *[]) { &gxbb_mpll1_div.hw },
  796. .num_parents = 1,
  797. .flags = CLK_SET_RATE_PARENT,
  798. },
  799. };
  800. static struct clk_regmap gxbb_mpll2_div = {
  801. .data = &(struct meson_clk_mpll_data){
  802. .sdm = {
  803. .reg_off = HHI_MPLL_CNTL9,
  804. .shift = 0,
  805. .width = 14,
  806. },
  807. .sdm_en = {
  808. .reg_off = HHI_MPLL_CNTL9,
  809. .shift = 15,
  810. .width = 1,
  811. },
  812. .n2 = {
  813. .reg_off = HHI_MPLL_CNTL9,
  814. .shift = 16,
  815. .width = 9,
  816. },
  817. .lock = &meson_clk_lock,
  818. },
  819. .hw.init = &(struct clk_init_data){
  820. .name = "mpll2_div",
  821. .ops = &meson_clk_mpll_ops,
  822. .parent_hws = (const struct clk_hw *[]) {
  823. &gxbb_mpll_prediv.hw
  824. },
  825. .num_parents = 1,
  826. },
  827. };
  828. static struct clk_regmap gxbb_mpll2 = {
  829. .data = &(struct clk_regmap_gate_data){
  830. .offset = HHI_MPLL_CNTL9,
  831. .bit_idx = 14,
  832. },
  833. .hw.init = &(struct clk_init_data){
  834. .name = "mpll2",
  835. .ops = &clk_regmap_gate_ops,
  836. .parent_hws = (const struct clk_hw *[]) { &gxbb_mpll2_div.hw },
  837. .num_parents = 1,
  838. .flags = CLK_SET_RATE_PARENT,
  839. },
  840. };
  841. static u32 mux_table_clk81[] = { 0, 2, 3, 4, 5, 6, 7 };
  842. static const struct clk_parent_data clk81_parent_data[] = {
  843. { .fw_name = "xtal", },
  844. { .hw = &gxbb_fclk_div7.hw },
  845. { .hw = &gxbb_mpll1.hw },
  846. { .hw = &gxbb_mpll2.hw },
  847. { .hw = &gxbb_fclk_div4.hw },
  848. { .hw = &gxbb_fclk_div3.hw },
  849. { .hw = &gxbb_fclk_div5.hw },
  850. };
  851. static struct clk_regmap gxbb_mpeg_clk_sel = {
  852. .data = &(struct clk_regmap_mux_data){
  853. .offset = HHI_MPEG_CLK_CNTL,
  854. .mask = 0x7,
  855. .shift = 12,
  856. .table = mux_table_clk81,
  857. },
  858. .hw.init = &(struct clk_init_data){
  859. .name = "mpeg_clk_sel",
  860. .ops = &clk_regmap_mux_ro_ops,
  861. /*
  862. * bits 14:12 selects from 8 possible parents:
  863. * xtal, 1'b0 (wtf), fclk_div7, mpll_clkout1, mpll_clkout2,
  864. * fclk_div4, fclk_div3, fclk_div5
  865. */
  866. .parent_data = clk81_parent_data,
  867. .num_parents = ARRAY_SIZE(clk81_parent_data),
  868. },
  869. };
  870. static struct clk_regmap gxbb_mpeg_clk_div = {
  871. .data = &(struct clk_regmap_div_data){
  872. .offset = HHI_MPEG_CLK_CNTL,
  873. .shift = 0,
  874. .width = 7,
  875. },
  876. .hw.init = &(struct clk_init_data){
  877. .name = "mpeg_clk_div",
  878. .ops = &clk_regmap_divider_ro_ops,
  879. .parent_hws = (const struct clk_hw *[]) {
  880. &gxbb_mpeg_clk_sel.hw
  881. },
  882. .num_parents = 1,
  883. },
  884. };
  885. /* the mother of dragons gates */
  886. static struct clk_regmap gxbb_clk81 = {
  887. .data = &(struct clk_regmap_gate_data){
  888. .offset = HHI_MPEG_CLK_CNTL,
  889. .bit_idx = 7,
  890. },
  891. .hw.init = &(struct clk_init_data){
  892. .name = "clk81",
  893. .ops = &clk_regmap_gate_ops,
  894. .parent_hws = (const struct clk_hw *[]) {
  895. &gxbb_mpeg_clk_div.hw
  896. },
  897. .num_parents = 1,
  898. .flags = CLK_IS_CRITICAL,
  899. },
  900. };
  901. static struct clk_regmap gxbb_sar_adc_clk_sel = {
  902. .data = &(struct clk_regmap_mux_data){
  903. .offset = HHI_SAR_CLK_CNTL,
  904. .mask = 0x3,
  905. .shift = 9,
  906. },
  907. .hw.init = &(struct clk_init_data){
  908. .name = "sar_adc_clk_sel",
  909. .ops = &clk_regmap_mux_ops,
  910. /* NOTE: The datasheet doesn't list the parents for bit 10 */
  911. .parent_data = (const struct clk_parent_data []) {
  912. { .fw_name = "xtal", },
  913. { .hw = &gxbb_clk81.hw },
  914. },
  915. .num_parents = 2,
  916. },
  917. };
  918. static struct clk_regmap gxbb_sar_adc_clk_div = {
  919. .data = &(struct clk_regmap_div_data){
  920. .offset = HHI_SAR_CLK_CNTL,
  921. .shift = 0,
  922. .width = 8,
  923. },
  924. .hw.init = &(struct clk_init_data){
  925. .name = "sar_adc_clk_div",
  926. .ops = &clk_regmap_divider_ops,
  927. .parent_hws = (const struct clk_hw *[]) {
  928. &gxbb_sar_adc_clk_sel.hw
  929. },
  930. .num_parents = 1,
  931. .flags = CLK_SET_RATE_PARENT,
  932. },
  933. };
  934. static struct clk_regmap gxbb_sar_adc_clk = {
  935. .data = &(struct clk_regmap_gate_data){
  936. .offset = HHI_SAR_CLK_CNTL,
  937. .bit_idx = 8,
  938. },
  939. .hw.init = &(struct clk_init_data){
  940. .name = "sar_adc_clk",
  941. .ops = &clk_regmap_gate_ops,
  942. .parent_hws = (const struct clk_hw *[]) {
  943. &gxbb_sar_adc_clk_div.hw
  944. },
  945. .num_parents = 1,
  946. .flags = CLK_SET_RATE_PARENT,
  947. },
  948. };
  949. /*
  950. * The MALI IP is clocked by two identical clocks (mali_0 and mali_1)
  951. * muxed by a glitch-free switch. The CCF can manage this glitch-free
  952. * mux because it does top-to-bottom updates the each clock tree and
  953. * switches to the "inactive" one when CLK_SET_RATE_GATE is set.
  954. */
  955. static const struct clk_parent_data gxbb_mali_0_1_parent_data[] = {
  956. { .fw_name = "xtal", },
  957. { .hw = &gxbb_gp0_pll.hw },
  958. { .hw = &gxbb_mpll2.hw },
  959. { .hw = &gxbb_mpll1.hw },
  960. { .hw = &gxbb_fclk_div7.hw },
  961. { .hw = &gxbb_fclk_div4.hw },
  962. { .hw = &gxbb_fclk_div3.hw },
  963. { .hw = &gxbb_fclk_div5.hw },
  964. };
  965. static struct clk_regmap gxbb_mali_0_sel = {
  966. .data = &(struct clk_regmap_mux_data){
  967. .offset = HHI_MALI_CLK_CNTL,
  968. .mask = 0x7,
  969. .shift = 9,
  970. },
  971. .hw.init = &(struct clk_init_data){
  972. .name = "mali_0_sel",
  973. .ops = &clk_regmap_mux_ops,
  974. .parent_data = gxbb_mali_0_1_parent_data,
  975. .num_parents = 8,
  976. /*
  977. * Don't request the parent to change the rate because
  978. * all GPU frequencies can be derived from the fclk_*
  979. * clocks and one special GP0_PLL setting. This is
  980. * important because we need the MPLL clocks for audio.
  981. */
  982. .flags = 0,
  983. },
  984. };
  985. static struct clk_regmap gxbb_mali_0_div = {
  986. .data = &(struct clk_regmap_div_data){
  987. .offset = HHI_MALI_CLK_CNTL,
  988. .shift = 0,
  989. .width = 7,
  990. },
  991. .hw.init = &(struct clk_init_data){
  992. .name = "mali_0_div",
  993. .ops = &clk_regmap_divider_ops,
  994. .parent_hws = (const struct clk_hw *[]) {
  995. &gxbb_mali_0_sel.hw
  996. },
  997. .num_parents = 1,
  998. .flags = CLK_SET_RATE_PARENT,
  999. },
  1000. };
  1001. static struct clk_regmap gxbb_mali_0 = {
  1002. .data = &(struct clk_regmap_gate_data){
  1003. .offset = HHI_MALI_CLK_CNTL,
  1004. .bit_idx = 8,
  1005. },
  1006. .hw.init = &(struct clk_init_data){
  1007. .name = "mali_0",
  1008. .ops = &clk_regmap_gate_ops,
  1009. .parent_hws = (const struct clk_hw *[]) {
  1010. &gxbb_mali_0_div.hw
  1011. },
  1012. .num_parents = 1,
  1013. .flags = CLK_SET_RATE_GATE | CLK_SET_RATE_PARENT,
  1014. },
  1015. };
  1016. static struct clk_regmap gxbb_mali_1_sel = {
  1017. .data = &(struct clk_regmap_mux_data){
  1018. .offset = HHI_MALI_CLK_CNTL,
  1019. .mask = 0x7,
  1020. .shift = 25,
  1021. },
  1022. .hw.init = &(struct clk_init_data){
  1023. .name = "mali_1_sel",
  1024. .ops = &clk_regmap_mux_ops,
  1025. .parent_data = gxbb_mali_0_1_parent_data,
  1026. .num_parents = 8,
  1027. /*
  1028. * Don't request the parent to change the rate because
  1029. * all GPU frequencies can be derived from the fclk_*
  1030. * clocks and one special GP0_PLL setting. This is
  1031. * important because we need the MPLL clocks for audio.
  1032. */
  1033. .flags = 0,
  1034. },
  1035. };
  1036. static struct clk_regmap gxbb_mali_1_div = {
  1037. .data = &(struct clk_regmap_div_data){
  1038. .offset = HHI_MALI_CLK_CNTL,
  1039. .shift = 16,
  1040. .width = 7,
  1041. },
  1042. .hw.init = &(struct clk_init_data){
  1043. .name = "mali_1_div",
  1044. .ops = &clk_regmap_divider_ops,
  1045. .parent_hws = (const struct clk_hw *[]) {
  1046. &gxbb_mali_1_sel.hw
  1047. },
  1048. .num_parents = 1,
  1049. .flags = CLK_SET_RATE_PARENT,
  1050. },
  1051. };
  1052. static struct clk_regmap gxbb_mali_1 = {
  1053. .data = &(struct clk_regmap_gate_data){
  1054. .offset = HHI_MALI_CLK_CNTL,
  1055. .bit_idx = 24,
  1056. },
  1057. .hw.init = &(struct clk_init_data){
  1058. .name = "mali_1",
  1059. .ops = &clk_regmap_gate_ops,
  1060. .parent_hws = (const struct clk_hw *[]) {
  1061. &gxbb_mali_1_div.hw
  1062. },
  1063. .num_parents = 1,
  1064. .flags = CLK_SET_RATE_GATE | CLK_SET_RATE_PARENT,
  1065. },
  1066. };
  1067. static const struct clk_hw *gxbb_mali_parent_hws[] = {
  1068. &gxbb_mali_0.hw,
  1069. &gxbb_mali_1.hw,
  1070. };
  1071. static struct clk_regmap gxbb_mali = {
  1072. .data = &(struct clk_regmap_mux_data){
  1073. .offset = HHI_MALI_CLK_CNTL,
  1074. .mask = 1,
  1075. .shift = 31,
  1076. },
  1077. .hw.init = &(struct clk_init_data){
  1078. .name = "mali",
  1079. .ops = &clk_regmap_mux_ops,
  1080. .parent_hws = gxbb_mali_parent_hws,
  1081. .num_parents = 2,
  1082. .flags = CLK_SET_RATE_PARENT,
  1083. },
  1084. };
  1085. static struct clk_regmap gxbb_cts_amclk_sel = {
  1086. .data = &(struct clk_regmap_mux_data){
  1087. .offset = HHI_AUD_CLK_CNTL,
  1088. .mask = 0x3,
  1089. .shift = 9,
  1090. .table = (u32[]){ 1, 2, 3 },
  1091. .flags = CLK_MUX_ROUND_CLOSEST,
  1092. },
  1093. .hw.init = &(struct clk_init_data){
  1094. .name = "cts_amclk_sel",
  1095. .ops = &clk_regmap_mux_ops,
  1096. .parent_hws = (const struct clk_hw *[]) {
  1097. &gxbb_mpll0.hw,
  1098. &gxbb_mpll1.hw,
  1099. &gxbb_mpll2.hw,
  1100. },
  1101. .num_parents = 3,
  1102. },
  1103. };
  1104. static struct clk_regmap gxbb_cts_amclk_div = {
  1105. .data = &(struct clk_regmap_div_data) {
  1106. .offset = HHI_AUD_CLK_CNTL,
  1107. .shift = 0,
  1108. .width = 8,
  1109. .flags = CLK_DIVIDER_ROUND_CLOSEST,
  1110. },
  1111. .hw.init = &(struct clk_init_data){
  1112. .name = "cts_amclk_div",
  1113. .ops = &clk_regmap_divider_ops,
  1114. .parent_hws = (const struct clk_hw *[]) {
  1115. &gxbb_cts_amclk_sel.hw
  1116. },
  1117. .num_parents = 1,
  1118. .flags = CLK_SET_RATE_PARENT,
  1119. },
  1120. };
  1121. static struct clk_regmap gxbb_cts_amclk = {
  1122. .data = &(struct clk_regmap_gate_data){
  1123. .offset = HHI_AUD_CLK_CNTL,
  1124. .bit_idx = 8,
  1125. },
  1126. .hw.init = &(struct clk_init_data){
  1127. .name = "cts_amclk",
  1128. .ops = &clk_regmap_gate_ops,
  1129. .parent_hws = (const struct clk_hw *[]) {
  1130. &gxbb_cts_amclk_div.hw
  1131. },
  1132. .num_parents = 1,
  1133. .flags = CLK_SET_RATE_PARENT,
  1134. },
  1135. };
  1136. static struct clk_regmap gxbb_cts_mclk_i958_sel = {
  1137. .data = &(struct clk_regmap_mux_data){
  1138. .offset = HHI_AUD_CLK_CNTL2,
  1139. .mask = 0x3,
  1140. .shift = 25,
  1141. .table = (u32[]){ 1, 2, 3 },
  1142. .flags = CLK_MUX_ROUND_CLOSEST,
  1143. },
  1144. .hw.init = &(struct clk_init_data) {
  1145. .name = "cts_mclk_i958_sel",
  1146. .ops = &clk_regmap_mux_ops,
  1147. .parent_hws = (const struct clk_hw *[]) {
  1148. &gxbb_mpll0.hw,
  1149. &gxbb_mpll1.hw,
  1150. &gxbb_mpll2.hw,
  1151. },
  1152. .num_parents = 3,
  1153. },
  1154. };
  1155. static struct clk_regmap gxbb_cts_mclk_i958_div = {
  1156. .data = &(struct clk_regmap_div_data){
  1157. .offset = HHI_AUD_CLK_CNTL2,
  1158. .shift = 16,
  1159. .width = 8,
  1160. .flags = CLK_DIVIDER_ROUND_CLOSEST,
  1161. },
  1162. .hw.init = &(struct clk_init_data) {
  1163. .name = "cts_mclk_i958_div",
  1164. .ops = &clk_regmap_divider_ops,
  1165. .parent_hws = (const struct clk_hw *[]) {
  1166. &gxbb_cts_mclk_i958_sel.hw
  1167. },
  1168. .num_parents = 1,
  1169. .flags = CLK_SET_RATE_PARENT,
  1170. },
  1171. };
  1172. static struct clk_regmap gxbb_cts_mclk_i958 = {
  1173. .data = &(struct clk_regmap_gate_data){
  1174. .offset = HHI_AUD_CLK_CNTL2,
  1175. .bit_idx = 24,
  1176. },
  1177. .hw.init = &(struct clk_init_data){
  1178. .name = "cts_mclk_i958",
  1179. .ops = &clk_regmap_gate_ops,
  1180. .parent_hws = (const struct clk_hw *[]) {
  1181. &gxbb_cts_mclk_i958_div.hw
  1182. },
  1183. .num_parents = 1,
  1184. .flags = CLK_SET_RATE_PARENT,
  1185. },
  1186. };
  1187. static struct clk_regmap gxbb_cts_i958 = {
  1188. .data = &(struct clk_regmap_mux_data){
  1189. .offset = HHI_AUD_CLK_CNTL2,
  1190. .mask = 0x1,
  1191. .shift = 27,
  1192. },
  1193. .hw.init = &(struct clk_init_data){
  1194. .name = "cts_i958",
  1195. .ops = &clk_regmap_mux_ops,
  1196. .parent_hws = (const struct clk_hw *[]) {
  1197. &gxbb_cts_amclk.hw,
  1198. &gxbb_cts_mclk_i958.hw
  1199. },
  1200. .num_parents = 2,
  1201. /*
  1202. *The parent is specific to origin of the audio data. Let the
  1203. * consumer choose the appropriate parent
  1204. */
  1205. .flags = CLK_SET_RATE_PARENT | CLK_SET_RATE_NO_REPARENT,
  1206. },
  1207. };
  1208. static const struct clk_parent_data gxbb_32k_clk_parent_data[] = {
  1209. { .fw_name = "xtal", },
  1210. /*
  1211. * FIXME: This clock is provided by the ao clock controller but the
  1212. * clock is not yet part of the binding of this controller, so string
  1213. * name must be use to set this parent.
  1214. */
  1215. { .name = "cts_slow_oscin", .index = -1 },
  1216. { .hw = &gxbb_fclk_div3.hw },
  1217. { .hw = &gxbb_fclk_div5.hw },
  1218. };
  1219. static struct clk_regmap gxbb_32k_clk_sel = {
  1220. .data = &(struct clk_regmap_mux_data){
  1221. .offset = HHI_32K_CLK_CNTL,
  1222. .mask = 0x3,
  1223. .shift = 16,
  1224. },
  1225. .hw.init = &(struct clk_init_data){
  1226. .name = "32k_clk_sel",
  1227. .ops = &clk_regmap_mux_ops,
  1228. .parent_data = gxbb_32k_clk_parent_data,
  1229. .num_parents = 4,
  1230. .flags = CLK_SET_RATE_PARENT,
  1231. },
  1232. };
  1233. static struct clk_regmap gxbb_32k_clk_div = {
  1234. .data = &(struct clk_regmap_div_data){
  1235. .offset = HHI_32K_CLK_CNTL,
  1236. .shift = 0,
  1237. .width = 14,
  1238. },
  1239. .hw.init = &(struct clk_init_data){
  1240. .name = "32k_clk_div",
  1241. .ops = &clk_regmap_divider_ops,
  1242. .parent_hws = (const struct clk_hw *[]) {
  1243. &gxbb_32k_clk_sel.hw
  1244. },
  1245. .num_parents = 1,
  1246. .flags = CLK_SET_RATE_PARENT | CLK_DIVIDER_ROUND_CLOSEST,
  1247. },
  1248. };
  1249. static struct clk_regmap gxbb_32k_clk = {
  1250. .data = &(struct clk_regmap_gate_data){
  1251. .offset = HHI_32K_CLK_CNTL,
  1252. .bit_idx = 15,
  1253. },
  1254. .hw.init = &(struct clk_init_data){
  1255. .name = "32k_clk",
  1256. .ops = &clk_regmap_gate_ops,
  1257. .parent_hws = (const struct clk_hw *[]) {
  1258. &gxbb_32k_clk_div.hw
  1259. },
  1260. .num_parents = 1,
  1261. .flags = CLK_SET_RATE_PARENT,
  1262. },
  1263. };
  1264. static const struct clk_parent_data gxbb_sd_emmc_clk0_parent_data[] = {
  1265. { .fw_name = "xtal", },
  1266. { .hw = &gxbb_fclk_div2.hw },
  1267. { .hw = &gxbb_fclk_div3.hw },
  1268. { .hw = &gxbb_fclk_div5.hw },
  1269. { .hw = &gxbb_fclk_div7.hw },
  1270. /*
  1271. * Following these parent clocks, we should also have had mpll2, mpll3
  1272. * and gp0_pll but these clocks are too precious to be used here. All
  1273. * the necessary rates for MMC and NAND operation can be acheived using
  1274. * xtal or fclk_div clocks
  1275. */
  1276. };
  1277. /* SDIO clock */
  1278. static struct clk_regmap gxbb_sd_emmc_a_clk0_sel = {
  1279. .data = &(struct clk_regmap_mux_data){
  1280. .offset = HHI_SD_EMMC_CLK_CNTL,
  1281. .mask = 0x7,
  1282. .shift = 9,
  1283. },
  1284. .hw.init = &(struct clk_init_data) {
  1285. .name = "sd_emmc_a_clk0_sel",
  1286. .ops = &clk_regmap_mux_ops,
  1287. .parent_data = gxbb_sd_emmc_clk0_parent_data,
  1288. .num_parents = ARRAY_SIZE(gxbb_sd_emmc_clk0_parent_data),
  1289. .flags = CLK_SET_RATE_PARENT,
  1290. },
  1291. };
  1292. static struct clk_regmap gxbb_sd_emmc_a_clk0_div = {
  1293. .data = &(struct clk_regmap_div_data){
  1294. .offset = HHI_SD_EMMC_CLK_CNTL,
  1295. .shift = 0,
  1296. .width = 7,
  1297. .flags = CLK_DIVIDER_ROUND_CLOSEST,
  1298. },
  1299. .hw.init = &(struct clk_init_data) {
  1300. .name = "sd_emmc_a_clk0_div",
  1301. .ops = &clk_regmap_divider_ops,
  1302. .parent_hws = (const struct clk_hw *[]) {
  1303. &gxbb_sd_emmc_a_clk0_sel.hw
  1304. },
  1305. .num_parents = 1,
  1306. .flags = CLK_SET_RATE_PARENT,
  1307. },
  1308. };
  1309. static struct clk_regmap gxbb_sd_emmc_a_clk0 = {
  1310. .data = &(struct clk_regmap_gate_data){
  1311. .offset = HHI_SD_EMMC_CLK_CNTL,
  1312. .bit_idx = 7,
  1313. },
  1314. .hw.init = &(struct clk_init_data){
  1315. .name = "sd_emmc_a_clk0",
  1316. .ops = &clk_regmap_gate_ops,
  1317. .parent_hws = (const struct clk_hw *[]) {
  1318. &gxbb_sd_emmc_a_clk0_div.hw
  1319. },
  1320. .num_parents = 1,
  1321. .flags = CLK_SET_RATE_PARENT,
  1322. },
  1323. };
  1324. /* SDcard clock */
  1325. static struct clk_regmap gxbb_sd_emmc_b_clk0_sel = {
  1326. .data = &(struct clk_regmap_mux_data){
  1327. .offset = HHI_SD_EMMC_CLK_CNTL,
  1328. .mask = 0x7,
  1329. .shift = 25,
  1330. },
  1331. .hw.init = &(struct clk_init_data) {
  1332. .name = "sd_emmc_b_clk0_sel",
  1333. .ops = &clk_regmap_mux_ops,
  1334. .parent_data = gxbb_sd_emmc_clk0_parent_data,
  1335. .num_parents = ARRAY_SIZE(gxbb_sd_emmc_clk0_parent_data),
  1336. .flags = CLK_SET_RATE_PARENT,
  1337. },
  1338. };
  1339. static struct clk_regmap gxbb_sd_emmc_b_clk0_div = {
  1340. .data = &(struct clk_regmap_div_data){
  1341. .offset = HHI_SD_EMMC_CLK_CNTL,
  1342. .shift = 16,
  1343. .width = 7,
  1344. .flags = CLK_DIVIDER_ROUND_CLOSEST,
  1345. },
  1346. .hw.init = &(struct clk_init_data) {
  1347. .name = "sd_emmc_b_clk0_div",
  1348. .ops = &clk_regmap_divider_ops,
  1349. .parent_hws = (const struct clk_hw *[]) {
  1350. &gxbb_sd_emmc_b_clk0_sel.hw
  1351. },
  1352. .num_parents = 1,
  1353. .flags = CLK_SET_RATE_PARENT,
  1354. },
  1355. };
  1356. static struct clk_regmap gxbb_sd_emmc_b_clk0 = {
  1357. .data = &(struct clk_regmap_gate_data){
  1358. .offset = HHI_SD_EMMC_CLK_CNTL,
  1359. .bit_idx = 23,
  1360. },
  1361. .hw.init = &(struct clk_init_data){
  1362. .name = "sd_emmc_b_clk0",
  1363. .ops = &clk_regmap_gate_ops,
  1364. .parent_hws = (const struct clk_hw *[]) {
  1365. &gxbb_sd_emmc_b_clk0_div.hw
  1366. },
  1367. .num_parents = 1,
  1368. .flags = CLK_SET_RATE_PARENT,
  1369. },
  1370. };
  1371. /* EMMC/NAND clock */
  1372. static struct clk_regmap gxbb_sd_emmc_c_clk0_sel = {
  1373. .data = &(struct clk_regmap_mux_data){
  1374. .offset = HHI_NAND_CLK_CNTL,
  1375. .mask = 0x7,
  1376. .shift = 9,
  1377. },
  1378. .hw.init = &(struct clk_init_data) {
  1379. .name = "sd_emmc_c_clk0_sel",
  1380. .ops = &clk_regmap_mux_ops,
  1381. .parent_data = gxbb_sd_emmc_clk0_parent_data,
  1382. .num_parents = ARRAY_SIZE(gxbb_sd_emmc_clk0_parent_data),
  1383. .flags = CLK_SET_RATE_PARENT,
  1384. },
  1385. };
  1386. static struct clk_regmap gxbb_sd_emmc_c_clk0_div = {
  1387. .data = &(struct clk_regmap_div_data){
  1388. .offset = HHI_NAND_CLK_CNTL,
  1389. .shift = 0,
  1390. .width = 7,
  1391. .flags = CLK_DIVIDER_ROUND_CLOSEST,
  1392. },
  1393. .hw.init = &(struct clk_init_data) {
  1394. .name = "sd_emmc_c_clk0_div",
  1395. .ops = &clk_regmap_divider_ops,
  1396. .parent_hws = (const struct clk_hw *[]) {
  1397. &gxbb_sd_emmc_c_clk0_sel.hw
  1398. },
  1399. .num_parents = 1,
  1400. .flags = CLK_SET_RATE_PARENT,
  1401. },
  1402. };
  1403. static struct clk_regmap gxbb_sd_emmc_c_clk0 = {
  1404. .data = &(struct clk_regmap_gate_data){
  1405. .offset = HHI_NAND_CLK_CNTL,
  1406. .bit_idx = 7,
  1407. },
  1408. .hw.init = &(struct clk_init_data){
  1409. .name = "sd_emmc_c_clk0",
  1410. .ops = &clk_regmap_gate_ops,
  1411. .parent_hws = (const struct clk_hw *[]) {
  1412. &gxbb_sd_emmc_c_clk0_div.hw
  1413. },
  1414. .num_parents = 1,
  1415. .flags = CLK_SET_RATE_PARENT,
  1416. },
  1417. };
  1418. /* VPU Clock */
  1419. static const struct clk_hw *gxbb_vpu_parent_hws[] = {
  1420. &gxbb_fclk_div4.hw,
  1421. &gxbb_fclk_div3.hw,
  1422. &gxbb_fclk_div5.hw,
  1423. &gxbb_fclk_div7.hw,
  1424. };
  1425. static struct clk_regmap gxbb_vpu_0_sel = {
  1426. .data = &(struct clk_regmap_mux_data){
  1427. .offset = HHI_VPU_CLK_CNTL,
  1428. .mask = 0x3,
  1429. .shift = 9,
  1430. },
  1431. .hw.init = &(struct clk_init_data){
  1432. .name = "vpu_0_sel",
  1433. .ops = &clk_regmap_mux_ops,
  1434. /*
  1435. * bits 9:10 selects from 4 possible parents:
  1436. * fclk_div4, fclk_div3, fclk_div5, fclk_div7,
  1437. */
  1438. .parent_hws = gxbb_vpu_parent_hws,
  1439. .num_parents = ARRAY_SIZE(gxbb_vpu_parent_hws),
  1440. .flags = CLK_SET_RATE_NO_REPARENT,
  1441. },
  1442. };
  1443. static struct clk_regmap gxbb_vpu_0_div = {
  1444. .data = &(struct clk_regmap_div_data){
  1445. .offset = HHI_VPU_CLK_CNTL,
  1446. .shift = 0,
  1447. .width = 7,
  1448. },
  1449. .hw.init = &(struct clk_init_data){
  1450. .name = "vpu_0_div",
  1451. .ops = &clk_regmap_divider_ops,
  1452. .parent_hws = (const struct clk_hw *[]) { &gxbb_vpu_0_sel.hw },
  1453. .num_parents = 1,
  1454. .flags = CLK_SET_RATE_PARENT,
  1455. },
  1456. };
  1457. static struct clk_regmap gxbb_vpu_0 = {
  1458. .data = &(struct clk_regmap_gate_data){
  1459. .offset = HHI_VPU_CLK_CNTL,
  1460. .bit_idx = 8,
  1461. },
  1462. .hw.init = &(struct clk_init_data) {
  1463. .name = "vpu_0",
  1464. .ops = &clk_regmap_gate_ops,
  1465. .parent_hws = (const struct clk_hw *[]) { &gxbb_vpu_0_div.hw },
  1466. .num_parents = 1,
  1467. .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
  1468. },
  1469. };
  1470. static struct clk_regmap gxbb_vpu_1_sel = {
  1471. .data = &(struct clk_regmap_mux_data){
  1472. .offset = HHI_VPU_CLK_CNTL,
  1473. .mask = 0x3,
  1474. .shift = 25,
  1475. },
  1476. .hw.init = &(struct clk_init_data){
  1477. .name = "vpu_1_sel",
  1478. .ops = &clk_regmap_mux_ops,
  1479. /*
  1480. * bits 25:26 selects from 4 possible parents:
  1481. * fclk_div4, fclk_div3, fclk_div5, fclk_div7,
  1482. */
  1483. .parent_hws = gxbb_vpu_parent_hws,
  1484. .num_parents = ARRAY_SIZE(gxbb_vpu_parent_hws),
  1485. .flags = CLK_SET_RATE_NO_REPARENT,
  1486. },
  1487. };
  1488. static struct clk_regmap gxbb_vpu_1_div = {
  1489. .data = &(struct clk_regmap_div_data){
  1490. .offset = HHI_VPU_CLK_CNTL,
  1491. .shift = 16,
  1492. .width = 7,
  1493. },
  1494. .hw.init = &(struct clk_init_data){
  1495. .name = "vpu_1_div",
  1496. .ops = &clk_regmap_divider_ops,
  1497. .parent_hws = (const struct clk_hw *[]) { &gxbb_vpu_1_sel.hw },
  1498. .num_parents = 1,
  1499. .flags = CLK_SET_RATE_PARENT,
  1500. },
  1501. };
  1502. static struct clk_regmap gxbb_vpu_1 = {
  1503. .data = &(struct clk_regmap_gate_data){
  1504. .offset = HHI_VPU_CLK_CNTL,
  1505. .bit_idx = 24,
  1506. },
  1507. .hw.init = &(struct clk_init_data) {
  1508. .name = "vpu_1",
  1509. .ops = &clk_regmap_gate_ops,
  1510. .parent_hws = (const struct clk_hw *[]) { &gxbb_vpu_1_div.hw },
  1511. .num_parents = 1,
  1512. .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
  1513. },
  1514. };
  1515. static struct clk_regmap gxbb_vpu = {
  1516. .data = &(struct clk_regmap_mux_data){
  1517. .offset = HHI_VPU_CLK_CNTL,
  1518. .mask = 1,
  1519. .shift = 31,
  1520. },
  1521. .hw.init = &(struct clk_init_data){
  1522. .name = "vpu",
  1523. .ops = &clk_regmap_mux_ops,
  1524. /*
  1525. * bit 31 selects from 2 possible parents:
  1526. * vpu_0 or vpu_1
  1527. */
  1528. .parent_hws = (const struct clk_hw *[]) {
  1529. &gxbb_vpu_0.hw,
  1530. &gxbb_vpu_1.hw
  1531. },
  1532. .num_parents = 2,
  1533. .flags = CLK_SET_RATE_NO_REPARENT,
  1534. },
  1535. };
  1536. /* VAPB Clock */
  1537. static const struct clk_hw *gxbb_vapb_parent_hws[] = {
  1538. &gxbb_fclk_div4.hw,
  1539. &gxbb_fclk_div3.hw,
  1540. &gxbb_fclk_div5.hw,
  1541. &gxbb_fclk_div7.hw,
  1542. };
  1543. static struct clk_regmap gxbb_vapb_0_sel = {
  1544. .data = &(struct clk_regmap_mux_data){
  1545. .offset = HHI_VAPBCLK_CNTL,
  1546. .mask = 0x3,
  1547. .shift = 9,
  1548. },
  1549. .hw.init = &(struct clk_init_data){
  1550. .name = "vapb_0_sel",
  1551. .ops = &clk_regmap_mux_ops,
  1552. /*
  1553. * bits 9:10 selects from 4 possible parents:
  1554. * fclk_div4, fclk_div3, fclk_div5, fclk_div7,
  1555. */
  1556. .parent_hws = gxbb_vapb_parent_hws,
  1557. .num_parents = ARRAY_SIZE(gxbb_vapb_parent_hws),
  1558. .flags = CLK_SET_RATE_NO_REPARENT,
  1559. },
  1560. };
  1561. static struct clk_regmap gxbb_vapb_0_div = {
  1562. .data = &(struct clk_regmap_div_data){
  1563. .offset = HHI_VAPBCLK_CNTL,
  1564. .shift = 0,
  1565. .width = 7,
  1566. },
  1567. .hw.init = &(struct clk_init_data){
  1568. .name = "vapb_0_div",
  1569. .ops = &clk_regmap_divider_ops,
  1570. .parent_hws = (const struct clk_hw *[]) {
  1571. &gxbb_vapb_0_sel.hw
  1572. },
  1573. .num_parents = 1,
  1574. .flags = CLK_SET_RATE_PARENT,
  1575. },
  1576. };
  1577. static struct clk_regmap gxbb_vapb_0 = {
  1578. .data = &(struct clk_regmap_gate_data){
  1579. .offset = HHI_VAPBCLK_CNTL,
  1580. .bit_idx = 8,
  1581. },
  1582. .hw.init = &(struct clk_init_data) {
  1583. .name = "vapb_0",
  1584. .ops = &clk_regmap_gate_ops,
  1585. .parent_hws = (const struct clk_hw *[]) {
  1586. &gxbb_vapb_0_div.hw
  1587. },
  1588. .num_parents = 1,
  1589. .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
  1590. },
  1591. };
  1592. static struct clk_regmap gxbb_vapb_1_sel = {
  1593. .data = &(struct clk_regmap_mux_data){
  1594. .offset = HHI_VAPBCLK_CNTL,
  1595. .mask = 0x3,
  1596. .shift = 25,
  1597. },
  1598. .hw.init = &(struct clk_init_data){
  1599. .name = "vapb_1_sel",
  1600. .ops = &clk_regmap_mux_ops,
  1601. /*
  1602. * bits 25:26 selects from 4 possible parents:
  1603. * fclk_div4, fclk_div3, fclk_div5, fclk_div7,
  1604. */
  1605. .parent_hws = gxbb_vapb_parent_hws,
  1606. .num_parents = ARRAY_SIZE(gxbb_vapb_parent_hws),
  1607. .flags = CLK_SET_RATE_NO_REPARENT,
  1608. },
  1609. };
  1610. static struct clk_regmap gxbb_vapb_1_div = {
  1611. .data = &(struct clk_regmap_div_data){
  1612. .offset = HHI_VAPBCLK_CNTL,
  1613. .shift = 16,
  1614. .width = 7,
  1615. },
  1616. .hw.init = &(struct clk_init_data){
  1617. .name = "vapb_1_div",
  1618. .ops = &clk_regmap_divider_ops,
  1619. .parent_hws = (const struct clk_hw *[]) {
  1620. &gxbb_vapb_1_sel.hw
  1621. },
  1622. .num_parents = 1,
  1623. .flags = CLK_SET_RATE_PARENT,
  1624. },
  1625. };
  1626. static struct clk_regmap gxbb_vapb_1 = {
  1627. .data = &(struct clk_regmap_gate_data){
  1628. .offset = HHI_VAPBCLK_CNTL,
  1629. .bit_idx = 24,
  1630. },
  1631. .hw.init = &(struct clk_init_data) {
  1632. .name = "vapb_1",
  1633. .ops = &clk_regmap_gate_ops,
  1634. .parent_hws = (const struct clk_hw *[]) {
  1635. &gxbb_vapb_1_div.hw
  1636. },
  1637. .num_parents = 1,
  1638. .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
  1639. },
  1640. };
  1641. static struct clk_regmap gxbb_vapb_sel = {
  1642. .data = &(struct clk_regmap_mux_data){
  1643. .offset = HHI_VAPBCLK_CNTL,
  1644. .mask = 1,
  1645. .shift = 31,
  1646. },
  1647. .hw.init = &(struct clk_init_data){
  1648. .name = "vapb_sel",
  1649. .ops = &clk_regmap_mux_ops,
  1650. /*
  1651. * bit 31 selects from 2 possible parents:
  1652. * vapb_0 or vapb_1
  1653. */
  1654. .parent_hws = (const struct clk_hw *[]) {
  1655. &gxbb_vapb_0.hw,
  1656. &gxbb_vapb_1.hw
  1657. },
  1658. .num_parents = 2,
  1659. .flags = CLK_SET_RATE_NO_REPARENT,
  1660. },
  1661. };
  1662. static struct clk_regmap gxbb_vapb = {
  1663. .data = &(struct clk_regmap_gate_data){
  1664. .offset = HHI_VAPBCLK_CNTL,
  1665. .bit_idx = 30,
  1666. },
  1667. .hw.init = &(struct clk_init_data) {
  1668. .name = "vapb",
  1669. .ops = &clk_regmap_gate_ops,
  1670. .parent_hws = (const struct clk_hw *[]) { &gxbb_vapb_sel.hw },
  1671. .num_parents = 1,
  1672. .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
  1673. },
  1674. };
  1675. /* Video Clocks */
  1676. static struct clk_regmap gxbb_vid_pll_div = {
  1677. .data = &(struct meson_vid_pll_div_data){
  1678. .val = {
  1679. .reg_off = HHI_VID_PLL_CLK_DIV,
  1680. .shift = 0,
  1681. .width = 15,
  1682. },
  1683. .sel = {
  1684. .reg_off = HHI_VID_PLL_CLK_DIV,
  1685. .shift = 16,
  1686. .width = 2,
  1687. },
  1688. },
  1689. .hw.init = &(struct clk_init_data) {
  1690. .name = "vid_pll_div",
  1691. .ops = &meson_vid_pll_div_ro_ops,
  1692. .parent_data = &(const struct clk_parent_data) {
  1693. /*
  1694. * Note:
  1695. * GXL and GXBB have different hdmi_plls (with
  1696. * different struct clk_hw). We fallback to the global
  1697. * naming string mechanism so vid_pll_div picks up the
  1698. * appropriate one.
  1699. */
  1700. .name = "hdmi_pll",
  1701. .index = -1,
  1702. },
  1703. .num_parents = 1,
  1704. .flags = CLK_SET_RATE_PARENT | CLK_GET_RATE_NOCACHE,
  1705. },
  1706. };
  1707. static const struct clk_parent_data gxbb_vid_pll_parent_data[] = {
  1708. { .hw = &gxbb_vid_pll_div.hw },
  1709. /*
  1710. * Note:
  1711. * GXL and GXBB have different hdmi_plls (with
  1712. * different struct clk_hw). We fallback to the global
  1713. * naming string mechanism so vid_pll_div picks up the
  1714. * appropriate one.
  1715. */
  1716. { .name = "hdmi_pll", .index = -1 },
  1717. };
  1718. static struct clk_regmap gxbb_vid_pll_sel = {
  1719. .data = &(struct clk_regmap_mux_data){
  1720. .offset = HHI_VID_PLL_CLK_DIV,
  1721. .mask = 0x1,
  1722. .shift = 18,
  1723. },
  1724. .hw.init = &(struct clk_init_data){
  1725. .name = "vid_pll_sel",
  1726. .ops = &clk_regmap_mux_ops,
  1727. /*
  1728. * bit 18 selects from 2 possible parents:
  1729. * vid_pll_div or hdmi_pll
  1730. */
  1731. .parent_data = gxbb_vid_pll_parent_data,
  1732. .num_parents = ARRAY_SIZE(gxbb_vid_pll_parent_data),
  1733. .flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE,
  1734. },
  1735. };
  1736. static struct clk_regmap gxbb_vid_pll = {
  1737. .data = &(struct clk_regmap_gate_data){
  1738. .offset = HHI_VID_PLL_CLK_DIV,
  1739. .bit_idx = 19,
  1740. },
  1741. .hw.init = &(struct clk_init_data) {
  1742. .name = "vid_pll",
  1743. .ops = &clk_regmap_gate_ops,
  1744. .parent_hws = (const struct clk_hw *[]) {
  1745. &gxbb_vid_pll_sel.hw
  1746. },
  1747. .num_parents = 1,
  1748. .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
  1749. },
  1750. };
  1751. static const struct clk_hw *gxbb_vclk_parent_hws[] = {
  1752. &gxbb_vid_pll.hw,
  1753. &gxbb_fclk_div4.hw,
  1754. &gxbb_fclk_div3.hw,
  1755. &gxbb_fclk_div5.hw,
  1756. &gxbb_vid_pll.hw,
  1757. &gxbb_fclk_div7.hw,
  1758. &gxbb_mpll1.hw,
  1759. };
  1760. static struct clk_regmap gxbb_vclk_sel = {
  1761. .data = &(struct clk_regmap_mux_data){
  1762. .offset = HHI_VID_CLK_CNTL,
  1763. .mask = 0x7,
  1764. .shift = 16,
  1765. },
  1766. .hw.init = &(struct clk_init_data){
  1767. .name = "vclk_sel",
  1768. .ops = &clk_regmap_mux_ops,
  1769. /*
  1770. * bits 16:18 selects from 8 possible parents:
  1771. * vid_pll, fclk_div4, fclk_div3, fclk_div5,
  1772. * vid_pll, fclk_div7, mp1
  1773. */
  1774. .parent_hws = gxbb_vclk_parent_hws,
  1775. .num_parents = ARRAY_SIZE(gxbb_vclk_parent_hws),
  1776. .flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE,
  1777. },
  1778. };
  1779. static struct clk_regmap gxbb_vclk2_sel = {
  1780. .data = &(struct clk_regmap_mux_data){
  1781. .offset = HHI_VIID_CLK_CNTL,
  1782. .mask = 0x7,
  1783. .shift = 16,
  1784. },
  1785. .hw.init = &(struct clk_init_data){
  1786. .name = "vclk2_sel",
  1787. .ops = &clk_regmap_mux_ops,
  1788. /*
  1789. * bits 16:18 selects from 8 possible parents:
  1790. * vid_pll, fclk_div4, fclk_div3, fclk_div5,
  1791. * vid_pll, fclk_div7, mp1
  1792. */
  1793. .parent_hws = gxbb_vclk_parent_hws,
  1794. .num_parents = ARRAY_SIZE(gxbb_vclk_parent_hws),
  1795. .flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE,
  1796. },
  1797. };
  1798. static struct clk_regmap gxbb_vclk_input = {
  1799. .data = &(struct clk_regmap_gate_data){
  1800. .offset = HHI_VID_CLK_DIV,
  1801. .bit_idx = 16,
  1802. },
  1803. .hw.init = &(struct clk_init_data) {
  1804. .name = "vclk_input",
  1805. .ops = &clk_regmap_gate_ops,
  1806. .parent_hws = (const struct clk_hw *[]) { &gxbb_vclk_sel.hw },
  1807. .num_parents = 1,
  1808. .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
  1809. },
  1810. };
  1811. static struct clk_regmap gxbb_vclk2_input = {
  1812. .data = &(struct clk_regmap_gate_data){
  1813. .offset = HHI_VIID_CLK_DIV,
  1814. .bit_idx = 16,
  1815. },
  1816. .hw.init = &(struct clk_init_data) {
  1817. .name = "vclk2_input",
  1818. .ops = &clk_regmap_gate_ops,
  1819. .parent_hws = (const struct clk_hw *[]) { &gxbb_vclk2_sel.hw },
  1820. .num_parents = 1,
  1821. .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
  1822. },
  1823. };
  1824. static struct clk_regmap gxbb_vclk_div = {
  1825. .data = &(struct clk_regmap_div_data){
  1826. .offset = HHI_VID_CLK_DIV,
  1827. .shift = 0,
  1828. .width = 8,
  1829. },
  1830. .hw.init = &(struct clk_init_data){
  1831. .name = "vclk_div",
  1832. .ops = &clk_regmap_divider_ops,
  1833. .parent_hws = (const struct clk_hw *[]) {
  1834. &gxbb_vclk_input.hw
  1835. },
  1836. .num_parents = 1,
  1837. .flags = CLK_GET_RATE_NOCACHE,
  1838. },
  1839. };
  1840. static struct clk_regmap gxbb_vclk2_div = {
  1841. .data = &(struct clk_regmap_div_data){
  1842. .offset = HHI_VIID_CLK_DIV,
  1843. .shift = 0,
  1844. .width = 8,
  1845. },
  1846. .hw.init = &(struct clk_init_data){
  1847. .name = "vclk2_div",
  1848. .ops = &clk_regmap_divider_ops,
  1849. .parent_hws = (const struct clk_hw *[]) {
  1850. &gxbb_vclk2_input.hw
  1851. },
  1852. .num_parents = 1,
  1853. .flags = CLK_GET_RATE_NOCACHE,
  1854. },
  1855. };
  1856. static struct clk_regmap gxbb_vclk = {
  1857. .data = &(struct clk_regmap_gate_data){
  1858. .offset = HHI_VID_CLK_CNTL,
  1859. .bit_idx = 19,
  1860. },
  1861. .hw.init = &(struct clk_init_data) {
  1862. .name = "vclk",
  1863. .ops = &clk_regmap_gate_ops,
  1864. .parent_hws = (const struct clk_hw *[]) { &gxbb_vclk_div.hw },
  1865. .num_parents = 1,
  1866. .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
  1867. },
  1868. };
  1869. static struct clk_regmap gxbb_vclk2 = {
  1870. .data = &(struct clk_regmap_gate_data){
  1871. .offset = HHI_VIID_CLK_CNTL,
  1872. .bit_idx = 19,
  1873. },
  1874. .hw.init = &(struct clk_init_data) {
  1875. .name = "vclk2",
  1876. .ops = &clk_regmap_gate_ops,
  1877. .parent_hws = (const struct clk_hw *[]) { &gxbb_vclk2_div.hw },
  1878. .num_parents = 1,
  1879. .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
  1880. },
  1881. };
  1882. static struct clk_regmap gxbb_vclk_div1 = {
  1883. .data = &(struct clk_regmap_gate_data){
  1884. .offset = HHI_VID_CLK_CNTL,
  1885. .bit_idx = 0,
  1886. },
  1887. .hw.init = &(struct clk_init_data) {
  1888. .name = "vclk_div1",
  1889. .ops = &clk_regmap_gate_ops,
  1890. .parent_hws = (const struct clk_hw *[]) { &gxbb_vclk.hw },
  1891. .num_parents = 1,
  1892. .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
  1893. },
  1894. };
  1895. static struct clk_regmap gxbb_vclk_div2_en = {
  1896. .data = &(struct clk_regmap_gate_data){
  1897. .offset = HHI_VID_CLK_CNTL,
  1898. .bit_idx = 1,
  1899. },
  1900. .hw.init = &(struct clk_init_data) {
  1901. .name = "vclk_div2_en",
  1902. .ops = &clk_regmap_gate_ops,
  1903. .parent_hws = (const struct clk_hw *[]) { &gxbb_vclk.hw },
  1904. .num_parents = 1,
  1905. .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
  1906. },
  1907. };
  1908. static struct clk_regmap gxbb_vclk_div4_en = {
  1909. .data = &(struct clk_regmap_gate_data){
  1910. .offset = HHI_VID_CLK_CNTL,
  1911. .bit_idx = 2,
  1912. },
  1913. .hw.init = &(struct clk_init_data) {
  1914. .name = "vclk_div4_en",
  1915. .ops = &clk_regmap_gate_ops,
  1916. .parent_hws = (const struct clk_hw *[]) { &gxbb_vclk.hw },
  1917. .num_parents = 1,
  1918. .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
  1919. },
  1920. };
  1921. static struct clk_regmap gxbb_vclk_div6_en = {
  1922. .data = &(struct clk_regmap_gate_data){
  1923. .offset = HHI_VID_CLK_CNTL,
  1924. .bit_idx = 3,
  1925. },
  1926. .hw.init = &(struct clk_init_data) {
  1927. .name = "vclk_div6_en",
  1928. .ops = &clk_regmap_gate_ops,
  1929. .parent_hws = (const struct clk_hw *[]) { &gxbb_vclk.hw },
  1930. .num_parents = 1,
  1931. .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
  1932. },
  1933. };
  1934. static struct clk_regmap gxbb_vclk_div12_en = {
  1935. .data = &(struct clk_regmap_gate_data){
  1936. .offset = HHI_VID_CLK_CNTL,
  1937. .bit_idx = 4,
  1938. },
  1939. .hw.init = &(struct clk_init_data) {
  1940. .name = "vclk_div12_en",
  1941. .ops = &clk_regmap_gate_ops,
  1942. .parent_hws = (const struct clk_hw *[]) { &gxbb_vclk.hw },
  1943. .num_parents = 1,
  1944. .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
  1945. },
  1946. };
  1947. static struct clk_regmap gxbb_vclk2_div1 = {
  1948. .data = &(struct clk_regmap_gate_data){
  1949. .offset = HHI_VIID_CLK_CNTL,
  1950. .bit_idx = 0,
  1951. },
  1952. .hw.init = &(struct clk_init_data) {
  1953. .name = "vclk2_div1",
  1954. .ops = &clk_regmap_gate_ops,
  1955. .parent_hws = (const struct clk_hw *[]) { &gxbb_vclk2.hw },
  1956. .num_parents = 1,
  1957. .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
  1958. },
  1959. };
  1960. static struct clk_regmap gxbb_vclk2_div2_en = {
  1961. .data = &(struct clk_regmap_gate_data){
  1962. .offset = HHI_VIID_CLK_CNTL,
  1963. .bit_idx = 1,
  1964. },
  1965. .hw.init = &(struct clk_init_data) {
  1966. .name = "vclk2_div2_en",
  1967. .ops = &clk_regmap_gate_ops,
  1968. .parent_hws = (const struct clk_hw *[]) { &gxbb_vclk2.hw },
  1969. .num_parents = 1,
  1970. .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
  1971. },
  1972. };
  1973. static struct clk_regmap gxbb_vclk2_div4_en = {
  1974. .data = &(struct clk_regmap_gate_data){
  1975. .offset = HHI_VIID_CLK_CNTL,
  1976. .bit_idx = 2,
  1977. },
  1978. .hw.init = &(struct clk_init_data) {
  1979. .name = "vclk2_div4_en",
  1980. .ops = &clk_regmap_gate_ops,
  1981. .parent_hws = (const struct clk_hw *[]) { &gxbb_vclk2.hw },
  1982. .num_parents = 1,
  1983. .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
  1984. },
  1985. };
  1986. static struct clk_regmap gxbb_vclk2_div6_en = {
  1987. .data = &(struct clk_regmap_gate_data){
  1988. .offset = HHI_VIID_CLK_CNTL,
  1989. .bit_idx = 3,
  1990. },
  1991. .hw.init = &(struct clk_init_data) {
  1992. .name = "vclk2_div6_en",
  1993. .ops = &clk_regmap_gate_ops,
  1994. .parent_hws = (const struct clk_hw *[]) { &gxbb_vclk2.hw },
  1995. .num_parents = 1,
  1996. .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
  1997. },
  1998. };
  1999. static struct clk_regmap gxbb_vclk2_div12_en = {
  2000. .data = &(struct clk_regmap_gate_data){
  2001. .offset = HHI_VIID_CLK_CNTL,
  2002. .bit_idx = 4,
  2003. },
  2004. .hw.init = &(struct clk_init_data) {
  2005. .name = "vclk2_div12_en",
  2006. .ops = &clk_regmap_gate_ops,
  2007. .parent_hws = (const struct clk_hw *[]) { &gxbb_vclk2.hw },
  2008. .num_parents = 1,
  2009. .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
  2010. },
  2011. };
  2012. static struct clk_fixed_factor gxbb_vclk_div2 = {
  2013. .mult = 1,
  2014. .div = 2,
  2015. .hw.init = &(struct clk_init_data){
  2016. .name = "vclk_div2",
  2017. .ops = &clk_fixed_factor_ops,
  2018. .parent_hws = (const struct clk_hw *[]) {
  2019. &gxbb_vclk_div2_en.hw
  2020. },
  2021. .num_parents = 1,
  2022. },
  2023. };
  2024. static struct clk_fixed_factor gxbb_vclk_div4 = {
  2025. .mult = 1,
  2026. .div = 4,
  2027. .hw.init = &(struct clk_init_data){
  2028. .name = "vclk_div4",
  2029. .ops = &clk_fixed_factor_ops,
  2030. .parent_hws = (const struct clk_hw *[]) {
  2031. &gxbb_vclk_div4_en.hw
  2032. },
  2033. .num_parents = 1,
  2034. },
  2035. };
  2036. static struct clk_fixed_factor gxbb_vclk_div6 = {
  2037. .mult = 1,
  2038. .div = 6,
  2039. .hw.init = &(struct clk_init_data){
  2040. .name = "vclk_div6",
  2041. .ops = &clk_fixed_factor_ops,
  2042. .parent_hws = (const struct clk_hw *[]) {
  2043. &gxbb_vclk_div6_en.hw
  2044. },
  2045. .num_parents = 1,
  2046. },
  2047. };
  2048. static struct clk_fixed_factor gxbb_vclk_div12 = {
  2049. .mult = 1,
  2050. .div = 12,
  2051. .hw.init = &(struct clk_init_data){
  2052. .name = "vclk_div12",
  2053. .ops = &clk_fixed_factor_ops,
  2054. .parent_hws = (const struct clk_hw *[]) {
  2055. &gxbb_vclk_div12_en.hw
  2056. },
  2057. .num_parents = 1,
  2058. },
  2059. };
  2060. static struct clk_fixed_factor gxbb_vclk2_div2 = {
  2061. .mult = 1,
  2062. .div = 2,
  2063. .hw.init = &(struct clk_init_data){
  2064. .name = "vclk2_div2",
  2065. .ops = &clk_fixed_factor_ops,
  2066. .parent_hws = (const struct clk_hw *[]) {
  2067. &gxbb_vclk2_div2_en.hw
  2068. },
  2069. .num_parents = 1,
  2070. },
  2071. };
  2072. static struct clk_fixed_factor gxbb_vclk2_div4 = {
  2073. .mult = 1,
  2074. .div = 4,
  2075. .hw.init = &(struct clk_init_data){
  2076. .name = "vclk2_div4",
  2077. .ops = &clk_fixed_factor_ops,
  2078. .parent_hws = (const struct clk_hw *[]) {
  2079. &gxbb_vclk2_div4_en.hw
  2080. },
  2081. .num_parents = 1,
  2082. },
  2083. };
  2084. static struct clk_fixed_factor gxbb_vclk2_div6 = {
  2085. .mult = 1,
  2086. .div = 6,
  2087. .hw.init = &(struct clk_init_data){
  2088. .name = "vclk2_div6",
  2089. .ops = &clk_fixed_factor_ops,
  2090. .parent_hws = (const struct clk_hw *[]) {
  2091. &gxbb_vclk2_div6_en.hw
  2092. },
  2093. .num_parents = 1,
  2094. },
  2095. };
  2096. static struct clk_fixed_factor gxbb_vclk2_div12 = {
  2097. .mult = 1,
  2098. .div = 12,
  2099. .hw.init = &(struct clk_init_data){
  2100. .name = "vclk2_div12",
  2101. .ops = &clk_fixed_factor_ops,
  2102. .parent_hws = (const struct clk_hw *[]) {
  2103. &gxbb_vclk2_div12_en.hw
  2104. },
  2105. .num_parents = 1,
  2106. },
  2107. };
  2108. static u32 mux_table_cts_sel[] = { 0, 1, 2, 3, 4, 8, 9, 10, 11, 12 };
  2109. static const struct clk_hw *gxbb_cts_parent_hws[] = {
  2110. &gxbb_vclk_div1.hw,
  2111. &gxbb_vclk_div2.hw,
  2112. &gxbb_vclk_div4.hw,
  2113. &gxbb_vclk_div6.hw,
  2114. &gxbb_vclk_div12.hw,
  2115. &gxbb_vclk2_div1.hw,
  2116. &gxbb_vclk2_div2.hw,
  2117. &gxbb_vclk2_div4.hw,
  2118. &gxbb_vclk2_div6.hw,
  2119. &gxbb_vclk2_div12.hw,
  2120. };
  2121. static struct clk_regmap gxbb_cts_enci_sel = {
  2122. .data = &(struct clk_regmap_mux_data){
  2123. .offset = HHI_VID_CLK_DIV,
  2124. .mask = 0xf,
  2125. .shift = 28,
  2126. .table = mux_table_cts_sel,
  2127. },
  2128. .hw.init = &(struct clk_init_data){
  2129. .name = "cts_enci_sel",
  2130. .ops = &clk_regmap_mux_ops,
  2131. .parent_hws = gxbb_cts_parent_hws,
  2132. .num_parents = ARRAY_SIZE(gxbb_cts_parent_hws),
  2133. .flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE,
  2134. },
  2135. };
  2136. static struct clk_regmap gxbb_cts_encp_sel = {
  2137. .data = &(struct clk_regmap_mux_data){
  2138. .offset = HHI_VID_CLK_DIV,
  2139. .mask = 0xf,
  2140. .shift = 20,
  2141. .table = mux_table_cts_sel,
  2142. },
  2143. .hw.init = &(struct clk_init_data){
  2144. .name = "cts_encp_sel",
  2145. .ops = &clk_regmap_mux_ops,
  2146. .parent_hws = gxbb_cts_parent_hws,
  2147. .num_parents = ARRAY_SIZE(gxbb_cts_parent_hws),
  2148. .flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE,
  2149. },
  2150. };
  2151. static struct clk_regmap gxbb_cts_vdac_sel = {
  2152. .data = &(struct clk_regmap_mux_data){
  2153. .offset = HHI_VIID_CLK_DIV,
  2154. .mask = 0xf,
  2155. .shift = 28,
  2156. .table = mux_table_cts_sel,
  2157. },
  2158. .hw.init = &(struct clk_init_data){
  2159. .name = "cts_vdac_sel",
  2160. .ops = &clk_regmap_mux_ops,
  2161. .parent_hws = gxbb_cts_parent_hws,
  2162. .num_parents = ARRAY_SIZE(gxbb_cts_parent_hws),
  2163. .flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE,
  2164. },
  2165. };
  2166. /* TOFIX: add support for cts_tcon */
  2167. static u32 mux_table_hdmi_tx_sel[] = { 0, 1, 2, 3, 4, 8, 9, 10, 11, 12 };
  2168. static const struct clk_hw *gxbb_cts_hdmi_tx_parent_hws[] = {
  2169. &gxbb_vclk_div1.hw,
  2170. &gxbb_vclk_div2.hw,
  2171. &gxbb_vclk_div4.hw,
  2172. &gxbb_vclk_div6.hw,
  2173. &gxbb_vclk_div12.hw,
  2174. &gxbb_vclk2_div1.hw,
  2175. &gxbb_vclk2_div2.hw,
  2176. &gxbb_vclk2_div4.hw,
  2177. &gxbb_vclk2_div6.hw,
  2178. &gxbb_vclk2_div12.hw,
  2179. };
  2180. static struct clk_regmap gxbb_hdmi_tx_sel = {
  2181. .data = &(struct clk_regmap_mux_data){
  2182. .offset = HHI_HDMI_CLK_CNTL,
  2183. .mask = 0xf,
  2184. .shift = 16,
  2185. .table = mux_table_hdmi_tx_sel,
  2186. },
  2187. .hw.init = &(struct clk_init_data){
  2188. .name = "hdmi_tx_sel",
  2189. .ops = &clk_regmap_mux_ops,
  2190. /*
  2191. * bits 31:28 selects from 12 possible parents:
  2192. * vclk_div1, vclk_div2, vclk_div4, vclk_div6, vclk_div12
  2193. * vclk2_div1, vclk2_div2, vclk2_div4, vclk2_div6, vclk2_div12,
  2194. * cts_tcon
  2195. */
  2196. .parent_hws = gxbb_cts_hdmi_tx_parent_hws,
  2197. .num_parents = ARRAY_SIZE(gxbb_cts_hdmi_tx_parent_hws),
  2198. .flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE,
  2199. },
  2200. };
  2201. static struct clk_regmap gxbb_cts_enci = {
  2202. .data = &(struct clk_regmap_gate_data){
  2203. .offset = HHI_VID_CLK_CNTL2,
  2204. .bit_idx = 0,
  2205. },
  2206. .hw.init = &(struct clk_init_data) {
  2207. .name = "cts_enci",
  2208. .ops = &clk_regmap_gate_ops,
  2209. .parent_hws = (const struct clk_hw *[]) {
  2210. &gxbb_cts_enci_sel.hw
  2211. },
  2212. .num_parents = 1,
  2213. .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
  2214. },
  2215. };
  2216. static struct clk_regmap gxbb_cts_encp = {
  2217. .data = &(struct clk_regmap_gate_data){
  2218. .offset = HHI_VID_CLK_CNTL2,
  2219. .bit_idx = 2,
  2220. },
  2221. .hw.init = &(struct clk_init_data) {
  2222. .name = "cts_encp",
  2223. .ops = &clk_regmap_gate_ops,
  2224. .parent_hws = (const struct clk_hw *[]) {
  2225. &gxbb_cts_encp_sel.hw
  2226. },
  2227. .num_parents = 1,
  2228. .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
  2229. },
  2230. };
  2231. static struct clk_regmap gxbb_cts_vdac = {
  2232. .data = &(struct clk_regmap_gate_data){
  2233. .offset = HHI_VID_CLK_CNTL2,
  2234. .bit_idx = 4,
  2235. },
  2236. .hw.init = &(struct clk_init_data) {
  2237. .name = "cts_vdac",
  2238. .ops = &clk_regmap_gate_ops,
  2239. .parent_hws = (const struct clk_hw *[]) {
  2240. &gxbb_cts_vdac_sel.hw
  2241. },
  2242. .num_parents = 1,
  2243. .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
  2244. },
  2245. };
  2246. static struct clk_regmap gxbb_hdmi_tx = {
  2247. .data = &(struct clk_regmap_gate_data){
  2248. .offset = HHI_VID_CLK_CNTL2,
  2249. .bit_idx = 5,
  2250. },
  2251. .hw.init = &(struct clk_init_data) {
  2252. .name = "hdmi_tx",
  2253. .ops = &clk_regmap_gate_ops,
  2254. .parent_hws = (const struct clk_hw *[]) {
  2255. &gxbb_hdmi_tx_sel.hw
  2256. },
  2257. .num_parents = 1,
  2258. .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
  2259. },
  2260. };
  2261. /* HDMI Clocks */
  2262. static const struct clk_parent_data gxbb_hdmi_parent_data[] = {
  2263. { .fw_name = "xtal", },
  2264. { .hw = &gxbb_fclk_div4.hw },
  2265. { .hw = &gxbb_fclk_div3.hw },
  2266. { .hw = &gxbb_fclk_div5.hw },
  2267. };
  2268. static struct clk_regmap gxbb_hdmi_sel = {
  2269. .data = &(struct clk_regmap_mux_data){
  2270. .offset = HHI_HDMI_CLK_CNTL,
  2271. .mask = 0x3,
  2272. .shift = 9,
  2273. .flags = CLK_MUX_ROUND_CLOSEST,
  2274. },
  2275. .hw.init = &(struct clk_init_data){
  2276. .name = "hdmi_sel",
  2277. .ops = &clk_regmap_mux_ops,
  2278. .parent_data = gxbb_hdmi_parent_data,
  2279. .num_parents = ARRAY_SIZE(gxbb_hdmi_parent_data),
  2280. .flags = CLK_SET_RATE_NO_REPARENT | CLK_GET_RATE_NOCACHE,
  2281. },
  2282. };
  2283. static struct clk_regmap gxbb_hdmi_div = {
  2284. .data = &(struct clk_regmap_div_data){
  2285. .offset = HHI_HDMI_CLK_CNTL,
  2286. .shift = 0,
  2287. .width = 7,
  2288. },
  2289. .hw.init = &(struct clk_init_data){
  2290. .name = "hdmi_div",
  2291. .ops = &clk_regmap_divider_ops,
  2292. .parent_hws = (const struct clk_hw *[]) { &gxbb_hdmi_sel.hw },
  2293. .num_parents = 1,
  2294. .flags = CLK_GET_RATE_NOCACHE,
  2295. },
  2296. };
  2297. static struct clk_regmap gxbb_hdmi = {
  2298. .data = &(struct clk_regmap_gate_data){
  2299. .offset = HHI_HDMI_CLK_CNTL,
  2300. .bit_idx = 8,
  2301. },
  2302. .hw.init = &(struct clk_init_data) {
  2303. .name = "hdmi",
  2304. .ops = &clk_regmap_gate_ops,
  2305. .parent_hws = (const struct clk_hw *[]) { &gxbb_hdmi_div.hw },
  2306. .num_parents = 1,
  2307. .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
  2308. },
  2309. };
  2310. /* VDEC clocks */
  2311. static const struct clk_hw *gxbb_vdec_parent_hws[] = {
  2312. &gxbb_fclk_div4.hw,
  2313. &gxbb_fclk_div3.hw,
  2314. &gxbb_fclk_div5.hw,
  2315. &gxbb_fclk_div7.hw,
  2316. };
  2317. static struct clk_regmap gxbb_vdec_1_sel = {
  2318. .data = &(struct clk_regmap_mux_data){
  2319. .offset = HHI_VDEC_CLK_CNTL,
  2320. .mask = 0x3,
  2321. .shift = 9,
  2322. .flags = CLK_MUX_ROUND_CLOSEST,
  2323. },
  2324. .hw.init = &(struct clk_init_data){
  2325. .name = "vdec_1_sel",
  2326. .ops = &clk_regmap_mux_ops,
  2327. .parent_hws = gxbb_vdec_parent_hws,
  2328. .num_parents = ARRAY_SIZE(gxbb_vdec_parent_hws),
  2329. .flags = CLK_SET_RATE_PARENT,
  2330. },
  2331. };
  2332. static struct clk_regmap gxbb_vdec_1_div = {
  2333. .data = &(struct clk_regmap_div_data){
  2334. .offset = HHI_VDEC_CLK_CNTL,
  2335. .shift = 0,
  2336. .width = 7,
  2337. .flags = CLK_DIVIDER_ROUND_CLOSEST,
  2338. },
  2339. .hw.init = &(struct clk_init_data){
  2340. .name = "vdec_1_div",
  2341. .ops = &clk_regmap_divider_ops,
  2342. .parent_hws = (const struct clk_hw *[]) {
  2343. &gxbb_vdec_1_sel.hw
  2344. },
  2345. .num_parents = 1,
  2346. .flags = CLK_SET_RATE_PARENT,
  2347. },
  2348. };
  2349. static struct clk_regmap gxbb_vdec_1 = {
  2350. .data = &(struct clk_regmap_gate_data){
  2351. .offset = HHI_VDEC_CLK_CNTL,
  2352. .bit_idx = 8,
  2353. },
  2354. .hw.init = &(struct clk_init_data) {
  2355. .name = "vdec_1",
  2356. .ops = &clk_regmap_gate_ops,
  2357. .parent_hws = (const struct clk_hw *[]) {
  2358. &gxbb_vdec_1_div.hw
  2359. },
  2360. .num_parents = 1,
  2361. .flags = CLK_SET_RATE_PARENT,
  2362. },
  2363. };
  2364. static struct clk_regmap gxbb_vdec_hevc_sel = {
  2365. .data = &(struct clk_regmap_mux_data){
  2366. .offset = HHI_VDEC2_CLK_CNTL,
  2367. .mask = 0x3,
  2368. .shift = 25,
  2369. .flags = CLK_MUX_ROUND_CLOSEST,
  2370. },
  2371. .hw.init = &(struct clk_init_data){
  2372. .name = "vdec_hevc_sel",
  2373. .ops = &clk_regmap_mux_ops,
  2374. .parent_hws = gxbb_vdec_parent_hws,
  2375. .num_parents = ARRAY_SIZE(gxbb_vdec_parent_hws),
  2376. .flags = CLK_SET_RATE_PARENT,
  2377. },
  2378. };
  2379. static struct clk_regmap gxbb_vdec_hevc_div = {
  2380. .data = &(struct clk_regmap_div_data){
  2381. .offset = HHI_VDEC2_CLK_CNTL,
  2382. .shift = 16,
  2383. .width = 7,
  2384. .flags = CLK_DIVIDER_ROUND_CLOSEST,
  2385. },
  2386. .hw.init = &(struct clk_init_data){
  2387. .name = "vdec_hevc_div",
  2388. .ops = &clk_regmap_divider_ops,
  2389. .parent_hws = (const struct clk_hw *[]) {
  2390. &gxbb_vdec_hevc_sel.hw
  2391. },
  2392. .num_parents = 1,
  2393. .flags = CLK_SET_RATE_PARENT,
  2394. },
  2395. };
  2396. static struct clk_regmap gxbb_vdec_hevc = {
  2397. .data = &(struct clk_regmap_gate_data){
  2398. .offset = HHI_VDEC2_CLK_CNTL,
  2399. .bit_idx = 24,
  2400. },
  2401. .hw.init = &(struct clk_init_data) {
  2402. .name = "vdec_hevc",
  2403. .ops = &clk_regmap_gate_ops,
  2404. .parent_hws = (const struct clk_hw *[]) {
  2405. &gxbb_vdec_hevc_div.hw
  2406. },
  2407. .num_parents = 1,
  2408. .flags = CLK_SET_RATE_PARENT,
  2409. },
  2410. };
  2411. static u32 mux_table_gen_clk[] = { 0, 4, 5, 6, 7, 8,
  2412. 9, 10, 11, 13, 14, };
  2413. static const struct clk_parent_data gen_clk_parent_data[] = {
  2414. { .fw_name = "xtal", },
  2415. { .hw = &gxbb_vdec_1.hw },
  2416. { .hw = &gxbb_vdec_hevc.hw },
  2417. { .hw = &gxbb_mpll0.hw },
  2418. { .hw = &gxbb_mpll1.hw },
  2419. { .hw = &gxbb_mpll2.hw },
  2420. { .hw = &gxbb_fclk_div4.hw },
  2421. { .hw = &gxbb_fclk_div3.hw },
  2422. { .hw = &gxbb_fclk_div5.hw },
  2423. { .hw = &gxbb_fclk_div7.hw },
  2424. { .hw = &gxbb_gp0_pll.hw },
  2425. };
  2426. static struct clk_regmap gxbb_gen_clk_sel = {
  2427. .data = &(struct clk_regmap_mux_data){
  2428. .offset = HHI_GEN_CLK_CNTL,
  2429. .mask = 0xf,
  2430. .shift = 12,
  2431. .table = mux_table_gen_clk,
  2432. },
  2433. .hw.init = &(struct clk_init_data){
  2434. .name = "gen_clk_sel",
  2435. .ops = &clk_regmap_mux_ops,
  2436. /*
  2437. * bits 15:12 selects from 14 possible parents:
  2438. * xtal, [rtc_oscin_i], [sys_cpu_div16], [ddr_dpll_pt],
  2439. * vid_pll, vid2_pll (hevc), mpll0, mpll1, mpll2, fdiv4,
  2440. * fdiv3, fdiv5, [cts_msr_clk], fdiv7, gp0_pll
  2441. */
  2442. .parent_data = gen_clk_parent_data,
  2443. .num_parents = ARRAY_SIZE(gen_clk_parent_data),
  2444. },
  2445. };
  2446. static struct clk_regmap gxbb_gen_clk_div = {
  2447. .data = &(struct clk_regmap_div_data){
  2448. .offset = HHI_GEN_CLK_CNTL,
  2449. .shift = 0,
  2450. .width = 11,
  2451. },
  2452. .hw.init = &(struct clk_init_data){
  2453. .name = "gen_clk_div",
  2454. .ops = &clk_regmap_divider_ops,
  2455. .parent_hws = (const struct clk_hw *[]) {
  2456. &gxbb_gen_clk_sel.hw
  2457. },
  2458. .num_parents = 1,
  2459. .flags = CLK_SET_RATE_PARENT,
  2460. },
  2461. };
  2462. static struct clk_regmap gxbb_gen_clk = {
  2463. .data = &(struct clk_regmap_gate_data){
  2464. .offset = HHI_GEN_CLK_CNTL,
  2465. .bit_idx = 7,
  2466. },
  2467. .hw.init = &(struct clk_init_data){
  2468. .name = "gen_clk",
  2469. .ops = &clk_regmap_gate_ops,
  2470. .parent_hws = (const struct clk_hw *[]) {
  2471. &gxbb_gen_clk_div.hw
  2472. },
  2473. .num_parents = 1,
  2474. .flags = CLK_SET_RATE_PARENT,
  2475. },
  2476. };
  2477. #define MESON_GATE(_name, _reg, _bit) \
  2478. MESON_PCLK(_name, _reg, _bit, &gxbb_clk81.hw)
  2479. /* Everything Else (EE) domain gates */
  2480. static MESON_GATE(gxbb_ddr, HHI_GCLK_MPEG0, 0);
  2481. static MESON_GATE(gxbb_dos, HHI_GCLK_MPEG0, 1);
  2482. static MESON_GATE(gxbb_isa, HHI_GCLK_MPEG0, 5);
  2483. static MESON_GATE(gxbb_pl301, HHI_GCLK_MPEG0, 6);
  2484. static MESON_GATE(gxbb_periphs, HHI_GCLK_MPEG0, 7);
  2485. static MESON_GATE(gxbb_spicc, HHI_GCLK_MPEG0, 8);
  2486. static MESON_GATE(gxbb_i2c, HHI_GCLK_MPEG0, 9);
  2487. static MESON_GATE(gxbb_sana, HHI_GCLK_MPEG0, 10);
  2488. static MESON_GATE(gxbb_smart_card, HHI_GCLK_MPEG0, 11);
  2489. static MESON_GATE(gxbb_rng0, HHI_GCLK_MPEG0, 12);
  2490. static MESON_GATE(gxbb_uart0, HHI_GCLK_MPEG0, 13);
  2491. static MESON_GATE(gxbb_sdhc, HHI_GCLK_MPEG0, 14);
  2492. static MESON_GATE(gxbb_stream, HHI_GCLK_MPEG0, 15);
  2493. static MESON_GATE(gxbb_async_fifo, HHI_GCLK_MPEG0, 16);
  2494. static MESON_GATE(gxbb_sdio, HHI_GCLK_MPEG0, 17);
  2495. static MESON_GATE(gxbb_abuf, HHI_GCLK_MPEG0, 18);
  2496. static MESON_GATE(gxbb_hiu_iface, HHI_GCLK_MPEG0, 19);
  2497. static MESON_GATE(gxbb_assist_misc, HHI_GCLK_MPEG0, 23);
  2498. static MESON_GATE(gxbb_emmc_a, HHI_GCLK_MPEG0, 24);
  2499. static MESON_GATE(gxbb_emmc_b, HHI_GCLK_MPEG0, 25);
  2500. static MESON_GATE(gxbb_emmc_c, HHI_GCLK_MPEG0, 26);
  2501. static MESON_GATE(gxl_acodec, HHI_GCLK_MPEG0, 28);
  2502. static MESON_GATE(gxbb_spi, HHI_GCLK_MPEG0, 30);
  2503. static MESON_GATE(gxbb_i2s_spdif, HHI_GCLK_MPEG1, 2);
  2504. static MESON_GATE(gxbb_eth, HHI_GCLK_MPEG1, 3);
  2505. static MESON_GATE(gxbb_demux, HHI_GCLK_MPEG1, 4);
  2506. static MESON_GATE(gxbb_blkmv, HHI_GCLK_MPEG1, 14);
  2507. static MESON_GATE(gxbb_aiu, HHI_GCLK_MPEG1, 15);
  2508. static MESON_GATE(gxbb_uart1, HHI_GCLK_MPEG1, 16);
  2509. static MESON_GATE(gxbb_g2d, HHI_GCLK_MPEG1, 20);
  2510. static MESON_GATE(gxbb_usb0, HHI_GCLK_MPEG1, 21);
  2511. static MESON_GATE(gxbb_usb1, HHI_GCLK_MPEG1, 22);
  2512. static MESON_GATE(gxbb_reset, HHI_GCLK_MPEG1, 23);
  2513. static MESON_GATE(gxbb_nand, HHI_GCLK_MPEG1, 24);
  2514. static MESON_GATE(gxbb_dos_parser, HHI_GCLK_MPEG1, 25);
  2515. static MESON_GATE(gxbb_usb, HHI_GCLK_MPEG1, 26);
  2516. static MESON_GATE(gxbb_vdin1, HHI_GCLK_MPEG1, 28);
  2517. static MESON_GATE(gxbb_ahb_arb0, HHI_GCLK_MPEG1, 29);
  2518. static MESON_GATE(gxbb_efuse, HHI_GCLK_MPEG1, 30);
  2519. static MESON_GATE(gxbb_boot_rom, HHI_GCLK_MPEG1, 31);
  2520. static MESON_GATE(gxbb_ahb_data_bus, HHI_GCLK_MPEG2, 1);
  2521. static MESON_GATE(gxbb_ahb_ctrl_bus, HHI_GCLK_MPEG2, 2);
  2522. static MESON_GATE(gxbb_hdmi_intr_sync, HHI_GCLK_MPEG2, 3);
  2523. static MESON_GATE(gxbb_hdmi_pclk, HHI_GCLK_MPEG2, 4);
  2524. static MESON_GATE(gxbb_usb1_ddr_bridge, HHI_GCLK_MPEG2, 8);
  2525. static MESON_GATE(gxbb_usb0_ddr_bridge, HHI_GCLK_MPEG2, 9);
  2526. static MESON_GATE(gxbb_mmc_pclk, HHI_GCLK_MPEG2, 11);
  2527. static MESON_GATE(gxbb_dvin, HHI_GCLK_MPEG2, 12);
  2528. static MESON_GATE(gxbb_uart2, HHI_GCLK_MPEG2, 15);
  2529. static MESON_GATE(gxbb_sar_adc, HHI_GCLK_MPEG2, 22);
  2530. static MESON_GATE(gxbb_vpu_intr, HHI_GCLK_MPEG2, 25);
  2531. static MESON_GATE(gxbb_sec_ahb_ahb3_bridge, HHI_GCLK_MPEG2, 26);
  2532. static MESON_GATE(gxbb_clk81_a53, HHI_GCLK_MPEG2, 29);
  2533. static MESON_GATE(gxbb_vclk2_venci0, HHI_GCLK_OTHER, 1);
  2534. static MESON_GATE(gxbb_vclk2_venci1, HHI_GCLK_OTHER, 2);
  2535. static MESON_GATE(gxbb_vclk2_vencp0, HHI_GCLK_OTHER, 3);
  2536. static MESON_GATE(gxbb_vclk2_vencp1, HHI_GCLK_OTHER, 4);
  2537. static MESON_GATE(gxbb_gclk_venci_int0, HHI_GCLK_OTHER, 8);
  2538. static MESON_GATE(gxbb_gclk_vencp_int, HHI_GCLK_OTHER, 9);
  2539. static MESON_GATE(gxbb_dac_clk, HHI_GCLK_OTHER, 10);
  2540. static MESON_GATE(gxbb_aoclk_gate, HHI_GCLK_OTHER, 14);
  2541. static MESON_GATE(gxbb_iec958_gate, HHI_GCLK_OTHER, 16);
  2542. static MESON_GATE(gxbb_enc480p, HHI_GCLK_OTHER, 20);
  2543. static MESON_GATE(gxbb_rng1, HHI_GCLK_OTHER, 21);
  2544. static MESON_GATE(gxbb_gclk_venci_int1, HHI_GCLK_OTHER, 22);
  2545. static MESON_GATE(gxbb_vclk2_venclmcc, HHI_GCLK_OTHER, 24);
  2546. static MESON_GATE(gxbb_vclk2_vencl, HHI_GCLK_OTHER, 25);
  2547. static MESON_GATE(gxbb_vclk_other, HHI_GCLK_OTHER, 26);
  2548. static MESON_GATE(gxbb_edp, HHI_GCLK_OTHER, 31);
  2549. /* Always On (AO) domain gates */
  2550. static MESON_GATE(gxbb_ao_media_cpu, HHI_GCLK_AO, 0);
  2551. static MESON_GATE(gxbb_ao_ahb_sram, HHI_GCLK_AO, 1);
  2552. static MESON_GATE(gxbb_ao_ahb_bus, HHI_GCLK_AO, 2);
  2553. static MESON_GATE(gxbb_ao_iface, HHI_GCLK_AO, 3);
  2554. static MESON_GATE(gxbb_ao_i2c, HHI_GCLK_AO, 4);
  2555. /* AIU gates */
  2556. static MESON_PCLK(gxbb_aiu_glue, HHI_GCLK_MPEG1, 6, &gxbb_aiu.hw);
  2557. static MESON_PCLK(gxbb_iec958, HHI_GCLK_MPEG1, 7, &gxbb_aiu_glue.hw);
  2558. static MESON_PCLK(gxbb_i2s_out, HHI_GCLK_MPEG1, 8, &gxbb_aiu_glue.hw);
  2559. static MESON_PCLK(gxbb_amclk, HHI_GCLK_MPEG1, 9, &gxbb_aiu_glue.hw);
  2560. static MESON_PCLK(gxbb_aififo2, HHI_GCLK_MPEG1, 10, &gxbb_aiu_glue.hw);
  2561. static MESON_PCLK(gxbb_mixer, HHI_GCLK_MPEG1, 11, &gxbb_aiu_glue.hw);
  2562. static MESON_PCLK(gxbb_mixer_iface, HHI_GCLK_MPEG1, 12, &gxbb_aiu_glue.hw);
  2563. static MESON_PCLK(gxbb_adc, HHI_GCLK_MPEG1, 13, &gxbb_aiu_glue.hw);
  2564. /* Array of all clocks provided by this provider */
  2565. static struct clk_hw *gxbb_hw_clks[] = {
  2566. [CLKID_SYS_PLL] = &gxbb_sys_pll.hw,
  2567. [CLKID_HDMI_PLL] = &gxbb_hdmi_pll.hw,
  2568. [CLKID_FIXED_PLL] = &gxbb_fixed_pll.hw,
  2569. [CLKID_FCLK_DIV2] = &gxbb_fclk_div2.hw,
  2570. [CLKID_FCLK_DIV3] = &gxbb_fclk_div3.hw,
  2571. [CLKID_FCLK_DIV4] = &gxbb_fclk_div4.hw,
  2572. [CLKID_FCLK_DIV5] = &gxbb_fclk_div5.hw,
  2573. [CLKID_FCLK_DIV7] = &gxbb_fclk_div7.hw,
  2574. [CLKID_GP0_PLL] = &gxbb_gp0_pll.hw,
  2575. [CLKID_MPEG_SEL] = &gxbb_mpeg_clk_sel.hw,
  2576. [CLKID_MPEG_DIV] = &gxbb_mpeg_clk_div.hw,
  2577. [CLKID_CLK81] = &gxbb_clk81.hw,
  2578. [CLKID_MPLL0] = &gxbb_mpll0.hw,
  2579. [CLKID_MPLL1] = &gxbb_mpll1.hw,
  2580. [CLKID_MPLL2] = &gxbb_mpll2.hw,
  2581. [CLKID_DDR] = &gxbb_ddr.hw,
  2582. [CLKID_DOS] = &gxbb_dos.hw,
  2583. [CLKID_ISA] = &gxbb_isa.hw,
  2584. [CLKID_PL301] = &gxbb_pl301.hw,
  2585. [CLKID_PERIPHS] = &gxbb_periphs.hw,
  2586. [CLKID_SPICC] = &gxbb_spicc.hw,
  2587. [CLKID_I2C] = &gxbb_i2c.hw,
  2588. [CLKID_SAR_ADC] = &gxbb_sar_adc.hw,
  2589. [CLKID_SMART_CARD] = &gxbb_smart_card.hw,
  2590. [CLKID_RNG0] = &gxbb_rng0.hw,
  2591. [CLKID_UART0] = &gxbb_uart0.hw,
  2592. [CLKID_SDHC] = &gxbb_sdhc.hw,
  2593. [CLKID_STREAM] = &gxbb_stream.hw,
  2594. [CLKID_ASYNC_FIFO] = &gxbb_async_fifo.hw,
  2595. [CLKID_SDIO] = &gxbb_sdio.hw,
  2596. [CLKID_ABUF] = &gxbb_abuf.hw,
  2597. [CLKID_HIU_IFACE] = &gxbb_hiu_iface.hw,
  2598. [CLKID_ASSIST_MISC] = &gxbb_assist_misc.hw,
  2599. [CLKID_SPI] = &gxbb_spi.hw,
  2600. [CLKID_I2S_SPDIF] = &gxbb_i2s_spdif.hw,
  2601. [CLKID_ETH] = &gxbb_eth.hw,
  2602. [CLKID_DEMUX] = &gxbb_demux.hw,
  2603. [CLKID_AIU_GLUE] = &gxbb_aiu_glue.hw,
  2604. [CLKID_IEC958] = &gxbb_iec958.hw,
  2605. [CLKID_I2S_OUT] = &gxbb_i2s_out.hw,
  2606. [CLKID_AMCLK] = &gxbb_amclk.hw,
  2607. [CLKID_AIFIFO2] = &gxbb_aififo2.hw,
  2608. [CLKID_MIXER] = &gxbb_mixer.hw,
  2609. [CLKID_MIXER_IFACE] = &gxbb_mixer_iface.hw,
  2610. [CLKID_ADC] = &gxbb_adc.hw,
  2611. [CLKID_BLKMV] = &gxbb_blkmv.hw,
  2612. [CLKID_AIU] = &gxbb_aiu.hw,
  2613. [CLKID_UART1] = &gxbb_uart1.hw,
  2614. [CLKID_G2D] = &gxbb_g2d.hw,
  2615. [CLKID_USB0] = &gxbb_usb0.hw,
  2616. [CLKID_USB1] = &gxbb_usb1.hw,
  2617. [CLKID_RESET] = &gxbb_reset.hw,
  2618. [CLKID_NAND] = &gxbb_nand.hw,
  2619. [CLKID_DOS_PARSER] = &gxbb_dos_parser.hw,
  2620. [CLKID_USB] = &gxbb_usb.hw,
  2621. [CLKID_VDIN1] = &gxbb_vdin1.hw,
  2622. [CLKID_AHB_ARB0] = &gxbb_ahb_arb0.hw,
  2623. [CLKID_EFUSE] = &gxbb_efuse.hw,
  2624. [CLKID_BOOT_ROM] = &gxbb_boot_rom.hw,
  2625. [CLKID_AHB_DATA_BUS] = &gxbb_ahb_data_bus.hw,
  2626. [CLKID_AHB_CTRL_BUS] = &gxbb_ahb_ctrl_bus.hw,
  2627. [CLKID_HDMI_INTR_SYNC] = &gxbb_hdmi_intr_sync.hw,
  2628. [CLKID_HDMI_PCLK] = &gxbb_hdmi_pclk.hw,
  2629. [CLKID_USB1_DDR_BRIDGE] = &gxbb_usb1_ddr_bridge.hw,
  2630. [CLKID_USB0_DDR_BRIDGE] = &gxbb_usb0_ddr_bridge.hw,
  2631. [CLKID_MMC_PCLK] = &gxbb_mmc_pclk.hw,
  2632. [CLKID_DVIN] = &gxbb_dvin.hw,
  2633. [CLKID_UART2] = &gxbb_uart2.hw,
  2634. [CLKID_SANA] = &gxbb_sana.hw,
  2635. [CLKID_VPU_INTR] = &gxbb_vpu_intr.hw,
  2636. [CLKID_SEC_AHB_AHB3_BRIDGE] = &gxbb_sec_ahb_ahb3_bridge.hw,
  2637. [CLKID_CLK81_A53] = &gxbb_clk81_a53.hw,
  2638. [CLKID_VCLK2_VENCI0] = &gxbb_vclk2_venci0.hw,
  2639. [CLKID_VCLK2_VENCI1] = &gxbb_vclk2_venci1.hw,
  2640. [CLKID_VCLK2_VENCP0] = &gxbb_vclk2_vencp0.hw,
  2641. [CLKID_VCLK2_VENCP1] = &gxbb_vclk2_vencp1.hw,
  2642. [CLKID_GCLK_VENCI_INT0] = &gxbb_gclk_venci_int0.hw,
  2643. [CLKID_GCLK_VENCI_INT] = &gxbb_gclk_vencp_int.hw,
  2644. [CLKID_DAC_CLK] = &gxbb_dac_clk.hw,
  2645. [CLKID_AOCLK_GATE] = &gxbb_aoclk_gate.hw,
  2646. [CLKID_IEC958_GATE] = &gxbb_iec958_gate.hw,
  2647. [CLKID_ENC480P] = &gxbb_enc480p.hw,
  2648. [CLKID_RNG1] = &gxbb_rng1.hw,
  2649. [CLKID_GCLK_VENCI_INT1] = &gxbb_gclk_venci_int1.hw,
  2650. [CLKID_VCLK2_VENCLMCC] = &gxbb_vclk2_venclmcc.hw,
  2651. [CLKID_VCLK2_VENCL] = &gxbb_vclk2_vencl.hw,
  2652. [CLKID_VCLK_OTHER] = &gxbb_vclk_other.hw,
  2653. [CLKID_EDP] = &gxbb_edp.hw,
  2654. [CLKID_AO_MEDIA_CPU] = &gxbb_ao_media_cpu.hw,
  2655. [CLKID_AO_AHB_SRAM] = &gxbb_ao_ahb_sram.hw,
  2656. [CLKID_AO_AHB_BUS] = &gxbb_ao_ahb_bus.hw,
  2657. [CLKID_AO_IFACE] = &gxbb_ao_iface.hw,
  2658. [CLKID_AO_I2C] = &gxbb_ao_i2c.hw,
  2659. [CLKID_SD_EMMC_A] = &gxbb_emmc_a.hw,
  2660. [CLKID_SD_EMMC_B] = &gxbb_emmc_b.hw,
  2661. [CLKID_SD_EMMC_C] = &gxbb_emmc_c.hw,
  2662. [CLKID_SAR_ADC_CLK] = &gxbb_sar_adc_clk.hw,
  2663. [CLKID_SAR_ADC_SEL] = &gxbb_sar_adc_clk_sel.hw,
  2664. [CLKID_SAR_ADC_DIV] = &gxbb_sar_adc_clk_div.hw,
  2665. [CLKID_MALI_0_SEL] = &gxbb_mali_0_sel.hw,
  2666. [CLKID_MALI_0_DIV] = &gxbb_mali_0_div.hw,
  2667. [CLKID_MALI_0] = &gxbb_mali_0.hw,
  2668. [CLKID_MALI_1_SEL] = &gxbb_mali_1_sel.hw,
  2669. [CLKID_MALI_1_DIV] = &gxbb_mali_1_div.hw,
  2670. [CLKID_MALI_1] = &gxbb_mali_1.hw,
  2671. [CLKID_MALI] = &gxbb_mali.hw,
  2672. [CLKID_CTS_AMCLK] = &gxbb_cts_amclk.hw,
  2673. [CLKID_CTS_AMCLK_SEL] = &gxbb_cts_amclk_sel.hw,
  2674. [CLKID_CTS_AMCLK_DIV] = &gxbb_cts_amclk_div.hw,
  2675. [CLKID_CTS_MCLK_I958] = &gxbb_cts_mclk_i958.hw,
  2676. [CLKID_CTS_MCLK_I958_SEL] = &gxbb_cts_mclk_i958_sel.hw,
  2677. [CLKID_CTS_MCLK_I958_DIV] = &gxbb_cts_mclk_i958_div.hw,
  2678. [CLKID_CTS_I958] = &gxbb_cts_i958.hw,
  2679. [CLKID_32K_CLK] = &gxbb_32k_clk.hw,
  2680. [CLKID_32K_CLK_SEL] = &gxbb_32k_clk_sel.hw,
  2681. [CLKID_32K_CLK_DIV] = &gxbb_32k_clk_div.hw,
  2682. [CLKID_SD_EMMC_A_CLK0_SEL] = &gxbb_sd_emmc_a_clk0_sel.hw,
  2683. [CLKID_SD_EMMC_A_CLK0_DIV] = &gxbb_sd_emmc_a_clk0_div.hw,
  2684. [CLKID_SD_EMMC_A_CLK0] = &gxbb_sd_emmc_a_clk0.hw,
  2685. [CLKID_SD_EMMC_B_CLK0_SEL] = &gxbb_sd_emmc_b_clk0_sel.hw,
  2686. [CLKID_SD_EMMC_B_CLK0_DIV] = &gxbb_sd_emmc_b_clk0_div.hw,
  2687. [CLKID_SD_EMMC_B_CLK0] = &gxbb_sd_emmc_b_clk0.hw,
  2688. [CLKID_SD_EMMC_C_CLK0_SEL] = &gxbb_sd_emmc_c_clk0_sel.hw,
  2689. [CLKID_SD_EMMC_C_CLK0_DIV] = &gxbb_sd_emmc_c_clk0_div.hw,
  2690. [CLKID_SD_EMMC_C_CLK0] = &gxbb_sd_emmc_c_clk0.hw,
  2691. [CLKID_VPU_0_SEL] = &gxbb_vpu_0_sel.hw,
  2692. [CLKID_VPU_0_DIV] = &gxbb_vpu_0_div.hw,
  2693. [CLKID_VPU_0] = &gxbb_vpu_0.hw,
  2694. [CLKID_VPU_1_SEL] = &gxbb_vpu_1_sel.hw,
  2695. [CLKID_VPU_1_DIV] = &gxbb_vpu_1_div.hw,
  2696. [CLKID_VPU_1] = &gxbb_vpu_1.hw,
  2697. [CLKID_VPU] = &gxbb_vpu.hw,
  2698. [CLKID_VAPB_0_SEL] = &gxbb_vapb_0_sel.hw,
  2699. [CLKID_VAPB_0_DIV] = &gxbb_vapb_0_div.hw,
  2700. [CLKID_VAPB_0] = &gxbb_vapb_0.hw,
  2701. [CLKID_VAPB_1_SEL] = &gxbb_vapb_1_sel.hw,
  2702. [CLKID_VAPB_1_DIV] = &gxbb_vapb_1_div.hw,
  2703. [CLKID_VAPB_1] = &gxbb_vapb_1.hw,
  2704. [CLKID_VAPB_SEL] = &gxbb_vapb_sel.hw,
  2705. [CLKID_VAPB] = &gxbb_vapb.hw,
  2706. [CLKID_HDMI_PLL_PRE_MULT] = &gxbb_hdmi_pll_pre_mult.hw,
  2707. [CLKID_MPLL0_DIV] = &gxbb_mpll0_div.hw,
  2708. [CLKID_MPLL1_DIV] = &gxbb_mpll1_div.hw,
  2709. [CLKID_MPLL2_DIV] = &gxbb_mpll2_div.hw,
  2710. [CLKID_MPLL_PREDIV] = &gxbb_mpll_prediv.hw,
  2711. [CLKID_FCLK_DIV2_DIV] = &gxbb_fclk_div2_div.hw,
  2712. [CLKID_FCLK_DIV3_DIV] = &gxbb_fclk_div3_div.hw,
  2713. [CLKID_FCLK_DIV4_DIV] = &gxbb_fclk_div4_div.hw,
  2714. [CLKID_FCLK_DIV5_DIV] = &gxbb_fclk_div5_div.hw,
  2715. [CLKID_FCLK_DIV7_DIV] = &gxbb_fclk_div7_div.hw,
  2716. [CLKID_VDEC_1_SEL] = &gxbb_vdec_1_sel.hw,
  2717. [CLKID_VDEC_1_DIV] = &gxbb_vdec_1_div.hw,
  2718. [CLKID_VDEC_1] = &gxbb_vdec_1.hw,
  2719. [CLKID_VDEC_HEVC_SEL] = &gxbb_vdec_hevc_sel.hw,
  2720. [CLKID_VDEC_HEVC_DIV] = &gxbb_vdec_hevc_div.hw,
  2721. [CLKID_VDEC_HEVC] = &gxbb_vdec_hevc.hw,
  2722. [CLKID_GEN_CLK_SEL] = &gxbb_gen_clk_sel.hw,
  2723. [CLKID_GEN_CLK_DIV] = &gxbb_gen_clk_div.hw,
  2724. [CLKID_GEN_CLK] = &gxbb_gen_clk.hw,
  2725. [CLKID_FIXED_PLL_DCO] = &gxbb_fixed_pll_dco.hw,
  2726. [CLKID_HDMI_PLL_DCO] = &gxbb_hdmi_pll_dco.hw,
  2727. [CLKID_HDMI_PLL_OD] = &gxbb_hdmi_pll_od.hw,
  2728. [CLKID_HDMI_PLL_OD2] = &gxbb_hdmi_pll_od2.hw,
  2729. [CLKID_SYS_PLL_DCO] = &gxbb_sys_pll_dco.hw,
  2730. [CLKID_GP0_PLL_DCO] = &gxbb_gp0_pll_dco.hw,
  2731. [CLKID_VID_PLL_DIV] = &gxbb_vid_pll_div.hw,
  2732. [CLKID_VID_PLL_SEL] = &gxbb_vid_pll_sel.hw,
  2733. [CLKID_VID_PLL] = &gxbb_vid_pll.hw,
  2734. [CLKID_VCLK_SEL] = &gxbb_vclk_sel.hw,
  2735. [CLKID_VCLK2_SEL] = &gxbb_vclk2_sel.hw,
  2736. [CLKID_VCLK_INPUT] = &gxbb_vclk_input.hw,
  2737. [CLKID_VCLK2_INPUT] = &gxbb_vclk2_input.hw,
  2738. [CLKID_VCLK_DIV] = &gxbb_vclk_div.hw,
  2739. [CLKID_VCLK2_DIV] = &gxbb_vclk2_div.hw,
  2740. [CLKID_VCLK] = &gxbb_vclk.hw,
  2741. [CLKID_VCLK2] = &gxbb_vclk2.hw,
  2742. [CLKID_VCLK_DIV1] = &gxbb_vclk_div1.hw,
  2743. [CLKID_VCLK_DIV2_EN] = &gxbb_vclk_div2_en.hw,
  2744. [CLKID_VCLK_DIV2] = &gxbb_vclk_div2.hw,
  2745. [CLKID_VCLK_DIV4_EN] = &gxbb_vclk_div4_en.hw,
  2746. [CLKID_VCLK_DIV4] = &gxbb_vclk_div4.hw,
  2747. [CLKID_VCLK_DIV6_EN] = &gxbb_vclk_div6_en.hw,
  2748. [CLKID_VCLK_DIV6] = &gxbb_vclk_div6.hw,
  2749. [CLKID_VCLK_DIV12_EN] = &gxbb_vclk_div12_en.hw,
  2750. [CLKID_VCLK_DIV12] = &gxbb_vclk_div12.hw,
  2751. [CLKID_VCLK2_DIV1] = &gxbb_vclk2_div1.hw,
  2752. [CLKID_VCLK2_DIV2_EN] = &gxbb_vclk2_div2_en.hw,
  2753. [CLKID_VCLK2_DIV2] = &gxbb_vclk2_div2.hw,
  2754. [CLKID_VCLK2_DIV4_EN] = &gxbb_vclk2_div4_en.hw,
  2755. [CLKID_VCLK2_DIV4] = &gxbb_vclk2_div4.hw,
  2756. [CLKID_VCLK2_DIV6_EN] = &gxbb_vclk2_div6_en.hw,
  2757. [CLKID_VCLK2_DIV6] = &gxbb_vclk2_div6.hw,
  2758. [CLKID_VCLK2_DIV12_EN] = &gxbb_vclk2_div12_en.hw,
  2759. [CLKID_VCLK2_DIV12] = &gxbb_vclk2_div12.hw,
  2760. [CLKID_CTS_ENCI_SEL] = &gxbb_cts_enci_sel.hw,
  2761. [CLKID_CTS_ENCP_SEL] = &gxbb_cts_encp_sel.hw,
  2762. [CLKID_CTS_VDAC_SEL] = &gxbb_cts_vdac_sel.hw,
  2763. [CLKID_HDMI_TX_SEL] = &gxbb_hdmi_tx_sel.hw,
  2764. [CLKID_CTS_ENCI] = &gxbb_cts_enci.hw,
  2765. [CLKID_CTS_ENCP] = &gxbb_cts_encp.hw,
  2766. [CLKID_CTS_VDAC] = &gxbb_cts_vdac.hw,
  2767. [CLKID_HDMI_TX] = &gxbb_hdmi_tx.hw,
  2768. [CLKID_HDMI_SEL] = &gxbb_hdmi_sel.hw,
  2769. [CLKID_HDMI_DIV] = &gxbb_hdmi_div.hw,
  2770. [CLKID_HDMI] = &gxbb_hdmi.hw,
  2771. };
  2772. static struct clk_hw *gxl_hw_clks[] = {
  2773. [CLKID_SYS_PLL] = &gxbb_sys_pll.hw,
  2774. [CLKID_HDMI_PLL] = &gxl_hdmi_pll.hw,
  2775. [CLKID_FIXED_PLL] = &gxbb_fixed_pll.hw,
  2776. [CLKID_FCLK_DIV2] = &gxbb_fclk_div2.hw,
  2777. [CLKID_FCLK_DIV3] = &gxbb_fclk_div3.hw,
  2778. [CLKID_FCLK_DIV4] = &gxbb_fclk_div4.hw,
  2779. [CLKID_FCLK_DIV5] = &gxbb_fclk_div5.hw,
  2780. [CLKID_FCLK_DIV7] = &gxbb_fclk_div7.hw,
  2781. [CLKID_GP0_PLL] = &gxbb_gp0_pll.hw,
  2782. [CLKID_MPEG_SEL] = &gxbb_mpeg_clk_sel.hw,
  2783. [CLKID_MPEG_DIV] = &gxbb_mpeg_clk_div.hw,
  2784. [CLKID_CLK81] = &gxbb_clk81.hw,
  2785. [CLKID_MPLL0] = &gxbb_mpll0.hw,
  2786. [CLKID_MPLL1] = &gxbb_mpll1.hw,
  2787. [CLKID_MPLL2] = &gxbb_mpll2.hw,
  2788. [CLKID_DDR] = &gxbb_ddr.hw,
  2789. [CLKID_DOS] = &gxbb_dos.hw,
  2790. [CLKID_ISA] = &gxbb_isa.hw,
  2791. [CLKID_PL301] = &gxbb_pl301.hw,
  2792. [CLKID_PERIPHS] = &gxbb_periphs.hw,
  2793. [CLKID_SPICC] = &gxbb_spicc.hw,
  2794. [CLKID_I2C] = &gxbb_i2c.hw,
  2795. [CLKID_SAR_ADC] = &gxbb_sar_adc.hw,
  2796. [CLKID_SMART_CARD] = &gxbb_smart_card.hw,
  2797. [CLKID_RNG0] = &gxbb_rng0.hw,
  2798. [CLKID_UART0] = &gxbb_uart0.hw,
  2799. [CLKID_SDHC] = &gxbb_sdhc.hw,
  2800. [CLKID_STREAM] = &gxbb_stream.hw,
  2801. [CLKID_ASYNC_FIFO] = &gxbb_async_fifo.hw,
  2802. [CLKID_SDIO] = &gxbb_sdio.hw,
  2803. [CLKID_ABUF] = &gxbb_abuf.hw,
  2804. [CLKID_HIU_IFACE] = &gxbb_hiu_iface.hw,
  2805. [CLKID_ASSIST_MISC] = &gxbb_assist_misc.hw,
  2806. [CLKID_SPI] = &gxbb_spi.hw,
  2807. [CLKID_I2S_SPDIF] = &gxbb_i2s_spdif.hw,
  2808. [CLKID_ETH] = &gxbb_eth.hw,
  2809. [CLKID_DEMUX] = &gxbb_demux.hw,
  2810. [CLKID_AIU_GLUE] = &gxbb_aiu_glue.hw,
  2811. [CLKID_IEC958] = &gxbb_iec958.hw,
  2812. [CLKID_I2S_OUT] = &gxbb_i2s_out.hw,
  2813. [CLKID_AMCLK] = &gxbb_amclk.hw,
  2814. [CLKID_AIFIFO2] = &gxbb_aififo2.hw,
  2815. [CLKID_MIXER] = &gxbb_mixer.hw,
  2816. [CLKID_MIXER_IFACE] = &gxbb_mixer_iface.hw,
  2817. [CLKID_ADC] = &gxbb_adc.hw,
  2818. [CLKID_BLKMV] = &gxbb_blkmv.hw,
  2819. [CLKID_AIU] = &gxbb_aiu.hw,
  2820. [CLKID_UART1] = &gxbb_uart1.hw,
  2821. [CLKID_G2D] = &gxbb_g2d.hw,
  2822. [CLKID_USB0] = &gxbb_usb0.hw,
  2823. [CLKID_USB1] = &gxbb_usb1.hw,
  2824. [CLKID_RESET] = &gxbb_reset.hw,
  2825. [CLKID_NAND] = &gxbb_nand.hw,
  2826. [CLKID_DOS_PARSER] = &gxbb_dos_parser.hw,
  2827. [CLKID_USB] = &gxbb_usb.hw,
  2828. [CLKID_VDIN1] = &gxbb_vdin1.hw,
  2829. [CLKID_AHB_ARB0] = &gxbb_ahb_arb0.hw,
  2830. [CLKID_EFUSE] = &gxbb_efuse.hw,
  2831. [CLKID_BOOT_ROM] = &gxbb_boot_rom.hw,
  2832. [CLKID_AHB_DATA_BUS] = &gxbb_ahb_data_bus.hw,
  2833. [CLKID_AHB_CTRL_BUS] = &gxbb_ahb_ctrl_bus.hw,
  2834. [CLKID_HDMI_INTR_SYNC] = &gxbb_hdmi_intr_sync.hw,
  2835. [CLKID_HDMI_PCLK] = &gxbb_hdmi_pclk.hw,
  2836. [CLKID_USB1_DDR_BRIDGE] = &gxbb_usb1_ddr_bridge.hw,
  2837. [CLKID_USB0_DDR_BRIDGE] = &gxbb_usb0_ddr_bridge.hw,
  2838. [CLKID_MMC_PCLK] = &gxbb_mmc_pclk.hw,
  2839. [CLKID_DVIN] = &gxbb_dvin.hw,
  2840. [CLKID_UART2] = &gxbb_uart2.hw,
  2841. [CLKID_SANA] = &gxbb_sana.hw,
  2842. [CLKID_VPU_INTR] = &gxbb_vpu_intr.hw,
  2843. [CLKID_SEC_AHB_AHB3_BRIDGE] = &gxbb_sec_ahb_ahb3_bridge.hw,
  2844. [CLKID_CLK81_A53] = &gxbb_clk81_a53.hw,
  2845. [CLKID_VCLK2_VENCI0] = &gxbb_vclk2_venci0.hw,
  2846. [CLKID_VCLK2_VENCI1] = &gxbb_vclk2_venci1.hw,
  2847. [CLKID_VCLK2_VENCP0] = &gxbb_vclk2_vencp0.hw,
  2848. [CLKID_VCLK2_VENCP1] = &gxbb_vclk2_vencp1.hw,
  2849. [CLKID_GCLK_VENCI_INT0] = &gxbb_gclk_venci_int0.hw,
  2850. [CLKID_GCLK_VENCI_INT] = &gxbb_gclk_vencp_int.hw,
  2851. [CLKID_DAC_CLK] = &gxbb_dac_clk.hw,
  2852. [CLKID_AOCLK_GATE] = &gxbb_aoclk_gate.hw,
  2853. [CLKID_IEC958_GATE] = &gxbb_iec958_gate.hw,
  2854. [CLKID_ENC480P] = &gxbb_enc480p.hw,
  2855. [CLKID_RNG1] = &gxbb_rng1.hw,
  2856. [CLKID_GCLK_VENCI_INT1] = &gxbb_gclk_venci_int1.hw,
  2857. [CLKID_VCLK2_VENCLMCC] = &gxbb_vclk2_venclmcc.hw,
  2858. [CLKID_VCLK2_VENCL] = &gxbb_vclk2_vencl.hw,
  2859. [CLKID_VCLK_OTHER] = &gxbb_vclk_other.hw,
  2860. [CLKID_EDP] = &gxbb_edp.hw,
  2861. [CLKID_AO_MEDIA_CPU] = &gxbb_ao_media_cpu.hw,
  2862. [CLKID_AO_AHB_SRAM] = &gxbb_ao_ahb_sram.hw,
  2863. [CLKID_AO_AHB_BUS] = &gxbb_ao_ahb_bus.hw,
  2864. [CLKID_AO_IFACE] = &gxbb_ao_iface.hw,
  2865. [CLKID_AO_I2C] = &gxbb_ao_i2c.hw,
  2866. [CLKID_SD_EMMC_A] = &gxbb_emmc_a.hw,
  2867. [CLKID_SD_EMMC_B] = &gxbb_emmc_b.hw,
  2868. [CLKID_SD_EMMC_C] = &gxbb_emmc_c.hw,
  2869. [CLKID_SAR_ADC_CLK] = &gxbb_sar_adc_clk.hw,
  2870. [CLKID_SAR_ADC_SEL] = &gxbb_sar_adc_clk_sel.hw,
  2871. [CLKID_SAR_ADC_DIV] = &gxbb_sar_adc_clk_div.hw,
  2872. [CLKID_MALI_0_SEL] = &gxbb_mali_0_sel.hw,
  2873. [CLKID_MALI_0_DIV] = &gxbb_mali_0_div.hw,
  2874. [CLKID_MALI_0] = &gxbb_mali_0.hw,
  2875. [CLKID_MALI_1_SEL] = &gxbb_mali_1_sel.hw,
  2876. [CLKID_MALI_1_DIV] = &gxbb_mali_1_div.hw,
  2877. [CLKID_MALI_1] = &gxbb_mali_1.hw,
  2878. [CLKID_MALI] = &gxbb_mali.hw,
  2879. [CLKID_CTS_AMCLK] = &gxbb_cts_amclk.hw,
  2880. [CLKID_CTS_AMCLK_SEL] = &gxbb_cts_amclk_sel.hw,
  2881. [CLKID_CTS_AMCLK_DIV] = &gxbb_cts_amclk_div.hw,
  2882. [CLKID_CTS_MCLK_I958] = &gxbb_cts_mclk_i958.hw,
  2883. [CLKID_CTS_MCLK_I958_SEL] = &gxbb_cts_mclk_i958_sel.hw,
  2884. [CLKID_CTS_MCLK_I958_DIV] = &gxbb_cts_mclk_i958_div.hw,
  2885. [CLKID_CTS_I958] = &gxbb_cts_i958.hw,
  2886. [CLKID_32K_CLK] = &gxbb_32k_clk.hw,
  2887. [CLKID_32K_CLK_SEL] = &gxbb_32k_clk_sel.hw,
  2888. [CLKID_32K_CLK_DIV] = &gxbb_32k_clk_div.hw,
  2889. [CLKID_SD_EMMC_A_CLK0_SEL] = &gxbb_sd_emmc_a_clk0_sel.hw,
  2890. [CLKID_SD_EMMC_A_CLK0_DIV] = &gxbb_sd_emmc_a_clk0_div.hw,
  2891. [CLKID_SD_EMMC_A_CLK0] = &gxbb_sd_emmc_a_clk0.hw,
  2892. [CLKID_SD_EMMC_B_CLK0_SEL] = &gxbb_sd_emmc_b_clk0_sel.hw,
  2893. [CLKID_SD_EMMC_B_CLK0_DIV] = &gxbb_sd_emmc_b_clk0_div.hw,
  2894. [CLKID_SD_EMMC_B_CLK0] = &gxbb_sd_emmc_b_clk0.hw,
  2895. [CLKID_SD_EMMC_C_CLK0_SEL] = &gxbb_sd_emmc_c_clk0_sel.hw,
  2896. [CLKID_SD_EMMC_C_CLK0_DIV] = &gxbb_sd_emmc_c_clk0_div.hw,
  2897. [CLKID_SD_EMMC_C_CLK0] = &gxbb_sd_emmc_c_clk0.hw,
  2898. [CLKID_VPU_0_SEL] = &gxbb_vpu_0_sel.hw,
  2899. [CLKID_VPU_0_DIV] = &gxbb_vpu_0_div.hw,
  2900. [CLKID_VPU_0] = &gxbb_vpu_0.hw,
  2901. [CLKID_VPU_1_SEL] = &gxbb_vpu_1_sel.hw,
  2902. [CLKID_VPU_1_DIV] = &gxbb_vpu_1_div.hw,
  2903. [CLKID_VPU_1] = &gxbb_vpu_1.hw,
  2904. [CLKID_VPU] = &gxbb_vpu.hw,
  2905. [CLKID_VAPB_0_SEL] = &gxbb_vapb_0_sel.hw,
  2906. [CLKID_VAPB_0_DIV] = &gxbb_vapb_0_div.hw,
  2907. [CLKID_VAPB_0] = &gxbb_vapb_0.hw,
  2908. [CLKID_VAPB_1_SEL] = &gxbb_vapb_1_sel.hw,
  2909. [CLKID_VAPB_1_DIV] = &gxbb_vapb_1_div.hw,
  2910. [CLKID_VAPB_1] = &gxbb_vapb_1.hw,
  2911. [CLKID_VAPB_SEL] = &gxbb_vapb_sel.hw,
  2912. [CLKID_VAPB] = &gxbb_vapb.hw,
  2913. [CLKID_MPLL0_DIV] = &gxl_mpll0_div.hw,
  2914. [CLKID_MPLL1_DIV] = &gxbb_mpll1_div.hw,
  2915. [CLKID_MPLL2_DIV] = &gxbb_mpll2_div.hw,
  2916. [CLKID_MPLL_PREDIV] = &gxbb_mpll_prediv.hw,
  2917. [CLKID_FCLK_DIV2_DIV] = &gxbb_fclk_div2_div.hw,
  2918. [CLKID_FCLK_DIV3_DIV] = &gxbb_fclk_div3_div.hw,
  2919. [CLKID_FCLK_DIV4_DIV] = &gxbb_fclk_div4_div.hw,
  2920. [CLKID_FCLK_DIV5_DIV] = &gxbb_fclk_div5_div.hw,
  2921. [CLKID_FCLK_DIV7_DIV] = &gxbb_fclk_div7_div.hw,
  2922. [CLKID_VDEC_1_SEL] = &gxbb_vdec_1_sel.hw,
  2923. [CLKID_VDEC_1_DIV] = &gxbb_vdec_1_div.hw,
  2924. [CLKID_VDEC_1] = &gxbb_vdec_1.hw,
  2925. [CLKID_VDEC_HEVC_SEL] = &gxbb_vdec_hevc_sel.hw,
  2926. [CLKID_VDEC_HEVC_DIV] = &gxbb_vdec_hevc_div.hw,
  2927. [CLKID_VDEC_HEVC] = &gxbb_vdec_hevc.hw,
  2928. [CLKID_GEN_CLK_SEL] = &gxbb_gen_clk_sel.hw,
  2929. [CLKID_GEN_CLK_DIV] = &gxbb_gen_clk_div.hw,
  2930. [CLKID_GEN_CLK] = &gxbb_gen_clk.hw,
  2931. [CLKID_FIXED_PLL_DCO] = &gxbb_fixed_pll_dco.hw,
  2932. [CLKID_HDMI_PLL_DCO] = &gxl_hdmi_pll_dco.hw,
  2933. [CLKID_HDMI_PLL_OD] = &gxl_hdmi_pll_od.hw,
  2934. [CLKID_HDMI_PLL_OD2] = &gxl_hdmi_pll_od2.hw,
  2935. [CLKID_SYS_PLL_DCO] = &gxbb_sys_pll_dco.hw,
  2936. [CLKID_GP0_PLL_DCO] = &gxl_gp0_pll_dco.hw,
  2937. [CLKID_VID_PLL_DIV] = &gxbb_vid_pll_div.hw,
  2938. [CLKID_VID_PLL_SEL] = &gxbb_vid_pll_sel.hw,
  2939. [CLKID_VID_PLL] = &gxbb_vid_pll.hw,
  2940. [CLKID_VCLK_SEL] = &gxbb_vclk_sel.hw,
  2941. [CLKID_VCLK2_SEL] = &gxbb_vclk2_sel.hw,
  2942. [CLKID_VCLK_INPUT] = &gxbb_vclk_input.hw,
  2943. [CLKID_VCLK2_INPUT] = &gxbb_vclk2_input.hw,
  2944. [CLKID_VCLK_DIV] = &gxbb_vclk_div.hw,
  2945. [CLKID_VCLK2_DIV] = &gxbb_vclk2_div.hw,
  2946. [CLKID_VCLK] = &gxbb_vclk.hw,
  2947. [CLKID_VCLK2] = &gxbb_vclk2.hw,
  2948. [CLKID_VCLK_DIV1] = &gxbb_vclk_div1.hw,
  2949. [CLKID_VCLK_DIV2_EN] = &gxbb_vclk_div2_en.hw,
  2950. [CLKID_VCLK_DIV2] = &gxbb_vclk_div2.hw,
  2951. [CLKID_VCLK_DIV4_EN] = &gxbb_vclk_div4_en.hw,
  2952. [CLKID_VCLK_DIV4] = &gxbb_vclk_div4.hw,
  2953. [CLKID_VCLK_DIV6_EN] = &gxbb_vclk_div6_en.hw,
  2954. [CLKID_VCLK_DIV6] = &gxbb_vclk_div6.hw,
  2955. [CLKID_VCLK_DIV12_EN] = &gxbb_vclk_div12_en.hw,
  2956. [CLKID_VCLK_DIV12] = &gxbb_vclk_div12.hw,
  2957. [CLKID_VCLK2_DIV1] = &gxbb_vclk2_div1.hw,
  2958. [CLKID_VCLK2_DIV2_EN] = &gxbb_vclk2_div2_en.hw,
  2959. [CLKID_VCLK2_DIV2] = &gxbb_vclk2_div2.hw,
  2960. [CLKID_VCLK2_DIV4_EN] = &gxbb_vclk2_div4_en.hw,
  2961. [CLKID_VCLK2_DIV4] = &gxbb_vclk2_div4.hw,
  2962. [CLKID_VCLK2_DIV6_EN] = &gxbb_vclk2_div6_en.hw,
  2963. [CLKID_VCLK2_DIV6] = &gxbb_vclk2_div6.hw,
  2964. [CLKID_VCLK2_DIV12_EN] = &gxbb_vclk2_div12_en.hw,
  2965. [CLKID_VCLK2_DIV12] = &gxbb_vclk2_div12.hw,
  2966. [CLKID_CTS_ENCI_SEL] = &gxbb_cts_enci_sel.hw,
  2967. [CLKID_CTS_ENCP_SEL] = &gxbb_cts_encp_sel.hw,
  2968. [CLKID_CTS_VDAC_SEL] = &gxbb_cts_vdac_sel.hw,
  2969. [CLKID_HDMI_TX_SEL] = &gxbb_hdmi_tx_sel.hw,
  2970. [CLKID_CTS_ENCI] = &gxbb_cts_enci.hw,
  2971. [CLKID_CTS_ENCP] = &gxbb_cts_encp.hw,
  2972. [CLKID_CTS_VDAC] = &gxbb_cts_vdac.hw,
  2973. [CLKID_HDMI_TX] = &gxbb_hdmi_tx.hw,
  2974. [CLKID_HDMI_SEL] = &gxbb_hdmi_sel.hw,
  2975. [CLKID_HDMI_DIV] = &gxbb_hdmi_div.hw,
  2976. [CLKID_HDMI] = &gxbb_hdmi.hw,
  2977. [CLKID_ACODEC] = &gxl_acodec.hw,
  2978. };
  2979. static struct clk_regmap *const gxbb_clk_regmaps[] = {
  2980. &gxbb_clk81,
  2981. &gxbb_ddr,
  2982. &gxbb_dos,
  2983. &gxbb_isa,
  2984. &gxbb_pl301,
  2985. &gxbb_periphs,
  2986. &gxbb_spicc,
  2987. &gxbb_i2c,
  2988. &gxbb_sar_adc,
  2989. &gxbb_smart_card,
  2990. &gxbb_rng0,
  2991. &gxbb_uart0,
  2992. &gxbb_sdhc,
  2993. &gxbb_stream,
  2994. &gxbb_async_fifo,
  2995. &gxbb_sdio,
  2996. &gxbb_abuf,
  2997. &gxbb_hiu_iface,
  2998. &gxbb_assist_misc,
  2999. &gxbb_spi,
  3000. &gxbb_i2s_spdif,
  3001. &gxbb_eth,
  3002. &gxbb_demux,
  3003. &gxbb_aiu_glue,
  3004. &gxbb_iec958,
  3005. &gxbb_i2s_out,
  3006. &gxbb_amclk,
  3007. &gxbb_aififo2,
  3008. &gxbb_mixer,
  3009. &gxbb_mixer_iface,
  3010. &gxbb_adc,
  3011. &gxbb_blkmv,
  3012. &gxbb_aiu,
  3013. &gxbb_uart1,
  3014. &gxbb_g2d,
  3015. &gxbb_usb0,
  3016. &gxbb_usb1,
  3017. &gxbb_reset,
  3018. &gxbb_nand,
  3019. &gxbb_dos_parser,
  3020. &gxbb_usb,
  3021. &gxbb_vdin1,
  3022. &gxbb_ahb_arb0,
  3023. &gxbb_efuse,
  3024. &gxbb_boot_rom,
  3025. &gxbb_ahb_data_bus,
  3026. &gxbb_ahb_ctrl_bus,
  3027. &gxbb_hdmi_intr_sync,
  3028. &gxbb_hdmi_pclk,
  3029. &gxbb_usb1_ddr_bridge,
  3030. &gxbb_usb0_ddr_bridge,
  3031. &gxbb_mmc_pclk,
  3032. &gxbb_dvin,
  3033. &gxbb_uart2,
  3034. &gxbb_sana,
  3035. &gxbb_vpu_intr,
  3036. &gxbb_sec_ahb_ahb3_bridge,
  3037. &gxbb_clk81_a53,
  3038. &gxbb_vclk2_venci0,
  3039. &gxbb_vclk2_venci1,
  3040. &gxbb_vclk2_vencp0,
  3041. &gxbb_vclk2_vencp1,
  3042. &gxbb_gclk_venci_int0,
  3043. &gxbb_gclk_vencp_int,
  3044. &gxbb_dac_clk,
  3045. &gxbb_aoclk_gate,
  3046. &gxbb_iec958_gate,
  3047. &gxbb_enc480p,
  3048. &gxbb_rng1,
  3049. &gxbb_gclk_venci_int1,
  3050. &gxbb_vclk2_venclmcc,
  3051. &gxbb_vclk2_vencl,
  3052. &gxbb_vclk_other,
  3053. &gxbb_edp,
  3054. &gxbb_ao_media_cpu,
  3055. &gxbb_ao_ahb_sram,
  3056. &gxbb_ao_ahb_bus,
  3057. &gxbb_ao_iface,
  3058. &gxbb_ao_i2c,
  3059. &gxbb_emmc_a,
  3060. &gxbb_emmc_b,
  3061. &gxbb_emmc_c,
  3062. &gxbb_sar_adc_clk,
  3063. &gxbb_mali_0,
  3064. &gxbb_mali_1,
  3065. &gxbb_cts_amclk,
  3066. &gxbb_cts_mclk_i958,
  3067. &gxbb_32k_clk,
  3068. &gxbb_sd_emmc_a_clk0,
  3069. &gxbb_sd_emmc_b_clk0,
  3070. &gxbb_sd_emmc_c_clk0,
  3071. &gxbb_vpu_0,
  3072. &gxbb_vpu_1,
  3073. &gxbb_vapb_0,
  3074. &gxbb_vapb_1,
  3075. &gxbb_vapb,
  3076. &gxbb_mpeg_clk_div,
  3077. &gxbb_sar_adc_clk_div,
  3078. &gxbb_mali_0_div,
  3079. &gxbb_mali_1_div,
  3080. &gxbb_cts_mclk_i958_div,
  3081. &gxbb_32k_clk_div,
  3082. &gxbb_sd_emmc_a_clk0_div,
  3083. &gxbb_sd_emmc_b_clk0_div,
  3084. &gxbb_sd_emmc_c_clk0_div,
  3085. &gxbb_vpu_0_div,
  3086. &gxbb_vpu_1_div,
  3087. &gxbb_vapb_0_div,
  3088. &gxbb_vapb_1_div,
  3089. &gxbb_mpeg_clk_sel,
  3090. &gxbb_sar_adc_clk_sel,
  3091. &gxbb_mali_0_sel,
  3092. &gxbb_mali_1_sel,
  3093. &gxbb_mali,
  3094. &gxbb_cts_amclk_sel,
  3095. &gxbb_cts_mclk_i958_sel,
  3096. &gxbb_cts_i958,
  3097. &gxbb_32k_clk_sel,
  3098. &gxbb_sd_emmc_a_clk0_sel,
  3099. &gxbb_sd_emmc_b_clk0_sel,
  3100. &gxbb_sd_emmc_c_clk0_sel,
  3101. &gxbb_vpu_0_sel,
  3102. &gxbb_vpu_1_sel,
  3103. &gxbb_vpu,
  3104. &gxbb_vapb_0_sel,
  3105. &gxbb_vapb_1_sel,
  3106. &gxbb_vapb_sel,
  3107. &gxbb_mpll0,
  3108. &gxbb_mpll1,
  3109. &gxbb_mpll2,
  3110. &gxbb_mpll0_div,
  3111. &gxbb_mpll1_div,
  3112. &gxbb_mpll2_div,
  3113. &gxbb_cts_amclk_div,
  3114. &gxbb_fixed_pll,
  3115. &gxbb_sys_pll,
  3116. &gxbb_mpll_prediv,
  3117. &gxbb_fclk_div2,
  3118. &gxbb_fclk_div3,
  3119. &gxbb_fclk_div4,
  3120. &gxbb_fclk_div5,
  3121. &gxbb_fclk_div7,
  3122. &gxbb_vdec_1_sel,
  3123. &gxbb_vdec_1_div,
  3124. &gxbb_vdec_1,
  3125. &gxbb_vdec_hevc_sel,
  3126. &gxbb_vdec_hevc_div,
  3127. &gxbb_vdec_hevc,
  3128. &gxbb_gen_clk_sel,
  3129. &gxbb_gen_clk_div,
  3130. &gxbb_gen_clk,
  3131. &gxbb_fixed_pll_dco,
  3132. &gxbb_sys_pll_dco,
  3133. &gxbb_gp0_pll,
  3134. &gxbb_vid_pll,
  3135. &gxbb_vid_pll_sel,
  3136. &gxbb_vid_pll_div,
  3137. &gxbb_vclk,
  3138. &gxbb_vclk_sel,
  3139. &gxbb_vclk_div,
  3140. &gxbb_vclk_input,
  3141. &gxbb_vclk_div1,
  3142. &gxbb_vclk_div2_en,
  3143. &gxbb_vclk_div4_en,
  3144. &gxbb_vclk_div6_en,
  3145. &gxbb_vclk_div12_en,
  3146. &gxbb_vclk2,
  3147. &gxbb_vclk2_sel,
  3148. &gxbb_vclk2_div,
  3149. &gxbb_vclk2_input,
  3150. &gxbb_vclk2_div1,
  3151. &gxbb_vclk2_div2_en,
  3152. &gxbb_vclk2_div4_en,
  3153. &gxbb_vclk2_div6_en,
  3154. &gxbb_vclk2_div12_en,
  3155. &gxbb_cts_enci,
  3156. &gxbb_cts_enci_sel,
  3157. &gxbb_cts_encp,
  3158. &gxbb_cts_encp_sel,
  3159. &gxbb_cts_vdac,
  3160. &gxbb_cts_vdac_sel,
  3161. &gxbb_hdmi_tx,
  3162. &gxbb_hdmi_tx_sel,
  3163. &gxbb_hdmi_sel,
  3164. &gxbb_hdmi_div,
  3165. &gxbb_hdmi,
  3166. &gxbb_gp0_pll_dco,
  3167. &gxbb_hdmi_pll,
  3168. &gxbb_hdmi_pll_od,
  3169. &gxbb_hdmi_pll_od2,
  3170. &gxbb_hdmi_pll_dco,
  3171. };
  3172. static struct clk_regmap *const gxl_clk_regmaps[] = {
  3173. &gxbb_clk81,
  3174. &gxbb_ddr,
  3175. &gxbb_dos,
  3176. &gxbb_isa,
  3177. &gxbb_pl301,
  3178. &gxbb_periphs,
  3179. &gxbb_spicc,
  3180. &gxbb_i2c,
  3181. &gxbb_sar_adc,
  3182. &gxbb_smart_card,
  3183. &gxbb_rng0,
  3184. &gxbb_uart0,
  3185. &gxbb_sdhc,
  3186. &gxbb_stream,
  3187. &gxbb_async_fifo,
  3188. &gxbb_sdio,
  3189. &gxbb_abuf,
  3190. &gxbb_hiu_iface,
  3191. &gxbb_assist_misc,
  3192. &gxbb_spi,
  3193. &gxbb_i2s_spdif,
  3194. &gxbb_eth,
  3195. &gxbb_demux,
  3196. &gxbb_aiu_glue,
  3197. &gxbb_iec958,
  3198. &gxbb_i2s_out,
  3199. &gxbb_amclk,
  3200. &gxbb_aififo2,
  3201. &gxbb_mixer,
  3202. &gxbb_mixer_iface,
  3203. &gxbb_adc,
  3204. &gxbb_blkmv,
  3205. &gxbb_aiu,
  3206. &gxbb_uart1,
  3207. &gxbb_g2d,
  3208. &gxbb_usb0,
  3209. &gxbb_usb1,
  3210. &gxbb_reset,
  3211. &gxbb_nand,
  3212. &gxbb_dos_parser,
  3213. &gxbb_usb,
  3214. &gxbb_vdin1,
  3215. &gxbb_ahb_arb0,
  3216. &gxbb_efuse,
  3217. &gxbb_boot_rom,
  3218. &gxbb_ahb_data_bus,
  3219. &gxbb_ahb_ctrl_bus,
  3220. &gxbb_hdmi_intr_sync,
  3221. &gxbb_hdmi_pclk,
  3222. &gxbb_usb1_ddr_bridge,
  3223. &gxbb_usb0_ddr_bridge,
  3224. &gxbb_mmc_pclk,
  3225. &gxbb_dvin,
  3226. &gxbb_uart2,
  3227. &gxbb_sana,
  3228. &gxbb_vpu_intr,
  3229. &gxbb_sec_ahb_ahb3_bridge,
  3230. &gxbb_clk81_a53,
  3231. &gxbb_vclk2_venci0,
  3232. &gxbb_vclk2_venci1,
  3233. &gxbb_vclk2_vencp0,
  3234. &gxbb_vclk2_vencp1,
  3235. &gxbb_gclk_venci_int0,
  3236. &gxbb_gclk_vencp_int,
  3237. &gxbb_dac_clk,
  3238. &gxbb_aoclk_gate,
  3239. &gxbb_iec958_gate,
  3240. &gxbb_enc480p,
  3241. &gxbb_rng1,
  3242. &gxbb_gclk_venci_int1,
  3243. &gxbb_vclk2_venclmcc,
  3244. &gxbb_vclk2_vencl,
  3245. &gxbb_vclk_other,
  3246. &gxbb_edp,
  3247. &gxbb_ao_media_cpu,
  3248. &gxbb_ao_ahb_sram,
  3249. &gxbb_ao_ahb_bus,
  3250. &gxbb_ao_iface,
  3251. &gxbb_ao_i2c,
  3252. &gxbb_emmc_a,
  3253. &gxbb_emmc_b,
  3254. &gxbb_emmc_c,
  3255. &gxbb_sar_adc_clk,
  3256. &gxbb_mali_0,
  3257. &gxbb_mali_1,
  3258. &gxbb_cts_amclk,
  3259. &gxbb_cts_mclk_i958,
  3260. &gxbb_32k_clk,
  3261. &gxbb_sd_emmc_a_clk0,
  3262. &gxbb_sd_emmc_b_clk0,
  3263. &gxbb_sd_emmc_c_clk0,
  3264. &gxbb_vpu_0,
  3265. &gxbb_vpu_1,
  3266. &gxbb_vapb_0,
  3267. &gxbb_vapb_1,
  3268. &gxbb_vapb,
  3269. &gxbb_mpeg_clk_div,
  3270. &gxbb_sar_adc_clk_div,
  3271. &gxbb_mali_0_div,
  3272. &gxbb_mali_1_div,
  3273. &gxbb_cts_mclk_i958_div,
  3274. &gxbb_32k_clk_div,
  3275. &gxbb_sd_emmc_a_clk0_div,
  3276. &gxbb_sd_emmc_b_clk0_div,
  3277. &gxbb_sd_emmc_c_clk0_div,
  3278. &gxbb_vpu_0_div,
  3279. &gxbb_vpu_1_div,
  3280. &gxbb_vapb_0_div,
  3281. &gxbb_vapb_1_div,
  3282. &gxbb_mpeg_clk_sel,
  3283. &gxbb_sar_adc_clk_sel,
  3284. &gxbb_mali_0_sel,
  3285. &gxbb_mali_1_sel,
  3286. &gxbb_mali,
  3287. &gxbb_cts_amclk_sel,
  3288. &gxbb_cts_mclk_i958_sel,
  3289. &gxbb_cts_i958,
  3290. &gxbb_32k_clk_sel,
  3291. &gxbb_sd_emmc_a_clk0_sel,
  3292. &gxbb_sd_emmc_b_clk0_sel,
  3293. &gxbb_sd_emmc_c_clk0_sel,
  3294. &gxbb_vpu_0_sel,
  3295. &gxbb_vpu_1_sel,
  3296. &gxbb_vpu,
  3297. &gxbb_vapb_0_sel,
  3298. &gxbb_vapb_1_sel,
  3299. &gxbb_vapb_sel,
  3300. &gxbb_mpll0,
  3301. &gxbb_mpll1,
  3302. &gxbb_mpll2,
  3303. &gxl_mpll0_div,
  3304. &gxbb_mpll1_div,
  3305. &gxbb_mpll2_div,
  3306. &gxbb_cts_amclk_div,
  3307. &gxbb_fixed_pll,
  3308. &gxbb_sys_pll,
  3309. &gxbb_mpll_prediv,
  3310. &gxbb_fclk_div2,
  3311. &gxbb_fclk_div3,
  3312. &gxbb_fclk_div4,
  3313. &gxbb_fclk_div5,
  3314. &gxbb_fclk_div7,
  3315. &gxbb_vdec_1_sel,
  3316. &gxbb_vdec_1_div,
  3317. &gxbb_vdec_1,
  3318. &gxbb_vdec_hevc_sel,
  3319. &gxbb_vdec_hevc_div,
  3320. &gxbb_vdec_hevc,
  3321. &gxbb_gen_clk_sel,
  3322. &gxbb_gen_clk_div,
  3323. &gxbb_gen_clk,
  3324. &gxbb_fixed_pll_dco,
  3325. &gxbb_sys_pll_dco,
  3326. &gxbb_gp0_pll,
  3327. &gxbb_vid_pll,
  3328. &gxbb_vid_pll_sel,
  3329. &gxbb_vid_pll_div,
  3330. &gxbb_vclk,
  3331. &gxbb_vclk_sel,
  3332. &gxbb_vclk_div,
  3333. &gxbb_vclk_input,
  3334. &gxbb_vclk_div1,
  3335. &gxbb_vclk_div2_en,
  3336. &gxbb_vclk_div4_en,
  3337. &gxbb_vclk_div6_en,
  3338. &gxbb_vclk_div12_en,
  3339. &gxbb_vclk2,
  3340. &gxbb_vclk2_sel,
  3341. &gxbb_vclk2_div,
  3342. &gxbb_vclk2_input,
  3343. &gxbb_vclk2_div1,
  3344. &gxbb_vclk2_div2_en,
  3345. &gxbb_vclk2_div4_en,
  3346. &gxbb_vclk2_div6_en,
  3347. &gxbb_vclk2_div12_en,
  3348. &gxbb_cts_enci,
  3349. &gxbb_cts_enci_sel,
  3350. &gxbb_cts_encp,
  3351. &gxbb_cts_encp_sel,
  3352. &gxbb_cts_vdac,
  3353. &gxbb_cts_vdac_sel,
  3354. &gxbb_hdmi_tx,
  3355. &gxbb_hdmi_tx_sel,
  3356. &gxbb_hdmi_sel,
  3357. &gxbb_hdmi_div,
  3358. &gxbb_hdmi,
  3359. &gxl_gp0_pll_dco,
  3360. &gxl_hdmi_pll,
  3361. &gxl_hdmi_pll_od,
  3362. &gxl_hdmi_pll_od2,
  3363. &gxl_hdmi_pll_dco,
  3364. &gxl_acodec,
  3365. };
  3366. static const struct meson_eeclkc_data gxbb_clkc_data = {
  3367. .regmap_clks = gxbb_clk_regmaps,
  3368. .regmap_clk_num = ARRAY_SIZE(gxbb_clk_regmaps),
  3369. .hw_clks = {
  3370. .hws = gxbb_hw_clks,
  3371. .num = ARRAY_SIZE(gxbb_hw_clks),
  3372. },
  3373. };
  3374. static const struct meson_eeclkc_data gxl_clkc_data = {
  3375. .regmap_clks = gxl_clk_regmaps,
  3376. .regmap_clk_num = ARRAY_SIZE(gxl_clk_regmaps),
  3377. .hw_clks = {
  3378. .hws = gxl_hw_clks,
  3379. .num = ARRAY_SIZE(gxl_hw_clks),
  3380. },
  3381. };
  3382. static const struct of_device_id clkc_match_table[] = {
  3383. { .compatible = "amlogic,gxbb-clkc", .data = &gxbb_clkc_data },
  3384. { .compatible = "amlogic,gxl-clkc", .data = &gxl_clkc_data },
  3385. {},
  3386. };
  3387. MODULE_DEVICE_TABLE(of, clkc_match_table);
  3388. static struct platform_driver gxbb_driver = {
  3389. .probe = meson_eeclkc_probe,
  3390. .driver = {
  3391. .name = "gxbb-clkc",
  3392. .of_match_table = clkc_match_table,
  3393. },
  3394. };
  3395. module_platform_driver(gxbb_driver);
  3396. MODULE_DESCRIPTION("Amlogic GXBB Main Clock Controller driver");
  3397. MODULE_LICENSE("GPL");
  3398. MODULE_IMPORT_NS(CLK_MESON);