blob: 6c5f12ac0087a0b8baf538f435d244f2ffa1537b [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
Thierry Reding71c38622014-11-03 13:23:02 +010055struct tegra_bo *tegra_bo_create(struct drm_device *drm, size_t size,
Thierry Reding773af772013-10-04 22:34:01 +020056 unsigned long flags);
Arto Merilainende2ba662013-03-22 16:34:08 +020057struct tegra_bo *tegra_bo_create_with_handle(struct drm_file *file,
Thierry Reding773af772013-10-04 22:34:01 +020058 struct drm_device *drm,
Thierry Reding71c38622014-11-03 13:23:02 +010059 size_t size,
Thierry Reding773af772013-10-04 22:34:01 +020060 unsigned long flags,
Thierry Reding71c38622014-11-03 13:23:02 +010061 u32 *handle);
Arto Merilainende2ba662013-03-22 16:34:08 +020062void tegra_bo_free_object(struct drm_gem_object *gem);
Arto Merilainende2ba662013-03-22 16:34:08 +020063int tegra_bo_dumb_create(struct drm_file *file, struct drm_device *drm,
64 struct drm_mode_create_dumb *args);
65int tegra_bo_dumb_map_offset(struct drm_file *file, struct drm_device *drm,
Thierry Reding71c38622014-11-03 13:23:02 +010066 u32 handle, u64 *offset);
Arto Merilainende2ba662013-03-22 16:34:08 +020067
68int tegra_drm_mmap(struct file *file, struct vm_area_struct *vma);
69
70extern const struct vm_operations_struct tegra_bo_vm_ops;
71
Thierry Reding38003912013-12-12 10:00:43 +010072struct dma_buf *tegra_gem_prime_export(struct drm_device *drm,
73 struct drm_gem_object *gem,
74 int flags);
75struct drm_gem_object *tegra_gem_prime_import(struct drm_device *drm,
76 struct dma_buf *buf);
77
Arto Merilainende2ba662013-03-22 16:34:08 +020078#endif