etnaviv_gem.c 22 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923
  1. /*
  2. * Copyright (C) 2015 Etnaviv Project
  3. *
  4. * This program is free software; you can redistribute it and/or modify it
  5. * under the terms of the GNU General Public License version 2 as published by
  6. * the Free Software Foundation.
  7. *
  8. * This program is distributed in the hope that it will be useful, but WITHOUT
  9. * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  10. * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
  11. * more details.
  12. *
  13. * You should have received a copy of the GNU General Public License along with
  14. * this program. If not, see <http://www.gnu.org/licenses/>.
  15. */
  16. #include <linux/spinlock.h>
  17. #include <linux/shmem_fs.h>
  18. #include "etnaviv_drv.h"
  19. #include "etnaviv_gem.h"
  20. #include "etnaviv_gpu.h"
  21. #include "etnaviv_mmu.h"
  22. static void etnaviv_gem_scatter_map(struct etnaviv_gem_object *etnaviv_obj)
  23. {
  24. struct drm_device *dev = etnaviv_obj->base.dev;
  25. struct sg_table *sgt = etnaviv_obj->sgt;
  26. /*
  27. * For non-cached buffers, ensure the new pages are clean
  28. * because display controller, GPU, etc. are not coherent.
  29. */
  30. if (etnaviv_obj->flags & ETNA_BO_CACHE_MASK)
  31. dma_map_sg(dev->dev, sgt->sgl, sgt->nents, DMA_BIDIRECTIONAL);
  32. }
  33. static void etnaviv_gem_scatterlist_unmap(struct etnaviv_gem_object *etnaviv_obj)
  34. {
  35. struct drm_device *dev = etnaviv_obj->base.dev;
  36. struct sg_table *sgt = etnaviv_obj->sgt;
  37. /*
  38. * For non-cached buffers, ensure the new pages are clean
  39. * because display controller, GPU, etc. are not coherent:
  40. *
  41. * WARNING: The DMA API does not support concurrent CPU
  42. * and device access to the memory area. With BIDIRECTIONAL,
  43. * we will clean the cache lines which overlap the region,
  44. * and invalidate all cache lines (partially) contained in
  45. * the region.
  46. *
  47. * If you have dirty data in the overlapping cache lines,
  48. * that will corrupt the GPU-written data. If you have
  49. * written into the remainder of the region, this can
  50. * discard those writes.
  51. */
  52. if (etnaviv_obj->flags & ETNA_BO_CACHE_MASK)
  53. dma_unmap_sg(dev->dev, sgt->sgl, sgt->nents, DMA_BIDIRECTIONAL);
  54. }
  55. /* called with etnaviv_obj->lock held */
  56. static int etnaviv_gem_shmem_get_pages(struct etnaviv_gem_object *etnaviv_obj)
  57. {
  58. struct drm_device *dev = etnaviv_obj->base.dev;
  59. struct page **p = drm_gem_get_pages(&etnaviv_obj->base);
  60. if (IS_ERR(p)) {
  61. dev_err(dev->dev, "could not get pages: %ld\n", PTR_ERR(p));
  62. return PTR_ERR(p);
  63. }
  64. etnaviv_obj->pages = p;
  65. return 0;
  66. }
  67. static void put_pages(struct etnaviv_gem_object *etnaviv_obj)
  68. {
  69. if (etnaviv_obj->sgt) {
  70. etnaviv_gem_scatterlist_unmap(etnaviv_obj);
  71. sg_free_table(etnaviv_obj->sgt);
  72. kfree(etnaviv_obj->sgt);
  73. etnaviv_obj->sgt = NULL;
  74. }
  75. if (etnaviv_obj->pages) {
  76. drm_gem_put_pages(&etnaviv_obj->base, etnaviv_obj->pages,
  77. true, false);
  78. etnaviv_obj->pages = NULL;
  79. }
  80. }
  81. struct page **etnaviv_gem_get_pages(struct etnaviv_gem_object *etnaviv_obj)
  82. {
  83. int ret;
  84. lockdep_assert_held(&etnaviv_obj->lock);
  85. if (!etnaviv_obj->pages) {
  86. ret = etnaviv_obj->ops->get_pages(etnaviv_obj);
  87. if (ret < 0)
  88. return ERR_PTR(ret);
  89. }
  90. if (!etnaviv_obj->sgt) {
  91. struct drm_device *dev = etnaviv_obj->base.dev;
  92. int npages = etnaviv_obj->base.size >> PAGE_SHIFT;
  93. struct sg_table *sgt;
  94. sgt = drm_prime_pages_to_sg(etnaviv_obj->pages, npages);
  95. if (IS_ERR(sgt)) {
  96. dev_err(dev->dev, "failed to allocate sgt: %ld\n",
  97. PTR_ERR(sgt));
  98. return ERR_CAST(sgt);
  99. }
  100. etnaviv_obj->sgt = sgt;
  101. etnaviv_gem_scatter_map(etnaviv_obj);
  102. }
  103. return etnaviv_obj->pages;
  104. }
  105. void etnaviv_gem_put_pages(struct etnaviv_gem_object *etnaviv_obj)
  106. {
  107. lockdep_assert_held(&etnaviv_obj->lock);
  108. /* when we start tracking the pin count, then do something here */
  109. }
  110. static int etnaviv_gem_mmap_obj(struct drm_gem_object *obj,
  111. struct vm_area_struct *vma)
  112. {
  113. struct etnaviv_gem_object *etnaviv_obj = to_etnaviv_bo(obj);
  114. pgprot_t vm_page_prot;
  115. vma->vm_flags &= ~VM_PFNMAP;
  116. vma->vm_flags |= VM_MIXEDMAP;
  117. vm_page_prot = vm_get_page_prot(vma->vm_flags);
  118. if (etnaviv_obj->flags & ETNA_BO_WC) {
  119. vma->vm_page_prot = pgprot_writecombine(vm_page_prot);
  120. } else if (etnaviv_obj->flags & ETNA_BO_UNCACHED) {
  121. vma->vm_page_prot = pgprot_noncached(vm_page_prot);
  122. } else {
  123. /*
  124. * Shunt off cached objs to shmem file so they have their own
  125. * address_space (so unmap_mapping_range does what we want,
  126. * in particular in the case of mmap'd dmabufs)
  127. */
  128. fput(vma->vm_file);
  129. get_file(obj->filp);
  130. vma->vm_pgoff = 0;
  131. vma->vm_file = obj->filp;
  132. vma->vm_page_prot = vm_page_prot;
  133. }
  134. return 0;
  135. }
  136. int etnaviv_gem_mmap(struct file *filp, struct vm_area_struct *vma)
  137. {
  138. struct etnaviv_gem_object *obj;
  139. int ret;
  140. ret = drm_gem_mmap(filp, vma);
  141. if (ret) {
  142. DBG("mmap failed: %d", ret);
  143. return ret;
  144. }
  145. obj = to_etnaviv_bo(vma->vm_private_data);
  146. return etnaviv_gem_mmap_obj(vma->vm_private_data, vma);
  147. }
  148. int etnaviv_gem_fault(struct vm_area_struct *vma, struct vm_fault *vmf)
  149. {
  150. struct drm_gem_object *obj = vma->vm_private_data;
  151. struct etnaviv_gem_object *etnaviv_obj = to_etnaviv_bo(obj);
  152. struct page **pages, *page;
  153. pgoff_t pgoff;
  154. int ret;
  155. /*
  156. * Make sure we don't parallel update on a fault, nor move or remove
  157. * something from beneath our feet. Note that vm_insert_page() is
  158. * specifically coded to take care of this, so we don't have to.
  159. */
  160. ret = mutex_lock_interruptible(&etnaviv_obj->lock);
  161. if (ret)
  162. goto out;
  163. /* make sure we have pages attached now */
  164. pages = etnaviv_gem_get_pages(etnaviv_obj);
  165. mutex_unlock(&etnaviv_obj->lock);
  166. if (IS_ERR(pages)) {
  167. ret = PTR_ERR(pages);
  168. goto out;
  169. }
  170. /* We don't use vmf->pgoff since that has the fake offset: */
  171. pgoff = ((unsigned long)vmf->virtual_address -
  172. vma->vm_start) >> PAGE_SHIFT;
  173. page = pages[pgoff];
  174. VERB("Inserting %p pfn %lx, pa %lx", vmf->virtual_address,
  175. page_to_pfn(page), page_to_pfn(page) << PAGE_SHIFT);
  176. ret = vm_insert_page(vma, (unsigned long)vmf->virtual_address, page);
  177. out:
  178. switch (ret) {
  179. case -EAGAIN:
  180. case 0:
  181. case -ERESTARTSYS:
  182. case -EINTR:
  183. case -EBUSY:
  184. /*
  185. * EBUSY is ok: this just means that another thread
  186. * already did the job.
  187. */
  188. return VM_FAULT_NOPAGE;
  189. case -ENOMEM:
  190. return VM_FAULT_OOM;
  191. default:
  192. return VM_FAULT_SIGBUS;
  193. }
  194. }
  195. int etnaviv_gem_mmap_offset(struct drm_gem_object *obj, u64 *offset)
  196. {
  197. int ret;
  198. /* Make it mmapable */
  199. ret = drm_gem_create_mmap_offset(obj);
  200. if (ret)
  201. dev_err(obj->dev->dev, "could not allocate mmap offset\n");
  202. else
  203. *offset = drm_vma_node_offset_addr(&obj->vma_node);
  204. return ret;
  205. }
  206. static struct etnaviv_vram_mapping *
  207. etnaviv_gem_get_vram_mapping(struct etnaviv_gem_object *obj,
  208. struct etnaviv_iommu *mmu)
  209. {
  210. struct etnaviv_vram_mapping *mapping;
  211. list_for_each_entry(mapping, &obj->vram_list, obj_node) {
  212. if (mapping->mmu == mmu)
  213. return mapping;
  214. }
  215. return NULL;
  216. }
  217. void etnaviv_gem_mapping_reference(struct etnaviv_vram_mapping *mapping)
  218. {
  219. struct etnaviv_gem_object *etnaviv_obj = mapping->object;
  220. drm_gem_object_reference(&etnaviv_obj->base);
  221. mutex_lock(&etnaviv_obj->lock);
  222. WARN_ON(mapping->use == 0);
  223. mapping->use += 1;
  224. mutex_unlock(&etnaviv_obj->lock);
  225. }
  226. void etnaviv_gem_mapping_unreference(struct etnaviv_vram_mapping *mapping)
  227. {
  228. struct etnaviv_gem_object *etnaviv_obj = mapping->object;
  229. mutex_lock(&etnaviv_obj->lock);
  230. WARN_ON(mapping->use == 0);
  231. mapping->use -= 1;
  232. mutex_unlock(&etnaviv_obj->lock);
  233. drm_gem_object_unreference_unlocked(&etnaviv_obj->base);
  234. }
  235. struct etnaviv_vram_mapping *etnaviv_gem_mapping_get(
  236. struct drm_gem_object *obj, struct etnaviv_gpu *gpu)
  237. {
  238. struct etnaviv_gem_object *etnaviv_obj = to_etnaviv_bo(obj);
  239. struct etnaviv_vram_mapping *mapping;
  240. struct page **pages;
  241. int ret = 0;
  242. mutex_lock(&etnaviv_obj->lock);
  243. mapping = etnaviv_gem_get_vram_mapping(etnaviv_obj, gpu->mmu);
  244. if (mapping) {
  245. /*
  246. * Holding the object lock prevents the use count changing
  247. * beneath us. If the use count is zero, the MMU might be
  248. * reaping this object, so take the lock and re-check that
  249. * the MMU owns this mapping to close this race.
  250. */
  251. if (mapping->use == 0) {
  252. mutex_lock(&gpu->mmu->lock);
  253. if (mapping->mmu == gpu->mmu)
  254. mapping->use += 1;
  255. else
  256. mapping = NULL;
  257. mutex_unlock(&gpu->mmu->lock);
  258. if (mapping)
  259. goto out;
  260. } else {
  261. mapping->use += 1;
  262. goto out;
  263. }
  264. }
  265. pages = etnaviv_gem_get_pages(etnaviv_obj);
  266. if (IS_ERR(pages)) {
  267. ret = PTR_ERR(pages);
  268. goto out;
  269. }
  270. /*
  271. * See if we have a reaped vram mapping we can re-use before
  272. * allocating a fresh mapping.
  273. */
  274. mapping = etnaviv_gem_get_vram_mapping(etnaviv_obj, NULL);
  275. if (!mapping) {
  276. mapping = kzalloc(sizeof(*mapping), GFP_KERNEL);
  277. if (!mapping) {
  278. ret = -ENOMEM;
  279. goto out;
  280. }
  281. INIT_LIST_HEAD(&mapping->scan_node);
  282. mapping->object = etnaviv_obj;
  283. } else {
  284. list_del(&mapping->obj_node);
  285. }
  286. mapping->mmu = gpu->mmu;
  287. mapping->use = 1;
  288. ret = etnaviv_iommu_map_gem(gpu->mmu, etnaviv_obj, gpu->memory_base,
  289. mapping);
  290. if (ret < 0)
  291. kfree(mapping);
  292. else
  293. list_add_tail(&mapping->obj_node, &etnaviv_obj->vram_list);
  294. out:
  295. mutex_unlock(&etnaviv_obj->lock);
  296. if (ret)
  297. return ERR_PTR(ret);
  298. /* Take a reference on the object */
  299. drm_gem_object_reference(obj);
  300. return mapping;
  301. }
  302. void *etnaviv_gem_vmap(struct drm_gem_object *obj)
  303. {
  304. struct etnaviv_gem_object *etnaviv_obj = to_etnaviv_bo(obj);
  305. if (etnaviv_obj->vaddr)
  306. return etnaviv_obj->vaddr;
  307. mutex_lock(&etnaviv_obj->lock);
  308. /*
  309. * Need to check again, as we might have raced with another thread
  310. * while waiting for the mutex.
  311. */
  312. if (!etnaviv_obj->vaddr)
  313. etnaviv_obj->vaddr = etnaviv_obj->ops->vmap(etnaviv_obj);
  314. mutex_unlock(&etnaviv_obj->lock);
  315. return etnaviv_obj->vaddr;
  316. }
  317. static void *etnaviv_gem_vmap_impl(struct etnaviv_gem_object *obj)
  318. {
  319. struct page **pages;
  320. lockdep_assert_held(&obj->lock);
  321. pages = etnaviv_gem_get_pages(obj);
  322. if (IS_ERR(pages))
  323. return NULL;
  324. return vmap(pages, obj->base.size >> PAGE_SHIFT,
  325. VM_MAP, pgprot_writecombine(PAGE_KERNEL));
  326. }
  327. static inline enum dma_data_direction etnaviv_op_to_dma_dir(u32 op)
  328. {
  329. if (op & ETNA_PREP_READ)
  330. return DMA_FROM_DEVICE;
  331. else if (op & ETNA_PREP_WRITE)
  332. return DMA_TO_DEVICE;
  333. else
  334. return DMA_BIDIRECTIONAL;
  335. }
  336. int etnaviv_gem_cpu_prep(struct drm_gem_object *obj, u32 op,
  337. struct timespec *timeout)
  338. {
  339. struct etnaviv_gem_object *etnaviv_obj = to_etnaviv_bo(obj);
  340. struct drm_device *dev = obj->dev;
  341. bool write = !!(op & ETNA_PREP_WRITE);
  342. int ret;
  343. if (op & ETNA_PREP_NOSYNC) {
  344. if (!reservation_object_test_signaled_rcu(etnaviv_obj->resv,
  345. write))
  346. return -EBUSY;
  347. } else {
  348. unsigned long remain = etnaviv_timeout_to_jiffies(timeout);
  349. ret = reservation_object_wait_timeout_rcu(etnaviv_obj->resv,
  350. write, true, remain);
  351. if (ret <= 0)
  352. return ret == 0 ? -ETIMEDOUT : ret;
  353. }
  354. if (etnaviv_obj->flags & ETNA_BO_CACHED) {
  355. if (!etnaviv_obj->sgt) {
  356. void *ret;
  357. mutex_lock(&etnaviv_obj->lock);
  358. ret = etnaviv_gem_get_pages(etnaviv_obj);
  359. mutex_unlock(&etnaviv_obj->lock);
  360. if (IS_ERR(ret))
  361. return PTR_ERR(ret);
  362. }
  363. dma_sync_sg_for_cpu(dev->dev, etnaviv_obj->sgt->sgl,
  364. etnaviv_obj->sgt->nents,
  365. etnaviv_op_to_dma_dir(op));
  366. etnaviv_obj->last_cpu_prep_op = op;
  367. }
  368. return 0;
  369. }
  370. int etnaviv_gem_cpu_fini(struct drm_gem_object *obj)
  371. {
  372. struct drm_device *dev = obj->dev;
  373. struct etnaviv_gem_object *etnaviv_obj = to_etnaviv_bo(obj);
  374. if (etnaviv_obj->flags & ETNA_BO_CACHED) {
  375. /* fini without a prep is almost certainly a userspace error */
  376. WARN_ON(etnaviv_obj->last_cpu_prep_op == 0);
  377. dma_sync_sg_for_device(dev->dev, etnaviv_obj->sgt->sgl,
  378. etnaviv_obj->sgt->nents,
  379. etnaviv_op_to_dma_dir(etnaviv_obj->last_cpu_prep_op));
  380. etnaviv_obj->last_cpu_prep_op = 0;
  381. }
  382. return 0;
  383. }
  384. int etnaviv_gem_wait_bo(struct etnaviv_gpu *gpu, struct drm_gem_object *obj,
  385. struct timespec *timeout)
  386. {
  387. struct etnaviv_gem_object *etnaviv_obj = to_etnaviv_bo(obj);
  388. return etnaviv_gpu_wait_obj_inactive(gpu, etnaviv_obj, timeout);
  389. }
  390. #ifdef CONFIG_DEBUG_FS
  391. static void etnaviv_gem_describe_fence(struct fence *fence,
  392. const char *type, struct seq_file *m)
  393. {
  394. if (!test_bit(FENCE_FLAG_SIGNALED_BIT, &fence->flags))
  395. seq_printf(m, "\t%9s: %s %s seq %u\n",
  396. type,
  397. fence->ops->get_driver_name(fence),
  398. fence->ops->get_timeline_name(fence),
  399. fence->seqno);
  400. }
  401. static void etnaviv_gem_describe(struct drm_gem_object *obj, struct seq_file *m)
  402. {
  403. struct etnaviv_gem_object *etnaviv_obj = to_etnaviv_bo(obj);
  404. struct reservation_object *robj = etnaviv_obj->resv;
  405. struct reservation_object_list *fobj;
  406. struct fence *fence;
  407. unsigned long off = drm_vma_node_start(&obj->vma_node);
  408. seq_printf(m, "%08x: %c %2d (%2d) %08lx %p %zd\n",
  409. etnaviv_obj->flags, is_active(etnaviv_obj) ? 'A' : 'I',
  410. obj->name, obj->refcount.refcount.counter,
  411. off, etnaviv_obj->vaddr, obj->size);
  412. rcu_read_lock();
  413. fobj = rcu_dereference(robj->fence);
  414. if (fobj) {
  415. unsigned int i, shared_count = fobj->shared_count;
  416. for (i = 0; i < shared_count; i++) {
  417. fence = rcu_dereference(fobj->shared[i]);
  418. etnaviv_gem_describe_fence(fence, "Shared", m);
  419. }
  420. }
  421. fence = rcu_dereference(robj->fence_excl);
  422. if (fence)
  423. etnaviv_gem_describe_fence(fence, "Exclusive", m);
  424. rcu_read_unlock();
  425. }
  426. void etnaviv_gem_describe_objects(struct etnaviv_drm_private *priv,
  427. struct seq_file *m)
  428. {
  429. struct etnaviv_gem_object *etnaviv_obj;
  430. int count = 0;
  431. size_t size = 0;
  432. mutex_lock(&priv->gem_lock);
  433. list_for_each_entry(etnaviv_obj, &priv->gem_list, gem_node) {
  434. struct drm_gem_object *obj = &etnaviv_obj->base;
  435. seq_puts(m, " ");
  436. etnaviv_gem_describe(obj, m);
  437. count++;
  438. size += obj->size;
  439. }
  440. mutex_unlock(&priv->gem_lock);
  441. seq_printf(m, "Total %d objects, %zu bytes\n", count, size);
  442. }
  443. #endif
  444. static void etnaviv_gem_shmem_release(struct etnaviv_gem_object *etnaviv_obj)
  445. {
  446. if (etnaviv_obj->vaddr)
  447. vunmap(etnaviv_obj->vaddr);
  448. put_pages(etnaviv_obj);
  449. }
  450. static const struct etnaviv_gem_ops etnaviv_gem_shmem_ops = {
  451. .get_pages = etnaviv_gem_shmem_get_pages,
  452. .release = etnaviv_gem_shmem_release,
  453. .vmap = etnaviv_gem_vmap_impl,
  454. };
  455. void etnaviv_gem_free_object(struct drm_gem_object *obj)
  456. {
  457. struct etnaviv_gem_object *etnaviv_obj = to_etnaviv_bo(obj);
  458. struct etnaviv_vram_mapping *mapping, *tmp;
  459. /* object should not be active */
  460. WARN_ON(is_active(etnaviv_obj));
  461. list_del(&etnaviv_obj->gem_node);
  462. list_for_each_entry_safe(mapping, tmp, &etnaviv_obj->vram_list,
  463. obj_node) {
  464. struct etnaviv_iommu *mmu = mapping->mmu;
  465. WARN_ON(mapping->use);
  466. if (mmu)
  467. etnaviv_iommu_unmap_gem(mmu, mapping);
  468. list_del(&mapping->obj_node);
  469. kfree(mapping);
  470. }
  471. drm_gem_free_mmap_offset(obj);
  472. etnaviv_obj->ops->release(etnaviv_obj);
  473. if (etnaviv_obj->resv == &etnaviv_obj->_resv)
  474. reservation_object_fini(&etnaviv_obj->_resv);
  475. drm_gem_object_release(obj);
  476. kfree(etnaviv_obj);
  477. }
  478. int etnaviv_gem_obj_add(struct drm_device *dev, struct drm_gem_object *obj)
  479. {
  480. struct etnaviv_drm_private *priv = dev->dev_private;
  481. struct etnaviv_gem_object *etnaviv_obj = to_etnaviv_bo(obj);
  482. mutex_lock(&priv->gem_lock);
  483. list_add_tail(&etnaviv_obj->gem_node, &priv->gem_list);
  484. mutex_unlock(&priv->gem_lock);
  485. return 0;
  486. }
  487. static int etnaviv_gem_new_impl(struct drm_device *dev, u32 size, u32 flags,
  488. struct reservation_object *robj, const struct etnaviv_gem_ops *ops,
  489. struct drm_gem_object **obj)
  490. {
  491. struct etnaviv_gem_object *etnaviv_obj;
  492. unsigned sz = sizeof(*etnaviv_obj);
  493. bool valid = true;
  494. /* validate flags */
  495. switch (flags & ETNA_BO_CACHE_MASK) {
  496. case ETNA_BO_UNCACHED:
  497. case ETNA_BO_CACHED:
  498. case ETNA_BO_WC:
  499. break;
  500. default:
  501. valid = false;
  502. }
  503. if (!valid) {
  504. dev_err(dev->dev, "invalid cache flag: %x\n",
  505. (flags & ETNA_BO_CACHE_MASK));
  506. return -EINVAL;
  507. }
  508. etnaviv_obj = kzalloc(sz, GFP_KERNEL);
  509. if (!etnaviv_obj)
  510. return -ENOMEM;
  511. etnaviv_obj->flags = flags;
  512. etnaviv_obj->ops = ops;
  513. if (robj) {
  514. etnaviv_obj->resv = robj;
  515. } else {
  516. etnaviv_obj->resv = &etnaviv_obj->_resv;
  517. reservation_object_init(&etnaviv_obj->_resv);
  518. }
  519. mutex_init(&etnaviv_obj->lock);
  520. INIT_LIST_HEAD(&etnaviv_obj->vram_list);
  521. *obj = &etnaviv_obj->base;
  522. return 0;
  523. }
  524. static struct drm_gem_object *__etnaviv_gem_new(struct drm_device *dev,
  525. u32 size, u32 flags)
  526. {
  527. struct drm_gem_object *obj = NULL;
  528. int ret;
  529. size = PAGE_ALIGN(size);
  530. ret = etnaviv_gem_new_impl(dev, size, flags, NULL,
  531. &etnaviv_gem_shmem_ops, &obj);
  532. if (ret)
  533. goto fail;
  534. ret = drm_gem_object_init(dev, obj, size);
  535. if (ret == 0) {
  536. struct address_space *mapping;
  537. /*
  538. * Our buffers are kept pinned, so allocating them
  539. * from the MOVABLE zone is a really bad idea, and
  540. * conflicts with CMA. See coments above new_inode()
  541. * why this is required _and_ expected if you're
  542. * going to pin these pages.
  543. */
  544. mapping = file_inode(obj->filp)->i_mapping;
  545. mapping_set_gfp_mask(mapping, GFP_HIGHUSER);
  546. }
  547. if (ret)
  548. goto fail;
  549. return obj;
  550. fail:
  551. if (obj)
  552. drm_gem_object_unreference_unlocked(obj);
  553. return ERR_PTR(ret);
  554. }
  555. /* convenience method to construct a GEM buffer object, and userspace handle */
  556. int etnaviv_gem_new_handle(struct drm_device *dev, struct drm_file *file,
  557. u32 size, u32 flags, u32 *handle)
  558. {
  559. struct drm_gem_object *obj;
  560. int ret;
  561. obj = __etnaviv_gem_new(dev, size, flags);
  562. if (IS_ERR(obj))
  563. return PTR_ERR(obj);
  564. ret = etnaviv_gem_obj_add(dev, obj);
  565. if (ret < 0) {
  566. drm_gem_object_unreference_unlocked(obj);
  567. return ret;
  568. }
  569. ret = drm_gem_handle_create(file, obj, handle);
  570. /* drop reference from allocate - handle holds it now */
  571. drm_gem_object_unreference_unlocked(obj);
  572. return ret;
  573. }
  574. struct drm_gem_object *etnaviv_gem_new(struct drm_device *dev,
  575. u32 size, u32 flags)
  576. {
  577. struct drm_gem_object *obj;
  578. int ret;
  579. obj = __etnaviv_gem_new(dev, size, flags);
  580. if (IS_ERR(obj))
  581. return obj;
  582. ret = etnaviv_gem_obj_add(dev, obj);
  583. if (ret < 0) {
  584. drm_gem_object_unreference_unlocked(obj);
  585. return ERR_PTR(ret);
  586. }
  587. return obj;
  588. }
  589. int etnaviv_gem_new_private(struct drm_device *dev, size_t size, u32 flags,
  590. struct reservation_object *robj, const struct etnaviv_gem_ops *ops,
  591. struct etnaviv_gem_object **res)
  592. {
  593. struct drm_gem_object *obj;
  594. int ret;
  595. ret = etnaviv_gem_new_impl(dev, size, flags, robj, ops, &obj);
  596. if (ret)
  597. return ret;
  598. drm_gem_private_object_init(dev, obj, size);
  599. *res = to_etnaviv_bo(obj);
  600. return 0;
  601. }
  602. struct get_pages_work {
  603. struct work_struct work;
  604. struct mm_struct *mm;
  605. struct task_struct *task;
  606. struct etnaviv_gem_object *etnaviv_obj;
  607. };
  608. static struct page **etnaviv_gem_userptr_do_get_pages(
  609. struct etnaviv_gem_object *etnaviv_obj, struct mm_struct *mm, struct task_struct *task)
  610. {
  611. int ret = 0, pinned, npages = etnaviv_obj->base.size >> PAGE_SHIFT;
  612. struct page **pvec;
  613. uintptr_t ptr;
  614. pvec = drm_malloc_ab(npages, sizeof(struct page *));
  615. if (!pvec)
  616. return ERR_PTR(-ENOMEM);
  617. pinned = 0;
  618. ptr = etnaviv_obj->userptr.ptr;
  619. down_read(&mm->mmap_sem);
  620. while (pinned < npages) {
  621. ret = get_user_pages_remote(task, mm, ptr, npages - pinned,
  622. !etnaviv_obj->userptr.ro, 0,
  623. pvec + pinned, NULL);
  624. if (ret < 0)
  625. break;
  626. ptr += ret * PAGE_SIZE;
  627. pinned += ret;
  628. }
  629. up_read(&mm->mmap_sem);
  630. if (ret < 0) {
  631. release_pages(pvec, pinned, 0);
  632. drm_free_large(pvec);
  633. return ERR_PTR(ret);
  634. }
  635. return pvec;
  636. }
  637. static void __etnaviv_gem_userptr_get_pages(struct work_struct *_work)
  638. {
  639. struct get_pages_work *work = container_of(_work, typeof(*work), work);
  640. struct etnaviv_gem_object *etnaviv_obj = work->etnaviv_obj;
  641. struct page **pvec;
  642. pvec = etnaviv_gem_userptr_do_get_pages(etnaviv_obj, work->mm, work->task);
  643. mutex_lock(&etnaviv_obj->lock);
  644. if (IS_ERR(pvec)) {
  645. etnaviv_obj->userptr.work = ERR_CAST(pvec);
  646. } else {
  647. etnaviv_obj->userptr.work = NULL;
  648. etnaviv_obj->pages = pvec;
  649. }
  650. mutex_unlock(&etnaviv_obj->lock);
  651. drm_gem_object_unreference_unlocked(&etnaviv_obj->base);
  652. mmput(work->mm);
  653. put_task_struct(work->task);
  654. kfree(work);
  655. }
  656. static int etnaviv_gem_userptr_get_pages(struct etnaviv_gem_object *etnaviv_obj)
  657. {
  658. struct page **pvec = NULL;
  659. struct get_pages_work *work;
  660. struct mm_struct *mm;
  661. int ret, pinned, npages = etnaviv_obj->base.size >> PAGE_SHIFT;
  662. if (etnaviv_obj->userptr.work) {
  663. if (IS_ERR(etnaviv_obj->userptr.work)) {
  664. ret = PTR_ERR(etnaviv_obj->userptr.work);
  665. etnaviv_obj->userptr.work = NULL;
  666. } else {
  667. ret = -EAGAIN;
  668. }
  669. return ret;
  670. }
  671. mm = get_task_mm(etnaviv_obj->userptr.task);
  672. pinned = 0;
  673. if (mm == current->mm) {
  674. pvec = drm_malloc_ab(npages, sizeof(struct page *));
  675. if (!pvec) {
  676. mmput(mm);
  677. return -ENOMEM;
  678. }
  679. pinned = __get_user_pages_fast(etnaviv_obj->userptr.ptr, npages,
  680. !etnaviv_obj->userptr.ro, pvec);
  681. if (pinned < 0) {
  682. drm_free_large(pvec);
  683. mmput(mm);
  684. return pinned;
  685. }
  686. if (pinned == npages) {
  687. etnaviv_obj->pages = pvec;
  688. mmput(mm);
  689. return 0;
  690. }
  691. }
  692. release_pages(pvec, pinned, 0);
  693. drm_free_large(pvec);
  694. work = kmalloc(sizeof(*work), GFP_KERNEL);
  695. if (!work) {
  696. mmput(mm);
  697. return -ENOMEM;
  698. }
  699. get_task_struct(current);
  700. drm_gem_object_reference(&etnaviv_obj->base);
  701. work->mm = mm;
  702. work->task = current;
  703. work->etnaviv_obj = etnaviv_obj;
  704. etnaviv_obj->userptr.work = &work->work;
  705. INIT_WORK(&work->work, __etnaviv_gem_userptr_get_pages);
  706. etnaviv_queue_work(etnaviv_obj->base.dev, &work->work);
  707. return -EAGAIN;
  708. }
  709. static void etnaviv_gem_userptr_release(struct etnaviv_gem_object *etnaviv_obj)
  710. {
  711. if (etnaviv_obj->sgt) {
  712. etnaviv_gem_scatterlist_unmap(etnaviv_obj);
  713. sg_free_table(etnaviv_obj->sgt);
  714. kfree(etnaviv_obj->sgt);
  715. }
  716. if (etnaviv_obj->pages) {
  717. int npages = etnaviv_obj->base.size >> PAGE_SHIFT;
  718. release_pages(etnaviv_obj->pages, npages, 0);
  719. drm_free_large(etnaviv_obj->pages);
  720. }
  721. put_task_struct(etnaviv_obj->userptr.task);
  722. }
  723. static const struct etnaviv_gem_ops etnaviv_gem_userptr_ops = {
  724. .get_pages = etnaviv_gem_userptr_get_pages,
  725. .release = etnaviv_gem_userptr_release,
  726. .vmap = etnaviv_gem_vmap_impl,
  727. };
  728. int etnaviv_gem_new_userptr(struct drm_device *dev, struct drm_file *file,
  729. uintptr_t ptr, u32 size, u32 flags, u32 *handle)
  730. {
  731. struct etnaviv_gem_object *etnaviv_obj;
  732. int ret;
  733. ret = etnaviv_gem_new_private(dev, size, ETNA_BO_CACHED, NULL,
  734. &etnaviv_gem_userptr_ops, &etnaviv_obj);
  735. if (ret)
  736. return ret;
  737. etnaviv_obj->userptr.ptr = ptr;
  738. etnaviv_obj->userptr.task = current;
  739. etnaviv_obj->userptr.ro = !(flags & ETNA_USERPTR_WRITE);
  740. get_task_struct(current);
  741. ret = etnaviv_gem_obj_add(dev, &etnaviv_obj->base);
  742. if (ret) {
  743. drm_gem_object_unreference_unlocked(&etnaviv_obj->base);
  744. return ret;
  745. }
  746. ret = drm_gem_handle_create(file, &etnaviv_obj->base, handle);
  747. /* drop reference from allocate - handle holds it now */
  748. drm_gem_object_unreference_unlocked(&etnaviv_obj->base);
  749. return ret;
  750. }