/*
* Copyright (c) 2017-2018, NVIDIA CORPORATION. All rights reserved.
*
* This program is free software; you can redistribute it and/or modify it
* under the terms and conditions of the GNU General Public License,
* version 2, as published by the Free Software Foundation.
*
* This program is distributed in the hope it will be useful, but WITHOUT
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
* more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see .
*/
#ifndef __NVGPU_LINUX_DMABUF_VIDMEM_H__
#define __NVGPU_LINUX_DMABUF_VIDMEM_H__
#include
struct dma_buf;
struct gk20a;
struct scatterlist;
#ifdef CONFIG_GK20A_VIDMEM
struct gk20a *nvgpu_vidmem_buf_owner(struct dma_buf *dmabuf);
int nvgpu_vidmem_export_linux(struct gk20a *g, size_t bytes);
void nvgpu_vidmem_set_page_alloc(struct scatterlist *sgl, u64 addr);
struct nvgpu_page_alloc *nvgpu_vidmem_get_page_alloc(struct scatterlist *sgl);
int nvgpu_vidmem_buf_access_memory(struct gk20a *g, struct dma_buf *dmabuf,
void *buffer, u64 offset, u64 size, u32 cmd);
#else /* !CONFIG_GK20A_VIDMEM */
static inline struct gk20a *nvgpu_vidmem_buf_owner(struct dma_buf *dmabuf)
{
return NULL;
}
static inline int nvgpu_vidmem_export_linux(struct gk20a *g, size_t bytes)
{
return -ENOSYS;
}
static inline void nvgpu_vidmem_set_page_alloc(struct scatterlist *sgl,
u64 addr)
{
}
static inline struct nvgpu_page_alloc *nvgpu_vidmem_get_page_alloc(
struct scatterlist *sgl)
{
return NULL;
}
static inline int nvgpu_vidmem_buf_access_memory(struct gk20a *g,
struct dma_buf *dmabuf,
void *buffer, u64 offset,
u64 size, u32 cmd)
{
return -ENOSYS;
}
#endif
struct nvgpu_vidmem_linux {
struct dma_buf *dmabuf;
void *dmabuf_priv;
void (*dmabuf_priv_delete)(void *);
};
#endif