blob: c4993fc2c3bde43e7a41065edabac65d2e9b60e8 [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 *
6 * This program is free software; you can redistribute it and/or modify it
7 * under the terms and conditions of the GNU General Public License,
8 * version 2, as published by the Free Software Foundation.
9 *
10 * This program is distributed in the hope it will be useful, but WITHOUT
11 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
12 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
13 * more details.
14 *
15 * You should have received a copy of the GNU General Public License
16 * along with this program. If not, see <http://www.gnu.org/licenses/>.
17 */
18
19#ifndef __HOST1X_GEM_H
20#define __HOST1X_GEM_H
21
Thierry Reding35d747a2013-09-24 16:30:32 +020022#include <linux/host1x.h>
23
Arto Merilainende2ba662013-03-22 16:34:08 +020024#include <drm/drm.h>
25#include <drm/drmP.h>
26
Thierry Reding773af772013-10-04 22:34:01 +020027#define TEGRA_BO_TILED (1 << 0)
28
Arto Merilainende2ba662013-03-22 16:34:08 +020029struct tegra_bo {
30 struct drm_gem_object gem;
31 struct host1x_bo base;
Thierry Reding773af772013-10-04 22:34:01 +020032 unsigned long flags;
Arto Merilainende2ba662013-03-22 16:34:08 +020033 dma_addr_t paddr;
34 void *vaddr;
35};
36
37static inline struct tegra_bo *to_tegra_bo(struct drm_gem_object *gem)
38{
39 return container_of(gem, struct tegra_bo, gem);
40}
41
42extern const struct host1x_bo_ops tegra_bo_ops;
43
Thierry Reding773af772013-10-04 22:34:01 +020044struct tegra_bo *tegra_bo_create(struct drm_device *drm, unsigned int size,
45 unsigned long flags);
Arto Merilainende2ba662013-03-22 16:34:08 +020046struct tegra_bo *tegra_bo_create_with_handle(struct drm_file *file,
Thierry Reding773af772013-10-04 22:34:01 +020047 struct drm_device *drm,
48 unsigned int size,
49 unsigned long flags,
50 unsigned int *handle);
Arto Merilainende2ba662013-03-22 16:34:08 +020051void tegra_bo_free_object(struct drm_gem_object *gem);
Arto Merilainende2ba662013-03-22 16:34:08 +020052int tegra_bo_dumb_create(struct drm_file *file, struct drm_device *drm,
53 struct drm_mode_create_dumb *args);
54int tegra_bo_dumb_map_offset(struct drm_file *file, struct drm_device *drm,
55 uint32_t handle, uint64_t *offset);
Arto Merilainende2ba662013-03-22 16:34:08 +020056
57int tegra_drm_mmap(struct file *file, struct vm_area_struct *vma);
58
59extern const struct vm_operations_struct tegra_bo_vm_ops;
60
61#endif