msm_iommu.c 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810
  1. /* Copyright (c) 2010-2011, Code Aurora Forum. All rights reserved.
  2. *
  3. * This program is free software; you can redistribute it and/or modify
  4. * it under the terms of the GNU General Public License version 2 and
  5. * only version 2 as published by the Free Software Foundation.
  6. *
  7. * This program is distributed in the hope that it will be useful,
  8. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10. * GNU General Public License for more details.
  11. *
  12. * You should have received a copy of the GNU General Public License
  13. * along with this program; if not, write to the Free Software
  14. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
  15. * 02110-1301, USA.
  16. */
  17. #define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
  18. #include <linux/kernel.h>
  19. #include <linux/module.h>
  20. #include <linux/platform_device.h>
  21. #include <linux/errno.h>
  22. #include <linux/io.h>
  23. #include <linux/interrupt.h>
  24. #include <linux/list.h>
  25. #include <linux/spinlock.h>
  26. #include <linux/slab.h>
  27. #include <linux/iommu.h>
  28. #include <linux/clk.h>
  29. #include <linux/err.h>
  30. #include <linux/of_iommu.h>
  31. #include <asm/cacheflush.h>
  32. #include <asm/sizes.h>
  33. #include "msm_iommu_hw-8xxx.h"
  34. #include "msm_iommu.h"
  35. #include "io-pgtable.h"
  36. #define MRC(reg, processor, op1, crn, crm, op2) \
  37. __asm__ __volatile__ ( \
  38. " mrc " #processor "," #op1 ", %0," #crn "," #crm "," #op2 "\n" \
  39. : "=r" (reg))
  40. /* bitmap of the page sizes currently supported */
  41. #define MSM_IOMMU_PGSIZES (SZ_4K | SZ_64K | SZ_1M | SZ_16M)
  42. DEFINE_SPINLOCK(msm_iommu_lock);
  43. static LIST_HEAD(qcom_iommu_devices);
  44. static struct iommu_ops msm_iommu_ops;
  45. struct msm_priv {
  46. struct list_head list_attached;
  47. struct iommu_domain domain;
  48. struct io_pgtable_cfg cfg;
  49. struct io_pgtable_ops *iop;
  50. struct device *dev;
  51. spinlock_t pgtlock; /* pagetable lock */
  52. };
  53. static struct msm_priv *to_msm_priv(struct iommu_domain *dom)
  54. {
  55. return container_of(dom, struct msm_priv, domain);
  56. }
  57. static int __enable_clocks(struct msm_iommu_dev *iommu)
  58. {
  59. int ret;
  60. ret = clk_enable(iommu->pclk);
  61. if (ret)
  62. goto fail;
  63. if (iommu->clk) {
  64. ret = clk_enable(iommu->clk);
  65. if (ret)
  66. clk_disable(iommu->pclk);
  67. }
  68. fail:
  69. return ret;
  70. }
  71. static void __disable_clocks(struct msm_iommu_dev *iommu)
  72. {
  73. if (iommu->clk)
  74. clk_disable(iommu->clk);
  75. clk_disable(iommu->pclk);
  76. }
  77. static void msm_iommu_reset(void __iomem *base, int ncb)
  78. {
  79. int ctx;
  80. SET_RPUE(base, 0);
  81. SET_RPUEIE(base, 0);
  82. SET_ESRRESTORE(base, 0);
  83. SET_TBE(base, 0);
  84. SET_CR(base, 0);
  85. SET_SPDMBE(base, 0);
  86. SET_TESTBUSCR(base, 0);
  87. SET_TLBRSW(base, 0);
  88. SET_GLOBAL_TLBIALL(base, 0);
  89. SET_RPU_ACR(base, 0);
  90. SET_TLBLKCRWE(base, 1);
  91. for (ctx = 0; ctx < ncb; ctx++) {
  92. SET_BPRCOSH(base, ctx, 0);
  93. SET_BPRCISH(base, ctx, 0);
  94. SET_BPRCNSH(base, ctx, 0);
  95. SET_BPSHCFG(base, ctx, 0);
  96. SET_BPMTCFG(base, ctx, 0);
  97. SET_ACTLR(base, ctx, 0);
  98. SET_SCTLR(base, ctx, 0);
  99. SET_FSRRESTORE(base, ctx, 0);
  100. SET_TTBR0(base, ctx, 0);
  101. SET_TTBR1(base, ctx, 0);
  102. SET_TTBCR(base, ctx, 0);
  103. SET_BFBCR(base, ctx, 0);
  104. SET_PAR(base, ctx, 0);
  105. SET_FAR(base, ctx, 0);
  106. SET_CTX_TLBIALL(base, ctx, 0);
  107. SET_TLBFLPTER(base, ctx, 0);
  108. SET_TLBSLPTER(base, ctx, 0);
  109. SET_TLBLKCR(base, ctx, 0);
  110. SET_CONTEXTIDR(base, ctx, 0);
  111. }
  112. }
  113. static void __flush_iotlb(void *cookie)
  114. {
  115. struct msm_priv *priv = cookie;
  116. struct msm_iommu_dev *iommu = NULL;
  117. struct msm_iommu_ctx_dev *master;
  118. int ret = 0;
  119. list_for_each_entry(iommu, &priv->list_attached, dom_node) {
  120. ret = __enable_clocks(iommu);
  121. if (ret)
  122. goto fail;
  123. list_for_each_entry(master, &iommu->ctx_list, list)
  124. SET_CTX_TLBIALL(iommu->base, master->num, 0);
  125. __disable_clocks(iommu);
  126. }
  127. fail:
  128. return;
  129. }
  130. static void __flush_iotlb_range(unsigned long iova, size_t size,
  131. size_t granule, bool leaf, void *cookie)
  132. {
  133. struct msm_priv *priv = cookie;
  134. struct msm_iommu_dev *iommu = NULL;
  135. struct msm_iommu_ctx_dev *master;
  136. int ret = 0;
  137. int temp_size;
  138. list_for_each_entry(iommu, &priv->list_attached, dom_node) {
  139. ret = __enable_clocks(iommu);
  140. if (ret)
  141. goto fail;
  142. list_for_each_entry(master, &iommu->ctx_list, list) {
  143. temp_size = size;
  144. do {
  145. iova &= TLBIVA_VA;
  146. iova |= GET_CONTEXTIDR_ASID(iommu->base,
  147. master->num);
  148. SET_TLBIVA(iommu->base, master->num, iova);
  149. iova += granule;
  150. } while (temp_size -= granule);
  151. }
  152. __disable_clocks(iommu);
  153. }
  154. fail:
  155. return;
  156. }
  157. static void __flush_iotlb_sync(void *cookie)
  158. {
  159. /*
  160. * Nothing is needed here, the barrier to guarantee
  161. * completion of the tlb sync operation is implicitly
  162. * taken care when the iommu client does a writel before
  163. * kick starting the other master.
  164. */
  165. }
  166. static const struct iommu_gather_ops msm_iommu_gather_ops = {
  167. .tlb_flush_all = __flush_iotlb,
  168. .tlb_add_flush = __flush_iotlb_range,
  169. .tlb_sync = __flush_iotlb_sync,
  170. };
  171. static int msm_iommu_alloc_ctx(unsigned long *map, int start, int end)
  172. {
  173. int idx;
  174. do {
  175. idx = find_next_zero_bit(map, end, start);
  176. if (idx == end)
  177. return -ENOSPC;
  178. } while (test_and_set_bit(idx, map));
  179. return idx;
  180. }
  181. static void msm_iommu_free_ctx(unsigned long *map, int idx)
  182. {
  183. clear_bit(idx, map);
  184. }
  185. static void config_mids(struct msm_iommu_dev *iommu,
  186. struct msm_iommu_ctx_dev *master)
  187. {
  188. int mid, ctx, i;
  189. for (i = 0; i < master->num_mids; i++) {
  190. mid = master->mids[i];
  191. ctx = master->num;
  192. SET_M2VCBR_N(iommu->base, mid, 0);
  193. SET_CBACR_N(iommu->base, ctx, 0);
  194. /* Set VMID = 0 */
  195. SET_VMID(iommu->base, mid, 0);
  196. /* Set the context number for that MID to this context */
  197. SET_CBNDX(iommu->base, mid, ctx);
  198. /* Set MID associated with this context bank to 0*/
  199. SET_CBVMID(iommu->base, ctx, 0);
  200. /* Set the ASID for TLB tagging for this context */
  201. SET_CONTEXTIDR_ASID(iommu->base, ctx, ctx);
  202. /* Set security bit override to be Non-secure */
  203. SET_NSCFG(iommu->base, mid, 3);
  204. }
  205. }
  206. static void __reset_context(void __iomem *base, int ctx)
  207. {
  208. SET_BPRCOSH(base, ctx, 0);
  209. SET_BPRCISH(base, ctx, 0);
  210. SET_BPRCNSH(base, ctx, 0);
  211. SET_BPSHCFG(base, ctx, 0);
  212. SET_BPMTCFG(base, ctx, 0);
  213. SET_ACTLR(base, ctx, 0);
  214. SET_SCTLR(base, ctx, 0);
  215. SET_FSRRESTORE(base, ctx, 0);
  216. SET_TTBR0(base, ctx, 0);
  217. SET_TTBR1(base, ctx, 0);
  218. SET_TTBCR(base, ctx, 0);
  219. SET_BFBCR(base, ctx, 0);
  220. SET_PAR(base, ctx, 0);
  221. SET_FAR(base, ctx, 0);
  222. SET_CTX_TLBIALL(base, ctx, 0);
  223. SET_TLBFLPTER(base, ctx, 0);
  224. SET_TLBSLPTER(base, ctx, 0);
  225. SET_TLBLKCR(base, ctx, 0);
  226. }
  227. static void __program_context(void __iomem *base, int ctx,
  228. struct msm_priv *priv)
  229. {
  230. __reset_context(base, ctx);
  231. /* Turn on TEX Remap */
  232. SET_TRE(base, ctx, 1);
  233. SET_AFE(base, ctx, 1);
  234. /* Set up HTW mode */
  235. /* TLB miss configuration: perform HTW on miss */
  236. SET_TLBMCFG(base, ctx, 0x3);
  237. /* V2P configuration: HTW for access */
  238. SET_V2PCFG(base, ctx, 0x3);
  239. SET_TTBCR(base, ctx, priv->cfg.arm_v7s_cfg.tcr);
  240. SET_TTBR0(base, ctx, priv->cfg.arm_v7s_cfg.ttbr[0]);
  241. SET_TTBR1(base, ctx, priv->cfg.arm_v7s_cfg.ttbr[1]);
  242. /* Set prrr and nmrr */
  243. SET_PRRR(base, ctx, priv->cfg.arm_v7s_cfg.prrr);
  244. SET_NMRR(base, ctx, priv->cfg.arm_v7s_cfg.nmrr);
  245. /* Invalidate the TLB for this context */
  246. SET_CTX_TLBIALL(base, ctx, 0);
  247. /* Set interrupt number to "secure" interrupt */
  248. SET_IRPTNDX(base, ctx, 0);
  249. /* Enable context fault interrupt */
  250. SET_CFEIE(base, ctx, 1);
  251. /* Stall access on a context fault and let the handler deal with it */
  252. SET_CFCFG(base, ctx, 1);
  253. /* Redirect all cacheable requests to L2 slave port. */
  254. SET_RCISH(base, ctx, 1);
  255. SET_RCOSH(base, ctx, 1);
  256. SET_RCNSH(base, ctx, 1);
  257. /* Turn on BFB prefetch */
  258. SET_BFBDFE(base, ctx, 1);
  259. /* Enable the MMU */
  260. SET_M(base, ctx, 1);
  261. }
  262. static struct iommu_domain *msm_iommu_domain_alloc(unsigned type)
  263. {
  264. struct msm_priv *priv;
  265. if (type != IOMMU_DOMAIN_UNMANAGED)
  266. return NULL;
  267. priv = kzalloc(sizeof(*priv), GFP_KERNEL);
  268. if (!priv)
  269. goto fail_nomem;
  270. INIT_LIST_HEAD(&priv->list_attached);
  271. priv->domain.geometry.aperture_start = 0;
  272. priv->domain.geometry.aperture_end = (1ULL << 32) - 1;
  273. priv->domain.geometry.force_aperture = true;
  274. return &priv->domain;
  275. fail_nomem:
  276. kfree(priv);
  277. return NULL;
  278. }
  279. static void msm_iommu_domain_free(struct iommu_domain *domain)
  280. {
  281. struct msm_priv *priv;
  282. unsigned long flags;
  283. spin_lock_irqsave(&msm_iommu_lock, flags);
  284. priv = to_msm_priv(domain);
  285. kfree(priv);
  286. spin_unlock_irqrestore(&msm_iommu_lock, flags);
  287. }
  288. static int msm_iommu_domain_config(struct msm_priv *priv)
  289. {
  290. spin_lock_init(&priv->pgtlock);
  291. priv->cfg = (struct io_pgtable_cfg) {
  292. .quirks = IO_PGTABLE_QUIRK_TLBI_ON_MAP,
  293. .pgsize_bitmap = msm_iommu_ops.pgsize_bitmap,
  294. .ias = 32,
  295. .oas = 32,
  296. .tlb = &msm_iommu_gather_ops,
  297. .iommu_dev = priv->dev,
  298. };
  299. priv->iop = alloc_io_pgtable_ops(ARM_V7S, &priv->cfg, priv);
  300. if (!priv->iop) {
  301. dev_err(priv->dev, "Failed to allocate pgtable\n");
  302. return -EINVAL;
  303. }
  304. msm_iommu_ops.pgsize_bitmap = priv->cfg.pgsize_bitmap;
  305. return 0;
  306. }
  307. static int msm_iommu_attach_dev(struct iommu_domain *domain, struct device *dev)
  308. {
  309. int ret = 0;
  310. unsigned long flags;
  311. struct msm_iommu_dev *iommu;
  312. struct msm_priv *priv = to_msm_priv(domain);
  313. struct msm_iommu_ctx_dev *master;
  314. priv->dev = dev;
  315. msm_iommu_domain_config(priv);
  316. spin_lock_irqsave(&msm_iommu_lock, flags);
  317. list_for_each_entry(iommu, &qcom_iommu_devices, dev_node) {
  318. master = list_first_entry(&iommu->ctx_list,
  319. struct msm_iommu_ctx_dev,
  320. list);
  321. if (master->of_node == dev->of_node) {
  322. ret = __enable_clocks(iommu);
  323. if (ret)
  324. goto fail;
  325. list_for_each_entry(master, &iommu->ctx_list, list) {
  326. if (master->num) {
  327. dev_err(dev, "domain already attached");
  328. ret = -EEXIST;
  329. goto fail;
  330. }
  331. master->num =
  332. msm_iommu_alloc_ctx(iommu->context_map,
  333. 0, iommu->ncb);
  334. if (IS_ERR_VALUE(master->num)) {
  335. ret = -ENODEV;
  336. goto fail;
  337. }
  338. config_mids(iommu, master);
  339. __program_context(iommu->base, master->num,
  340. priv);
  341. }
  342. __disable_clocks(iommu);
  343. list_add(&iommu->dom_node, &priv->list_attached);
  344. }
  345. }
  346. fail:
  347. spin_unlock_irqrestore(&msm_iommu_lock, flags);
  348. return ret;
  349. }
  350. static void msm_iommu_detach_dev(struct iommu_domain *domain,
  351. struct device *dev)
  352. {
  353. struct msm_priv *priv = to_msm_priv(domain);
  354. unsigned long flags;
  355. struct msm_iommu_dev *iommu;
  356. struct msm_iommu_ctx_dev *master;
  357. int ret;
  358. free_io_pgtable_ops(priv->iop);
  359. spin_lock_irqsave(&msm_iommu_lock, flags);
  360. list_for_each_entry(iommu, &priv->list_attached, dom_node) {
  361. ret = __enable_clocks(iommu);
  362. if (ret)
  363. goto fail;
  364. list_for_each_entry(master, &iommu->ctx_list, list) {
  365. msm_iommu_free_ctx(iommu->context_map, master->num);
  366. __reset_context(iommu->base, master->num);
  367. }
  368. __disable_clocks(iommu);
  369. }
  370. fail:
  371. spin_unlock_irqrestore(&msm_iommu_lock, flags);
  372. }
  373. static int msm_iommu_map(struct iommu_domain *domain, unsigned long iova,
  374. phys_addr_t pa, size_t len, int prot)
  375. {
  376. struct msm_priv *priv = to_msm_priv(domain);
  377. unsigned long flags;
  378. int ret;
  379. spin_lock_irqsave(&priv->pgtlock, flags);
  380. ret = priv->iop->map(priv->iop, iova, pa, len, prot);
  381. spin_unlock_irqrestore(&priv->pgtlock, flags);
  382. return ret;
  383. }
  384. static size_t msm_iommu_unmap(struct iommu_domain *domain, unsigned long iova,
  385. size_t len)
  386. {
  387. struct msm_priv *priv = to_msm_priv(domain);
  388. unsigned long flags;
  389. spin_lock_irqsave(&priv->pgtlock, flags);
  390. len = priv->iop->unmap(priv->iop, iova, len);
  391. spin_unlock_irqrestore(&priv->pgtlock, flags);
  392. return len;
  393. }
  394. static phys_addr_t msm_iommu_iova_to_phys(struct iommu_domain *domain,
  395. dma_addr_t va)
  396. {
  397. struct msm_priv *priv;
  398. struct msm_iommu_dev *iommu;
  399. struct msm_iommu_ctx_dev *master;
  400. unsigned int par;
  401. unsigned long flags;
  402. phys_addr_t ret = 0;
  403. spin_lock_irqsave(&msm_iommu_lock, flags);
  404. priv = to_msm_priv(domain);
  405. iommu = list_first_entry(&priv->list_attached,
  406. struct msm_iommu_dev, dom_node);
  407. if (list_empty(&iommu->ctx_list))
  408. goto fail;
  409. master = list_first_entry(&iommu->ctx_list,
  410. struct msm_iommu_ctx_dev, list);
  411. if (!master)
  412. goto fail;
  413. ret = __enable_clocks(iommu);
  414. if (ret)
  415. goto fail;
  416. /* Invalidate context TLB */
  417. SET_CTX_TLBIALL(iommu->base, master->num, 0);
  418. SET_V2PPR(iommu->base, master->num, va & V2Pxx_VA);
  419. par = GET_PAR(iommu->base, master->num);
  420. /* We are dealing with a supersection */
  421. if (GET_NOFAULT_SS(iommu->base, master->num))
  422. ret = (par & 0xFF000000) | (va & 0x00FFFFFF);
  423. else /* Upper 20 bits from PAR, lower 12 from VA */
  424. ret = (par & 0xFFFFF000) | (va & 0x00000FFF);
  425. if (GET_FAULT(iommu->base, master->num))
  426. ret = 0;
  427. __disable_clocks(iommu);
  428. fail:
  429. spin_unlock_irqrestore(&msm_iommu_lock, flags);
  430. return ret;
  431. }
  432. static bool msm_iommu_capable(enum iommu_cap cap)
  433. {
  434. return false;
  435. }
  436. static void print_ctx_regs(void __iomem *base, int ctx)
  437. {
  438. unsigned int fsr = GET_FSR(base, ctx);
  439. pr_err("FAR = %08x PAR = %08x\n",
  440. GET_FAR(base, ctx), GET_PAR(base, ctx));
  441. pr_err("FSR = %08x [%s%s%s%s%s%s%s%s%s%s]\n", fsr,
  442. (fsr & 0x02) ? "TF " : "",
  443. (fsr & 0x04) ? "AFF " : "",
  444. (fsr & 0x08) ? "APF " : "",
  445. (fsr & 0x10) ? "TLBMF " : "",
  446. (fsr & 0x20) ? "HTWDEEF " : "",
  447. (fsr & 0x40) ? "HTWSEEF " : "",
  448. (fsr & 0x80) ? "MHF " : "",
  449. (fsr & 0x10000) ? "SL " : "",
  450. (fsr & 0x40000000) ? "SS " : "",
  451. (fsr & 0x80000000) ? "MULTI " : "");
  452. pr_err("FSYNR0 = %08x FSYNR1 = %08x\n",
  453. GET_FSYNR0(base, ctx), GET_FSYNR1(base, ctx));
  454. pr_err("TTBR0 = %08x TTBR1 = %08x\n",
  455. GET_TTBR0(base, ctx), GET_TTBR1(base, ctx));
  456. pr_err("SCTLR = %08x ACTLR = %08x\n",
  457. GET_SCTLR(base, ctx), GET_ACTLR(base, ctx));
  458. }
  459. static void insert_iommu_master(struct device *dev,
  460. struct msm_iommu_dev **iommu,
  461. struct of_phandle_args *spec)
  462. {
  463. struct msm_iommu_ctx_dev *master = dev->archdata.iommu;
  464. int sid;
  465. if (list_empty(&(*iommu)->ctx_list)) {
  466. master = kzalloc(sizeof(*master), GFP_ATOMIC);
  467. master->of_node = dev->of_node;
  468. list_add(&master->list, &(*iommu)->ctx_list);
  469. dev->archdata.iommu = master;
  470. }
  471. for (sid = 0; sid < master->num_mids; sid++)
  472. if (master->mids[sid] == spec->args[0]) {
  473. dev_warn(dev, "Stream ID 0x%hx repeated; ignoring\n",
  474. sid);
  475. return;
  476. }
  477. master->mids[master->num_mids++] = spec->args[0];
  478. }
  479. static int qcom_iommu_of_xlate(struct device *dev,
  480. struct of_phandle_args *spec)
  481. {
  482. struct msm_iommu_dev *iommu;
  483. unsigned long flags;
  484. int ret = 0;
  485. spin_lock_irqsave(&msm_iommu_lock, flags);
  486. list_for_each_entry(iommu, &qcom_iommu_devices, dev_node)
  487. if (iommu->dev->of_node == spec->np)
  488. break;
  489. if (!iommu || iommu->dev->of_node != spec->np) {
  490. ret = -ENODEV;
  491. goto fail;
  492. }
  493. insert_iommu_master(dev, &iommu, spec);
  494. fail:
  495. spin_unlock_irqrestore(&msm_iommu_lock, flags);
  496. return ret;
  497. }
  498. irqreturn_t msm_iommu_fault_handler(int irq, void *dev_id)
  499. {
  500. struct msm_iommu_dev *iommu = dev_id;
  501. unsigned int fsr;
  502. int i, ret;
  503. spin_lock(&msm_iommu_lock);
  504. if (!iommu) {
  505. pr_err("Invalid device ID in context interrupt handler\n");
  506. goto fail;
  507. }
  508. pr_err("Unexpected IOMMU page fault!\n");
  509. pr_err("base = %08x\n", (unsigned int)iommu->base);
  510. ret = __enable_clocks(iommu);
  511. if (ret)
  512. goto fail;
  513. for (i = 0; i < iommu->ncb; i++) {
  514. fsr = GET_FSR(iommu->base, i);
  515. if (fsr) {
  516. pr_err("Fault occurred in context %d.\n", i);
  517. pr_err("Interesting registers:\n");
  518. print_ctx_regs(iommu->base, i);
  519. SET_FSR(iommu->base, i, 0x4000000F);
  520. }
  521. }
  522. __disable_clocks(iommu);
  523. fail:
  524. spin_unlock(&msm_iommu_lock);
  525. return 0;
  526. }
  527. static struct iommu_ops msm_iommu_ops = {
  528. .capable = msm_iommu_capable,
  529. .domain_alloc = msm_iommu_domain_alloc,
  530. .domain_free = msm_iommu_domain_free,
  531. .attach_dev = msm_iommu_attach_dev,
  532. .detach_dev = msm_iommu_detach_dev,
  533. .map = msm_iommu_map,
  534. .unmap = msm_iommu_unmap,
  535. .map_sg = default_iommu_map_sg,
  536. .iova_to_phys = msm_iommu_iova_to_phys,
  537. .pgsize_bitmap = MSM_IOMMU_PGSIZES,
  538. .of_xlate = qcom_iommu_of_xlate,
  539. };
  540. static int msm_iommu_probe(struct platform_device *pdev)
  541. {
  542. struct resource *r;
  543. struct msm_iommu_dev *iommu;
  544. int ret, par, val;
  545. iommu = devm_kzalloc(&pdev->dev, sizeof(*iommu), GFP_KERNEL);
  546. if (!iommu)
  547. return -ENODEV;
  548. iommu->dev = &pdev->dev;
  549. INIT_LIST_HEAD(&iommu->ctx_list);
  550. iommu->pclk = devm_clk_get(iommu->dev, "smmu_pclk");
  551. if (IS_ERR(iommu->pclk)) {
  552. dev_err(iommu->dev, "could not get smmu_pclk\n");
  553. return PTR_ERR(iommu->pclk);
  554. }
  555. ret = clk_prepare(iommu->pclk);
  556. if (ret) {
  557. dev_err(iommu->dev, "could not prepare smmu_pclk\n");
  558. return ret;
  559. }
  560. iommu->clk = devm_clk_get(iommu->dev, "iommu_clk");
  561. if (IS_ERR(iommu->clk)) {
  562. dev_err(iommu->dev, "could not get iommu_clk\n");
  563. clk_unprepare(iommu->pclk);
  564. return PTR_ERR(iommu->clk);
  565. }
  566. ret = clk_prepare(iommu->clk);
  567. if (ret) {
  568. dev_err(iommu->dev, "could not prepare iommu_clk\n");
  569. clk_unprepare(iommu->pclk);
  570. return ret;
  571. }
  572. r = platform_get_resource(pdev, IORESOURCE_MEM, 0);
  573. iommu->base = devm_ioremap_resource(iommu->dev, r);
  574. if (IS_ERR(iommu->base)) {
  575. dev_err(iommu->dev, "could not get iommu base\n");
  576. ret = PTR_ERR(iommu->base);
  577. goto fail;
  578. }
  579. iommu->irq = platform_get_irq(pdev, 0);
  580. if (iommu->irq < 0) {
  581. dev_err(iommu->dev, "could not get iommu irq\n");
  582. ret = -ENODEV;
  583. goto fail;
  584. }
  585. ret = of_property_read_u32(iommu->dev->of_node, "qcom,ncb", &val);
  586. if (ret) {
  587. dev_err(iommu->dev, "could not get ncb\n");
  588. goto fail;
  589. }
  590. iommu->ncb = val;
  591. msm_iommu_reset(iommu->base, iommu->ncb);
  592. SET_M(iommu->base, 0, 1);
  593. SET_PAR(iommu->base, 0, 0);
  594. SET_V2PCFG(iommu->base, 0, 1);
  595. SET_V2PPR(iommu->base, 0, 0);
  596. par = GET_PAR(iommu->base, 0);
  597. SET_V2PCFG(iommu->base, 0, 0);
  598. SET_M(iommu->base, 0, 0);
  599. if (!par) {
  600. pr_err("Invalid PAR value detected\n");
  601. ret = -ENODEV;
  602. goto fail;
  603. }
  604. ret = devm_request_threaded_irq(iommu->dev, iommu->irq, NULL,
  605. msm_iommu_fault_handler,
  606. IRQF_ONESHOT | IRQF_SHARED,
  607. "msm_iommu_secure_irpt_handler",
  608. iommu);
  609. if (ret) {
  610. pr_err("Request IRQ %d failed with ret=%d\n", iommu->irq, ret);
  611. goto fail;
  612. }
  613. list_add(&iommu->dev_node, &qcom_iommu_devices);
  614. of_iommu_set_ops(pdev->dev.of_node, &msm_iommu_ops);
  615. pr_info("device mapped at %p, irq %d with %d ctx banks\n",
  616. iommu->base, iommu->irq, iommu->ncb);
  617. return ret;
  618. fail:
  619. clk_unprepare(iommu->clk);
  620. clk_unprepare(iommu->pclk);
  621. return ret;
  622. }
  623. static const struct of_device_id msm_iommu_dt_match[] = {
  624. { .compatible = "qcom,apq8064-iommu" },
  625. {}
  626. };
  627. static int msm_iommu_remove(struct platform_device *pdev)
  628. {
  629. struct msm_iommu_dev *iommu = platform_get_drvdata(pdev);
  630. clk_unprepare(iommu->clk);
  631. clk_unprepare(iommu->pclk);
  632. return 0;
  633. }
  634. static struct platform_driver msm_iommu_driver = {
  635. .driver = {
  636. .name = "msm_iommu",
  637. .of_match_table = msm_iommu_dt_match,
  638. },
  639. .probe = msm_iommu_probe,
  640. .remove = msm_iommu_remove,
  641. };
  642. static int __init msm_iommu_driver_init(void)
  643. {
  644. int ret;
  645. ret = platform_driver_register(&msm_iommu_driver);
  646. if (ret != 0)
  647. pr_err("Failed to register IOMMU driver\n");
  648. return ret;
  649. }
  650. static void __exit msm_iommu_driver_exit(void)
  651. {
  652. platform_driver_unregister(&msm_iommu_driver);
  653. }
  654. subsys_initcall(msm_iommu_driver_init);
  655. module_exit(msm_iommu_driver_exit);
  656. static int __init msm_iommu_init(void)
  657. {
  658. bus_set_iommu(&platform_bus_type, &msm_iommu_ops);
  659. return 0;
  660. }
  661. static int __init msm_iommu_of_setup(struct device_node *np)
  662. {
  663. msm_iommu_init();
  664. return 0;
  665. }
  666. IOMMU_OF_DECLARE(msm_iommu_of, "qcom,apq8064-iommu", msm_iommu_of_setup);
  667. MODULE_LICENSE("GPL v2");
  668. MODULE_AUTHOR("Stepan Moskovchenko <stepanm@codeaurora.org>");