blob: d345ff340725f5754a541adf77859d0aa5a08806 [file] [log] [blame]
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -07001/* Copyright (c) 2002,2007-2011, Code Aurora Forum. All rights reserved.
2 *
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>
Jeremy Gebben32660362011-11-03 09:59:51 -060018#include "kgsl_mmu.h"
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070019
20struct kgsl_device;
21struct kgsl_process_private;
22
23#define KGSL_CACHE_OP_INV 0x01
24#define KGSL_CACHE_OP_FLUSH 0x02
25#define KGSL_CACHE_OP_CLEAN 0x03
26
27/** Set if the memdesc describes cached memory */
28#define KGSL_MEMFLAGS_CACHED 0x00000001
29
30struct kgsl_memdesc_ops {
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070031 int (*vmflags)(struct kgsl_memdesc *);
32 int (*vmfault)(struct kgsl_memdesc *, struct vm_area_struct *,
33 struct vm_fault *);
34 void (*free)(struct kgsl_memdesc *memdesc);
35};
36
37extern struct kgsl_memdesc_ops kgsl_vmalloc_ops;
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070038
39int kgsl_sharedmem_vmalloc(struct kgsl_memdesc *memdesc,
40 struct kgsl_pagetable *pagetable, size_t size);
41
42int kgsl_sharedmem_vmalloc_user(struct kgsl_memdesc *memdesc,
43 struct kgsl_pagetable *pagetable,
44 size_t size, int flags);
45
46int kgsl_sharedmem_alloc_coherent(struct kgsl_memdesc *memdesc, size_t size);
47
48int kgsl_sharedmem_ebimem_user(struct kgsl_memdesc *memdesc,
49 struct kgsl_pagetable *pagetable,
50 size_t size, int flags);
51
52int kgsl_sharedmem_ebimem(struct kgsl_memdesc *memdesc,
53 struct kgsl_pagetable *pagetable,
54 size_t size);
55
56void kgsl_sharedmem_free(struct kgsl_memdesc *memdesc);
57
58int kgsl_sharedmem_readl(const struct kgsl_memdesc *memdesc,
59 uint32_t *dst,
60 unsigned int offsetbytes);
61
62int kgsl_sharedmem_writel(const struct kgsl_memdesc *memdesc,
63 unsigned int offsetbytes,
64 uint32_t src);
65
66int kgsl_sharedmem_set(const struct kgsl_memdesc *memdesc,
67 unsigned int offsetbytes, unsigned int value,
68 unsigned int sizebytes);
69
70void kgsl_cache_range_op(struct kgsl_memdesc *memdesc, int op);
71
72void kgsl_process_init_sysfs(struct kgsl_process_private *private);
73void kgsl_process_uninit_sysfs(struct kgsl_process_private *private);
74
75int kgsl_sharedmem_init_sysfs(void);
76void kgsl_sharedmem_uninit_sysfs(void);
77
78static inline int
Jordan Croused17e9aa2011-10-12 16:57:48 -060079memdesc_sg_phys(struct kgsl_memdesc *memdesc,
80 unsigned int physaddr, unsigned int size)
81{
82 struct page *page = phys_to_page(physaddr);
83
84 memdesc->sg = kmalloc(sizeof(struct scatterlist) * 1, GFP_KERNEL);
85 if (memdesc->sg == NULL)
86 return -ENOMEM;
87
88 memdesc->sglen = 1;
89 sg_init_table(memdesc->sg, 1);
90 sg_set_page(&memdesc->sg[0], page, size, 0);
91 return 0;
92}
93
94static inline int
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070095kgsl_allocate(struct kgsl_memdesc *memdesc,
96 struct kgsl_pagetable *pagetable, size_t size)
97{
Jeremy Gebben32660362011-11-03 09:59:51 -060098 if (kgsl_mmu_get_mmutype() == KGSL_MMU_TYPE_NONE)
99 return kgsl_sharedmem_ebimem(memdesc, pagetable, size);
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700100 return kgsl_sharedmem_vmalloc(memdesc, pagetable, size);
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700101}
102
103static inline int
104kgsl_allocate_user(struct kgsl_memdesc *memdesc,
105 struct kgsl_pagetable *pagetable,
106 size_t size, unsigned int flags)
107{
Jeremy Gebben32660362011-11-03 09:59:51 -0600108 if (kgsl_mmu_get_mmutype() == KGSL_MMU_TYPE_NONE)
109 return kgsl_sharedmem_ebimem_user(memdesc, pagetable, size,
110 flags);
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700111 return kgsl_sharedmem_vmalloc_user(memdesc, pagetable, size, flags);
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700112}
113
114static inline int
115kgsl_allocate_contiguous(struct kgsl_memdesc *memdesc, size_t size)
116{
117 int ret = kgsl_sharedmem_alloc_coherent(memdesc, size);
Jeremy Gebben32660362011-11-03 09:59:51 -0600118 if (!ret && (kgsl_mmu_get_mmutype() == KGSL_MMU_TYPE_NONE))
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700119 memdesc->gpuaddr = memdesc->physaddr;
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700120 return ret;
121}
122
123#endif /* __KGSL_SHAREDMEM_H */