blob: af0d74d4a35c16c718fea7c2396cb775d0de6661 [file] [log] [blame]
Jeff Boody28afec42012-01-18 15:47:46 -07001/* Copyright (c) 2002,2007-2012, Code Aurora Forum. All rights reserved.
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -07002 *
3 * This program is free software; you can redistribute it and/or modify
4 * it under the terms of the GNU General Public License version 2 and
5 * only version 2 as published by the Free Software Foundation.
6 *
7 * This program is distributed in the hope that it will be useful,
8 * but WITHOUT ANY WARRANTY; without even the implied warranty of
9 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
10 * GNU General Public License for more details.
11 *
12 */
13#ifndef __KGSL_SHAREDMEM_H
14#define __KGSL_SHAREDMEM_H
15
Jordan Croused17e9aa2011-10-12 16:57:48 -060016#include <linux/slab.h>
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070017#include <linux/dma-mapping.h>
Jeff Boody28afec42012-01-18 15:47:46 -070018#include <linux/vmalloc.h>
Jeremy Gebben32660362011-11-03 09:59:51 -060019#include "kgsl_mmu.h"
Anshuman Danieecd5202012-02-17 19:52:49 +053020#include <linux/slab.h>
21#include <linux/kmemleak.h>
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070022
23struct kgsl_device;
24struct kgsl_process_private;
25
26#define KGSL_CACHE_OP_INV 0x01
27#define KGSL_CACHE_OP_FLUSH 0x02
28#define KGSL_CACHE_OP_CLEAN 0x03
29
30/** Set if the memdesc describes cached memory */
31#define KGSL_MEMFLAGS_CACHED 0x00000001
Jeremy Gebben7faf9ec2012-03-21 14:09:55 -060032/** Set if the memdesc is mapped into all pagetables */
33#define KGSL_MEMFLAGS_GLOBAL 0x00000002
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070034
35struct kgsl_memdesc_ops {
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070036 int (*vmflags)(struct kgsl_memdesc *);
37 int (*vmfault)(struct kgsl_memdesc *, struct vm_area_struct *,
38 struct vm_fault *);
39 void (*free)(struct kgsl_memdesc *memdesc);
40};
41
42extern struct kgsl_memdesc_ops kgsl_vmalloc_ops;
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070043
44int kgsl_sharedmem_vmalloc(struct kgsl_memdesc *memdesc,
45 struct kgsl_pagetable *pagetable, size_t size);
46
47int kgsl_sharedmem_vmalloc_user(struct kgsl_memdesc *memdesc,
48 struct kgsl_pagetable *pagetable,
49 size_t size, int flags);
50
51int kgsl_sharedmem_alloc_coherent(struct kgsl_memdesc *memdesc, size_t size);
52
53int kgsl_sharedmem_ebimem_user(struct kgsl_memdesc *memdesc,
54 struct kgsl_pagetable *pagetable,
55 size_t size, int flags);
56
57int kgsl_sharedmem_ebimem(struct kgsl_memdesc *memdesc,
58 struct kgsl_pagetable *pagetable,
59 size_t size);
60
61void kgsl_sharedmem_free(struct kgsl_memdesc *memdesc);
62
63int kgsl_sharedmem_readl(const struct kgsl_memdesc *memdesc,
64 uint32_t *dst,
65 unsigned int offsetbytes);
66
67int kgsl_sharedmem_writel(const struct kgsl_memdesc *memdesc,
68 unsigned int offsetbytes,
69 uint32_t src);
70
71int kgsl_sharedmem_set(const struct kgsl_memdesc *memdesc,
72 unsigned int offsetbytes, unsigned int value,
73 unsigned int sizebytes);
74
75void kgsl_cache_range_op(struct kgsl_memdesc *memdesc, int op);
76
77void kgsl_process_init_sysfs(struct kgsl_process_private *private);
78void kgsl_process_uninit_sysfs(struct kgsl_process_private *private);
79
80int kgsl_sharedmem_init_sysfs(void);
81void kgsl_sharedmem_uninit_sysfs(void);
82
83static inline int
Jordan Croused17e9aa2011-10-12 16:57:48 -060084memdesc_sg_phys(struct kgsl_memdesc *memdesc,
85 unsigned int physaddr, unsigned int size)
86{
87 struct page *page = phys_to_page(physaddr);
88
Jeff Boody28afec42012-01-18 15:47:46 -070089 memdesc->sg = vmalloc(sizeof(struct scatterlist) * 1);
Jordan Croused17e9aa2011-10-12 16:57:48 -060090 if (memdesc->sg == NULL)
91 return -ENOMEM;
92
Anshuman Danieecd5202012-02-17 19:52:49 +053093 kmemleak_not_leak(memdesc->sg);
94
Jordan Croused17e9aa2011-10-12 16:57:48 -060095 memdesc->sglen = 1;
96 sg_init_table(memdesc->sg, 1);
97 sg_set_page(&memdesc->sg[0], page, size, 0);
98 return 0;
99}
100
101static inline int
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700102kgsl_allocate(struct kgsl_memdesc *memdesc,
103 struct kgsl_pagetable *pagetable, size_t size)
104{
Jeremy Gebben32660362011-11-03 09:59:51 -0600105 if (kgsl_mmu_get_mmutype() == KGSL_MMU_TYPE_NONE)
106 return kgsl_sharedmem_ebimem(memdesc, pagetable, size);
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700107 return kgsl_sharedmem_vmalloc(memdesc, pagetable, size);
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700108}
109
110static inline int
111kgsl_allocate_user(struct kgsl_memdesc *memdesc,
112 struct kgsl_pagetable *pagetable,
113 size_t size, unsigned int flags)
114{
Jeremy Gebben32660362011-11-03 09:59:51 -0600115 if (kgsl_mmu_get_mmutype() == KGSL_MMU_TYPE_NONE)
116 return kgsl_sharedmem_ebimem_user(memdesc, pagetable, size,
117 flags);
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700118 return kgsl_sharedmem_vmalloc_user(memdesc, pagetable, size, flags);
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700119}
120
121static inline int
122kgsl_allocate_contiguous(struct kgsl_memdesc *memdesc, size_t size)
123{
124 int ret = kgsl_sharedmem_alloc_coherent(memdesc, size);
Jeremy Gebben32660362011-11-03 09:59:51 -0600125 if (!ret && (kgsl_mmu_get_mmutype() == KGSL_MMU_TYPE_NONE))
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700126 memdesc->gpuaddr = memdesc->physaddr;
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700127 return ret;
128}
129
130#endif /* __KGSL_SHAREDMEM_H */