omap_gem.c 39 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537
  1. // SPDX-License-Identifier: GPL-2.0-only
  2. /*
  3. * Copyright (C) 2011 Texas Instruments Incorporated - https://www.ti.com/
  4. * Author: Rob Clark <[email protected]>
  5. */
  6. #include <linux/dma-mapping.h>
  7. #include <linux/seq_file.h>
  8. #include <linux/shmem_fs.h>
  9. #include <linux/spinlock.h>
  10. #include <linux/pfn_t.h>
  11. #include <drm/drm_prime.h>
  12. #include <drm/drm_vma_manager.h>
  13. #include "omap_drv.h"
  14. #include "omap_dmm_tiler.h"
  15. /*
  16. * GEM buffer object implementation.
  17. */
  18. /* note: we use upper 8 bits of flags for driver-internal flags: */
  19. #define OMAP_BO_MEM_DMA_API 0x01000000 /* memory allocated with the dma_alloc_* API */
  20. #define OMAP_BO_MEM_SHMEM 0x02000000 /* memory allocated through shmem backing */
  21. #define OMAP_BO_MEM_DMABUF 0x08000000 /* memory imported from a dmabuf */
  22. struct omap_gem_object {
  23. struct drm_gem_object base;
  24. struct list_head mm_list;
  25. u32 flags;
  26. /** width/height for tiled formats (rounded up to slot boundaries) */
  27. u16 width, height;
  28. /** roll applied when mapping to DMM */
  29. u32 roll;
  30. /** protects pin_cnt, block, pages, dma_addrs and vaddr */
  31. struct mutex lock;
  32. /**
  33. * dma_addr contains the buffer DMA address. It is valid for
  34. *
  35. * - buffers allocated through the DMA mapping API (with the
  36. * OMAP_BO_MEM_DMA_API flag set)
  37. *
  38. * - buffers imported from dmabuf (with the OMAP_BO_MEM_DMABUF flag set)
  39. * if they are physically contiguous (when sgt->orig_nents == 1)
  40. *
  41. * - buffers mapped through the TILER when pin_cnt is not zero, in which
  42. * case the DMA address points to the TILER aperture
  43. *
  44. * Physically contiguous buffers have their DMA address equal to the
  45. * physical address as we don't remap those buffers through the TILER.
  46. *
  47. * Buffers mapped to the TILER have their DMA address pointing to the
  48. * TILER aperture. As TILER mappings are refcounted (through pin_cnt)
  49. * the DMA address must be accessed through omap_gem_pin() to ensure
  50. * that the mapping won't disappear unexpectedly. References must be
  51. * released with omap_gem_unpin().
  52. */
  53. dma_addr_t dma_addr;
  54. /**
  55. * # of users
  56. */
  57. refcount_t pin_cnt;
  58. /**
  59. * If the buffer has been imported from a dmabuf the OMAP_DB_DMABUF flag
  60. * is set and the sgt field is valid.
  61. */
  62. struct sg_table *sgt;
  63. /**
  64. * tiler block used when buffer is remapped in DMM/TILER.
  65. */
  66. struct tiler_block *block;
  67. /**
  68. * Array of backing pages, if allocated. Note that pages are never
  69. * allocated for buffers originally allocated from contiguous memory
  70. */
  71. struct page **pages;
  72. /** addresses corresponding to pages in above array */
  73. dma_addr_t *dma_addrs;
  74. /**
  75. * Virtual address, if mapped.
  76. */
  77. void *vaddr;
  78. };
  79. #define to_omap_bo(x) container_of(x, struct omap_gem_object, base)
  80. /* To deal with userspace mmap'ings of 2d tiled buffers, which (a) are
  81. * not necessarily pinned in TILER all the time, and (b) when they are
  82. * they are not necessarily page aligned, we reserve one or more small
  83. * regions in each of the 2d containers to use as a user-GART where we
  84. * can create a second page-aligned mapping of parts of the buffer
  85. * being accessed from userspace.
  86. *
  87. * Note that we could optimize slightly when we know that multiple
  88. * tiler containers are backed by the same PAT.. but I'll leave that
  89. * for later..
  90. */
  91. #define NUM_USERGART_ENTRIES 2
  92. struct omap_drm_usergart_entry {
  93. struct tiler_block *block; /* the reserved tiler block */
  94. dma_addr_t dma_addr;
  95. struct drm_gem_object *obj; /* the current pinned obj */
  96. pgoff_t obj_pgoff; /* page offset of obj currently
  97. mapped in */
  98. };
  99. struct omap_drm_usergart {
  100. struct omap_drm_usergart_entry entry[NUM_USERGART_ENTRIES];
  101. int height; /* height in rows */
  102. int height_shift; /* ilog2(height in rows) */
  103. int slot_shift; /* ilog2(width per slot) */
  104. int stride_pfn; /* stride in pages */
  105. int last; /* index of last used entry */
  106. };
  107. /* -----------------------------------------------------------------------------
  108. * Helpers
  109. */
  110. /** get mmap offset */
  111. u64 omap_gem_mmap_offset(struct drm_gem_object *obj)
  112. {
  113. struct drm_device *dev = obj->dev;
  114. int ret;
  115. size_t size;
  116. /* Make it mmapable */
  117. size = omap_gem_mmap_size(obj);
  118. ret = drm_gem_create_mmap_offset_size(obj, size);
  119. if (ret) {
  120. dev_err(dev->dev, "could not allocate mmap offset\n");
  121. return 0;
  122. }
  123. return drm_vma_node_offset_addr(&obj->vma_node);
  124. }
  125. static bool omap_gem_is_contiguous(struct omap_gem_object *omap_obj)
  126. {
  127. if (omap_obj->flags & OMAP_BO_MEM_DMA_API)
  128. return true;
  129. if ((omap_obj->flags & OMAP_BO_MEM_DMABUF) && omap_obj->sgt->nents == 1)
  130. return true;
  131. return false;
  132. }
  133. /* -----------------------------------------------------------------------------
  134. * Eviction
  135. */
  136. static void omap_gem_evict_entry(struct drm_gem_object *obj,
  137. enum tiler_fmt fmt, struct omap_drm_usergart_entry *entry)
  138. {
  139. struct omap_gem_object *omap_obj = to_omap_bo(obj);
  140. struct omap_drm_private *priv = obj->dev->dev_private;
  141. int n = priv->usergart[fmt].height;
  142. size_t size = PAGE_SIZE * n;
  143. loff_t off = omap_gem_mmap_offset(obj) +
  144. (entry->obj_pgoff << PAGE_SHIFT);
  145. const int m = DIV_ROUND_UP(omap_obj->width << fmt, PAGE_SIZE);
  146. if (m > 1) {
  147. int i;
  148. /* if stride > than PAGE_SIZE then sparse mapping: */
  149. for (i = n; i > 0; i--) {
  150. unmap_mapping_range(obj->dev->anon_inode->i_mapping,
  151. off, PAGE_SIZE, 1);
  152. off += PAGE_SIZE * m;
  153. }
  154. } else {
  155. unmap_mapping_range(obj->dev->anon_inode->i_mapping,
  156. off, size, 1);
  157. }
  158. entry->obj = NULL;
  159. }
  160. /* Evict a buffer from usergart, if it is mapped there */
  161. static void omap_gem_evict(struct drm_gem_object *obj)
  162. {
  163. struct omap_gem_object *omap_obj = to_omap_bo(obj);
  164. struct omap_drm_private *priv = obj->dev->dev_private;
  165. if (omap_obj->flags & OMAP_BO_TILED_MASK) {
  166. enum tiler_fmt fmt = gem2fmt(omap_obj->flags);
  167. int i;
  168. for (i = 0; i < NUM_USERGART_ENTRIES; i++) {
  169. struct omap_drm_usergart_entry *entry =
  170. &priv->usergart[fmt].entry[i];
  171. if (entry->obj == obj)
  172. omap_gem_evict_entry(obj, fmt, entry);
  173. }
  174. }
  175. }
  176. /* -----------------------------------------------------------------------------
  177. * Page Management
  178. */
  179. /*
  180. * Ensure backing pages are allocated. Must be called with the omap_obj.lock
  181. * held.
  182. */
  183. static int omap_gem_attach_pages(struct drm_gem_object *obj)
  184. {
  185. struct drm_device *dev = obj->dev;
  186. struct omap_gem_object *omap_obj = to_omap_bo(obj);
  187. struct page **pages;
  188. int npages = obj->size >> PAGE_SHIFT;
  189. int i, ret;
  190. dma_addr_t *addrs;
  191. lockdep_assert_held(&omap_obj->lock);
  192. /*
  193. * If not using shmem (in which case backing pages don't need to be
  194. * allocated) or if pages are already allocated we're done.
  195. */
  196. if (!(omap_obj->flags & OMAP_BO_MEM_SHMEM) || omap_obj->pages)
  197. return 0;
  198. pages = drm_gem_get_pages(obj);
  199. if (IS_ERR(pages)) {
  200. dev_err(obj->dev->dev, "could not get pages: %ld\n", PTR_ERR(pages));
  201. return PTR_ERR(pages);
  202. }
  203. /* for non-cached buffers, ensure the new pages are clean because
  204. * DSS, GPU, etc. are not cache coherent:
  205. */
  206. if (omap_obj->flags & (OMAP_BO_WC|OMAP_BO_UNCACHED)) {
  207. addrs = kmalloc_array(npages, sizeof(*addrs), GFP_KERNEL);
  208. if (!addrs) {
  209. ret = -ENOMEM;
  210. goto free_pages;
  211. }
  212. for (i = 0; i < npages; i++) {
  213. addrs[i] = dma_map_page(dev->dev, pages[i],
  214. 0, PAGE_SIZE, DMA_TO_DEVICE);
  215. if (dma_mapping_error(dev->dev, addrs[i])) {
  216. dev_warn(dev->dev,
  217. "%s: failed to map page\n", __func__);
  218. for (i = i - 1; i >= 0; --i) {
  219. dma_unmap_page(dev->dev, addrs[i],
  220. PAGE_SIZE, DMA_TO_DEVICE);
  221. }
  222. ret = -ENOMEM;
  223. goto free_addrs;
  224. }
  225. }
  226. } else {
  227. addrs = kcalloc(npages, sizeof(*addrs), GFP_KERNEL);
  228. if (!addrs) {
  229. ret = -ENOMEM;
  230. goto free_pages;
  231. }
  232. }
  233. omap_obj->dma_addrs = addrs;
  234. omap_obj->pages = pages;
  235. return 0;
  236. free_addrs:
  237. kfree(addrs);
  238. free_pages:
  239. drm_gem_put_pages(obj, pages, true, false);
  240. return ret;
  241. }
  242. /* Release backing pages. Must be called with the omap_obj.lock held. */
  243. static void omap_gem_detach_pages(struct drm_gem_object *obj)
  244. {
  245. struct omap_gem_object *omap_obj = to_omap_bo(obj);
  246. unsigned int npages = obj->size >> PAGE_SHIFT;
  247. unsigned int i;
  248. lockdep_assert_held(&omap_obj->lock);
  249. for (i = 0; i < npages; i++) {
  250. if (omap_obj->dma_addrs[i])
  251. dma_unmap_page(obj->dev->dev, omap_obj->dma_addrs[i],
  252. PAGE_SIZE, DMA_TO_DEVICE);
  253. }
  254. kfree(omap_obj->dma_addrs);
  255. omap_obj->dma_addrs = NULL;
  256. drm_gem_put_pages(obj, omap_obj->pages, true, false);
  257. omap_obj->pages = NULL;
  258. }
  259. /* get buffer flags */
  260. u32 omap_gem_flags(struct drm_gem_object *obj)
  261. {
  262. return to_omap_bo(obj)->flags;
  263. }
  264. /** get mmap size */
  265. size_t omap_gem_mmap_size(struct drm_gem_object *obj)
  266. {
  267. struct omap_gem_object *omap_obj = to_omap_bo(obj);
  268. size_t size = obj->size;
  269. if (omap_obj->flags & OMAP_BO_TILED_MASK) {
  270. /* for tiled buffers, the virtual size has stride rounded up
  271. * to 4kb.. (to hide the fact that row n+1 might start 16kb or
  272. * 32kb later!). But we don't back the entire buffer with
  273. * pages, only the valid picture part.. so need to adjust for
  274. * this in the size used to mmap and generate mmap offset
  275. */
  276. size = tiler_vsize(gem2fmt(omap_obj->flags),
  277. omap_obj->width, omap_obj->height);
  278. }
  279. return size;
  280. }
  281. /* -----------------------------------------------------------------------------
  282. * Fault Handling
  283. */
  284. /* Normal handling for the case of faulting in non-tiled buffers */
  285. static vm_fault_t omap_gem_fault_1d(struct drm_gem_object *obj,
  286. struct vm_area_struct *vma, struct vm_fault *vmf)
  287. {
  288. struct omap_gem_object *omap_obj = to_omap_bo(obj);
  289. unsigned long pfn;
  290. pgoff_t pgoff;
  291. /* We don't use vmf->pgoff since that has the fake offset: */
  292. pgoff = (vmf->address - vma->vm_start) >> PAGE_SHIFT;
  293. if (omap_obj->pages) {
  294. omap_gem_cpu_sync_page(obj, pgoff);
  295. pfn = page_to_pfn(omap_obj->pages[pgoff]);
  296. } else {
  297. BUG_ON(!omap_gem_is_contiguous(omap_obj));
  298. pfn = (omap_obj->dma_addr >> PAGE_SHIFT) + pgoff;
  299. }
  300. VERB("Inserting %p pfn %lx, pa %lx", (void *)vmf->address,
  301. pfn, pfn << PAGE_SHIFT);
  302. return vmf_insert_mixed(vma, vmf->address,
  303. __pfn_to_pfn_t(pfn, PFN_DEV));
  304. }
  305. /* Special handling for the case of faulting in 2d tiled buffers */
  306. static vm_fault_t omap_gem_fault_2d(struct drm_gem_object *obj,
  307. struct vm_area_struct *vma, struct vm_fault *vmf)
  308. {
  309. struct omap_gem_object *omap_obj = to_omap_bo(obj);
  310. struct omap_drm_private *priv = obj->dev->dev_private;
  311. struct omap_drm_usergart_entry *entry;
  312. enum tiler_fmt fmt = gem2fmt(omap_obj->flags);
  313. struct page *pages[64]; /* XXX is this too much to have on stack? */
  314. unsigned long pfn;
  315. pgoff_t pgoff, base_pgoff;
  316. unsigned long vaddr;
  317. int i, err, slots;
  318. vm_fault_t ret = VM_FAULT_NOPAGE;
  319. /*
  320. * Note the height of the slot is also equal to the number of pages
  321. * that need to be mapped in to fill 4kb wide CPU page. If the slot
  322. * height is 64, then 64 pages fill a 4kb wide by 64 row region.
  323. */
  324. const int n = priv->usergart[fmt].height;
  325. const int n_shift = priv->usergart[fmt].height_shift;
  326. /*
  327. * If buffer width in bytes > PAGE_SIZE then the virtual stride is
  328. * rounded up to next multiple of PAGE_SIZE.. this need to be taken
  329. * into account in some of the math, so figure out virtual stride
  330. * in pages
  331. */
  332. const int m = DIV_ROUND_UP(omap_obj->width << fmt, PAGE_SIZE);
  333. /* We don't use vmf->pgoff since that has the fake offset: */
  334. pgoff = (vmf->address - vma->vm_start) >> PAGE_SHIFT;
  335. /*
  336. * Actual address we start mapping at is rounded down to previous slot
  337. * boundary in the y direction:
  338. */
  339. base_pgoff = round_down(pgoff, m << n_shift);
  340. /* figure out buffer width in slots */
  341. slots = omap_obj->width >> priv->usergart[fmt].slot_shift;
  342. vaddr = vmf->address - ((pgoff - base_pgoff) << PAGE_SHIFT);
  343. entry = &priv->usergart[fmt].entry[priv->usergart[fmt].last];
  344. /* evict previous buffer using this usergart entry, if any: */
  345. if (entry->obj)
  346. omap_gem_evict_entry(entry->obj, fmt, entry);
  347. entry->obj = obj;
  348. entry->obj_pgoff = base_pgoff;
  349. /* now convert base_pgoff to phys offset from virt offset: */
  350. base_pgoff = (base_pgoff >> n_shift) * slots;
  351. /* for wider-than 4k.. figure out which part of the slot-row we want: */
  352. if (m > 1) {
  353. int off = pgoff % m;
  354. entry->obj_pgoff += off;
  355. base_pgoff /= m;
  356. slots = min(slots - (off << n_shift), n);
  357. base_pgoff += off << n_shift;
  358. vaddr += off << PAGE_SHIFT;
  359. }
  360. /*
  361. * Map in pages. Beyond the valid pixel part of the buffer, we set
  362. * pages[i] to NULL to get a dummy page mapped in.. if someone
  363. * reads/writes it they will get random/undefined content, but at
  364. * least it won't be corrupting whatever other random page used to
  365. * be mapped in, or other undefined behavior.
  366. */
  367. memcpy(pages, &omap_obj->pages[base_pgoff],
  368. sizeof(struct page *) * slots);
  369. memset(pages + slots, 0,
  370. sizeof(struct page *) * (n - slots));
  371. err = tiler_pin(entry->block, pages, ARRAY_SIZE(pages), 0, true);
  372. if (err) {
  373. ret = vmf_error(err);
  374. dev_err(obj->dev->dev, "failed to pin: %d\n", err);
  375. return ret;
  376. }
  377. pfn = entry->dma_addr >> PAGE_SHIFT;
  378. VERB("Inserting %p pfn %lx, pa %lx", (void *)vmf->address,
  379. pfn, pfn << PAGE_SHIFT);
  380. for (i = n; i > 0; i--) {
  381. ret = vmf_insert_mixed(vma,
  382. vaddr, __pfn_to_pfn_t(pfn, PFN_DEV));
  383. if (ret & VM_FAULT_ERROR)
  384. break;
  385. pfn += priv->usergart[fmt].stride_pfn;
  386. vaddr += PAGE_SIZE * m;
  387. }
  388. /* simple round-robin: */
  389. priv->usergart[fmt].last = (priv->usergart[fmt].last + 1)
  390. % NUM_USERGART_ENTRIES;
  391. return ret;
  392. }
  393. /**
  394. * omap_gem_fault - pagefault handler for GEM objects
  395. * @vmf: fault detail
  396. *
  397. * Invoked when a fault occurs on an mmap of a GEM managed area. GEM
  398. * does most of the work for us including the actual map/unmap calls
  399. * but we need to do the actual page work.
  400. *
  401. * The VMA was set up by GEM. In doing so it also ensured that the
  402. * vma->vm_private_data points to the GEM object that is backing this
  403. * mapping.
  404. */
  405. static vm_fault_t omap_gem_fault(struct vm_fault *vmf)
  406. {
  407. struct vm_area_struct *vma = vmf->vma;
  408. struct drm_gem_object *obj = vma->vm_private_data;
  409. struct omap_gem_object *omap_obj = to_omap_bo(obj);
  410. int err;
  411. vm_fault_t ret;
  412. /* Make sure we don't parallel update on a fault, nor move or remove
  413. * something from beneath our feet
  414. */
  415. mutex_lock(&omap_obj->lock);
  416. /* if a shmem backed object, make sure we have pages attached now */
  417. err = omap_gem_attach_pages(obj);
  418. if (err) {
  419. ret = vmf_error(err);
  420. goto fail;
  421. }
  422. /* where should we do corresponding put_pages().. we are mapping
  423. * the original page, rather than thru a GART, so we can't rely
  424. * on eviction to trigger this. But munmap() or all mappings should
  425. * probably trigger put_pages()?
  426. */
  427. if (omap_obj->flags & OMAP_BO_TILED_MASK)
  428. ret = omap_gem_fault_2d(obj, vma, vmf);
  429. else
  430. ret = omap_gem_fault_1d(obj, vma, vmf);
  431. fail:
  432. mutex_unlock(&omap_obj->lock);
  433. return ret;
  434. }
  435. /** We override mainly to fix up some of the vm mapping flags.. */
  436. int omap_gem_mmap(struct file *filp, struct vm_area_struct *vma)
  437. {
  438. int ret;
  439. ret = drm_gem_mmap(filp, vma);
  440. if (ret) {
  441. DBG("mmap failed: %d", ret);
  442. return ret;
  443. }
  444. return omap_gem_mmap_obj(vma->vm_private_data, vma);
  445. }
  446. int omap_gem_mmap_obj(struct drm_gem_object *obj,
  447. struct vm_area_struct *vma)
  448. {
  449. struct omap_gem_object *omap_obj = to_omap_bo(obj);
  450. vm_flags_mod(vma, VM_MIXEDMAP, VM_PFNMAP);
  451. if (omap_obj->flags & OMAP_BO_WC) {
  452. vma->vm_page_prot = pgprot_writecombine(vm_get_page_prot(vma->vm_flags));
  453. } else if (omap_obj->flags & OMAP_BO_UNCACHED) {
  454. vma->vm_page_prot = pgprot_noncached(vm_get_page_prot(vma->vm_flags));
  455. } else {
  456. /*
  457. * We do have some private objects, at least for scanout buffers
  458. * on hardware without DMM/TILER. But these are allocated write-
  459. * combine
  460. */
  461. if (WARN_ON(!obj->filp))
  462. return -EINVAL;
  463. /*
  464. * Shunt off cached objs to shmem file so they have their own
  465. * address_space (so unmap_mapping_range does what we want,
  466. * in particular in the case of mmap'd dmabufs)
  467. */
  468. vma->vm_pgoff = 0;
  469. vma_set_file(vma, obj->filp);
  470. vma->vm_page_prot = vm_get_page_prot(vma->vm_flags);
  471. }
  472. return 0;
  473. }
  474. /* -----------------------------------------------------------------------------
  475. * Dumb Buffers
  476. */
  477. /**
  478. * omap_gem_dumb_create - create a dumb buffer
  479. * @file: our client file
  480. * @dev: our device
  481. * @args: the requested arguments copied from userspace
  482. *
  483. * Allocate a buffer suitable for use for a frame buffer of the
  484. * form described by user space. Give userspace a handle by which
  485. * to reference it.
  486. */
  487. int omap_gem_dumb_create(struct drm_file *file, struct drm_device *dev,
  488. struct drm_mode_create_dumb *args)
  489. {
  490. union omap_gem_size gsize;
  491. args->pitch = DIV_ROUND_UP(args->width * args->bpp, 8);
  492. args->size = PAGE_ALIGN(args->pitch * args->height);
  493. gsize = (union omap_gem_size){
  494. .bytes = args->size,
  495. };
  496. return omap_gem_new_handle(dev, file, gsize,
  497. OMAP_BO_SCANOUT | OMAP_BO_WC, &args->handle);
  498. }
  499. /**
  500. * omap_gem_dumb_map - buffer mapping for dumb interface
  501. * @file: our drm client file
  502. * @dev: drm device
  503. * @handle: GEM handle to the object (from dumb_create)
  504. * @offset: memory map offset placeholder
  505. *
  506. * Do the necessary setup to allow the mapping of the frame buffer
  507. * into user memory. We don't have to do much here at the moment.
  508. */
  509. int omap_gem_dumb_map_offset(struct drm_file *file, struct drm_device *dev,
  510. u32 handle, u64 *offset)
  511. {
  512. struct drm_gem_object *obj;
  513. int ret = 0;
  514. /* GEM does all our handle to object mapping */
  515. obj = drm_gem_object_lookup(file, handle);
  516. if (obj == NULL) {
  517. ret = -ENOENT;
  518. goto fail;
  519. }
  520. *offset = omap_gem_mmap_offset(obj);
  521. drm_gem_object_put(obj);
  522. fail:
  523. return ret;
  524. }
  525. #ifdef CONFIG_DRM_FBDEV_EMULATION
  526. /* Set scrolling position. This allows us to implement fast scrolling
  527. * for console.
  528. *
  529. * Call only from non-atomic contexts.
  530. */
  531. int omap_gem_roll(struct drm_gem_object *obj, u32 roll)
  532. {
  533. struct omap_gem_object *omap_obj = to_omap_bo(obj);
  534. u32 npages = obj->size >> PAGE_SHIFT;
  535. int ret = 0;
  536. if (roll > npages) {
  537. dev_err(obj->dev->dev, "invalid roll: %d\n", roll);
  538. return -EINVAL;
  539. }
  540. omap_obj->roll = roll;
  541. mutex_lock(&omap_obj->lock);
  542. /* if we aren't mapped yet, we don't need to do anything */
  543. if (omap_obj->block) {
  544. ret = omap_gem_attach_pages(obj);
  545. if (ret)
  546. goto fail;
  547. ret = tiler_pin(omap_obj->block, omap_obj->pages, npages,
  548. roll, true);
  549. if (ret)
  550. dev_err(obj->dev->dev, "could not repin: %d\n", ret);
  551. }
  552. fail:
  553. mutex_unlock(&omap_obj->lock);
  554. return ret;
  555. }
  556. #endif
  557. /* -----------------------------------------------------------------------------
  558. * Memory Management & DMA Sync
  559. */
  560. /*
  561. * shmem buffers that are mapped cached are not coherent.
  562. *
  563. * We keep track of dirty pages using page faulting to perform cache management.
  564. * When a page is mapped to the CPU in read/write mode the device can't access
  565. * it and omap_obj->dma_addrs[i] is NULL. When a page is mapped to the device
  566. * the omap_obj->dma_addrs[i] is set to the DMA address, and the page is
  567. * unmapped from the CPU.
  568. */
  569. static inline bool omap_gem_is_cached_coherent(struct drm_gem_object *obj)
  570. {
  571. struct omap_gem_object *omap_obj = to_omap_bo(obj);
  572. return !((omap_obj->flags & OMAP_BO_MEM_SHMEM) &&
  573. ((omap_obj->flags & OMAP_BO_CACHE_MASK) == OMAP_BO_CACHED));
  574. }
  575. /* Sync the buffer for CPU access.. note pages should already be
  576. * attached, ie. omap_gem_get_pages()
  577. */
  578. void omap_gem_cpu_sync_page(struct drm_gem_object *obj, int pgoff)
  579. {
  580. struct drm_device *dev = obj->dev;
  581. struct omap_gem_object *omap_obj = to_omap_bo(obj);
  582. if (omap_gem_is_cached_coherent(obj))
  583. return;
  584. if (omap_obj->dma_addrs[pgoff]) {
  585. dma_unmap_page(dev->dev, omap_obj->dma_addrs[pgoff],
  586. PAGE_SIZE, DMA_TO_DEVICE);
  587. omap_obj->dma_addrs[pgoff] = 0;
  588. }
  589. }
  590. /* sync the buffer for DMA access */
  591. void omap_gem_dma_sync_buffer(struct drm_gem_object *obj,
  592. enum dma_data_direction dir)
  593. {
  594. struct drm_device *dev = obj->dev;
  595. struct omap_gem_object *omap_obj = to_omap_bo(obj);
  596. int i, npages = obj->size >> PAGE_SHIFT;
  597. struct page **pages = omap_obj->pages;
  598. bool dirty = false;
  599. if (omap_gem_is_cached_coherent(obj))
  600. return;
  601. for (i = 0; i < npages; i++) {
  602. if (!omap_obj->dma_addrs[i]) {
  603. dma_addr_t addr;
  604. addr = dma_map_page(dev->dev, pages[i], 0,
  605. PAGE_SIZE, dir);
  606. if (dma_mapping_error(dev->dev, addr)) {
  607. dev_warn(dev->dev, "%s: failed to map page\n",
  608. __func__);
  609. break;
  610. }
  611. dirty = true;
  612. omap_obj->dma_addrs[i] = addr;
  613. }
  614. }
  615. if (dirty) {
  616. unmap_mapping_range(obj->filp->f_mapping, 0,
  617. omap_gem_mmap_size(obj), 1);
  618. }
  619. }
  620. static int omap_gem_pin_tiler(struct drm_gem_object *obj)
  621. {
  622. struct omap_gem_object *omap_obj = to_omap_bo(obj);
  623. u32 npages = obj->size >> PAGE_SHIFT;
  624. enum tiler_fmt fmt = gem2fmt(omap_obj->flags);
  625. struct tiler_block *block;
  626. int ret;
  627. BUG_ON(omap_obj->block);
  628. if (omap_obj->flags & OMAP_BO_TILED_MASK) {
  629. block = tiler_reserve_2d(fmt, omap_obj->width, omap_obj->height,
  630. PAGE_SIZE);
  631. } else {
  632. block = tiler_reserve_1d(obj->size);
  633. }
  634. if (IS_ERR(block)) {
  635. ret = PTR_ERR(block);
  636. dev_err(obj->dev->dev, "could not remap: %d (%d)\n", ret, fmt);
  637. goto fail;
  638. }
  639. /* TODO: enable async refill.. */
  640. ret = tiler_pin(block, omap_obj->pages, npages, omap_obj->roll, true);
  641. if (ret) {
  642. tiler_release(block);
  643. dev_err(obj->dev->dev, "could not pin: %d\n", ret);
  644. goto fail;
  645. }
  646. omap_obj->dma_addr = tiler_ssptr(block);
  647. omap_obj->block = block;
  648. DBG("got dma address: %pad", &omap_obj->dma_addr);
  649. fail:
  650. return ret;
  651. }
  652. /**
  653. * omap_gem_pin() - Pin a GEM object in memory
  654. * @obj: the GEM object
  655. * @dma_addr: the DMA address
  656. *
  657. * Pin the given GEM object in memory and fill the dma_addr pointer with the
  658. * object's DMA address. If the buffer is not physically contiguous it will be
  659. * remapped through the TILER to provide a contiguous view.
  660. *
  661. * Pins are reference-counted, calling this function multiple times is allowed
  662. * as long the corresponding omap_gem_unpin() calls are balanced.
  663. *
  664. * Return 0 on success or a negative error code otherwise.
  665. */
  666. int omap_gem_pin(struct drm_gem_object *obj, dma_addr_t *dma_addr)
  667. {
  668. struct omap_drm_private *priv = obj->dev->dev_private;
  669. struct omap_gem_object *omap_obj = to_omap_bo(obj);
  670. int ret = 0;
  671. mutex_lock(&omap_obj->lock);
  672. if (!omap_gem_is_contiguous(omap_obj)) {
  673. if (refcount_read(&omap_obj->pin_cnt) == 0) {
  674. refcount_set(&omap_obj->pin_cnt, 1);
  675. ret = omap_gem_attach_pages(obj);
  676. if (ret)
  677. goto fail;
  678. if (omap_obj->flags & OMAP_BO_SCANOUT) {
  679. if (priv->has_dmm) {
  680. ret = omap_gem_pin_tiler(obj);
  681. if (ret)
  682. goto fail;
  683. }
  684. }
  685. } else {
  686. refcount_inc(&omap_obj->pin_cnt);
  687. }
  688. }
  689. if (dma_addr)
  690. *dma_addr = omap_obj->dma_addr;
  691. fail:
  692. mutex_unlock(&omap_obj->lock);
  693. return ret;
  694. }
  695. /**
  696. * omap_gem_unpin_locked() - Unpin a GEM object from memory
  697. * @obj: the GEM object
  698. *
  699. * omap_gem_unpin() without locking.
  700. */
  701. static void omap_gem_unpin_locked(struct drm_gem_object *obj)
  702. {
  703. struct omap_drm_private *priv = obj->dev->dev_private;
  704. struct omap_gem_object *omap_obj = to_omap_bo(obj);
  705. int ret;
  706. if (omap_gem_is_contiguous(omap_obj))
  707. return;
  708. if (refcount_dec_and_test(&omap_obj->pin_cnt)) {
  709. if (omap_obj->sgt) {
  710. sg_free_table(omap_obj->sgt);
  711. kfree(omap_obj->sgt);
  712. omap_obj->sgt = NULL;
  713. }
  714. if (!(omap_obj->flags & OMAP_BO_SCANOUT))
  715. return;
  716. if (priv->has_dmm) {
  717. ret = tiler_unpin(omap_obj->block);
  718. if (ret) {
  719. dev_err(obj->dev->dev,
  720. "could not unpin pages: %d\n", ret);
  721. }
  722. ret = tiler_release(omap_obj->block);
  723. if (ret) {
  724. dev_err(obj->dev->dev,
  725. "could not release unmap: %d\n", ret);
  726. }
  727. omap_obj->dma_addr = 0;
  728. omap_obj->block = NULL;
  729. }
  730. }
  731. }
  732. /**
  733. * omap_gem_unpin() - Unpin a GEM object from memory
  734. * @obj: the GEM object
  735. *
  736. * Unpin the given GEM object previously pinned with omap_gem_pin(). Pins are
  737. * reference-counted, the actual unpin will only be performed when the number
  738. * of calls to this function matches the number of calls to omap_gem_pin().
  739. */
  740. void omap_gem_unpin(struct drm_gem_object *obj)
  741. {
  742. struct omap_gem_object *omap_obj = to_omap_bo(obj);
  743. mutex_lock(&omap_obj->lock);
  744. omap_gem_unpin_locked(obj);
  745. mutex_unlock(&omap_obj->lock);
  746. }
  747. /* Get rotated scanout address (only valid if already pinned), at the
  748. * specified orientation and x,y offset from top-left corner of buffer
  749. * (only valid for tiled 2d buffers)
  750. */
  751. int omap_gem_rotated_dma_addr(struct drm_gem_object *obj, u32 orient,
  752. int x, int y, dma_addr_t *dma_addr)
  753. {
  754. struct omap_gem_object *omap_obj = to_omap_bo(obj);
  755. int ret = -EINVAL;
  756. mutex_lock(&omap_obj->lock);
  757. if ((refcount_read(&omap_obj->pin_cnt) > 0) && omap_obj->block &&
  758. (omap_obj->flags & OMAP_BO_TILED_MASK)) {
  759. *dma_addr = tiler_tsptr(omap_obj->block, orient, x, y);
  760. ret = 0;
  761. }
  762. mutex_unlock(&omap_obj->lock);
  763. return ret;
  764. }
  765. /* Get tiler stride for the buffer (only valid for 2d tiled buffers) */
  766. int omap_gem_tiled_stride(struct drm_gem_object *obj, u32 orient)
  767. {
  768. struct omap_gem_object *omap_obj = to_omap_bo(obj);
  769. int ret = -EINVAL;
  770. if (omap_obj->flags & OMAP_BO_TILED_MASK)
  771. ret = tiler_stride(gem2fmt(omap_obj->flags), orient);
  772. return ret;
  773. }
  774. /* if !remap, and we don't have pages backing, then fail, rather than
  775. * increasing the pin count (which we don't really do yet anyways,
  776. * because we don't support swapping pages back out). And 'remap'
  777. * might not be quite the right name, but I wanted to keep it working
  778. * similarly to omap_gem_pin(). Note though that mutex is not
  779. * aquired if !remap (because this can be called in atomic ctxt),
  780. * but probably omap_gem_unpin() should be changed to work in the
  781. * same way. If !remap, a matching omap_gem_put_pages() call is not
  782. * required (and should not be made).
  783. */
  784. int omap_gem_get_pages(struct drm_gem_object *obj, struct page ***pages,
  785. bool remap)
  786. {
  787. struct omap_gem_object *omap_obj = to_omap_bo(obj);
  788. int ret = 0;
  789. mutex_lock(&omap_obj->lock);
  790. if (remap) {
  791. ret = omap_gem_attach_pages(obj);
  792. if (ret)
  793. goto unlock;
  794. }
  795. if (!omap_obj->pages) {
  796. ret = -ENOMEM;
  797. goto unlock;
  798. }
  799. *pages = omap_obj->pages;
  800. unlock:
  801. mutex_unlock(&omap_obj->lock);
  802. return ret;
  803. }
  804. /* release pages when DMA no longer being performed */
  805. int omap_gem_put_pages(struct drm_gem_object *obj)
  806. {
  807. /* do something here if we dynamically attach/detach pages.. at
  808. * least they would no longer need to be pinned if everyone has
  809. * released the pages..
  810. */
  811. return 0;
  812. }
  813. struct sg_table *omap_gem_get_sg(struct drm_gem_object *obj,
  814. enum dma_data_direction dir)
  815. {
  816. struct omap_gem_object *omap_obj = to_omap_bo(obj);
  817. dma_addr_t addr;
  818. struct sg_table *sgt;
  819. struct scatterlist *sg;
  820. unsigned int count, len, stride, i;
  821. int ret;
  822. ret = omap_gem_pin(obj, &addr);
  823. if (ret)
  824. return ERR_PTR(ret);
  825. mutex_lock(&omap_obj->lock);
  826. sgt = omap_obj->sgt;
  827. if (sgt)
  828. goto out;
  829. sgt = kzalloc(sizeof(*sgt), GFP_KERNEL);
  830. if (!sgt) {
  831. ret = -ENOMEM;
  832. goto err_unpin;
  833. }
  834. if (addr) {
  835. if (omap_obj->flags & OMAP_BO_TILED_MASK) {
  836. enum tiler_fmt fmt = gem2fmt(omap_obj->flags);
  837. len = omap_obj->width << (int)fmt;
  838. count = omap_obj->height;
  839. stride = tiler_stride(fmt, 0);
  840. } else {
  841. len = obj->size;
  842. count = 1;
  843. stride = 0;
  844. }
  845. } else {
  846. count = obj->size >> PAGE_SHIFT;
  847. }
  848. ret = sg_alloc_table(sgt, count, GFP_KERNEL);
  849. if (ret)
  850. goto err_free;
  851. /* this must be after omap_gem_pin() to ensure we have pages attached */
  852. omap_gem_dma_sync_buffer(obj, dir);
  853. if (addr) {
  854. for_each_sg(sgt->sgl, sg, count, i) {
  855. sg_set_page(sg, phys_to_page(addr), len,
  856. offset_in_page(addr));
  857. sg_dma_address(sg) = addr;
  858. sg_dma_len(sg) = len;
  859. addr += stride;
  860. }
  861. } else {
  862. for_each_sg(sgt->sgl, sg, count, i) {
  863. sg_set_page(sg, omap_obj->pages[i], PAGE_SIZE, 0);
  864. sg_dma_address(sg) = omap_obj->dma_addrs[i];
  865. sg_dma_len(sg) = PAGE_SIZE;
  866. }
  867. }
  868. omap_obj->sgt = sgt;
  869. out:
  870. mutex_unlock(&omap_obj->lock);
  871. return sgt;
  872. err_free:
  873. kfree(sgt);
  874. err_unpin:
  875. mutex_unlock(&omap_obj->lock);
  876. omap_gem_unpin(obj);
  877. return ERR_PTR(ret);
  878. }
  879. void omap_gem_put_sg(struct drm_gem_object *obj, struct sg_table *sgt)
  880. {
  881. struct omap_gem_object *omap_obj = to_omap_bo(obj);
  882. if (WARN_ON(omap_obj->sgt != sgt))
  883. return;
  884. omap_gem_unpin(obj);
  885. }
  886. #ifdef CONFIG_DRM_FBDEV_EMULATION
  887. /*
  888. * Get kernel virtual address for CPU access.. this more or less only
  889. * exists for omap_fbdev.
  890. */
  891. void *omap_gem_vaddr(struct drm_gem_object *obj)
  892. {
  893. struct omap_gem_object *omap_obj = to_omap_bo(obj);
  894. void *vaddr;
  895. int ret;
  896. mutex_lock(&omap_obj->lock);
  897. if (!omap_obj->vaddr) {
  898. ret = omap_gem_attach_pages(obj);
  899. if (ret) {
  900. vaddr = ERR_PTR(ret);
  901. goto unlock;
  902. }
  903. omap_obj->vaddr = vmap(omap_obj->pages, obj->size >> PAGE_SHIFT,
  904. VM_MAP, pgprot_writecombine(PAGE_KERNEL));
  905. }
  906. vaddr = omap_obj->vaddr;
  907. unlock:
  908. mutex_unlock(&omap_obj->lock);
  909. return vaddr;
  910. }
  911. #endif
  912. /* -----------------------------------------------------------------------------
  913. * Power Management
  914. */
  915. #ifdef CONFIG_PM
  916. /* re-pin objects in DMM in resume path: */
  917. int omap_gem_resume(struct drm_device *dev)
  918. {
  919. struct omap_drm_private *priv = dev->dev_private;
  920. struct omap_gem_object *omap_obj;
  921. int ret = 0;
  922. mutex_lock(&priv->list_lock);
  923. list_for_each_entry(omap_obj, &priv->obj_list, mm_list) {
  924. if (omap_obj->block) {
  925. struct drm_gem_object *obj = &omap_obj->base;
  926. u32 npages = obj->size >> PAGE_SHIFT;
  927. WARN_ON(!omap_obj->pages); /* this can't happen */
  928. ret = tiler_pin(omap_obj->block,
  929. omap_obj->pages, npages,
  930. omap_obj->roll, true);
  931. if (ret) {
  932. dev_err(dev->dev, "could not repin: %d\n", ret);
  933. goto done;
  934. }
  935. }
  936. }
  937. done:
  938. mutex_unlock(&priv->list_lock);
  939. return ret;
  940. }
  941. #endif
  942. /* -----------------------------------------------------------------------------
  943. * DebugFS
  944. */
  945. #ifdef CONFIG_DEBUG_FS
  946. void omap_gem_describe(struct drm_gem_object *obj, struct seq_file *m)
  947. {
  948. struct omap_gem_object *omap_obj = to_omap_bo(obj);
  949. u64 off;
  950. off = drm_vma_node_start(&obj->vma_node);
  951. mutex_lock(&omap_obj->lock);
  952. seq_printf(m, "%08x: %2d (%2d) %08llx %pad (%2d) %p %4d",
  953. omap_obj->flags, obj->name, kref_read(&obj->refcount),
  954. off, &omap_obj->dma_addr,
  955. refcount_read(&omap_obj->pin_cnt),
  956. omap_obj->vaddr, omap_obj->roll);
  957. if (omap_obj->flags & OMAP_BO_TILED_MASK) {
  958. seq_printf(m, " %dx%d", omap_obj->width, omap_obj->height);
  959. if (omap_obj->block) {
  960. struct tcm_area *area = &omap_obj->block->area;
  961. seq_printf(m, " (%dx%d, %dx%d)",
  962. area->p0.x, area->p0.y,
  963. area->p1.x, area->p1.y);
  964. }
  965. } else {
  966. seq_printf(m, " %zu", obj->size);
  967. }
  968. mutex_unlock(&omap_obj->lock);
  969. seq_printf(m, "\n");
  970. }
  971. void omap_gem_describe_objects(struct list_head *list, struct seq_file *m)
  972. {
  973. struct omap_gem_object *omap_obj;
  974. int count = 0;
  975. size_t size = 0;
  976. list_for_each_entry(omap_obj, list, mm_list) {
  977. struct drm_gem_object *obj = &omap_obj->base;
  978. seq_printf(m, " ");
  979. omap_gem_describe(obj, m);
  980. count++;
  981. size += obj->size;
  982. }
  983. seq_printf(m, "Total %d objects, %zu bytes\n", count, size);
  984. }
  985. #endif
  986. /* -----------------------------------------------------------------------------
  987. * Constructor & Destructor
  988. */
  989. static void omap_gem_free_object(struct drm_gem_object *obj)
  990. {
  991. struct drm_device *dev = obj->dev;
  992. struct omap_drm_private *priv = dev->dev_private;
  993. struct omap_gem_object *omap_obj = to_omap_bo(obj);
  994. omap_gem_evict(obj);
  995. mutex_lock(&priv->list_lock);
  996. list_del(&omap_obj->mm_list);
  997. mutex_unlock(&priv->list_lock);
  998. /*
  999. * We own the sole reference to the object at this point, but to keep
  1000. * lockdep happy, we must still take the omap_obj_lock to call
  1001. * omap_gem_detach_pages(). This should hardly make any difference as
  1002. * there can't be any lock contention.
  1003. */
  1004. mutex_lock(&omap_obj->lock);
  1005. /* The object should not be pinned. */
  1006. WARN_ON(refcount_read(&omap_obj->pin_cnt) > 0);
  1007. if (omap_obj->pages) {
  1008. if (omap_obj->flags & OMAP_BO_MEM_DMABUF)
  1009. kfree(omap_obj->pages);
  1010. else
  1011. omap_gem_detach_pages(obj);
  1012. }
  1013. if (omap_obj->flags & OMAP_BO_MEM_DMA_API) {
  1014. dma_free_wc(dev->dev, obj->size, omap_obj->vaddr,
  1015. omap_obj->dma_addr);
  1016. } else if (omap_obj->vaddr) {
  1017. vunmap(omap_obj->vaddr);
  1018. } else if (obj->import_attach) {
  1019. drm_prime_gem_destroy(obj, omap_obj->sgt);
  1020. }
  1021. mutex_unlock(&omap_obj->lock);
  1022. drm_gem_object_release(obj);
  1023. mutex_destroy(&omap_obj->lock);
  1024. kfree(omap_obj);
  1025. }
  1026. static bool omap_gem_validate_flags(struct drm_device *dev, u32 flags)
  1027. {
  1028. struct omap_drm_private *priv = dev->dev_private;
  1029. switch (flags & OMAP_BO_CACHE_MASK) {
  1030. case OMAP_BO_CACHED:
  1031. case OMAP_BO_WC:
  1032. case OMAP_BO_CACHE_MASK:
  1033. break;
  1034. default:
  1035. return false;
  1036. }
  1037. if (flags & OMAP_BO_TILED_MASK) {
  1038. if (!priv->usergart)
  1039. return false;
  1040. switch (flags & OMAP_BO_TILED_MASK) {
  1041. case OMAP_BO_TILED_8:
  1042. case OMAP_BO_TILED_16:
  1043. case OMAP_BO_TILED_32:
  1044. break;
  1045. default:
  1046. return false;
  1047. }
  1048. }
  1049. return true;
  1050. }
  1051. static const struct vm_operations_struct omap_gem_vm_ops = {
  1052. .fault = omap_gem_fault,
  1053. .open = drm_gem_vm_open,
  1054. .close = drm_gem_vm_close,
  1055. };
  1056. static const struct drm_gem_object_funcs omap_gem_object_funcs = {
  1057. .free = omap_gem_free_object,
  1058. .export = omap_gem_prime_export,
  1059. .vm_ops = &omap_gem_vm_ops,
  1060. };
  1061. /* GEM buffer object constructor */
  1062. struct drm_gem_object *omap_gem_new(struct drm_device *dev,
  1063. union omap_gem_size gsize, u32 flags)
  1064. {
  1065. struct omap_drm_private *priv = dev->dev_private;
  1066. struct omap_gem_object *omap_obj;
  1067. struct drm_gem_object *obj;
  1068. struct address_space *mapping;
  1069. size_t size;
  1070. int ret;
  1071. if (!omap_gem_validate_flags(dev, flags))
  1072. return NULL;
  1073. /* Validate the flags and compute the memory and cache flags. */
  1074. if (flags & OMAP_BO_TILED_MASK) {
  1075. /*
  1076. * Tiled buffers are always shmem paged backed. When they are
  1077. * scanned out, they are remapped into DMM/TILER.
  1078. */
  1079. flags |= OMAP_BO_MEM_SHMEM;
  1080. /*
  1081. * Currently don't allow cached buffers. There is some caching
  1082. * stuff that needs to be handled better.
  1083. */
  1084. flags &= ~(OMAP_BO_CACHED|OMAP_BO_WC|OMAP_BO_UNCACHED);
  1085. flags |= tiler_get_cpu_cache_flags();
  1086. } else if ((flags & OMAP_BO_SCANOUT) && !priv->has_dmm) {
  1087. /*
  1088. * If we don't have DMM, we must allocate scanout buffers
  1089. * from contiguous DMA memory.
  1090. */
  1091. flags |= OMAP_BO_MEM_DMA_API;
  1092. } else if (!(flags & OMAP_BO_MEM_DMABUF)) {
  1093. /*
  1094. * All other buffers not backed by dma_buf are shmem-backed.
  1095. */
  1096. flags |= OMAP_BO_MEM_SHMEM;
  1097. }
  1098. /* Allocate the initialize the OMAP GEM object. */
  1099. omap_obj = kzalloc(sizeof(*omap_obj), GFP_KERNEL);
  1100. if (!omap_obj)
  1101. return NULL;
  1102. obj = &omap_obj->base;
  1103. omap_obj->flags = flags;
  1104. mutex_init(&omap_obj->lock);
  1105. if (flags & OMAP_BO_TILED_MASK) {
  1106. /*
  1107. * For tiled buffers align dimensions to slot boundaries and
  1108. * calculate size based on aligned dimensions.
  1109. */
  1110. tiler_align(gem2fmt(flags), &gsize.tiled.width,
  1111. &gsize.tiled.height);
  1112. size = tiler_size(gem2fmt(flags), gsize.tiled.width,
  1113. gsize.tiled.height);
  1114. omap_obj->width = gsize.tiled.width;
  1115. omap_obj->height = gsize.tiled.height;
  1116. } else {
  1117. size = PAGE_ALIGN(gsize.bytes);
  1118. }
  1119. obj->funcs = &omap_gem_object_funcs;
  1120. /* Initialize the GEM object. */
  1121. if (!(flags & OMAP_BO_MEM_SHMEM)) {
  1122. drm_gem_private_object_init(dev, obj, size);
  1123. } else {
  1124. ret = drm_gem_object_init(dev, obj, size);
  1125. if (ret)
  1126. goto err_free;
  1127. mapping = obj->filp->f_mapping;
  1128. mapping_set_gfp_mask(mapping, GFP_USER | __GFP_DMA32);
  1129. }
  1130. /* Allocate memory if needed. */
  1131. if (flags & OMAP_BO_MEM_DMA_API) {
  1132. omap_obj->vaddr = dma_alloc_wc(dev->dev, size,
  1133. &omap_obj->dma_addr,
  1134. GFP_KERNEL);
  1135. if (!omap_obj->vaddr)
  1136. goto err_release;
  1137. }
  1138. mutex_lock(&priv->list_lock);
  1139. list_add(&omap_obj->mm_list, &priv->obj_list);
  1140. mutex_unlock(&priv->list_lock);
  1141. return obj;
  1142. err_release:
  1143. drm_gem_object_release(obj);
  1144. err_free:
  1145. kfree(omap_obj);
  1146. return NULL;
  1147. }
  1148. struct drm_gem_object *omap_gem_new_dmabuf(struct drm_device *dev, size_t size,
  1149. struct sg_table *sgt)
  1150. {
  1151. struct omap_drm_private *priv = dev->dev_private;
  1152. struct omap_gem_object *omap_obj;
  1153. struct drm_gem_object *obj;
  1154. union omap_gem_size gsize;
  1155. /* Without a DMM only physically contiguous buffers can be supported. */
  1156. if (sgt->orig_nents != 1 && !priv->has_dmm)
  1157. return ERR_PTR(-EINVAL);
  1158. gsize.bytes = PAGE_ALIGN(size);
  1159. obj = omap_gem_new(dev, gsize, OMAP_BO_MEM_DMABUF | OMAP_BO_WC);
  1160. if (!obj)
  1161. return ERR_PTR(-ENOMEM);
  1162. omap_obj = to_omap_bo(obj);
  1163. mutex_lock(&omap_obj->lock);
  1164. omap_obj->sgt = sgt;
  1165. if (sgt->orig_nents == 1) {
  1166. omap_obj->dma_addr = sg_dma_address(sgt->sgl);
  1167. } else {
  1168. /* Create pages list from sgt */
  1169. struct page **pages;
  1170. unsigned int npages;
  1171. unsigned int ret;
  1172. npages = DIV_ROUND_UP(size, PAGE_SIZE);
  1173. pages = kcalloc(npages, sizeof(*pages), GFP_KERNEL);
  1174. if (!pages) {
  1175. omap_gem_free_object(obj);
  1176. obj = ERR_PTR(-ENOMEM);
  1177. goto done;
  1178. }
  1179. omap_obj->pages = pages;
  1180. ret = drm_prime_sg_to_page_array(sgt, pages, npages);
  1181. if (ret) {
  1182. omap_gem_free_object(obj);
  1183. obj = ERR_PTR(-ENOMEM);
  1184. goto done;
  1185. }
  1186. }
  1187. done:
  1188. mutex_unlock(&omap_obj->lock);
  1189. return obj;
  1190. }
  1191. /* convenience method to construct a GEM buffer object, and userspace handle */
  1192. int omap_gem_new_handle(struct drm_device *dev, struct drm_file *file,
  1193. union omap_gem_size gsize, u32 flags, u32 *handle)
  1194. {
  1195. struct drm_gem_object *obj;
  1196. int ret;
  1197. obj = omap_gem_new(dev, gsize, flags);
  1198. if (!obj)
  1199. return -ENOMEM;
  1200. ret = drm_gem_handle_create(file, obj, handle);
  1201. if (ret) {
  1202. omap_gem_free_object(obj);
  1203. return ret;
  1204. }
  1205. /* drop reference from allocate - handle holds it now */
  1206. drm_gem_object_put(obj);
  1207. return 0;
  1208. }
  1209. /* -----------------------------------------------------------------------------
  1210. * Init & Cleanup
  1211. */
  1212. /* If DMM is used, we need to set some stuff up.. */
  1213. void omap_gem_init(struct drm_device *dev)
  1214. {
  1215. struct omap_drm_private *priv = dev->dev_private;
  1216. struct omap_drm_usergart *usergart;
  1217. const enum tiler_fmt fmts[] = {
  1218. TILFMT_8BIT, TILFMT_16BIT, TILFMT_32BIT
  1219. };
  1220. int i, j;
  1221. if (!dmm_is_available()) {
  1222. /* DMM only supported on OMAP4 and later, so this isn't fatal */
  1223. dev_warn(dev->dev, "DMM not available, disable DMM support\n");
  1224. return;
  1225. }
  1226. usergart = kcalloc(3, sizeof(*usergart), GFP_KERNEL);
  1227. if (!usergart)
  1228. return;
  1229. /* reserve 4k aligned/wide regions for userspace mappings: */
  1230. for (i = 0; i < ARRAY_SIZE(fmts); i++) {
  1231. u16 h = 1, w = PAGE_SIZE >> i;
  1232. tiler_align(fmts[i], &w, &h);
  1233. /* note: since each region is 1 4kb page wide, and minimum
  1234. * number of rows, the height ends up being the same as the
  1235. * # of pages in the region
  1236. */
  1237. usergart[i].height = h;
  1238. usergart[i].height_shift = ilog2(h);
  1239. usergart[i].stride_pfn = tiler_stride(fmts[i], 0) >> PAGE_SHIFT;
  1240. usergart[i].slot_shift = ilog2((PAGE_SIZE / h) >> i);
  1241. for (j = 0; j < NUM_USERGART_ENTRIES; j++) {
  1242. struct omap_drm_usergart_entry *entry;
  1243. struct tiler_block *block;
  1244. entry = &usergart[i].entry[j];
  1245. block = tiler_reserve_2d(fmts[i], w, h, PAGE_SIZE);
  1246. if (IS_ERR(block)) {
  1247. dev_err(dev->dev,
  1248. "reserve failed: %d, %d, %ld\n",
  1249. i, j, PTR_ERR(block));
  1250. return;
  1251. }
  1252. entry->dma_addr = tiler_ssptr(block);
  1253. entry->block = block;
  1254. DBG("%d:%d: %dx%d: dma_addr=%pad stride=%d", i, j, w, h,
  1255. &entry->dma_addr,
  1256. usergart[i].stride_pfn << PAGE_SHIFT);
  1257. }
  1258. }
  1259. priv->usergart = usergart;
  1260. priv->has_dmm = true;
  1261. }
  1262. void omap_gem_deinit(struct drm_device *dev)
  1263. {
  1264. struct omap_drm_private *priv = dev->dev_private;
  1265. /* I believe we can rely on there being no more outstanding GEM
  1266. * objects which could depend on usergart/dmm at this point.
  1267. */
  1268. kfree(priv->usergart);
  1269. }