clk-rcg2.c 45 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859
  1. // SPDX-License-Identifier: GPL-2.0
  2. /*
  3. * Copyright (c) 2013, 2018, The Linux Foundation. All rights reserved.
  4. */
  5. #include <linux/kernel.h>
  6. #include <linux/bitops.h>
  7. #include <linux/err.h>
  8. #include <linux/bug.h>
  9. #include <linux/export.h>
  10. #include <linux/clk.h>
  11. #include <linux/clk-provider.h>
  12. #include <linux/delay.h>
  13. #include <linux/rational.h>
  14. #include <linux/regmap.h>
  15. #include <linux/math64.h>
  16. #include <linux/gcd.h>
  17. #include <linux/minmax.h>
  18. #include <linux/slab.h>
  19. #include <asm/div64.h>
  20. #include "clk-rcg.h"
  21. #include "common.h"
  22. #define CMD_REG 0x0
  23. #define CMD_UPDATE BIT(0)
  24. #define CMD_ROOT_EN BIT(1)
  25. #define CMD_DIRTY_CFG BIT(4)
  26. #define CMD_DIRTY_N BIT(5)
  27. #define CMD_DIRTY_M BIT(6)
  28. #define CMD_DIRTY_D BIT(7)
  29. #define CMD_ROOT_OFF BIT(31)
  30. #define CFG_REG 0x4
  31. #define CFG_SRC_DIV_SHIFT 0
  32. #define CFG_SRC_DIV_LENGTH 8
  33. #define CFG_SRC_SEL_SHIFT 8
  34. #define CFG_SRC_SEL_MASK (0x7 << CFG_SRC_SEL_SHIFT)
  35. #define CFG_MODE_SHIFT 12
  36. #define CFG_MODE_MASK (0x3 << CFG_MODE_SHIFT)
  37. #define CFG_MODE_DUAL_EDGE (0x2 << CFG_MODE_SHIFT)
  38. #define CFG_HW_CLK_CTRL_MASK BIT(20)
  39. #define M_REG 0x8
  40. #define N_REG 0xc
  41. #define D_REG 0x10
  42. #define RCG_CFG_OFFSET(rcg) ((rcg)->cmd_rcgr + (rcg)->cfg_off + CFG_REG)
  43. #define RCG_M_OFFSET(rcg) ((rcg)->cmd_rcgr + (rcg)->cfg_off + M_REG)
  44. #define RCG_N_OFFSET(rcg) ((rcg)->cmd_rcgr + (rcg)->cfg_off + N_REG)
  45. #define RCG_D_OFFSET(rcg) ((rcg)->cmd_rcgr + (rcg)->cfg_off + D_REG)
  46. /* Dynamic Frequency Scaling */
  47. #define MAX_PERF_LEVEL 8
  48. #define SE_CMD_DFSR_OFFSET 0x14
  49. #define SE_CMD_DFS_EN BIT(0)
  50. #define SE_PERF_DFSR(level) (0x1c + 0x4 * (level))
  51. #define SE_PERF_M_DFSR(level) (0x5c + 0x4 * (level))
  52. #define SE_PERF_N_DFSR(level) (0x9c + 0x4 * (level))
  53. enum freq_policy {
  54. FLOOR,
  55. CEIL,
  56. };
  57. static int clk_rcg2_is_enabled(struct clk_hw *hw)
  58. {
  59. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  60. u32 cmd;
  61. int ret;
  62. ret = regmap_read(rcg->clkr.regmap, rcg->cmd_rcgr + CMD_REG, &cmd);
  63. if (ret)
  64. return ret;
  65. return (cmd & CMD_ROOT_OFF) == 0;
  66. }
  67. static u8 __clk_rcg2_get_parent(struct clk_hw *hw, u32 cfg)
  68. {
  69. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  70. int num_parents = clk_hw_get_num_parents(hw);
  71. int i;
  72. cfg &= CFG_SRC_SEL_MASK;
  73. cfg >>= CFG_SRC_SEL_SHIFT;
  74. for (i = 0; i < num_parents; i++)
  75. if (cfg == rcg->parent_map[i].cfg)
  76. return i;
  77. pr_debug("%s: Clock %s has invalid parent, using default.\n",
  78. __func__, clk_hw_get_name(hw));
  79. return 0;
  80. }
  81. static u8 clk_rcg2_get_parent(struct clk_hw *hw)
  82. {
  83. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  84. u32 cfg;
  85. int ret;
  86. ret = regmap_read(rcg->clkr.regmap, RCG_CFG_OFFSET(rcg), &cfg);
  87. if (ret) {
  88. pr_debug("%s: Unable to read CFG register for %s\n",
  89. __func__, clk_hw_get_name(hw));
  90. return 0;
  91. }
  92. return __clk_rcg2_get_parent(hw, cfg);
  93. }
  94. static int update_config(struct clk_rcg2 *rcg)
  95. {
  96. int count, ret;
  97. u32 cmd;
  98. struct clk_hw *hw = &rcg->clkr.hw;
  99. const char *name = clk_hw_get_name(hw);
  100. ret = regmap_update_bits(rcg->clkr.regmap, rcg->cmd_rcgr + CMD_REG,
  101. CMD_UPDATE, CMD_UPDATE);
  102. if (ret)
  103. return ret;
  104. /* Wait for update to take effect */
  105. for (count = 500; count > 0; count--) {
  106. ret = regmap_read(rcg->clkr.regmap, rcg->cmd_rcgr + CMD_REG, &cmd);
  107. if (ret)
  108. return ret;
  109. if (!(cmd & CMD_UPDATE))
  110. return 0;
  111. udelay(1);
  112. }
  113. WARN(1, "%s: rcg didn't update its configuration.", name);
  114. return -EBUSY;
  115. }
  116. static int clk_rcg2_set_parent(struct clk_hw *hw, u8 index)
  117. {
  118. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  119. int ret;
  120. u32 cfg = rcg->parent_map[index].cfg << CFG_SRC_SEL_SHIFT;
  121. ret = regmap_update_bits(rcg->clkr.regmap, RCG_CFG_OFFSET(rcg),
  122. CFG_SRC_SEL_MASK, cfg);
  123. if (ret)
  124. return ret;
  125. return update_config(rcg);
  126. }
  127. /**
  128. * convert_to_reg_val() - Convert divisor values to hardware values.
  129. *
  130. * @f: Frequency table with pure m/n/pre_div parameters.
  131. */
  132. static void convert_to_reg_val(struct freq_tbl *f)
  133. {
  134. f->pre_div *= 2;
  135. f->pre_div -= 1;
  136. }
  137. /**
  138. * calc_rate() - Calculate rate based on m/n:d values
  139. *
  140. * @rate: Parent rate.
  141. * @m: Multiplier.
  142. * @n: Divisor.
  143. * @mode: Use zero to ignore m/n calculation.
  144. * @hid_div: Pre divisor register value. Pre divisor value
  145. * relates to hid_div as pre_div = (hid_div + 1) / 2.
  146. *
  147. * Return calculated rate according to formula:
  148. *
  149. * parent_rate m
  150. * rate = ----------- x ---
  151. * pre_div n
  152. */
  153. static unsigned long
  154. calc_rate(unsigned long rate, u32 m, u32 n, u32 mode, u32 hid_div)
  155. {
  156. if (hid_div)
  157. rate = mult_frac(rate, 2, hid_div + 1);
  158. if (mode)
  159. rate = mult_frac(rate, m, n);
  160. return rate;
  161. }
  162. static unsigned long
  163. __clk_rcg2_recalc_rate(struct clk_hw *hw, unsigned long parent_rate, u32 cfg)
  164. {
  165. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  166. u32 hid_div, m = 0, n = 0, mode = 0, mask;
  167. if (rcg->mnd_width) {
  168. mask = BIT(rcg->mnd_width) - 1;
  169. regmap_read(rcg->clkr.regmap, RCG_M_OFFSET(rcg), &m);
  170. m &= mask;
  171. regmap_read(rcg->clkr.regmap, RCG_N_OFFSET(rcg), &n);
  172. n = ~n;
  173. n &= mask;
  174. n += m;
  175. mode = cfg & CFG_MODE_MASK;
  176. mode >>= CFG_MODE_SHIFT;
  177. }
  178. mask = BIT(rcg->hid_width) - 1;
  179. hid_div = cfg >> CFG_SRC_DIV_SHIFT;
  180. hid_div &= mask;
  181. return calc_rate(parent_rate, m, n, mode, hid_div);
  182. }
  183. static unsigned long
  184. clk_rcg2_recalc_rate(struct clk_hw *hw, unsigned long parent_rate)
  185. {
  186. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  187. u32 cfg;
  188. regmap_read(rcg->clkr.regmap, RCG_CFG_OFFSET(rcg), &cfg);
  189. return __clk_rcg2_recalc_rate(hw, parent_rate, cfg);
  190. }
  191. static int _freq_tbl_determine_rate(struct clk_hw *hw, const struct freq_tbl *f,
  192. struct clk_rate_request *req,
  193. enum freq_policy policy)
  194. {
  195. unsigned long clk_flags, rate = req->rate;
  196. struct clk_hw *p;
  197. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  198. int index;
  199. switch (policy) {
  200. case FLOOR:
  201. f = qcom_find_freq_floor(f, rate);
  202. break;
  203. case CEIL:
  204. f = qcom_find_freq(f, rate);
  205. break;
  206. default:
  207. return -EINVAL;
  208. }
  209. if (!f)
  210. return -EINVAL;
  211. index = qcom_find_src_index(hw, rcg->parent_map, f->src);
  212. if (index < 0)
  213. return index;
  214. clk_flags = clk_hw_get_flags(hw);
  215. p = clk_hw_get_parent_by_index(hw, index);
  216. if (!p)
  217. return -EINVAL;
  218. if (clk_flags & CLK_SET_RATE_PARENT) {
  219. rate = f->freq;
  220. if (f->pre_div) {
  221. if (!rate)
  222. rate = req->rate;
  223. rate /= 2;
  224. rate *= f->pre_div + 1;
  225. }
  226. if (f->n) {
  227. u64 tmp = rate;
  228. tmp = tmp * f->n;
  229. do_div(tmp, f->m);
  230. rate = tmp;
  231. }
  232. } else {
  233. rate = clk_hw_get_rate(p);
  234. }
  235. req->best_parent_hw = p;
  236. req->best_parent_rate = rate;
  237. req->rate = f->freq;
  238. return 0;
  239. }
  240. static const struct freq_conf *
  241. __clk_rcg2_select_conf(struct clk_hw *hw, const struct freq_multi_tbl *f,
  242. unsigned long req_rate)
  243. {
  244. unsigned long rate_diff, best_rate_diff = ULONG_MAX;
  245. const struct freq_conf *conf, *best_conf = NULL;
  246. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  247. const char *name = clk_hw_get_name(hw);
  248. unsigned long parent_rate, rate;
  249. struct clk_hw *p;
  250. int index, i;
  251. /* Exit early if only one config is defined */
  252. if (f->num_confs == 1) {
  253. best_conf = f->confs;
  254. goto exit;
  255. }
  256. /* Search in each provided config the one that is near the wanted rate */
  257. for (i = 0, conf = f->confs; i < f->num_confs; i++, conf++) {
  258. index = qcom_find_src_index(hw, rcg->parent_map, conf->src);
  259. if (index < 0)
  260. continue;
  261. p = clk_hw_get_parent_by_index(hw, index);
  262. if (!p)
  263. continue;
  264. parent_rate = clk_hw_get_rate(p);
  265. rate = calc_rate(parent_rate, conf->n, conf->m, conf->n, conf->pre_div);
  266. if (rate == req_rate) {
  267. best_conf = conf;
  268. goto exit;
  269. }
  270. rate_diff = abs_diff(req_rate, rate);
  271. if (rate_diff < best_rate_diff) {
  272. best_rate_diff = rate_diff;
  273. best_conf = conf;
  274. }
  275. }
  276. /*
  277. * Very unlikely. Warn if we couldn't find a correct config
  278. * due to parent not found in every config.
  279. */
  280. if (unlikely(!best_conf)) {
  281. WARN(1, "%s: can't find a configuration for rate %lu\n",
  282. name, req_rate);
  283. return ERR_PTR(-EINVAL);
  284. }
  285. exit:
  286. return best_conf;
  287. }
  288. static int _freq_tbl_fm_determine_rate(struct clk_hw *hw, const struct freq_multi_tbl *f,
  289. struct clk_rate_request *req)
  290. {
  291. unsigned long clk_flags, rate = req->rate;
  292. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  293. const struct freq_conf *conf;
  294. struct clk_hw *p;
  295. int index;
  296. f = qcom_find_freq_multi(f, rate);
  297. if (!f || !f->confs)
  298. return -EINVAL;
  299. conf = __clk_rcg2_select_conf(hw, f, rate);
  300. if (IS_ERR(conf))
  301. return PTR_ERR(conf);
  302. index = qcom_find_src_index(hw, rcg->parent_map, conf->src);
  303. if (index < 0)
  304. return index;
  305. clk_flags = clk_hw_get_flags(hw);
  306. p = clk_hw_get_parent_by_index(hw, index);
  307. if (!p)
  308. return -EINVAL;
  309. if (clk_flags & CLK_SET_RATE_PARENT) {
  310. rate = f->freq;
  311. if (conf->pre_div) {
  312. if (!rate)
  313. rate = req->rate;
  314. rate /= 2;
  315. rate *= conf->pre_div + 1;
  316. }
  317. if (conf->n) {
  318. u64 tmp = rate;
  319. tmp = tmp * conf->n;
  320. do_div(tmp, conf->m);
  321. rate = tmp;
  322. }
  323. } else {
  324. rate = clk_hw_get_rate(p);
  325. }
  326. req->best_parent_hw = p;
  327. req->best_parent_rate = rate;
  328. req->rate = f->freq;
  329. return 0;
  330. }
  331. static int clk_rcg2_determine_rate(struct clk_hw *hw,
  332. struct clk_rate_request *req)
  333. {
  334. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  335. return _freq_tbl_determine_rate(hw, rcg->freq_tbl, req, CEIL);
  336. }
  337. static int clk_rcg2_determine_floor_rate(struct clk_hw *hw,
  338. struct clk_rate_request *req)
  339. {
  340. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  341. return _freq_tbl_determine_rate(hw, rcg->freq_tbl, req, FLOOR);
  342. }
  343. static int clk_rcg2_fm_determine_rate(struct clk_hw *hw,
  344. struct clk_rate_request *req)
  345. {
  346. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  347. return _freq_tbl_fm_determine_rate(hw, rcg->freq_multi_tbl, req);
  348. }
  349. /**
  350. * clk_rcg2_split_div() - Split multiplier that doesn't fit in n neither in pre_div.
  351. *
  352. * @multiplier: Multiplier to split between n and pre_div.
  353. * @pre_div: Pointer to pre divisor value.
  354. * @n: Pointer to n divisor value.
  355. * @pre_div_max: Pre divisor maximum value.
  356. */
  357. static inline void clk_rcg2_split_div(int multiplier, unsigned int *pre_div,
  358. u16 *n, unsigned int pre_div_max)
  359. {
  360. *n = mult_frac(multiplier * *n, *pre_div, pre_div_max);
  361. *pre_div = pre_div_max;
  362. }
  363. static void clk_rcg2_calc_mnd(u64 parent_rate, u64 rate, struct freq_tbl *f,
  364. unsigned int mnd_max, unsigned int pre_div_max)
  365. {
  366. int i = 2;
  367. unsigned int pre_div = 1;
  368. unsigned long rates_gcd, scaled_parent_rate;
  369. u16 m, n = 1, n_candidate = 1, n_max;
  370. rates_gcd = gcd(parent_rate, rate);
  371. m = div64_u64(rate, rates_gcd);
  372. scaled_parent_rate = div64_u64(parent_rate, rates_gcd);
  373. while (scaled_parent_rate > (mnd_max + m) * pre_div_max) {
  374. // we're exceeding divisor's range, trying lower scale.
  375. if (m > 1) {
  376. m--;
  377. scaled_parent_rate = mult_frac(scaled_parent_rate, m, (m + 1));
  378. } else {
  379. // cannot lower scale, just set max divisor values.
  380. f->n = mnd_max + m;
  381. f->pre_div = pre_div_max;
  382. f->m = m;
  383. return;
  384. }
  385. }
  386. n_max = m + mnd_max;
  387. while (scaled_parent_rate > 1) {
  388. while (scaled_parent_rate % i == 0) {
  389. n_candidate *= i;
  390. if (n_candidate < n_max)
  391. n = n_candidate;
  392. else if (pre_div * i < pre_div_max)
  393. pre_div *= i;
  394. else
  395. clk_rcg2_split_div(i, &pre_div, &n, pre_div_max);
  396. scaled_parent_rate /= i;
  397. }
  398. i++;
  399. }
  400. f->m = m;
  401. f->n = n;
  402. f->pre_div = pre_div > 1 ? pre_div : 0;
  403. }
  404. static int clk_rcg2_determine_gp_rate(struct clk_hw *hw,
  405. struct clk_rate_request *req)
  406. {
  407. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  408. struct freq_tbl f_tbl = {}, *f = &f_tbl;
  409. int mnd_max = BIT(rcg->mnd_width) - 1;
  410. int hid_max = BIT(rcg->hid_width) - 1;
  411. struct clk_hw *parent;
  412. u64 parent_rate;
  413. parent = clk_hw_get_parent(hw);
  414. parent_rate = clk_get_rate(parent->clk);
  415. if (!parent_rate)
  416. return -EINVAL;
  417. clk_rcg2_calc_mnd(parent_rate, req->rate, f, mnd_max, hid_max / 2);
  418. convert_to_reg_val(f);
  419. req->rate = calc_rate(parent_rate, f->m, f->n, f->n, f->pre_div);
  420. return 0;
  421. }
  422. static int __clk_rcg2_configure_parent(struct clk_rcg2 *rcg, u8 src, u32 *_cfg)
  423. {
  424. struct clk_hw *hw = &rcg->clkr.hw;
  425. int index = qcom_find_src_index(hw, rcg->parent_map, src);
  426. if (index < 0)
  427. return index;
  428. *_cfg &= ~CFG_SRC_SEL_MASK;
  429. *_cfg |= rcg->parent_map[index].cfg << CFG_SRC_SEL_SHIFT;
  430. return 0;
  431. }
  432. static int __clk_rcg2_configure_mnd(struct clk_rcg2 *rcg, const struct freq_tbl *f,
  433. u32 *_cfg)
  434. {
  435. u32 cfg, mask, d_val, not2d_val, n_minus_m;
  436. int ret;
  437. if (rcg->mnd_width && f->n) {
  438. mask = BIT(rcg->mnd_width) - 1;
  439. ret = regmap_update_bits(rcg->clkr.regmap,
  440. RCG_M_OFFSET(rcg), mask, f->m);
  441. if (ret)
  442. return ret;
  443. ret = regmap_update_bits(rcg->clkr.regmap,
  444. RCG_N_OFFSET(rcg), mask, ~(f->n - f->m));
  445. if (ret)
  446. return ret;
  447. /* Calculate 2d value */
  448. d_val = f->n;
  449. n_minus_m = f->n - f->m;
  450. n_minus_m *= 2;
  451. d_val = clamp_t(u32, d_val, f->m, n_minus_m);
  452. not2d_val = ~d_val & mask;
  453. ret = regmap_update_bits(rcg->clkr.regmap,
  454. RCG_D_OFFSET(rcg), mask, not2d_val);
  455. if (ret)
  456. return ret;
  457. }
  458. mask = BIT(rcg->hid_width) - 1;
  459. mask |= CFG_MODE_MASK | CFG_HW_CLK_CTRL_MASK;
  460. cfg = f->pre_div << CFG_SRC_DIV_SHIFT;
  461. if (rcg->mnd_width && f->n && (f->m != f->n))
  462. cfg |= CFG_MODE_DUAL_EDGE;
  463. if (rcg->hw_clk_ctrl)
  464. cfg |= CFG_HW_CLK_CTRL_MASK;
  465. *_cfg &= ~mask;
  466. *_cfg |= cfg;
  467. return 0;
  468. }
  469. static int __clk_rcg2_configure(struct clk_rcg2 *rcg, const struct freq_tbl *f,
  470. u32 *_cfg)
  471. {
  472. int ret;
  473. ret = __clk_rcg2_configure_parent(rcg, f->src, _cfg);
  474. if (ret)
  475. return ret;
  476. ret = __clk_rcg2_configure_mnd(rcg, f, _cfg);
  477. if (ret)
  478. return ret;
  479. return 0;
  480. }
  481. static int clk_rcg2_configure(struct clk_rcg2 *rcg, const struct freq_tbl *f)
  482. {
  483. u32 cfg;
  484. int ret;
  485. ret = regmap_read(rcg->clkr.regmap, RCG_CFG_OFFSET(rcg), &cfg);
  486. if (ret)
  487. return ret;
  488. ret = __clk_rcg2_configure(rcg, f, &cfg);
  489. if (ret)
  490. return ret;
  491. ret = regmap_write(rcg->clkr.regmap, RCG_CFG_OFFSET(rcg), cfg);
  492. if (ret)
  493. return ret;
  494. return update_config(rcg);
  495. }
  496. static int clk_rcg2_configure_gp(struct clk_rcg2 *rcg, const struct freq_tbl *f)
  497. {
  498. u32 cfg;
  499. int ret;
  500. ret = regmap_read(rcg->clkr.regmap, RCG_CFG_OFFSET(rcg), &cfg);
  501. if (ret)
  502. return ret;
  503. ret = __clk_rcg2_configure_mnd(rcg, f, &cfg);
  504. if (ret)
  505. return ret;
  506. ret = regmap_write(rcg->clkr.regmap, RCG_CFG_OFFSET(rcg), cfg);
  507. if (ret)
  508. return ret;
  509. return update_config(rcg);
  510. }
  511. static int __clk_rcg2_set_rate(struct clk_hw *hw, unsigned long rate,
  512. enum freq_policy policy)
  513. {
  514. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  515. const struct freq_tbl *f;
  516. switch (policy) {
  517. case FLOOR:
  518. f = qcom_find_freq_floor(rcg->freq_tbl, rate);
  519. break;
  520. case CEIL:
  521. f = qcom_find_freq(rcg->freq_tbl, rate);
  522. break;
  523. default:
  524. return -EINVAL;
  525. }
  526. if (!f)
  527. return -EINVAL;
  528. return clk_rcg2_configure(rcg, f);
  529. }
  530. static int __clk_rcg2_fm_set_rate(struct clk_hw *hw, unsigned long rate)
  531. {
  532. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  533. const struct freq_multi_tbl *f;
  534. const struct freq_conf *conf;
  535. struct freq_tbl f_tbl = {};
  536. f = qcom_find_freq_multi(rcg->freq_multi_tbl, rate);
  537. if (!f || !f->confs)
  538. return -EINVAL;
  539. conf = __clk_rcg2_select_conf(hw, f, rate);
  540. if (IS_ERR(conf))
  541. return PTR_ERR(conf);
  542. f_tbl.freq = f->freq;
  543. f_tbl.src = conf->src;
  544. f_tbl.pre_div = conf->pre_div;
  545. f_tbl.m = conf->m;
  546. f_tbl.n = conf->n;
  547. return clk_rcg2_configure(rcg, &f_tbl);
  548. }
  549. static int clk_rcg2_set_rate(struct clk_hw *hw, unsigned long rate,
  550. unsigned long parent_rate)
  551. {
  552. return __clk_rcg2_set_rate(hw, rate, CEIL);
  553. }
  554. static int clk_rcg2_set_gp_rate(struct clk_hw *hw, unsigned long rate,
  555. unsigned long parent_rate)
  556. {
  557. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  558. int mnd_max = BIT(rcg->mnd_width) - 1;
  559. int hid_max = BIT(rcg->hid_width) - 1;
  560. struct freq_tbl f_tbl = {}, *f = &f_tbl;
  561. int ret;
  562. clk_rcg2_calc_mnd(parent_rate, rate, f, mnd_max, hid_max / 2);
  563. convert_to_reg_val(f);
  564. ret = clk_rcg2_configure_gp(rcg, f);
  565. return ret;
  566. }
  567. static int clk_rcg2_set_floor_rate(struct clk_hw *hw, unsigned long rate,
  568. unsigned long parent_rate)
  569. {
  570. return __clk_rcg2_set_rate(hw, rate, FLOOR);
  571. }
  572. static int clk_rcg2_fm_set_rate(struct clk_hw *hw, unsigned long rate,
  573. unsigned long parent_rate)
  574. {
  575. return __clk_rcg2_fm_set_rate(hw, rate);
  576. }
  577. static int clk_rcg2_set_rate_and_parent(struct clk_hw *hw,
  578. unsigned long rate, unsigned long parent_rate, u8 index)
  579. {
  580. return __clk_rcg2_set_rate(hw, rate, CEIL);
  581. }
  582. static int clk_rcg2_set_floor_rate_and_parent(struct clk_hw *hw,
  583. unsigned long rate, unsigned long parent_rate, u8 index)
  584. {
  585. return __clk_rcg2_set_rate(hw, rate, FLOOR);
  586. }
  587. static int clk_rcg2_fm_set_rate_and_parent(struct clk_hw *hw,
  588. unsigned long rate, unsigned long parent_rate, u8 index)
  589. {
  590. return __clk_rcg2_fm_set_rate(hw, rate);
  591. }
  592. static int clk_rcg2_get_duty_cycle(struct clk_hw *hw, struct clk_duty *duty)
  593. {
  594. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  595. u32 notn_m, n, m, d, not2d, mask;
  596. if (!rcg->mnd_width) {
  597. /* 50 % duty-cycle for Non-MND RCGs */
  598. duty->num = 1;
  599. duty->den = 2;
  600. return 0;
  601. }
  602. regmap_read(rcg->clkr.regmap, RCG_D_OFFSET(rcg), &not2d);
  603. regmap_read(rcg->clkr.regmap, RCG_M_OFFSET(rcg), &m);
  604. regmap_read(rcg->clkr.regmap, RCG_N_OFFSET(rcg), &notn_m);
  605. if (!not2d && !m && !notn_m) {
  606. /* 50 % duty-cycle always */
  607. duty->num = 1;
  608. duty->den = 2;
  609. return 0;
  610. }
  611. mask = BIT(rcg->mnd_width) - 1;
  612. d = ~(not2d) & mask;
  613. d = DIV_ROUND_CLOSEST(d, 2);
  614. n = (~(notn_m) + m) & mask;
  615. duty->num = d;
  616. duty->den = n;
  617. return 0;
  618. }
  619. static int clk_rcg2_set_duty_cycle(struct clk_hw *hw, struct clk_duty *duty)
  620. {
  621. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  622. u32 notn_m, n, m, d, not2d, mask, cfg;
  623. int ret;
  624. /* Duty-cycle cannot be modified for non-MND RCGs */
  625. if (!rcg->mnd_width)
  626. return -EINVAL;
  627. mask = BIT(rcg->mnd_width) - 1;
  628. regmap_read(rcg->clkr.regmap, RCG_N_OFFSET(rcg), &notn_m);
  629. regmap_read(rcg->clkr.regmap, RCG_M_OFFSET(rcg), &m);
  630. regmap_read(rcg->clkr.regmap, RCG_CFG_OFFSET(rcg), &cfg);
  631. /* Duty-cycle cannot be modified if MND divider is in bypass mode. */
  632. if (!(cfg & CFG_MODE_MASK))
  633. return -EINVAL;
  634. n = (~(notn_m) + m) & mask;
  635. /* Calculate 2d value */
  636. d = DIV_ROUND_CLOSEST(n * duty->num * 2, duty->den);
  637. /*
  638. * Check bit widths of 2d. If D is too big reduce duty cycle.
  639. * Also make sure it is never zero.
  640. */
  641. d = clamp_val(d, 1, mask);
  642. if ((d / 2) > (n - m))
  643. d = (n - m) * 2;
  644. else if ((d / 2) < (m / 2))
  645. d = m;
  646. not2d = ~d & mask;
  647. ret = regmap_update_bits(rcg->clkr.regmap, RCG_D_OFFSET(rcg), mask,
  648. not2d);
  649. if (ret)
  650. return ret;
  651. return update_config(rcg);
  652. }
  653. const struct clk_ops clk_rcg2_ops = {
  654. .is_enabled = clk_rcg2_is_enabled,
  655. .get_parent = clk_rcg2_get_parent,
  656. .set_parent = clk_rcg2_set_parent,
  657. .recalc_rate = clk_rcg2_recalc_rate,
  658. .determine_rate = clk_rcg2_determine_rate,
  659. .set_rate = clk_rcg2_set_rate,
  660. .set_rate_and_parent = clk_rcg2_set_rate_and_parent,
  661. .get_duty_cycle = clk_rcg2_get_duty_cycle,
  662. .set_duty_cycle = clk_rcg2_set_duty_cycle,
  663. };
  664. EXPORT_SYMBOL_GPL(clk_rcg2_ops);
  665. const struct clk_ops clk_rcg2_gp_ops = {
  666. .is_enabled = clk_rcg2_is_enabled,
  667. .get_parent = clk_rcg2_get_parent,
  668. .set_parent = clk_rcg2_set_parent,
  669. .recalc_rate = clk_rcg2_recalc_rate,
  670. .determine_rate = clk_rcg2_determine_gp_rate,
  671. .set_rate = clk_rcg2_set_gp_rate,
  672. .get_duty_cycle = clk_rcg2_get_duty_cycle,
  673. .set_duty_cycle = clk_rcg2_set_duty_cycle,
  674. };
  675. EXPORT_SYMBOL_GPL(clk_rcg2_gp_ops);
  676. const struct clk_ops clk_rcg2_floor_ops = {
  677. .is_enabled = clk_rcg2_is_enabled,
  678. .get_parent = clk_rcg2_get_parent,
  679. .set_parent = clk_rcg2_set_parent,
  680. .recalc_rate = clk_rcg2_recalc_rate,
  681. .determine_rate = clk_rcg2_determine_floor_rate,
  682. .set_rate = clk_rcg2_set_floor_rate,
  683. .set_rate_and_parent = clk_rcg2_set_floor_rate_and_parent,
  684. .get_duty_cycle = clk_rcg2_get_duty_cycle,
  685. .set_duty_cycle = clk_rcg2_set_duty_cycle,
  686. };
  687. EXPORT_SYMBOL_GPL(clk_rcg2_floor_ops);
  688. const struct clk_ops clk_rcg2_fm_ops = {
  689. .is_enabled = clk_rcg2_is_enabled,
  690. .get_parent = clk_rcg2_get_parent,
  691. .set_parent = clk_rcg2_set_parent,
  692. .recalc_rate = clk_rcg2_recalc_rate,
  693. .determine_rate = clk_rcg2_fm_determine_rate,
  694. .set_rate = clk_rcg2_fm_set_rate,
  695. .set_rate_and_parent = clk_rcg2_fm_set_rate_and_parent,
  696. .get_duty_cycle = clk_rcg2_get_duty_cycle,
  697. .set_duty_cycle = clk_rcg2_set_duty_cycle,
  698. };
  699. EXPORT_SYMBOL_GPL(clk_rcg2_fm_ops);
  700. const struct clk_ops clk_rcg2_mux_closest_ops = {
  701. .determine_rate = __clk_mux_determine_rate_closest,
  702. .get_parent = clk_rcg2_get_parent,
  703. .set_parent = clk_rcg2_set_parent,
  704. };
  705. EXPORT_SYMBOL_GPL(clk_rcg2_mux_closest_ops);
  706. struct frac_entry {
  707. int num;
  708. int den;
  709. };
  710. static const struct frac_entry frac_table_675m[] = { /* link rate of 270M */
  711. { 52, 295 }, /* 119 M */
  712. { 11, 57 }, /* 130.25 M */
  713. { 63, 307 }, /* 138.50 M */
  714. { 11, 50 }, /* 148.50 M */
  715. { 47, 206 }, /* 154 M */
  716. { 31, 100 }, /* 205.25 M */
  717. { 107, 269 }, /* 268.50 M */
  718. { },
  719. };
  720. static struct frac_entry frac_table_810m[] = { /* Link rate of 162M */
  721. { 31, 211 }, /* 119 M */
  722. { 32, 199 }, /* 130.25 M */
  723. { 63, 307 }, /* 138.50 M */
  724. { 11, 60 }, /* 148.50 M */
  725. { 50, 263 }, /* 154 M */
  726. { 31, 120 }, /* 205.25 M */
  727. { 119, 359 }, /* 268.50 M */
  728. { },
  729. };
  730. static int clk_edp_pixel_set_rate(struct clk_hw *hw, unsigned long rate,
  731. unsigned long parent_rate)
  732. {
  733. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  734. struct freq_tbl f = *rcg->freq_tbl;
  735. const struct frac_entry *frac;
  736. int delta = 100000;
  737. s64 src_rate = parent_rate;
  738. s64 request;
  739. u32 mask = BIT(rcg->hid_width) - 1;
  740. u32 hid_div;
  741. if (src_rate == 810000000)
  742. frac = frac_table_810m;
  743. else
  744. frac = frac_table_675m;
  745. for (; frac->num; frac++) {
  746. request = rate;
  747. request *= frac->den;
  748. request = div_s64(request, frac->num);
  749. if ((src_rate < (request - delta)) ||
  750. (src_rate > (request + delta)))
  751. continue;
  752. regmap_read(rcg->clkr.regmap, rcg->cmd_rcgr + CFG_REG,
  753. &hid_div);
  754. f.pre_div = hid_div;
  755. f.pre_div >>= CFG_SRC_DIV_SHIFT;
  756. f.pre_div &= mask;
  757. f.m = frac->num;
  758. f.n = frac->den;
  759. return clk_rcg2_configure(rcg, &f);
  760. }
  761. return -EINVAL;
  762. }
  763. static int clk_edp_pixel_set_rate_and_parent(struct clk_hw *hw,
  764. unsigned long rate, unsigned long parent_rate, u8 index)
  765. {
  766. /* Parent index is set statically in frequency table */
  767. return clk_edp_pixel_set_rate(hw, rate, parent_rate);
  768. }
  769. static int clk_edp_pixel_determine_rate(struct clk_hw *hw,
  770. struct clk_rate_request *req)
  771. {
  772. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  773. const struct freq_tbl *f = rcg->freq_tbl;
  774. const struct frac_entry *frac;
  775. int delta = 100000;
  776. s64 request;
  777. u32 mask = BIT(rcg->hid_width) - 1;
  778. u32 hid_div;
  779. int index = qcom_find_src_index(hw, rcg->parent_map, f->src);
  780. /* Force the correct parent */
  781. req->best_parent_hw = clk_hw_get_parent_by_index(hw, index);
  782. req->best_parent_rate = clk_hw_get_rate(req->best_parent_hw);
  783. if (req->best_parent_rate == 810000000)
  784. frac = frac_table_810m;
  785. else
  786. frac = frac_table_675m;
  787. for (; frac->num; frac++) {
  788. request = req->rate;
  789. request *= frac->den;
  790. request = div_s64(request, frac->num);
  791. if ((req->best_parent_rate < (request - delta)) ||
  792. (req->best_parent_rate > (request + delta)))
  793. continue;
  794. regmap_read(rcg->clkr.regmap, rcg->cmd_rcgr + CFG_REG,
  795. &hid_div);
  796. hid_div >>= CFG_SRC_DIV_SHIFT;
  797. hid_div &= mask;
  798. req->rate = calc_rate(req->best_parent_rate,
  799. frac->num, frac->den,
  800. !!frac->den, hid_div);
  801. return 0;
  802. }
  803. return -EINVAL;
  804. }
  805. const struct clk_ops clk_edp_pixel_ops = {
  806. .is_enabled = clk_rcg2_is_enabled,
  807. .get_parent = clk_rcg2_get_parent,
  808. .set_parent = clk_rcg2_set_parent,
  809. .recalc_rate = clk_rcg2_recalc_rate,
  810. .set_rate = clk_edp_pixel_set_rate,
  811. .set_rate_and_parent = clk_edp_pixel_set_rate_and_parent,
  812. .determine_rate = clk_edp_pixel_determine_rate,
  813. };
  814. EXPORT_SYMBOL_GPL(clk_edp_pixel_ops);
  815. static int clk_byte_determine_rate(struct clk_hw *hw,
  816. struct clk_rate_request *req)
  817. {
  818. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  819. const struct freq_tbl *f = rcg->freq_tbl;
  820. int index = qcom_find_src_index(hw, rcg->parent_map, f->src);
  821. unsigned long parent_rate, div;
  822. u32 mask = BIT(rcg->hid_width) - 1;
  823. struct clk_hw *p;
  824. if (req->rate == 0)
  825. return -EINVAL;
  826. req->best_parent_hw = p = clk_hw_get_parent_by_index(hw, index);
  827. req->best_parent_rate = parent_rate = clk_hw_round_rate(p, req->rate);
  828. div = DIV_ROUND_UP((2 * parent_rate), req->rate) - 1;
  829. div = min_t(u32, div, mask);
  830. req->rate = calc_rate(parent_rate, 0, 0, 0, div);
  831. return 0;
  832. }
  833. static int clk_byte_set_rate(struct clk_hw *hw, unsigned long rate,
  834. unsigned long parent_rate)
  835. {
  836. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  837. struct freq_tbl f = *rcg->freq_tbl;
  838. unsigned long div;
  839. u32 mask = BIT(rcg->hid_width) - 1;
  840. div = DIV_ROUND_UP((2 * parent_rate), rate) - 1;
  841. div = min_t(u32, div, mask);
  842. f.pre_div = div;
  843. return clk_rcg2_configure(rcg, &f);
  844. }
  845. static int clk_byte_set_rate_and_parent(struct clk_hw *hw,
  846. unsigned long rate, unsigned long parent_rate, u8 index)
  847. {
  848. /* Parent index is set statically in frequency table */
  849. return clk_byte_set_rate(hw, rate, parent_rate);
  850. }
  851. const struct clk_ops clk_byte_ops = {
  852. .is_enabled = clk_rcg2_is_enabled,
  853. .get_parent = clk_rcg2_get_parent,
  854. .set_parent = clk_rcg2_set_parent,
  855. .recalc_rate = clk_rcg2_recalc_rate,
  856. .set_rate = clk_byte_set_rate,
  857. .set_rate_and_parent = clk_byte_set_rate_and_parent,
  858. .determine_rate = clk_byte_determine_rate,
  859. };
  860. EXPORT_SYMBOL_GPL(clk_byte_ops);
  861. static int clk_byte2_determine_rate(struct clk_hw *hw,
  862. struct clk_rate_request *req)
  863. {
  864. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  865. unsigned long parent_rate, div;
  866. u32 mask = BIT(rcg->hid_width) - 1;
  867. struct clk_hw *p;
  868. unsigned long rate = req->rate;
  869. if (rate == 0)
  870. return -EINVAL;
  871. p = req->best_parent_hw;
  872. req->best_parent_rate = parent_rate = clk_hw_round_rate(p, rate);
  873. div = DIV_ROUND_UP((2 * parent_rate), rate) - 1;
  874. div = min_t(u32, div, mask);
  875. req->rate = calc_rate(parent_rate, 0, 0, 0, div);
  876. return 0;
  877. }
  878. static int clk_byte2_set_rate(struct clk_hw *hw, unsigned long rate,
  879. unsigned long parent_rate)
  880. {
  881. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  882. struct freq_tbl f = { 0 };
  883. unsigned long div;
  884. int i, num_parents = clk_hw_get_num_parents(hw);
  885. u32 mask = BIT(rcg->hid_width) - 1;
  886. u32 cfg;
  887. div = DIV_ROUND_UP((2 * parent_rate), rate) - 1;
  888. div = min_t(u32, div, mask);
  889. f.pre_div = div;
  890. regmap_read(rcg->clkr.regmap, rcg->cmd_rcgr + CFG_REG, &cfg);
  891. cfg &= CFG_SRC_SEL_MASK;
  892. cfg >>= CFG_SRC_SEL_SHIFT;
  893. for (i = 0; i < num_parents; i++) {
  894. if (cfg == rcg->parent_map[i].cfg) {
  895. f.src = rcg->parent_map[i].src;
  896. return clk_rcg2_configure(rcg, &f);
  897. }
  898. }
  899. return -EINVAL;
  900. }
  901. static int clk_byte2_set_rate_and_parent(struct clk_hw *hw,
  902. unsigned long rate, unsigned long parent_rate, u8 index)
  903. {
  904. /* Read the hardware to determine parent during set_rate */
  905. return clk_byte2_set_rate(hw, rate, parent_rate);
  906. }
  907. const struct clk_ops clk_byte2_ops = {
  908. .is_enabled = clk_rcg2_is_enabled,
  909. .get_parent = clk_rcg2_get_parent,
  910. .set_parent = clk_rcg2_set_parent,
  911. .recalc_rate = clk_rcg2_recalc_rate,
  912. .set_rate = clk_byte2_set_rate,
  913. .set_rate_and_parent = clk_byte2_set_rate_and_parent,
  914. .determine_rate = clk_byte2_determine_rate,
  915. };
  916. EXPORT_SYMBOL_GPL(clk_byte2_ops);
  917. static const struct frac_entry frac_table_pixel[] = {
  918. { 3, 8 },
  919. { 2, 9 },
  920. { 4, 9 },
  921. { 1, 1 },
  922. { 2, 3 },
  923. { }
  924. };
  925. static int clk_pixel_determine_rate(struct clk_hw *hw,
  926. struct clk_rate_request *req)
  927. {
  928. unsigned long request, src_rate;
  929. int delta = 100000;
  930. const struct frac_entry *frac = frac_table_pixel;
  931. for (; frac->num; frac++) {
  932. request = (req->rate * frac->den) / frac->num;
  933. src_rate = clk_hw_round_rate(req->best_parent_hw, request);
  934. if ((src_rate < (request - delta)) ||
  935. (src_rate > (request + delta)))
  936. continue;
  937. req->best_parent_rate = src_rate;
  938. req->rate = (src_rate * frac->num) / frac->den;
  939. return 0;
  940. }
  941. return -EINVAL;
  942. }
  943. static int clk_pixel_set_rate(struct clk_hw *hw, unsigned long rate,
  944. unsigned long parent_rate)
  945. {
  946. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  947. struct freq_tbl f = { 0 };
  948. const struct frac_entry *frac = frac_table_pixel;
  949. unsigned long request;
  950. int delta = 100000;
  951. u32 mask = BIT(rcg->hid_width) - 1;
  952. u32 hid_div, cfg;
  953. int i, num_parents = clk_hw_get_num_parents(hw);
  954. regmap_read(rcg->clkr.regmap, rcg->cmd_rcgr + CFG_REG, &cfg);
  955. cfg &= CFG_SRC_SEL_MASK;
  956. cfg >>= CFG_SRC_SEL_SHIFT;
  957. for (i = 0; i < num_parents; i++)
  958. if (cfg == rcg->parent_map[i].cfg) {
  959. f.src = rcg->parent_map[i].src;
  960. break;
  961. }
  962. for (; frac->num; frac++) {
  963. request = (rate * frac->den) / frac->num;
  964. if ((parent_rate < (request - delta)) ||
  965. (parent_rate > (request + delta)))
  966. continue;
  967. regmap_read(rcg->clkr.regmap, rcg->cmd_rcgr + CFG_REG,
  968. &hid_div);
  969. f.pre_div = hid_div;
  970. f.pre_div >>= CFG_SRC_DIV_SHIFT;
  971. f.pre_div &= mask;
  972. f.m = frac->num;
  973. f.n = frac->den;
  974. return clk_rcg2_configure(rcg, &f);
  975. }
  976. return -EINVAL;
  977. }
  978. static int clk_pixel_set_rate_and_parent(struct clk_hw *hw, unsigned long rate,
  979. unsigned long parent_rate, u8 index)
  980. {
  981. return clk_pixel_set_rate(hw, rate, parent_rate);
  982. }
  983. const struct clk_ops clk_pixel_ops = {
  984. .is_enabled = clk_rcg2_is_enabled,
  985. .get_parent = clk_rcg2_get_parent,
  986. .set_parent = clk_rcg2_set_parent,
  987. .recalc_rate = clk_rcg2_recalc_rate,
  988. .set_rate = clk_pixel_set_rate,
  989. .set_rate_and_parent = clk_pixel_set_rate_and_parent,
  990. .determine_rate = clk_pixel_determine_rate,
  991. };
  992. EXPORT_SYMBOL_GPL(clk_pixel_ops);
  993. static int clk_gfx3d_determine_rate(struct clk_hw *hw,
  994. struct clk_rate_request *req)
  995. {
  996. struct clk_rate_request parent_req = { .min_rate = 0, .max_rate = ULONG_MAX };
  997. struct clk_rcg2_gfx3d *cgfx = to_clk_rcg2_gfx3d(hw);
  998. struct clk_hw *xo, *p0, *p1, *p2;
  999. unsigned long p0_rate;
  1000. u8 mux_div = cgfx->div;
  1001. int ret;
  1002. p0 = cgfx->hws[0];
  1003. p1 = cgfx->hws[1];
  1004. p2 = cgfx->hws[2];
  1005. /*
  1006. * This function does ping-pong the RCG between PLLs: if we don't
  1007. * have at least one fixed PLL and two variable ones,
  1008. * then it's not going to work correctly.
  1009. */
  1010. if (WARN_ON(!p0 || !p1 || !p2))
  1011. return -EINVAL;
  1012. xo = clk_hw_get_parent_by_index(hw, 0);
  1013. if (req->rate == clk_hw_get_rate(xo)) {
  1014. req->best_parent_hw = xo;
  1015. return 0;
  1016. }
  1017. if (mux_div == 0)
  1018. mux_div = 1;
  1019. parent_req.rate = req->rate * mux_div;
  1020. /* This has to be a fixed rate PLL */
  1021. p0_rate = clk_hw_get_rate(p0);
  1022. if (parent_req.rate == p0_rate) {
  1023. req->rate = req->best_parent_rate = p0_rate;
  1024. req->best_parent_hw = p0;
  1025. return 0;
  1026. }
  1027. if (req->best_parent_hw == p0) {
  1028. /* Are we going back to a previously used rate? */
  1029. if (clk_hw_get_rate(p2) == parent_req.rate)
  1030. req->best_parent_hw = p2;
  1031. else
  1032. req->best_parent_hw = p1;
  1033. } else if (req->best_parent_hw == p2) {
  1034. req->best_parent_hw = p1;
  1035. } else {
  1036. req->best_parent_hw = p2;
  1037. }
  1038. clk_hw_get_rate_range(req->best_parent_hw,
  1039. &parent_req.min_rate, &parent_req.max_rate);
  1040. if (req->min_rate > parent_req.min_rate)
  1041. parent_req.min_rate = req->min_rate;
  1042. if (req->max_rate < parent_req.max_rate)
  1043. parent_req.max_rate = req->max_rate;
  1044. parent_req.best_parent_hw = req->best_parent_hw;
  1045. ret = __clk_determine_rate(req->best_parent_hw, &parent_req);
  1046. if (ret)
  1047. return ret;
  1048. req->rate = req->best_parent_rate = parent_req.rate;
  1049. req->rate /= mux_div;
  1050. return 0;
  1051. }
  1052. static int clk_gfx3d_set_rate_and_parent(struct clk_hw *hw, unsigned long rate,
  1053. unsigned long parent_rate, u8 index)
  1054. {
  1055. struct clk_rcg2_gfx3d *cgfx = to_clk_rcg2_gfx3d(hw);
  1056. struct clk_rcg2 *rcg = &cgfx->rcg;
  1057. u32 cfg;
  1058. int ret;
  1059. cfg = rcg->parent_map[index].cfg << CFG_SRC_SEL_SHIFT;
  1060. /* On some targets, the GFX3D RCG may need to divide PLL frequency */
  1061. if (cgfx->div > 1)
  1062. cfg |= ((2 * cgfx->div) - 1) << CFG_SRC_DIV_SHIFT;
  1063. ret = regmap_write(rcg->clkr.regmap, rcg->cmd_rcgr + CFG_REG, cfg);
  1064. if (ret)
  1065. return ret;
  1066. return update_config(rcg);
  1067. }
  1068. static int clk_gfx3d_set_rate(struct clk_hw *hw, unsigned long rate,
  1069. unsigned long parent_rate)
  1070. {
  1071. /*
  1072. * We should never get here; clk_gfx3d_determine_rate() should always
  1073. * make us use a different parent than what we're currently using, so
  1074. * clk_gfx3d_set_rate_and_parent() should always be called.
  1075. */
  1076. return 0;
  1077. }
  1078. const struct clk_ops clk_gfx3d_ops = {
  1079. .is_enabled = clk_rcg2_is_enabled,
  1080. .get_parent = clk_rcg2_get_parent,
  1081. .set_parent = clk_rcg2_set_parent,
  1082. .recalc_rate = clk_rcg2_recalc_rate,
  1083. .set_rate = clk_gfx3d_set_rate,
  1084. .set_rate_and_parent = clk_gfx3d_set_rate_and_parent,
  1085. .determine_rate = clk_gfx3d_determine_rate,
  1086. };
  1087. EXPORT_SYMBOL_GPL(clk_gfx3d_ops);
  1088. static int clk_rcg2_set_force_enable(struct clk_hw *hw)
  1089. {
  1090. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  1091. const char *name = clk_hw_get_name(hw);
  1092. int ret, count;
  1093. ret = regmap_update_bits(rcg->clkr.regmap, rcg->cmd_rcgr + CMD_REG,
  1094. CMD_ROOT_EN, CMD_ROOT_EN);
  1095. if (ret)
  1096. return ret;
  1097. /* wait for RCG to turn ON */
  1098. for (count = 500; count > 0; count--) {
  1099. if (clk_rcg2_is_enabled(hw))
  1100. return 0;
  1101. udelay(1);
  1102. }
  1103. pr_err("%s: RCG did not turn on\n", name);
  1104. return -ETIMEDOUT;
  1105. }
  1106. static int clk_rcg2_clear_force_enable(struct clk_hw *hw)
  1107. {
  1108. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  1109. return regmap_update_bits(rcg->clkr.regmap, rcg->cmd_rcgr + CMD_REG,
  1110. CMD_ROOT_EN, 0);
  1111. }
  1112. static int
  1113. clk_rcg2_shared_force_enable_clear(struct clk_hw *hw, const struct freq_tbl *f)
  1114. {
  1115. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  1116. int ret;
  1117. ret = clk_rcg2_set_force_enable(hw);
  1118. if (ret)
  1119. return ret;
  1120. ret = clk_rcg2_configure(rcg, f);
  1121. if (ret)
  1122. return ret;
  1123. return clk_rcg2_clear_force_enable(hw);
  1124. }
  1125. static int __clk_rcg2_shared_set_rate(struct clk_hw *hw, unsigned long rate,
  1126. unsigned long parent_rate,
  1127. enum freq_policy policy)
  1128. {
  1129. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  1130. const struct freq_tbl *f;
  1131. switch (policy) {
  1132. case FLOOR:
  1133. f = qcom_find_freq_floor(rcg->freq_tbl, rate);
  1134. break;
  1135. case CEIL:
  1136. f = qcom_find_freq(rcg->freq_tbl, rate);
  1137. break;
  1138. default:
  1139. return -EINVAL;
  1140. }
  1141. /*
  1142. * In case clock is disabled, update the M, N and D registers, cache
  1143. * the CFG value in parked_cfg and don't hit the update bit of CMD
  1144. * register.
  1145. */
  1146. if (!clk_hw_is_enabled(hw))
  1147. return __clk_rcg2_configure(rcg, f, &rcg->parked_cfg);
  1148. return clk_rcg2_shared_force_enable_clear(hw, f);
  1149. }
  1150. static int clk_rcg2_shared_set_rate(struct clk_hw *hw, unsigned long rate,
  1151. unsigned long parent_rate)
  1152. {
  1153. return __clk_rcg2_shared_set_rate(hw, rate, parent_rate, CEIL);
  1154. }
  1155. static int clk_rcg2_shared_set_rate_and_parent(struct clk_hw *hw,
  1156. unsigned long rate, unsigned long parent_rate, u8 index)
  1157. {
  1158. return __clk_rcg2_shared_set_rate(hw, rate, parent_rate, CEIL);
  1159. }
  1160. static int clk_rcg2_shared_set_floor_rate(struct clk_hw *hw, unsigned long rate,
  1161. unsigned long parent_rate)
  1162. {
  1163. return __clk_rcg2_shared_set_rate(hw, rate, parent_rate, FLOOR);
  1164. }
  1165. static int clk_rcg2_shared_set_floor_rate_and_parent(struct clk_hw *hw,
  1166. unsigned long rate, unsigned long parent_rate, u8 index)
  1167. {
  1168. return __clk_rcg2_shared_set_rate(hw, rate, parent_rate, FLOOR);
  1169. }
  1170. static int clk_rcg2_shared_enable(struct clk_hw *hw)
  1171. {
  1172. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  1173. int ret;
  1174. /*
  1175. * Set the update bit because required configuration has already
  1176. * been written in clk_rcg2_shared_set_rate()
  1177. */
  1178. ret = clk_rcg2_set_force_enable(hw);
  1179. if (ret)
  1180. return ret;
  1181. /* Write back the stored configuration corresponding to current rate */
  1182. ret = regmap_write(rcg->clkr.regmap, rcg->cmd_rcgr + CFG_REG, rcg->parked_cfg);
  1183. if (ret)
  1184. return ret;
  1185. ret = update_config(rcg);
  1186. if (ret)
  1187. return ret;
  1188. return clk_rcg2_clear_force_enable(hw);
  1189. }
  1190. static void clk_rcg2_shared_disable(struct clk_hw *hw)
  1191. {
  1192. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  1193. /*
  1194. * Store current configuration as switching to safe source would clear
  1195. * the SRC and DIV of CFG register
  1196. */
  1197. regmap_read(rcg->clkr.regmap, rcg->cmd_rcgr + CFG_REG, &rcg->parked_cfg);
  1198. /*
  1199. * Park the RCG at a safe configuration - sourced off of safe source.
  1200. * Force enable and disable the RCG while configuring it to safeguard
  1201. * against any update signal coming from the downstream clock.
  1202. * The current parent is still prepared and enabled at this point, and
  1203. * the safe source is always on while application processor subsystem
  1204. * is online. Therefore, the RCG can safely switch its parent.
  1205. */
  1206. clk_rcg2_set_force_enable(hw);
  1207. regmap_write(rcg->clkr.regmap, rcg->cmd_rcgr + CFG_REG,
  1208. rcg->safe_src_index << CFG_SRC_SEL_SHIFT);
  1209. update_config(rcg);
  1210. clk_rcg2_clear_force_enable(hw);
  1211. }
  1212. static u8 clk_rcg2_shared_get_parent(struct clk_hw *hw)
  1213. {
  1214. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  1215. /* If the shared rcg is parked use the cached cfg instead */
  1216. if (!clk_hw_is_enabled(hw))
  1217. return __clk_rcg2_get_parent(hw, rcg->parked_cfg);
  1218. return clk_rcg2_get_parent(hw);
  1219. }
  1220. static int clk_rcg2_shared_set_parent(struct clk_hw *hw, u8 index)
  1221. {
  1222. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  1223. /* If the shared rcg is parked only update the cached cfg */
  1224. if (!clk_hw_is_enabled(hw)) {
  1225. rcg->parked_cfg &= ~CFG_SRC_SEL_MASK;
  1226. rcg->parked_cfg |= rcg->parent_map[index].cfg << CFG_SRC_SEL_SHIFT;
  1227. return 0;
  1228. }
  1229. return clk_rcg2_set_parent(hw, index);
  1230. }
  1231. static unsigned long
  1232. clk_rcg2_shared_recalc_rate(struct clk_hw *hw, unsigned long parent_rate)
  1233. {
  1234. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  1235. /* If the shared rcg is parked use the cached cfg instead */
  1236. if (!clk_hw_is_enabled(hw))
  1237. return __clk_rcg2_recalc_rate(hw, parent_rate, rcg->parked_cfg);
  1238. return clk_rcg2_recalc_rate(hw, parent_rate);
  1239. }
  1240. static int clk_rcg2_shared_init(struct clk_hw *hw)
  1241. {
  1242. /*
  1243. * This does a few things:
  1244. *
  1245. * 1. Sets rcg->parked_cfg to reflect the value at probe so that the
  1246. * proper parent is reported from clk_rcg2_shared_get_parent().
  1247. *
  1248. * 2. Clears the force enable bit of the RCG because we rely on child
  1249. * clks (branches) to turn the RCG on/off with a hardware feedback
  1250. * mechanism and only set the force enable bit in the RCG when we
  1251. * want to make sure the clk stays on for parent switches or
  1252. * parking.
  1253. *
  1254. * 3. Parks shared RCGs on the safe source at registration because we
  1255. * can't be certain that the parent clk will stay on during boot,
  1256. * especially if the parent is shared. If this RCG is enabled at
  1257. * boot, and the parent is turned off, the RCG will get stuck on. A
  1258. * GDSC can wedge if is turned on and the RCG is stuck on because
  1259. * the GDSC's controller will hang waiting for the clk status to
  1260. * toggle on when it never does.
  1261. *
  1262. * The safest option here is to "park" the RCG at init so that the clk
  1263. * can never get stuck on or off. This ensures the GDSC can't get
  1264. * wedged.
  1265. */
  1266. clk_rcg2_shared_disable(hw);
  1267. return 0;
  1268. }
  1269. const struct clk_ops clk_rcg2_shared_ops = {
  1270. .init = clk_rcg2_shared_init,
  1271. .enable = clk_rcg2_shared_enable,
  1272. .disable = clk_rcg2_shared_disable,
  1273. .get_parent = clk_rcg2_shared_get_parent,
  1274. .set_parent = clk_rcg2_shared_set_parent,
  1275. .recalc_rate = clk_rcg2_shared_recalc_rate,
  1276. .determine_rate = clk_rcg2_determine_rate,
  1277. .set_rate = clk_rcg2_shared_set_rate,
  1278. .set_rate_and_parent = clk_rcg2_shared_set_rate_and_parent,
  1279. };
  1280. EXPORT_SYMBOL_GPL(clk_rcg2_shared_ops);
  1281. const struct clk_ops clk_rcg2_shared_floor_ops = {
  1282. .enable = clk_rcg2_shared_enable,
  1283. .disable = clk_rcg2_shared_disable,
  1284. .get_parent = clk_rcg2_shared_get_parent,
  1285. .set_parent = clk_rcg2_shared_set_parent,
  1286. .recalc_rate = clk_rcg2_shared_recalc_rate,
  1287. .determine_rate = clk_rcg2_determine_floor_rate,
  1288. .set_rate = clk_rcg2_shared_set_floor_rate,
  1289. .set_rate_and_parent = clk_rcg2_shared_set_floor_rate_and_parent,
  1290. };
  1291. EXPORT_SYMBOL_GPL(clk_rcg2_shared_floor_ops);
  1292. static int clk_rcg2_shared_no_init_park(struct clk_hw *hw)
  1293. {
  1294. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  1295. /*
  1296. * Read the config register so that the parent is properly mapped at
  1297. * registration time.
  1298. */
  1299. regmap_read(rcg->clkr.regmap, rcg->cmd_rcgr + CFG_REG, &rcg->parked_cfg);
  1300. return 0;
  1301. }
  1302. /*
  1303. * Like clk_rcg2_shared_ops but skip the init so that the clk frequency is left
  1304. * unchanged at registration time.
  1305. */
  1306. const struct clk_ops clk_rcg2_shared_no_init_park_ops = {
  1307. .init = clk_rcg2_shared_no_init_park,
  1308. .enable = clk_rcg2_shared_enable,
  1309. .disable = clk_rcg2_shared_disable,
  1310. .get_parent = clk_rcg2_shared_get_parent,
  1311. .set_parent = clk_rcg2_shared_set_parent,
  1312. .recalc_rate = clk_rcg2_shared_recalc_rate,
  1313. .determine_rate = clk_rcg2_determine_rate,
  1314. .set_rate = clk_rcg2_shared_set_rate,
  1315. .set_rate_and_parent = clk_rcg2_shared_set_rate_and_parent,
  1316. };
  1317. EXPORT_SYMBOL_GPL(clk_rcg2_shared_no_init_park_ops);
  1318. /* Common APIs to be used for DFS based RCGR */
  1319. static void clk_rcg2_dfs_populate_freq(struct clk_hw *hw, unsigned int l,
  1320. struct freq_tbl *f)
  1321. {
  1322. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  1323. struct clk_hw *p;
  1324. unsigned long prate = 0;
  1325. u32 val, mask, cfg, mode, src;
  1326. int i, num_parents;
  1327. regmap_read(rcg->clkr.regmap, rcg->cmd_rcgr + SE_PERF_DFSR(l), &cfg);
  1328. mask = BIT(rcg->hid_width) - 1;
  1329. f->pre_div = 1;
  1330. if (cfg & mask)
  1331. f->pre_div = cfg & mask;
  1332. src = cfg & CFG_SRC_SEL_MASK;
  1333. src >>= CFG_SRC_SEL_SHIFT;
  1334. num_parents = clk_hw_get_num_parents(hw);
  1335. for (i = 0; i < num_parents; i++) {
  1336. if (src == rcg->parent_map[i].cfg) {
  1337. f->src = rcg->parent_map[i].src;
  1338. p = clk_hw_get_parent_by_index(&rcg->clkr.hw, i);
  1339. prate = clk_hw_get_rate(p);
  1340. }
  1341. }
  1342. mode = cfg & CFG_MODE_MASK;
  1343. mode >>= CFG_MODE_SHIFT;
  1344. if (mode) {
  1345. mask = BIT(rcg->mnd_width) - 1;
  1346. regmap_read(rcg->clkr.regmap, rcg->cmd_rcgr + SE_PERF_M_DFSR(l),
  1347. &val);
  1348. val &= mask;
  1349. f->m = val;
  1350. regmap_read(rcg->clkr.regmap, rcg->cmd_rcgr + SE_PERF_N_DFSR(l),
  1351. &val);
  1352. val = ~val;
  1353. val &= mask;
  1354. val += f->m;
  1355. f->n = val;
  1356. }
  1357. f->freq = calc_rate(prate, f->m, f->n, mode, f->pre_div);
  1358. }
  1359. static int clk_rcg2_dfs_populate_freq_table(struct clk_rcg2 *rcg)
  1360. {
  1361. struct freq_tbl *freq_tbl;
  1362. int i;
  1363. /* Allocate space for 1 extra since table is NULL terminated */
  1364. freq_tbl = kzalloc_objs(*freq_tbl, MAX_PERF_LEVEL + 1);
  1365. if (!freq_tbl)
  1366. return -ENOMEM;
  1367. rcg->freq_tbl = freq_tbl;
  1368. for (i = 0; i < MAX_PERF_LEVEL; i++)
  1369. clk_rcg2_dfs_populate_freq(&rcg->clkr.hw, i, freq_tbl + i);
  1370. return 0;
  1371. }
  1372. static int clk_rcg2_dfs_determine_rate(struct clk_hw *hw,
  1373. struct clk_rate_request *req)
  1374. {
  1375. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  1376. int ret;
  1377. if (!rcg->freq_tbl) {
  1378. ret = clk_rcg2_dfs_populate_freq_table(rcg);
  1379. if (ret) {
  1380. pr_err("Failed to update DFS tables for %s\n",
  1381. clk_hw_get_name(hw));
  1382. return ret;
  1383. }
  1384. }
  1385. return clk_rcg2_determine_rate(hw, req);
  1386. }
  1387. static unsigned long
  1388. clk_rcg2_dfs_recalc_rate(struct clk_hw *hw, unsigned long parent_rate)
  1389. {
  1390. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  1391. u32 level, mask, cfg, m = 0, n = 0, mode, pre_div;
  1392. regmap_read(rcg->clkr.regmap,
  1393. rcg->cmd_rcgr + SE_CMD_DFSR_OFFSET, &level);
  1394. level &= GENMASK(4, 1);
  1395. level >>= 1;
  1396. if (rcg->freq_tbl)
  1397. return rcg->freq_tbl[level].freq;
  1398. /*
  1399. * Assume that parent_rate is actually the parent because
  1400. * we can't do any better at figuring it out when the table
  1401. * hasn't been populated yet. We only populate the table
  1402. * in determine_rate because we can't guarantee the parents
  1403. * will be registered with the framework until then.
  1404. */
  1405. regmap_read(rcg->clkr.regmap, rcg->cmd_rcgr + SE_PERF_DFSR(level),
  1406. &cfg);
  1407. mask = BIT(rcg->hid_width) - 1;
  1408. pre_div = 1;
  1409. if (cfg & mask)
  1410. pre_div = cfg & mask;
  1411. mode = cfg & CFG_MODE_MASK;
  1412. mode >>= CFG_MODE_SHIFT;
  1413. if (mode) {
  1414. mask = BIT(rcg->mnd_width) - 1;
  1415. regmap_read(rcg->clkr.regmap,
  1416. rcg->cmd_rcgr + SE_PERF_M_DFSR(level), &m);
  1417. m &= mask;
  1418. regmap_read(rcg->clkr.regmap,
  1419. rcg->cmd_rcgr + SE_PERF_N_DFSR(level), &n);
  1420. n = ~n;
  1421. n &= mask;
  1422. n += m;
  1423. }
  1424. return calc_rate(parent_rate, m, n, mode, pre_div);
  1425. }
  1426. static const struct clk_ops clk_rcg2_dfs_ops = {
  1427. .is_enabled = clk_rcg2_is_enabled,
  1428. .get_parent = clk_rcg2_get_parent,
  1429. .determine_rate = clk_rcg2_dfs_determine_rate,
  1430. .recalc_rate = clk_rcg2_dfs_recalc_rate,
  1431. };
  1432. static int clk_rcg2_enable_dfs(const struct clk_rcg_dfs_data *data,
  1433. struct regmap *regmap)
  1434. {
  1435. struct clk_rcg2 *rcg = data->rcg;
  1436. struct clk_init_data *init = data->init;
  1437. u32 val;
  1438. int ret;
  1439. ret = regmap_read(regmap, rcg->cmd_rcgr + SE_CMD_DFSR_OFFSET, &val);
  1440. if (ret)
  1441. return -EINVAL;
  1442. if (!(val & SE_CMD_DFS_EN))
  1443. return 0;
  1444. /*
  1445. * Rate changes with consumer writing a register in
  1446. * their own I/O region
  1447. */
  1448. init->flags |= CLK_GET_RATE_NOCACHE;
  1449. init->ops = &clk_rcg2_dfs_ops;
  1450. rcg->freq_tbl = NULL;
  1451. return 0;
  1452. }
  1453. int qcom_cc_register_rcg_dfs(struct regmap *regmap,
  1454. const struct clk_rcg_dfs_data *rcgs, size_t len)
  1455. {
  1456. int i, ret;
  1457. for (i = 0; i < len; i++) {
  1458. ret = clk_rcg2_enable_dfs(&rcgs[i], regmap);
  1459. if (ret)
  1460. return ret;
  1461. }
  1462. return 0;
  1463. }
  1464. EXPORT_SYMBOL_GPL(qcom_cc_register_rcg_dfs);
  1465. static int clk_rcg2_dp_set_rate(struct clk_hw *hw, unsigned long rate,
  1466. unsigned long parent_rate)
  1467. {
  1468. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  1469. struct freq_tbl f = { 0 };
  1470. u32 mask = BIT(rcg->hid_width) - 1;
  1471. u32 hid_div, cfg;
  1472. int i, num_parents = clk_hw_get_num_parents(hw);
  1473. unsigned long num, den;
  1474. rational_best_approximation(parent_rate, rate,
  1475. GENMASK(rcg->mnd_width - 1, 0),
  1476. GENMASK(rcg->mnd_width - 1, 0), &den, &num);
  1477. if (!num || !den)
  1478. return -EINVAL;
  1479. regmap_read(rcg->clkr.regmap, rcg->cmd_rcgr + CFG_REG, &cfg);
  1480. hid_div = cfg;
  1481. cfg &= CFG_SRC_SEL_MASK;
  1482. cfg >>= CFG_SRC_SEL_SHIFT;
  1483. for (i = 0; i < num_parents; i++) {
  1484. if (cfg == rcg->parent_map[i].cfg) {
  1485. f.src = rcg->parent_map[i].src;
  1486. break;
  1487. }
  1488. }
  1489. f.pre_div = hid_div;
  1490. f.pre_div >>= CFG_SRC_DIV_SHIFT;
  1491. f.pre_div &= mask;
  1492. if (num != den) {
  1493. f.m = num;
  1494. f.n = den;
  1495. } else {
  1496. f.m = 0;
  1497. f.n = 0;
  1498. }
  1499. return clk_rcg2_configure(rcg, &f);
  1500. }
  1501. static int clk_rcg2_dp_set_rate_and_parent(struct clk_hw *hw,
  1502. unsigned long rate, unsigned long parent_rate, u8 index)
  1503. {
  1504. return clk_rcg2_dp_set_rate(hw, rate, parent_rate);
  1505. }
  1506. static int clk_rcg2_dp_determine_rate(struct clk_hw *hw,
  1507. struct clk_rate_request *req)
  1508. {
  1509. struct clk_rcg2 *rcg = to_clk_rcg2(hw);
  1510. unsigned long num, den;
  1511. u64 tmp;
  1512. /* Parent rate is a fixed phy link rate */
  1513. rational_best_approximation(req->best_parent_rate, req->rate,
  1514. GENMASK(rcg->mnd_width - 1, 0),
  1515. GENMASK(rcg->mnd_width - 1, 0), &den, &num);
  1516. if (!num || !den)
  1517. return -EINVAL;
  1518. tmp = req->best_parent_rate * num;
  1519. do_div(tmp, den);
  1520. req->rate = tmp;
  1521. return 0;
  1522. }
  1523. const struct clk_ops clk_dp_ops = {
  1524. .is_enabled = clk_rcg2_is_enabled,
  1525. .get_parent = clk_rcg2_get_parent,
  1526. .set_parent = clk_rcg2_set_parent,
  1527. .recalc_rate = clk_rcg2_recalc_rate,
  1528. .set_rate = clk_rcg2_dp_set_rate,
  1529. .set_rate_and_parent = clk_rcg2_dp_set_rate_and_parent,
  1530. .determine_rate = clk_rcg2_dp_determine_rate,
  1531. };
  1532. EXPORT_SYMBOL_GPL(clk_dp_ops);