blob: 8eb9fd24ef0e5dcf50ab0ac5c9ca0f6d4f251506 [file] [log] [blame]
Arto Merilainende2ba662013-03-22 16:34:08 +02001/*
2 * Tegra host1x GEM implementation
3 *
4 * Copyright (c) 2012-2013, NVIDIA Corporation.
5 *
Thierry Reding9a2ac2d2014-02-11 15:52:01 +01006 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License version 2 as
8 * published by the Free Software Foundation.
Arto Merilainende2ba662013-03-22 16:34:08 +02009 */
10
11#ifndef __HOST1X_GEM_H
12#define __HOST1X_GEM_H
13
Thierry Reding35d747a2013-09-24 16:30:32 +020014#include <linux/host1x.h>
15
Arto Merilainende2ba662013-03-22 16:34:08 +020016#include <drm/drm.h>
17#include <drm/drmP.h>
Daniel Vetterd9fc9412014-09-23 15:46:53 +020018#include <drm/drm_gem.h>
Arto Merilainende2ba662013-03-22 16:34:08 +020019
Thierry Redingc134f012014-06-03 14:48:12 +020020#define TEGRA_BO_BOTTOM_UP (1 << 0)
21
22enum tegra_bo_tiling_mode {
23 TEGRA_BO_TILING_MODE_PITCH,
24 TEGRA_BO_TILING_MODE_TILED,
25 TEGRA_BO_TILING_MODE_BLOCK,
26};
27
28struct tegra_bo_tiling {
29 enum tegra_bo_tiling_mode mode;
30 unsigned long value;
31};
Thierry Reding773af772013-10-04 22:34:01 +020032
Arto Merilainende2ba662013-03-22 16:34:08 +020033struct tegra_bo {
34 struct drm_gem_object gem;
35 struct host1x_bo base;
Thierry Reding773af772013-10-04 22:34:01 +020036 unsigned long flags;
Thierry Reding38003912013-12-12 10:00:43 +010037 struct sg_table *sgt;
Arto Merilainende2ba662013-03-22 16:34:08 +020038 dma_addr_t paddr;
39 void *vaddr;
Thierry Redingc134f012014-06-03 14:48:12 +020040
Thierry Redingdf06b752014-06-26 21:41:53 +020041 struct drm_mm_node *mm;
42 unsigned long num_pages;
43 struct page **pages;
44 /* size of IOMMU mapping */
45 size_t size;
46
Thierry Redingc134f012014-06-03 14:48:12 +020047 struct tegra_bo_tiling tiling;
Arto Merilainende2ba662013-03-22 16:34:08 +020048};
49
50static inline struct tegra_bo *to_tegra_bo(struct drm_gem_object *gem)
51{
52 return container_of(gem, struct tegra_bo, gem);
53}
54
Dmitry Osipenko368f6222017-06-15 02:18:26 +030055static inline struct tegra_bo *host1x_to_tegra_bo(struct host1x_bo *bo)
56{
57 return container_of(bo, struct tegra_bo, base);
58}
59
Thierry Reding71c38622014-11-03 13:23:02 +010060struct tegra_bo *tegra_bo_create(struct drm_device *drm, size_t size,
Thierry Reding773af772013-10-04 22:34:01 +020061 unsigned long flags);
Arto Merilainende2ba662013-03-22 16:34:08 +020062struct tegra_bo *tegra_bo_create_with_handle(struct drm_file *file,
Thierry Reding773af772013-10-04 22:34:01 +020063 struct drm_device *drm,
Thierry Reding71c38622014-11-03 13:23:02 +010064 size_t size,
Thierry Reding773af772013-10-04 22:34:01 +020065 unsigned long flags,
Thierry Reding71c38622014-11-03 13:23:02 +010066 u32 *handle);
Arto Merilainende2ba662013-03-22 16:34:08 +020067void tegra_bo_free_object(struct drm_gem_object *gem);
Arto Merilainende2ba662013-03-22 16:34:08 +020068int tegra_bo_dumb_create(struct drm_file *file, struct drm_device *drm,
69 struct drm_mode_create_dumb *args);
Arto Merilainende2ba662013-03-22 16:34:08 +020070
71int tegra_drm_mmap(struct file *file, struct vm_area_struct *vma);
72
73extern const struct vm_operations_struct tegra_bo_vm_ops;
74
Thierry Reding38003912013-12-12 10:00:43 +010075struct dma_buf *tegra_gem_prime_export(struct drm_device *drm,
76 struct drm_gem_object *gem,
77 int flags);
78struct drm_gem_object *tegra_gem_prime_import(struct drm_device *drm,
79 struct dma_buf *buf);
80
Arto Merilainende2ba662013-03-22 16:34:08 +020081#endif