blob: cd823245af6ddb349834635bb61c8e4519ef295d [file] [log] [blame]
/* SPDX-License-Identifier: (GPL-2.0+ OR MIT) */
/*
* Copyright (c) 2019 Amlogic, Inc. All rights reserved.
*/
#ifndef __AM_MESON_GEM_H
#define __AM_MESON_GEM_H
#include <drm/drm_gem.h>
#include <uapi/drm/meson_drm.h>
#include <ion/ion_private.h>
#include <linux/amlogic/meson_uvm_core.h>
#include "meson_drv.h"
struct am_meson_gem_object {
struct drm_gem_object base;
unsigned int flags;
/*for buffer create from ion heap */
struct ion_buffer *ionbuffer;
struct dma_buf *dmabuf;
bool bscatter;
/* for buffer import form other driver */
phys_addr_t addr;
struct sg_table *sg;
/* for uvm related field */
bool is_uvm;
bool is_afbc;
bool is_secure;
struct uvm_handle *dma_handle;
struct uvm_buf_obj ubo;
};
/* GEM MANAGER CREATE*/
int am_meson_gem_create(struct meson_drm *drmdrv);
void am_meson_gem_cleanup(struct meson_drm *drmdrv);
int am_meson_gem_mmap(struct file *filp, struct vm_area_struct *vma);
/* GEM DUMB OPERATIONS */
int am_meson_gem_dumb_create(struct drm_file *file_priv, struct drm_device *dev,
struct drm_mode_create_dumb *args);
int am_meson_gem_dumb_destroy(struct drm_file *file,
struct drm_device *dev, uint32_t handle);
int am_meson_gem_create_ioctl(struct drm_device *dev, void *data,
struct drm_file *file_priv);
int am_meson_gem_dumb_map_offset(struct drm_file *file_priv,
struct drm_device *dev,
u32 handle, uint64_t *offset);
/* GEM OBJECT OPERATIONS */
struct am_meson_gem_object *
am_meson_gem_object_create(struct drm_device *dev, unsigned int flags,
unsigned long size);
void am_meson_gem_object_free(struct drm_gem_object *gem_obj);
int am_meson_gem_object_mmap(struct am_meson_gem_object *obj,
struct vm_area_struct *vma);
phys_addr_t am_meson_gem_object_get_phyaddr(struct meson_drm *drm,
struct am_meson_gem_object *meson_gem,
size_t *len);
/* GEM PRIME OPERATIONS */
struct sg_table *am_meson_gem_prime_get_sg_table(struct drm_gem_object *obj);
struct drm_gem_object *
am_meson_gem_prime_import_sg_table(struct drm_device *dev,
struct dma_buf_attachment *attach,
struct sg_table *sgt);
void *am_meson_gem_prime_vmap(struct drm_gem_object *obj);
void am_meson_gem_prime_vunmap(struct drm_gem_object *obj, void *vaddr);
int am_meson_gem_prime_mmap(struct drm_gem_object *obj,
struct vm_area_struct *vma);
struct dma_buf *am_meson_drm_gem_prime_export(struct drm_gem_object *obj,
int flags);
struct drm_gem_object *am_meson_drm_gem_prime_import(struct drm_device *dev,
struct dma_buf *dmabuf);
#endif /* __AM_MESON_GEM_H */