gcc-ipq806x.c 52 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452
  1. /*
  2. * Copyright (c) 2014, The Linux Foundation. All rights reserved.
  3. *
  4. * This software is licensed under the terms of the GNU General Public
  5. * License version 2, as published by the Free Software Foundation, and
  6. * may be copied, distributed, and modified under those terms.
  7. *
  8. * This program is distributed in the hope that it will be useful,
  9. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  10. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  11. * GNU General Public License for more details.
  12. */
  13. #include <linux/kernel.h>
  14. #include <linux/bitops.h>
  15. #include <linux/err.h>
  16. #include <linux/platform_device.h>
  17. #include <linux/module.h>
  18. #include <linux/of.h>
  19. #include <linux/of_device.h>
  20. #include <linux/clk-provider.h>
  21. #include <linux/regmap.h>
  22. #include <linux/reset-controller.h>
  23. #include <dt-bindings/clock/qcom,gcc-ipq806x.h>
  24. #include <dt-bindings/reset/qcom,gcc-ipq806x.h>
  25. #include "common.h"
  26. #include "clk-regmap.h"
  27. #include "clk-pll.h"
  28. #include "clk-rcg.h"
  29. #include "clk-branch.h"
  30. #include "reset.h"
  31. static struct clk_pll pll0 = {
  32. .l_reg = 0x30c4,
  33. .m_reg = 0x30c8,
  34. .n_reg = 0x30cc,
  35. .config_reg = 0x30d4,
  36. .mode_reg = 0x30c0,
  37. .status_reg = 0x30d8,
  38. .status_bit = 16,
  39. .clkr.hw.init = &(struct clk_init_data){
  40. .name = "pll0",
  41. .parent_names = (const char *[]){ "pxo" },
  42. .num_parents = 1,
  43. .ops = &clk_pll_ops,
  44. },
  45. };
  46. static struct clk_regmap pll0_vote = {
  47. .enable_reg = 0x34c0,
  48. .enable_mask = BIT(0),
  49. .hw.init = &(struct clk_init_data){
  50. .name = "pll0_vote",
  51. .parent_names = (const char *[]){ "pll0" },
  52. .num_parents = 1,
  53. .ops = &clk_pll_vote_ops,
  54. },
  55. };
  56. static struct clk_pll pll3 = {
  57. .l_reg = 0x3164,
  58. .m_reg = 0x3168,
  59. .n_reg = 0x316c,
  60. .config_reg = 0x3174,
  61. .mode_reg = 0x3160,
  62. .status_reg = 0x3178,
  63. .status_bit = 16,
  64. .clkr.hw.init = &(struct clk_init_data){
  65. .name = "pll3",
  66. .parent_names = (const char *[]){ "pxo" },
  67. .num_parents = 1,
  68. .ops = &clk_pll_ops,
  69. },
  70. };
  71. static struct clk_pll pll8 = {
  72. .l_reg = 0x3144,
  73. .m_reg = 0x3148,
  74. .n_reg = 0x314c,
  75. .config_reg = 0x3154,
  76. .mode_reg = 0x3140,
  77. .status_reg = 0x3158,
  78. .status_bit = 16,
  79. .clkr.hw.init = &(struct clk_init_data){
  80. .name = "pll8",
  81. .parent_names = (const char *[]){ "pxo" },
  82. .num_parents = 1,
  83. .ops = &clk_pll_ops,
  84. },
  85. };
  86. static struct clk_regmap pll8_vote = {
  87. .enable_reg = 0x34c0,
  88. .enable_mask = BIT(8),
  89. .hw.init = &(struct clk_init_data){
  90. .name = "pll8_vote",
  91. .parent_names = (const char *[]){ "pll8" },
  92. .num_parents = 1,
  93. .ops = &clk_pll_vote_ops,
  94. },
  95. };
  96. static struct clk_pll pll14 = {
  97. .l_reg = 0x31c4,
  98. .m_reg = 0x31c8,
  99. .n_reg = 0x31cc,
  100. .config_reg = 0x31d4,
  101. .mode_reg = 0x31c0,
  102. .status_reg = 0x31d8,
  103. .status_bit = 16,
  104. .clkr.hw.init = &(struct clk_init_data){
  105. .name = "pll14",
  106. .parent_names = (const char *[]){ "pxo" },
  107. .num_parents = 1,
  108. .ops = &clk_pll_ops,
  109. },
  110. };
  111. static struct clk_regmap pll14_vote = {
  112. .enable_reg = 0x34c0,
  113. .enable_mask = BIT(14),
  114. .hw.init = &(struct clk_init_data){
  115. .name = "pll14_vote",
  116. .parent_names = (const char *[]){ "pll14" },
  117. .num_parents = 1,
  118. .ops = &clk_pll_vote_ops,
  119. },
  120. };
  121. #define P_PXO 0
  122. #define P_PLL8 1
  123. #define P_PLL3 1
  124. #define P_PLL0 2
  125. #define P_CXO 2
  126. static const u8 gcc_pxo_pll8_map[] = {
  127. [P_PXO] = 0,
  128. [P_PLL8] = 3,
  129. };
  130. static const char *gcc_pxo_pll8[] = {
  131. "pxo",
  132. "pll8_vote",
  133. };
  134. static const u8 gcc_pxo_pll8_cxo_map[] = {
  135. [P_PXO] = 0,
  136. [P_PLL8] = 3,
  137. [P_CXO] = 5,
  138. };
  139. static const char *gcc_pxo_pll8_cxo[] = {
  140. "pxo",
  141. "pll8_vote",
  142. "cxo",
  143. };
  144. static const u8 gcc_pxo_pll3_map[] = {
  145. [P_PXO] = 0,
  146. [P_PLL3] = 1,
  147. };
  148. static const u8 gcc_pxo_pll3_sata_map[] = {
  149. [P_PXO] = 0,
  150. [P_PLL3] = 6,
  151. };
  152. static const char *gcc_pxo_pll3[] = {
  153. "pxo",
  154. "pll3",
  155. };
  156. static const u8 gcc_pxo_pll8_pll0[] = {
  157. [P_PXO] = 0,
  158. [P_PLL8] = 3,
  159. [P_PLL0] = 2,
  160. };
  161. static const char *gcc_pxo_pll8_pll0_map[] = {
  162. "pxo",
  163. "pll8_vote",
  164. "pll0_vote",
  165. };
  166. static struct freq_tbl clk_tbl_gsbi_uart[] = {
  167. { 1843200, P_PLL8, 2, 6, 625 },
  168. { 3686400, P_PLL8, 2, 12, 625 },
  169. { 7372800, P_PLL8, 2, 24, 625 },
  170. { 14745600, P_PLL8, 2, 48, 625 },
  171. { 16000000, P_PLL8, 4, 1, 6 },
  172. { 24000000, P_PLL8, 4, 1, 4 },
  173. { 32000000, P_PLL8, 4, 1, 3 },
  174. { 40000000, P_PLL8, 1, 5, 48 },
  175. { 46400000, P_PLL8, 1, 29, 240 },
  176. { 48000000, P_PLL8, 4, 1, 2 },
  177. { 51200000, P_PLL8, 1, 2, 15 },
  178. { 56000000, P_PLL8, 1, 7, 48 },
  179. { 58982400, P_PLL8, 1, 96, 625 },
  180. { 64000000, P_PLL8, 2, 1, 3 },
  181. { }
  182. };
  183. static struct clk_rcg gsbi1_uart_src = {
  184. .ns_reg = 0x29d4,
  185. .md_reg = 0x29d0,
  186. .mn = {
  187. .mnctr_en_bit = 8,
  188. .mnctr_reset_bit = 7,
  189. .mnctr_mode_shift = 5,
  190. .n_val_shift = 16,
  191. .m_val_shift = 16,
  192. .width = 16,
  193. },
  194. .p = {
  195. .pre_div_shift = 3,
  196. .pre_div_width = 2,
  197. },
  198. .s = {
  199. .src_sel_shift = 0,
  200. .parent_map = gcc_pxo_pll8_map,
  201. },
  202. .freq_tbl = clk_tbl_gsbi_uart,
  203. .clkr = {
  204. .enable_reg = 0x29d4,
  205. .enable_mask = BIT(11),
  206. .hw.init = &(struct clk_init_data){
  207. .name = "gsbi1_uart_src",
  208. .parent_names = gcc_pxo_pll8,
  209. .num_parents = 2,
  210. .ops = &clk_rcg_ops,
  211. .flags = CLK_SET_PARENT_GATE,
  212. },
  213. },
  214. };
  215. static struct clk_branch gsbi1_uart_clk = {
  216. .halt_reg = 0x2fcc,
  217. .halt_bit = 12,
  218. .clkr = {
  219. .enable_reg = 0x29d4,
  220. .enable_mask = BIT(9),
  221. .hw.init = &(struct clk_init_data){
  222. .name = "gsbi1_uart_clk",
  223. .parent_names = (const char *[]){
  224. "gsbi1_uart_src",
  225. },
  226. .num_parents = 1,
  227. .ops = &clk_branch_ops,
  228. .flags = CLK_SET_RATE_PARENT,
  229. },
  230. },
  231. };
  232. static struct clk_rcg gsbi2_uart_src = {
  233. .ns_reg = 0x29f4,
  234. .md_reg = 0x29f0,
  235. .mn = {
  236. .mnctr_en_bit = 8,
  237. .mnctr_reset_bit = 7,
  238. .mnctr_mode_shift = 5,
  239. .n_val_shift = 16,
  240. .m_val_shift = 16,
  241. .width = 16,
  242. },
  243. .p = {
  244. .pre_div_shift = 3,
  245. .pre_div_width = 2,
  246. },
  247. .s = {
  248. .src_sel_shift = 0,
  249. .parent_map = gcc_pxo_pll8_map,
  250. },
  251. .freq_tbl = clk_tbl_gsbi_uart,
  252. .clkr = {
  253. .enable_reg = 0x29f4,
  254. .enable_mask = BIT(11),
  255. .hw.init = &(struct clk_init_data){
  256. .name = "gsbi2_uart_src",
  257. .parent_names = gcc_pxo_pll8,
  258. .num_parents = 2,
  259. .ops = &clk_rcg_ops,
  260. .flags = CLK_SET_PARENT_GATE,
  261. },
  262. },
  263. };
  264. static struct clk_branch gsbi2_uart_clk = {
  265. .halt_reg = 0x2fcc,
  266. .halt_bit = 8,
  267. .clkr = {
  268. .enable_reg = 0x29f4,
  269. .enable_mask = BIT(9),
  270. .hw.init = &(struct clk_init_data){
  271. .name = "gsbi2_uart_clk",
  272. .parent_names = (const char *[]){
  273. "gsbi2_uart_src",
  274. },
  275. .num_parents = 1,
  276. .ops = &clk_branch_ops,
  277. .flags = CLK_SET_RATE_PARENT,
  278. },
  279. },
  280. };
  281. static struct clk_rcg gsbi4_uart_src = {
  282. .ns_reg = 0x2a34,
  283. .md_reg = 0x2a30,
  284. .mn = {
  285. .mnctr_en_bit = 8,
  286. .mnctr_reset_bit = 7,
  287. .mnctr_mode_shift = 5,
  288. .n_val_shift = 16,
  289. .m_val_shift = 16,
  290. .width = 16,
  291. },
  292. .p = {
  293. .pre_div_shift = 3,
  294. .pre_div_width = 2,
  295. },
  296. .s = {
  297. .src_sel_shift = 0,
  298. .parent_map = gcc_pxo_pll8_map,
  299. },
  300. .freq_tbl = clk_tbl_gsbi_uart,
  301. .clkr = {
  302. .enable_reg = 0x2a34,
  303. .enable_mask = BIT(11),
  304. .hw.init = &(struct clk_init_data){
  305. .name = "gsbi4_uart_src",
  306. .parent_names = gcc_pxo_pll8,
  307. .num_parents = 2,
  308. .ops = &clk_rcg_ops,
  309. .flags = CLK_SET_PARENT_GATE,
  310. },
  311. },
  312. };
  313. static struct clk_branch gsbi4_uart_clk = {
  314. .halt_reg = 0x2fd0,
  315. .halt_bit = 26,
  316. .clkr = {
  317. .enable_reg = 0x2a34,
  318. .enable_mask = BIT(9),
  319. .hw.init = &(struct clk_init_data){
  320. .name = "gsbi4_uart_clk",
  321. .parent_names = (const char *[]){
  322. "gsbi4_uart_src",
  323. },
  324. .num_parents = 1,
  325. .ops = &clk_branch_ops,
  326. .flags = CLK_SET_RATE_PARENT,
  327. },
  328. },
  329. };
  330. static struct clk_rcg gsbi5_uart_src = {
  331. .ns_reg = 0x2a54,
  332. .md_reg = 0x2a50,
  333. .mn = {
  334. .mnctr_en_bit = 8,
  335. .mnctr_reset_bit = 7,
  336. .mnctr_mode_shift = 5,
  337. .n_val_shift = 16,
  338. .m_val_shift = 16,
  339. .width = 16,
  340. },
  341. .p = {
  342. .pre_div_shift = 3,
  343. .pre_div_width = 2,
  344. },
  345. .s = {
  346. .src_sel_shift = 0,
  347. .parent_map = gcc_pxo_pll8_map,
  348. },
  349. .freq_tbl = clk_tbl_gsbi_uart,
  350. .clkr = {
  351. .enable_reg = 0x2a54,
  352. .enable_mask = BIT(11),
  353. .hw.init = &(struct clk_init_data){
  354. .name = "gsbi5_uart_src",
  355. .parent_names = gcc_pxo_pll8,
  356. .num_parents = 2,
  357. .ops = &clk_rcg_ops,
  358. .flags = CLK_SET_PARENT_GATE,
  359. },
  360. },
  361. };
  362. static struct clk_branch gsbi5_uart_clk = {
  363. .halt_reg = 0x2fd0,
  364. .halt_bit = 22,
  365. .clkr = {
  366. .enable_reg = 0x2a54,
  367. .enable_mask = BIT(9),
  368. .hw.init = &(struct clk_init_data){
  369. .name = "gsbi5_uart_clk",
  370. .parent_names = (const char *[]){
  371. "gsbi5_uart_src",
  372. },
  373. .num_parents = 1,
  374. .ops = &clk_branch_ops,
  375. .flags = CLK_SET_RATE_PARENT,
  376. },
  377. },
  378. };
  379. static struct clk_rcg gsbi6_uart_src = {
  380. .ns_reg = 0x2a74,
  381. .md_reg = 0x2a70,
  382. .mn = {
  383. .mnctr_en_bit = 8,
  384. .mnctr_reset_bit = 7,
  385. .mnctr_mode_shift = 5,
  386. .n_val_shift = 16,
  387. .m_val_shift = 16,
  388. .width = 16,
  389. },
  390. .p = {
  391. .pre_div_shift = 3,
  392. .pre_div_width = 2,
  393. },
  394. .s = {
  395. .src_sel_shift = 0,
  396. .parent_map = gcc_pxo_pll8_map,
  397. },
  398. .freq_tbl = clk_tbl_gsbi_uart,
  399. .clkr = {
  400. .enable_reg = 0x2a74,
  401. .enable_mask = BIT(11),
  402. .hw.init = &(struct clk_init_data){
  403. .name = "gsbi6_uart_src",
  404. .parent_names = gcc_pxo_pll8,
  405. .num_parents = 2,
  406. .ops = &clk_rcg_ops,
  407. .flags = CLK_SET_PARENT_GATE,
  408. },
  409. },
  410. };
  411. static struct clk_branch gsbi6_uart_clk = {
  412. .halt_reg = 0x2fd0,
  413. .halt_bit = 18,
  414. .clkr = {
  415. .enable_reg = 0x2a74,
  416. .enable_mask = BIT(9),
  417. .hw.init = &(struct clk_init_data){
  418. .name = "gsbi6_uart_clk",
  419. .parent_names = (const char *[]){
  420. "gsbi6_uart_src",
  421. },
  422. .num_parents = 1,
  423. .ops = &clk_branch_ops,
  424. .flags = CLK_SET_RATE_PARENT,
  425. },
  426. },
  427. };
  428. static struct clk_rcg gsbi7_uart_src = {
  429. .ns_reg = 0x2a94,
  430. .md_reg = 0x2a90,
  431. .mn = {
  432. .mnctr_en_bit = 8,
  433. .mnctr_reset_bit = 7,
  434. .mnctr_mode_shift = 5,
  435. .n_val_shift = 16,
  436. .m_val_shift = 16,
  437. .width = 16,
  438. },
  439. .p = {
  440. .pre_div_shift = 3,
  441. .pre_div_width = 2,
  442. },
  443. .s = {
  444. .src_sel_shift = 0,
  445. .parent_map = gcc_pxo_pll8_map,
  446. },
  447. .freq_tbl = clk_tbl_gsbi_uart,
  448. .clkr = {
  449. .enable_reg = 0x2a94,
  450. .enable_mask = BIT(11),
  451. .hw.init = &(struct clk_init_data){
  452. .name = "gsbi7_uart_src",
  453. .parent_names = gcc_pxo_pll8,
  454. .num_parents = 2,
  455. .ops = &clk_rcg_ops,
  456. .flags = CLK_SET_PARENT_GATE,
  457. },
  458. },
  459. };
  460. static struct clk_branch gsbi7_uart_clk = {
  461. .halt_reg = 0x2fd0,
  462. .halt_bit = 14,
  463. .clkr = {
  464. .enable_reg = 0x2a94,
  465. .enable_mask = BIT(9),
  466. .hw.init = &(struct clk_init_data){
  467. .name = "gsbi7_uart_clk",
  468. .parent_names = (const char *[]){
  469. "gsbi7_uart_src",
  470. },
  471. .num_parents = 1,
  472. .ops = &clk_branch_ops,
  473. .flags = CLK_SET_RATE_PARENT,
  474. },
  475. },
  476. };
  477. static struct freq_tbl clk_tbl_gsbi_qup[] = {
  478. { 1100000, P_PXO, 1, 2, 49 },
  479. { 5400000, P_PXO, 1, 1, 5 },
  480. { 10800000, P_PXO, 1, 2, 5 },
  481. { 15060000, P_PLL8, 1, 2, 51 },
  482. { 24000000, P_PLL8, 4, 1, 4 },
  483. { 25600000, P_PLL8, 1, 1, 15 },
  484. { 27000000, P_PXO, 1, 0, 0 },
  485. { 48000000, P_PLL8, 4, 1, 2 },
  486. { 51200000, P_PLL8, 1, 2, 15 },
  487. { }
  488. };
  489. static struct clk_rcg gsbi1_qup_src = {
  490. .ns_reg = 0x29cc,
  491. .md_reg = 0x29c8,
  492. .mn = {
  493. .mnctr_en_bit = 8,
  494. .mnctr_reset_bit = 7,
  495. .mnctr_mode_shift = 5,
  496. .n_val_shift = 16,
  497. .m_val_shift = 16,
  498. .width = 8,
  499. },
  500. .p = {
  501. .pre_div_shift = 3,
  502. .pre_div_width = 2,
  503. },
  504. .s = {
  505. .src_sel_shift = 0,
  506. .parent_map = gcc_pxo_pll8_map,
  507. },
  508. .freq_tbl = clk_tbl_gsbi_qup,
  509. .clkr = {
  510. .enable_reg = 0x29cc,
  511. .enable_mask = BIT(11),
  512. .hw.init = &(struct clk_init_data){
  513. .name = "gsbi1_qup_src",
  514. .parent_names = gcc_pxo_pll8,
  515. .num_parents = 2,
  516. .ops = &clk_rcg_ops,
  517. .flags = CLK_SET_PARENT_GATE,
  518. },
  519. },
  520. };
  521. static struct clk_branch gsbi1_qup_clk = {
  522. .halt_reg = 0x2fcc,
  523. .halt_bit = 11,
  524. .clkr = {
  525. .enable_reg = 0x29cc,
  526. .enable_mask = BIT(9),
  527. .hw.init = &(struct clk_init_data){
  528. .name = "gsbi1_qup_clk",
  529. .parent_names = (const char *[]){ "gsbi1_qup_src" },
  530. .num_parents = 1,
  531. .ops = &clk_branch_ops,
  532. .flags = CLK_SET_RATE_PARENT,
  533. },
  534. },
  535. };
  536. static struct clk_rcg gsbi2_qup_src = {
  537. .ns_reg = 0x29ec,
  538. .md_reg = 0x29e8,
  539. .mn = {
  540. .mnctr_en_bit = 8,
  541. .mnctr_reset_bit = 7,
  542. .mnctr_mode_shift = 5,
  543. .n_val_shift = 16,
  544. .m_val_shift = 16,
  545. .width = 8,
  546. },
  547. .p = {
  548. .pre_div_shift = 3,
  549. .pre_div_width = 2,
  550. },
  551. .s = {
  552. .src_sel_shift = 0,
  553. .parent_map = gcc_pxo_pll8_map,
  554. },
  555. .freq_tbl = clk_tbl_gsbi_qup,
  556. .clkr = {
  557. .enable_reg = 0x29ec,
  558. .enable_mask = BIT(11),
  559. .hw.init = &(struct clk_init_data){
  560. .name = "gsbi2_qup_src",
  561. .parent_names = gcc_pxo_pll8,
  562. .num_parents = 2,
  563. .ops = &clk_rcg_ops,
  564. .flags = CLK_SET_PARENT_GATE,
  565. },
  566. },
  567. };
  568. static struct clk_branch gsbi2_qup_clk = {
  569. .halt_reg = 0x2fcc,
  570. .halt_bit = 6,
  571. .clkr = {
  572. .enable_reg = 0x29ec,
  573. .enable_mask = BIT(9),
  574. .hw.init = &(struct clk_init_data){
  575. .name = "gsbi2_qup_clk",
  576. .parent_names = (const char *[]){ "gsbi2_qup_src" },
  577. .num_parents = 1,
  578. .ops = &clk_branch_ops,
  579. .flags = CLK_SET_RATE_PARENT,
  580. },
  581. },
  582. };
  583. static struct clk_rcg gsbi4_qup_src = {
  584. .ns_reg = 0x2a2c,
  585. .md_reg = 0x2a28,
  586. .mn = {
  587. .mnctr_en_bit = 8,
  588. .mnctr_reset_bit = 7,
  589. .mnctr_mode_shift = 5,
  590. .n_val_shift = 16,
  591. .m_val_shift = 16,
  592. .width = 8,
  593. },
  594. .p = {
  595. .pre_div_shift = 3,
  596. .pre_div_width = 2,
  597. },
  598. .s = {
  599. .src_sel_shift = 0,
  600. .parent_map = gcc_pxo_pll8_map,
  601. },
  602. .freq_tbl = clk_tbl_gsbi_qup,
  603. .clkr = {
  604. .enable_reg = 0x2a2c,
  605. .enable_mask = BIT(11),
  606. .hw.init = &(struct clk_init_data){
  607. .name = "gsbi4_qup_src",
  608. .parent_names = gcc_pxo_pll8,
  609. .num_parents = 2,
  610. .ops = &clk_rcg_ops,
  611. .flags = CLK_SET_PARENT_GATE,
  612. },
  613. },
  614. };
  615. static struct clk_branch gsbi4_qup_clk = {
  616. .halt_reg = 0x2fd0,
  617. .halt_bit = 24,
  618. .clkr = {
  619. .enable_reg = 0x2a2c,
  620. .enable_mask = BIT(9),
  621. .hw.init = &(struct clk_init_data){
  622. .name = "gsbi4_qup_clk",
  623. .parent_names = (const char *[]){ "gsbi4_qup_src" },
  624. .num_parents = 1,
  625. .ops = &clk_branch_ops,
  626. .flags = CLK_SET_RATE_PARENT,
  627. },
  628. },
  629. };
  630. static struct clk_rcg gsbi5_qup_src = {
  631. .ns_reg = 0x2a4c,
  632. .md_reg = 0x2a48,
  633. .mn = {
  634. .mnctr_en_bit = 8,
  635. .mnctr_reset_bit = 7,
  636. .mnctr_mode_shift = 5,
  637. .n_val_shift = 16,
  638. .m_val_shift = 16,
  639. .width = 8,
  640. },
  641. .p = {
  642. .pre_div_shift = 3,
  643. .pre_div_width = 2,
  644. },
  645. .s = {
  646. .src_sel_shift = 0,
  647. .parent_map = gcc_pxo_pll8_map,
  648. },
  649. .freq_tbl = clk_tbl_gsbi_qup,
  650. .clkr = {
  651. .enable_reg = 0x2a4c,
  652. .enable_mask = BIT(11),
  653. .hw.init = &(struct clk_init_data){
  654. .name = "gsbi5_qup_src",
  655. .parent_names = gcc_pxo_pll8,
  656. .num_parents = 2,
  657. .ops = &clk_rcg_ops,
  658. .flags = CLK_SET_PARENT_GATE,
  659. },
  660. },
  661. };
  662. static struct clk_branch gsbi5_qup_clk = {
  663. .halt_reg = 0x2fd0,
  664. .halt_bit = 20,
  665. .clkr = {
  666. .enable_reg = 0x2a4c,
  667. .enable_mask = BIT(9),
  668. .hw.init = &(struct clk_init_data){
  669. .name = "gsbi5_qup_clk",
  670. .parent_names = (const char *[]){ "gsbi5_qup_src" },
  671. .num_parents = 1,
  672. .ops = &clk_branch_ops,
  673. .flags = CLK_SET_RATE_PARENT,
  674. },
  675. },
  676. };
  677. static struct clk_rcg gsbi6_qup_src = {
  678. .ns_reg = 0x2a6c,
  679. .md_reg = 0x2a68,
  680. .mn = {
  681. .mnctr_en_bit = 8,
  682. .mnctr_reset_bit = 7,
  683. .mnctr_mode_shift = 5,
  684. .n_val_shift = 16,
  685. .m_val_shift = 16,
  686. .width = 8,
  687. },
  688. .p = {
  689. .pre_div_shift = 3,
  690. .pre_div_width = 2,
  691. },
  692. .s = {
  693. .src_sel_shift = 0,
  694. .parent_map = gcc_pxo_pll8_map,
  695. },
  696. .freq_tbl = clk_tbl_gsbi_qup,
  697. .clkr = {
  698. .enable_reg = 0x2a6c,
  699. .enable_mask = BIT(11),
  700. .hw.init = &(struct clk_init_data){
  701. .name = "gsbi6_qup_src",
  702. .parent_names = gcc_pxo_pll8,
  703. .num_parents = 2,
  704. .ops = &clk_rcg_ops,
  705. .flags = CLK_SET_PARENT_GATE,
  706. },
  707. },
  708. };
  709. static struct clk_branch gsbi6_qup_clk = {
  710. .halt_reg = 0x2fd0,
  711. .halt_bit = 16,
  712. .clkr = {
  713. .enable_reg = 0x2a6c,
  714. .enable_mask = BIT(9),
  715. .hw.init = &(struct clk_init_data){
  716. .name = "gsbi6_qup_clk",
  717. .parent_names = (const char *[]){ "gsbi6_qup_src" },
  718. .num_parents = 1,
  719. .ops = &clk_branch_ops,
  720. .flags = CLK_SET_RATE_PARENT,
  721. },
  722. },
  723. };
  724. static struct clk_rcg gsbi7_qup_src = {
  725. .ns_reg = 0x2a8c,
  726. .md_reg = 0x2a88,
  727. .mn = {
  728. .mnctr_en_bit = 8,
  729. .mnctr_reset_bit = 7,
  730. .mnctr_mode_shift = 5,
  731. .n_val_shift = 16,
  732. .m_val_shift = 16,
  733. .width = 8,
  734. },
  735. .p = {
  736. .pre_div_shift = 3,
  737. .pre_div_width = 2,
  738. },
  739. .s = {
  740. .src_sel_shift = 0,
  741. .parent_map = gcc_pxo_pll8_map,
  742. },
  743. .freq_tbl = clk_tbl_gsbi_qup,
  744. .clkr = {
  745. .enable_reg = 0x2a8c,
  746. .enable_mask = BIT(11),
  747. .hw.init = &(struct clk_init_data){
  748. .name = "gsbi7_qup_src",
  749. .parent_names = gcc_pxo_pll8,
  750. .num_parents = 2,
  751. .ops = &clk_rcg_ops,
  752. .flags = CLK_SET_PARENT_GATE,
  753. },
  754. },
  755. };
  756. static struct clk_branch gsbi7_qup_clk = {
  757. .halt_reg = 0x2fd0,
  758. .halt_bit = 12,
  759. .clkr = {
  760. .enable_reg = 0x2a8c,
  761. .enable_mask = BIT(9),
  762. .hw.init = &(struct clk_init_data){
  763. .name = "gsbi7_qup_clk",
  764. .parent_names = (const char *[]){ "gsbi7_qup_src" },
  765. .num_parents = 1,
  766. .ops = &clk_branch_ops,
  767. .flags = CLK_SET_RATE_PARENT,
  768. },
  769. },
  770. };
  771. static struct clk_branch gsbi1_h_clk = {
  772. .hwcg_reg = 0x29c0,
  773. .hwcg_bit = 6,
  774. .halt_reg = 0x2fcc,
  775. .halt_bit = 13,
  776. .clkr = {
  777. .enable_reg = 0x29c0,
  778. .enable_mask = BIT(4),
  779. .hw.init = &(struct clk_init_data){
  780. .name = "gsbi1_h_clk",
  781. .ops = &clk_branch_ops,
  782. .flags = CLK_IS_ROOT,
  783. },
  784. },
  785. };
  786. static struct clk_branch gsbi2_h_clk = {
  787. .hwcg_reg = 0x29e0,
  788. .hwcg_bit = 6,
  789. .halt_reg = 0x2fcc,
  790. .halt_bit = 9,
  791. .clkr = {
  792. .enable_reg = 0x29e0,
  793. .enable_mask = BIT(4),
  794. .hw.init = &(struct clk_init_data){
  795. .name = "gsbi2_h_clk",
  796. .ops = &clk_branch_ops,
  797. .flags = CLK_IS_ROOT,
  798. },
  799. },
  800. };
  801. static struct clk_branch gsbi4_h_clk = {
  802. .hwcg_reg = 0x2a20,
  803. .hwcg_bit = 6,
  804. .halt_reg = 0x2fd0,
  805. .halt_bit = 27,
  806. .clkr = {
  807. .enable_reg = 0x2a20,
  808. .enable_mask = BIT(4),
  809. .hw.init = &(struct clk_init_data){
  810. .name = "gsbi4_h_clk",
  811. .ops = &clk_branch_ops,
  812. .flags = CLK_IS_ROOT,
  813. },
  814. },
  815. };
  816. static struct clk_branch gsbi5_h_clk = {
  817. .hwcg_reg = 0x2a40,
  818. .hwcg_bit = 6,
  819. .halt_reg = 0x2fd0,
  820. .halt_bit = 23,
  821. .clkr = {
  822. .enable_reg = 0x2a40,
  823. .enable_mask = BIT(4),
  824. .hw.init = &(struct clk_init_data){
  825. .name = "gsbi5_h_clk",
  826. .ops = &clk_branch_ops,
  827. .flags = CLK_IS_ROOT,
  828. },
  829. },
  830. };
  831. static struct clk_branch gsbi6_h_clk = {
  832. .hwcg_reg = 0x2a60,
  833. .hwcg_bit = 6,
  834. .halt_reg = 0x2fd0,
  835. .halt_bit = 19,
  836. .clkr = {
  837. .enable_reg = 0x2a60,
  838. .enable_mask = BIT(4),
  839. .hw.init = &(struct clk_init_data){
  840. .name = "gsbi6_h_clk",
  841. .ops = &clk_branch_ops,
  842. .flags = CLK_IS_ROOT,
  843. },
  844. },
  845. };
  846. static struct clk_branch gsbi7_h_clk = {
  847. .hwcg_reg = 0x2a80,
  848. .hwcg_bit = 6,
  849. .halt_reg = 0x2fd0,
  850. .halt_bit = 15,
  851. .clkr = {
  852. .enable_reg = 0x2a80,
  853. .enable_mask = BIT(4),
  854. .hw.init = &(struct clk_init_data){
  855. .name = "gsbi7_h_clk",
  856. .ops = &clk_branch_ops,
  857. .flags = CLK_IS_ROOT,
  858. },
  859. },
  860. };
  861. static const struct freq_tbl clk_tbl_gp[] = {
  862. { 12500000, P_PXO, 2, 0, 0 },
  863. { 25000000, P_PXO, 1, 0, 0 },
  864. { 64000000, P_PLL8, 2, 1, 3 },
  865. { 76800000, P_PLL8, 1, 1, 5 },
  866. { 96000000, P_PLL8, 4, 0, 0 },
  867. { 128000000, P_PLL8, 3, 0, 0 },
  868. { 192000000, P_PLL8, 2, 0, 0 },
  869. { }
  870. };
  871. static struct clk_rcg gp0_src = {
  872. .ns_reg = 0x2d24,
  873. .md_reg = 0x2d00,
  874. .mn = {
  875. .mnctr_en_bit = 8,
  876. .mnctr_reset_bit = 7,
  877. .mnctr_mode_shift = 5,
  878. .n_val_shift = 16,
  879. .m_val_shift = 16,
  880. .width = 8,
  881. },
  882. .p = {
  883. .pre_div_shift = 3,
  884. .pre_div_width = 2,
  885. },
  886. .s = {
  887. .src_sel_shift = 0,
  888. .parent_map = gcc_pxo_pll8_cxo_map,
  889. },
  890. .freq_tbl = clk_tbl_gp,
  891. .clkr = {
  892. .enable_reg = 0x2d24,
  893. .enable_mask = BIT(11),
  894. .hw.init = &(struct clk_init_data){
  895. .name = "gp0_src",
  896. .parent_names = gcc_pxo_pll8_cxo,
  897. .num_parents = 3,
  898. .ops = &clk_rcg_ops,
  899. .flags = CLK_SET_PARENT_GATE,
  900. },
  901. }
  902. };
  903. static struct clk_branch gp0_clk = {
  904. .halt_reg = 0x2fd8,
  905. .halt_bit = 7,
  906. .clkr = {
  907. .enable_reg = 0x2d24,
  908. .enable_mask = BIT(9),
  909. .hw.init = &(struct clk_init_data){
  910. .name = "gp0_clk",
  911. .parent_names = (const char *[]){ "gp0_src" },
  912. .num_parents = 1,
  913. .ops = &clk_branch_ops,
  914. .flags = CLK_SET_RATE_PARENT,
  915. },
  916. },
  917. };
  918. static struct clk_rcg gp1_src = {
  919. .ns_reg = 0x2d44,
  920. .md_reg = 0x2d40,
  921. .mn = {
  922. .mnctr_en_bit = 8,
  923. .mnctr_reset_bit = 7,
  924. .mnctr_mode_shift = 5,
  925. .n_val_shift = 16,
  926. .m_val_shift = 16,
  927. .width = 8,
  928. },
  929. .p = {
  930. .pre_div_shift = 3,
  931. .pre_div_width = 2,
  932. },
  933. .s = {
  934. .src_sel_shift = 0,
  935. .parent_map = gcc_pxo_pll8_cxo_map,
  936. },
  937. .freq_tbl = clk_tbl_gp,
  938. .clkr = {
  939. .enable_reg = 0x2d44,
  940. .enable_mask = BIT(11),
  941. .hw.init = &(struct clk_init_data){
  942. .name = "gp1_src",
  943. .parent_names = gcc_pxo_pll8_cxo,
  944. .num_parents = 3,
  945. .ops = &clk_rcg_ops,
  946. .flags = CLK_SET_RATE_GATE,
  947. },
  948. }
  949. };
  950. static struct clk_branch gp1_clk = {
  951. .halt_reg = 0x2fd8,
  952. .halt_bit = 6,
  953. .clkr = {
  954. .enable_reg = 0x2d44,
  955. .enable_mask = BIT(9),
  956. .hw.init = &(struct clk_init_data){
  957. .name = "gp1_clk",
  958. .parent_names = (const char *[]){ "gp1_src" },
  959. .num_parents = 1,
  960. .ops = &clk_branch_ops,
  961. .flags = CLK_SET_RATE_PARENT,
  962. },
  963. },
  964. };
  965. static struct clk_rcg gp2_src = {
  966. .ns_reg = 0x2d64,
  967. .md_reg = 0x2d60,
  968. .mn = {
  969. .mnctr_en_bit = 8,
  970. .mnctr_reset_bit = 7,
  971. .mnctr_mode_shift = 5,
  972. .n_val_shift = 16,
  973. .m_val_shift = 16,
  974. .width = 8,
  975. },
  976. .p = {
  977. .pre_div_shift = 3,
  978. .pre_div_width = 2,
  979. },
  980. .s = {
  981. .src_sel_shift = 0,
  982. .parent_map = gcc_pxo_pll8_cxo_map,
  983. },
  984. .freq_tbl = clk_tbl_gp,
  985. .clkr = {
  986. .enable_reg = 0x2d64,
  987. .enable_mask = BIT(11),
  988. .hw.init = &(struct clk_init_data){
  989. .name = "gp2_src",
  990. .parent_names = gcc_pxo_pll8_cxo,
  991. .num_parents = 3,
  992. .ops = &clk_rcg_ops,
  993. .flags = CLK_SET_RATE_GATE,
  994. },
  995. }
  996. };
  997. static struct clk_branch gp2_clk = {
  998. .halt_reg = 0x2fd8,
  999. .halt_bit = 5,
  1000. .clkr = {
  1001. .enable_reg = 0x2d64,
  1002. .enable_mask = BIT(9),
  1003. .hw.init = &(struct clk_init_data){
  1004. .name = "gp2_clk",
  1005. .parent_names = (const char *[]){ "gp2_src" },
  1006. .num_parents = 1,
  1007. .ops = &clk_branch_ops,
  1008. .flags = CLK_SET_RATE_PARENT,
  1009. },
  1010. },
  1011. };
  1012. static struct clk_branch pmem_clk = {
  1013. .hwcg_reg = 0x25a0,
  1014. .hwcg_bit = 6,
  1015. .halt_reg = 0x2fc8,
  1016. .halt_bit = 20,
  1017. .clkr = {
  1018. .enable_reg = 0x25a0,
  1019. .enable_mask = BIT(4),
  1020. .hw.init = &(struct clk_init_data){
  1021. .name = "pmem_clk",
  1022. .ops = &clk_branch_ops,
  1023. .flags = CLK_IS_ROOT,
  1024. },
  1025. },
  1026. };
  1027. static struct clk_rcg prng_src = {
  1028. .ns_reg = 0x2e80,
  1029. .p = {
  1030. .pre_div_shift = 3,
  1031. .pre_div_width = 4,
  1032. },
  1033. .s = {
  1034. .src_sel_shift = 0,
  1035. .parent_map = gcc_pxo_pll8_map,
  1036. },
  1037. .clkr = {
  1038. .hw.init = &(struct clk_init_data){
  1039. .name = "prng_src",
  1040. .parent_names = gcc_pxo_pll8,
  1041. .num_parents = 2,
  1042. .ops = &clk_rcg_ops,
  1043. },
  1044. },
  1045. };
  1046. static struct clk_branch prng_clk = {
  1047. .halt_reg = 0x2fd8,
  1048. .halt_check = BRANCH_HALT_VOTED,
  1049. .halt_bit = 10,
  1050. .clkr = {
  1051. .enable_reg = 0x3080,
  1052. .enable_mask = BIT(10),
  1053. .hw.init = &(struct clk_init_data){
  1054. .name = "prng_clk",
  1055. .parent_names = (const char *[]){ "prng_src" },
  1056. .num_parents = 1,
  1057. .ops = &clk_branch_ops,
  1058. },
  1059. },
  1060. };
  1061. static const struct freq_tbl clk_tbl_sdc[] = {
  1062. { 200000, P_PXO, 2, 2, 125 },
  1063. { 400000, P_PLL8, 4, 1, 240 },
  1064. { 16000000, P_PLL8, 4, 1, 6 },
  1065. { 17070000, P_PLL8, 1, 2, 45 },
  1066. { 20210000, P_PLL8, 1, 1, 19 },
  1067. { 24000000, P_PLL8, 4, 1, 4 },
  1068. { 48000000, P_PLL8, 4, 1, 2 },
  1069. { 64000000, P_PLL8, 3, 1, 2 },
  1070. { 96000000, P_PLL8, 4, 0, 0 },
  1071. { 192000000, P_PLL8, 2, 0, 0 },
  1072. { }
  1073. };
  1074. static struct clk_rcg sdc1_src = {
  1075. .ns_reg = 0x282c,
  1076. .md_reg = 0x2828,
  1077. .mn = {
  1078. .mnctr_en_bit = 8,
  1079. .mnctr_reset_bit = 7,
  1080. .mnctr_mode_shift = 5,
  1081. .n_val_shift = 16,
  1082. .m_val_shift = 16,
  1083. .width = 8,
  1084. },
  1085. .p = {
  1086. .pre_div_shift = 3,
  1087. .pre_div_width = 2,
  1088. },
  1089. .s = {
  1090. .src_sel_shift = 0,
  1091. .parent_map = gcc_pxo_pll8_map,
  1092. },
  1093. .freq_tbl = clk_tbl_sdc,
  1094. .clkr = {
  1095. .enable_reg = 0x282c,
  1096. .enable_mask = BIT(11),
  1097. .hw.init = &(struct clk_init_data){
  1098. .name = "sdc1_src",
  1099. .parent_names = gcc_pxo_pll8,
  1100. .num_parents = 2,
  1101. .ops = &clk_rcg_ops,
  1102. .flags = CLK_SET_RATE_GATE,
  1103. },
  1104. }
  1105. };
  1106. static struct clk_branch sdc1_clk = {
  1107. .halt_reg = 0x2fc8,
  1108. .halt_bit = 6,
  1109. .clkr = {
  1110. .enable_reg = 0x282c,
  1111. .enable_mask = BIT(9),
  1112. .hw.init = &(struct clk_init_data){
  1113. .name = "sdc1_clk",
  1114. .parent_names = (const char *[]){ "sdc1_src" },
  1115. .num_parents = 1,
  1116. .ops = &clk_branch_ops,
  1117. .flags = CLK_SET_RATE_PARENT,
  1118. },
  1119. },
  1120. };
  1121. static struct clk_rcg sdc3_src = {
  1122. .ns_reg = 0x286c,
  1123. .md_reg = 0x2868,
  1124. .mn = {
  1125. .mnctr_en_bit = 8,
  1126. .mnctr_reset_bit = 7,
  1127. .mnctr_mode_shift = 5,
  1128. .n_val_shift = 16,
  1129. .m_val_shift = 16,
  1130. .width = 8,
  1131. },
  1132. .p = {
  1133. .pre_div_shift = 3,
  1134. .pre_div_width = 2,
  1135. },
  1136. .s = {
  1137. .src_sel_shift = 0,
  1138. .parent_map = gcc_pxo_pll8_map,
  1139. },
  1140. .freq_tbl = clk_tbl_sdc,
  1141. .clkr = {
  1142. .enable_reg = 0x286c,
  1143. .enable_mask = BIT(11),
  1144. .hw.init = &(struct clk_init_data){
  1145. .name = "sdc3_src",
  1146. .parent_names = gcc_pxo_pll8,
  1147. .num_parents = 2,
  1148. .ops = &clk_rcg_ops,
  1149. .flags = CLK_SET_RATE_GATE,
  1150. },
  1151. }
  1152. };
  1153. static struct clk_branch sdc3_clk = {
  1154. .halt_reg = 0x2fc8,
  1155. .halt_bit = 4,
  1156. .clkr = {
  1157. .enable_reg = 0x286c,
  1158. .enable_mask = BIT(9),
  1159. .hw.init = &(struct clk_init_data){
  1160. .name = "sdc3_clk",
  1161. .parent_names = (const char *[]){ "sdc3_src" },
  1162. .num_parents = 1,
  1163. .ops = &clk_branch_ops,
  1164. .flags = CLK_SET_RATE_PARENT,
  1165. },
  1166. },
  1167. };
  1168. static struct clk_branch sdc1_h_clk = {
  1169. .hwcg_reg = 0x2820,
  1170. .hwcg_bit = 6,
  1171. .halt_reg = 0x2fc8,
  1172. .halt_bit = 11,
  1173. .clkr = {
  1174. .enable_reg = 0x2820,
  1175. .enable_mask = BIT(4),
  1176. .hw.init = &(struct clk_init_data){
  1177. .name = "sdc1_h_clk",
  1178. .ops = &clk_branch_ops,
  1179. .flags = CLK_IS_ROOT,
  1180. },
  1181. },
  1182. };
  1183. static struct clk_branch sdc3_h_clk = {
  1184. .hwcg_reg = 0x2860,
  1185. .hwcg_bit = 6,
  1186. .halt_reg = 0x2fc8,
  1187. .halt_bit = 9,
  1188. .clkr = {
  1189. .enable_reg = 0x2860,
  1190. .enable_mask = BIT(4),
  1191. .hw.init = &(struct clk_init_data){
  1192. .name = "sdc3_h_clk",
  1193. .ops = &clk_branch_ops,
  1194. .flags = CLK_IS_ROOT,
  1195. },
  1196. },
  1197. };
  1198. static const struct freq_tbl clk_tbl_tsif_ref[] = {
  1199. { 105000, P_PXO, 1, 1, 256 },
  1200. { }
  1201. };
  1202. static struct clk_rcg tsif_ref_src = {
  1203. .ns_reg = 0x2710,
  1204. .md_reg = 0x270c,
  1205. .mn = {
  1206. .mnctr_en_bit = 8,
  1207. .mnctr_reset_bit = 7,
  1208. .mnctr_mode_shift = 5,
  1209. .n_val_shift = 16,
  1210. .m_val_shift = 16,
  1211. .width = 16,
  1212. },
  1213. .p = {
  1214. .pre_div_shift = 3,
  1215. .pre_div_width = 2,
  1216. },
  1217. .s = {
  1218. .src_sel_shift = 0,
  1219. .parent_map = gcc_pxo_pll8_map,
  1220. },
  1221. .freq_tbl = clk_tbl_tsif_ref,
  1222. .clkr = {
  1223. .enable_reg = 0x2710,
  1224. .enable_mask = BIT(11),
  1225. .hw.init = &(struct clk_init_data){
  1226. .name = "tsif_ref_src",
  1227. .parent_names = gcc_pxo_pll8,
  1228. .num_parents = 2,
  1229. .ops = &clk_rcg_ops,
  1230. .flags = CLK_SET_RATE_GATE,
  1231. },
  1232. }
  1233. };
  1234. static struct clk_branch tsif_ref_clk = {
  1235. .halt_reg = 0x2fd4,
  1236. .halt_bit = 5,
  1237. .clkr = {
  1238. .enable_reg = 0x2710,
  1239. .enable_mask = BIT(9),
  1240. .hw.init = &(struct clk_init_data){
  1241. .name = "tsif_ref_clk",
  1242. .parent_names = (const char *[]){ "tsif_ref_src" },
  1243. .num_parents = 1,
  1244. .ops = &clk_branch_ops,
  1245. .flags = CLK_SET_RATE_PARENT,
  1246. },
  1247. },
  1248. };
  1249. static struct clk_branch tsif_h_clk = {
  1250. .hwcg_reg = 0x2700,
  1251. .hwcg_bit = 6,
  1252. .halt_reg = 0x2fd4,
  1253. .halt_bit = 7,
  1254. .clkr = {
  1255. .enable_reg = 0x2700,
  1256. .enable_mask = BIT(4),
  1257. .hw.init = &(struct clk_init_data){
  1258. .name = "tsif_h_clk",
  1259. .ops = &clk_branch_ops,
  1260. .flags = CLK_IS_ROOT,
  1261. },
  1262. },
  1263. };
  1264. static struct clk_branch dma_bam_h_clk = {
  1265. .hwcg_reg = 0x25c0,
  1266. .hwcg_bit = 6,
  1267. .halt_reg = 0x2fc8,
  1268. .halt_bit = 12,
  1269. .clkr = {
  1270. .enable_reg = 0x25c0,
  1271. .enable_mask = BIT(4),
  1272. .hw.init = &(struct clk_init_data){
  1273. .name = "dma_bam_h_clk",
  1274. .ops = &clk_branch_ops,
  1275. .flags = CLK_IS_ROOT,
  1276. },
  1277. },
  1278. };
  1279. static struct clk_branch adm0_clk = {
  1280. .halt_reg = 0x2fdc,
  1281. .halt_check = BRANCH_HALT_VOTED,
  1282. .halt_bit = 12,
  1283. .clkr = {
  1284. .enable_reg = 0x3080,
  1285. .enable_mask = BIT(2),
  1286. .hw.init = &(struct clk_init_data){
  1287. .name = "adm0_clk",
  1288. .ops = &clk_branch_ops,
  1289. .flags = CLK_IS_ROOT,
  1290. },
  1291. },
  1292. };
  1293. static struct clk_branch adm0_pbus_clk = {
  1294. .hwcg_reg = 0x2208,
  1295. .hwcg_bit = 6,
  1296. .halt_reg = 0x2fdc,
  1297. .halt_check = BRANCH_HALT_VOTED,
  1298. .halt_bit = 11,
  1299. .clkr = {
  1300. .enable_reg = 0x3080,
  1301. .enable_mask = BIT(3),
  1302. .hw.init = &(struct clk_init_data){
  1303. .name = "adm0_pbus_clk",
  1304. .ops = &clk_branch_ops,
  1305. .flags = CLK_IS_ROOT,
  1306. },
  1307. },
  1308. };
  1309. static struct clk_branch pmic_arb0_h_clk = {
  1310. .halt_reg = 0x2fd8,
  1311. .halt_check = BRANCH_HALT_VOTED,
  1312. .halt_bit = 22,
  1313. .clkr = {
  1314. .enable_reg = 0x3080,
  1315. .enable_mask = BIT(8),
  1316. .hw.init = &(struct clk_init_data){
  1317. .name = "pmic_arb0_h_clk",
  1318. .ops = &clk_branch_ops,
  1319. .flags = CLK_IS_ROOT,
  1320. },
  1321. },
  1322. };
  1323. static struct clk_branch pmic_arb1_h_clk = {
  1324. .halt_reg = 0x2fd8,
  1325. .halt_check = BRANCH_HALT_VOTED,
  1326. .halt_bit = 21,
  1327. .clkr = {
  1328. .enable_reg = 0x3080,
  1329. .enable_mask = BIT(9),
  1330. .hw.init = &(struct clk_init_data){
  1331. .name = "pmic_arb1_h_clk",
  1332. .ops = &clk_branch_ops,
  1333. .flags = CLK_IS_ROOT,
  1334. },
  1335. },
  1336. };
  1337. static struct clk_branch pmic_ssbi2_clk = {
  1338. .halt_reg = 0x2fd8,
  1339. .halt_check = BRANCH_HALT_VOTED,
  1340. .halt_bit = 23,
  1341. .clkr = {
  1342. .enable_reg = 0x3080,
  1343. .enable_mask = BIT(7),
  1344. .hw.init = &(struct clk_init_data){
  1345. .name = "pmic_ssbi2_clk",
  1346. .ops = &clk_branch_ops,
  1347. .flags = CLK_IS_ROOT,
  1348. },
  1349. },
  1350. };
  1351. static struct clk_branch rpm_msg_ram_h_clk = {
  1352. .hwcg_reg = 0x27e0,
  1353. .hwcg_bit = 6,
  1354. .halt_reg = 0x2fd8,
  1355. .halt_check = BRANCH_HALT_VOTED,
  1356. .halt_bit = 12,
  1357. .clkr = {
  1358. .enable_reg = 0x3080,
  1359. .enable_mask = BIT(6),
  1360. .hw.init = &(struct clk_init_data){
  1361. .name = "rpm_msg_ram_h_clk",
  1362. .ops = &clk_branch_ops,
  1363. .flags = CLK_IS_ROOT,
  1364. },
  1365. },
  1366. };
  1367. static const struct freq_tbl clk_tbl_pcie_ref[] = {
  1368. { 100000000, P_PLL3, 12, 0, 0 },
  1369. { }
  1370. };
  1371. static struct clk_rcg pcie_ref_src = {
  1372. .ns_reg = 0x3860,
  1373. .p = {
  1374. .pre_div_shift = 3,
  1375. .pre_div_width = 4,
  1376. },
  1377. .s = {
  1378. .src_sel_shift = 0,
  1379. .parent_map = gcc_pxo_pll3_map,
  1380. },
  1381. .freq_tbl = clk_tbl_pcie_ref,
  1382. .clkr = {
  1383. .enable_reg = 0x3860,
  1384. .enable_mask = BIT(11),
  1385. .hw.init = &(struct clk_init_data){
  1386. .name = "pcie_ref_src",
  1387. .parent_names = gcc_pxo_pll3,
  1388. .num_parents = 2,
  1389. .ops = &clk_rcg_ops,
  1390. .flags = CLK_SET_RATE_GATE,
  1391. },
  1392. },
  1393. };
  1394. static struct clk_branch pcie_ref_src_clk = {
  1395. .halt_reg = 0x2fdc,
  1396. .halt_bit = 30,
  1397. .clkr = {
  1398. .enable_reg = 0x3860,
  1399. .enable_mask = BIT(9),
  1400. .hw.init = &(struct clk_init_data){
  1401. .name = "pcie_ref_src_clk",
  1402. .parent_names = (const char *[]){ "pcie_ref_src" },
  1403. .num_parents = 1,
  1404. .ops = &clk_branch_ops,
  1405. .flags = CLK_SET_RATE_PARENT,
  1406. },
  1407. },
  1408. };
  1409. static struct clk_branch pcie_a_clk = {
  1410. .halt_reg = 0x2fc0,
  1411. .halt_bit = 13,
  1412. .clkr = {
  1413. .enable_reg = 0x22c0,
  1414. .enable_mask = BIT(4),
  1415. .hw.init = &(struct clk_init_data){
  1416. .name = "pcie_a_clk",
  1417. .ops = &clk_branch_ops,
  1418. .flags = CLK_IS_ROOT,
  1419. },
  1420. },
  1421. };
  1422. static struct clk_branch pcie_aux_clk = {
  1423. .halt_reg = 0x2fdc,
  1424. .halt_bit = 31,
  1425. .clkr = {
  1426. .enable_reg = 0x22c8,
  1427. .enable_mask = BIT(4),
  1428. .hw.init = &(struct clk_init_data){
  1429. .name = "pcie_aux_clk",
  1430. .ops = &clk_branch_ops,
  1431. .flags = CLK_IS_ROOT,
  1432. },
  1433. },
  1434. };
  1435. static struct clk_branch pcie_h_clk = {
  1436. .halt_reg = 0x2fd4,
  1437. .halt_bit = 8,
  1438. .clkr = {
  1439. .enable_reg = 0x22cc,
  1440. .enable_mask = BIT(4),
  1441. .hw.init = &(struct clk_init_data){
  1442. .name = "pcie_h_clk",
  1443. .ops = &clk_branch_ops,
  1444. .flags = CLK_IS_ROOT,
  1445. },
  1446. },
  1447. };
  1448. static struct clk_branch pcie_phy_clk = {
  1449. .halt_reg = 0x2fdc,
  1450. .halt_bit = 29,
  1451. .clkr = {
  1452. .enable_reg = 0x22d0,
  1453. .enable_mask = BIT(4),
  1454. .hw.init = &(struct clk_init_data){
  1455. .name = "pcie_phy_clk",
  1456. .ops = &clk_branch_ops,
  1457. .flags = CLK_IS_ROOT,
  1458. },
  1459. },
  1460. };
  1461. static struct clk_rcg pcie1_ref_src = {
  1462. .ns_reg = 0x3aa0,
  1463. .p = {
  1464. .pre_div_shift = 3,
  1465. .pre_div_width = 4,
  1466. },
  1467. .s = {
  1468. .src_sel_shift = 0,
  1469. .parent_map = gcc_pxo_pll3_map,
  1470. },
  1471. .freq_tbl = clk_tbl_pcie_ref,
  1472. .clkr = {
  1473. .enable_reg = 0x3aa0,
  1474. .enable_mask = BIT(11),
  1475. .hw.init = &(struct clk_init_data){
  1476. .name = "pcie1_ref_src",
  1477. .parent_names = gcc_pxo_pll3,
  1478. .num_parents = 2,
  1479. .ops = &clk_rcg_ops,
  1480. .flags = CLK_SET_RATE_GATE,
  1481. },
  1482. },
  1483. };
  1484. static struct clk_branch pcie1_ref_src_clk = {
  1485. .halt_reg = 0x2fdc,
  1486. .halt_bit = 27,
  1487. .clkr = {
  1488. .enable_reg = 0x3aa0,
  1489. .enable_mask = BIT(9),
  1490. .hw.init = &(struct clk_init_data){
  1491. .name = "pcie1_ref_src_clk",
  1492. .parent_names = (const char *[]){ "pcie1_ref_src" },
  1493. .num_parents = 1,
  1494. .ops = &clk_branch_ops,
  1495. .flags = CLK_SET_RATE_PARENT,
  1496. },
  1497. },
  1498. };
  1499. static struct clk_branch pcie1_a_clk = {
  1500. .halt_reg = 0x2fc0,
  1501. .halt_bit = 10,
  1502. .clkr = {
  1503. .enable_reg = 0x3a80,
  1504. .enable_mask = BIT(4),
  1505. .hw.init = &(struct clk_init_data){
  1506. .name = "pcie1_a_clk",
  1507. .ops = &clk_branch_ops,
  1508. .flags = CLK_IS_ROOT,
  1509. },
  1510. },
  1511. };
  1512. static struct clk_branch pcie1_aux_clk = {
  1513. .halt_reg = 0x2fdc,
  1514. .halt_bit = 28,
  1515. .clkr = {
  1516. .enable_reg = 0x3a88,
  1517. .enable_mask = BIT(4),
  1518. .hw.init = &(struct clk_init_data){
  1519. .name = "pcie1_aux_clk",
  1520. .ops = &clk_branch_ops,
  1521. .flags = CLK_IS_ROOT,
  1522. },
  1523. },
  1524. };
  1525. static struct clk_branch pcie1_h_clk = {
  1526. .halt_reg = 0x2fd4,
  1527. .halt_bit = 9,
  1528. .clkr = {
  1529. .enable_reg = 0x3a8c,
  1530. .enable_mask = BIT(4),
  1531. .hw.init = &(struct clk_init_data){
  1532. .name = "pcie1_h_clk",
  1533. .ops = &clk_branch_ops,
  1534. .flags = CLK_IS_ROOT,
  1535. },
  1536. },
  1537. };
  1538. static struct clk_branch pcie1_phy_clk = {
  1539. .halt_reg = 0x2fdc,
  1540. .halt_bit = 26,
  1541. .clkr = {
  1542. .enable_reg = 0x3a90,
  1543. .enable_mask = BIT(4),
  1544. .hw.init = &(struct clk_init_data){
  1545. .name = "pcie1_phy_clk",
  1546. .ops = &clk_branch_ops,
  1547. .flags = CLK_IS_ROOT,
  1548. },
  1549. },
  1550. };
  1551. static struct clk_rcg pcie2_ref_src = {
  1552. .ns_reg = 0x3ae0,
  1553. .p = {
  1554. .pre_div_shift = 3,
  1555. .pre_div_width = 4,
  1556. },
  1557. .s = {
  1558. .src_sel_shift = 0,
  1559. .parent_map = gcc_pxo_pll3_map,
  1560. },
  1561. .freq_tbl = clk_tbl_pcie_ref,
  1562. .clkr = {
  1563. .enable_reg = 0x3ae0,
  1564. .enable_mask = BIT(11),
  1565. .hw.init = &(struct clk_init_data){
  1566. .name = "pcie2_ref_src",
  1567. .parent_names = gcc_pxo_pll3,
  1568. .num_parents = 2,
  1569. .ops = &clk_rcg_ops,
  1570. .flags = CLK_SET_RATE_GATE,
  1571. },
  1572. },
  1573. };
  1574. static struct clk_branch pcie2_ref_src_clk = {
  1575. .halt_reg = 0x2fdc,
  1576. .halt_bit = 24,
  1577. .clkr = {
  1578. .enable_reg = 0x3ae0,
  1579. .enable_mask = BIT(9),
  1580. .hw.init = &(struct clk_init_data){
  1581. .name = "pcie2_ref_src_clk",
  1582. .parent_names = (const char *[]){ "pcie2_ref_src" },
  1583. .num_parents = 1,
  1584. .ops = &clk_branch_ops,
  1585. .flags = CLK_SET_RATE_PARENT,
  1586. },
  1587. },
  1588. };
  1589. static struct clk_branch pcie2_a_clk = {
  1590. .halt_reg = 0x2fc0,
  1591. .halt_bit = 9,
  1592. .clkr = {
  1593. .enable_reg = 0x3ac0,
  1594. .enable_mask = BIT(4),
  1595. .hw.init = &(struct clk_init_data){
  1596. .name = "pcie2_a_clk",
  1597. .ops = &clk_branch_ops,
  1598. .flags = CLK_IS_ROOT,
  1599. },
  1600. },
  1601. };
  1602. static struct clk_branch pcie2_aux_clk = {
  1603. .halt_reg = 0x2fdc,
  1604. .halt_bit = 25,
  1605. .clkr = {
  1606. .enable_reg = 0x3ac8,
  1607. .enable_mask = BIT(4),
  1608. .hw.init = &(struct clk_init_data){
  1609. .name = "pcie2_aux_clk",
  1610. .ops = &clk_branch_ops,
  1611. .flags = CLK_IS_ROOT,
  1612. },
  1613. },
  1614. };
  1615. static struct clk_branch pcie2_h_clk = {
  1616. .halt_reg = 0x2fd4,
  1617. .halt_bit = 10,
  1618. .clkr = {
  1619. .enable_reg = 0x3acc,
  1620. .enable_mask = BIT(4),
  1621. .hw.init = &(struct clk_init_data){
  1622. .name = "pcie2_h_clk",
  1623. .ops = &clk_branch_ops,
  1624. .flags = CLK_IS_ROOT,
  1625. },
  1626. },
  1627. };
  1628. static struct clk_branch pcie2_phy_clk = {
  1629. .halt_reg = 0x2fdc,
  1630. .halt_bit = 23,
  1631. .clkr = {
  1632. .enable_reg = 0x3ad0,
  1633. .enable_mask = BIT(4),
  1634. .hw.init = &(struct clk_init_data){
  1635. .name = "pcie2_phy_clk",
  1636. .ops = &clk_branch_ops,
  1637. .flags = CLK_IS_ROOT,
  1638. },
  1639. },
  1640. };
  1641. static const struct freq_tbl clk_tbl_sata_ref[] = {
  1642. { 100000000, P_PLL3, 12, 0, 0 },
  1643. { }
  1644. };
  1645. static struct clk_rcg sata_ref_src = {
  1646. .ns_reg = 0x2c08,
  1647. .p = {
  1648. .pre_div_shift = 3,
  1649. .pre_div_width = 4,
  1650. },
  1651. .s = {
  1652. .src_sel_shift = 0,
  1653. .parent_map = gcc_pxo_pll3_sata_map,
  1654. },
  1655. .freq_tbl = clk_tbl_sata_ref,
  1656. .clkr = {
  1657. .enable_reg = 0x2c08,
  1658. .enable_mask = BIT(7),
  1659. .hw.init = &(struct clk_init_data){
  1660. .name = "sata_ref_src",
  1661. .parent_names = gcc_pxo_pll3,
  1662. .num_parents = 2,
  1663. .ops = &clk_rcg_ops,
  1664. .flags = CLK_SET_RATE_GATE,
  1665. },
  1666. },
  1667. };
  1668. static struct clk_branch sata_rxoob_clk = {
  1669. .halt_reg = 0x2fdc,
  1670. .halt_bit = 20,
  1671. .clkr = {
  1672. .enable_reg = 0x2c0c,
  1673. .enable_mask = BIT(4),
  1674. .hw.init = &(struct clk_init_data){
  1675. .name = "sata_rxoob_clk",
  1676. .parent_names = (const char *[]){ "sata_ref_src" },
  1677. .num_parents = 1,
  1678. .ops = &clk_branch_ops,
  1679. .flags = CLK_SET_RATE_PARENT,
  1680. },
  1681. },
  1682. };
  1683. static struct clk_branch sata_pmalive_clk = {
  1684. .halt_reg = 0x2fdc,
  1685. .halt_bit = 19,
  1686. .clkr = {
  1687. .enable_reg = 0x2c10,
  1688. .enable_mask = BIT(4),
  1689. .hw.init = &(struct clk_init_data){
  1690. .name = "sata_pmalive_clk",
  1691. .parent_names = (const char *[]){ "sata_ref_src" },
  1692. .num_parents = 1,
  1693. .ops = &clk_branch_ops,
  1694. .flags = CLK_SET_RATE_PARENT,
  1695. },
  1696. },
  1697. };
  1698. static struct clk_branch sata_phy_ref_clk = {
  1699. .halt_reg = 0x2fdc,
  1700. .halt_bit = 18,
  1701. .clkr = {
  1702. .enable_reg = 0x2c14,
  1703. .enable_mask = BIT(4),
  1704. .hw.init = &(struct clk_init_data){
  1705. .name = "sata_phy_ref_clk",
  1706. .parent_names = (const char *[]){ "pxo" },
  1707. .num_parents = 1,
  1708. .ops = &clk_branch_ops,
  1709. },
  1710. },
  1711. };
  1712. static struct clk_branch sata_a_clk = {
  1713. .halt_reg = 0x2fc0,
  1714. .halt_bit = 12,
  1715. .clkr = {
  1716. .enable_reg = 0x2c20,
  1717. .enable_mask = BIT(4),
  1718. .hw.init = &(struct clk_init_data){
  1719. .name = "sata_a_clk",
  1720. .ops = &clk_branch_ops,
  1721. .flags = CLK_IS_ROOT,
  1722. },
  1723. },
  1724. };
  1725. static struct clk_branch sata_h_clk = {
  1726. .halt_reg = 0x2fdc,
  1727. .halt_bit = 21,
  1728. .clkr = {
  1729. .enable_reg = 0x2c00,
  1730. .enable_mask = BIT(4),
  1731. .hw.init = &(struct clk_init_data){
  1732. .name = "sata_h_clk",
  1733. .ops = &clk_branch_ops,
  1734. .flags = CLK_IS_ROOT,
  1735. },
  1736. },
  1737. };
  1738. static struct clk_branch sfab_sata_s_h_clk = {
  1739. .halt_reg = 0x2fc4,
  1740. .halt_bit = 14,
  1741. .clkr = {
  1742. .enable_reg = 0x2480,
  1743. .enable_mask = BIT(4),
  1744. .hw.init = &(struct clk_init_data){
  1745. .name = "sfab_sata_s_h_clk",
  1746. .ops = &clk_branch_ops,
  1747. .flags = CLK_IS_ROOT,
  1748. },
  1749. },
  1750. };
  1751. static struct clk_branch sata_phy_cfg_clk = {
  1752. .halt_reg = 0x2fcc,
  1753. .halt_bit = 14,
  1754. .clkr = {
  1755. .enable_reg = 0x2c40,
  1756. .enable_mask = BIT(4),
  1757. .hw.init = &(struct clk_init_data){
  1758. .name = "sata_phy_cfg_clk",
  1759. .ops = &clk_branch_ops,
  1760. .flags = CLK_IS_ROOT,
  1761. },
  1762. },
  1763. };
  1764. static const struct freq_tbl clk_tbl_usb30_master[] = {
  1765. { 125000000, P_PLL0, 1, 5, 32 },
  1766. { }
  1767. };
  1768. static struct clk_rcg usb30_master_clk_src = {
  1769. .ns_reg = 0x3b2c,
  1770. .md_reg = 0x3b28,
  1771. .mn = {
  1772. .mnctr_en_bit = 8,
  1773. .mnctr_reset_bit = 7,
  1774. .mnctr_mode_shift = 5,
  1775. .n_val_shift = 16,
  1776. .m_val_shift = 16,
  1777. .width = 8,
  1778. },
  1779. .p = {
  1780. .pre_div_shift = 3,
  1781. .pre_div_width = 2,
  1782. },
  1783. .s = {
  1784. .src_sel_shift = 0,
  1785. .parent_map = gcc_pxo_pll8_pll0,
  1786. },
  1787. .freq_tbl = clk_tbl_usb30_master,
  1788. .clkr = {
  1789. .enable_reg = 0x3b2c,
  1790. .enable_mask = BIT(11),
  1791. .hw.init = &(struct clk_init_data){
  1792. .name = "usb30_master_ref_src",
  1793. .parent_names = gcc_pxo_pll8_pll0_map,
  1794. .num_parents = 3,
  1795. .ops = &clk_rcg_ops,
  1796. .flags = CLK_SET_RATE_GATE,
  1797. },
  1798. },
  1799. };
  1800. static struct clk_branch usb30_0_branch_clk = {
  1801. .halt_reg = 0x2fc4,
  1802. .halt_bit = 22,
  1803. .clkr = {
  1804. .enable_reg = 0x3b24,
  1805. .enable_mask = BIT(4),
  1806. .hw.init = &(struct clk_init_data){
  1807. .name = "usb30_0_branch_clk",
  1808. .parent_names = (const char *[]){ "usb30_master_ref_src", },
  1809. .num_parents = 1,
  1810. .ops = &clk_branch_ops,
  1811. .flags = CLK_SET_RATE_PARENT,
  1812. },
  1813. },
  1814. };
  1815. static struct clk_branch usb30_1_branch_clk = {
  1816. .halt_reg = 0x2fc4,
  1817. .halt_bit = 17,
  1818. .clkr = {
  1819. .enable_reg = 0x3b34,
  1820. .enable_mask = BIT(4),
  1821. .hw.init = &(struct clk_init_data){
  1822. .name = "usb30_1_branch_clk",
  1823. .parent_names = (const char *[]){ "usb30_master_ref_src", },
  1824. .num_parents = 1,
  1825. .ops = &clk_branch_ops,
  1826. .flags = CLK_SET_RATE_PARENT,
  1827. },
  1828. },
  1829. };
  1830. static const struct freq_tbl clk_tbl_usb30_utmi[] = {
  1831. { 60000000, P_PLL8, 1, 5, 32 },
  1832. { }
  1833. };
  1834. static struct clk_rcg usb30_utmi_clk = {
  1835. .ns_reg = 0x3b44,
  1836. .md_reg = 0x3b40,
  1837. .mn = {
  1838. .mnctr_en_bit = 8,
  1839. .mnctr_reset_bit = 7,
  1840. .mnctr_mode_shift = 5,
  1841. .n_val_shift = 16,
  1842. .m_val_shift = 16,
  1843. .width = 8,
  1844. },
  1845. .p = {
  1846. .pre_div_shift = 3,
  1847. .pre_div_width = 2,
  1848. },
  1849. .s = {
  1850. .src_sel_shift = 0,
  1851. .parent_map = gcc_pxo_pll8_pll0,
  1852. },
  1853. .freq_tbl = clk_tbl_usb30_utmi,
  1854. .clkr = {
  1855. .enable_reg = 0x3b44,
  1856. .enable_mask = BIT(11),
  1857. .hw.init = &(struct clk_init_data){
  1858. .name = "usb30_utmi_clk",
  1859. .parent_names = gcc_pxo_pll8_pll0_map,
  1860. .num_parents = 3,
  1861. .ops = &clk_rcg_ops,
  1862. .flags = CLK_SET_RATE_GATE,
  1863. },
  1864. },
  1865. };
  1866. static struct clk_branch usb30_0_utmi_clk_ctl = {
  1867. .halt_reg = 0x2fc4,
  1868. .halt_bit = 21,
  1869. .clkr = {
  1870. .enable_reg = 0x3b48,
  1871. .enable_mask = BIT(4),
  1872. .hw.init = &(struct clk_init_data){
  1873. .name = "usb30_0_utmi_clk_ctl",
  1874. .parent_names = (const char *[]){ "usb30_utmi_clk", },
  1875. .num_parents = 1,
  1876. .ops = &clk_branch_ops,
  1877. .flags = CLK_SET_RATE_PARENT,
  1878. },
  1879. },
  1880. };
  1881. static struct clk_branch usb30_1_utmi_clk_ctl = {
  1882. .halt_reg = 0x2fc4,
  1883. .halt_bit = 15,
  1884. .clkr = {
  1885. .enable_reg = 0x3b4c,
  1886. .enable_mask = BIT(4),
  1887. .hw.init = &(struct clk_init_data){
  1888. .name = "usb30_1_utmi_clk_ctl",
  1889. .parent_names = (const char *[]){ "usb30_utmi_clk", },
  1890. .num_parents = 1,
  1891. .ops = &clk_branch_ops,
  1892. .flags = CLK_SET_RATE_PARENT,
  1893. },
  1894. },
  1895. };
  1896. static const struct freq_tbl clk_tbl_usb[] = {
  1897. { 60000000, P_PLL8, 1, 5, 32 },
  1898. { }
  1899. };
  1900. static struct clk_rcg usb_hs1_xcvr_clk_src = {
  1901. .ns_reg = 0x290C,
  1902. .md_reg = 0x2908,
  1903. .mn = {
  1904. .mnctr_en_bit = 8,
  1905. .mnctr_reset_bit = 7,
  1906. .mnctr_mode_shift = 5,
  1907. .n_val_shift = 16,
  1908. .m_val_shift = 16,
  1909. .width = 8,
  1910. },
  1911. .p = {
  1912. .pre_div_shift = 3,
  1913. .pre_div_width = 2,
  1914. },
  1915. .s = {
  1916. .src_sel_shift = 0,
  1917. .parent_map = gcc_pxo_pll8_pll0,
  1918. },
  1919. .freq_tbl = clk_tbl_usb,
  1920. .clkr = {
  1921. .enable_reg = 0x2968,
  1922. .enable_mask = BIT(11),
  1923. .hw.init = &(struct clk_init_data){
  1924. .name = "usb_hs1_xcvr_src",
  1925. .parent_names = gcc_pxo_pll8_pll0_map,
  1926. .num_parents = 3,
  1927. .ops = &clk_rcg_ops,
  1928. .flags = CLK_SET_RATE_GATE,
  1929. },
  1930. },
  1931. };
  1932. static struct clk_branch usb_hs1_xcvr_clk = {
  1933. .halt_reg = 0x2fcc,
  1934. .halt_bit = 17,
  1935. .clkr = {
  1936. .enable_reg = 0x290c,
  1937. .enable_mask = BIT(9),
  1938. .hw.init = &(struct clk_init_data){
  1939. .name = "usb_hs1_xcvr_clk",
  1940. .parent_names = (const char *[]){ "usb_hs1_xcvr_src" },
  1941. .num_parents = 1,
  1942. .ops = &clk_branch_ops,
  1943. .flags = CLK_SET_RATE_PARENT,
  1944. },
  1945. },
  1946. };
  1947. static struct clk_branch usb_hs1_h_clk = {
  1948. .hwcg_reg = 0x2900,
  1949. .hwcg_bit = 6,
  1950. .halt_reg = 0x2fc8,
  1951. .halt_bit = 1,
  1952. .clkr = {
  1953. .enable_reg = 0x2900,
  1954. .enable_mask = BIT(4),
  1955. .hw.init = &(struct clk_init_data){
  1956. .name = "usb_hs1_h_clk",
  1957. .ops = &clk_branch_ops,
  1958. .flags = CLK_IS_ROOT,
  1959. },
  1960. },
  1961. };
  1962. static struct clk_rcg usb_fs1_xcvr_clk_src = {
  1963. .ns_reg = 0x2968,
  1964. .md_reg = 0x2964,
  1965. .mn = {
  1966. .mnctr_en_bit = 8,
  1967. .mnctr_reset_bit = 7,
  1968. .mnctr_mode_shift = 5,
  1969. .n_val_shift = 16,
  1970. .m_val_shift = 16,
  1971. .width = 8,
  1972. },
  1973. .p = {
  1974. .pre_div_shift = 3,
  1975. .pre_div_width = 2,
  1976. },
  1977. .s = {
  1978. .src_sel_shift = 0,
  1979. .parent_map = gcc_pxo_pll8_pll0,
  1980. },
  1981. .freq_tbl = clk_tbl_usb,
  1982. .clkr = {
  1983. .enable_reg = 0x2968,
  1984. .enable_mask = BIT(11),
  1985. .hw.init = &(struct clk_init_data){
  1986. .name = "usb_fs1_xcvr_src",
  1987. .parent_names = gcc_pxo_pll8_pll0_map,
  1988. .num_parents = 3,
  1989. .ops = &clk_rcg_ops,
  1990. .flags = CLK_SET_RATE_GATE,
  1991. },
  1992. },
  1993. };
  1994. static struct clk_branch usb_fs1_xcvr_clk = {
  1995. .halt_reg = 0x2fcc,
  1996. .halt_bit = 17,
  1997. .clkr = {
  1998. .enable_reg = 0x2968,
  1999. .enable_mask = BIT(9),
  2000. .hw.init = &(struct clk_init_data){
  2001. .name = "usb_fs1_xcvr_clk",
  2002. .parent_names = (const char *[]){ "usb_fs1_xcvr_src", },
  2003. .num_parents = 1,
  2004. .ops = &clk_branch_ops,
  2005. .flags = CLK_SET_RATE_PARENT,
  2006. },
  2007. },
  2008. };
  2009. static struct clk_branch usb_fs1_sys_clk = {
  2010. .halt_reg = 0x2fcc,
  2011. .halt_bit = 18,
  2012. .clkr = {
  2013. .enable_reg = 0x296c,
  2014. .enable_mask = BIT(4),
  2015. .hw.init = &(struct clk_init_data){
  2016. .name = "usb_fs1_sys_clk",
  2017. .parent_names = (const char *[]){ "usb_fs1_xcvr_src", },
  2018. .num_parents = 1,
  2019. .ops = &clk_branch_ops,
  2020. .flags = CLK_SET_RATE_PARENT,
  2021. },
  2022. },
  2023. };
  2024. static struct clk_branch usb_fs1_h_clk = {
  2025. .halt_reg = 0x2fcc,
  2026. .halt_bit = 19,
  2027. .clkr = {
  2028. .enable_reg = 0x2960,
  2029. .enable_mask = BIT(4),
  2030. .hw.init = &(struct clk_init_data){
  2031. .name = "usb_fs1_h_clk",
  2032. .ops = &clk_branch_ops,
  2033. .flags = CLK_IS_ROOT,
  2034. },
  2035. },
  2036. };
  2037. static struct clk_regmap *gcc_ipq806x_clks[] = {
  2038. [PLL0] = &pll0.clkr,
  2039. [PLL0_VOTE] = &pll0_vote,
  2040. [PLL3] = &pll3.clkr,
  2041. [PLL8] = &pll8.clkr,
  2042. [PLL8_VOTE] = &pll8_vote,
  2043. [PLL14] = &pll14.clkr,
  2044. [PLL14_VOTE] = &pll14_vote,
  2045. [GSBI1_UART_SRC] = &gsbi1_uart_src.clkr,
  2046. [GSBI1_UART_CLK] = &gsbi1_uart_clk.clkr,
  2047. [GSBI2_UART_SRC] = &gsbi2_uart_src.clkr,
  2048. [GSBI2_UART_CLK] = &gsbi2_uart_clk.clkr,
  2049. [GSBI4_UART_SRC] = &gsbi4_uart_src.clkr,
  2050. [GSBI4_UART_CLK] = &gsbi4_uart_clk.clkr,
  2051. [GSBI5_UART_SRC] = &gsbi5_uart_src.clkr,
  2052. [GSBI5_UART_CLK] = &gsbi5_uart_clk.clkr,
  2053. [GSBI6_UART_SRC] = &gsbi6_uart_src.clkr,
  2054. [GSBI6_UART_CLK] = &gsbi6_uart_clk.clkr,
  2055. [GSBI7_UART_SRC] = &gsbi7_uart_src.clkr,
  2056. [GSBI7_UART_CLK] = &gsbi7_uart_clk.clkr,
  2057. [GSBI1_QUP_SRC] = &gsbi1_qup_src.clkr,
  2058. [GSBI1_QUP_CLK] = &gsbi1_qup_clk.clkr,
  2059. [GSBI2_QUP_SRC] = &gsbi2_qup_src.clkr,
  2060. [GSBI2_QUP_CLK] = &gsbi2_qup_clk.clkr,
  2061. [GSBI4_QUP_SRC] = &gsbi4_qup_src.clkr,
  2062. [GSBI4_QUP_CLK] = &gsbi4_qup_clk.clkr,
  2063. [GSBI5_QUP_SRC] = &gsbi5_qup_src.clkr,
  2064. [GSBI5_QUP_CLK] = &gsbi5_qup_clk.clkr,
  2065. [GSBI6_QUP_SRC] = &gsbi6_qup_src.clkr,
  2066. [GSBI6_QUP_CLK] = &gsbi6_qup_clk.clkr,
  2067. [GSBI7_QUP_SRC] = &gsbi7_qup_src.clkr,
  2068. [GSBI7_QUP_CLK] = &gsbi7_qup_clk.clkr,
  2069. [GP0_SRC] = &gp0_src.clkr,
  2070. [GP0_CLK] = &gp0_clk.clkr,
  2071. [GP1_SRC] = &gp1_src.clkr,
  2072. [GP1_CLK] = &gp1_clk.clkr,
  2073. [GP2_SRC] = &gp2_src.clkr,
  2074. [GP2_CLK] = &gp2_clk.clkr,
  2075. [PMEM_A_CLK] = &pmem_clk.clkr,
  2076. [PRNG_SRC] = &prng_src.clkr,
  2077. [PRNG_CLK] = &prng_clk.clkr,
  2078. [SDC1_SRC] = &sdc1_src.clkr,
  2079. [SDC1_CLK] = &sdc1_clk.clkr,
  2080. [SDC3_SRC] = &sdc3_src.clkr,
  2081. [SDC3_CLK] = &sdc3_clk.clkr,
  2082. [TSIF_REF_SRC] = &tsif_ref_src.clkr,
  2083. [TSIF_REF_CLK] = &tsif_ref_clk.clkr,
  2084. [DMA_BAM_H_CLK] = &dma_bam_h_clk.clkr,
  2085. [GSBI1_H_CLK] = &gsbi1_h_clk.clkr,
  2086. [GSBI2_H_CLK] = &gsbi2_h_clk.clkr,
  2087. [GSBI4_H_CLK] = &gsbi4_h_clk.clkr,
  2088. [GSBI5_H_CLK] = &gsbi5_h_clk.clkr,
  2089. [GSBI6_H_CLK] = &gsbi6_h_clk.clkr,
  2090. [GSBI7_H_CLK] = &gsbi7_h_clk.clkr,
  2091. [TSIF_H_CLK] = &tsif_h_clk.clkr,
  2092. [SDC1_H_CLK] = &sdc1_h_clk.clkr,
  2093. [SDC3_H_CLK] = &sdc3_h_clk.clkr,
  2094. [ADM0_CLK] = &adm0_clk.clkr,
  2095. [ADM0_PBUS_CLK] = &adm0_pbus_clk.clkr,
  2096. [PCIE_A_CLK] = &pcie_a_clk.clkr,
  2097. [PCIE_AUX_CLK] = &pcie_aux_clk.clkr,
  2098. [PCIE_H_CLK] = &pcie_h_clk.clkr,
  2099. [PCIE_PHY_CLK] = &pcie_phy_clk.clkr,
  2100. [SFAB_SATA_S_H_CLK] = &sfab_sata_s_h_clk.clkr,
  2101. [PMIC_ARB0_H_CLK] = &pmic_arb0_h_clk.clkr,
  2102. [PMIC_ARB1_H_CLK] = &pmic_arb1_h_clk.clkr,
  2103. [PMIC_SSBI2_CLK] = &pmic_ssbi2_clk.clkr,
  2104. [RPM_MSG_RAM_H_CLK] = &rpm_msg_ram_h_clk.clkr,
  2105. [SATA_H_CLK] = &sata_h_clk.clkr,
  2106. [SATA_CLK_SRC] = &sata_ref_src.clkr,
  2107. [SATA_RXOOB_CLK] = &sata_rxoob_clk.clkr,
  2108. [SATA_PMALIVE_CLK] = &sata_pmalive_clk.clkr,
  2109. [SATA_PHY_REF_CLK] = &sata_phy_ref_clk.clkr,
  2110. [SATA_A_CLK] = &sata_a_clk.clkr,
  2111. [SATA_PHY_CFG_CLK] = &sata_phy_cfg_clk.clkr,
  2112. [PCIE_ALT_REF_SRC] = &pcie_ref_src.clkr,
  2113. [PCIE_ALT_REF_CLK] = &pcie_ref_src_clk.clkr,
  2114. [PCIE_1_A_CLK] = &pcie1_a_clk.clkr,
  2115. [PCIE_1_AUX_CLK] = &pcie1_aux_clk.clkr,
  2116. [PCIE_1_H_CLK] = &pcie1_h_clk.clkr,
  2117. [PCIE_1_PHY_CLK] = &pcie1_phy_clk.clkr,
  2118. [PCIE_1_ALT_REF_SRC] = &pcie1_ref_src.clkr,
  2119. [PCIE_1_ALT_REF_CLK] = &pcie1_ref_src_clk.clkr,
  2120. [PCIE_2_A_CLK] = &pcie2_a_clk.clkr,
  2121. [PCIE_2_AUX_CLK] = &pcie2_aux_clk.clkr,
  2122. [PCIE_2_H_CLK] = &pcie2_h_clk.clkr,
  2123. [PCIE_2_PHY_CLK] = &pcie2_phy_clk.clkr,
  2124. [PCIE_2_ALT_REF_SRC] = &pcie2_ref_src.clkr,
  2125. [PCIE_2_ALT_REF_CLK] = &pcie2_ref_src_clk.clkr,
  2126. [USB30_MASTER_SRC] = &usb30_master_clk_src.clkr,
  2127. [USB30_0_MASTER_CLK] = &usb30_0_branch_clk.clkr,
  2128. [USB30_1_MASTER_CLK] = &usb30_1_branch_clk.clkr,
  2129. [USB30_UTMI_SRC] = &usb30_utmi_clk.clkr,
  2130. [USB30_0_UTMI_CLK] = &usb30_0_utmi_clk_ctl.clkr,
  2131. [USB30_1_UTMI_CLK] = &usb30_1_utmi_clk_ctl.clkr,
  2132. [USB_HS1_H_CLK] = &usb_hs1_h_clk.clkr,
  2133. [USB_HS1_XCVR_SRC] = &usb_hs1_xcvr_clk_src.clkr,
  2134. [USB_HS1_XCVR_CLK] = &usb_hs1_xcvr_clk.clkr,
  2135. [USB_FS1_H_CLK] = &usb_fs1_h_clk.clkr,
  2136. [USB_FS1_XCVR_SRC] = &usb_fs1_xcvr_clk_src.clkr,
  2137. [USB_FS1_XCVR_CLK] = &usb_fs1_xcvr_clk.clkr,
  2138. [USB_FS1_SYSTEM_CLK] = &usb_fs1_sys_clk.clkr,
  2139. };
  2140. static const struct qcom_reset_map gcc_ipq806x_resets[] = {
  2141. [QDSS_STM_RESET] = { 0x2060, 6 },
  2142. [AFAB_SMPSS_S_RESET] = { 0x20b8, 2 },
  2143. [AFAB_SMPSS_M1_RESET] = { 0x20b8, 1 },
  2144. [AFAB_SMPSS_M0_RESET] = { 0x20b8, 0 },
  2145. [AFAB_EBI1_CH0_RESET] = { 0x20c0, 7 },
  2146. [AFAB_EBI1_CH1_RESET] = { 0x20c4, 7 },
  2147. [SFAB_ADM0_M0_RESET] = { 0x21e0, 7 },
  2148. [SFAB_ADM0_M1_RESET] = { 0x21e4, 7 },
  2149. [SFAB_ADM0_M2_RESET] = { 0x21e8, 7 },
  2150. [ADM0_C2_RESET] = { 0x220c, 4 },
  2151. [ADM0_C1_RESET] = { 0x220c, 3 },
  2152. [ADM0_C0_RESET] = { 0x220c, 2 },
  2153. [ADM0_PBUS_RESET] = { 0x220c, 1 },
  2154. [ADM0_RESET] = { 0x220c, 0 },
  2155. [QDSS_CLKS_SW_RESET] = { 0x2260, 5 },
  2156. [QDSS_POR_RESET] = { 0x2260, 4 },
  2157. [QDSS_TSCTR_RESET] = { 0x2260, 3 },
  2158. [QDSS_HRESET_RESET] = { 0x2260, 2 },
  2159. [QDSS_AXI_RESET] = { 0x2260, 1 },
  2160. [QDSS_DBG_RESET] = { 0x2260, 0 },
  2161. [SFAB_PCIE_M_RESET] = { 0x22d8, 1 },
  2162. [SFAB_PCIE_S_RESET] = { 0x22d8, 0 },
  2163. [PCIE_EXT_RESET] = { 0x22dc, 6 },
  2164. [PCIE_PHY_RESET] = { 0x22dc, 5 },
  2165. [PCIE_PCI_RESET] = { 0x22dc, 4 },
  2166. [PCIE_POR_RESET] = { 0x22dc, 3 },
  2167. [PCIE_HCLK_RESET] = { 0x22dc, 2 },
  2168. [PCIE_ACLK_RESET] = { 0x22dc, 0 },
  2169. [SFAB_LPASS_RESET] = { 0x23a0, 7 },
  2170. [SFAB_AFAB_M_RESET] = { 0x23e0, 7 },
  2171. [AFAB_SFAB_M0_RESET] = { 0x2420, 7 },
  2172. [AFAB_SFAB_M1_RESET] = { 0x2424, 7 },
  2173. [SFAB_SATA_S_RESET] = { 0x2480, 7 },
  2174. [SFAB_DFAB_M_RESET] = { 0x2500, 7 },
  2175. [DFAB_SFAB_M_RESET] = { 0x2520, 7 },
  2176. [DFAB_SWAY0_RESET] = { 0x2540, 7 },
  2177. [DFAB_SWAY1_RESET] = { 0x2544, 7 },
  2178. [DFAB_ARB0_RESET] = { 0x2560, 7 },
  2179. [DFAB_ARB1_RESET] = { 0x2564, 7 },
  2180. [PPSS_PROC_RESET] = { 0x2594, 1 },
  2181. [PPSS_RESET] = { 0x2594, 0 },
  2182. [DMA_BAM_RESET] = { 0x25c0, 7 },
  2183. [SPS_TIC_H_RESET] = { 0x2600, 7 },
  2184. [SFAB_CFPB_M_RESET] = { 0x2680, 7 },
  2185. [SFAB_CFPB_S_RESET] = { 0x26c0, 7 },
  2186. [TSIF_H_RESET] = { 0x2700, 7 },
  2187. [CE1_H_RESET] = { 0x2720, 7 },
  2188. [CE1_CORE_RESET] = { 0x2724, 7 },
  2189. [CE1_SLEEP_RESET] = { 0x2728, 7 },
  2190. [CE2_H_RESET] = { 0x2740, 7 },
  2191. [CE2_CORE_RESET] = { 0x2744, 7 },
  2192. [SFAB_SFPB_M_RESET] = { 0x2780, 7 },
  2193. [SFAB_SFPB_S_RESET] = { 0x27a0, 7 },
  2194. [RPM_PROC_RESET] = { 0x27c0, 7 },
  2195. [PMIC_SSBI2_RESET] = { 0x280c, 12 },
  2196. [SDC1_RESET] = { 0x2830, 0 },
  2197. [SDC2_RESET] = { 0x2850, 0 },
  2198. [SDC3_RESET] = { 0x2870, 0 },
  2199. [SDC4_RESET] = { 0x2890, 0 },
  2200. [USB_HS1_RESET] = { 0x2910, 0 },
  2201. [USB_HSIC_RESET] = { 0x2934, 0 },
  2202. [USB_FS1_XCVR_RESET] = { 0x2974, 1 },
  2203. [USB_FS1_RESET] = { 0x2974, 0 },
  2204. [GSBI1_RESET] = { 0x29dc, 0 },
  2205. [GSBI2_RESET] = { 0x29fc, 0 },
  2206. [GSBI3_RESET] = { 0x2a1c, 0 },
  2207. [GSBI4_RESET] = { 0x2a3c, 0 },
  2208. [GSBI5_RESET] = { 0x2a5c, 0 },
  2209. [GSBI6_RESET] = { 0x2a7c, 0 },
  2210. [GSBI7_RESET] = { 0x2a9c, 0 },
  2211. [SPDM_RESET] = { 0x2b6c, 0 },
  2212. [SEC_CTRL_RESET] = { 0x2b80, 7 },
  2213. [TLMM_H_RESET] = { 0x2ba0, 7 },
  2214. [SFAB_SATA_M_RESET] = { 0x2c18, 0 },
  2215. [SATA_RESET] = { 0x2c1c, 0 },
  2216. [TSSC_RESET] = { 0x2ca0, 7 },
  2217. [PDM_RESET] = { 0x2cc0, 12 },
  2218. [MPM_H_RESET] = { 0x2da0, 7 },
  2219. [MPM_RESET] = { 0x2da4, 0 },
  2220. [SFAB_SMPSS_S_RESET] = { 0x2e00, 7 },
  2221. [PRNG_RESET] = { 0x2e80, 12 },
  2222. [SFAB_CE3_M_RESET] = { 0x36c8, 1 },
  2223. [SFAB_CE3_S_RESET] = { 0x36c8, 0 },
  2224. [CE3_SLEEP_RESET] = { 0x36d0, 7 },
  2225. [PCIE_1_M_RESET] = { 0x3a98, 1 },
  2226. [PCIE_1_S_RESET] = { 0x3a98, 0 },
  2227. [PCIE_1_EXT_RESET] = { 0x3a9c, 6 },
  2228. [PCIE_1_PHY_RESET] = { 0x3a9c, 5 },
  2229. [PCIE_1_PCI_RESET] = { 0x3a9c, 4 },
  2230. [PCIE_1_POR_RESET] = { 0x3a9c, 3 },
  2231. [PCIE_1_HCLK_RESET] = { 0x3a9c, 2 },
  2232. [PCIE_1_ACLK_RESET] = { 0x3a9c, 0 },
  2233. [PCIE_2_M_RESET] = { 0x3ad8, 1 },
  2234. [PCIE_2_S_RESET] = { 0x3ad8, 0 },
  2235. [PCIE_2_EXT_RESET] = { 0x3adc, 6 },
  2236. [PCIE_2_PHY_RESET] = { 0x3adc, 5 },
  2237. [PCIE_2_PCI_RESET] = { 0x3adc, 4 },
  2238. [PCIE_2_POR_RESET] = { 0x3adc, 3 },
  2239. [PCIE_2_HCLK_RESET] = { 0x3adc, 2 },
  2240. [PCIE_2_ACLK_RESET] = { 0x3adc, 0 },
  2241. [SFAB_USB30_S_RESET] = { 0x3b54, 1 },
  2242. [SFAB_USB30_M_RESET] = { 0x3b54, 0 },
  2243. [USB30_0_PORT2_HS_PHY_RESET] = { 0x3b50, 5 },
  2244. [USB30_0_MASTER_RESET] = { 0x3b50, 4 },
  2245. [USB30_0_SLEEP_RESET] = { 0x3b50, 3 },
  2246. [USB30_0_UTMI_PHY_RESET] = { 0x3b50, 2 },
  2247. [USB30_0_POWERON_RESET] = { 0x3b50, 1 },
  2248. [USB30_0_PHY_RESET] = { 0x3b50, 0 },
  2249. [USB30_1_MASTER_RESET] = { 0x3b58, 4 },
  2250. [USB30_1_SLEEP_RESET] = { 0x3b58, 3 },
  2251. [USB30_1_UTMI_PHY_RESET] = { 0x3b58, 2 },
  2252. [USB30_1_POWERON_RESET] = { 0x3b58, 1 },
  2253. [USB30_1_PHY_RESET] = { 0x3b58, 0 },
  2254. [NSSFB0_RESET] = { 0x3b60, 6 },
  2255. [NSSFB1_RESET] = { 0x3b60, 7 },
  2256. };
  2257. static const struct regmap_config gcc_ipq806x_regmap_config = {
  2258. .reg_bits = 32,
  2259. .reg_stride = 4,
  2260. .val_bits = 32,
  2261. .max_register = 0x3e40,
  2262. .fast_io = true,
  2263. };
  2264. static const struct qcom_cc_desc gcc_ipq806x_desc = {
  2265. .config = &gcc_ipq806x_regmap_config,
  2266. .clks = gcc_ipq806x_clks,
  2267. .num_clks = ARRAY_SIZE(gcc_ipq806x_clks),
  2268. .resets = gcc_ipq806x_resets,
  2269. .num_resets = ARRAY_SIZE(gcc_ipq806x_resets),
  2270. };
  2271. static const struct of_device_id gcc_ipq806x_match_table[] = {
  2272. { .compatible = "qcom,gcc-ipq8064" },
  2273. { }
  2274. };
  2275. MODULE_DEVICE_TABLE(of, gcc_ipq806x_match_table);
  2276. static int gcc_ipq806x_probe(struct platform_device *pdev)
  2277. {
  2278. struct clk *clk;
  2279. struct device *dev = &pdev->dev;
  2280. /* Temporary until RPM clocks supported */
  2281. clk = clk_register_fixed_rate(dev, "cxo", NULL, CLK_IS_ROOT, 25000000);
  2282. if (IS_ERR(clk))
  2283. return PTR_ERR(clk);
  2284. clk = clk_register_fixed_rate(dev, "pxo", NULL, CLK_IS_ROOT, 25000000);
  2285. if (IS_ERR(clk))
  2286. return PTR_ERR(clk);
  2287. return qcom_cc_probe(pdev, &gcc_ipq806x_desc);
  2288. }
  2289. static int gcc_ipq806x_remove(struct platform_device *pdev)
  2290. {
  2291. qcom_cc_remove(pdev);
  2292. return 0;
  2293. }
  2294. static struct platform_driver gcc_ipq806x_driver = {
  2295. .probe = gcc_ipq806x_probe,
  2296. .remove = gcc_ipq806x_remove,
  2297. .driver = {
  2298. .name = "gcc-ipq806x",
  2299. .of_match_table = gcc_ipq806x_match_table,
  2300. },
  2301. };
  2302. static int __init gcc_ipq806x_init(void)
  2303. {
  2304. return platform_driver_register(&gcc_ipq806x_driver);
  2305. }
  2306. core_initcall(gcc_ipq806x_init);
  2307. static void __exit gcc_ipq806x_exit(void)
  2308. {
  2309. platform_driver_unregister(&gcc_ipq806x_driver);
  2310. }
  2311. module_exit(gcc_ipq806x_exit);
  2312. MODULE_DESCRIPTION("QCOM GCC IPQ806x Driver");
  2313. MODULE_LICENSE("GPL v2");
  2314. MODULE_ALIAS("platform:gcc-ipq806x");