clock.c 33 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * (C) Copyright 2013-2015
  4. * NVIDIA Corporation <www.nvidia.com>
  5. */
  6. /* Tegra124 Clock control functions */
  7. #include <common.h>
  8. #include <asm/io.h>
  9. #include <asm/arch/clock.h>
  10. #include <asm/arch/sysctr.h>
  11. #include <asm/arch/tegra.h>
  12. #include <asm/arch-tegra/clk_rst.h>
  13. #include <asm/arch-tegra/timer.h>
  14. #include <div64.h>
  15. #include <fdtdec.h>
  16. /*
  17. * Clock types that we can use as a source. The Tegra124 has muxes for the
  18. * peripheral clocks, and in most cases there are four options for the clock
  19. * source. This gives us a clock 'type' and exploits what commonality exists
  20. * in the device.
  21. *
  22. * Letters are obvious, except for T which means CLK_M, and S which means the
  23. * clock derived from 32KHz. Beware that CLK_M (also called OSC in the
  24. * datasheet) and PLL_M are different things. The former is the basic
  25. * clock supplied to the SOC from an external oscillator. The latter is the
  26. * memory clock PLL.
  27. *
  28. * See definitions in clock_id in the header file.
  29. */
  30. enum clock_type_id {
  31. CLOCK_TYPE_AXPT, /* PLL_A, PLL_X, PLL_P, CLK_M */
  32. CLOCK_TYPE_MCPA, /* and so on */
  33. CLOCK_TYPE_MCPT,
  34. CLOCK_TYPE_PCM,
  35. CLOCK_TYPE_PCMT,
  36. CLOCK_TYPE_PDCT,
  37. CLOCK_TYPE_ACPT,
  38. CLOCK_TYPE_ASPTE,
  39. CLOCK_TYPE_PMDACD2T,
  40. CLOCK_TYPE_PCST,
  41. CLOCK_TYPE_DP,
  42. CLOCK_TYPE_PC2CC3M,
  43. CLOCK_TYPE_PC2CC3S_T,
  44. CLOCK_TYPE_PC2CC3M_T,
  45. CLOCK_TYPE_PC2CC3M_T16, /* PC2CC3M_T, but w/16-bit divisor (I2C) */
  46. CLOCK_TYPE_MC2CC3P_A,
  47. CLOCK_TYPE_M,
  48. CLOCK_TYPE_MCPTM2C2C3,
  49. CLOCK_TYPE_PC2CC3T_S,
  50. CLOCK_TYPE_AC2CC3P_TS2,
  51. CLOCK_TYPE_COUNT,
  52. CLOCK_TYPE_NONE = -1, /* invalid clock type */
  53. };
  54. enum {
  55. CLOCK_MAX_MUX = 8 /* number of source options for each clock */
  56. };
  57. /*
  58. * Clock source mux for each clock type. This just converts our enum into
  59. * a list of mux sources for use by the code.
  60. *
  61. * Note:
  62. * The extra column in each clock source array is used to store the mask
  63. * bits in its register for the source.
  64. */
  65. #define CLK(x) CLOCK_ID_ ## x
  66. static enum clock_id clock_source[CLOCK_TYPE_COUNT][CLOCK_MAX_MUX+1] = {
  67. { CLK(AUDIO), CLK(XCPU), CLK(PERIPH), CLK(OSC),
  68. CLK(NONE), CLK(NONE), CLK(NONE), CLK(NONE),
  69. MASK_BITS_31_30},
  70. { CLK(MEMORY), CLK(CGENERAL), CLK(PERIPH), CLK(AUDIO),
  71. CLK(NONE), CLK(NONE), CLK(NONE), CLK(NONE),
  72. MASK_BITS_31_30},
  73. { CLK(MEMORY), CLK(CGENERAL), CLK(PERIPH), CLK(OSC),
  74. CLK(NONE), CLK(NONE), CLK(NONE), CLK(NONE),
  75. MASK_BITS_31_30},
  76. { CLK(PERIPH), CLK(CGENERAL), CLK(MEMORY), CLK(NONE),
  77. CLK(NONE), CLK(NONE), CLK(NONE), CLK(NONE),
  78. MASK_BITS_31_30},
  79. { CLK(PERIPH), CLK(CGENERAL), CLK(MEMORY), CLK(OSC),
  80. CLK(NONE), CLK(NONE), CLK(NONE), CLK(NONE),
  81. MASK_BITS_31_30},
  82. { CLK(PERIPH), CLK(DISPLAY), CLK(CGENERAL), CLK(OSC),
  83. CLK(NONE), CLK(NONE), CLK(NONE), CLK(NONE),
  84. MASK_BITS_31_30},
  85. { CLK(AUDIO), CLK(CGENERAL), CLK(PERIPH), CLK(OSC),
  86. CLK(NONE), CLK(NONE), CLK(NONE), CLK(NONE),
  87. MASK_BITS_31_30},
  88. { CLK(AUDIO), CLK(SFROM32KHZ), CLK(PERIPH), CLK(OSC),
  89. CLK(EPCI), CLK(NONE), CLK(NONE), CLK(NONE),
  90. MASK_BITS_31_29},
  91. { CLK(PERIPH), CLK(MEMORY), CLK(DISPLAY), CLK(AUDIO),
  92. CLK(CGENERAL), CLK(DISPLAY2), CLK(OSC), CLK(NONE),
  93. MASK_BITS_31_29},
  94. { CLK(PERIPH), CLK(CGENERAL), CLK(SFROM32KHZ), CLK(OSC),
  95. CLK(NONE), CLK(NONE), CLK(NONE), CLK(NONE),
  96. MASK_BITS_31_28},
  97. /* CLOCK_TYPE_DP */
  98. { CLK(NONE), CLK(NONE), CLK(NONE), CLK(NONE),
  99. CLK(NONE), CLK(NONE), CLK(NONE), CLK(NONE),
  100. MASK_BITS_31_28},
  101. /* Additional clock types on Tegra114+ */
  102. /* CLOCK_TYPE_PC2CC3M */
  103. { CLK(PERIPH), CLK(CGENERAL2), CLK(CGENERAL), CLK(CGENERAL3),
  104. CLK(MEMORY), CLK(NONE), CLK(NONE), CLK(NONE),
  105. MASK_BITS_31_29},
  106. /* CLOCK_TYPE_PC2CC3S_T */
  107. { CLK(PERIPH), CLK(CGENERAL2), CLK(CGENERAL), CLK(CGENERAL3),
  108. CLK(SFROM32KHZ), CLK(NONE), CLK(OSC), CLK(NONE),
  109. MASK_BITS_31_29},
  110. /* CLOCK_TYPE_PC2CC3M_T */
  111. { CLK(PERIPH), CLK(CGENERAL2), CLK(CGENERAL), CLK(CGENERAL3),
  112. CLK(MEMORY), CLK(NONE), CLK(OSC), CLK(NONE),
  113. MASK_BITS_31_29},
  114. /* CLOCK_TYPE_PC2CC3M_T, w/16-bit divisor (I2C) */
  115. { CLK(PERIPH), CLK(CGENERAL2), CLK(CGENERAL), CLK(CGENERAL3),
  116. CLK(MEMORY), CLK(NONE), CLK(OSC), CLK(NONE),
  117. MASK_BITS_31_29},
  118. /* CLOCK_TYPE_MC2CC3P_A */
  119. { CLK(MEMORY), CLK(CGENERAL2), CLK(CGENERAL), CLK(CGENERAL3),
  120. CLK(PERIPH), CLK(NONE), CLK(AUDIO), CLK(NONE),
  121. MASK_BITS_31_29},
  122. /* CLOCK_TYPE_M */
  123. { CLK(MEMORY), CLK(NONE), CLK(NONE), CLK(NONE),
  124. CLK(NONE), CLK(NONE), CLK(NONE), CLK(NONE),
  125. MASK_BITS_31_30},
  126. /* CLOCK_TYPE_MCPTM2C2C3 */
  127. { CLK(MEMORY), CLK(CGENERAL), CLK(PERIPH), CLK(OSC),
  128. CLK(MEMORY2), CLK(CGENERAL2), CLK(CGENERAL3), CLK(NONE),
  129. MASK_BITS_31_29},
  130. /* CLOCK_TYPE_PC2CC3T_S */
  131. { CLK(PERIPH), CLK(CGENERAL2), CLK(CGENERAL), CLK(CGENERAL3),
  132. CLK(OSC), CLK(NONE), CLK(SFROM32KHZ), CLK(NONE),
  133. MASK_BITS_31_29},
  134. /* CLOCK_TYPE_AC2CC3P_TS2 */
  135. { CLK(AUDIO), CLK(CGENERAL2), CLK(CGENERAL), CLK(CGENERAL3),
  136. CLK(PERIPH), CLK(NONE), CLK(OSC), CLK(SRC2),
  137. MASK_BITS_31_29},
  138. };
  139. /*
  140. * Clock type for each peripheral clock source. We put the name in each
  141. * record just so it is easy to match things up
  142. */
  143. #define TYPE(name, type) type
  144. static enum clock_type_id clock_periph_type[PERIPHC_COUNT] = {
  145. /* 0x00 */
  146. TYPE(PERIPHC_I2S1, CLOCK_TYPE_AXPT),
  147. TYPE(PERIPHC_I2S2, CLOCK_TYPE_AXPT),
  148. TYPE(PERIPHC_SPDIF_OUT, CLOCK_TYPE_AXPT),
  149. TYPE(PERIPHC_SPDIF_IN, CLOCK_TYPE_PC2CC3M),
  150. TYPE(PERIPHC_PWM, CLOCK_TYPE_PC2CC3S_T),
  151. TYPE(PERIPHC_05h, CLOCK_TYPE_NONE),
  152. TYPE(PERIPHC_SBC2, CLOCK_TYPE_PC2CC3M_T),
  153. TYPE(PERIPHC_SBC3, CLOCK_TYPE_PC2CC3M_T),
  154. /* 0x08 */
  155. TYPE(PERIPHC_08h, CLOCK_TYPE_NONE),
  156. TYPE(PERIPHC_I2C1, CLOCK_TYPE_PC2CC3M_T16),
  157. TYPE(PERIPHC_I2C5, CLOCK_TYPE_PC2CC3M_T16),
  158. TYPE(PERIPHC_0bh, CLOCK_TYPE_NONE),
  159. TYPE(PERIPHC_0ch, CLOCK_TYPE_NONE),
  160. TYPE(PERIPHC_SBC1, CLOCK_TYPE_PC2CC3M_T),
  161. TYPE(PERIPHC_DISP1, CLOCK_TYPE_PMDACD2T),
  162. TYPE(PERIPHC_DISP2, CLOCK_TYPE_PMDACD2T),
  163. /* 0x10 */
  164. TYPE(PERIPHC_10h, CLOCK_TYPE_NONE),
  165. TYPE(PERIPHC_11h, CLOCK_TYPE_NONE),
  166. TYPE(PERIPHC_VI, CLOCK_TYPE_MC2CC3P_A),
  167. TYPE(PERIPHC_13h, CLOCK_TYPE_NONE),
  168. TYPE(PERIPHC_SDMMC1, CLOCK_TYPE_PC2CC3M_T),
  169. TYPE(PERIPHC_SDMMC2, CLOCK_TYPE_PC2CC3M_T),
  170. TYPE(PERIPHC_16h, CLOCK_TYPE_NONE),
  171. TYPE(PERIPHC_17h, CLOCK_TYPE_NONE),
  172. /* 0x18 */
  173. TYPE(PERIPHC_18h, CLOCK_TYPE_NONE),
  174. TYPE(PERIPHC_SDMMC4, CLOCK_TYPE_PC2CC3M_T),
  175. TYPE(PERIPHC_VFIR, CLOCK_TYPE_PC2CC3M_T),
  176. TYPE(PERIPHC_1Bh, CLOCK_TYPE_NONE),
  177. TYPE(PERIPHC_1Ch, CLOCK_TYPE_NONE),
  178. TYPE(PERIPHC_HSI, CLOCK_TYPE_PC2CC3M_T),
  179. TYPE(PERIPHC_UART1, CLOCK_TYPE_PC2CC3M_T),
  180. TYPE(PERIPHC_UART2, CLOCK_TYPE_PC2CC3M_T),
  181. /* 0x20 */
  182. TYPE(PERIPHC_HOST1X, CLOCK_TYPE_MC2CC3P_A),
  183. TYPE(PERIPHC_21h, CLOCK_TYPE_NONE),
  184. TYPE(PERIPHC_22h, CLOCK_TYPE_NONE),
  185. TYPE(PERIPHC_HDMI, CLOCK_TYPE_PMDACD2T),
  186. TYPE(PERIPHC_24h, CLOCK_TYPE_NONE),
  187. TYPE(PERIPHC_25h, CLOCK_TYPE_NONE),
  188. TYPE(PERIPHC_I2C2, CLOCK_TYPE_PC2CC3M_T16),
  189. TYPE(PERIPHC_EMC, CLOCK_TYPE_MCPTM2C2C3),
  190. /* 0x28 */
  191. TYPE(PERIPHC_UART3, CLOCK_TYPE_PC2CC3M_T),
  192. TYPE(PERIPHC_29h, CLOCK_TYPE_NONE),
  193. TYPE(PERIPHC_VI_SENSOR, CLOCK_TYPE_MC2CC3P_A),
  194. TYPE(PERIPHC_2bh, CLOCK_TYPE_NONE),
  195. TYPE(PERIPHC_2ch, CLOCK_TYPE_NONE),
  196. TYPE(PERIPHC_SBC4, CLOCK_TYPE_PC2CC3M_T),
  197. TYPE(PERIPHC_I2C3, CLOCK_TYPE_PC2CC3M_T16),
  198. TYPE(PERIPHC_SDMMC3, CLOCK_TYPE_PC2CC3M_T),
  199. /* 0x30 */
  200. TYPE(PERIPHC_UART4, CLOCK_TYPE_PC2CC3M_T),
  201. TYPE(PERIPHC_UART5, CLOCK_TYPE_PC2CC3M_T),
  202. TYPE(PERIPHC_VDE, CLOCK_TYPE_PC2CC3M_T),
  203. TYPE(PERIPHC_OWR, CLOCK_TYPE_PC2CC3M_T),
  204. TYPE(PERIPHC_NOR, CLOCK_TYPE_PC2CC3M_T),
  205. TYPE(PERIPHC_CSITE, CLOCK_TYPE_PC2CC3M_T),
  206. TYPE(PERIPHC_I2S0, CLOCK_TYPE_AXPT),
  207. TYPE(PERIPHC_DTV, CLOCK_TYPE_NONE),
  208. /* 0x38 */
  209. TYPE(PERIPHC_38h, CLOCK_TYPE_NONE),
  210. TYPE(PERIPHC_39h, CLOCK_TYPE_NONE),
  211. TYPE(PERIPHC_3ah, CLOCK_TYPE_NONE),
  212. TYPE(PERIPHC_3bh, CLOCK_TYPE_NONE),
  213. TYPE(PERIPHC_MSENC, CLOCK_TYPE_MC2CC3P_A),
  214. TYPE(PERIPHC_TSEC, CLOCK_TYPE_PC2CC3M_T),
  215. TYPE(PERIPHC_3eh, CLOCK_TYPE_NONE),
  216. TYPE(PERIPHC_OSC, CLOCK_TYPE_NONE),
  217. /* 0x40 */
  218. TYPE(PERIPHC_40h, CLOCK_TYPE_NONE), /* start with 0x3b0 */
  219. TYPE(PERIPHC_MSELECT, CLOCK_TYPE_PC2CC3M_T),
  220. TYPE(PERIPHC_TSENSOR, CLOCK_TYPE_PC2CC3T_S),
  221. TYPE(PERIPHC_I2S3, CLOCK_TYPE_AXPT),
  222. TYPE(PERIPHC_I2S4, CLOCK_TYPE_AXPT),
  223. TYPE(PERIPHC_I2C4, CLOCK_TYPE_PC2CC3M_T16),
  224. TYPE(PERIPHC_SBC5, CLOCK_TYPE_PC2CC3M_T),
  225. TYPE(PERIPHC_SBC6, CLOCK_TYPE_PC2CC3M_T),
  226. /* 0x48 */
  227. TYPE(PERIPHC_AUDIO, CLOCK_TYPE_AC2CC3P_TS2),
  228. TYPE(PERIPHC_49h, CLOCK_TYPE_NONE),
  229. TYPE(PERIPHC_DAM0, CLOCK_TYPE_AC2CC3P_TS2),
  230. TYPE(PERIPHC_DAM1, CLOCK_TYPE_AC2CC3P_TS2),
  231. TYPE(PERIPHC_DAM2, CLOCK_TYPE_AC2CC3P_TS2),
  232. TYPE(PERIPHC_HDA2CODEC2X, CLOCK_TYPE_PC2CC3M_T),
  233. TYPE(PERIPHC_ACTMON, CLOCK_TYPE_PC2CC3S_T),
  234. TYPE(PERIPHC_EXTPERIPH1, CLOCK_TYPE_ASPTE),
  235. /* 0x50 */
  236. TYPE(PERIPHC_EXTPERIPH2, CLOCK_TYPE_ASPTE),
  237. TYPE(PERIPHC_EXTPERIPH3, CLOCK_TYPE_ASPTE),
  238. TYPE(PERIPHC_52h, CLOCK_TYPE_NONE),
  239. TYPE(PERIPHC_I2CSLOW, CLOCK_TYPE_PC2CC3S_T),
  240. TYPE(PERIPHC_SYS, CLOCK_TYPE_NONE),
  241. TYPE(PERIPHC_55h, CLOCK_TYPE_NONE),
  242. TYPE(PERIPHC_56h, CLOCK_TYPE_NONE),
  243. TYPE(PERIPHC_57h, CLOCK_TYPE_NONE),
  244. /* 0x58 */
  245. TYPE(PERIPHC_58h, CLOCK_TYPE_NONE),
  246. TYPE(PERIPHC_SOR, CLOCK_TYPE_NONE),
  247. TYPE(PERIPHC_5ah, CLOCK_TYPE_NONE),
  248. TYPE(PERIPHC_5bh, CLOCK_TYPE_NONE),
  249. TYPE(PERIPHC_SATAOOB, CLOCK_TYPE_PCMT),
  250. TYPE(PERIPHC_SATA, CLOCK_TYPE_PCMT),
  251. TYPE(PERIPHC_HDA, CLOCK_TYPE_PC2CC3M_T),
  252. TYPE(PERIPHC_5fh, CLOCK_TYPE_NONE),
  253. /* 0x60 */
  254. TYPE(PERIPHC_XUSB_CORE_HOST, CLOCK_TYPE_NONE),
  255. TYPE(PERIPHC_XUSB_FALCON, CLOCK_TYPE_NONE),
  256. TYPE(PERIPHC_XUSB_FS, CLOCK_TYPE_NONE),
  257. TYPE(PERIPHC_XUSB_CORE_DEV, CLOCK_TYPE_NONE),
  258. TYPE(PERIPHC_XUSB_SS, CLOCK_TYPE_NONE),
  259. TYPE(PERIPHC_CILAB, CLOCK_TYPE_NONE),
  260. TYPE(PERIPHC_CILCD, CLOCK_TYPE_NONE),
  261. TYPE(PERIPHC_CILE, CLOCK_TYPE_NONE),
  262. /* 0x68 */
  263. TYPE(PERIPHC_DSIA_LP, CLOCK_TYPE_NONE),
  264. TYPE(PERIPHC_DSIB_LP, CLOCK_TYPE_NONE),
  265. TYPE(PERIPHC_ENTROPY, CLOCK_TYPE_NONE),
  266. TYPE(PERIPHC_DVFS_REF, CLOCK_TYPE_NONE),
  267. TYPE(PERIPHC_DVFS_SOC, CLOCK_TYPE_NONE),
  268. TYPE(PERIPHC_TRACECLKIN, CLOCK_TYPE_NONE),
  269. TYPE(PERIPHC_ADX0, CLOCK_TYPE_NONE),
  270. TYPE(PERIPHC_AMX0, CLOCK_TYPE_NONE),
  271. /* 0x70 */
  272. TYPE(PERIPHC_EMC_LATENCY, CLOCK_TYPE_NONE),
  273. TYPE(PERIPHC_SOC_THERM, CLOCK_TYPE_NONE),
  274. TYPE(PERIPHC_72h, CLOCK_TYPE_NONE),
  275. TYPE(PERIPHC_73h, CLOCK_TYPE_NONE),
  276. TYPE(PERIPHC_74h, CLOCK_TYPE_NONE),
  277. TYPE(PERIPHC_75h, CLOCK_TYPE_NONE),
  278. TYPE(PERIPHC_VI_SENSOR2, CLOCK_TYPE_NONE),
  279. TYPE(PERIPHC_I2C6, CLOCK_TYPE_PC2CC3M_T16),
  280. /* 0x78 */
  281. TYPE(PERIPHC_78h, CLOCK_TYPE_NONE),
  282. TYPE(PERIPHC_EMC_DLL, CLOCK_TYPE_MCPTM2C2C3),
  283. TYPE(PERIPHC_HDMI_AUDIO, CLOCK_TYPE_NONE),
  284. TYPE(PERIPHC_CLK72MHZ, CLOCK_TYPE_NONE),
  285. TYPE(PERIPHC_ADX1, CLOCK_TYPE_AC2CC3P_TS2),
  286. TYPE(PERIPHC_AMX1, CLOCK_TYPE_AC2CC3P_TS2),
  287. TYPE(PERIPHC_VIC, CLOCK_TYPE_NONE),
  288. TYPE(PERIPHC_7Fh, CLOCK_TYPE_NONE),
  289. };
  290. /*
  291. * This array translates a periph_id to a periphc_internal_id
  292. *
  293. * Not present/matched up:
  294. * uint vi_sensor; _VI_SENSOR_0, 0x1A8
  295. * SPDIF - which is both 0x08 and 0x0c
  296. *
  297. */
  298. #define NONE(name) (-1)
  299. #define OFFSET(name, value) PERIPHC_ ## name
  300. static s8 periph_id_to_internal_id[PERIPH_ID_COUNT] = {
  301. /* Low word: 31:0 */
  302. NONE(CPU),
  303. NONE(COP),
  304. NONE(TRIGSYS),
  305. NONE(ISPB),
  306. NONE(RESERVED4),
  307. NONE(TMR),
  308. PERIPHC_UART1,
  309. PERIPHC_UART2, /* and vfir 0x68 */
  310. /* 8 */
  311. NONE(GPIO),
  312. PERIPHC_SDMMC2,
  313. PERIPHC_SPDIF_IN,
  314. PERIPHC_I2S1,
  315. PERIPHC_I2C1,
  316. NONE(RESERVED13),
  317. PERIPHC_SDMMC1,
  318. PERIPHC_SDMMC4,
  319. /* 16 */
  320. NONE(TCW),
  321. PERIPHC_PWM,
  322. PERIPHC_I2S2,
  323. NONE(RESERVED19),
  324. PERIPHC_VI,
  325. NONE(RESERVED21),
  326. NONE(USBD),
  327. NONE(ISP),
  328. /* 24 */
  329. NONE(RESERVED24),
  330. NONE(RESERVED25),
  331. PERIPHC_DISP2,
  332. PERIPHC_DISP1,
  333. PERIPHC_HOST1X,
  334. NONE(VCP),
  335. PERIPHC_I2S0,
  336. NONE(CACHE2),
  337. /* Middle word: 63:32 */
  338. NONE(MEM),
  339. NONE(AHBDMA),
  340. NONE(APBDMA),
  341. NONE(RESERVED35),
  342. NONE(RESERVED36),
  343. NONE(STAT_MON),
  344. NONE(RESERVED38),
  345. NONE(FUSE),
  346. /* 40 */
  347. NONE(KFUSE),
  348. PERIPHC_SBC1, /* SBCx = SPIx */
  349. PERIPHC_NOR,
  350. NONE(RESERVED43),
  351. PERIPHC_SBC2,
  352. NONE(XIO),
  353. PERIPHC_SBC3,
  354. PERIPHC_I2C5,
  355. /* 48 */
  356. NONE(DSI),
  357. NONE(RESERVED49),
  358. PERIPHC_HSI,
  359. PERIPHC_HDMI,
  360. NONE(CSI),
  361. NONE(RESERVED53),
  362. PERIPHC_I2C2,
  363. PERIPHC_UART3,
  364. /* 56 */
  365. NONE(MIPI_CAL),
  366. PERIPHC_EMC,
  367. NONE(USB2),
  368. NONE(USB3),
  369. NONE(RESERVED60),
  370. PERIPHC_VDE,
  371. NONE(BSEA),
  372. NONE(BSEV),
  373. /* Upper word 95:64 */
  374. NONE(RESERVED64),
  375. PERIPHC_UART4,
  376. PERIPHC_UART5,
  377. PERIPHC_I2C3,
  378. PERIPHC_SBC4,
  379. PERIPHC_SDMMC3,
  380. NONE(PCIE),
  381. PERIPHC_OWR,
  382. /* 72 */
  383. NONE(AFI),
  384. PERIPHC_CSITE,
  385. NONE(PCIEXCLK),
  386. NONE(AVPUCQ),
  387. NONE(LA),
  388. NONE(TRACECLKIN),
  389. NONE(SOC_THERM),
  390. NONE(DTV),
  391. /* 80 */
  392. NONE(RESERVED80),
  393. PERIPHC_I2CSLOW,
  394. NONE(DSIB),
  395. PERIPHC_TSEC,
  396. NONE(RESERVED84),
  397. NONE(RESERVED85),
  398. NONE(RESERVED86),
  399. NONE(EMUCIF),
  400. /* 88 */
  401. NONE(RESERVED88),
  402. NONE(XUSB_HOST),
  403. NONE(RESERVED90),
  404. PERIPHC_MSENC,
  405. NONE(RESERVED92),
  406. NONE(RESERVED93),
  407. NONE(RESERVED94),
  408. NONE(XUSB_DEV),
  409. /* V word: 31:0 */
  410. NONE(CPUG),
  411. NONE(CPULP),
  412. NONE(V_RESERVED2),
  413. PERIPHC_MSELECT,
  414. NONE(V_RESERVED4),
  415. PERIPHC_I2S3,
  416. PERIPHC_I2S4,
  417. PERIPHC_I2C4,
  418. /* 104 */
  419. PERIPHC_SBC5,
  420. PERIPHC_SBC6,
  421. PERIPHC_AUDIO,
  422. NONE(APBIF),
  423. PERIPHC_DAM0,
  424. PERIPHC_DAM1,
  425. PERIPHC_DAM2,
  426. PERIPHC_HDA2CODEC2X,
  427. /* 112 */
  428. NONE(ATOMICS),
  429. NONE(V_RESERVED17),
  430. NONE(V_RESERVED18),
  431. NONE(V_RESERVED19),
  432. NONE(V_RESERVED20),
  433. NONE(V_RESERVED21),
  434. NONE(V_RESERVED22),
  435. PERIPHC_ACTMON,
  436. /* 120 */
  437. PERIPHC_EXTPERIPH1,
  438. NONE(EXTPERIPH2),
  439. NONE(EXTPERIPH3),
  440. NONE(OOB),
  441. PERIPHC_SATA,
  442. PERIPHC_HDA,
  443. NONE(TZRAM),
  444. NONE(SE),
  445. /* W word: 31:0 */
  446. NONE(HDA2HDMICODEC),
  447. NONE(SATACOLD),
  448. NONE(W_RESERVED2),
  449. NONE(W_RESERVED3),
  450. NONE(W_RESERVED4),
  451. NONE(W_RESERVED5),
  452. NONE(W_RESERVED6),
  453. NONE(W_RESERVED7),
  454. /* 136 */
  455. NONE(CEC),
  456. NONE(W_RESERVED9),
  457. NONE(W_RESERVED10),
  458. NONE(W_RESERVED11),
  459. NONE(W_RESERVED12),
  460. NONE(W_RESERVED13),
  461. NONE(XUSB_PADCTL),
  462. NONE(W_RESERVED15),
  463. /* 144 */
  464. NONE(W_RESERVED16),
  465. NONE(W_RESERVED17),
  466. NONE(W_RESERVED18),
  467. NONE(W_RESERVED19),
  468. NONE(W_RESERVED20),
  469. NONE(ENTROPY),
  470. NONE(DDS),
  471. NONE(W_RESERVED23),
  472. /* 152 */
  473. NONE(DP2),
  474. NONE(AMX0),
  475. NONE(ADX0),
  476. NONE(DVFS),
  477. NONE(XUSB_SS),
  478. NONE(W_RESERVED29),
  479. NONE(W_RESERVED30),
  480. NONE(W_RESERVED31),
  481. /* X word: 31:0 */
  482. NONE(SPARE),
  483. NONE(X_RESERVED1),
  484. NONE(X_RESERVED2),
  485. NONE(X_RESERVED3),
  486. NONE(CAM_MCLK),
  487. NONE(CAM_MCLK2),
  488. PERIPHC_I2C6,
  489. NONE(X_RESERVED7),
  490. /* 168 */
  491. NONE(X_RESERVED8),
  492. NONE(X_RESERVED9),
  493. NONE(X_RESERVED10),
  494. NONE(VIM2_CLK),
  495. NONE(X_RESERVED12),
  496. NONE(X_RESERVED13),
  497. NONE(EMC_DLL),
  498. NONE(X_RESERVED15),
  499. /* 176 */
  500. NONE(HDMI_AUDIO),
  501. NONE(CLK72MHZ),
  502. NONE(VIC),
  503. NONE(X_RESERVED19),
  504. NONE(ADX1),
  505. NONE(DPAUX),
  506. PERIPHC_SOR,
  507. NONE(X_RESERVED23),
  508. /* 184 */
  509. NONE(GPU),
  510. NONE(AMX1),
  511. NONE(X_RESERVED26),
  512. NONE(X_RESERVED27),
  513. NONE(X_RESERVED28),
  514. NONE(X_RESERVED29),
  515. NONE(X_RESERVED30),
  516. NONE(X_RESERVED31),
  517. };
  518. /*
  519. * PLL divider shift/mask tables for all PLL IDs.
  520. */
  521. struct clk_pll_info tegra_pll_info_table[CLOCK_ID_PLL_COUNT] = {
  522. /*
  523. * T124: same as T114, some deviations from T2x/T30. Adds PLLDP.
  524. * NOTE: If kcp_mask/kvco_mask == 0, they're not used in that PLL (PLLX, etc.)
  525. * If lock_ena or lock_det are >31, they're not used in that PLL.
  526. */
  527. { .m_shift = 0, .m_mask = 0xFF, .n_shift = 8, .n_mask = 0xFF, .p_shift = 20, .p_mask = 0x0F,
  528. .lock_ena = 24, .lock_det = 27, .kcp_shift = 28, .kcp_mask = 3, .kvco_shift = 27, .kvco_mask = 1 }, /* PLLC */
  529. { .m_shift = 0, .m_mask = 0xFF, .n_shift = 8, .n_mask = 0xFF, .p_shift = 0, .p_mask = 0,
  530. .lock_ena = 0, .lock_det = 27, .kcp_shift = 1, .kcp_mask = 3, .kvco_shift = 0, .kvco_mask = 1 }, /* PLLM */
  531. { .m_shift = 0, .m_mask = 0x1F, .n_shift = 8, .n_mask = 0x3FF, .p_shift = 20, .p_mask = 0x07,
  532. .lock_ena = 18, .lock_det = 27, .kcp_shift = 8, .kcp_mask = 0xF, .kvco_shift = 4, .kvco_mask = 0xF }, /* PLLP */
  533. { .m_shift = 0, .m_mask = 0x1F, .n_shift = 8, .n_mask = 0x3FF, .p_shift = 20, .p_mask = 0x07,
  534. .lock_ena = 18, .lock_det = 27, .kcp_shift = 8, .kcp_mask = 0xF, .kvco_shift = 4, .kvco_mask = 0xF }, /* PLLA */
  535. { .m_shift = 0, .m_mask = 0x1F, .n_shift = 8, .n_mask = 0x3FF, .p_shift = 20, .p_mask = 0x01,
  536. .lock_ena = 22, .lock_det = 27, .kcp_shift = 8, .kcp_mask = 0xF, .kvco_shift = 4, .kvco_mask = 0xF }, /* PLLU */
  537. { .m_shift = 0, .m_mask = 0x1F, .n_shift = 8, .n_mask = 0x3FF, .p_shift = 20, .p_mask = 0x07,
  538. .lock_ena = 22, .lock_det = 27, .kcp_shift = 8, .kcp_mask = 0xF, .kvco_shift = 4, .kvco_mask = 0xF }, /* PLLD */
  539. { .m_shift = 0, .m_mask = 0xFF, .n_shift = 8, .n_mask = 0xFF, .p_shift = 20, .p_mask = 0x0F,
  540. .lock_ena = 18, .lock_det = 27, .kcp_shift = 0, .kcp_mask = 0, .kvco_shift = 0, .kvco_mask = 0 }, /* PLLX */
  541. { .m_shift = 0, .m_mask = 0xFF, .n_shift = 8, .n_mask = 0xFF, .p_shift = 0, .p_mask = 0,
  542. .lock_ena = 9, .lock_det = 11, .kcp_shift = 6, .kcp_mask = 3, .kvco_shift = 0, .kvco_mask = 1 }, /* PLLE */
  543. { .m_shift = 0, .m_mask = 0x0F, .n_shift = 8, .n_mask = 0x3FF, .p_shift = 20, .p_mask = 0x07,
  544. .lock_ena = 18, .lock_det = 27, .kcp_shift = 8, .kcp_mask = 0xF, .kvco_shift = 4, .kvco_mask = 0xF }, /* PLLS (RESERVED) */
  545. { .m_shift = 0, .m_mask = 0xFF, .n_shift = 8, .n_mask = 0xFF, .p_shift = 20, .p_mask = 0xF,
  546. .lock_ena = 30, .lock_det = 27, .kcp_shift = 25, .kcp_mask = 3, .kvco_shift = 24, .kvco_mask = 1 }, /* PLLDP */
  547. };
  548. /*
  549. * Get the oscillator frequency, from the corresponding hardware configuration
  550. * field. Note that Tegra30+ support 3 new higher freqs, but we map back
  551. * to the old T20 freqs. Support for the higher oscillators is TBD.
  552. */
  553. enum clock_osc_freq clock_get_osc_freq(void)
  554. {
  555. struct clk_rst_ctlr *clkrst =
  556. (struct clk_rst_ctlr *)NV_PA_CLK_RST_BASE;
  557. u32 reg;
  558. reg = readl(&clkrst->crc_osc_ctrl);
  559. reg = (reg & OSC_FREQ_MASK) >> OSC_FREQ_SHIFT;
  560. if (reg & 1) /* one of the newer freqs */
  561. printf("Warning: OSC_FREQ is unsupported! (%d)\n", reg);
  562. return reg >> 2; /* Map to most common (T20) freqs */
  563. }
  564. /* Returns a pointer to the clock source register for a peripheral */
  565. u32 *get_periph_source_reg(enum periph_id periph_id)
  566. {
  567. struct clk_rst_ctlr *clkrst =
  568. (struct clk_rst_ctlr *)NV_PA_CLK_RST_BASE;
  569. enum periphc_internal_id internal_id;
  570. /* Coresight is a special case */
  571. if (periph_id == PERIPH_ID_CSI)
  572. return &clkrst->crc_clk_src[PERIPH_ID_CSI+1];
  573. assert(periph_id >= PERIPH_ID_FIRST && periph_id < PERIPH_ID_COUNT);
  574. internal_id = periph_id_to_internal_id[periph_id];
  575. assert(internal_id != -1);
  576. if (internal_id >= PERIPHC_X_FIRST) {
  577. internal_id -= PERIPHC_X_FIRST;
  578. return &clkrst->crc_clk_src_x[internal_id];
  579. } else if (internal_id >= PERIPHC_VW_FIRST) {
  580. internal_id -= PERIPHC_VW_FIRST;
  581. return &clkrst->crc_clk_src_vw[internal_id];
  582. } else {
  583. return &clkrst->crc_clk_src[internal_id];
  584. }
  585. }
  586. int get_periph_clock_info(enum periph_id periph_id, int *mux_bits,
  587. int *divider_bits, int *type)
  588. {
  589. enum periphc_internal_id internal_id;
  590. if (!clock_periph_id_isvalid(periph_id))
  591. return -1;
  592. internal_id = periph_id_to_internal_id[periph_id];
  593. if (!periphc_internal_id_isvalid(internal_id))
  594. return -1;
  595. *type = clock_periph_type[internal_id];
  596. if (!clock_type_id_isvalid(*type))
  597. return -1;
  598. *mux_bits = clock_source[*type][CLOCK_MAX_MUX];
  599. if (*type == CLOCK_TYPE_PC2CC3M_T16)
  600. *divider_bits = 16;
  601. else
  602. *divider_bits = 8;
  603. return 0;
  604. }
  605. enum clock_id get_periph_clock_id(enum periph_id periph_id, int source)
  606. {
  607. enum periphc_internal_id internal_id;
  608. int type;
  609. if (!clock_periph_id_isvalid(periph_id))
  610. return CLOCK_ID_NONE;
  611. internal_id = periph_id_to_internal_id[periph_id];
  612. if (!periphc_internal_id_isvalid(internal_id))
  613. return CLOCK_ID_NONE;
  614. type = clock_periph_type[internal_id];
  615. if (!clock_type_id_isvalid(type))
  616. return CLOCK_ID_NONE;
  617. return clock_source[type][source];
  618. }
  619. /**
  620. * Given a peripheral ID and the required source clock, this returns which
  621. * value should be programmed into the source mux for that peripheral.
  622. *
  623. * There is special code here to handle the one source type with 5 sources.
  624. *
  625. * @param periph_id peripheral to start
  626. * @param source PLL id of required parent clock
  627. * @param mux_bits Set to number of bits in mux register: 2 or 4
  628. * @param divider_bits Set to number of divider bits (8 or 16)
  629. * @return mux value (0-4, or -1 if not found)
  630. */
  631. int get_periph_clock_source(enum periph_id periph_id,
  632. enum clock_id parent, int *mux_bits, int *divider_bits)
  633. {
  634. enum clock_type_id type;
  635. int mux, err;
  636. err = get_periph_clock_info(periph_id, mux_bits, divider_bits, &type);
  637. assert(!err);
  638. for (mux = 0; mux < CLOCK_MAX_MUX; mux++)
  639. if (clock_source[type][mux] == parent)
  640. return mux;
  641. /* if we get here, either us or the caller has made a mistake */
  642. printf("Caller requested bad clock: periph=%d, parent=%d\n", periph_id,
  643. parent);
  644. return -1;
  645. }
  646. void clock_set_enable(enum periph_id periph_id, int enable)
  647. {
  648. struct clk_rst_ctlr *clkrst =
  649. (struct clk_rst_ctlr *)NV_PA_CLK_RST_BASE;
  650. u32 *clk;
  651. u32 reg;
  652. /* Enable/disable the clock to this peripheral */
  653. assert(clock_periph_id_isvalid(periph_id));
  654. if ((int)periph_id < (int)PERIPH_ID_VW_FIRST)
  655. clk = &clkrst->crc_clk_out_enb[PERIPH_REG(periph_id)];
  656. else if ((int)periph_id < PERIPH_ID_X_FIRST)
  657. clk = &clkrst->crc_clk_out_enb_vw[PERIPH_REG(periph_id)];
  658. else
  659. clk = &clkrst->crc_clk_out_enb_x;
  660. reg = readl(clk);
  661. if (enable)
  662. reg |= PERIPH_MASK(periph_id);
  663. else
  664. reg &= ~PERIPH_MASK(periph_id);
  665. writel(reg, clk);
  666. }
  667. void reset_set_enable(enum periph_id periph_id, int enable)
  668. {
  669. struct clk_rst_ctlr *clkrst =
  670. (struct clk_rst_ctlr *)NV_PA_CLK_RST_BASE;
  671. u32 *reset;
  672. u32 reg;
  673. /* Enable/disable reset to the peripheral */
  674. assert(clock_periph_id_isvalid(periph_id));
  675. if (periph_id < PERIPH_ID_VW_FIRST)
  676. reset = &clkrst->crc_rst_dev[PERIPH_REG(periph_id)];
  677. else if ((int)periph_id < PERIPH_ID_X_FIRST)
  678. reset = &clkrst->crc_rst_dev_vw[PERIPH_REG(periph_id)];
  679. else
  680. reset = &clkrst->crc_rst_devices_x;
  681. reg = readl(reset);
  682. if (enable)
  683. reg |= PERIPH_MASK(periph_id);
  684. else
  685. reg &= ~PERIPH_MASK(periph_id);
  686. writel(reg, reset);
  687. }
  688. #if CONFIG_IS_ENABLED(OF_CONTROL)
  689. /*
  690. * Convert a device tree clock ID to our peripheral ID. They are mostly
  691. * the same but we are very cautious so we check that a valid clock ID is
  692. * provided.
  693. *
  694. * @param clk_id Clock ID according to tegra124 device tree binding
  695. * @return peripheral ID, or PERIPH_ID_NONE if the clock ID is invalid
  696. */
  697. enum periph_id clk_id_to_periph_id(int clk_id)
  698. {
  699. if (clk_id > PERIPH_ID_COUNT)
  700. return PERIPH_ID_NONE;
  701. switch (clk_id) {
  702. case PERIPH_ID_RESERVED4:
  703. case PERIPH_ID_RESERVED25:
  704. case PERIPH_ID_RESERVED35:
  705. case PERIPH_ID_RESERVED36:
  706. case PERIPH_ID_RESERVED38:
  707. case PERIPH_ID_RESERVED43:
  708. case PERIPH_ID_RESERVED49:
  709. case PERIPH_ID_RESERVED53:
  710. case PERIPH_ID_RESERVED64:
  711. case PERIPH_ID_RESERVED84:
  712. case PERIPH_ID_RESERVED85:
  713. case PERIPH_ID_RESERVED86:
  714. case PERIPH_ID_RESERVED88:
  715. case PERIPH_ID_RESERVED90:
  716. case PERIPH_ID_RESERVED92:
  717. case PERIPH_ID_RESERVED93:
  718. case PERIPH_ID_RESERVED94:
  719. case PERIPH_ID_V_RESERVED2:
  720. case PERIPH_ID_V_RESERVED4:
  721. case PERIPH_ID_V_RESERVED17:
  722. case PERIPH_ID_V_RESERVED18:
  723. case PERIPH_ID_V_RESERVED19:
  724. case PERIPH_ID_V_RESERVED20:
  725. case PERIPH_ID_V_RESERVED21:
  726. case PERIPH_ID_V_RESERVED22:
  727. case PERIPH_ID_W_RESERVED2:
  728. case PERIPH_ID_W_RESERVED3:
  729. case PERIPH_ID_W_RESERVED4:
  730. case PERIPH_ID_W_RESERVED5:
  731. case PERIPH_ID_W_RESERVED6:
  732. case PERIPH_ID_W_RESERVED7:
  733. case PERIPH_ID_W_RESERVED9:
  734. case PERIPH_ID_W_RESERVED10:
  735. case PERIPH_ID_W_RESERVED11:
  736. case PERIPH_ID_W_RESERVED12:
  737. case PERIPH_ID_W_RESERVED13:
  738. case PERIPH_ID_W_RESERVED15:
  739. case PERIPH_ID_W_RESERVED16:
  740. case PERIPH_ID_W_RESERVED17:
  741. case PERIPH_ID_W_RESERVED18:
  742. case PERIPH_ID_W_RESERVED19:
  743. case PERIPH_ID_W_RESERVED20:
  744. case PERIPH_ID_W_RESERVED23:
  745. case PERIPH_ID_W_RESERVED29:
  746. case PERIPH_ID_W_RESERVED30:
  747. case PERIPH_ID_W_RESERVED31:
  748. return PERIPH_ID_NONE;
  749. default:
  750. return clk_id;
  751. }
  752. }
  753. #endif /* CONFIG_IS_ENABLED(OF_CONTROL) */
  754. void clock_early_init(void)
  755. {
  756. struct clk_rst_ctlr *clkrst =
  757. (struct clk_rst_ctlr *)NV_PA_CLK_RST_BASE;
  758. struct clk_pll_info *pllinfo;
  759. u32 data;
  760. tegra30_set_up_pllp();
  761. /* clear IDDQ before accessing any other PLLC registers */
  762. pllinfo = &tegra_pll_info_table[CLOCK_ID_CGENERAL];
  763. clrbits_le32(&clkrst->crc_pll[CLOCK_ID_CGENERAL].pll_misc, PLLC_IDDQ);
  764. udelay(2);
  765. /*
  766. * PLLC output frequency set to 600Mhz
  767. * PLLD output frequency set to 925Mhz
  768. */
  769. switch (clock_get_osc_freq()) {
  770. case CLOCK_OSC_FREQ_12_0: /* OSC is 12Mhz */
  771. clock_set_rate(CLOCK_ID_CGENERAL, 600, 12, 0, 8);
  772. clock_set_rate(CLOCK_ID_DISPLAY, 925, 12, 0, 12);
  773. break;
  774. case CLOCK_OSC_FREQ_26_0: /* OSC is 26Mhz */
  775. clock_set_rate(CLOCK_ID_CGENERAL, 600, 26, 0, 8);
  776. clock_set_rate(CLOCK_ID_DISPLAY, 925, 26, 0, 12);
  777. break;
  778. case CLOCK_OSC_FREQ_13_0: /* OSC is 13Mhz */
  779. clock_set_rate(CLOCK_ID_CGENERAL, 600, 13, 0, 8);
  780. clock_set_rate(CLOCK_ID_DISPLAY, 925, 13, 0, 12);
  781. break;
  782. case CLOCK_OSC_FREQ_19_2:
  783. default:
  784. /*
  785. * These are not supported. It is too early to print a
  786. * message and the UART likely won't work anyway due to the
  787. * oscillator being wrong.
  788. */
  789. break;
  790. }
  791. /* PLLC_MISC2: Set dynramp_stepA/B. MISC2 maps to pll_out[1] */
  792. writel(0x00561600, &clkrst->crc_pll[CLOCK_ID_CGENERAL].pll_out[1]);
  793. /* PLLC_MISC: Set LOCK_ENABLE */
  794. pllinfo = &tegra_pll_info_table[CLOCK_ID_CGENERAL];
  795. setbits_le32(&clkrst->crc_pll[CLOCK_ID_CGENERAL].pll_misc, (1 << pllinfo->lock_ena));
  796. udelay(2);
  797. /* PLLD_MISC: Set CLKENABLE, CPCON 12, LFCON 1, and enable lock */
  798. pllinfo = &tegra_pll_info_table[CLOCK_ID_DISPLAY];
  799. data = (12 << pllinfo->kcp_shift) | (1 << pllinfo->kvco_shift);
  800. data |= (1 << PLLD_CLKENABLE) | (1 << pllinfo->lock_ena);
  801. writel(data, &clkrst->crc_pll[CLOCK_ID_DISPLAY].pll_misc);
  802. udelay(2);
  803. }
  804. /*
  805. * clock_early_init_done - Check if clock_early_init() has been called
  806. *
  807. * Check a register that we set up to see if clock_early_init() has already
  808. * been called.
  809. *
  810. * @return true if clock_early_init() was called, false if not
  811. */
  812. bool clock_early_init_done(void)
  813. {
  814. struct clk_rst_ctlr *clkrst = (struct clk_rst_ctlr *)NV_PA_CLK_RST_BASE;
  815. u32 val;
  816. val = readl(&clkrst->crc_sclk_brst_pol);
  817. return val == 0x20002222;
  818. }
  819. void arch_timer_init(void)
  820. {
  821. struct sysctr_ctlr *sysctr = (struct sysctr_ctlr *)NV_PA_TSC_BASE;
  822. u32 freq, val;
  823. freq = clock_get_rate(CLOCK_ID_CLK_M);
  824. debug("%s: clk_m freq is %dHz [0x%08X]\n", __func__, freq, freq);
  825. /* ARM CNTFRQ */
  826. asm("mcr p15, 0, %0, c14, c0, 0\n" : : "r" (freq));
  827. /* Only Tegra114+ has the System Counter regs */
  828. debug("%s: setting CNTFID0 to 0x%08X\n", __func__, freq);
  829. writel(freq, &sysctr->cntfid0);
  830. val = readl(&sysctr->cntcr);
  831. val |= TSC_CNTCR_ENABLE | TSC_CNTCR_HDBG;
  832. writel(val, &sysctr->cntcr);
  833. debug("%s: TSC CNTCR = 0x%08X\n", __func__, val);
  834. }
  835. #define PLLE_SS_CNTL 0x68
  836. #define PLLE_SS_CNTL_SSCINCINTR(x) (((x) & 0x3f) << 24)
  837. #define PLLE_SS_CNTL_SSCINC(x) (((x) & 0xff) << 16)
  838. #define PLLE_SS_CNTL_SSCINVERT (1 << 15)
  839. #define PLLE_SS_CNTL_SSCCENTER (1 << 14)
  840. #define PLLE_SS_CNTL_SSCBYP (1 << 12)
  841. #define PLLE_SS_CNTL_INTERP_RESET (1 << 11)
  842. #define PLLE_SS_CNTL_BYPASS_SS (1 << 10)
  843. #define PLLE_SS_CNTL_SSCMAX(x) (((x) & 0x1ff) << 0)
  844. #define PLLE_BASE 0x0e8
  845. #define PLLE_BASE_ENABLE (1 << 30)
  846. #define PLLE_BASE_LOCK_OVERRIDE (1 << 29)
  847. #define PLLE_BASE_PLDIV_CML(x) (((x) & 0xf) << 24)
  848. #define PLLE_BASE_NDIV(x) (((x) & 0xff) << 8)
  849. #define PLLE_BASE_MDIV(x) (((x) & 0xff) << 0)
  850. #define PLLE_MISC 0x0ec
  851. #define PLLE_MISC_IDDQ_SWCTL (1 << 14)
  852. #define PLLE_MISC_IDDQ_OVERRIDE (1 << 13)
  853. #define PLLE_MISC_LOCK_ENABLE (1 << 9)
  854. #define PLLE_MISC_PTS (1 << 8)
  855. #define PLLE_MISC_VREG_BG_CTRL(x) (((x) & 0x3) << 4)
  856. #define PLLE_MISC_VREG_CTRL(x) (((x) & 0x3) << 2)
  857. #define PLLE_AUX 0x48c
  858. #define PLLE_AUX_SEQ_ENABLE (1 << 24)
  859. #define PLLE_AUX_ENABLE_SWCTL (1 << 4)
  860. int tegra_plle_enable(void)
  861. {
  862. unsigned int m = 1, n = 200, cpcon = 13;
  863. u32 value;
  864. value = readl(NV_PA_CLK_RST_BASE + PLLE_BASE);
  865. value &= ~PLLE_BASE_LOCK_OVERRIDE;
  866. writel(value, NV_PA_CLK_RST_BASE + PLLE_BASE);
  867. value = readl(NV_PA_CLK_RST_BASE + PLLE_AUX);
  868. value |= PLLE_AUX_ENABLE_SWCTL;
  869. value &= ~PLLE_AUX_SEQ_ENABLE;
  870. writel(value, NV_PA_CLK_RST_BASE + PLLE_AUX);
  871. udelay(1);
  872. value = readl(NV_PA_CLK_RST_BASE + PLLE_MISC);
  873. value |= PLLE_MISC_IDDQ_SWCTL;
  874. value &= ~PLLE_MISC_IDDQ_OVERRIDE;
  875. value |= PLLE_MISC_LOCK_ENABLE;
  876. value |= PLLE_MISC_PTS;
  877. value |= PLLE_MISC_VREG_BG_CTRL(3);
  878. value |= PLLE_MISC_VREG_CTRL(2);
  879. writel(value, NV_PA_CLK_RST_BASE + PLLE_MISC);
  880. udelay(5);
  881. value = readl(NV_PA_CLK_RST_BASE + PLLE_SS_CNTL);
  882. value |= PLLE_SS_CNTL_SSCBYP | PLLE_SS_CNTL_INTERP_RESET |
  883. PLLE_SS_CNTL_BYPASS_SS;
  884. writel(value, NV_PA_CLK_RST_BASE + PLLE_SS_CNTL);
  885. value = readl(NV_PA_CLK_RST_BASE + PLLE_BASE);
  886. value &= ~PLLE_BASE_PLDIV_CML(0xf);
  887. value &= ~PLLE_BASE_NDIV(0xff);
  888. value &= ~PLLE_BASE_MDIV(0xff);
  889. value |= PLLE_BASE_PLDIV_CML(cpcon);
  890. value |= PLLE_BASE_NDIV(n);
  891. value |= PLLE_BASE_MDIV(m);
  892. writel(value, NV_PA_CLK_RST_BASE + PLLE_BASE);
  893. udelay(1);
  894. value = readl(NV_PA_CLK_RST_BASE + PLLE_BASE);
  895. value |= PLLE_BASE_ENABLE;
  896. writel(value, NV_PA_CLK_RST_BASE + PLLE_BASE);
  897. /* wait for lock */
  898. udelay(300);
  899. value = readl(NV_PA_CLK_RST_BASE + PLLE_SS_CNTL);
  900. value &= ~PLLE_SS_CNTL_SSCINVERT;
  901. value &= ~PLLE_SS_CNTL_SSCCENTER;
  902. value &= ~PLLE_SS_CNTL_SSCINCINTR(0x3f);
  903. value &= ~PLLE_SS_CNTL_SSCINC(0xff);
  904. value &= ~PLLE_SS_CNTL_SSCMAX(0x1ff);
  905. value |= PLLE_SS_CNTL_SSCINCINTR(0x20);
  906. value |= PLLE_SS_CNTL_SSCINC(0x01);
  907. value |= PLLE_SS_CNTL_SSCMAX(0x25);
  908. writel(value, NV_PA_CLK_RST_BASE + PLLE_SS_CNTL);
  909. value = readl(NV_PA_CLK_RST_BASE + PLLE_SS_CNTL);
  910. value &= ~PLLE_SS_CNTL_SSCBYP;
  911. value &= ~PLLE_SS_CNTL_BYPASS_SS;
  912. writel(value, NV_PA_CLK_RST_BASE + PLLE_SS_CNTL);
  913. udelay(1);
  914. value = readl(NV_PA_CLK_RST_BASE + PLLE_SS_CNTL);
  915. value &= ~PLLE_SS_CNTL_INTERP_RESET;
  916. writel(value, NV_PA_CLK_RST_BASE + PLLE_SS_CNTL);
  917. udelay(1);
  918. return 0;
  919. }
  920. void clock_sor_enable_edp_clock(void)
  921. {
  922. u32 *reg;
  923. /* uses PLLP, has a non-standard bit layout. */
  924. reg = get_periph_source_reg(PERIPH_ID_SOR0);
  925. setbits_le32(reg, SOR0_CLK_SEL0);
  926. }
  927. u32 clock_set_display_rate(u32 frequency)
  928. {
  929. /**
  930. * plld (fo) = vco >> p, where 500MHz < vco < 1000MHz
  931. * = (cf * n) >> p, where 1MHz < cf < 6MHz
  932. * = ((ref / m) * n) >> p
  933. *
  934. * Iterate the possible values of p (3 bits, 2^7) to find out a minimum
  935. * safe vco, then find best (m, n). since m has only 5 bits, we can
  936. * iterate all possible values. Note Tegra 124 supports 11 bits for n,
  937. * but our pll_fields has only 10 bits for n.
  938. *
  939. * Note values undershoot or overshoot target output frequency may not
  940. * work if the values are not in "safe" range by panel specification.
  941. */
  942. u32 ref = clock_get_rate(CLOCK_ID_OSC);
  943. u32 divm, divn, divp, cpcon;
  944. u32 cf, vco, rounded_rate = frequency;
  945. u32 diff, best_diff, best_m = 0, best_n = 0, best_p;
  946. const u32 max_m = 1 << 5, max_n = 1 << 10, max_p = 1 << 3,
  947. mhz = 1000 * 1000, min_vco = 500 * mhz, max_vco = 1000 * mhz,
  948. min_cf = 1 * mhz, max_cf = 6 * mhz;
  949. int mux_bits, divider_bits, source;
  950. for (divp = 0, vco = frequency; vco < min_vco && divp < max_p; divp++)
  951. vco <<= 1;
  952. if (vco < min_vco || vco > max_vco) {
  953. printf("%s: Cannot find out a supported VCO for Frequency (%u)\n",
  954. __func__, frequency);
  955. return 0;
  956. }
  957. best_p = divp;
  958. best_diff = vco;
  959. for (divm = 1; divm < max_m && best_diff; divm++) {
  960. cf = ref / divm;
  961. if (cf < min_cf)
  962. break;
  963. if (cf > max_cf)
  964. continue;
  965. divn = vco / cf;
  966. if (divn >= max_n)
  967. continue;
  968. diff = vco - divn * cf;
  969. if (divn + 1 < max_n && diff > cf / 2) {
  970. divn++;
  971. diff = cf - diff;
  972. }
  973. if (diff >= best_diff)
  974. continue;
  975. best_diff = diff;
  976. best_m = divm;
  977. best_n = divn;
  978. }
  979. if (best_n < 50)
  980. cpcon = 2;
  981. else if (best_n < 300)
  982. cpcon = 3;
  983. else if (best_n < 600)
  984. cpcon = 8;
  985. else
  986. cpcon = 12;
  987. if (best_diff) {
  988. printf("%s: Failed to match output frequency %u, best difference is %u\n",
  989. __func__, frequency, best_diff);
  990. rounded_rate = (ref / best_m * best_n) >> best_p;
  991. }
  992. debug("%s: PLLD=%u ref=%u, m/n/p/cpcon=%u/%u/%u/%u\n",
  993. __func__, rounded_rate, ref, best_m, best_n, best_p, cpcon);
  994. source = get_periph_clock_source(PERIPH_ID_DISP1, CLOCK_ID_DISPLAY,
  995. &mux_bits, &divider_bits);
  996. clock_ll_set_source_bits(PERIPH_ID_DISP1, mux_bits, source);
  997. clock_set_rate(CLOCK_ID_DISPLAY, best_n, best_m, best_p, cpcon);
  998. return rounded_rate;
  999. }
  1000. void clock_set_up_plldp(void)
  1001. {
  1002. struct clk_rst_ctlr *clkrst =
  1003. (struct clk_rst_ctlr *)NV_PA_CLK_RST_BASE;
  1004. u32 value;
  1005. value = PLLDP_SS_CFG_UNDOCUMENTED | PLLDP_SS_CFG_DITHER;
  1006. writel(value | PLLDP_SS_CFG_CLAMP, &clkrst->crc_plldp_ss_cfg);
  1007. clock_start_pll(CLOCK_ID_DP, 1, 90, 3, 0, 0);
  1008. writel(value, &clkrst->crc_plldp_ss_cfg);
  1009. }
  1010. struct clk_pll_simple *clock_get_simple_pll(enum clock_id clkid)
  1011. {
  1012. struct clk_rst_ctlr *clkrst =
  1013. (struct clk_rst_ctlr *)NV_PA_CLK_RST_BASE;
  1014. if (clkid == CLOCK_ID_DP)
  1015. return &clkrst->plldp;
  1016. return NULL;
  1017. }
  1018. struct periph_clk_init periph_clk_init_table[] = {
  1019. { PERIPH_ID_SBC1, CLOCK_ID_PERIPH },
  1020. { PERIPH_ID_SBC2, CLOCK_ID_PERIPH },
  1021. { PERIPH_ID_SBC3, CLOCK_ID_PERIPH },
  1022. { PERIPH_ID_SBC4, CLOCK_ID_PERIPH },
  1023. { PERIPH_ID_SBC5, CLOCK_ID_PERIPH },
  1024. { PERIPH_ID_SBC6, CLOCK_ID_PERIPH },
  1025. { PERIPH_ID_HOST1X, CLOCK_ID_PERIPH },
  1026. { PERIPH_ID_DISP1, CLOCK_ID_CGENERAL },
  1027. { PERIPH_ID_SDMMC1, CLOCK_ID_PERIPH },
  1028. { PERIPH_ID_SDMMC2, CLOCK_ID_PERIPH },
  1029. { PERIPH_ID_SDMMC3, CLOCK_ID_PERIPH },
  1030. { PERIPH_ID_SDMMC4, CLOCK_ID_PERIPH },
  1031. { PERIPH_ID_PWM, CLOCK_ID_SFROM32KHZ },
  1032. { PERIPH_ID_I2C1, CLOCK_ID_PERIPH },
  1033. { PERIPH_ID_I2C2, CLOCK_ID_PERIPH },
  1034. { PERIPH_ID_I2C3, CLOCK_ID_PERIPH },
  1035. { PERIPH_ID_I2C4, CLOCK_ID_PERIPH },
  1036. { PERIPH_ID_I2C5, CLOCK_ID_PERIPH },
  1037. { PERIPH_ID_I2C6, CLOCK_ID_PERIPH },
  1038. { -1, },
  1039. };