brcmstb-avs-cpufreq.c 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786
  1. /*
  2. * CPU frequency scaling for Broadcom SoCs with AVS firmware that
  3. * supports DVS or DVFS
  4. *
  5. * Copyright (c) 2016 Broadcom
  6. *
  7. * This program is free software; you can redistribute it and/or
  8. * modify it under the terms of the GNU General Public License as
  9. * published by the Free Software Foundation version 2.
  10. *
  11. * This program is distributed "as is" WITHOUT ANY WARRANTY of any
  12. * kind, whether express or implied; without even the implied warranty
  13. * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. * GNU General Public License for more details.
  15. */
  16. /*
  17. * "AVS" is the name of a firmware developed at Broadcom. It derives
  18. * its name from the technique called "Adaptive Voltage Scaling".
  19. * Adaptive voltage scaling was the original purpose of this firmware.
  20. * The AVS firmware still supports "AVS mode", where all it does is
  21. * adaptive voltage scaling. However, on some newer Broadcom SoCs, the
  22. * AVS Firmware, despite its unchanged name, also supports DFS mode and
  23. * DVFS mode.
  24. *
  25. * In the context of this document and the related driver, "AVS" by
  26. * itself always means the Broadcom firmware and never refers to the
  27. * technique called "Adaptive Voltage Scaling".
  28. *
  29. * The Broadcom STB AVS CPUfreq driver provides voltage and frequency
  30. * scaling on Broadcom SoCs using AVS firmware with support for DFS and
  31. * DVFS. The AVS firmware is running on its own co-processor. The
  32. * driver supports both uniprocessor (UP) and symmetric multiprocessor
  33. * (SMP) systems which share clock and voltage across all CPUs.
  34. *
  35. * Actual voltage and frequency scaling is done solely by the AVS
  36. * firmware. This driver does not change frequency or voltage itself.
  37. * It provides a standard CPUfreq interface to the rest of the kernel
  38. * and to userland. It interfaces with the AVS firmware to effect the
  39. * requested changes and to report back the current system status in a
  40. * way that is expected by existing tools.
  41. */
  42. #include <linux/cpufreq.h>
  43. #include <linux/delay.h>
  44. #include <linux/interrupt.h>
  45. #include <linux/io.h>
  46. #include <linux/module.h>
  47. #include <linux/of_address.h>
  48. #include <linux/platform_device.h>
  49. #include <linux/semaphore.h>
  50. /* Max number of arguments AVS calls take */
  51. #define AVS_MAX_CMD_ARGS 4
  52. /*
  53. * This macro is used to generate AVS parameter register offsets. For
  54. * x >= AVS_MAX_CMD_ARGS, it returns 0 to protect against accidental memory
  55. * access outside of the parameter range. (Offset 0 is the first parameter.)
  56. */
  57. #define AVS_PARAM_MULT(x) ((x) < AVS_MAX_CMD_ARGS ? (x) : 0)
  58. /* AVS Mailbox Register offsets */
  59. #define AVS_MBOX_COMMAND 0x00
  60. #define AVS_MBOX_STATUS 0x04
  61. #define AVS_MBOX_VOLTAGE0 0x08
  62. #define AVS_MBOX_TEMP0 0x0c
  63. #define AVS_MBOX_PV0 0x10
  64. #define AVS_MBOX_MV0 0x14
  65. #define AVS_MBOX_PARAM(x) (0x18 + AVS_PARAM_MULT(x) * sizeof(u32))
  66. #define AVS_MBOX_REVISION 0x28
  67. #define AVS_MBOX_PSTATE 0x2c
  68. #define AVS_MBOX_HEARTBEAT 0x30
  69. #define AVS_MBOX_MAGIC 0x34
  70. #define AVS_MBOX_SIGMA_HVT 0x38
  71. #define AVS_MBOX_SIGMA_SVT 0x3c
  72. #define AVS_MBOX_VOLTAGE1 0x40
  73. #define AVS_MBOX_TEMP1 0x44
  74. #define AVS_MBOX_PV1 0x48
  75. #define AVS_MBOX_MV1 0x4c
  76. #define AVS_MBOX_FREQUENCY 0x50
  77. /* AVS Commands */
  78. #define AVS_CMD_AVAILABLE 0x00
  79. #define AVS_CMD_DISABLE 0x10
  80. #define AVS_CMD_ENABLE 0x11
  81. #define AVS_CMD_S2_ENTER 0x12
  82. #define AVS_CMD_S2_EXIT 0x13
  83. #define AVS_CMD_BBM_ENTER 0x14
  84. #define AVS_CMD_BBM_EXIT 0x15
  85. #define AVS_CMD_S3_ENTER 0x16
  86. #define AVS_CMD_S3_EXIT 0x17
  87. #define AVS_CMD_BALANCE 0x18
  88. /* PMAP and P-STATE commands */
  89. #define AVS_CMD_GET_PMAP 0x30
  90. #define AVS_CMD_SET_PMAP 0x31
  91. #define AVS_CMD_GET_PSTATE 0x40
  92. #define AVS_CMD_SET_PSTATE 0x41
  93. /* Different modes AVS supports (for GET_PMAP/SET_PMAP) */
  94. #define AVS_MODE_AVS 0x0
  95. #define AVS_MODE_DFS 0x1
  96. #define AVS_MODE_DVS 0x2
  97. #define AVS_MODE_DVFS 0x3
  98. /*
  99. * PMAP parameter p1
  100. * unused:31-24, mdiv_p0:23-16, unused:15-14, pdiv:13-10 , ndiv_int:9-0
  101. */
  102. #define NDIV_INT_SHIFT 0
  103. #define NDIV_INT_MASK 0x3ff
  104. #define PDIV_SHIFT 10
  105. #define PDIV_MASK 0xf
  106. #define MDIV_P0_SHIFT 16
  107. #define MDIV_P0_MASK 0xff
  108. /*
  109. * PMAP parameter p2
  110. * mdiv_p4:31-24, mdiv_p3:23-16, mdiv_p2:15:8, mdiv_p1:7:0
  111. */
  112. #define MDIV_P1_SHIFT 0
  113. #define MDIV_P1_MASK 0xff
  114. #define MDIV_P2_SHIFT 8
  115. #define MDIV_P2_MASK 0xff
  116. #define MDIV_P3_SHIFT 16
  117. #define MDIV_P3_MASK 0xff
  118. #define MDIV_P4_SHIFT 24
  119. #define MDIV_P4_MASK 0xff
  120. /* Different P-STATES AVS supports (for GET_PSTATE/SET_PSTATE) */
  121. #define AVS_PSTATE_P0 0x0
  122. #define AVS_PSTATE_P1 0x1
  123. #define AVS_PSTATE_P2 0x2
  124. #define AVS_PSTATE_P3 0x3
  125. #define AVS_PSTATE_P4 0x4
  126. #define AVS_PSTATE_MAX AVS_PSTATE_P4
  127. /* CPU L2 Interrupt Controller Registers */
  128. #define AVS_CPU_L2_SET0 0x04
  129. #define AVS_CPU_L2_INT_MASK BIT(31)
  130. /* AVS Command Status Values */
  131. #define AVS_STATUS_CLEAR 0x00
  132. /* Command/notification accepted */
  133. #define AVS_STATUS_SUCCESS 0xf0
  134. /* Command/notification rejected */
  135. #define AVS_STATUS_FAILURE 0xff
  136. /* Invalid command/notification (unknown) */
  137. #define AVS_STATUS_INVALID 0xf1
  138. /* Non-AVS modes are not supported */
  139. #define AVS_STATUS_NO_SUPP 0xf2
  140. /* Cannot set P-State until P-Map supplied */
  141. #define AVS_STATUS_NO_MAP 0xf3
  142. /* Cannot change P-Map after initial P-Map set */
  143. #define AVS_STATUS_MAP_SET 0xf4
  144. /* Max AVS status; higher numbers are used for debugging */
  145. #define AVS_STATUS_MAX 0xff
  146. /* Other AVS related constants */
  147. #define AVS_LOOP_LIMIT 10000
  148. #define AVS_TIMEOUT 300 /* in ms; expected completion is < 10ms */
  149. #define AVS_FIRMWARE_MAGIC 0xa11600d1
  150. #define BRCM_AVS_CPUFREQ_PREFIX "brcmstb-avs"
  151. #define BRCM_AVS_CPUFREQ_NAME BRCM_AVS_CPUFREQ_PREFIX "-cpufreq"
  152. #define BRCM_AVS_CPU_DATA "brcm,avs-cpu-data-mem"
  153. #define BRCM_AVS_CPU_INTR "brcm,avs-cpu-l2-intr"
  154. #define BRCM_AVS_HOST_INTR "sw_intr"
  155. struct pmap {
  156. unsigned int mode;
  157. unsigned int p1;
  158. unsigned int p2;
  159. unsigned int state;
  160. };
  161. struct private_data {
  162. void __iomem *base;
  163. void __iomem *avs_intr_base;
  164. struct device *dev;
  165. struct completion done;
  166. struct semaphore sem;
  167. struct pmap pmap;
  168. int host_irq;
  169. };
  170. static void __iomem *__map_region(const char *name)
  171. {
  172. struct device_node *np;
  173. void __iomem *ptr;
  174. np = of_find_compatible_node(NULL, NULL, name);
  175. if (!np)
  176. return NULL;
  177. ptr = of_iomap(np, 0);
  178. of_node_put(np);
  179. return ptr;
  180. }
  181. static unsigned long wait_for_avs_command(struct private_data *priv,
  182. unsigned long timeout)
  183. {
  184. unsigned long time_left = 0;
  185. u32 val;
  186. /* Event driven, wait for the command interrupt */
  187. if (priv->host_irq >= 0)
  188. return wait_for_completion_timeout(&priv->done,
  189. msecs_to_jiffies(timeout));
  190. /* Polling for command completion */
  191. do {
  192. time_left = timeout;
  193. val = readl(priv->base + AVS_MBOX_STATUS);
  194. if (val)
  195. break;
  196. usleep_range(1000, 2000);
  197. } while (--timeout);
  198. return time_left;
  199. }
  200. static int __issue_avs_command(struct private_data *priv, unsigned int cmd,
  201. unsigned int num_in, unsigned int num_out,
  202. u32 args[])
  203. {
  204. void __iomem *base = priv->base;
  205. unsigned long time_left;
  206. unsigned int i;
  207. int ret;
  208. u32 val;
  209. ret = down_interruptible(&priv->sem);
  210. if (ret)
  211. return ret;
  212. /*
  213. * Make sure no other command is currently running: cmd is 0 if AVS
  214. * co-processor is idle. Due to the guard above, we should almost never
  215. * have to wait here.
  216. */
  217. for (i = 0, val = 1; val != 0 && i < AVS_LOOP_LIMIT; i++)
  218. val = readl(base + AVS_MBOX_COMMAND);
  219. /* Give the caller a chance to retry if AVS is busy. */
  220. if (i == AVS_LOOP_LIMIT) {
  221. ret = -EAGAIN;
  222. goto out;
  223. }
  224. /* Clear status before we begin. */
  225. writel(AVS_STATUS_CLEAR, base + AVS_MBOX_STATUS);
  226. /* Provide input parameters */
  227. for (i = 0; i < num_in; i++)
  228. writel(args[i], base + AVS_MBOX_PARAM(i));
  229. /* Protect from spurious interrupts. */
  230. reinit_completion(&priv->done);
  231. /* Now issue the command & tell firmware to wake up to process it. */
  232. writel(cmd, base + AVS_MBOX_COMMAND);
  233. writel(AVS_CPU_L2_INT_MASK, priv->avs_intr_base + AVS_CPU_L2_SET0);
  234. /* Wait for AVS co-processor to finish processing the command. */
  235. time_left = wait_for_avs_command(priv, AVS_TIMEOUT);
  236. /*
  237. * If the AVS status is not in the expected range, it means AVS didn't
  238. * complete our command in time, and we return an error. Also, if there
  239. * is no "time left", we timed out waiting for the interrupt.
  240. */
  241. val = readl(base + AVS_MBOX_STATUS);
  242. if (time_left == 0 || val == 0 || val > AVS_STATUS_MAX) {
  243. dev_err(priv->dev, "AVS command %#x didn't complete in time\n",
  244. cmd);
  245. dev_err(priv->dev, " Time left: %u ms, AVS status: %#x\n",
  246. jiffies_to_msecs(time_left), val);
  247. ret = -ETIMEDOUT;
  248. goto out;
  249. }
  250. /* Process returned values */
  251. for (i = 0; i < num_out; i++)
  252. args[i] = readl(base + AVS_MBOX_PARAM(i));
  253. /* Clear status to tell AVS co-processor we are done. */
  254. writel(AVS_STATUS_CLEAR, base + AVS_MBOX_STATUS);
  255. /* Convert firmware errors to errno's as much as possible. */
  256. switch (val) {
  257. case AVS_STATUS_INVALID:
  258. ret = -EINVAL;
  259. break;
  260. case AVS_STATUS_NO_SUPP:
  261. ret = -ENOTSUPP;
  262. break;
  263. case AVS_STATUS_NO_MAP:
  264. ret = -ENOENT;
  265. break;
  266. case AVS_STATUS_MAP_SET:
  267. ret = -EEXIST;
  268. break;
  269. case AVS_STATUS_FAILURE:
  270. ret = -EIO;
  271. break;
  272. }
  273. out:
  274. up(&priv->sem);
  275. return ret;
  276. }
  277. static irqreturn_t irq_handler(int irq, void *data)
  278. {
  279. struct private_data *priv = data;
  280. /* AVS command completed execution. Wake up __issue_avs_command(). */
  281. complete(&priv->done);
  282. return IRQ_HANDLED;
  283. }
  284. static char *brcm_avs_mode_to_string(unsigned int mode)
  285. {
  286. switch (mode) {
  287. case AVS_MODE_AVS:
  288. return "AVS";
  289. case AVS_MODE_DFS:
  290. return "DFS";
  291. case AVS_MODE_DVS:
  292. return "DVS";
  293. case AVS_MODE_DVFS:
  294. return "DVFS";
  295. }
  296. return NULL;
  297. }
  298. static void brcm_avs_parse_p1(u32 p1, unsigned int *mdiv_p0, unsigned int *pdiv,
  299. unsigned int *ndiv)
  300. {
  301. *mdiv_p0 = (p1 >> MDIV_P0_SHIFT) & MDIV_P0_MASK;
  302. *pdiv = (p1 >> PDIV_SHIFT) & PDIV_MASK;
  303. *ndiv = (p1 >> NDIV_INT_SHIFT) & NDIV_INT_MASK;
  304. }
  305. static void brcm_avs_parse_p2(u32 p2, unsigned int *mdiv_p1,
  306. unsigned int *mdiv_p2, unsigned int *mdiv_p3,
  307. unsigned int *mdiv_p4)
  308. {
  309. *mdiv_p4 = (p2 >> MDIV_P4_SHIFT) & MDIV_P4_MASK;
  310. *mdiv_p3 = (p2 >> MDIV_P3_SHIFT) & MDIV_P3_MASK;
  311. *mdiv_p2 = (p2 >> MDIV_P2_SHIFT) & MDIV_P2_MASK;
  312. *mdiv_p1 = (p2 >> MDIV_P1_SHIFT) & MDIV_P1_MASK;
  313. }
  314. static int brcm_avs_get_pmap(struct private_data *priv, struct pmap *pmap)
  315. {
  316. u32 args[AVS_MAX_CMD_ARGS];
  317. int ret;
  318. ret = __issue_avs_command(priv, AVS_CMD_GET_PMAP, 0, 4, args);
  319. if (ret || !pmap)
  320. return ret;
  321. pmap->mode = args[0];
  322. pmap->p1 = args[1];
  323. pmap->p2 = args[2];
  324. pmap->state = args[3];
  325. return 0;
  326. }
  327. static int brcm_avs_set_pmap(struct private_data *priv, struct pmap *pmap)
  328. {
  329. u32 args[AVS_MAX_CMD_ARGS];
  330. args[0] = pmap->mode;
  331. args[1] = pmap->p1;
  332. args[2] = pmap->p2;
  333. args[3] = pmap->state;
  334. return __issue_avs_command(priv, AVS_CMD_SET_PMAP, 4, 0, args);
  335. }
  336. static int brcm_avs_get_pstate(struct private_data *priv, unsigned int *pstate)
  337. {
  338. u32 args[AVS_MAX_CMD_ARGS];
  339. int ret;
  340. ret = __issue_avs_command(priv, AVS_CMD_GET_PSTATE, 0, 1, args);
  341. if (ret)
  342. return ret;
  343. *pstate = args[0];
  344. return 0;
  345. }
  346. static int brcm_avs_set_pstate(struct private_data *priv, unsigned int pstate)
  347. {
  348. u32 args[AVS_MAX_CMD_ARGS];
  349. args[0] = pstate;
  350. return __issue_avs_command(priv, AVS_CMD_SET_PSTATE, 1, 0, args);
  351. }
  352. static u32 brcm_avs_get_voltage(void __iomem *base)
  353. {
  354. return readl(base + AVS_MBOX_VOLTAGE1);
  355. }
  356. static u32 brcm_avs_get_frequency(void __iomem *base)
  357. {
  358. return readl(base + AVS_MBOX_FREQUENCY) * 1000; /* in kHz */
  359. }
  360. /*
  361. * We determine which frequencies are supported by cycling through all P-states
  362. * and reading back what frequency we are running at for each P-state.
  363. */
  364. static struct cpufreq_frequency_table *
  365. brcm_avs_get_freq_table(struct device *dev, struct private_data *priv)
  366. {
  367. struct cpufreq_frequency_table *table;
  368. unsigned int pstate;
  369. int i, ret;
  370. /* Remember P-state for later */
  371. ret = brcm_avs_get_pstate(priv, &pstate);
  372. if (ret)
  373. return ERR_PTR(ret);
  374. /*
  375. * We allocate space for the 5 different P-STATES AVS,
  376. * plus extra space for a terminating element.
  377. */
  378. table = devm_kcalloc(dev, AVS_PSTATE_MAX + 1 + 1, sizeof(*table),
  379. GFP_KERNEL);
  380. if (!table)
  381. return ERR_PTR(-ENOMEM);
  382. for (i = AVS_PSTATE_P0; i <= AVS_PSTATE_MAX; i++) {
  383. ret = brcm_avs_set_pstate(priv, i);
  384. if (ret)
  385. return ERR_PTR(ret);
  386. table[i].frequency = brcm_avs_get_frequency(priv->base);
  387. table[i].driver_data = i;
  388. }
  389. table[i].frequency = CPUFREQ_TABLE_END;
  390. /* Restore P-state */
  391. ret = brcm_avs_set_pstate(priv, pstate);
  392. if (ret)
  393. return ERR_PTR(ret);
  394. return table;
  395. }
  396. /*
  397. * To ensure the right firmware is running we need to
  398. * - check the MAGIC matches what we expect
  399. * - brcm_avs_get_pmap() doesn't return -ENOTSUPP or -EINVAL
  400. * We need to set up our interrupt handling before calling brcm_avs_get_pmap()!
  401. */
  402. static bool brcm_avs_is_firmware_loaded(struct private_data *priv)
  403. {
  404. u32 magic;
  405. int rc;
  406. rc = brcm_avs_get_pmap(priv, NULL);
  407. magic = readl(priv->base + AVS_MBOX_MAGIC);
  408. return (magic == AVS_FIRMWARE_MAGIC) && ((rc != -ENOTSUPP) ||
  409. (rc != -EINVAL));
  410. }
  411. static unsigned int brcm_avs_cpufreq_get(unsigned int cpu)
  412. {
  413. struct cpufreq_policy *policy = cpufreq_cpu_get(cpu);
  414. struct private_data *priv = policy->driver_data;
  415. cpufreq_cpu_put(policy);
  416. return brcm_avs_get_frequency(priv->base);
  417. }
  418. static int brcm_avs_target_index(struct cpufreq_policy *policy,
  419. unsigned int index)
  420. {
  421. return brcm_avs_set_pstate(policy->driver_data,
  422. policy->freq_table[index].driver_data);
  423. }
  424. static int brcm_avs_suspend(struct cpufreq_policy *policy)
  425. {
  426. struct private_data *priv = policy->driver_data;
  427. int ret;
  428. ret = brcm_avs_get_pmap(priv, &priv->pmap);
  429. if (ret)
  430. return ret;
  431. /*
  432. * We can't use the P-state returned by brcm_avs_get_pmap(), since
  433. * that's the initial P-state from when the P-map was downloaded to the
  434. * AVS co-processor, not necessarily the P-state we are running at now.
  435. * So, we get the current P-state explicitly.
  436. */
  437. ret = brcm_avs_get_pstate(priv, &priv->pmap.state);
  438. if (ret)
  439. return ret;
  440. /* This is best effort. Nothing to do if it fails. */
  441. (void)__issue_avs_command(priv, AVS_CMD_S2_ENTER, 0, 0, NULL);
  442. return 0;
  443. }
  444. static int brcm_avs_resume(struct cpufreq_policy *policy)
  445. {
  446. struct private_data *priv = policy->driver_data;
  447. int ret;
  448. /* This is best effort. Nothing to do if it fails. */
  449. (void)__issue_avs_command(priv, AVS_CMD_S2_EXIT, 0, 0, NULL);
  450. ret = brcm_avs_set_pmap(priv, &priv->pmap);
  451. if (ret == -EEXIST) {
  452. struct platform_device *pdev = cpufreq_get_driver_data();
  453. struct device *dev = &pdev->dev;
  454. dev_warn(dev, "PMAP was already set\n");
  455. ret = 0;
  456. }
  457. return ret;
  458. }
  459. /*
  460. * All initialization code that we only want to execute once goes here. Setup
  461. * code that can be re-tried on every core (if it failed before) can go into
  462. * brcm_avs_cpufreq_init().
  463. */
  464. static int brcm_avs_prepare_init(struct platform_device *pdev)
  465. {
  466. struct private_data *priv;
  467. struct device *dev;
  468. int ret;
  469. dev = &pdev->dev;
  470. priv = devm_kzalloc(dev, sizeof(*priv), GFP_KERNEL);
  471. if (!priv)
  472. return -ENOMEM;
  473. priv->dev = dev;
  474. sema_init(&priv->sem, 1);
  475. init_completion(&priv->done);
  476. platform_set_drvdata(pdev, priv);
  477. priv->base = __map_region(BRCM_AVS_CPU_DATA);
  478. if (!priv->base) {
  479. dev_err(dev, "Couldn't find property %s in device tree.\n",
  480. BRCM_AVS_CPU_DATA);
  481. return -ENOENT;
  482. }
  483. priv->avs_intr_base = __map_region(BRCM_AVS_CPU_INTR);
  484. if (!priv->avs_intr_base) {
  485. dev_err(dev, "Couldn't find property %s in device tree.\n",
  486. BRCM_AVS_CPU_INTR);
  487. ret = -ENOENT;
  488. goto unmap_base;
  489. }
  490. priv->host_irq = platform_get_irq_byname(pdev, BRCM_AVS_HOST_INTR);
  491. ret = devm_request_irq(dev, priv->host_irq, irq_handler,
  492. IRQF_TRIGGER_RISING,
  493. BRCM_AVS_HOST_INTR, priv);
  494. if (ret && priv->host_irq >= 0) {
  495. dev_err(dev, "IRQ request failed: %s (%d) -- %d\n",
  496. BRCM_AVS_HOST_INTR, priv->host_irq, ret);
  497. goto unmap_intr_base;
  498. }
  499. if (brcm_avs_is_firmware_loaded(priv))
  500. return 0;
  501. dev_err(dev, "AVS firmware is not loaded or doesn't support DVFS\n");
  502. ret = -ENODEV;
  503. unmap_intr_base:
  504. iounmap(priv->avs_intr_base);
  505. unmap_base:
  506. iounmap(priv->base);
  507. return ret;
  508. }
  509. static void brcm_avs_prepare_uninit(struct platform_device *pdev)
  510. {
  511. struct private_data *priv;
  512. priv = platform_get_drvdata(pdev);
  513. iounmap(priv->avs_intr_base);
  514. iounmap(priv->base);
  515. }
  516. static int brcm_avs_cpufreq_init(struct cpufreq_policy *policy)
  517. {
  518. struct cpufreq_frequency_table *freq_table;
  519. struct platform_device *pdev;
  520. struct private_data *priv;
  521. struct device *dev;
  522. int ret;
  523. pdev = cpufreq_get_driver_data();
  524. priv = platform_get_drvdata(pdev);
  525. policy->driver_data = priv;
  526. dev = &pdev->dev;
  527. freq_table = brcm_avs_get_freq_table(dev, priv);
  528. if (IS_ERR(freq_table)) {
  529. ret = PTR_ERR(freq_table);
  530. dev_err(dev, "Couldn't determine frequency table (%d).\n", ret);
  531. return ret;
  532. }
  533. policy->freq_table = freq_table;
  534. /* All cores share the same clock and thus the same policy. */
  535. cpumask_setall(policy->cpus);
  536. ret = __issue_avs_command(priv, AVS_CMD_ENABLE, 0, 0, NULL);
  537. if (!ret) {
  538. unsigned int pstate;
  539. ret = brcm_avs_get_pstate(priv, &pstate);
  540. if (!ret) {
  541. policy->cur = freq_table[pstate].frequency;
  542. dev_info(dev, "registered\n");
  543. return 0;
  544. }
  545. }
  546. dev_err(dev, "couldn't initialize driver (%d)\n", ret);
  547. return ret;
  548. }
  549. static ssize_t show_brcm_avs_pstate(struct cpufreq_policy *policy, char *buf)
  550. {
  551. struct private_data *priv = policy->driver_data;
  552. unsigned int pstate;
  553. if (brcm_avs_get_pstate(priv, &pstate))
  554. return sprintf(buf, "<unknown>\n");
  555. return sprintf(buf, "%u\n", pstate);
  556. }
  557. static ssize_t show_brcm_avs_mode(struct cpufreq_policy *policy, char *buf)
  558. {
  559. struct private_data *priv = policy->driver_data;
  560. struct pmap pmap;
  561. if (brcm_avs_get_pmap(priv, &pmap))
  562. return sprintf(buf, "<unknown>\n");
  563. return sprintf(buf, "%s %u\n", brcm_avs_mode_to_string(pmap.mode),
  564. pmap.mode);
  565. }
  566. static ssize_t show_brcm_avs_pmap(struct cpufreq_policy *policy, char *buf)
  567. {
  568. unsigned int mdiv_p0, mdiv_p1, mdiv_p2, mdiv_p3, mdiv_p4;
  569. struct private_data *priv = policy->driver_data;
  570. unsigned int ndiv, pdiv;
  571. struct pmap pmap;
  572. if (brcm_avs_get_pmap(priv, &pmap))
  573. return sprintf(buf, "<unknown>\n");
  574. brcm_avs_parse_p1(pmap.p1, &mdiv_p0, &pdiv, &ndiv);
  575. brcm_avs_parse_p2(pmap.p2, &mdiv_p1, &mdiv_p2, &mdiv_p3, &mdiv_p4);
  576. return sprintf(buf, "0x%08x 0x%08x %u %u %u %u %u %u %u %u %u\n",
  577. pmap.p1, pmap.p2, ndiv, pdiv, mdiv_p0, mdiv_p1, mdiv_p2,
  578. mdiv_p3, mdiv_p4, pmap.mode, pmap.state);
  579. }
  580. static ssize_t show_brcm_avs_voltage(struct cpufreq_policy *policy, char *buf)
  581. {
  582. struct private_data *priv = policy->driver_data;
  583. return sprintf(buf, "0x%08x\n", brcm_avs_get_voltage(priv->base));
  584. }
  585. static ssize_t show_brcm_avs_frequency(struct cpufreq_policy *policy, char *buf)
  586. {
  587. struct private_data *priv = policy->driver_data;
  588. return sprintf(buf, "0x%08x\n", brcm_avs_get_frequency(priv->base));
  589. }
  590. cpufreq_freq_attr_ro(brcm_avs_pstate);
  591. cpufreq_freq_attr_ro(brcm_avs_mode);
  592. cpufreq_freq_attr_ro(brcm_avs_pmap);
  593. cpufreq_freq_attr_ro(brcm_avs_voltage);
  594. cpufreq_freq_attr_ro(brcm_avs_frequency);
  595. static struct freq_attr *brcm_avs_cpufreq_attr[] = {
  596. &cpufreq_freq_attr_scaling_available_freqs,
  597. &brcm_avs_pstate,
  598. &brcm_avs_mode,
  599. &brcm_avs_pmap,
  600. &brcm_avs_voltage,
  601. &brcm_avs_frequency,
  602. NULL
  603. };
  604. static struct cpufreq_driver brcm_avs_driver = {
  605. .flags = CPUFREQ_NEED_INITIAL_FREQ_CHECK,
  606. .verify = cpufreq_generic_frequency_table_verify,
  607. .target_index = brcm_avs_target_index,
  608. .get = brcm_avs_cpufreq_get,
  609. .suspend = brcm_avs_suspend,
  610. .resume = brcm_avs_resume,
  611. .init = brcm_avs_cpufreq_init,
  612. .attr = brcm_avs_cpufreq_attr,
  613. .name = BRCM_AVS_CPUFREQ_PREFIX,
  614. };
  615. static int brcm_avs_cpufreq_probe(struct platform_device *pdev)
  616. {
  617. int ret;
  618. ret = brcm_avs_prepare_init(pdev);
  619. if (ret)
  620. return ret;
  621. brcm_avs_driver.driver_data = pdev;
  622. ret = cpufreq_register_driver(&brcm_avs_driver);
  623. if (ret)
  624. brcm_avs_prepare_uninit(pdev);
  625. return ret;
  626. }
  627. static int brcm_avs_cpufreq_remove(struct platform_device *pdev)
  628. {
  629. int ret;
  630. ret = cpufreq_unregister_driver(&brcm_avs_driver);
  631. WARN_ON(ret);
  632. brcm_avs_prepare_uninit(pdev);
  633. return 0;
  634. }
  635. static const struct of_device_id brcm_avs_cpufreq_match[] = {
  636. { .compatible = BRCM_AVS_CPU_DATA },
  637. { }
  638. };
  639. MODULE_DEVICE_TABLE(of, brcm_avs_cpufreq_match);
  640. static struct platform_driver brcm_avs_cpufreq_platdrv = {
  641. .driver = {
  642. .name = BRCM_AVS_CPUFREQ_NAME,
  643. .of_match_table = brcm_avs_cpufreq_match,
  644. },
  645. .probe = brcm_avs_cpufreq_probe,
  646. .remove = brcm_avs_cpufreq_remove,
  647. };
  648. module_platform_driver(brcm_avs_cpufreq_platdrv);
  649. MODULE_AUTHOR("Markus Mayer <[email protected]>");
  650. MODULE_DESCRIPTION("CPUfreq driver for Broadcom STB AVS");
  651. MODULE_LICENSE("GPL");