gxbb.c 64 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362
  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.h>
  7. #include <linux/clk-provider.h>
  8. #include <linux/init.h>
  9. #include <linux/of_device.h>
  10. #include <linux/mfd/syscon.h>
  11. #include <linux/platform_device.h>
  12. #include <linux/regmap.h>
  13. #include "clkc.h"
  14. #include "gxbb.h"
  15. #include "clk-regmap.h"
  16. static DEFINE_SPINLOCK(meson_clk_lock);
  17. static const struct pll_params_table gxbb_gp0_pll_params_table[] = {
  18. PLL_PARAMS(32, 1),
  19. PLL_PARAMS(33, 1),
  20. PLL_PARAMS(34, 1),
  21. PLL_PARAMS(35, 1),
  22. PLL_PARAMS(36, 1),
  23. PLL_PARAMS(37, 1),
  24. PLL_PARAMS(38, 1),
  25. PLL_PARAMS(39, 1),
  26. PLL_PARAMS(40, 1),
  27. PLL_PARAMS(41, 1),
  28. PLL_PARAMS(42, 1),
  29. PLL_PARAMS(43, 1),
  30. PLL_PARAMS(44, 1),
  31. PLL_PARAMS(45, 1),
  32. PLL_PARAMS(46, 1),
  33. PLL_PARAMS(47, 1),
  34. PLL_PARAMS(48, 1),
  35. PLL_PARAMS(49, 1),
  36. PLL_PARAMS(50, 1),
  37. PLL_PARAMS(51, 1),
  38. PLL_PARAMS(52, 1),
  39. PLL_PARAMS(53, 1),
  40. PLL_PARAMS(54, 1),
  41. PLL_PARAMS(55, 1),
  42. PLL_PARAMS(56, 1),
  43. PLL_PARAMS(57, 1),
  44. PLL_PARAMS(58, 1),
  45. PLL_PARAMS(59, 1),
  46. PLL_PARAMS(60, 1),
  47. PLL_PARAMS(61, 1),
  48. PLL_PARAMS(62, 1),
  49. { /* sentinel */ },
  50. };
  51. static const struct pll_params_table gxl_gp0_pll_params_table[] = {
  52. PLL_PARAMS(42, 1),
  53. PLL_PARAMS(43, 1),
  54. PLL_PARAMS(44, 1),
  55. PLL_PARAMS(45, 1),
  56. PLL_PARAMS(46, 1),
  57. PLL_PARAMS(47, 1),
  58. PLL_PARAMS(48, 1),
  59. PLL_PARAMS(49, 1),
  60. PLL_PARAMS(50, 1),
  61. PLL_PARAMS(51, 1),
  62. PLL_PARAMS(52, 1),
  63. PLL_PARAMS(53, 1),
  64. PLL_PARAMS(54, 1),
  65. PLL_PARAMS(55, 1),
  66. PLL_PARAMS(56, 1),
  67. PLL_PARAMS(57, 1),
  68. PLL_PARAMS(58, 1),
  69. PLL_PARAMS(59, 1),
  70. PLL_PARAMS(60, 1),
  71. PLL_PARAMS(61, 1),
  72. PLL_PARAMS(62, 1),
  73. PLL_PARAMS(63, 1),
  74. PLL_PARAMS(64, 1),
  75. PLL_PARAMS(65, 1),
  76. PLL_PARAMS(66, 1),
  77. { /* sentinel */ },
  78. };
  79. static struct clk_regmap gxbb_fixed_pll_dco = {
  80. .data = &(struct meson_clk_pll_data){
  81. .en = {
  82. .reg_off = HHI_MPLL_CNTL,
  83. .shift = 30,
  84. .width = 1,
  85. },
  86. .m = {
  87. .reg_off = HHI_MPLL_CNTL,
  88. .shift = 0,
  89. .width = 9,
  90. },
  91. .n = {
  92. .reg_off = HHI_MPLL_CNTL,
  93. .shift = 9,
  94. .width = 5,
  95. },
  96. .frac = {
  97. .reg_off = HHI_MPLL_CNTL2,
  98. .shift = 0,
  99. .width = 12,
  100. },
  101. .l = {
  102. .reg_off = HHI_MPLL_CNTL,
  103. .shift = 31,
  104. .width = 1,
  105. },
  106. .rst = {
  107. .reg_off = HHI_MPLL_CNTL,
  108. .shift = 29,
  109. .width = 1,
  110. },
  111. },
  112. .hw.init = &(struct clk_init_data){
  113. .name = "fixed_pll_dco",
  114. .ops = &meson_clk_pll_ro_ops,
  115. .parent_names = (const char *[]){ "xtal" },
  116. .num_parents = 1,
  117. },
  118. };
  119. static struct clk_regmap gxbb_fixed_pll = {
  120. .data = &(struct clk_regmap_div_data){
  121. .offset = HHI_MPLL_CNTL,
  122. .shift = 16,
  123. .width = 2,
  124. .flags = CLK_DIVIDER_POWER_OF_TWO,
  125. },
  126. .hw.init = &(struct clk_init_data){
  127. .name = "fixed_pll",
  128. .ops = &clk_regmap_divider_ro_ops,
  129. .parent_names = (const char *[]){ "fixed_pll_dco" },
  130. .num_parents = 1,
  131. /*
  132. * This clock won't ever change at runtime so
  133. * CLK_SET_RATE_PARENT is not required
  134. */
  135. },
  136. };
  137. static struct clk_fixed_factor gxbb_hdmi_pll_pre_mult = {
  138. .mult = 2,
  139. .div = 1,
  140. .hw.init = &(struct clk_init_data){
  141. .name = "hdmi_pll_pre_mult",
  142. .ops = &clk_fixed_factor_ops,
  143. .parent_names = (const char *[]){ "xtal" },
  144. .num_parents = 1,
  145. },
  146. };
  147. static struct clk_regmap gxbb_hdmi_pll_dco = {
  148. .data = &(struct meson_clk_pll_data){
  149. .en = {
  150. .reg_off = HHI_HDMI_PLL_CNTL,
  151. .shift = 30,
  152. .width = 1,
  153. },
  154. .m = {
  155. .reg_off = HHI_HDMI_PLL_CNTL,
  156. .shift = 0,
  157. .width = 9,
  158. },
  159. .n = {
  160. .reg_off = HHI_HDMI_PLL_CNTL,
  161. .shift = 9,
  162. .width = 5,
  163. },
  164. .frac = {
  165. .reg_off = HHI_HDMI_PLL_CNTL2,
  166. .shift = 0,
  167. .width = 12,
  168. },
  169. .l = {
  170. .reg_off = HHI_HDMI_PLL_CNTL,
  171. .shift = 31,
  172. .width = 1,
  173. },
  174. .rst = {
  175. .reg_off = HHI_HDMI_PLL_CNTL,
  176. .shift = 28,
  177. .width = 1,
  178. },
  179. },
  180. .hw.init = &(struct clk_init_data){
  181. .name = "hdmi_pll_dco",
  182. .ops = &meson_clk_pll_ro_ops,
  183. .parent_names = (const char *[]){ "hdmi_pll_pre_mult" },
  184. .num_parents = 1,
  185. /*
  186. * Display directly handle hdmi pll registers ATM, we need
  187. * NOCACHE to keep our view of the clock as accurate as possible
  188. */
  189. .flags = CLK_GET_RATE_NOCACHE,
  190. },
  191. };
  192. static struct clk_regmap gxbb_hdmi_pll_od = {
  193. .data = &(struct clk_regmap_div_data){
  194. .offset = HHI_HDMI_PLL_CNTL2,
  195. .shift = 16,
  196. .width = 2,
  197. .flags = CLK_DIVIDER_POWER_OF_TWO,
  198. },
  199. .hw.init = &(struct clk_init_data){
  200. .name = "hdmi_pll_od",
  201. .ops = &clk_regmap_divider_ro_ops,
  202. .parent_names = (const char *[]){ "hdmi_pll_dco" },
  203. .num_parents = 1,
  204. .flags = CLK_GET_RATE_NOCACHE | CLK_SET_RATE_PARENT,
  205. },
  206. };
  207. static struct clk_regmap gxbb_hdmi_pll_od2 = {
  208. .data = &(struct clk_regmap_div_data){
  209. .offset = HHI_HDMI_PLL_CNTL2,
  210. .shift = 22,
  211. .width = 2,
  212. .flags = CLK_DIVIDER_POWER_OF_TWO,
  213. },
  214. .hw.init = &(struct clk_init_data){
  215. .name = "hdmi_pll_od2",
  216. .ops = &clk_regmap_divider_ro_ops,
  217. .parent_names = (const char *[]){ "hdmi_pll_od" },
  218. .num_parents = 1,
  219. .flags = CLK_GET_RATE_NOCACHE | CLK_SET_RATE_PARENT,
  220. },
  221. };
  222. static struct clk_regmap gxbb_hdmi_pll = {
  223. .data = &(struct clk_regmap_div_data){
  224. .offset = HHI_HDMI_PLL_CNTL2,
  225. .shift = 18,
  226. .width = 2,
  227. .flags = CLK_DIVIDER_POWER_OF_TWO,
  228. },
  229. .hw.init = &(struct clk_init_data){
  230. .name = "hdmi_pll",
  231. .ops = &clk_regmap_divider_ro_ops,
  232. .parent_names = (const char *[]){ "hdmi_pll_od2" },
  233. .num_parents = 1,
  234. .flags = CLK_GET_RATE_NOCACHE | CLK_SET_RATE_PARENT,
  235. },
  236. };
  237. static struct clk_regmap gxl_hdmi_pll_od = {
  238. .data = &(struct clk_regmap_div_data){
  239. .offset = HHI_HDMI_PLL_CNTL + 8,
  240. .shift = 21,
  241. .width = 2,
  242. .flags = CLK_DIVIDER_POWER_OF_TWO,
  243. },
  244. .hw.init = &(struct clk_init_data){
  245. .name = "hdmi_pll_od",
  246. .ops = &clk_regmap_divider_ro_ops,
  247. .parent_names = (const char *[]){ "hdmi_pll_dco" },
  248. .num_parents = 1,
  249. .flags = CLK_GET_RATE_NOCACHE | CLK_SET_RATE_PARENT,
  250. },
  251. };
  252. static struct clk_regmap gxl_hdmi_pll_od2 = {
  253. .data = &(struct clk_regmap_div_data){
  254. .offset = HHI_HDMI_PLL_CNTL + 8,
  255. .shift = 23,
  256. .width = 2,
  257. .flags = CLK_DIVIDER_POWER_OF_TWO,
  258. },
  259. .hw.init = &(struct clk_init_data){
  260. .name = "hdmi_pll_od2",
  261. .ops = &clk_regmap_divider_ro_ops,
  262. .parent_names = (const char *[]){ "hdmi_pll_od" },
  263. .num_parents = 1,
  264. .flags = CLK_GET_RATE_NOCACHE | CLK_SET_RATE_PARENT,
  265. },
  266. };
  267. static struct clk_regmap gxl_hdmi_pll = {
  268. .data = &(struct clk_regmap_div_data){
  269. .offset = HHI_HDMI_PLL_CNTL + 8,
  270. .shift = 19,
  271. .width = 2,
  272. .flags = CLK_DIVIDER_POWER_OF_TWO,
  273. },
  274. .hw.init = &(struct clk_init_data){
  275. .name = "hdmi_pll",
  276. .ops = &clk_regmap_divider_ro_ops,
  277. .parent_names = (const char *[]){ "hdmi_pll_od2" },
  278. .num_parents = 1,
  279. .flags = CLK_GET_RATE_NOCACHE | CLK_SET_RATE_PARENT,
  280. },
  281. };
  282. static struct clk_regmap gxbb_sys_pll_dco = {
  283. .data = &(struct meson_clk_pll_data){
  284. .en = {
  285. .reg_off = HHI_SYS_PLL_CNTL,
  286. .shift = 30,
  287. .width = 1,
  288. },
  289. .m = {
  290. .reg_off = HHI_SYS_PLL_CNTL,
  291. .shift = 0,
  292. .width = 9,
  293. },
  294. .n = {
  295. .reg_off = HHI_SYS_PLL_CNTL,
  296. .shift = 9,
  297. .width = 5,
  298. },
  299. .l = {
  300. .reg_off = HHI_SYS_PLL_CNTL,
  301. .shift = 31,
  302. .width = 1,
  303. },
  304. .rst = {
  305. .reg_off = HHI_SYS_PLL_CNTL,
  306. .shift = 29,
  307. .width = 1,
  308. },
  309. },
  310. .hw.init = &(struct clk_init_data){
  311. .name = "sys_pll_dco",
  312. .ops = &meson_clk_pll_ro_ops,
  313. .parent_names = (const char *[]){ "xtal" },
  314. .num_parents = 1,
  315. },
  316. };
  317. static struct clk_regmap gxbb_sys_pll = {
  318. .data = &(struct clk_regmap_div_data){
  319. .offset = HHI_SYS_PLL_CNTL,
  320. .shift = 10,
  321. .width = 2,
  322. .flags = CLK_DIVIDER_POWER_OF_TWO,
  323. },
  324. .hw.init = &(struct clk_init_data){
  325. .name = "sys_pll",
  326. .ops = &clk_regmap_divider_ro_ops,
  327. .parent_names = (const char *[]){ "sys_pll_dco" },
  328. .num_parents = 1,
  329. .flags = CLK_SET_RATE_PARENT,
  330. },
  331. };
  332. static const struct reg_sequence gxbb_gp0_init_regs[] = {
  333. { .reg = HHI_GP0_PLL_CNTL2, .def = 0x69c80000 },
  334. { .reg = HHI_GP0_PLL_CNTL3, .def = 0x0a5590c4 },
  335. { .reg = HHI_GP0_PLL_CNTL4, .def = 0x0000500d },
  336. };
  337. static struct clk_regmap gxbb_gp0_pll_dco = {
  338. .data = &(struct meson_clk_pll_data){
  339. .en = {
  340. .reg_off = HHI_GP0_PLL_CNTL,
  341. .shift = 30,
  342. .width = 1,
  343. },
  344. .m = {
  345. .reg_off = HHI_GP0_PLL_CNTL,
  346. .shift = 0,
  347. .width = 9,
  348. },
  349. .n = {
  350. .reg_off = HHI_GP0_PLL_CNTL,
  351. .shift = 9,
  352. .width = 5,
  353. },
  354. .l = {
  355. .reg_off = HHI_GP0_PLL_CNTL,
  356. .shift = 31,
  357. .width = 1,
  358. },
  359. .rst = {
  360. .reg_off = HHI_GP0_PLL_CNTL,
  361. .shift = 29,
  362. .width = 1,
  363. },
  364. .table = gxbb_gp0_pll_params_table,
  365. .init_regs = gxbb_gp0_init_regs,
  366. .init_count = ARRAY_SIZE(gxbb_gp0_init_regs),
  367. },
  368. .hw.init = &(struct clk_init_data){
  369. .name = "gp0_pll_dco",
  370. .ops = &meson_clk_pll_ops,
  371. .parent_names = (const char *[]){ "xtal" },
  372. .num_parents = 1,
  373. },
  374. };
  375. static const struct reg_sequence gxl_gp0_init_regs[] = {
  376. { .reg = HHI_GP0_PLL_CNTL1, .def = 0xc084b000 },
  377. { .reg = HHI_GP0_PLL_CNTL2, .def = 0xb75020be },
  378. { .reg = HHI_GP0_PLL_CNTL3, .def = 0x0a59a288 },
  379. { .reg = HHI_GP0_PLL_CNTL4, .def = 0xc000004d },
  380. { .reg = HHI_GP0_PLL_CNTL5, .def = 0x00078000 },
  381. };
  382. static struct clk_regmap gxl_gp0_pll_dco = {
  383. .data = &(struct meson_clk_pll_data){
  384. .en = {
  385. .reg_off = HHI_GP0_PLL_CNTL,
  386. .shift = 30,
  387. .width = 1,
  388. },
  389. .m = {
  390. .reg_off = HHI_GP0_PLL_CNTL,
  391. .shift = 0,
  392. .width = 9,
  393. },
  394. .n = {
  395. .reg_off = HHI_GP0_PLL_CNTL,
  396. .shift = 9,
  397. .width = 5,
  398. },
  399. .frac = {
  400. .reg_off = HHI_GP0_PLL_CNTL1,
  401. .shift = 0,
  402. .width = 10,
  403. },
  404. .l = {
  405. .reg_off = HHI_GP0_PLL_CNTL,
  406. .shift = 31,
  407. .width = 1,
  408. },
  409. .rst = {
  410. .reg_off = HHI_GP0_PLL_CNTL,
  411. .shift = 29,
  412. .width = 1,
  413. },
  414. .table = gxl_gp0_pll_params_table,
  415. .init_regs = gxl_gp0_init_regs,
  416. .init_count = ARRAY_SIZE(gxl_gp0_init_regs),
  417. },
  418. .hw.init = &(struct clk_init_data){
  419. .name = "gp0_pll_dco",
  420. .ops = &meson_clk_pll_ops,
  421. .parent_names = (const char *[]){ "xtal" },
  422. .num_parents = 1,
  423. },
  424. };
  425. static struct clk_regmap gxbb_gp0_pll = {
  426. .data = &(struct clk_regmap_div_data){
  427. .offset = HHI_GP0_PLL_CNTL,
  428. .shift = 16,
  429. .width = 2,
  430. .flags = CLK_DIVIDER_POWER_OF_TWO,
  431. },
  432. .hw.init = &(struct clk_init_data){
  433. .name = "gp0_pll",
  434. .ops = &clk_regmap_divider_ops,
  435. .parent_names = (const char *[]){ "gp0_pll_dco" },
  436. .num_parents = 1,
  437. .flags = CLK_SET_RATE_PARENT,
  438. },
  439. };
  440. static struct clk_fixed_factor gxbb_fclk_div2_div = {
  441. .mult = 1,
  442. .div = 2,
  443. .hw.init = &(struct clk_init_data){
  444. .name = "fclk_div2_div",
  445. .ops = &clk_fixed_factor_ops,
  446. .parent_names = (const char *[]){ "fixed_pll" },
  447. .num_parents = 1,
  448. },
  449. };
  450. static struct clk_regmap gxbb_fclk_div2 = {
  451. .data = &(struct clk_regmap_gate_data){
  452. .offset = HHI_MPLL_CNTL6,
  453. .bit_idx = 27,
  454. },
  455. .hw.init = &(struct clk_init_data){
  456. .name = "fclk_div2",
  457. .ops = &clk_regmap_gate_ops,
  458. .parent_names = (const char *[]){ "fclk_div2_div" },
  459. .num_parents = 1,
  460. .flags = CLK_IS_CRITICAL,
  461. },
  462. };
  463. static struct clk_fixed_factor gxbb_fclk_div3_div = {
  464. .mult = 1,
  465. .div = 3,
  466. .hw.init = &(struct clk_init_data){
  467. .name = "fclk_div3_div",
  468. .ops = &clk_fixed_factor_ops,
  469. .parent_names = (const char *[]){ "fixed_pll" },
  470. .num_parents = 1,
  471. },
  472. };
  473. static struct clk_regmap gxbb_fclk_div3 = {
  474. .data = &(struct clk_regmap_gate_data){
  475. .offset = HHI_MPLL_CNTL6,
  476. .bit_idx = 28,
  477. },
  478. .hw.init = &(struct clk_init_data){
  479. .name = "fclk_div3",
  480. .ops = &clk_regmap_gate_ops,
  481. .parent_names = (const char *[]){ "fclk_div3_div" },
  482. .num_parents = 1,
  483. /*
  484. * FIXME:
  485. * This clock, as fdiv2, is used by the SCPI FW and is required
  486. * by the platform to operate correctly.
  487. * Until the following condition are met, we need this clock to
  488. * be marked as critical:
  489. * a) The SCPI generic driver claims and enable all the clocks
  490. * it needs
  491. * b) CCF has a clock hand-off mechanism to make the sure the
  492. * clock stays on until the proper driver comes along
  493. */
  494. .flags = CLK_IS_CRITICAL,
  495. },
  496. };
  497. static struct clk_fixed_factor gxbb_fclk_div4_div = {
  498. .mult = 1,
  499. .div = 4,
  500. .hw.init = &(struct clk_init_data){
  501. .name = "fclk_div4_div",
  502. .ops = &clk_fixed_factor_ops,
  503. .parent_names = (const char *[]){ "fixed_pll" },
  504. .num_parents = 1,
  505. },
  506. };
  507. static struct clk_regmap gxbb_fclk_div4 = {
  508. .data = &(struct clk_regmap_gate_data){
  509. .offset = HHI_MPLL_CNTL6,
  510. .bit_idx = 29,
  511. },
  512. .hw.init = &(struct clk_init_data){
  513. .name = "fclk_div4",
  514. .ops = &clk_regmap_gate_ops,
  515. .parent_names = (const char *[]){ "fclk_div4_div" },
  516. .num_parents = 1,
  517. },
  518. };
  519. static struct clk_fixed_factor gxbb_fclk_div5_div = {
  520. .mult = 1,
  521. .div = 5,
  522. .hw.init = &(struct clk_init_data){
  523. .name = "fclk_div5_div",
  524. .ops = &clk_fixed_factor_ops,
  525. .parent_names = (const char *[]){ "fixed_pll" },
  526. .num_parents = 1,
  527. },
  528. };
  529. static struct clk_regmap gxbb_fclk_div5 = {
  530. .data = &(struct clk_regmap_gate_data){
  531. .offset = HHI_MPLL_CNTL6,
  532. .bit_idx = 30,
  533. },
  534. .hw.init = &(struct clk_init_data){
  535. .name = "fclk_div5",
  536. .ops = &clk_regmap_gate_ops,
  537. .parent_names = (const char *[]){ "fclk_div5_div" },
  538. .num_parents = 1,
  539. },
  540. };
  541. static struct clk_fixed_factor gxbb_fclk_div7_div = {
  542. .mult = 1,
  543. .div = 7,
  544. .hw.init = &(struct clk_init_data){
  545. .name = "fclk_div7_div",
  546. .ops = &clk_fixed_factor_ops,
  547. .parent_names = (const char *[]){ "fixed_pll" },
  548. .num_parents = 1,
  549. },
  550. };
  551. static struct clk_regmap gxbb_fclk_div7 = {
  552. .data = &(struct clk_regmap_gate_data){
  553. .offset = HHI_MPLL_CNTL6,
  554. .bit_idx = 31,
  555. },
  556. .hw.init = &(struct clk_init_data){
  557. .name = "fclk_div7",
  558. .ops = &clk_regmap_gate_ops,
  559. .parent_names = (const char *[]){ "fclk_div7_div" },
  560. .num_parents = 1,
  561. },
  562. };
  563. static struct clk_regmap gxbb_mpll_prediv = {
  564. .data = &(struct clk_regmap_div_data){
  565. .offset = HHI_MPLL_CNTL5,
  566. .shift = 12,
  567. .width = 1,
  568. },
  569. .hw.init = &(struct clk_init_data){
  570. .name = "mpll_prediv",
  571. .ops = &clk_regmap_divider_ro_ops,
  572. .parent_names = (const char *[]){ "fixed_pll" },
  573. .num_parents = 1,
  574. },
  575. };
  576. static struct clk_regmap gxbb_mpll0_div = {
  577. .data = &(struct meson_clk_mpll_data){
  578. .sdm = {
  579. .reg_off = HHI_MPLL_CNTL7,
  580. .shift = 0,
  581. .width = 14,
  582. },
  583. .sdm_en = {
  584. .reg_off = HHI_MPLL_CNTL7,
  585. .shift = 15,
  586. .width = 1,
  587. },
  588. .n2 = {
  589. .reg_off = HHI_MPLL_CNTL7,
  590. .shift = 16,
  591. .width = 9,
  592. },
  593. .ssen = {
  594. .reg_off = HHI_MPLL_CNTL,
  595. .shift = 25,
  596. .width = 1,
  597. },
  598. .lock = &meson_clk_lock,
  599. },
  600. .hw.init = &(struct clk_init_data){
  601. .name = "mpll0_div",
  602. .ops = &meson_clk_mpll_ops,
  603. .parent_names = (const char *[]){ "mpll_prediv" },
  604. .num_parents = 1,
  605. },
  606. };
  607. static struct clk_regmap gxbb_mpll0 = {
  608. .data = &(struct clk_regmap_gate_data){
  609. .offset = HHI_MPLL_CNTL7,
  610. .bit_idx = 14,
  611. },
  612. .hw.init = &(struct clk_init_data){
  613. .name = "mpll0",
  614. .ops = &clk_regmap_gate_ops,
  615. .parent_names = (const char *[]){ "mpll0_div" },
  616. .num_parents = 1,
  617. .flags = CLK_SET_RATE_PARENT,
  618. },
  619. };
  620. static struct clk_regmap gxbb_mpll1_div = {
  621. .data = &(struct meson_clk_mpll_data){
  622. .sdm = {
  623. .reg_off = HHI_MPLL_CNTL8,
  624. .shift = 0,
  625. .width = 14,
  626. },
  627. .sdm_en = {
  628. .reg_off = HHI_MPLL_CNTL8,
  629. .shift = 15,
  630. .width = 1,
  631. },
  632. .n2 = {
  633. .reg_off = HHI_MPLL_CNTL8,
  634. .shift = 16,
  635. .width = 9,
  636. },
  637. .lock = &meson_clk_lock,
  638. },
  639. .hw.init = &(struct clk_init_data){
  640. .name = "mpll1_div",
  641. .ops = &meson_clk_mpll_ops,
  642. .parent_names = (const char *[]){ "mpll_prediv" },
  643. .num_parents = 1,
  644. },
  645. };
  646. static struct clk_regmap gxbb_mpll1 = {
  647. .data = &(struct clk_regmap_gate_data){
  648. .offset = HHI_MPLL_CNTL8,
  649. .bit_idx = 14,
  650. },
  651. .hw.init = &(struct clk_init_data){
  652. .name = "mpll1",
  653. .ops = &clk_regmap_gate_ops,
  654. .parent_names = (const char *[]){ "mpll1_div" },
  655. .num_parents = 1,
  656. .flags = CLK_SET_RATE_PARENT,
  657. },
  658. };
  659. static struct clk_regmap gxbb_mpll2_div = {
  660. .data = &(struct meson_clk_mpll_data){
  661. .sdm = {
  662. .reg_off = HHI_MPLL_CNTL9,
  663. .shift = 0,
  664. .width = 14,
  665. },
  666. .sdm_en = {
  667. .reg_off = HHI_MPLL_CNTL9,
  668. .shift = 15,
  669. .width = 1,
  670. },
  671. .n2 = {
  672. .reg_off = HHI_MPLL_CNTL9,
  673. .shift = 16,
  674. .width = 9,
  675. },
  676. .lock = &meson_clk_lock,
  677. },
  678. .hw.init = &(struct clk_init_data){
  679. .name = "mpll2_div",
  680. .ops = &meson_clk_mpll_ops,
  681. .parent_names = (const char *[]){ "mpll_prediv" },
  682. .num_parents = 1,
  683. },
  684. };
  685. static struct clk_regmap gxbb_mpll2 = {
  686. .data = &(struct clk_regmap_gate_data){
  687. .offset = HHI_MPLL_CNTL9,
  688. .bit_idx = 14,
  689. },
  690. .hw.init = &(struct clk_init_data){
  691. .name = "mpll2",
  692. .ops = &clk_regmap_gate_ops,
  693. .parent_names = (const char *[]){ "mpll2_div" },
  694. .num_parents = 1,
  695. .flags = CLK_SET_RATE_PARENT,
  696. },
  697. };
  698. static u32 mux_table_clk81[] = { 0, 2, 3, 4, 5, 6, 7 };
  699. static const char * const clk81_parent_names[] = {
  700. "xtal", "fclk_div7", "mpll1", "mpll2", "fclk_div4",
  701. "fclk_div3", "fclk_div5"
  702. };
  703. static struct clk_regmap gxbb_mpeg_clk_sel = {
  704. .data = &(struct clk_regmap_mux_data){
  705. .offset = HHI_MPEG_CLK_CNTL,
  706. .mask = 0x7,
  707. .shift = 12,
  708. .table = mux_table_clk81,
  709. },
  710. .hw.init = &(struct clk_init_data){
  711. .name = "mpeg_clk_sel",
  712. .ops = &clk_regmap_mux_ro_ops,
  713. /*
  714. * bits 14:12 selects from 8 possible parents:
  715. * xtal, 1'b0 (wtf), fclk_div7, mpll_clkout1, mpll_clkout2,
  716. * fclk_div4, fclk_div3, fclk_div5
  717. */
  718. .parent_names = clk81_parent_names,
  719. .num_parents = ARRAY_SIZE(clk81_parent_names),
  720. },
  721. };
  722. static struct clk_regmap gxbb_mpeg_clk_div = {
  723. .data = &(struct clk_regmap_div_data){
  724. .offset = HHI_MPEG_CLK_CNTL,
  725. .shift = 0,
  726. .width = 7,
  727. },
  728. .hw.init = &(struct clk_init_data){
  729. .name = "mpeg_clk_div",
  730. .ops = &clk_regmap_divider_ro_ops,
  731. .parent_names = (const char *[]){ "mpeg_clk_sel" },
  732. .num_parents = 1,
  733. },
  734. };
  735. /* the mother of dragons gates */
  736. static struct clk_regmap gxbb_clk81 = {
  737. .data = &(struct clk_regmap_gate_data){
  738. .offset = HHI_MPEG_CLK_CNTL,
  739. .bit_idx = 7,
  740. },
  741. .hw.init = &(struct clk_init_data){
  742. .name = "clk81",
  743. .ops = &clk_regmap_gate_ops,
  744. .parent_names = (const char *[]){ "mpeg_clk_div" },
  745. .num_parents = 1,
  746. .flags = CLK_IS_CRITICAL,
  747. },
  748. };
  749. static struct clk_regmap gxbb_sar_adc_clk_sel = {
  750. .data = &(struct clk_regmap_mux_data){
  751. .offset = HHI_SAR_CLK_CNTL,
  752. .mask = 0x3,
  753. .shift = 9,
  754. },
  755. .hw.init = &(struct clk_init_data){
  756. .name = "sar_adc_clk_sel",
  757. .ops = &clk_regmap_mux_ops,
  758. /* NOTE: The datasheet doesn't list the parents for bit 10 */
  759. .parent_names = (const char *[]){ "xtal", "clk81", },
  760. .num_parents = 2,
  761. },
  762. };
  763. static struct clk_regmap gxbb_sar_adc_clk_div = {
  764. .data = &(struct clk_regmap_div_data){
  765. .offset = HHI_SAR_CLK_CNTL,
  766. .shift = 0,
  767. .width = 8,
  768. },
  769. .hw.init = &(struct clk_init_data){
  770. .name = "sar_adc_clk_div",
  771. .ops = &clk_regmap_divider_ops,
  772. .parent_names = (const char *[]){ "sar_adc_clk_sel" },
  773. .num_parents = 1,
  774. },
  775. };
  776. static struct clk_regmap gxbb_sar_adc_clk = {
  777. .data = &(struct clk_regmap_gate_data){
  778. .offset = HHI_SAR_CLK_CNTL,
  779. .bit_idx = 8,
  780. },
  781. .hw.init = &(struct clk_init_data){
  782. .name = "sar_adc_clk",
  783. .ops = &clk_regmap_gate_ops,
  784. .parent_names = (const char *[]){ "sar_adc_clk_div" },
  785. .num_parents = 1,
  786. .flags = CLK_SET_RATE_PARENT,
  787. },
  788. };
  789. /*
  790. * The MALI IP is clocked by two identical clocks (mali_0 and mali_1)
  791. * muxed by a glitch-free switch.
  792. */
  793. static const char * const gxbb_mali_0_1_parent_names[] = {
  794. "xtal", "gp0_pll", "mpll2", "mpll1", "fclk_div7",
  795. "fclk_div4", "fclk_div3", "fclk_div5"
  796. };
  797. static struct clk_regmap gxbb_mali_0_sel = {
  798. .data = &(struct clk_regmap_mux_data){
  799. .offset = HHI_MALI_CLK_CNTL,
  800. .mask = 0x7,
  801. .shift = 9,
  802. },
  803. .hw.init = &(struct clk_init_data){
  804. .name = "mali_0_sel",
  805. .ops = &clk_regmap_mux_ops,
  806. /*
  807. * bits 10:9 selects from 8 possible parents:
  808. * xtal, gp0_pll, mpll2, mpll1, fclk_div7,
  809. * fclk_div4, fclk_div3, fclk_div5
  810. */
  811. .parent_names = gxbb_mali_0_1_parent_names,
  812. .num_parents = 8,
  813. .flags = CLK_SET_RATE_NO_REPARENT,
  814. },
  815. };
  816. static struct clk_regmap gxbb_mali_0_div = {
  817. .data = &(struct clk_regmap_div_data){
  818. .offset = HHI_MALI_CLK_CNTL,
  819. .shift = 0,
  820. .width = 7,
  821. },
  822. .hw.init = &(struct clk_init_data){
  823. .name = "mali_0_div",
  824. .ops = &clk_regmap_divider_ops,
  825. .parent_names = (const char *[]){ "mali_0_sel" },
  826. .num_parents = 1,
  827. .flags = CLK_SET_RATE_NO_REPARENT,
  828. },
  829. };
  830. static struct clk_regmap gxbb_mali_0 = {
  831. .data = &(struct clk_regmap_gate_data){
  832. .offset = HHI_MALI_CLK_CNTL,
  833. .bit_idx = 8,
  834. },
  835. .hw.init = &(struct clk_init_data){
  836. .name = "mali_0",
  837. .ops = &clk_regmap_gate_ops,
  838. .parent_names = (const char *[]){ "mali_0_div" },
  839. .num_parents = 1,
  840. .flags = CLK_SET_RATE_PARENT,
  841. },
  842. };
  843. static struct clk_regmap gxbb_mali_1_sel = {
  844. .data = &(struct clk_regmap_mux_data){
  845. .offset = HHI_MALI_CLK_CNTL,
  846. .mask = 0x7,
  847. .shift = 25,
  848. },
  849. .hw.init = &(struct clk_init_data){
  850. .name = "mali_1_sel",
  851. .ops = &clk_regmap_mux_ops,
  852. /*
  853. * bits 10:9 selects from 8 possible parents:
  854. * xtal, gp0_pll, mpll2, mpll1, fclk_div7,
  855. * fclk_div4, fclk_div3, fclk_div5
  856. */
  857. .parent_names = gxbb_mali_0_1_parent_names,
  858. .num_parents = 8,
  859. .flags = CLK_SET_RATE_NO_REPARENT,
  860. },
  861. };
  862. static struct clk_regmap gxbb_mali_1_div = {
  863. .data = &(struct clk_regmap_div_data){
  864. .offset = HHI_MALI_CLK_CNTL,
  865. .shift = 16,
  866. .width = 7,
  867. },
  868. .hw.init = &(struct clk_init_data){
  869. .name = "mali_1_div",
  870. .ops = &clk_regmap_divider_ops,
  871. .parent_names = (const char *[]){ "mali_1_sel" },
  872. .num_parents = 1,
  873. .flags = CLK_SET_RATE_NO_REPARENT,
  874. },
  875. };
  876. static struct clk_regmap gxbb_mali_1 = {
  877. .data = &(struct clk_regmap_gate_data){
  878. .offset = HHI_MALI_CLK_CNTL,
  879. .bit_idx = 24,
  880. },
  881. .hw.init = &(struct clk_init_data){
  882. .name = "mali_1",
  883. .ops = &clk_regmap_gate_ops,
  884. .parent_names = (const char *[]){ "mali_1_div" },
  885. .num_parents = 1,
  886. .flags = CLK_SET_RATE_PARENT,
  887. },
  888. };
  889. static const char * const gxbb_mali_parent_names[] = {
  890. "mali_0", "mali_1"
  891. };
  892. static struct clk_regmap gxbb_mali = {
  893. .data = &(struct clk_regmap_mux_data){
  894. .offset = HHI_MALI_CLK_CNTL,
  895. .mask = 1,
  896. .shift = 31,
  897. },
  898. .hw.init = &(struct clk_init_data){
  899. .name = "mali",
  900. .ops = &clk_regmap_mux_ops,
  901. .parent_names = gxbb_mali_parent_names,
  902. .num_parents = 2,
  903. .flags = CLK_SET_RATE_NO_REPARENT,
  904. },
  905. };
  906. static struct clk_regmap gxbb_cts_amclk_sel = {
  907. .data = &(struct clk_regmap_mux_data){
  908. .offset = HHI_AUD_CLK_CNTL,
  909. .mask = 0x3,
  910. .shift = 9,
  911. .table = (u32[]){ 1, 2, 3 },
  912. .flags = CLK_MUX_ROUND_CLOSEST,
  913. },
  914. .hw.init = &(struct clk_init_data){
  915. .name = "cts_amclk_sel",
  916. .ops = &clk_regmap_mux_ops,
  917. .parent_names = (const char *[]){ "mpll0", "mpll1", "mpll2" },
  918. .num_parents = 3,
  919. },
  920. };
  921. static struct clk_regmap gxbb_cts_amclk_div = {
  922. .data = &(struct clk_regmap_div_data) {
  923. .offset = HHI_AUD_CLK_CNTL,
  924. .shift = 0,
  925. .width = 8,
  926. .flags = CLK_DIVIDER_ROUND_CLOSEST,
  927. },
  928. .hw.init = &(struct clk_init_data){
  929. .name = "cts_amclk_div",
  930. .ops = &clk_regmap_divider_ops,
  931. .parent_names = (const char *[]){ "cts_amclk_sel" },
  932. .num_parents = 1,
  933. .flags = CLK_SET_RATE_PARENT,
  934. },
  935. };
  936. static struct clk_regmap gxbb_cts_amclk = {
  937. .data = &(struct clk_regmap_gate_data){
  938. .offset = HHI_AUD_CLK_CNTL,
  939. .bit_idx = 8,
  940. },
  941. .hw.init = &(struct clk_init_data){
  942. .name = "cts_amclk",
  943. .ops = &clk_regmap_gate_ops,
  944. .parent_names = (const char *[]){ "cts_amclk_div" },
  945. .num_parents = 1,
  946. .flags = CLK_SET_RATE_PARENT,
  947. },
  948. };
  949. static struct clk_regmap gxbb_cts_mclk_i958_sel = {
  950. .data = &(struct clk_regmap_mux_data){
  951. .offset = HHI_AUD_CLK_CNTL2,
  952. .mask = 0x3,
  953. .shift = 25,
  954. .table = (u32[]){ 1, 2, 3 },
  955. .flags = CLK_MUX_ROUND_CLOSEST,
  956. },
  957. .hw.init = &(struct clk_init_data) {
  958. .name = "cts_mclk_i958_sel",
  959. .ops = &clk_regmap_mux_ops,
  960. .parent_names = (const char *[]){ "mpll0", "mpll1", "mpll2" },
  961. .num_parents = 3,
  962. },
  963. };
  964. static struct clk_regmap gxbb_cts_mclk_i958_div = {
  965. .data = &(struct clk_regmap_div_data){
  966. .offset = HHI_AUD_CLK_CNTL2,
  967. .shift = 16,
  968. .width = 8,
  969. .flags = CLK_DIVIDER_ROUND_CLOSEST,
  970. },
  971. .hw.init = &(struct clk_init_data) {
  972. .name = "cts_mclk_i958_div",
  973. .ops = &clk_regmap_divider_ops,
  974. .parent_names = (const char *[]){ "cts_mclk_i958_sel" },
  975. .num_parents = 1,
  976. .flags = CLK_SET_RATE_PARENT,
  977. },
  978. };
  979. static struct clk_regmap gxbb_cts_mclk_i958 = {
  980. .data = &(struct clk_regmap_gate_data){
  981. .offset = HHI_AUD_CLK_CNTL2,
  982. .bit_idx = 24,
  983. },
  984. .hw.init = &(struct clk_init_data){
  985. .name = "cts_mclk_i958",
  986. .ops = &clk_regmap_gate_ops,
  987. .parent_names = (const char *[]){ "cts_mclk_i958_div" },
  988. .num_parents = 1,
  989. .flags = CLK_SET_RATE_PARENT,
  990. },
  991. };
  992. static struct clk_regmap gxbb_cts_i958 = {
  993. .data = &(struct clk_regmap_mux_data){
  994. .offset = HHI_AUD_CLK_CNTL2,
  995. .mask = 0x1,
  996. .shift = 27,
  997. },
  998. .hw.init = &(struct clk_init_data){
  999. .name = "cts_i958",
  1000. .ops = &clk_regmap_mux_ops,
  1001. .parent_names = (const char *[]){ "cts_amclk", "cts_mclk_i958" },
  1002. .num_parents = 2,
  1003. /*
  1004. *The parent is specific to origin of the audio data. Let the
  1005. * consumer choose the appropriate parent
  1006. */
  1007. .flags = CLK_SET_RATE_PARENT | CLK_SET_RATE_NO_REPARENT,
  1008. },
  1009. };
  1010. static struct clk_regmap gxbb_32k_clk_div = {
  1011. .data = &(struct clk_regmap_div_data){
  1012. .offset = HHI_32K_CLK_CNTL,
  1013. .shift = 0,
  1014. .width = 14,
  1015. },
  1016. .hw.init = &(struct clk_init_data){
  1017. .name = "32k_clk_div",
  1018. .ops = &clk_regmap_divider_ops,
  1019. .parent_names = (const char *[]){ "32k_clk_sel" },
  1020. .num_parents = 1,
  1021. .flags = CLK_SET_RATE_PARENT | CLK_DIVIDER_ROUND_CLOSEST,
  1022. },
  1023. };
  1024. static struct clk_regmap gxbb_32k_clk = {
  1025. .data = &(struct clk_regmap_gate_data){
  1026. .offset = HHI_32K_CLK_CNTL,
  1027. .bit_idx = 15,
  1028. },
  1029. .hw.init = &(struct clk_init_data){
  1030. .name = "32k_clk",
  1031. .ops = &clk_regmap_gate_ops,
  1032. .parent_names = (const char *[]){ "32k_clk_div" },
  1033. .num_parents = 1,
  1034. .flags = CLK_SET_RATE_PARENT,
  1035. },
  1036. };
  1037. static const char * const gxbb_32k_clk_parent_names[] = {
  1038. "xtal", "cts_slow_oscin", "fclk_div3", "fclk_div5"
  1039. };
  1040. static struct clk_regmap gxbb_32k_clk_sel = {
  1041. .data = &(struct clk_regmap_mux_data){
  1042. .offset = HHI_32K_CLK_CNTL,
  1043. .mask = 0x3,
  1044. .shift = 16,
  1045. },
  1046. .hw.init = &(struct clk_init_data){
  1047. .name = "32k_clk_sel",
  1048. .ops = &clk_regmap_mux_ops,
  1049. .parent_names = gxbb_32k_clk_parent_names,
  1050. .num_parents = 4,
  1051. .flags = CLK_SET_RATE_PARENT,
  1052. },
  1053. };
  1054. static const char * const gxbb_sd_emmc_clk0_parent_names[] = {
  1055. "xtal", "fclk_div2", "fclk_div3", "fclk_div5", "fclk_div7",
  1056. /*
  1057. * Following these parent clocks, we should also have had mpll2, mpll3
  1058. * and gp0_pll but these clocks are too precious to be used here. All
  1059. * the necessary rates for MMC and NAND operation can be acheived using
  1060. * xtal or fclk_div clocks
  1061. */
  1062. };
  1063. /* SDIO clock */
  1064. static struct clk_regmap gxbb_sd_emmc_a_clk0_sel = {
  1065. .data = &(struct clk_regmap_mux_data){
  1066. .offset = HHI_SD_EMMC_CLK_CNTL,
  1067. .mask = 0x7,
  1068. .shift = 9,
  1069. },
  1070. .hw.init = &(struct clk_init_data) {
  1071. .name = "sd_emmc_a_clk0_sel",
  1072. .ops = &clk_regmap_mux_ops,
  1073. .parent_names = gxbb_sd_emmc_clk0_parent_names,
  1074. .num_parents = ARRAY_SIZE(gxbb_sd_emmc_clk0_parent_names),
  1075. .flags = CLK_SET_RATE_PARENT,
  1076. },
  1077. };
  1078. static struct clk_regmap gxbb_sd_emmc_a_clk0_div = {
  1079. .data = &(struct clk_regmap_div_data){
  1080. .offset = HHI_SD_EMMC_CLK_CNTL,
  1081. .shift = 0,
  1082. .width = 7,
  1083. .flags = CLK_DIVIDER_ROUND_CLOSEST,
  1084. },
  1085. .hw.init = &(struct clk_init_data) {
  1086. .name = "sd_emmc_a_clk0_div",
  1087. .ops = &clk_regmap_divider_ops,
  1088. .parent_names = (const char *[]){ "sd_emmc_a_clk0_sel" },
  1089. .num_parents = 1,
  1090. .flags = CLK_SET_RATE_PARENT,
  1091. },
  1092. };
  1093. static struct clk_regmap gxbb_sd_emmc_a_clk0 = {
  1094. .data = &(struct clk_regmap_gate_data){
  1095. .offset = HHI_SD_EMMC_CLK_CNTL,
  1096. .bit_idx = 7,
  1097. },
  1098. .hw.init = &(struct clk_init_data){
  1099. .name = "sd_emmc_a_clk0",
  1100. .ops = &clk_regmap_gate_ops,
  1101. .parent_names = (const char *[]){ "sd_emmc_a_clk0_div" },
  1102. .num_parents = 1,
  1103. .flags = CLK_SET_RATE_PARENT,
  1104. },
  1105. };
  1106. /* SDcard clock */
  1107. static struct clk_regmap gxbb_sd_emmc_b_clk0_sel = {
  1108. .data = &(struct clk_regmap_mux_data){
  1109. .offset = HHI_SD_EMMC_CLK_CNTL,
  1110. .mask = 0x7,
  1111. .shift = 25,
  1112. },
  1113. .hw.init = &(struct clk_init_data) {
  1114. .name = "sd_emmc_b_clk0_sel",
  1115. .ops = &clk_regmap_mux_ops,
  1116. .parent_names = gxbb_sd_emmc_clk0_parent_names,
  1117. .num_parents = ARRAY_SIZE(gxbb_sd_emmc_clk0_parent_names),
  1118. .flags = CLK_SET_RATE_PARENT,
  1119. },
  1120. };
  1121. static struct clk_regmap gxbb_sd_emmc_b_clk0_div = {
  1122. .data = &(struct clk_regmap_div_data){
  1123. .offset = HHI_SD_EMMC_CLK_CNTL,
  1124. .shift = 16,
  1125. .width = 7,
  1126. .flags = CLK_DIVIDER_ROUND_CLOSEST,
  1127. },
  1128. .hw.init = &(struct clk_init_data) {
  1129. .name = "sd_emmc_b_clk0_div",
  1130. .ops = &clk_regmap_divider_ops,
  1131. .parent_names = (const char *[]){ "sd_emmc_b_clk0_sel" },
  1132. .num_parents = 1,
  1133. .flags = CLK_SET_RATE_PARENT,
  1134. },
  1135. };
  1136. static struct clk_regmap gxbb_sd_emmc_b_clk0 = {
  1137. .data = &(struct clk_regmap_gate_data){
  1138. .offset = HHI_SD_EMMC_CLK_CNTL,
  1139. .bit_idx = 23,
  1140. },
  1141. .hw.init = &(struct clk_init_data){
  1142. .name = "sd_emmc_b_clk0",
  1143. .ops = &clk_regmap_gate_ops,
  1144. .parent_names = (const char *[]){ "sd_emmc_b_clk0_div" },
  1145. .num_parents = 1,
  1146. .flags = CLK_SET_RATE_PARENT,
  1147. },
  1148. };
  1149. /* EMMC/NAND clock */
  1150. static struct clk_regmap gxbb_sd_emmc_c_clk0_sel = {
  1151. .data = &(struct clk_regmap_mux_data){
  1152. .offset = HHI_NAND_CLK_CNTL,
  1153. .mask = 0x7,
  1154. .shift = 9,
  1155. },
  1156. .hw.init = &(struct clk_init_data) {
  1157. .name = "sd_emmc_c_clk0_sel",
  1158. .ops = &clk_regmap_mux_ops,
  1159. .parent_names = gxbb_sd_emmc_clk0_parent_names,
  1160. .num_parents = ARRAY_SIZE(gxbb_sd_emmc_clk0_parent_names),
  1161. .flags = CLK_SET_RATE_PARENT,
  1162. },
  1163. };
  1164. static struct clk_regmap gxbb_sd_emmc_c_clk0_div = {
  1165. .data = &(struct clk_regmap_div_data){
  1166. .offset = HHI_NAND_CLK_CNTL,
  1167. .shift = 0,
  1168. .width = 7,
  1169. .flags = CLK_DIVIDER_ROUND_CLOSEST,
  1170. },
  1171. .hw.init = &(struct clk_init_data) {
  1172. .name = "sd_emmc_c_clk0_div",
  1173. .ops = &clk_regmap_divider_ops,
  1174. .parent_names = (const char *[]){ "sd_emmc_c_clk0_sel" },
  1175. .num_parents = 1,
  1176. .flags = CLK_SET_RATE_PARENT,
  1177. },
  1178. };
  1179. static struct clk_regmap gxbb_sd_emmc_c_clk0 = {
  1180. .data = &(struct clk_regmap_gate_data){
  1181. .offset = HHI_NAND_CLK_CNTL,
  1182. .bit_idx = 7,
  1183. },
  1184. .hw.init = &(struct clk_init_data){
  1185. .name = "sd_emmc_c_clk0",
  1186. .ops = &clk_regmap_gate_ops,
  1187. .parent_names = (const char *[]){ "sd_emmc_c_clk0_div" },
  1188. .num_parents = 1,
  1189. .flags = CLK_SET_RATE_PARENT,
  1190. },
  1191. };
  1192. /* VPU Clock */
  1193. static const char * const gxbb_vpu_parent_names[] = {
  1194. "fclk_div4", "fclk_div3", "fclk_div5", "fclk_div7"
  1195. };
  1196. static struct clk_regmap gxbb_vpu_0_sel = {
  1197. .data = &(struct clk_regmap_mux_data){
  1198. .offset = HHI_VPU_CLK_CNTL,
  1199. .mask = 0x3,
  1200. .shift = 9,
  1201. },
  1202. .hw.init = &(struct clk_init_data){
  1203. .name = "vpu_0_sel",
  1204. .ops = &clk_regmap_mux_ops,
  1205. /*
  1206. * bits 9:10 selects from 4 possible parents:
  1207. * fclk_div4, fclk_div3, fclk_div5, fclk_div7,
  1208. */
  1209. .parent_names = gxbb_vpu_parent_names,
  1210. .num_parents = ARRAY_SIZE(gxbb_vpu_parent_names),
  1211. .flags = CLK_SET_RATE_NO_REPARENT,
  1212. },
  1213. };
  1214. static struct clk_regmap gxbb_vpu_0_div = {
  1215. .data = &(struct clk_regmap_div_data){
  1216. .offset = HHI_VPU_CLK_CNTL,
  1217. .shift = 0,
  1218. .width = 7,
  1219. },
  1220. .hw.init = &(struct clk_init_data){
  1221. .name = "vpu_0_div",
  1222. .ops = &clk_regmap_divider_ops,
  1223. .parent_names = (const char *[]){ "vpu_0_sel" },
  1224. .num_parents = 1,
  1225. .flags = CLK_SET_RATE_PARENT,
  1226. },
  1227. };
  1228. static struct clk_regmap gxbb_vpu_0 = {
  1229. .data = &(struct clk_regmap_gate_data){
  1230. .offset = HHI_VPU_CLK_CNTL,
  1231. .bit_idx = 8,
  1232. },
  1233. .hw.init = &(struct clk_init_data) {
  1234. .name = "vpu_0",
  1235. .ops = &clk_regmap_gate_ops,
  1236. .parent_names = (const char *[]){ "vpu_0_div" },
  1237. .num_parents = 1,
  1238. .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
  1239. },
  1240. };
  1241. static struct clk_regmap gxbb_vpu_1_sel = {
  1242. .data = &(struct clk_regmap_mux_data){
  1243. .offset = HHI_VPU_CLK_CNTL,
  1244. .mask = 0x3,
  1245. .shift = 25,
  1246. },
  1247. .hw.init = &(struct clk_init_data){
  1248. .name = "vpu_1_sel",
  1249. .ops = &clk_regmap_mux_ops,
  1250. /*
  1251. * bits 25:26 selects from 4 possible parents:
  1252. * fclk_div4, fclk_div3, fclk_div5, fclk_div7,
  1253. */
  1254. .parent_names = gxbb_vpu_parent_names,
  1255. .num_parents = ARRAY_SIZE(gxbb_vpu_parent_names),
  1256. .flags = CLK_SET_RATE_NO_REPARENT,
  1257. },
  1258. };
  1259. static struct clk_regmap gxbb_vpu_1_div = {
  1260. .data = &(struct clk_regmap_div_data){
  1261. .offset = HHI_VPU_CLK_CNTL,
  1262. .shift = 16,
  1263. .width = 7,
  1264. },
  1265. .hw.init = &(struct clk_init_data){
  1266. .name = "vpu_1_div",
  1267. .ops = &clk_regmap_divider_ops,
  1268. .parent_names = (const char *[]){ "vpu_1_sel" },
  1269. .num_parents = 1,
  1270. .flags = CLK_SET_RATE_PARENT,
  1271. },
  1272. };
  1273. static struct clk_regmap gxbb_vpu_1 = {
  1274. .data = &(struct clk_regmap_gate_data){
  1275. .offset = HHI_VPU_CLK_CNTL,
  1276. .bit_idx = 24,
  1277. },
  1278. .hw.init = &(struct clk_init_data) {
  1279. .name = "vpu_1",
  1280. .ops = &clk_regmap_gate_ops,
  1281. .parent_names = (const char *[]){ "vpu_1_div" },
  1282. .num_parents = 1,
  1283. .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
  1284. },
  1285. };
  1286. static struct clk_regmap gxbb_vpu = {
  1287. .data = &(struct clk_regmap_mux_data){
  1288. .offset = HHI_VPU_CLK_CNTL,
  1289. .mask = 1,
  1290. .shift = 31,
  1291. },
  1292. .hw.init = &(struct clk_init_data){
  1293. .name = "vpu",
  1294. .ops = &clk_regmap_mux_ops,
  1295. /*
  1296. * bit 31 selects from 2 possible parents:
  1297. * vpu_0 or vpu_1
  1298. */
  1299. .parent_names = (const char *[]){ "vpu_0", "vpu_1" },
  1300. .num_parents = 2,
  1301. .flags = CLK_SET_RATE_NO_REPARENT,
  1302. },
  1303. };
  1304. /* VAPB Clock */
  1305. static const char * const gxbb_vapb_parent_names[] = {
  1306. "fclk_div4", "fclk_div3", "fclk_div5", "fclk_div7"
  1307. };
  1308. static struct clk_regmap gxbb_vapb_0_sel = {
  1309. .data = &(struct clk_regmap_mux_data){
  1310. .offset = HHI_VAPBCLK_CNTL,
  1311. .mask = 0x3,
  1312. .shift = 9,
  1313. },
  1314. .hw.init = &(struct clk_init_data){
  1315. .name = "vapb_0_sel",
  1316. .ops = &clk_regmap_mux_ops,
  1317. /*
  1318. * bits 9:10 selects from 4 possible parents:
  1319. * fclk_div4, fclk_div3, fclk_div5, fclk_div7,
  1320. */
  1321. .parent_names = gxbb_vapb_parent_names,
  1322. .num_parents = ARRAY_SIZE(gxbb_vapb_parent_names),
  1323. .flags = CLK_SET_RATE_NO_REPARENT,
  1324. },
  1325. };
  1326. static struct clk_regmap gxbb_vapb_0_div = {
  1327. .data = &(struct clk_regmap_div_data){
  1328. .offset = HHI_VAPBCLK_CNTL,
  1329. .shift = 0,
  1330. .width = 7,
  1331. },
  1332. .hw.init = &(struct clk_init_data){
  1333. .name = "vapb_0_div",
  1334. .ops = &clk_regmap_divider_ops,
  1335. .parent_names = (const char *[]){ "vapb_0_sel" },
  1336. .num_parents = 1,
  1337. .flags = CLK_SET_RATE_PARENT,
  1338. },
  1339. };
  1340. static struct clk_regmap gxbb_vapb_0 = {
  1341. .data = &(struct clk_regmap_gate_data){
  1342. .offset = HHI_VAPBCLK_CNTL,
  1343. .bit_idx = 8,
  1344. },
  1345. .hw.init = &(struct clk_init_data) {
  1346. .name = "vapb_0",
  1347. .ops = &clk_regmap_gate_ops,
  1348. .parent_names = (const char *[]){ "vapb_0_div" },
  1349. .num_parents = 1,
  1350. .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
  1351. },
  1352. };
  1353. static struct clk_regmap gxbb_vapb_1_sel = {
  1354. .data = &(struct clk_regmap_mux_data){
  1355. .offset = HHI_VAPBCLK_CNTL,
  1356. .mask = 0x3,
  1357. .shift = 25,
  1358. },
  1359. .hw.init = &(struct clk_init_data){
  1360. .name = "vapb_1_sel",
  1361. .ops = &clk_regmap_mux_ops,
  1362. /*
  1363. * bits 25:26 selects from 4 possible parents:
  1364. * fclk_div4, fclk_div3, fclk_div5, fclk_div7,
  1365. */
  1366. .parent_names = gxbb_vapb_parent_names,
  1367. .num_parents = ARRAY_SIZE(gxbb_vapb_parent_names),
  1368. .flags = CLK_SET_RATE_NO_REPARENT,
  1369. },
  1370. };
  1371. static struct clk_regmap gxbb_vapb_1_div = {
  1372. .data = &(struct clk_regmap_div_data){
  1373. .offset = HHI_VAPBCLK_CNTL,
  1374. .shift = 16,
  1375. .width = 7,
  1376. },
  1377. .hw.init = &(struct clk_init_data){
  1378. .name = "vapb_1_div",
  1379. .ops = &clk_regmap_divider_ops,
  1380. .parent_names = (const char *[]){ "vapb_1_sel" },
  1381. .num_parents = 1,
  1382. .flags = CLK_SET_RATE_PARENT,
  1383. },
  1384. };
  1385. static struct clk_regmap gxbb_vapb_1 = {
  1386. .data = &(struct clk_regmap_gate_data){
  1387. .offset = HHI_VAPBCLK_CNTL,
  1388. .bit_idx = 24,
  1389. },
  1390. .hw.init = &(struct clk_init_data) {
  1391. .name = "vapb_1",
  1392. .ops = &clk_regmap_gate_ops,
  1393. .parent_names = (const char *[]){ "vapb_1_div" },
  1394. .num_parents = 1,
  1395. .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
  1396. },
  1397. };
  1398. static struct clk_regmap gxbb_vapb_sel = {
  1399. .data = &(struct clk_regmap_mux_data){
  1400. .offset = HHI_VAPBCLK_CNTL,
  1401. .mask = 1,
  1402. .shift = 31,
  1403. },
  1404. .hw.init = &(struct clk_init_data){
  1405. .name = "vapb_sel",
  1406. .ops = &clk_regmap_mux_ops,
  1407. /*
  1408. * bit 31 selects from 2 possible parents:
  1409. * vapb_0 or vapb_1
  1410. */
  1411. .parent_names = (const char *[]){ "vapb_0", "vapb_1" },
  1412. .num_parents = 2,
  1413. .flags = CLK_SET_RATE_NO_REPARENT,
  1414. },
  1415. };
  1416. static struct clk_regmap gxbb_vapb = {
  1417. .data = &(struct clk_regmap_gate_data){
  1418. .offset = HHI_VAPBCLK_CNTL,
  1419. .bit_idx = 30,
  1420. },
  1421. .hw.init = &(struct clk_init_data) {
  1422. .name = "vapb",
  1423. .ops = &clk_regmap_gate_ops,
  1424. .parent_names = (const char *[]){ "vapb_sel" },
  1425. .num_parents = 1,
  1426. .flags = CLK_SET_RATE_PARENT | CLK_IGNORE_UNUSED,
  1427. },
  1428. };
  1429. /* VDEC clocks */
  1430. static const char * const gxbb_vdec_parent_names[] = {
  1431. "fclk_div4", "fclk_div3", "fclk_div5", "fclk_div7"
  1432. };
  1433. static struct clk_regmap gxbb_vdec_1_sel = {
  1434. .data = &(struct clk_regmap_mux_data){
  1435. .offset = HHI_VDEC_CLK_CNTL,
  1436. .mask = 0x3,
  1437. .shift = 9,
  1438. .flags = CLK_MUX_ROUND_CLOSEST,
  1439. },
  1440. .hw.init = &(struct clk_init_data){
  1441. .name = "vdec_1_sel",
  1442. .ops = &clk_regmap_mux_ops,
  1443. .parent_names = gxbb_vdec_parent_names,
  1444. .num_parents = ARRAY_SIZE(gxbb_vdec_parent_names),
  1445. .flags = CLK_SET_RATE_PARENT,
  1446. },
  1447. };
  1448. static struct clk_regmap gxbb_vdec_1_div = {
  1449. .data = &(struct clk_regmap_div_data){
  1450. .offset = HHI_VDEC_CLK_CNTL,
  1451. .shift = 0,
  1452. .width = 7,
  1453. },
  1454. .hw.init = &(struct clk_init_data){
  1455. .name = "vdec_1_div",
  1456. .ops = &clk_regmap_divider_ops,
  1457. .parent_names = (const char *[]){ "vdec_1_sel" },
  1458. .num_parents = 1,
  1459. .flags = CLK_SET_RATE_PARENT,
  1460. },
  1461. };
  1462. static struct clk_regmap gxbb_vdec_1 = {
  1463. .data = &(struct clk_regmap_gate_data){
  1464. .offset = HHI_VDEC_CLK_CNTL,
  1465. .bit_idx = 8,
  1466. },
  1467. .hw.init = &(struct clk_init_data) {
  1468. .name = "vdec_1",
  1469. .ops = &clk_regmap_gate_ops,
  1470. .parent_names = (const char *[]){ "vdec_1_div" },
  1471. .num_parents = 1,
  1472. .flags = CLK_SET_RATE_PARENT,
  1473. },
  1474. };
  1475. static struct clk_regmap gxbb_vdec_hevc_sel = {
  1476. .data = &(struct clk_regmap_mux_data){
  1477. .offset = HHI_VDEC2_CLK_CNTL,
  1478. .mask = 0x3,
  1479. .shift = 25,
  1480. .flags = CLK_MUX_ROUND_CLOSEST,
  1481. },
  1482. .hw.init = &(struct clk_init_data){
  1483. .name = "vdec_hevc_sel",
  1484. .ops = &clk_regmap_mux_ops,
  1485. .parent_names = gxbb_vdec_parent_names,
  1486. .num_parents = ARRAY_SIZE(gxbb_vdec_parent_names),
  1487. .flags = CLK_SET_RATE_PARENT,
  1488. },
  1489. };
  1490. static struct clk_regmap gxbb_vdec_hevc_div = {
  1491. .data = &(struct clk_regmap_div_data){
  1492. .offset = HHI_VDEC2_CLK_CNTL,
  1493. .shift = 16,
  1494. .width = 7,
  1495. },
  1496. .hw.init = &(struct clk_init_data){
  1497. .name = "vdec_hevc_div",
  1498. .ops = &clk_regmap_divider_ops,
  1499. .parent_names = (const char *[]){ "vdec_hevc_sel" },
  1500. .num_parents = 1,
  1501. .flags = CLK_SET_RATE_PARENT,
  1502. },
  1503. };
  1504. static struct clk_regmap gxbb_vdec_hevc = {
  1505. .data = &(struct clk_regmap_gate_data){
  1506. .offset = HHI_VDEC2_CLK_CNTL,
  1507. .bit_idx = 24,
  1508. },
  1509. .hw.init = &(struct clk_init_data) {
  1510. .name = "vdec_hevc",
  1511. .ops = &clk_regmap_gate_ops,
  1512. .parent_names = (const char *[]){ "vdec_hevc_div" },
  1513. .num_parents = 1,
  1514. .flags = CLK_SET_RATE_PARENT,
  1515. },
  1516. };
  1517. static u32 mux_table_gen_clk[] = { 0, 4, 5, 6, 7, 8,
  1518. 9, 10, 11, 13, 14, };
  1519. static const char * const gen_clk_parent_names[] = {
  1520. "xtal", "vdec_1", "vdec_hevc", "mpll0", "mpll1", "mpll2",
  1521. "fclk_div4", "fclk_div3", "fclk_div5", "fclk_div7", "gp0_pll",
  1522. };
  1523. static struct clk_regmap gxbb_gen_clk_sel = {
  1524. .data = &(struct clk_regmap_mux_data){
  1525. .offset = HHI_GEN_CLK_CNTL,
  1526. .mask = 0xf,
  1527. .shift = 12,
  1528. .table = mux_table_gen_clk,
  1529. },
  1530. .hw.init = &(struct clk_init_data){
  1531. .name = "gen_clk_sel",
  1532. .ops = &clk_regmap_mux_ops,
  1533. /*
  1534. * bits 15:12 selects from 14 possible parents:
  1535. * xtal, [rtc_oscin_i], [sys_cpu_div16], [ddr_dpll_pt],
  1536. * vid_pll, vid2_pll (hevc), mpll0, mpll1, mpll2, fdiv4,
  1537. * fdiv3, fdiv5, [cts_msr_clk], fdiv7, gp0_pll
  1538. */
  1539. .parent_names = gen_clk_parent_names,
  1540. .num_parents = ARRAY_SIZE(gen_clk_parent_names),
  1541. },
  1542. };
  1543. static struct clk_regmap gxbb_gen_clk_div = {
  1544. .data = &(struct clk_regmap_div_data){
  1545. .offset = HHI_GEN_CLK_CNTL,
  1546. .shift = 0,
  1547. .width = 11,
  1548. },
  1549. .hw.init = &(struct clk_init_data){
  1550. .name = "gen_clk_div",
  1551. .ops = &clk_regmap_divider_ops,
  1552. .parent_names = (const char *[]){ "gen_clk_sel" },
  1553. .num_parents = 1,
  1554. .flags = CLK_SET_RATE_PARENT,
  1555. },
  1556. };
  1557. static struct clk_regmap gxbb_gen_clk = {
  1558. .data = &(struct clk_regmap_gate_data){
  1559. .offset = HHI_GEN_CLK_CNTL,
  1560. .bit_idx = 7,
  1561. },
  1562. .hw.init = &(struct clk_init_data){
  1563. .name = "gen_clk",
  1564. .ops = &clk_regmap_gate_ops,
  1565. .parent_names = (const char *[]){ "gen_clk_div" },
  1566. .num_parents = 1,
  1567. .flags = CLK_SET_RATE_PARENT,
  1568. },
  1569. };
  1570. /* Everything Else (EE) domain gates */
  1571. static MESON_GATE(gxbb_ddr, HHI_GCLK_MPEG0, 0);
  1572. static MESON_GATE(gxbb_dos, HHI_GCLK_MPEG0, 1);
  1573. static MESON_GATE(gxbb_isa, HHI_GCLK_MPEG0, 5);
  1574. static MESON_GATE(gxbb_pl301, HHI_GCLK_MPEG0, 6);
  1575. static MESON_GATE(gxbb_periphs, HHI_GCLK_MPEG0, 7);
  1576. static MESON_GATE(gxbb_spicc, HHI_GCLK_MPEG0, 8);
  1577. static MESON_GATE(gxbb_i2c, HHI_GCLK_MPEG0, 9);
  1578. static MESON_GATE(gxbb_sana, HHI_GCLK_MPEG0, 10);
  1579. static MESON_GATE(gxbb_smart_card, HHI_GCLK_MPEG0, 11);
  1580. static MESON_GATE(gxbb_rng0, HHI_GCLK_MPEG0, 12);
  1581. static MESON_GATE(gxbb_uart0, HHI_GCLK_MPEG0, 13);
  1582. static MESON_GATE(gxbb_sdhc, HHI_GCLK_MPEG0, 14);
  1583. static MESON_GATE(gxbb_stream, HHI_GCLK_MPEG0, 15);
  1584. static MESON_GATE(gxbb_async_fifo, HHI_GCLK_MPEG0, 16);
  1585. static MESON_GATE(gxbb_sdio, HHI_GCLK_MPEG0, 17);
  1586. static MESON_GATE(gxbb_abuf, HHI_GCLK_MPEG0, 18);
  1587. static MESON_GATE(gxbb_hiu_iface, HHI_GCLK_MPEG0, 19);
  1588. static MESON_GATE(gxbb_assist_misc, HHI_GCLK_MPEG0, 23);
  1589. static MESON_GATE(gxbb_emmc_a, HHI_GCLK_MPEG0, 24);
  1590. static MESON_GATE(gxbb_emmc_b, HHI_GCLK_MPEG0, 25);
  1591. static MESON_GATE(gxbb_emmc_c, HHI_GCLK_MPEG0, 26);
  1592. static MESON_GATE(gxbb_spi, HHI_GCLK_MPEG0, 30);
  1593. static MESON_GATE(gxbb_i2s_spdif, HHI_GCLK_MPEG1, 2);
  1594. static MESON_GATE(gxbb_eth, HHI_GCLK_MPEG1, 3);
  1595. static MESON_GATE(gxbb_demux, HHI_GCLK_MPEG1, 4);
  1596. static MESON_GATE(gxbb_aiu_glue, HHI_GCLK_MPEG1, 6);
  1597. static MESON_GATE(gxbb_iec958, HHI_GCLK_MPEG1, 7);
  1598. static MESON_GATE(gxbb_i2s_out, HHI_GCLK_MPEG1, 8);
  1599. static MESON_GATE(gxbb_amclk, HHI_GCLK_MPEG1, 9);
  1600. static MESON_GATE(gxbb_aififo2, HHI_GCLK_MPEG1, 10);
  1601. static MESON_GATE(gxbb_mixer, HHI_GCLK_MPEG1, 11);
  1602. static MESON_GATE(gxbb_mixer_iface, HHI_GCLK_MPEG1, 12);
  1603. static MESON_GATE(gxbb_adc, HHI_GCLK_MPEG1, 13);
  1604. static MESON_GATE(gxbb_blkmv, HHI_GCLK_MPEG1, 14);
  1605. static MESON_GATE(gxbb_aiu, HHI_GCLK_MPEG1, 15);
  1606. static MESON_GATE(gxbb_uart1, HHI_GCLK_MPEG1, 16);
  1607. static MESON_GATE(gxbb_g2d, HHI_GCLK_MPEG1, 20);
  1608. static MESON_GATE(gxbb_usb0, HHI_GCLK_MPEG1, 21);
  1609. static MESON_GATE(gxbb_usb1, HHI_GCLK_MPEG1, 22);
  1610. static MESON_GATE(gxbb_reset, HHI_GCLK_MPEG1, 23);
  1611. static MESON_GATE(gxbb_nand, HHI_GCLK_MPEG1, 24);
  1612. static MESON_GATE(gxbb_dos_parser, HHI_GCLK_MPEG1, 25);
  1613. static MESON_GATE(gxbb_usb, HHI_GCLK_MPEG1, 26);
  1614. static MESON_GATE(gxbb_vdin1, HHI_GCLK_MPEG1, 28);
  1615. static MESON_GATE(gxbb_ahb_arb0, HHI_GCLK_MPEG1, 29);
  1616. static MESON_GATE(gxbb_efuse, HHI_GCLK_MPEG1, 30);
  1617. static MESON_GATE(gxbb_boot_rom, HHI_GCLK_MPEG1, 31);
  1618. static MESON_GATE(gxbb_ahb_data_bus, HHI_GCLK_MPEG2, 1);
  1619. static MESON_GATE(gxbb_ahb_ctrl_bus, HHI_GCLK_MPEG2, 2);
  1620. static MESON_GATE(gxbb_hdmi_intr_sync, HHI_GCLK_MPEG2, 3);
  1621. static MESON_GATE(gxbb_hdmi_pclk, HHI_GCLK_MPEG2, 4);
  1622. static MESON_GATE(gxbb_usb1_ddr_bridge, HHI_GCLK_MPEG2, 8);
  1623. static MESON_GATE(gxbb_usb0_ddr_bridge, HHI_GCLK_MPEG2, 9);
  1624. static MESON_GATE(gxbb_mmc_pclk, HHI_GCLK_MPEG2, 11);
  1625. static MESON_GATE(gxbb_dvin, HHI_GCLK_MPEG2, 12);
  1626. static MESON_GATE(gxbb_uart2, HHI_GCLK_MPEG2, 15);
  1627. static MESON_GATE(gxbb_sar_adc, HHI_GCLK_MPEG2, 22);
  1628. static MESON_GATE(gxbb_vpu_intr, HHI_GCLK_MPEG2, 25);
  1629. static MESON_GATE(gxbb_sec_ahb_ahb3_bridge, HHI_GCLK_MPEG2, 26);
  1630. static MESON_GATE(gxbb_clk81_a53, HHI_GCLK_MPEG2, 29);
  1631. static MESON_GATE(gxbb_vclk2_venci0, HHI_GCLK_OTHER, 1);
  1632. static MESON_GATE(gxbb_vclk2_venci1, HHI_GCLK_OTHER, 2);
  1633. static MESON_GATE(gxbb_vclk2_vencp0, HHI_GCLK_OTHER, 3);
  1634. static MESON_GATE(gxbb_vclk2_vencp1, HHI_GCLK_OTHER, 4);
  1635. static MESON_GATE(gxbb_gclk_venci_int0, HHI_GCLK_OTHER, 8);
  1636. static MESON_GATE(gxbb_gclk_vencp_int, HHI_GCLK_OTHER, 9);
  1637. static MESON_GATE(gxbb_dac_clk, HHI_GCLK_OTHER, 10);
  1638. static MESON_GATE(gxbb_aoclk_gate, HHI_GCLK_OTHER, 14);
  1639. static MESON_GATE(gxbb_iec958_gate, HHI_GCLK_OTHER, 16);
  1640. static MESON_GATE(gxbb_enc480p, HHI_GCLK_OTHER, 20);
  1641. static MESON_GATE(gxbb_rng1, HHI_GCLK_OTHER, 21);
  1642. static MESON_GATE(gxbb_gclk_venci_int1, HHI_GCLK_OTHER, 22);
  1643. static MESON_GATE(gxbb_vclk2_venclmcc, HHI_GCLK_OTHER, 24);
  1644. static MESON_GATE(gxbb_vclk2_vencl, HHI_GCLK_OTHER, 25);
  1645. static MESON_GATE(gxbb_vclk_other, HHI_GCLK_OTHER, 26);
  1646. static MESON_GATE(gxbb_edp, HHI_GCLK_OTHER, 31);
  1647. /* Always On (AO) domain gates */
  1648. static MESON_GATE(gxbb_ao_media_cpu, HHI_GCLK_AO, 0);
  1649. static MESON_GATE(gxbb_ao_ahb_sram, HHI_GCLK_AO, 1);
  1650. static MESON_GATE(gxbb_ao_ahb_bus, HHI_GCLK_AO, 2);
  1651. static MESON_GATE(gxbb_ao_iface, HHI_GCLK_AO, 3);
  1652. static MESON_GATE(gxbb_ao_i2c, HHI_GCLK_AO, 4);
  1653. /* Array of all clocks provided by this provider */
  1654. static struct clk_hw_onecell_data gxbb_hw_onecell_data = {
  1655. .hws = {
  1656. [CLKID_SYS_PLL] = &gxbb_sys_pll.hw,
  1657. [CLKID_HDMI_PLL] = &gxbb_hdmi_pll.hw,
  1658. [CLKID_FIXED_PLL] = &gxbb_fixed_pll.hw,
  1659. [CLKID_FCLK_DIV2] = &gxbb_fclk_div2.hw,
  1660. [CLKID_FCLK_DIV3] = &gxbb_fclk_div3.hw,
  1661. [CLKID_FCLK_DIV4] = &gxbb_fclk_div4.hw,
  1662. [CLKID_FCLK_DIV5] = &gxbb_fclk_div5.hw,
  1663. [CLKID_FCLK_DIV7] = &gxbb_fclk_div7.hw,
  1664. [CLKID_GP0_PLL] = &gxbb_gp0_pll.hw,
  1665. [CLKID_MPEG_SEL] = &gxbb_mpeg_clk_sel.hw,
  1666. [CLKID_MPEG_DIV] = &gxbb_mpeg_clk_div.hw,
  1667. [CLKID_CLK81] = &gxbb_clk81.hw,
  1668. [CLKID_MPLL0] = &gxbb_mpll0.hw,
  1669. [CLKID_MPLL1] = &gxbb_mpll1.hw,
  1670. [CLKID_MPLL2] = &gxbb_mpll2.hw,
  1671. [CLKID_DDR] = &gxbb_ddr.hw,
  1672. [CLKID_DOS] = &gxbb_dos.hw,
  1673. [CLKID_ISA] = &gxbb_isa.hw,
  1674. [CLKID_PL301] = &gxbb_pl301.hw,
  1675. [CLKID_PERIPHS] = &gxbb_periphs.hw,
  1676. [CLKID_SPICC] = &gxbb_spicc.hw,
  1677. [CLKID_I2C] = &gxbb_i2c.hw,
  1678. [CLKID_SAR_ADC] = &gxbb_sar_adc.hw,
  1679. [CLKID_SMART_CARD] = &gxbb_smart_card.hw,
  1680. [CLKID_RNG0] = &gxbb_rng0.hw,
  1681. [CLKID_UART0] = &gxbb_uart0.hw,
  1682. [CLKID_SDHC] = &gxbb_sdhc.hw,
  1683. [CLKID_STREAM] = &gxbb_stream.hw,
  1684. [CLKID_ASYNC_FIFO] = &gxbb_async_fifo.hw,
  1685. [CLKID_SDIO] = &gxbb_sdio.hw,
  1686. [CLKID_ABUF] = &gxbb_abuf.hw,
  1687. [CLKID_HIU_IFACE] = &gxbb_hiu_iface.hw,
  1688. [CLKID_ASSIST_MISC] = &gxbb_assist_misc.hw,
  1689. [CLKID_SPI] = &gxbb_spi.hw,
  1690. [CLKID_I2S_SPDIF] = &gxbb_i2s_spdif.hw,
  1691. [CLKID_ETH] = &gxbb_eth.hw,
  1692. [CLKID_DEMUX] = &gxbb_demux.hw,
  1693. [CLKID_AIU_GLUE] = &gxbb_aiu_glue.hw,
  1694. [CLKID_IEC958] = &gxbb_iec958.hw,
  1695. [CLKID_I2S_OUT] = &gxbb_i2s_out.hw,
  1696. [CLKID_AMCLK] = &gxbb_amclk.hw,
  1697. [CLKID_AIFIFO2] = &gxbb_aififo2.hw,
  1698. [CLKID_MIXER] = &gxbb_mixer.hw,
  1699. [CLKID_MIXER_IFACE] = &gxbb_mixer_iface.hw,
  1700. [CLKID_ADC] = &gxbb_adc.hw,
  1701. [CLKID_BLKMV] = &gxbb_blkmv.hw,
  1702. [CLKID_AIU] = &gxbb_aiu.hw,
  1703. [CLKID_UART1] = &gxbb_uart1.hw,
  1704. [CLKID_G2D] = &gxbb_g2d.hw,
  1705. [CLKID_USB0] = &gxbb_usb0.hw,
  1706. [CLKID_USB1] = &gxbb_usb1.hw,
  1707. [CLKID_RESET] = &gxbb_reset.hw,
  1708. [CLKID_NAND] = &gxbb_nand.hw,
  1709. [CLKID_DOS_PARSER] = &gxbb_dos_parser.hw,
  1710. [CLKID_USB] = &gxbb_usb.hw,
  1711. [CLKID_VDIN1] = &gxbb_vdin1.hw,
  1712. [CLKID_AHB_ARB0] = &gxbb_ahb_arb0.hw,
  1713. [CLKID_EFUSE] = &gxbb_efuse.hw,
  1714. [CLKID_BOOT_ROM] = &gxbb_boot_rom.hw,
  1715. [CLKID_AHB_DATA_BUS] = &gxbb_ahb_data_bus.hw,
  1716. [CLKID_AHB_CTRL_BUS] = &gxbb_ahb_ctrl_bus.hw,
  1717. [CLKID_HDMI_INTR_SYNC] = &gxbb_hdmi_intr_sync.hw,
  1718. [CLKID_HDMI_PCLK] = &gxbb_hdmi_pclk.hw,
  1719. [CLKID_USB1_DDR_BRIDGE] = &gxbb_usb1_ddr_bridge.hw,
  1720. [CLKID_USB0_DDR_BRIDGE] = &gxbb_usb0_ddr_bridge.hw,
  1721. [CLKID_MMC_PCLK] = &gxbb_mmc_pclk.hw,
  1722. [CLKID_DVIN] = &gxbb_dvin.hw,
  1723. [CLKID_UART2] = &gxbb_uart2.hw,
  1724. [CLKID_SANA] = &gxbb_sana.hw,
  1725. [CLKID_VPU_INTR] = &gxbb_vpu_intr.hw,
  1726. [CLKID_SEC_AHB_AHB3_BRIDGE] = &gxbb_sec_ahb_ahb3_bridge.hw,
  1727. [CLKID_CLK81_A53] = &gxbb_clk81_a53.hw,
  1728. [CLKID_VCLK2_VENCI0] = &gxbb_vclk2_venci0.hw,
  1729. [CLKID_VCLK2_VENCI1] = &gxbb_vclk2_venci1.hw,
  1730. [CLKID_VCLK2_VENCP0] = &gxbb_vclk2_vencp0.hw,
  1731. [CLKID_VCLK2_VENCP1] = &gxbb_vclk2_vencp1.hw,
  1732. [CLKID_GCLK_VENCI_INT0] = &gxbb_gclk_venci_int0.hw,
  1733. [CLKID_GCLK_VENCI_INT] = &gxbb_gclk_vencp_int.hw,
  1734. [CLKID_DAC_CLK] = &gxbb_dac_clk.hw,
  1735. [CLKID_AOCLK_GATE] = &gxbb_aoclk_gate.hw,
  1736. [CLKID_IEC958_GATE] = &gxbb_iec958_gate.hw,
  1737. [CLKID_ENC480P] = &gxbb_enc480p.hw,
  1738. [CLKID_RNG1] = &gxbb_rng1.hw,
  1739. [CLKID_GCLK_VENCI_INT1] = &gxbb_gclk_venci_int1.hw,
  1740. [CLKID_VCLK2_VENCLMCC] = &gxbb_vclk2_venclmcc.hw,
  1741. [CLKID_VCLK2_VENCL] = &gxbb_vclk2_vencl.hw,
  1742. [CLKID_VCLK_OTHER] = &gxbb_vclk_other.hw,
  1743. [CLKID_EDP] = &gxbb_edp.hw,
  1744. [CLKID_AO_MEDIA_CPU] = &gxbb_ao_media_cpu.hw,
  1745. [CLKID_AO_AHB_SRAM] = &gxbb_ao_ahb_sram.hw,
  1746. [CLKID_AO_AHB_BUS] = &gxbb_ao_ahb_bus.hw,
  1747. [CLKID_AO_IFACE] = &gxbb_ao_iface.hw,
  1748. [CLKID_AO_I2C] = &gxbb_ao_i2c.hw,
  1749. [CLKID_SD_EMMC_A] = &gxbb_emmc_a.hw,
  1750. [CLKID_SD_EMMC_B] = &gxbb_emmc_b.hw,
  1751. [CLKID_SD_EMMC_C] = &gxbb_emmc_c.hw,
  1752. [CLKID_SAR_ADC_CLK] = &gxbb_sar_adc_clk.hw,
  1753. [CLKID_SAR_ADC_SEL] = &gxbb_sar_adc_clk_sel.hw,
  1754. [CLKID_SAR_ADC_DIV] = &gxbb_sar_adc_clk_div.hw,
  1755. [CLKID_MALI_0_SEL] = &gxbb_mali_0_sel.hw,
  1756. [CLKID_MALI_0_DIV] = &gxbb_mali_0_div.hw,
  1757. [CLKID_MALI_0] = &gxbb_mali_0.hw,
  1758. [CLKID_MALI_1_SEL] = &gxbb_mali_1_sel.hw,
  1759. [CLKID_MALI_1_DIV] = &gxbb_mali_1_div.hw,
  1760. [CLKID_MALI_1] = &gxbb_mali_1.hw,
  1761. [CLKID_MALI] = &gxbb_mali.hw,
  1762. [CLKID_CTS_AMCLK] = &gxbb_cts_amclk.hw,
  1763. [CLKID_CTS_AMCLK_SEL] = &gxbb_cts_amclk_sel.hw,
  1764. [CLKID_CTS_AMCLK_DIV] = &gxbb_cts_amclk_div.hw,
  1765. [CLKID_CTS_MCLK_I958] = &gxbb_cts_mclk_i958.hw,
  1766. [CLKID_CTS_MCLK_I958_SEL] = &gxbb_cts_mclk_i958_sel.hw,
  1767. [CLKID_CTS_MCLK_I958_DIV] = &gxbb_cts_mclk_i958_div.hw,
  1768. [CLKID_CTS_I958] = &gxbb_cts_i958.hw,
  1769. [CLKID_32K_CLK] = &gxbb_32k_clk.hw,
  1770. [CLKID_32K_CLK_SEL] = &gxbb_32k_clk_sel.hw,
  1771. [CLKID_32K_CLK_DIV] = &gxbb_32k_clk_div.hw,
  1772. [CLKID_SD_EMMC_A_CLK0_SEL] = &gxbb_sd_emmc_a_clk0_sel.hw,
  1773. [CLKID_SD_EMMC_A_CLK0_DIV] = &gxbb_sd_emmc_a_clk0_div.hw,
  1774. [CLKID_SD_EMMC_A_CLK0] = &gxbb_sd_emmc_a_clk0.hw,
  1775. [CLKID_SD_EMMC_B_CLK0_SEL] = &gxbb_sd_emmc_b_clk0_sel.hw,
  1776. [CLKID_SD_EMMC_B_CLK0_DIV] = &gxbb_sd_emmc_b_clk0_div.hw,
  1777. [CLKID_SD_EMMC_B_CLK0] = &gxbb_sd_emmc_b_clk0.hw,
  1778. [CLKID_SD_EMMC_C_CLK0_SEL] = &gxbb_sd_emmc_c_clk0_sel.hw,
  1779. [CLKID_SD_EMMC_C_CLK0_DIV] = &gxbb_sd_emmc_c_clk0_div.hw,
  1780. [CLKID_SD_EMMC_C_CLK0] = &gxbb_sd_emmc_c_clk0.hw,
  1781. [CLKID_VPU_0_SEL] = &gxbb_vpu_0_sel.hw,
  1782. [CLKID_VPU_0_DIV] = &gxbb_vpu_0_div.hw,
  1783. [CLKID_VPU_0] = &gxbb_vpu_0.hw,
  1784. [CLKID_VPU_1_SEL] = &gxbb_vpu_1_sel.hw,
  1785. [CLKID_VPU_1_DIV] = &gxbb_vpu_1_div.hw,
  1786. [CLKID_VPU_1] = &gxbb_vpu_1.hw,
  1787. [CLKID_VPU] = &gxbb_vpu.hw,
  1788. [CLKID_VAPB_0_SEL] = &gxbb_vapb_0_sel.hw,
  1789. [CLKID_VAPB_0_DIV] = &gxbb_vapb_0_div.hw,
  1790. [CLKID_VAPB_0] = &gxbb_vapb_0.hw,
  1791. [CLKID_VAPB_1_SEL] = &gxbb_vapb_1_sel.hw,
  1792. [CLKID_VAPB_1_DIV] = &gxbb_vapb_1_div.hw,
  1793. [CLKID_VAPB_1] = &gxbb_vapb_1.hw,
  1794. [CLKID_VAPB_SEL] = &gxbb_vapb_sel.hw,
  1795. [CLKID_VAPB] = &gxbb_vapb.hw,
  1796. [CLKID_HDMI_PLL_PRE_MULT] = &gxbb_hdmi_pll_pre_mult.hw,
  1797. [CLKID_MPLL0_DIV] = &gxbb_mpll0_div.hw,
  1798. [CLKID_MPLL1_DIV] = &gxbb_mpll1_div.hw,
  1799. [CLKID_MPLL2_DIV] = &gxbb_mpll2_div.hw,
  1800. [CLKID_MPLL_PREDIV] = &gxbb_mpll_prediv.hw,
  1801. [CLKID_FCLK_DIV2_DIV] = &gxbb_fclk_div2_div.hw,
  1802. [CLKID_FCLK_DIV3_DIV] = &gxbb_fclk_div3_div.hw,
  1803. [CLKID_FCLK_DIV4_DIV] = &gxbb_fclk_div4_div.hw,
  1804. [CLKID_FCLK_DIV5_DIV] = &gxbb_fclk_div5_div.hw,
  1805. [CLKID_FCLK_DIV7_DIV] = &gxbb_fclk_div7_div.hw,
  1806. [CLKID_VDEC_1_SEL] = &gxbb_vdec_1_sel.hw,
  1807. [CLKID_VDEC_1_DIV] = &gxbb_vdec_1_div.hw,
  1808. [CLKID_VDEC_1] = &gxbb_vdec_1.hw,
  1809. [CLKID_VDEC_HEVC_SEL] = &gxbb_vdec_hevc_sel.hw,
  1810. [CLKID_VDEC_HEVC_DIV] = &gxbb_vdec_hevc_div.hw,
  1811. [CLKID_VDEC_HEVC] = &gxbb_vdec_hevc.hw,
  1812. [CLKID_GEN_CLK_SEL] = &gxbb_gen_clk_sel.hw,
  1813. [CLKID_GEN_CLK_DIV] = &gxbb_gen_clk_div.hw,
  1814. [CLKID_GEN_CLK] = &gxbb_gen_clk.hw,
  1815. [CLKID_FIXED_PLL_DCO] = &gxbb_fixed_pll_dco.hw,
  1816. [CLKID_HDMI_PLL_DCO] = &gxbb_hdmi_pll_dco.hw,
  1817. [CLKID_HDMI_PLL_OD] = &gxbb_hdmi_pll_od.hw,
  1818. [CLKID_HDMI_PLL_OD2] = &gxbb_hdmi_pll_od2.hw,
  1819. [CLKID_SYS_PLL_DCO] = &gxbb_sys_pll_dco.hw,
  1820. [CLKID_GP0_PLL_DCO] = &gxbb_gp0_pll_dco.hw,
  1821. [NR_CLKS] = NULL,
  1822. },
  1823. .num = NR_CLKS,
  1824. };
  1825. static struct clk_hw_onecell_data gxl_hw_onecell_data = {
  1826. .hws = {
  1827. [CLKID_SYS_PLL] = &gxbb_sys_pll.hw,
  1828. [CLKID_HDMI_PLL] = &gxl_hdmi_pll.hw,
  1829. [CLKID_FIXED_PLL] = &gxbb_fixed_pll.hw,
  1830. [CLKID_FCLK_DIV2] = &gxbb_fclk_div2.hw,
  1831. [CLKID_FCLK_DIV3] = &gxbb_fclk_div3.hw,
  1832. [CLKID_FCLK_DIV4] = &gxbb_fclk_div4.hw,
  1833. [CLKID_FCLK_DIV5] = &gxbb_fclk_div5.hw,
  1834. [CLKID_FCLK_DIV7] = &gxbb_fclk_div7.hw,
  1835. [CLKID_GP0_PLL] = &gxbb_gp0_pll.hw,
  1836. [CLKID_MPEG_SEL] = &gxbb_mpeg_clk_sel.hw,
  1837. [CLKID_MPEG_DIV] = &gxbb_mpeg_clk_div.hw,
  1838. [CLKID_CLK81] = &gxbb_clk81.hw,
  1839. [CLKID_MPLL0] = &gxbb_mpll0.hw,
  1840. [CLKID_MPLL1] = &gxbb_mpll1.hw,
  1841. [CLKID_MPLL2] = &gxbb_mpll2.hw,
  1842. [CLKID_DDR] = &gxbb_ddr.hw,
  1843. [CLKID_DOS] = &gxbb_dos.hw,
  1844. [CLKID_ISA] = &gxbb_isa.hw,
  1845. [CLKID_PL301] = &gxbb_pl301.hw,
  1846. [CLKID_PERIPHS] = &gxbb_periphs.hw,
  1847. [CLKID_SPICC] = &gxbb_spicc.hw,
  1848. [CLKID_I2C] = &gxbb_i2c.hw,
  1849. [CLKID_SAR_ADC] = &gxbb_sar_adc.hw,
  1850. [CLKID_SMART_CARD] = &gxbb_smart_card.hw,
  1851. [CLKID_RNG0] = &gxbb_rng0.hw,
  1852. [CLKID_UART0] = &gxbb_uart0.hw,
  1853. [CLKID_SDHC] = &gxbb_sdhc.hw,
  1854. [CLKID_STREAM] = &gxbb_stream.hw,
  1855. [CLKID_ASYNC_FIFO] = &gxbb_async_fifo.hw,
  1856. [CLKID_SDIO] = &gxbb_sdio.hw,
  1857. [CLKID_ABUF] = &gxbb_abuf.hw,
  1858. [CLKID_HIU_IFACE] = &gxbb_hiu_iface.hw,
  1859. [CLKID_ASSIST_MISC] = &gxbb_assist_misc.hw,
  1860. [CLKID_SPI] = &gxbb_spi.hw,
  1861. [CLKID_I2S_SPDIF] = &gxbb_i2s_spdif.hw,
  1862. [CLKID_ETH] = &gxbb_eth.hw,
  1863. [CLKID_DEMUX] = &gxbb_demux.hw,
  1864. [CLKID_AIU_GLUE] = &gxbb_aiu_glue.hw,
  1865. [CLKID_IEC958] = &gxbb_iec958.hw,
  1866. [CLKID_I2S_OUT] = &gxbb_i2s_out.hw,
  1867. [CLKID_AMCLK] = &gxbb_amclk.hw,
  1868. [CLKID_AIFIFO2] = &gxbb_aififo2.hw,
  1869. [CLKID_MIXER] = &gxbb_mixer.hw,
  1870. [CLKID_MIXER_IFACE] = &gxbb_mixer_iface.hw,
  1871. [CLKID_ADC] = &gxbb_adc.hw,
  1872. [CLKID_BLKMV] = &gxbb_blkmv.hw,
  1873. [CLKID_AIU] = &gxbb_aiu.hw,
  1874. [CLKID_UART1] = &gxbb_uart1.hw,
  1875. [CLKID_G2D] = &gxbb_g2d.hw,
  1876. [CLKID_USB0] = &gxbb_usb0.hw,
  1877. [CLKID_USB1] = &gxbb_usb1.hw,
  1878. [CLKID_RESET] = &gxbb_reset.hw,
  1879. [CLKID_NAND] = &gxbb_nand.hw,
  1880. [CLKID_DOS_PARSER] = &gxbb_dos_parser.hw,
  1881. [CLKID_USB] = &gxbb_usb.hw,
  1882. [CLKID_VDIN1] = &gxbb_vdin1.hw,
  1883. [CLKID_AHB_ARB0] = &gxbb_ahb_arb0.hw,
  1884. [CLKID_EFUSE] = &gxbb_efuse.hw,
  1885. [CLKID_BOOT_ROM] = &gxbb_boot_rom.hw,
  1886. [CLKID_AHB_DATA_BUS] = &gxbb_ahb_data_bus.hw,
  1887. [CLKID_AHB_CTRL_BUS] = &gxbb_ahb_ctrl_bus.hw,
  1888. [CLKID_HDMI_INTR_SYNC] = &gxbb_hdmi_intr_sync.hw,
  1889. [CLKID_HDMI_PCLK] = &gxbb_hdmi_pclk.hw,
  1890. [CLKID_USB1_DDR_BRIDGE] = &gxbb_usb1_ddr_bridge.hw,
  1891. [CLKID_USB0_DDR_BRIDGE] = &gxbb_usb0_ddr_bridge.hw,
  1892. [CLKID_MMC_PCLK] = &gxbb_mmc_pclk.hw,
  1893. [CLKID_DVIN] = &gxbb_dvin.hw,
  1894. [CLKID_UART2] = &gxbb_uart2.hw,
  1895. [CLKID_SANA] = &gxbb_sana.hw,
  1896. [CLKID_VPU_INTR] = &gxbb_vpu_intr.hw,
  1897. [CLKID_SEC_AHB_AHB3_BRIDGE] = &gxbb_sec_ahb_ahb3_bridge.hw,
  1898. [CLKID_CLK81_A53] = &gxbb_clk81_a53.hw,
  1899. [CLKID_VCLK2_VENCI0] = &gxbb_vclk2_venci0.hw,
  1900. [CLKID_VCLK2_VENCI1] = &gxbb_vclk2_venci1.hw,
  1901. [CLKID_VCLK2_VENCP0] = &gxbb_vclk2_vencp0.hw,
  1902. [CLKID_VCLK2_VENCP1] = &gxbb_vclk2_vencp1.hw,
  1903. [CLKID_GCLK_VENCI_INT0] = &gxbb_gclk_venci_int0.hw,
  1904. [CLKID_GCLK_VENCI_INT] = &gxbb_gclk_vencp_int.hw,
  1905. [CLKID_DAC_CLK] = &gxbb_dac_clk.hw,
  1906. [CLKID_AOCLK_GATE] = &gxbb_aoclk_gate.hw,
  1907. [CLKID_IEC958_GATE] = &gxbb_iec958_gate.hw,
  1908. [CLKID_ENC480P] = &gxbb_enc480p.hw,
  1909. [CLKID_RNG1] = &gxbb_rng1.hw,
  1910. [CLKID_GCLK_VENCI_INT1] = &gxbb_gclk_venci_int1.hw,
  1911. [CLKID_VCLK2_VENCLMCC] = &gxbb_vclk2_venclmcc.hw,
  1912. [CLKID_VCLK2_VENCL] = &gxbb_vclk2_vencl.hw,
  1913. [CLKID_VCLK_OTHER] = &gxbb_vclk_other.hw,
  1914. [CLKID_EDP] = &gxbb_edp.hw,
  1915. [CLKID_AO_MEDIA_CPU] = &gxbb_ao_media_cpu.hw,
  1916. [CLKID_AO_AHB_SRAM] = &gxbb_ao_ahb_sram.hw,
  1917. [CLKID_AO_AHB_BUS] = &gxbb_ao_ahb_bus.hw,
  1918. [CLKID_AO_IFACE] = &gxbb_ao_iface.hw,
  1919. [CLKID_AO_I2C] = &gxbb_ao_i2c.hw,
  1920. [CLKID_SD_EMMC_A] = &gxbb_emmc_a.hw,
  1921. [CLKID_SD_EMMC_B] = &gxbb_emmc_b.hw,
  1922. [CLKID_SD_EMMC_C] = &gxbb_emmc_c.hw,
  1923. [CLKID_SAR_ADC_CLK] = &gxbb_sar_adc_clk.hw,
  1924. [CLKID_SAR_ADC_SEL] = &gxbb_sar_adc_clk_sel.hw,
  1925. [CLKID_SAR_ADC_DIV] = &gxbb_sar_adc_clk_div.hw,
  1926. [CLKID_MALI_0_SEL] = &gxbb_mali_0_sel.hw,
  1927. [CLKID_MALI_0_DIV] = &gxbb_mali_0_div.hw,
  1928. [CLKID_MALI_0] = &gxbb_mali_0.hw,
  1929. [CLKID_MALI_1_SEL] = &gxbb_mali_1_sel.hw,
  1930. [CLKID_MALI_1_DIV] = &gxbb_mali_1_div.hw,
  1931. [CLKID_MALI_1] = &gxbb_mali_1.hw,
  1932. [CLKID_MALI] = &gxbb_mali.hw,
  1933. [CLKID_CTS_AMCLK] = &gxbb_cts_amclk.hw,
  1934. [CLKID_CTS_AMCLK_SEL] = &gxbb_cts_amclk_sel.hw,
  1935. [CLKID_CTS_AMCLK_DIV] = &gxbb_cts_amclk_div.hw,
  1936. [CLKID_CTS_MCLK_I958] = &gxbb_cts_mclk_i958.hw,
  1937. [CLKID_CTS_MCLK_I958_SEL] = &gxbb_cts_mclk_i958_sel.hw,
  1938. [CLKID_CTS_MCLK_I958_DIV] = &gxbb_cts_mclk_i958_div.hw,
  1939. [CLKID_CTS_I958] = &gxbb_cts_i958.hw,
  1940. [CLKID_32K_CLK] = &gxbb_32k_clk.hw,
  1941. [CLKID_32K_CLK_SEL] = &gxbb_32k_clk_sel.hw,
  1942. [CLKID_32K_CLK_DIV] = &gxbb_32k_clk_div.hw,
  1943. [CLKID_SD_EMMC_A_CLK0_SEL] = &gxbb_sd_emmc_a_clk0_sel.hw,
  1944. [CLKID_SD_EMMC_A_CLK0_DIV] = &gxbb_sd_emmc_a_clk0_div.hw,
  1945. [CLKID_SD_EMMC_A_CLK0] = &gxbb_sd_emmc_a_clk0.hw,
  1946. [CLKID_SD_EMMC_B_CLK0_SEL] = &gxbb_sd_emmc_b_clk0_sel.hw,
  1947. [CLKID_SD_EMMC_B_CLK0_DIV] = &gxbb_sd_emmc_b_clk0_div.hw,
  1948. [CLKID_SD_EMMC_B_CLK0] = &gxbb_sd_emmc_b_clk0.hw,
  1949. [CLKID_SD_EMMC_C_CLK0_SEL] = &gxbb_sd_emmc_c_clk0_sel.hw,
  1950. [CLKID_SD_EMMC_C_CLK0_DIV] = &gxbb_sd_emmc_c_clk0_div.hw,
  1951. [CLKID_SD_EMMC_C_CLK0] = &gxbb_sd_emmc_c_clk0.hw,
  1952. [CLKID_VPU_0_SEL] = &gxbb_vpu_0_sel.hw,
  1953. [CLKID_VPU_0_DIV] = &gxbb_vpu_0_div.hw,
  1954. [CLKID_VPU_0] = &gxbb_vpu_0.hw,
  1955. [CLKID_VPU_1_SEL] = &gxbb_vpu_1_sel.hw,
  1956. [CLKID_VPU_1_DIV] = &gxbb_vpu_1_div.hw,
  1957. [CLKID_VPU_1] = &gxbb_vpu_1.hw,
  1958. [CLKID_VPU] = &gxbb_vpu.hw,
  1959. [CLKID_VAPB_0_SEL] = &gxbb_vapb_0_sel.hw,
  1960. [CLKID_VAPB_0_DIV] = &gxbb_vapb_0_div.hw,
  1961. [CLKID_VAPB_0] = &gxbb_vapb_0.hw,
  1962. [CLKID_VAPB_1_SEL] = &gxbb_vapb_1_sel.hw,
  1963. [CLKID_VAPB_1_DIV] = &gxbb_vapb_1_div.hw,
  1964. [CLKID_VAPB_1] = &gxbb_vapb_1.hw,
  1965. [CLKID_VAPB_SEL] = &gxbb_vapb_sel.hw,
  1966. [CLKID_VAPB] = &gxbb_vapb.hw,
  1967. [CLKID_MPLL0_DIV] = &gxbb_mpll0_div.hw,
  1968. [CLKID_MPLL1_DIV] = &gxbb_mpll1_div.hw,
  1969. [CLKID_MPLL2_DIV] = &gxbb_mpll2_div.hw,
  1970. [CLKID_MPLL_PREDIV] = &gxbb_mpll_prediv.hw,
  1971. [CLKID_FCLK_DIV2_DIV] = &gxbb_fclk_div2_div.hw,
  1972. [CLKID_FCLK_DIV3_DIV] = &gxbb_fclk_div3_div.hw,
  1973. [CLKID_FCLK_DIV4_DIV] = &gxbb_fclk_div4_div.hw,
  1974. [CLKID_FCLK_DIV5_DIV] = &gxbb_fclk_div5_div.hw,
  1975. [CLKID_FCLK_DIV7_DIV] = &gxbb_fclk_div7_div.hw,
  1976. [CLKID_VDEC_1_SEL] = &gxbb_vdec_1_sel.hw,
  1977. [CLKID_VDEC_1_DIV] = &gxbb_vdec_1_div.hw,
  1978. [CLKID_VDEC_1] = &gxbb_vdec_1.hw,
  1979. [CLKID_VDEC_HEVC_SEL] = &gxbb_vdec_hevc_sel.hw,
  1980. [CLKID_VDEC_HEVC_DIV] = &gxbb_vdec_hevc_div.hw,
  1981. [CLKID_VDEC_HEVC] = &gxbb_vdec_hevc.hw,
  1982. [CLKID_GEN_CLK_SEL] = &gxbb_gen_clk_sel.hw,
  1983. [CLKID_GEN_CLK_DIV] = &gxbb_gen_clk_div.hw,
  1984. [CLKID_GEN_CLK] = &gxbb_gen_clk.hw,
  1985. [CLKID_FIXED_PLL_DCO] = &gxbb_fixed_pll_dco.hw,
  1986. [CLKID_HDMI_PLL_DCO] = &gxbb_hdmi_pll_dco.hw,
  1987. [CLKID_HDMI_PLL_OD] = &gxl_hdmi_pll_od.hw,
  1988. [CLKID_HDMI_PLL_OD2] = &gxl_hdmi_pll_od2.hw,
  1989. [CLKID_SYS_PLL_DCO] = &gxbb_sys_pll_dco.hw,
  1990. [CLKID_GP0_PLL_DCO] = &gxl_gp0_pll_dco.hw,
  1991. [NR_CLKS] = NULL,
  1992. },
  1993. .num = NR_CLKS,
  1994. };
  1995. static struct clk_regmap *const gxbb_clk_regmaps[] = {
  1996. &gxbb_gp0_pll_dco,
  1997. &gxbb_hdmi_pll,
  1998. &gxbb_hdmi_pll_od,
  1999. &gxbb_hdmi_pll_od2,
  2000. };
  2001. static struct clk_regmap *const gxl_clk_regmaps[] = {
  2002. &gxl_gp0_pll_dco,
  2003. &gxl_hdmi_pll,
  2004. &gxl_hdmi_pll_od,
  2005. &gxl_hdmi_pll_od2,
  2006. };
  2007. static struct clk_regmap *const gx_clk_regmaps[] = {
  2008. &gxbb_clk81,
  2009. &gxbb_ddr,
  2010. &gxbb_dos,
  2011. &gxbb_isa,
  2012. &gxbb_pl301,
  2013. &gxbb_periphs,
  2014. &gxbb_spicc,
  2015. &gxbb_i2c,
  2016. &gxbb_sar_adc,
  2017. &gxbb_smart_card,
  2018. &gxbb_rng0,
  2019. &gxbb_uart0,
  2020. &gxbb_sdhc,
  2021. &gxbb_stream,
  2022. &gxbb_async_fifo,
  2023. &gxbb_sdio,
  2024. &gxbb_abuf,
  2025. &gxbb_hiu_iface,
  2026. &gxbb_assist_misc,
  2027. &gxbb_spi,
  2028. &gxbb_i2s_spdif,
  2029. &gxbb_eth,
  2030. &gxbb_demux,
  2031. &gxbb_aiu_glue,
  2032. &gxbb_iec958,
  2033. &gxbb_i2s_out,
  2034. &gxbb_amclk,
  2035. &gxbb_aififo2,
  2036. &gxbb_mixer,
  2037. &gxbb_mixer_iface,
  2038. &gxbb_adc,
  2039. &gxbb_blkmv,
  2040. &gxbb_aiu,
  2041. &gxbb_uart1,
  2042. &gxbb_g2d,
  2043. &gxbb_usb0,
  2044. &gxbb_usb1,
  2045. &gxbb_reset,
  2046. &gxbb_nand,
  2047. &gxbb_dos_parser,
  2048. &gxbb_usb,
  2049. &gxbb_vdin1,
  2050. &gxbb_ahb_arb0,
  2051. &gxbb_efuse,
  2052. &gxbb_boot_rom,
  2053. &gxbb_ahb_data_bus,
  2054. &gxbb_ahb_ctrl_bus,
  2055. &gxbb_hdmi_intr_sync,
  2056. &gxbb_hdmi_pclk,
  2057. &gxbb_usb1_ddr_bridge,
  2058. &gxbb_usb0_ddr_bridge,
  2059. &gxbb_mmc_pclk,
  2060. &gxbb_dvin,
  2061. &gxbb_uart2,
  2062. &gxbb_sana,
  2063. &gxbb_vpu_intr,
  2064. &gxbb_sec_ahb_ahb3_bridge,
  2065. &gxbb_clk81_a53,
  2066. &gxbb_vclk2_venci0,
  2067. &gxbb_vclk2_venci1,
  2068. &gxbb_vclk2_vencp0,
  2069. &gxbb_vclk2_vencp1,
  2070. &gxbb_gclk_venci_int0,
  2071. &gxbb_gclk_vencp_int,
  2072. &gxbb_dac_clk,
  2073. &gxbb_aoclk_gate,
  2074. &gxbb_iec958_gate,
  2075. &gxbb_enc480p,
  2076. &gxbb_rng1,
  2077. &gxbb_gclk_venci_int1,
  2078. &gxbb_vclk2_venclmcc,
  2079. &gxbb_vclk2_vencl,
  2080. &gxbb_vclk_other,
  2081. &gxbb_edp,
  2082. &gxbb_ao_media_cpu,
  2083. &gxbb_ao_ahb_sram,
  2084. &gxbb_ao_ahb_bus,
  2085. &gxbb_ao_iface,
  2086. &gxbb_ao_i2c,
  2087. &gxbb_emmc_a,
  2088. &gxbb_emmc_b,
  2089. &gxbb_emmc_c,
  2090. &gxbb_sar_adc_clk,
  2091. &gxbb_mali_0,
  2092. &gxbb_mali_1,
  2093. &gxbb_cts_amclk,
  2094. &gxbb_cts_mclk_i958,
  2095. &gxbb_32k_clk,
  2096. &gxbb_sd_emmc_a_clk0,
  2097. &gxbb_sd_emmc_b_clk0,
  2098. &gxbb_sd_emmc_c_clk0,
  2099. &gxbb_vpu_0,
  2100. &gxbb_vpu_1,
  2101. &gxbb_vapb_0,
  2102. &gxbb_vapb_1,
  2103. &gxbb_vapb,
  2104. &gxbb_mpeg_clk_div,
  2105. &gxbb_sar_adc_clk_div,
  2106. &gxbb_mali_0_div,
  2107. &gxbb_mali_1_div,
  2108. &gxbb_cts_mclk_i958_div,
  2109. &gxbb_32k_clk_div,
  2110. &gxbb_sd_emmc_a_clk0_div,
  2111. &gxbb_sd_emmc_b_clk0_div,
  2112. &gxbb_sd_emmc_c_clk0_div,
  2113. &gxbb_vpu_0_div,
  2114. &gxbb_vpu_1_div,
  2115. &gxbb_vapb_0_div,
  2116. &gxbb_vapb_1_div,
  2117. &gxbb_mpeg_clk_sel,
  2118. &gxbb_sar_adc_clk_sel,
  2119. &gxbb_mali_0_sel,
  2120. &gxbb_mali_1_sel,
  2121. &gxbb_mali,
  2122. &gxbb_cts_amclk_sel,
  2123. &gxbb_cts_mclk_i958_sel,
  2124. &gxbb_cts_i958,
  2125. &gxbb_32k_clk_sel,
  2126. &gxbb_sd_emmc_a_clk0_sel,
  2127. &gxbb_sd_emmc_b_clk0_sel,
  2128. &gxbb_sd_emmc_c_clk0_sel,
  2129. &gxbb_vpu_0_sel,
  2130. &gxbb_vpu_1_sel,
  2131. &gxbb_vpu,
  2132. &gxbb_vapb_0_sel,
  2133. &gxbb_vapb_1_sel,
  2134. &gxbb_vapb_sel,
  2135. &gxbb_mpll0,
  2136. &gxbb_mpll1,
  2137. &gxbb_mpll2,
  2138. &gxbb_mpll0_div,
  2139. &gxbb_mpll1_div,
  2140. &gxbb_mpll2_div,
  2141. &gxbb_cts_amclk_div,
  2142. &gxbb_fixed_pll,
  2143. &gxbb_sys_pll,
  2144. &gxbb_mpll_prediv,
  2145. &gxbb_fclk_div2,
  2146. &gxbb_fclk_div3,
  2147. &gxbb_fclk_div4,
  2148. &gxbb_fclk_div5,
  2149. &gxbb_fclk_div7,
  2150. &gxbb_vdec_1_sel,
  2151. &gxbb_vdec_1_div,
  2152. &gxbb_vdec_1,
  2153. &gxbb_vdec_hevc_sel,
  2154. &gxbb_vdec_hevc_div,
  2155. &gxbb_vdec_hevc,
  2156. &gxbb_gen_clk_sel,
  2157. &gxbb_gen_clk_div,
  2158. &gxbb_gen_clk,
  2159. &gxbb_fixed_pll_dco,
  2160. &gxbb_hdmi_pll_dco,
  2161. &gxbb_sys_pll_dco,
  2162. &gxbb_gp0_pll,
  2163. };
  2164. struct clkc_data {
  2165. struct clk_regmap *const *regmap_clks;
  2166. unsigned int regmap_clks_count;
  2167. struct clk_hw_onecell_data *hw_onecell_data;
  2168. };
  2169. static const struct clkc_data gxbb_clkc_data = {
  2170. .regmap_clks = gxbb_clk_regmaps,
  2171. .regmap_clks_count = ARRAY_SIZE(gxbb_clk_regmaps),
  2172. .hw_onecell_data = &gxbb_hw_onecell_data,
  2173. };
  2174. static const struct clkc_data gxl_clkc_data = {
  2175. .regmap_clks = gxl_clk_regmaps,
  2176. .regmap_clks_count = ARRAY_SIZE(gxl_clk_regmaps),
  2177. .hw_onecell_data = &gxl_hw_onecell_data,
  2178. };
  2179. static const struct of_device_id clkc_match_table[] = {
  2180. { .compatible = "amlogic,gxbb-clkc", .data = &gxbb_clkc_data },
  2181. { .compatible = "amlogic,gxl-clkc", .data = &gxl_clkc_data },
  2182. {},
  2183. };
  2184. static int gxbb_clkc_probe(struct platform_device *pdev)
  2185. {
  2186. const struct clkc_data *clkc_data;
  2187. struct regmap *map;
  2188. int ret, i;
  2189. struct device *dev = &pdev->dev;
  2190. clkc_data = of_device_get_match_data(dev);
  2191. if (!clkc_data)
  2192. return -EINVAL;
  2193. /* Get the hhi system controller node if available */
  2194. map = syscon_node_to_regmap(of_get_parent(dev->of_node));
  2195. if (IS_ERR(map)) {
  2196. dev_err(dev, "failed to get HHI regmap\n");
  2197. return PTR_ERR(map);
  2198. }
  2199. /* Populate regmap for the common regmap backed clocks */
  2200. for (i = 0; i < ARRAY_SIZE(gx_clk_regmaps); i++)
  2201. gx_clk_regmaps[i]->map = map;
  2202. /* Populate regmap for soc specific clocks */
  2203. for (i = 0; i < clkc_data->regmap_clks_count; i++)
  2204. clkc_data->regmap_clks[i]->map = map;
  2205. /* Register all clks */
  2206. for (i = 0; i < clkc_data->hw_onecell_data->num; i++) {
  2207. /* array might be sparse */
  2208. if (!clkc_data->hw_onecell_data->hws[i])
  2209. continue;
  2210. ret = devm_clk_hw_register(dev,
  2211. clkc_data->hw_onecell_data->hws[i]);
  2212. if (ret) {
  2213. dev_err(dev, "Clock registration failed\n");
  2214. return ret;
  2215. }
  2216. }
  2217. return devm_of_clk_add_hw_provider(dev, of_clk_hw_onecell_get,
  2218. clkc_data->hw_onecell_data);
  2219. }
  2220. static struct platform_driver gxbb_driver = {
  2221. .probe = gxbb_clkc_probe,
  2222. .driver = {
  2223. .name = "gxbb-clkc",
  2224. .of_match_table = clkc_match_table,
  2225. },
  2226. };
  2227. builtin_platform_driver(gxbb_driver);