clk-versaclock3.c 29 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168
  1. // SPDX-License-Identifier: GPL-2.0+
  2. /*
  3. * Driver for Renesas Versaclock 3
  4. *
  5. * Copyright (C) 2023 Renesas Electronics Corp.
  6. */
  7. #include <linux/clk-provider.h>
  8. #include <linux/i2c.h>
  9. #include <linux/limits.h>
  10. #include <linux/module.h>
  11. #include <linux/regmap.h>
  12. #define NUM_CONFIG_REGISTERS 37
  13. #define VC3_GENERAL_CTR 0x0
  14. #define VC3_GENERAL_CTR_DIV1_SRC_SEL BIT(3)
  15. #define VC3_GENERAL_CTR_PLL3_REFIN_SEL BIT(2)
  16. #define VC3_PLL3_M_DIVIDER 0x3
  17. #define VC3_PLL3_M_DIV1 BIT(7)
  18. #define VC3_PLL3_M_DIV2 BIT(6)
  19. #define VC3_PLL3_M_DIV(n) ((n) & GENMASK(5, 0))
  20. #define VC3_PLL3_N_DIVIDER 0x4
  21. #define VC3_PLL3_LOOP_FILTER_N_DIV_MSB 0x5
  22. #define VC3_PLL3_CHARGE_PUMP_CTRL 0x6
  23. #define VC3_PLL3_CHARGE_PUMP_CTRL_OUTDIV3_SRC_SEL BIT(7)
  24. #define VC3_PLL1_CTRL_OUTDIV5 0x7
  25. #define VC3_PLL1_CTRL_OUTDIV5_PLL1_MDIV_DOUBLER BIT(7)
  26. #define VC3_PLL1_M_DIVIDER 0x8
  27. #define VC3_PLL1_M_DIV1 BIT(7)
  28. #define VC3_PLL1_M_DIV2 BIT(6)
  29. #define VC3_PLL1_M_DIV(n) ((n) & GENMASK(5, 0))
  30. #define VC3_PLL1_VCO_N_DIVIDER 0x9
  31. #define VC3_PLL1_LOOP_FILTER_N_DIV_MSB 0xa
  32. #define VC3_OUT_DIV1_DIV2_CTRL 0xf
  33. #define VC3_PLL2_FB_INT_DIV_MSB 0x10
  34. #define VC3_PLL2_FB_INT_DIV_LSB 0x11
  35. #define VC3_PLL2_FB_FRC_DIV_MSB 0x12
  36. #define VC3_PLL2_FB_FRC_DIV_LSB 0x13
  37. #define VC3_PLL2_M_DIVIDER 0x1a
  38. #define VC3_PLL2_MDIV_DOUBLER BIT(7)
  39. #define VC3_PLL2_M_DIV1 BIT(6)
  40. #define VC3_PLL2_M_DIV2 BIT(5)
  41. #define VC3_PLL2_M_DIV(n) ((n) & GENMASK(4, 0))
  42. #define VC3_OUT_DIV3_DIV4_CTRL 0x1b
  43. #define VC3_PLL_OP_CTRL 0x1c
  44. #define VC3_PLL_OP_CTRL_PLL2_REFIN_SEL 6
  45. #define VC3_OUTPUT_CTR 0x1d
  46. #define VC3_OUTPUT_CTR_DIV4_SRC_SEL BIT(3)
  47. #define VC3_SE2_CTRL_REG0 0x1f
  48. #define VC3_SE2_CTRL_REG0_SE2_CLK_SEL BIT(6)
  49. #define VC3_SE3_DIFF1_CTRL_REG 0x21
  50. #define VC3_SE3_DIFF1_CTRL_REG_SE3_CLK_SEL BIT(6)
  51. #define VC3_DIFF1_CTRL_REG 0x22
  52. #define VC3_DIFF1_CTRL_REG_DIFF1_CLK_SEL BIT(7)
  53. #define VC3_DIFF2_CTRL_REG 0x23
  54. #define VC3_DIFF2_CTRL_REG_DIFF2_CLK_SEL BIT(7)
  55. #define VC3_SE1_DIV4_CTRL 0x24
  56. #define VC3_SE1_DIV4_CTRL_SE1_CLK_SEL BIT(3)
  57. #define VC3_PLL1_VCO_MIN 300000000UL
  58. #define VC3_PLL1_VCO_MAX 600000000UL
  59. #define VC3_PLL3_VCO_MIN 300000000UL
  60. #define VC3_PLL3_VCO_MAX 800000000UL
  61. #define VC3_2_POW_16 (U16_MAX + 1)
  62. #define VC3_DIV_MASK(width) ((1 << (width)) - 1)
  63. enum vc3_pfd_mux {
  64. VC3_PFD2_MUX,
  65. VC3_PFD3_MUX,
  66. };
  67. enum vc3_pfd {
  68. VC3_PFD1,
  69. VC3_PFD2,
  70. VC3_PFD3,
  71. };
  72. enum vc3_pll {
  73. VC3_PLL1,
  74. VC3_PLL2,
  75. VC3_PLL3,
  76. };
  77. enum vc3_div_mux {
  78. VC3_DIV1_MUX,
  79. VC3_DIV3_MUX,
  80. VC3_DIV4_MUX,
  81. };
  82. enum vc3_div {
  83. VC3_DIV1,
  84. VC3_DIV2,
  85. VC3_DIV3,
  86. VC3_DIV4,
  87. VC3_DIV5,
  88. };
  89. enum vc3_clk {
  90. VC3_REF,
  91. VC3_SE1,
  92. VC3_SE2,
  93. VC3_SE3,
  94. VC3_DIFF1,
  95. VC3_DIFF2,
  96. };
  97. enum vc3_clk_mux {
  98. VC3_SE1_MUX = VC3_SE1 - 1,
  99. VC3_SE2_MUX = VC3_SE2 - 1,
  100. VC3_SE3_MUX = VC3_SE3 - 1,
  101. VC3_DIFF1_MUX = VC3_DIFF1 - 1,
  102. VC3_DIFF2_MUX = VC3_DIFF2 - 1,
  103. };
  104. struct vc3_clk_data {
  105. u8 offs;
  106. u8 bitmsk;
  107. };
  108. struct vc3_pfd_data {
  109. u8 num;
  110. u8 offs;
  111. u8 mdiv1_bitmsk;
  112. u8 mdiv2_bitmsk;
  113. };
  114. struct vc3_vco {
  115. unsigned long min;
  116. unsigned long max;
  117. };
  118. struct vc3_pll_data {
  119. struct vc3_vco vco;
  120. u8 num;
  121. u8 int_div_msb_offs;
  122. u8 int_div_lsb_offs;
  123. };
  124. struct vc3_div_data {
  125. const struct clk_div_table *table;
  126. u8 offs;
  127. u8 shift;
  128. u8 width;
  129. u8 flags;
  130. };
  131. struct vc3_hw_data {
  132. struct clk_hw hw;
  133. struct regmap *regmap;
  134. void *data;
  135. u32 div_int;
  136. u32 div_frc;
  137. };
  138. struct vc3_hw_cfg {
  139. struct vc3_vco pll2_vco;
  140. u32 se2_clk_sel_msk;
  141. };
  142. static const struct clk_div_table div1_divs[] = {
  143. { .val = 0, .div = 1, }, { .val = 1, .div = 4, },
  144. { .val = 2, .div = 5, }, { .val = 3, .div = 6, },
  145. { .val = 4, .div = 2, }, { .val = 5, .div = 8, },
  146. { .val = 6, .div = 10, }, { .val = 7, .div = 12, },
  147. { .val = 8, .div = 4, }, { .val = 9, .div = 16, },
  148. { .val = 10, .div = 20, }, { .val = 11, .div = 24, },
  149. { .val = 12, .div = 8, }, { .val = 13, .div = 32, },
  150. { .val = 14, .div = 40, }, { .val = 15, .div = 48, },
  151. {}
  152. };
  153. static const struct clk_div_table div245_divs[] = {
  154. { .val = 0, .div = 1, }, { .val = 1, .div = 3, },
  155. { .val = 2, .div = 5, }, { .val = 3, .div = 10, },
  156. { .val = 4, .div = 2, }, { .val = 5, .div = 6, },
  157. { .val = 6, .div = 10, }, { .val = 7, .div = 20, },
  158. { .val = 8, .div = 4, }, { .val = 9, .div = 12, },
  159. { .val = 10, .div = 20, }, { .val = 11, .div = 40, },
  160. { .val = 12, .div = 5, }, { .val = 13, .div = 15, },
  161. { .val = 14, .div = 25, }, { .val = 15, .div = 50, },
  162. {}
  163. };
  164. static const struct clk_div_table div3_divs[] = {
  165. { .val = 0, .div = 1, }, { .val = 1, .div = 3, },
  166. { .val = 2, .div = 5, }, { .val = 3, .div = 10, },
  167. { .val = 4, .div = 2, }, { .val = 5, .div = 6, },
  168. { .val = 6, .div = 10, }, { .val = 7, .div = 20, },
  169. { .val = 8, .div = 4, }, { .val = 9, .div = 12, },
  170. { .val = 10, .div = 20, }, { .val = 11, .div = 40, },
  171. { .val = 12, .div = 8, }, { .val = 13, .div = 24, },
  172. { .val = 14, .div = 40, }, { .val = 15, .div = 80, },
  173. {}
  174. };
  175. static struct clk_hw *clk_out[6];
  176. static u8 vc3_pfd_mux_get_parent(struct clk_hw *hw)
  177. {
  178. struct vc3_hw_data *vc3 = container_of(hw, struct vc3_hw_data, hw);
  179. const struct vc3_clk_data *pfd_mux = vc3->data;
  180. u32 src;
  181. regmap_read(vc3->regmap, pfd_mux->offs, &src);
  182. return !!(src & pfd_mux->bitmsk);
  183. }
  184. static int vc3_pfd_mux_set_parent(struct clk_hw *hw, u8 index)
  185. {
  186. struct vc3_hw_data *vc3 = container_of(hw, struct vc3_hw_data, hw);
  187. const struct vc3_clk_data *pfd_mux = vc3->data;
  188. return regmap_update_bits(vc3->regmap, pfd_mux->offs, pfd_mux->bitmsk,
  189. index ? pfd_mux->bitmsk : 0);
  190. }
  191. static const struct clk_ops vc3_pfd_mux_ops = {
  192. .determine_rate = clk_hw_determine_rate_no_reparent,
  193. .set_parent = vc3_pfd_mux_set_parent,
  194. .get_parent = vc3_pfd_mux_get_parent,
  195. };
  196. static unsigned long vc3_pfd_recalc_rate(struct clk_hw *hw,
  197. unsigned long parent_rate)
  198. {
  199. struct vc3_hw_data *vc3 = container_of(hw, struct vc3_hw_data, hw);
  200. const struct vc3_pfd_data *pfd = vc3->data;
  201. unsigned int prediv, premul;
  202. unsigned long rate;
  203. u8 mdiv;
  204. regmap_read(vc3->regmap, pfd->offs, &prediv);
  205. if (pfd->num == VC3_PFD1) {
  206. /* The bypass_prediv is set, PLL fed from Ref_in directly. */
  207. if (prediv & pfd->mdiv1_bitmsk) {
  208. /* check doubler is set or not */
  209. regmap_read(vc3->regmap, VC3_PLL1_CTRL_OUTDIV5, &premul);
  210. if (premul & VC3_PLL1_CTRL_OUTDIV5_PLL1_MDIV_DOUBLER)
  211. parent_rate *= 2;
  212. return parent_rate;
  213. }
  214. mdiv = VC3_PLL1_M_DIV(prediv);
  215. } else if (pfd->num == VC3_PFD2) {
  216. /* The bypass_prediv is set, PLL fed from Ref_in directly. */
  217. if (prediv & pfd->mdiv1_bitmsk) {
  218. regmap_read(vc3->regmap, VC3_PLL2_M_DIVIDER, &premul);
  219. /* check doubler is set or not */
  220. if (premul & VC3_PLL2_MDIV_DOUBLER)
  221. parent_rate *= 2;
  222. return parent_rate;
  223. }
  224. mdiv = VC3_PLL2_M_DIV(prediv);
  225. } else {
  226. /* The bypass_prediv is set, PLL fed from Ref_in directly. */
  227. if (prediv & pfd->mdiv1_bitmsk)
  228. return parent_rate;
  229. mdiv = VC3_PLL3_M_DIV(prediv);
  230. }
  231. if (prediv & pfd->mdiv2_bitmsk)
  232. rate = parent_rate / 2;
  233. else
  234. rate = parent_rate / mdiv;
  235. return rate;
  236. }
  237. static int vc3_pfd_determine_rate(struct clk_hw *hw,
  238. struct clk_rate_request *req)
  239. {
  240. struct vc3_hw_data *vc3 = container_of(hw, struct vc3_hw_data, hw);
  241. const struct vc3_pfd_data *pfd = vc3->data;
  242. unsigned long idiv;
  243. /* PLL cannot operate with input clock above 50 MHz. */
  244. if (req->rate > 50000000)
  245. return -EINVAL;
  246. /* CLKIN within range of PLL input, feed directly to PLL. */
  247. if (req->best_parent_rate <= 50000000) {
  248. req->rate = req->best_parent_rate;
  249. return 0;
  250. }
  251. idiv = DIV_ROUND_UP(req->best_parent_rate, req->rate);
  252. if (pfd->num == VC3_PFD1 || pfd->num == VC3_PFD3) {
  253. if (idiv > 63)
  254. return -EINVAL;
  255. } else {
  256. if (idiv > 31)
  257. return -EINVAL;
  258. }
  259. req->rate = req->best_parent_rate / idiv;
  260. return 0;
  261. }
  262. static int vc3_pfd_set_rate(struct clk_hw *hw, unsigned long rate,
  263. unsigned long parent_rate)
  264. {
  265. struct vc3_hw_data *vc3 = container_of(hw, struct vc3_hw_data, hw);
  266. const struct vc3_pfd_data *pfd = vc3->data;
  267. unsigned long idiv;
  268. u8 div;
  269. /* CLKIN within range of PLL input, feed directly to PLL. */
  270. if (parent_rate <= 50000000) {
  271. regmap_update_bits(vc3->regmap, pfd->offs, pfd->mdiv1_bitmsk,
  272. pfd->mdiv1_bitmsk);
  273. regmap_update_bits(vc3->regmap, pfd->offs, pfd->mdiv2_bitmsk, 0);
  274. return 0;
  275. }
  276. idiv = DIV_ROUND_UP(parent_rate, rate);
  277. /* We have dedicated div-2 predivider. */
  278. if (idiv == 2) {
  279. regmap_update_bits(vc3->regmap, pfd->offs, pfd->mdiv2_bitmsk,
  280. pfd->mdiv2_bitmsk);
  281. regmap_update_bits(vc3->regmap, pfd->offs, pfd->mdiv1_bitmsk, 0);
  282. } else {
  283. if (pfd->num == VC3_PFD1)
  284. div = VC3_PLL1_M_DIV(idiv);
  285. else if (pfd->num == VC3_PFD2)
  286. div = VC3_PLL2_M_DIV(idiv);
  287. else
  288. div = VC3_PLL3_M_DIV(idiv);
  289. regmap_write(vc3->regmap, pfd->offs, div);
  290. }
  291. return 0;
  292. }
  293. static const struct clk_ops vc3_pfd_ops = {
  294. .recalc_rate = vc3_pfd_recalc_rate,
  295. .determine_rate = vc3_pfd_determine_rate,
  296. .set_rate = vc3_pfd_set_rate,
  297. };
  298. static unsigned long vc3_pll_recalc_rate(struct clk_hw *hw,
  299. unsigned long parent_rate)
  300. {
  301. struct vc3_hw_data *vc3 = container_of(hw, struct vc3_hw_data, hw);
  302. const struct vc3_pll_data *pll = vc3->data;
  303. u32 div_int, div_frc, val;
  304. unsigned long rate;
  305. regmap_read(vc3->regmap, pll->int_div_msb_offs, &val);
  306. div_int = (val & GENMASK(2, 0)) << 8;
  307. regmap_read(vc3->regmap, pll->int_div_lsb_offs, &val);
  308. div_int |= val;
  309. if (pll->num == VC3_PLL2) {
  310. regmap_read(vc3->regmap, VC3_PLL2_FB_FRC_DIV_MSB, &val);
  311. div_frc = val << 8;
  312. regmap_read(vc3->regmap, VC3_PLL2_FB_FRC_DIV_LSB, &val);
  313. div_frc |= val;
  314. rate = (parent_rate *
  315. (div_int * VC3_2_POW_16 + div_frc) / VC3_2_POW_16);
  316. } else {
  317. rate = parent_rate * div_int;
  318. }
  319. return rate;
  320. }
  321. static int vc3_pll_determine_rate(struct clk_hw *hw,
  322. struct clk_rate_request *req)
  323. {
  324. struct vc3_hw_data *vc3 = container_of(hw, struct vc3_hw_data, hw);
  325. const struct vc3_pll_data *pll = vc3->data;
  326. u64 div_frc;
  327. if (req->rate < pll->vco.min)
  328. req->rate = pll->vco.min;
  329. if (req->rate > pll->vco.max)
  330. req->rate = pll->vco.max;
  331. vc3->div_int = req->rate / req->best_parent_rate;
  332. if (pll->num == VC3_PLL2) {
  333. if (vc3->div_int > 0x7ff)
  334. req->rate = req->best_parent_rate * 0x7ff;
  335. /* Determine best fractional part, which is 16 bit wide */
  336. div_frc = req->rate % req->best_parent_rate;
  337. div_frc *= BIT(16) - 1;
  338. vc3->div_frc = min_t(u64,
  339. div64_ul(div_frc, req->best_parent_rate),
  340. U16_MAX);
  341. req->rate = (req->best_parent_rate *
  342. (vc3->div_int * VC3_2_POW_16 + vc3->div_frc) / VC3_2_POW_16);
  343. } else {
  344. req->rate = req->best_parent_rate * vc3->div_int;
  345. }
  346. return 0;
  347. }
  348. static int vc3_pll_set_rate(struct clk_hw *hw, unsigned long rate,
  349. unsigned long parent_rate)
  350. {
  351. struct vc3_hw_data *vc3 = container_of(hw, struct vc3_hw_data, hw);
  352. const struct vc3_pll_data *pll = vc3->data;
  353. u32 val;
  354. regmap_read(vc3->regmap, pll->int_div_msb_offs, &val);
  355. val = (val & 0xf8) | ((vc3->div_int >> 8) & 0x7);
  356. regmap_write(vc3->regmap, pll->int_div_msb_offs, val);
  357. regmap_write(vc3->regmap, pll->int_div_lsb_offs, vc3->div_int & 0xff);
  358. if (pll->num == VC3_PLL2) {
  359. regmap_write(vc3->regmap, VC3_PLL2_FB_FRC_DIV_MSB,
  360. vc3->div_frc >> 8);
  361. regmap_write(vc3->regmap, VC3_PLL2_FB_FRC_DIV_LSB,
  362. vc3->div_frc & 0xff);
  363. }
  364. return 0;
  365. }
  366. static const struct clk_ops vc3_pll_ops = {
  367. .recalc_rate = vc3_pll_recalc_rate,
  368. .determine_rate = vc3_pll_determine_rate,
  369. .set_rate = vc3_pll_set_rate,
  370. };
  371. static u8 vc3_div_mux_get_parent(struct clk_hw *hw)
  372. {
  373. struct vc3_hw_data *vc3 = container_of(hw, struct vc3_hw_data, hw);
  374. const struct vc3_clk_data *div_mux = vc3->data;
  375. u32 src;
  376. regmap_read(vc3->regmap, div_mux->offs, &src);
  377. return !!(src & div_mux->bitmsk);
  378. }
  379. static int vc3_div_mux_set_parent(struct clk_hw *hw, u8 index)
  380. {
  381. struct vc3_hw_data *vc3 = container_of(hw, struct vc3_hw_data, hw);
  382. const struct vc3_clk_data *div_mux = vc3->data;
  383. return regmap_update_bits(vc3->regmap, div_mux->offs, div_mux->bitmsk,
  384. index ? div_mux->bitmsk : 0);
  385. }
  386. static const struct clk_ops vc3_div_mux_ops = {
  387. .determine_rate = clk_hw_determine_rate_no_reparent,
  388. .set_parent = vc3_div_mux_set_parent,
  389. .get_parent = vc3_div_mux_get_parent,
  390. };
  391. static unsigned int vc3_get_div(const struct clk_div_table *table,
  392. unsigned int val, unsigned long flag)
  393. {
  394. const struct clk_div_table *clkt;
  395. for (clkt = table; clkt->div; clkt++)
  396. if (clkt->val == val)
  397. return clkt->div;
  398. return 1;
  399. }
  400. static unsigned long vc3_div_recalc_rate(struct clk_hw *hw,
  401. unsigned long parent_rate)
  402. {
  403. struct vc3_hw_data *vc3 = container_of(hw, struct vc3_hw_data, hw);
  404. const struct vc3_div_data *div_data = vc3->data;
  405. unsigned int val;
  406. regmap_read(vc3->regmap, div_data->offs, &val);
  407. val >>= div_data->shift;
  408. val &= VC3_DIV_MASK(div_data->width);
  409. return divider_recalc_rate(hw, parent_rate, val, div_data->table,
  410. div_data->flags, div_data->width);
  411. }
  412. static int vc3_div_determine_rate(struct clk_hw *hw,
  413. struct clk_rate_request *req)
  414. {
  415. struct vc3_hw_data *vc3 = container_of(hw, struct vc3_hw_data, hw);
  416. const struct vc3_div_data *div_data = vc3->data;
  417. unsigned int bestdiv;
  418. /* if read only, just return current value */
  419. if (div_data->flags & CLK_DIVIDER_READ_ONLY) {
  420. regmap_read(vc3->regmap, div_data->offs, &bestdiv);
  421. bestdiv >>= div_data->shift;
  422. bestdiv &= VC3_DIV_MASK(div_data->width);
  423. bestdiv = vc3_get_div(div_data->table, bestdiv, div_data->flags);
  424. req->rate = DIV_ROUND_UP(req->best_parent_rate, bestdiv);
  425. return 0;
  426. }
  427. return divider_determine_rate(hw, req, div_data->table, div_data->width,
  428. div_data->flags);
  429. }
  430. static int vc3_div_set_rate(struct clk_hw *hw, unsigned long rate,
  431. unsigned long parent_rate)
  432. {
  433. struct vc3_hw_data *vc3 = container_of(hw, struct vc3_hw_data, hw);
  434. const struct vc3_div_data *div_data = vc3->data;
  435. unsigned int value;
  436. value = divider_get_val(rate, parent_rate, div_data->table,
  437. div_data->width, div_data->flags);
  438. return regmap_update_bits(vc3->regmap, div_data->offs,
  439. VC3_DIV_MASK(div_data->width) << div_data->shift,
  440. value << div_data->shift);
  441. }
  442. static const struct clk_ops vc3_div_ops = {
  443. .recalc_rate = vc3_div_recalc_rate,
  444. .determine_rate = vc3_div_determine_rate,
  445. .set_rate = vc3_div_set_rate,
  446. };
  447. static int vc3_clk_mux_determine_rate(struct clk_hw *hw,
  448. struct clk_rate_request *req)
  449. {
  450. int frc;
  451. if (clk_mux_determine_rate_flags(hw, req, CLK_SET_RATE_PARENT)) {
  452. /* The below check is equivalent to (best_parent_rate/rate) */
  453. if (req->best_parent_rate >= req->rate) {
  454. frc = DIV_ROUND_CLOSEST_ULL(req->best_parent_rate,
  455. req->rate);
  456. req->rate *= frc;
  457. return clk_mux_determine_rate_flags(hw, req,
  458. CLK_SET_RATE_PARENT);
  459. }
  460. }
  461. return 0;
  462. }
  463. static u8 vc3_clk_mux_get_parent(struct clk_hw *hw)
  464. {
  465. struct vc3_hw_data *vc3 = container_of(hw, struct vc3_hw_data, hw);
  466. const struct vc3_clk_data *clk_mux = vc3->data;
  467. u32 val;
  468. regmap_read(vc3->regmap, clk_mux->offs, &val);
  469. return !!(val & clk_mux->bitmsk);
  470. }
  471. static int vc3_clk_mux_set_parent(struct clk_hw *hw, u8 index)
  472. {
  473. struct vc3_hw_data *vc3 = container_of(hw, struct vc3_hw_data, hw);
  474. const struct vc3_clk_data *clk_mux = vc3->data;
  475. return regmap_update_bits(vc3->regmap, clk_mux->offs, clk_mux->bitmsk,
  476. index ? clk_mux->bitmsk : 0);
  477. }
  478. static const struct clk_ops vc3_clk_mux_ops = {
  479. .determine_rate = vc3_clk_mux_determine_rate,
  480. .set_parent = vc3_clk_mux_set_parent,
  481. .get_parent = vc3_clk_mux_get_parent,
  482. };
  483. static const struct regmap_config vc3_regmap_config = {
  484. .reg_bits = 8,
  485. .val_bits = 8,
  486. .cache_type = REGCACHE_MAPLE,
  487. .max_register = 0x24,
  488. };
  489. static struct vc3_hw_data clk_div[5];
  490. static const struct clk_parent_data pfd_mux_parent_data[] = {
  491. { .index = 0, },
  492. { .hw = &clk_div[VC3_DIV2].hw }
  493. };
  494. static struct vc3_hw_data clk_pfd_mux[] = {
  495. [VC3_PFD2_MUX] = {
  496. .data = &(struct vc3_clk_data) {
  497. .offs = VC3_PLL_OP_CTRL,
  498. .bitmsk = BIT(VC3_PLL_OP_CTRL_PLL2_REFIN_SEL)
  499. },
  500. .hw.init = &(struct clk_init_data) {
  501. .name = "pfd2_mux",
  502. .ops = &vc3_pfd_mux_ops,
  503. .parent_data = pfd_mux_parent_data,
  504. .num_parents = 2,
  505. .flags = CLK_SET_RATE_PARENT | CLK_SET_RATE_NO_REPARENT
  506. }
  507. },
  508. [VC3_PFD3_MUX] = {
  509. .data = &(struct vc3_clk_data) {
  510. .offs = VC3_GENERAL_CTR,
  511. .bitmsk = BIT(VC3_GENERAL_CTR_PLL3_REFIN_SEL)
  512. },
  513. .hw.init = &(struct clk_init_data) {
  514. .name = "pfd3_mux",
  515. .ops = &vc3_pfd_mux_ops,
  516. .parent_data = pfd_mux_parent_data,
  517. .num_parents = 2,
  518. .flags = CLK_SET_RATE_PARENT | CLK_SET_RATE_NO_REPARENT
  519. }
  520. }
  521. };
  522. static struct vc3_hw_data clk_pfd[] = {
  523. [VC3_PFD1] = {
  524. .data = &(struct vc3_pfd_data) {
  525. .num = VC3_PFD1,
  526. .offs = VC3_PLL1_M_DIVIDER,
  527. .mdiv1_bitmsk = VC3_PLL1_M_DIV1,
  528. .mdiv2_bitmsk = VC3_PLL1_M_DIV2
  529. },
  530. .hw.init = &(struct clk_init_data) {
  531. .name = "pfd1",
  532. .ops = &vc3_pfd_ops,
  533. .parent_data = &(const struct clk_parent_data) {
  534. .index = 0
  535. },
  536. .num_parents = 1,
  537. .flags = CLK_SET_RATE_PARENT
  538. }
  539. },
  540. [VC3_PFD2] = {
  541. .data = &(struct vc3_pfd_data) {
  542. .num = VC3_PFD2,
  543. .offs = VC3_PLL2_M_DIVIDER,
  544. .mdiv1_bitmsk = VC3_PLL2_M_DIV1,
  545. .mdiv2_bitmsk = VC3_PLL2_M_DIV2
  546. },
  547. .hw.init = &(struct clk_init_data) {
  548. .name = "pfd2",
  549. .ops = &vc3_pfd_ops,
  550. .parent_hws = (const struct clk_hw *[]) {
  551. &clk_pfd_mux[VC3_PFD2_MUX].hw
  552. },
  553. .num_parents = 1,
  554. .flags = CLK_SET_RATE_PARENT
  555. }
  556. },
  557. [VC3_PFD3] = {
  558. .data = &(struct vc3_pfd_data) {
  559. .num = VC3_PFD3,
  560. .offs = VC3_PLL3_M_DIVIDER,
  561. .mdiv1_bitmsk = VC3_PLL3_M_DIV1,
  562. .mdiv2_bitmsk = VC3_PLL3_M_DIV2
  563. },
  564. .hw.init = &(struct clk_init_data) {
  565. .name = "pfd3",
  566. .ops = &vc3_pfd_ops,
  567. .parent_hws = (const struct clk_hw *[]) {
  568. &clk_pfd_mux[VC3_PFD3_MUX].hw
  569. },
  570. .num_parents = 1,
  571. .flags = CLK_SET_RATE_PARENT
  572. }
  573. }
  574. };
  575. static struct vc3_hw_data clk_pll[] = {
  576. [VC3_PLL1] = {
  577. .data = &(struct vc3_pll_data) {
  578. .num = VC3_PLL1,
  579. .int_div_msb_offs = VC3_PLL1_LOOP_FILTER_N_DIV_MSB,
  580. .int_div_lsb_offs = VC3_PLL1_VCO_N_DIVIDER,
  581. .vco = {
  582. .min = VC3_PLL1_VCO_MIN,
  583. .max = VC3_PLL1_VCO_MAX
  584. }
  585. },
  586. .hw.init = &(struct clk_init_data) {
  587. .name = "pll1",
  588. .ops = &vc3_pll_ops,
  589. .parent_hws = (const struct clk_hw *[]) {
  590. &clk_pfd[VC3_PFD1].hw
  591. },
  592. .num_parents = 1,
  593. .flags = CLK_SET_RATE_PARENT
  594. }
  595. },
  596. [VC3_PLL2] = {
  597. .data = &(struct vc3_pll_data) {
  598. .num = VC3_PLL2,
  599. .int_div_msb_offs = VC3_PLL2_FB_INT_DIV_MSB,
  600. .int_div_lsb_offs = VC3_PLL2_FB_INT_DIV_LSB,
  601. },
  602. .hw.init = &(struct clk_init_data) {
  603. .name = "pll2",
  604. .ops = &vc3_pll_ops,
  605. .parent_hws = (const struct clk_hw *[]) {
  606. &clk_pfd[VC3_PFD2].hw
  607. },
  608. .num_parents = 1,
  609. .flags = CLK_SET_RATE_PARENT
  610. }
  611. },
  612. [VC3_PLL3] = {
  613. .data = &(struct vc3_pll_data) {
  614. .num = VC3_PLL3,
  615. .int_div_msb_offs = VC3_PLL3_LOOP_FILTER_N_DIV_MSB,
  616. .int_div_lsb_offs = VC3_PLL3_N_DIVIDER,
  617. .vco = {
  618. .min = VC3_PLL3_VCO_MIN,
  619. .max = VC3_PLL3_VCO_MAX
  620. }
  621. },
  622. .hw.init = &(struct clk_init_data) {
  623. .name = "pll3",
  624. .ops = &vc3_pll_ops,
  625. .parent_hws = (const struct clk_hw *[]) {
  626. &clk_pfd[VC3_PFD3].hw
  627. },
  628. .num_parents = 1,
  629. .flags = CLK_SET_RATE_PARENT
  630. }
  631. }
  632. };
  633. static const struct clk_parent_data div_mux_parent_data[][2] = {
  634. [VC3_DIV1_MUX] = {
  635. { .hw = &clk_pll[VC3_PLL1].hw },
  636. { .index = 0 }
  637. },
  638. [VC3_DIV3_MUX] = {
  639. { .hw = &clk_pll[VC3_PLL2].hw },
  640. { .hw = &clk_pll[VC3_PLL3].hw }
  641. },
  642. [VC3_DIV4_MUX] = {
  643. { .hw = &clk_pll[VC3_PLL2].hw },
  644. { .index = 0 }
  645. }
  646. };
  647. static struct vc3_hw_data clk_div_mux[] = {
  648. [VC3_DIV1_MUX] = {
  649. .data = &(struct vc3_clk_data) {
  650. .offs = VC3_GENERAL_CTR,
  651. .bitmsk = VC3_GENERAL_CTR_DIV1_SRC_SEL
  652. },
  653. .hw.init = &(struct clk_init_data) {
  654. .name = "div1_mux",
  655. .ops = &vc3_div_mux_ops,
  656. .parent_data = div_mux_parent_data[VC3_DIV1_MUX],
  657. .num_parents = 2,
  658. .flags = CLK_SET_RATE_PARENT | CLK_SET_RATE_NO_REPARENT
  659. }
  660. },
  661. [VC3_DIV3_MUX] = {
  662. .data = &(struct vc3_clk_data) {
  663. .offs = VC3_PLL3_CHARGE_PUMP_CTRL,
  664. .bitmsk = VC3_PLL3_CHARGE_PUMP_CTRL_OUTDIV3_SRC_SEL
  665. },
  666. .hw.init = &(struct clk_init_data) {
  667. .name = "div3_mux",
  668. .ops = &vc3_div_mux_ops,
  669. .parent_data = div_mux_parent_data[VC3_DIV3_MUX],
  670. .num_parents = 2,
  671. .flags = CLK_SET_RATE_PARENT | CLK_SET_RATE_NO_REPARENT
  672. }
  673. },
  674. [VC3_DIV4_MUX] = {
  675. .data = &(struct vc3_clk_data) {
  676. .offs = VC3_OUTPUT_CTR,
  677. .bitmsk = VC3_OUTPUT_CTR_DIV4_SRC_SEL
  678. },
  679. .hw.init = &(struct clk_init_data) {
  680. .name = "div4_mux",
  681. .ops = &vc3_div_mux_ops,
  682. .parent_data = div_mux_parent_data[VC3_DIV4_MUX],
  683. .num_parents = 2,
  684. .flags = CLK_SET_RATE_PARENT | CLK_SET_RATE_NO_REPARENT
  685. }
  686. }
  687. };
  688. static struct vc3_hw_data clk_div[] = {
  689. [VC3_DIV1] = {
  690. .data = &(struct vc3_div_data) {
  691. .offs = VC3_OUT_DIV1_DIV2_CTRL,
  692. .table = div1_divs,
  693. .shift = 4,
  694. .width = 4,
  695. .flags = CLK_DIVIDER_READ_ONLY
  696. },
  697. .hw.init = &(struct clk_init_data) {
  698. .name = "div1",
  699. .ops = &vc3_div_ops,
  700. .parent_hws = (const struct clk_hw *[]) {
  701. &clk_div_mux[VC3_DIV1_MUX].hw
  702. },
  703. .num_parents = 1,
  704. .flags = CLK_SET_RATE_PARENT
  705. }
  706. },
  707. [VC3_DIV2] = {
  708. .data = &(struct vc3_div_data) {
  709. .offs = VC3_OUT_DIV1_DIV2_CTRL,
  710. .table = div245_divs,
  711. .shift = 0,
  712. .width = 4,
  713. .flags = CLK_DIVIDER_READ_ONLY
  714. },
  715. .hw.init = &(struct clk_init_data) {
  716. .name = "div2",
  717. .ops = &vc3_div_ops,
  718. .parent_hws = (const struct clk_hw *[]) {
  719. &clk_pll[VC3_PLL1].hw
  720. },
  721. .num_parents = 1,
  722. .flags = CLK_SET_RATE_PARENT
  723. }
  724. },
  725. [VC3_DIV3] = {
  726. .data = &(struct vc3_div_data) {
  727. .offs = VC3_OUT_DIV3_DIV4_CTRL,
  728. .table = div3_divs,
  729. .shift = 4,
  730. .width = 4,
  731. .flags = CLK_DIVIDER_READ_ONLY
  732. },
  733. .hw.init = &(struct clk_init_data) {
  734. .name = "div3",
  735. .ops = &vc3_div_ops,
  736. .parent_hws = (const struct clk_hw *[]) {
  737. &clk_div_mux[VC3_DIV3_MUX].hw
  738. },
  739. .num_parents = 1,
  740. .flags = CLK_SET_RATE_PARENT
  741. }
  742. },
  743. [VC3_DIV4] = {
  744. .data = &(struct vc3_div_data) {
  745. .offs = VC3_OUT_DIV3_DIV4_CTRL,
  746. .table = div245_divs,
  747. .shift = 0,
  748. .width = 4,
  749. .flags = CLK_DIVIDER_READ_ONLY
  750. },
  751. .hw.init = &(struct clk_init_data) {
  752. .name = "div4",
  753. .ops = &vc3_div_ops,
  754. .parent_hws = (const struct clk_hw *[]) {
  755. &clk_div_mux[VC3_DIV4_MUX].hw
  756. },
  757. .num_parents = 1,
  758. .flags = CLK_SET_RATE_PARENT
  759. }
  760. },
  761. [VC3_DIV5] = {
  762. .data = &(struct vc3_div_data) {
  763. .offs = VC3_PLL1_CTRL_OUTDIV5,
  764. .table = div245_divs,
  765. .shift = 0,
  766. .width = 4,
  767. .flags = CLK_DIVIDER_READ_ONLY
  768. },
  769. .hw.init = &(struct clk_init_data) {
  770. .name = "div5",
  771. .ops = &vc3_div_ops,
  772. .parent_hws = (const struct clk_hw *[]) {
  773. &clk_pll[VC3_PLL3].hw
  774. },
  775. .num_parents = 1,
  776. .flags = CLK_SET_RATE_PARENT
  777. }
  778. }
  779. };
  780. static struct vc3_hw_data clk_mux[] = {
  781. [VC3_SE1_MUX] = {
  782. .data = &(struct vc3_clk_data) {
  783. .offs = VC3_SE1_DIV4_CTRL,
  784. .bitmsk = VC3_SE1_DIV4_CTRL_SE1_CLK_SEL
  785. },
  786. .hw.init = &(struct clk_init_data) {
  787. .name = "se1_mux",
  788. .ops = &vc3_clk_mux_ops,
  789. .parent_hws = (const struct clk_hw *[]) {
  790. &clk_div[VC3_DIV5].hw,
  791. &clk_div[VC3_DIV4].hw
  792. },
  793. .num_parents = 2,
  794. .flags = CLK_SET_RATE_PARENT
  795. }
  796. },
  797. [VC3_SE2_MUX] = {
  798. .data = &(struct vc3_clk_data) {
  799. .offs = VC3_SE2_CTRL_REG0,
  800. },
  801. .hw.init = &(struct clk_init_data) {
  802. .name = "se2_mux",
  803. .ops = &vc3_clk_mux_ops,
  804. .parent_hws = (const struct clk_hw *[]) {
  805. &clk_div[VC3_DIV5].hw,
  806. &clk_div[VC3_DIV4].hw
  807. },
  808. .num_parents = 2,
  809. .flags = CLK_SET_RATE_PARENT
  810. }
  811. },
  812. [VC3_SE3_MUX] = {
  813. .data = &(struct vc3_clk_data) {
  814. .offs = VC3_SE3_DIFF1_CTRL_REG,
  815. .bitmsk = VC3_SE3_DIFF1_CTRL_REG_SE3_CLK_SEL
  816. },
  817. .hw.init = &(struct clk_init_data) {
  818. .name = "se3_mux",
  819. .ops = &vc3_clk_mux_ops,
  820. .parent_hws = (const struct clk_hw *[]) {
  821. &clk_div[VC3_DIV2].hw,
  822. &clk_div[VC3_DIV4].hw
  823. },
  824. .num_parents = 2,
  825. .flags = CLK_SET_RATE_PARENT
  826. }
  827. },
  828. [VC3_DIFF1_MUX] = {
  829. .data = &(struct vc3_clk_data) {
  830. .offs = VC3_DIFF1_CTRL_REG,
  831. .bitmsk = VC3_DIFF1_CTRL_REG_DIFF1_CLK_SEL
  832. },
  833. .hw.init = &(struct clk_init_data) {
  834. .name = "diff1_mux",
  835. .ops = &vc3_clk_mux_ops,
  836. .parent_hws = (const struct clk_hw *[]) {
  837. &clk_div[VC3_DIV1].hw,
  838. &clk_div[VC3_DIV3].hw
  839. },
  840. .num_parents = 2,
  841. .flags = CLK_SET_RATE_PARENT
  842. }
  843. },
  844. [VC3_DIFF2_MUX] = {
  845. .data = &(struct vc3_clk_data) {
  846. .offs = VC3_DIFF2_CTRL_REG,
  847. .bitmsk = VC3_DIFF2_CTRL_REG_DIFF2_CLK_SEL
  848. },
  849. .hw.init = &(struct clk_init_data) {
  850. .name = "diff2_mux",
  851. .ops = &vc3_clk_mux_ops,
  852. .parent_hws = (const struct clk_hw *[]) {
  853. &clk_div[VC3_DIV1].hw,
  854. &clk_div[VC3_DIV3].hw
  855. },
  856. .num_parents = 2,
  857. .flags = CLK_SET_RATE_PARENT
  858. }
  859. }
  860. };
  861. static struct clk_hw *vc3_of_clk_get(struct of_phandle_args *clkspec,
  862. void *data)
  863. {
  864. unsigned int idx = clkspec->args[0];
  865. struct clk_hw **clkout_hw = data;
  866. if (idx >= ARRAY_SIZE(clk_out)) {
  867. pr_err("invalid clk index %u for provider %pOF\n", idx, clkspec->np);
  868. return ERR_PTR(-EINVAL);
  869. }
  870. return clkout_hw[idx];
  871. }
  872. static int vc3_probe(struct i2c_client *client)
  873. {
  874. struct device *dev = &client->dev;
  875. u8 settings[NUM_CONFIG_REGISTERS];
  876. const struct vc3_hw_cfg *data;
  877. struct regmap *regmap;
  878. const char *name;
  879. int ret, i;
  880. regmap = devm_regmap_init_i2c(client, &vc3_regmap_config);
  881. if (IS_ERR(regmap))
  882. return dev_err_probe(dev, PTR_ERR(regmap),
  883. "failed to allocate register map\n");
  884. ret = of_property_read_u8_array(dev->of_node, "renesas,settings",
  885. settings, ARRAY_SIZE(settings));
  886. if (!ret) {
  887. /*
  888. * A raw settings array was specified in the DT. Write the
  889. * settings to the device immediately.
  890. */
  891. for (i = 0; i < NUM_CONFIG_REGISTERS; i++) {
  892. ret = regmap_write(regmap, i, settings[i]);
  893. if (ret) {
  894. dev_err(dev, "error writing to chip (%i)\n", ret);
  895. return ret;
  896. }
  897. }
  898. } else if (ret == -EOVERFLOW) {
  899. dev_err(&client->dev, "EOVERFLOW reg settings. ARRAY_SIZE: %zu\n",
  900. ARRAY_SIZE(settings));
  901. return ret;
  902. }
  903. /* Register pfd muxes */
  904. for (i = 0; i < ARRAY_SIZE(clk_pfd_mux); i++) {
  905. clk_pfd_mux[i].regmap = regmap;
  906. ret = devm_clk_hw_register(dev, &clk_pfd_mux[i].hw);
  907. if (ret)
  908. return dev_err_probe(dev, ret, "%s failed\n",
  909. clk_pfd_mux[i].hw.init->name);
  910. }
  911. /* Register pfd's */
  912. for (i = 0; i < ARRAY_SIZE(clk_pfd); i++) {
  913. clk_pfd[i].regmap = regmap;
  914. ret = devm_clk_hw_register(dev, &clk_pfd[i].hw);
  915. if (ret)
  916. return dev_err_probe(dev, ret, "%s failed\n",
  917. clk_pfd[i].hw.init->name);
  918. }
  919. data = i2c_get_match_data(client);
  920. /* Register pll's */
  921. for (i = 0; i < ARRAY_SIZE(clk_pll); i++) {
  922. clk_pll[i].regmap = regmap;
  923. if (i == VC3_PLL2) {
  924. struct vc3_pll_data *pll_data = clk_pll[i].data;
  925. pll_data->vco = data->pll2_vco;
  926. }
  927. ret = devm_clk_hw_register(dev, &clk_pll[i].hw);
  928. if (ret)
  929. return dev_err_probe(dev, ret, "%s failed\n",
  930. clk_pll[i].hw.init->name);
  931. }
  932. /* Register divider muxes */
  933. for (i = 0; i < ARRAY_SIZE(clk_div_mux); i++) {
  934. clk_div_mux[i].regmap = regmap;
  935. ret = devm_clk_hw_register(dev, &clk_div_mux[i].hw);
  936. if (ret)
  937. return dev_err_probe(dev, ret, "%s failed\n",
  938. clk_div_mux[i].hw.init->name);
  939. }
  940. /* Register dividers */
  941. for (i = 0; i < ARRAY_SIZE(clk_div); i++) {
  942. clk_div[i].regmap = regmap;
  943. ret = devm_clk_hw_register(dev, &clk_div[i].hw);
  944. if (ret)
  945. return dev_err_probe(dev, ret, "%s failed\n",
  946. clk_div[i].hw.init->name);
  947. }
  948. /* Register clk muxes */
  949. for (i = 0; i < ARRAY_SIZE(clk_mux); i++) {
  950. clk_mux[i].regmap = regmap;
  951. if (i == VC3_SE2_MUX) {
  952. struct vc3_clk_data *clk_data = clk_mux[i].data;
  953. clk_data->bitmsk = data->se2_clk_sel_msk;
  954. }
  955. ret = devm_clk_hw_register(dev, &clk_mux[i].hw);
  956. if (ret)
  957. return dev_err_probe(dev, ret, "%s failed\n",
  958. clk_mux[i].hw.init->name);
  959. }
  960. /* Register clk outputs */
  961. for (i = 0; i < ARRAY_SIZE(clk_out); i++) {
  962. switch (i) {
  963. case VC3_DIFF2:
  964. name = "diff2";
  965. break;
  966. case VC3_DIFF1:
  967. name = "diff1";
  968. break;
  969. case VC3_SE3:
  970. name = "se3";
  971. break;
  972. case VC3_SE2:
  973. name = "se2";
  974. break;
  975. case VC3_SE1:
  976. name = "se1";
  977. break;
  978. case VC3_REF:
  979. name = "ref";
  980. break;
  981. default:
  982. return dev_err_probe(dev, -EINVAL, "invalid clk output %d\n", i);
  983. }
  984. if (i == VC3_REF)
  985. clk_out[i] = devm_clk_hw_register_fixed_factor_index(dev,
  986. name, 0, CLK_SET_RATE_PARENT, 1, 1);
  987. else
  988. clk_out[i] = devm_clk_hw_register_fixed_factor_parent_hw(dev,
  989. name, &clk_mux[i - 1].hw, CLK_SET_RATE_PARENT, 1, 1);
  990. if (IS_ERR(clk_out[i]))
  991. return PTR_ERR(clk_out[i]);
  992. }
  993. ret = devm_of_clk_add_hw_provider(dev, vc3_of_clk_get, clk_out);
  994. if (ret)
  995. return dev_err_probe(dev, ret, "unable to add clk provider\n");
  996. return ret;
  997. }
  998. static const struct vc3_hw_cfg vc3_5p = {
  999. .pll2_vco = { .min = 400000000UL, .max = 1200000000UL },
  1000. .se2_clk_sel_msk = BIT(6),
  1001. };
  1002. static const struct vc3_hw_cfg vc3_5l = {
  1003. .pll2_vco = { .min = 30000000UL, .max = 130000000UL },
  1004. .se2_clk_sel_msk = BIT(0),
  1005. };
  1006. static const struct of_device_id dev_ids[] = {
  1007. { .compatible = "renesas,5p35023", .data = &vc3_5p },
  1008. { .compatible = "renesas,5l35023", .data = &vc3_5l },
  1009. { /* Sentinel */ }
  1010. };
  1011. MODULE_DEVICE_TABLE(of, dev_ids);
  1012. static struct i2c_driver vc3_driver = {
  1013. .driver = {
  1014. .name = "vc3",
  1015. .of_match_table = of_match_ptr(dev_ids),
  1016. },
  1017. .probe = vc3_probe,
  1018. };
  1019. module_i2c_driver(vc3_driver);
  1020. MODULE_AUTHOR("Biju Das <biju.das.jz@bp.renesas.com>");
  1021. MODULE_DESCRIPTION("Renesas VersaClock 3 driver");
  1022. MODULE_LICENSE("GPL");