1 // SPDX-License-Identifier: GPL-2.0 OR MIT
2 /* Copyright 2018-2019 Qiang Yu <yuq825@gmail.com> */
3 
4 #include <linux/dma-buf.h>
5 #include <drm/drm_prime.h>
6 #include <drm/drm_drv.h>
7 #include <drm/drm_file.h>
8 
9 #include "lima_device.h"
10 #include "lima_object.h"
11 #include "lima_gem.h"
12 #include "lima_gem_prime.h"
13 
lima_gem_prime_import_sg_table(struct drm_device * dev,struct dma_buf_attachment * attach,struct sg_table * sgt)14 struct drm_gem_object *lima_gem_prime_import_sg_table(
15 	struct drm_device *dev, struct dma_buf_attachment *attach,
16 	struct sg_table *sgt)
17 {
18 	struct lima_device *ldev = to_lima_dev(dev);
19 	struct lima_bo *bo;
20 
21 	bo = lima_bo_create(ldev, attach->dmabuf->size, 0, sgt);
22 	if (IS_ERR(bo))
23 		return ERR_CAST(bo);
24 
25 	return &bo->gem;
26 }
27 
lima_gem_prime_get_sg_table(struct drm_gem_object * obj)28 struct sg_table *lima_gem_prime_get_sg_table(struct drm_gem_object *obj)
29 {
30 	struct lima_bo *bo = to_lima_bo(obj);
31 	int npages = obj->size >> PAGE_SHIFT;
32 
33 	return drm_prime_pages_to_sg(bo->pages, npages);
34 }
35 
lima_gem_prime_mmap(struct drm_gem_object * obj,struct vm_area_struct * vma)36 int lima_gem_prime_mmap(struct drm_gem_object *obj, struct vm_area_struct *vma)
37 {
38 	int ret;
39 
40 	ret = drm_gem_mmap_obj(obj, obj->size, vma);
41 	if (ret)
42 		return ret;
43 
44 	lima_set_vma_flags(vma);
45 	return 0;
46 }
47