162306a36Sopenharmony_ci/* SPDX-License-Identifier: GPL-2.0-only */
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * Tegra host1x GEM implementation
462306a36Sopenharmony_ci *
562306a36Sopenharmony_ci * Copyright (c) 2012-2013, NVIDIA Corporation.
662306a36Sopenharmony_ci */
762306a36Sopenharmony_ci
862306a36Sopenharmony_ci#ifndef __HOST1X_GEM_H
962306a36Sopenharmony_ci#define __HOST1X_GEM_H
1062306a36Sopenharmony_ci
1162306a36Sopenharmony_ci#include <linux/host1x.h>
1262306a36Sopenharmony_ci
1362306a36Sopenharmony_ci#include <drm/drm.h>
1462306a36Sopenharmony_ci#include <drm/drm_gem.h>
1562306a36Sopenharmony_ci
1662306a36Sopenharmony_ci#define TEGRA_BO_BOTTOM_UP (1 << 0)
1762306a36Sopenharmony_ci
1862306a36Sopenharmony_cienum tegra_bo_tiling_mode {
1962306a36Sopenharmony_ci	TEGRA_BO_TILING_MODE_PITCH,
2062306a36Sopenharmony_ci	TEGRA_BO_TILING_MODE_TILED,
2162306a36Sopenharmony_ci	TEGRA_BO_TILING_MODE_BLOCK,
2262306a36Sopenharmony_ci};
2362306a36Sopenharmony_ci
2462306a36Sopenharmony_cienum tegra_bo_sector_layout {
2562306a36Sopenharmony_ci	TEGRA_BO_SECTOR_LAYOUT_TEGRA,
2662306a36Sopenharmony_ci	TEGRA_BO_SECTOR_LAYOUT_GPU,
2762306a36Sopenharmony_ci};
2862306a36Sopenharmony_ci
2962306a36Sopenharmony_cistruct tegra_bo_tiling {
3062306a36Sopenharmony_ci	enum tegra_bo_tiling_mode mode;
3162306a36Sopenharmony_ci	unsigned long value;
3262306a36Sopenharmony_ci	enum tegra_bo_sector_layout sector_layout;
3362306a36Sopenharmony_ci};
3462306a36Sopenharmony_ci
3562306a36Sopenharmony_cistruct tegra_bo {
3662306a36Sopenharmony_ci	struct drm_gem_object gem;
3762306a36Sopenharmony_ci	struct host1x_bo base;
3862306a36Sopenharmony_ci	unsigned long flags;
3962306a36Sopenharmony_ci	struct sg_table *sgt;
4062306a36Sopenharmony_ci	dma_addr_t iova;
4162306a36Sopenharmony_ci	void *vaddr;
4262306a36Sopenharmony_ci
4362306a36Sopenharmony_ci	struct drm_mm_node *mm;
4462306a36Sopenharmony_ci	unsigned long num_pages;
4562306a36Sopenharmony_ci	struct page **pages;
4662306a36Sopenharmony_ci	/* size of IOMMU mapping */
4762306a36Sopenharmony_ci	size_t size;
4862306a36Sopenharmony_ci
4962306a36Sopenharmony_ci	struct tegra_bo_tiling tiling;
5062306a36Sopenharmony_ci};
5162306a36Sopenharmony_ci
5262306a36Sopenharmony_cistatic inline struct tegra_bo *to_tegra_bo(struct drm_gem_object *gem)
5362306a36Sopenharmony_ci{
5462306a36Sopenharmony_ci	return container_of(gem, struct tegra_bo, gem);
5562306a36Sopenharmony_ci}
5662306a36Sopenharmony_ci
5762306a36Sopenharmony_cistatic inline struct tegra_bo *host1x_to_tegra_bo(struct host1x_bo *bo)
5862306a36Sopenharmony_ci{
5962306a36Sopenharmony_ci	return container_of(bo, struct tegra_bo, base);
6062306a36Sopenharmony_ci}
6162306a36Sopenharmony_ci
6262306a36Sopenharmony_cistruct tegra_bo *tegra_bo_create(struct drm_device *drm, size_t size,
6362306a36Sopenharmony_ci				 unsigned long flags);
6462306a36Sopenharmony_cistruct tegra_bo *tegra_bo_create_with_handle(struct drm_file *file,
6562306a36Sopenharmony_ci					     struct drm_device *drm,
6662306a36Sopenharmony_ci					     size_t size,
6762306a36Sopenharmony_ci					     unsigned long flags,
6862306a36Sopenharmony_ci					     u32 *handle);
6962306a36Sopenharmony_civoid tegra_bo_free_object(struct drm_gem_object *gem);
7062306a36Sopenharmony_ciint tegra_bo_dumb_create(struct drm_file *file, struct drm_device *drm,
7162306a36Sopenharmony_ci			 struct drm_mode_create_dumb *args);
7262306a36Sopenharmony_ci
7362306a36Sopenharmony_ciextern const struct vm_operations_struct tegra_bo_vm_ops;
7462306a36Sopenharmony_ci
7562306a36Sopenharmony_ciint __tegra_gem_mmap(struct drm_gem_object *gem, struct vm_area_struct *vma);
7662306a36Sopenharmony_ciint tegra_drm_mmap(struct file *file, struct vm_area_struct *vma);
7762306a36Sopenharmony_ci
7862306a36Sopenharmony_cistruct dma_buf *tegra_gem_prime_export(struct drm_gem_object *gem,
7962306a36Sopenharmony_ci				       int flags);
8062306a36Sopenharmony_cistruct drm_gem_object *tegra_gem_prime_import(struct drm_device *drm,
8162306a36Sopenharmony_ci					      struct dma_buf *buf);
8262306a36Sopenharmony_ci
8362306a36Sopenharmony_cistruct host1x_bo *tegra_gem_lookup(struct drm_file *file, u32 handle);
8462306a36Sopenharmony_ci
8562306a36Sopenharmony_ci#endif
86