diff options
-rw-r--r-- | drivers/gpu/drm/exynos/exynos_drm_fbdev.c | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/drivers/gpu/drm/exynos/exynos_drm_fbdev.c b/drivers/gpu/drm/exynos/exynos_drm_fbdev.c index e7466c4414cb..151c4c9c50c7 100644 --- a/drivers/gpu/drm/exynos/exynos_drm_fbdev.c +++ b/drivers/gpu/drm/exynos/exynos_drm_fbdev.c | |||
@@ -46,8 +46,38 @@ struct exynos_drm_fbdev { | |||
46 | struct exynos_drm_gem_obj *exynos_gem_obj; | 46 | struct exynos_drm_gem_obj *exynos_gem_obj; |
47 | }; | 47 | }; |
48 | 48 | ||
49 | static int exynos_drm_fb_mmap(struct fb_info *info, | ||
50 | struct vm_area_struct *vma) | ||
51 | { | ||
52 | struct drm_fb_helper *helper = info->par; | ||
53 | struct exynos_drm_fbdev *exynos_fbd = to_exynos_fbdev(helper); | ||
54 | struct exynos_drm_gem_obj *exynos_gem_obj = exynos_fbd->exynos_gem_obj; | ||
55 | struct exynos_drm_gem_buf *buffer = exynos_gem_obj->buffer; | ||
56 | unsigned long vm_size; | ||
57 | int ret; | ||
58 | |||
59 | DRM_DEBUG_KMS("%s\n", __func__); | ||
60 | |||
61 | vma->vm_flags |= VM_IO | VM_DONTEXPAND | VM_DONTDUMP; | ||
62 | |||
63 | vm_size = vma->vm_end - vma->vm_start; | ||
64 | |||
65 | if (vm_size > buffer->size) | ||
66 | return -EINVAL; | ||
67 | |||
68 | ret = dma_mmap_attrs(helper->dev->dev, vma, buffer->kvaddr, | ||
69 | buffer->dma_addr, buffer->size, &buffer->dma_attrs); | ||
70 | if (ret < 0) { | ||
71 | DRM_ERROR("failed to mmap.\n"); | ||
72 | return ret; | ||
73 | } | ||
74 | |||
75 | return 0; | ||
76 | } | ||
77 | |||
49 | static struct fb_ops exynos_drm_fb_ops = { | 78 | static struct fb_ops exynos_drm_fb_ops = { |
50 | .owner = THIS_MODULE, | 79 | .owner = THIS_MODULE, |
80 | .fb_mmap = exynos_drm_fb_mmap, | ||
51 | .fb_fillrect = cfb_fillrect, | 81 | .fb_fillrect = cfb_fillrect, |
52 | .fb_copyarea = cfb_copyarea, | 82 | .fb_copyarea = cfb_copyarea, |
53 | .fb_imageblit = cfb_imageblit, | 83 | .fb_imageblit = cfb_imageblit, |