blob: 7674000bf47d6696ecec6db7507926144832c772 [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 Redingdb7fbdf2013-10-07 09:47:58 +020027#define TEGRA_BO_TILED (1 << 0)
28#define TEGRA_BO_BOTTOM_UP (1 << 1)
Thierry Reding773af772013-10-04 22:34:01 +020029
Arto Merilainende2ba662013-03-22 16:34:08 +020030struct tegra_bo {
31 struct drm_gem_object gem;
32 struct host1x_bo base;
Thierry Reding773af772013-10-04 22:34:01 +020033 unsigned long flags;
Arto Merilainende2ba662013-03-22 16:34:08 +020034 dma_addr_t paddr;
35 void *vaddr;
36};
37
38static inline struct tegra_bo *to_tegra_bo(struct drm_gem_object *gem)
39{
40 return container_of(gem, struct tegra_bo, gem);
41}
42
43extern const struct host1x_bo_ops tegra_bo_ops;
44
Thierry Reding773af772013-10-04 22:34:01 +020045struct tegra_bo *tegra_bo_create(struct drm_device *drm, unsigned int size,
46 unsigned long flags);
Arto Merilainende2ba662013-03-22 16:34:08 +020047struct tegra_bo *tegra_bo_create_with_handle(struct drm_file *file,
Thierry Reding773af772013-10-04 22:34:01 +020048 struct drm_device *drm,
49 unsigned int size,
50 unsigned long flags,
51 unsigned int *handle);
Arto Merilainende2ba662013-03-22 16:34:08 +020052void tegra_bo_free_object(struct drm_gem_object *gem);
Arto Merilainende2ba662013-03-22 16:34:08 +020053int tegra_bo_dumb_create(struct drm_file *file, struct drm_device *drm,
54 struct drm_mode_create_dumb *args);
55int tegra_bo_dumb_map_offset(struct drm_file *file, struct drm_device *drm,
56 uint32_t handle, uint64_t *offset);
Arto Merilainende2ba662013-03-22 16:34:08 +020057
58int tegra_drm_mmap(struct file *file, struct vm_area_struct *vma);
59
60extern const struct vm_operations_struct tegra_bo_vm_ops;
61
62#endif