blob: f543522836a59842eca9af64c482d4368a521133 [file] [log] [blame]
Dima Zavin81fa6d52009-08-05 17:51:29 -07001/****************************************************************************
2 ****************************************************************************
3 ***
4 *** This header was automatically generated from a Linux kernel header
5 *** of the same name, to make information necessary for userspace to
6 *** call into the kernel available to libc. It contains only constants,
7 *** structures, and macros generated from the original header, and thus,
8 *** contains no copyrightable information.
9 ***
10 ****************************************************************************
11 ****************************************************************************/
12#ifndef _MSM_KGSL_H
13#define _MSM_KGSL_H
Ben Cheng4b29af02012-03-07 16:14:53 -080014
Dima Zavin81fa6d52009-08-05 17:51:29 -070015#define KGSL_CONTEXT_SAVE_GMEM 1
16#define KGSL_CONTEXT_NO_GMEM_ALLOC 2
Ben Cheng4b29af02012-03-07 16:14:53 -080017
Dima Zavin81fa6d52009-08-05 17:51:29 -070018#define KGSL_FLAGS_NORMALMODE 0x00000000
19#define KGSL_FLAGS_SAFEMODE 0x00000001
20#define KGSL_FLAGS_INITIALIZED0 0x00000002
21#define KGSL_FLAGS_INITIALIZED 0x00000004
22#define KGSL_FLAGS_STARTED 0x00000008
23#define KGSL_FLAGS_ACTIVE 0x00000010
24#define KGSL_FLAGS_RESERVED0 0x00000020
25#define KGSL_FLAGS_RESERVED1 0x00000040
26#define KGSL_FLAGS_RESERVED2 0x00000080
Ben Cheng4b29af02012-03-07 16:14:53 -080027
Dima Zavin81fa6d52009-08-05 17:51:29 -070028enum kgsl_deviceid {
29 KGSL_DEVICE_ANY = 0x00000000,
30 KGSL_DEVICE_YAMATO = 0x00000001,
31 KGSL_DEVICE_G12 = 0x00000002,
32 KGSL_DEVICE_MAX = 0x00000002
33};
Ben Cheng4b29af02012-03-07 16:14:53 -080034
Dima Zavin81fa6d52009-08-05 17:51:29 -070035struct kgsl_devinfo {
Ben Cheng4b29af02012-03-07 16:14:53 -080036
Dima Zavin81fa6d52009-08-05 17:51:29 -070037 unsigned int device_id;
Ben Cheng4b29af02012-03-07 16:14:53 -080038
Dima Zavin81fa6d52009-08-05 17:51:29 -070039 unsigned int chip_id;
40 unsigned int mmu_enabled;
41 unsigned int gmem_gpubaseaddr;
Ben Cheng4b29af02012-03-07 16:14:53 -080042
Dima Zavin81fa6d52009-08-05 17:51:29 -070043 unsigned int gmem_hostbaseaddr;
44 unsigned int gmem_sizebytes;
45};
Ben Cheng4b29af02012-03-07 16:14:53 -080046
Dima Zavin81fa6d52009-08-05 17:51:29 -070047struct kgsl_devmemstore {
48 volatile unsigned int soptimestamp;
49 unsigned int sbz;
50 volatile unsigned int eoptimestamp;
51 unsigned int sbz2;
Dima Zavin4e383b82010-03-08 17:34:52 -080052 volatile unsigned int ts_cmp_enable;
53 unsigned int sbz3;
54 volatile unsigned int ref_wait_ts;
55 unsigned int sbz4;
Dima Zavin81fa6d52009-08-05 17:51:29 -070056};
Ben Cheng4b29af02012-03-07 16:14:53 -080057
Dima Zavin81fa6d52009-08-05 17:51:29 -070058#define KGSL_DEVICE_MEMSTORE_OFFSET(field) offsetof(struct kgsl_devmemstore, field)
Ben Cheng4b29af02012-03-07 16:14:53 -080059
Dima Zavin81fa6d52009-08-05 17:51:29 -070060enum kgsl_timestamp_type {
61 KGSL_TIMESTAMP_CONSUMED = 0x00000001,
62 KGSL_TIMESTAMP_RETIRED = 0x00000002,
63 KGSL_TIMESTAMP_MAX = 0x00000002,
64};
Ben Cheng4b29af02012-03-07 16:14:53 -080065
Dima Zavin81fa6d52009-08-05 17:51:29 -070066enum kgsl_property_type {
67 KGSL_PROP_DEVICE_INFO = 0x00000001,
68 KGSL_PROP_DEVICE_SHADOW = 0x00000002,
Dima Zavin9a96aaa2009-10-03 16:38:49 -070069 KGSL_PROP_DEVICE_POWER = 0x00000003,
70 KGSL_PROP_SHMEM = 0x00000004,
71 KGSL_PROP_SHMEM_APERTURES = 0x00000005,
Dima Zavin4e383b82010-03-08 17:34:52 -080072 KGSL_PROP_MMU_ENABLE = 0x00000006,
73 KGSL_PROP_INTERRUPT_WAITS = 0x00000007,
Dima Zavin81fa6d52009-08-05 17:51:29 -070074};
Ben Cheng4b29af02012-03-07 16:14:53 -080075
Dima Zavin81fa6d52009-08-05 17:51:29 -070076struct kgsl_shadowprop {
77 unsigned int gpuaddr;
78 unsigned int size;
79 unsigned int flags;
80};
Ben Cheng4b29af02012-03-07 16:14:53 -080081
Dima Zavin81fa6d52009-08-05 17:51:29 -070082#define KGSL_IOC_TYPE 0x09
Ben Cheng4b29af02012-03-07 16:14:53 -080083
Dima Zavin81fa6d52009-08-05 17:51:29 -070084struct kgsl_device_getproperty {
85 unsigned int type;
86 void *value;
87 unsigned int sizebytes;
88};
Ben Cheng4b29af02012-03-07 16:14:53 -080089
Dima Zavin81fa6d52009-08-05 17:51:29 -070090#define IOCTL_KGSL_DEVICE_GETPROPERTY _IOWR(KGSL_IOC_TYPE, 0x2, struct kgsl_device_getproperty)
Ben Cheng4b29af02012-03-07 16:14:53 -080091
Dima Zavin81fa6d52009-08-05 17:51:29 -070092struct kgsl_device_regread {
93 unsigned int offsetwords;
94 unsigned int value;
95};
Ben Cheng4b29af02012-03-07 16:14:53 -080096
Dima Zavin81fa6d52009-08-05 17:51:29 -070097#define IOCTL_KGSL_DEVICE_REGREAD _IOWR(KGSL_IOC_TYPE, 0x3, struct kgsl_device_regread)
Ben Cheng4b29af02012-03-07 16:14:53 -080098
Dima Zavin81fa6d52009-08-05 17:51:29 -070099struct kgsl_device_waittimestamp {
100 unsigned int timestamp;
101 unsigned int timeout;
102};
Ben Cheng4b29af02012-03-07 16:14:53 -0800103
Dima Zavin81fa6d52009-08-05 17:51:29 -0700104#define IOCTL_KGSL_DEVICE_WAITTIMESTAMP _IOW(KGSL_IOC_TYPE, 0x6, struct kgsl_device_waittimestamp)
Ben Cheng4b29af02012-03-07 16:14:53 -0800105
Dima Zavin81fa6d52009-08-05 17:51:29 -0700106struct kgsl_ringbuffer_issueibcmds {
107 unsigned int drawctxt_id;
108 unsigned int ibaddr;
109 unsigned int sizedwords;
110 unsigned int timestamp;
111 unsigned int flags;
112};
Ben Cheng4b29af02012-03-07 16:14:53 -0800113
Dima Zavin81fa6d52009-08-05 17:51:29 -0700114#define IOCTL_KGSL_RINGBUFFER_ISSUEIBCMDS _IOWR(KGSL_IOC_TYPE, 0x10, struct kgsl_ringbuffer_issueibcmds)
Ben Cheng4b29af02012-03-07 16:14:53 -0800115
Dima Zavin9a96aaa2009-10-03 16:38:49 -0700116struct kgsl_cmdstream_readtimestamp {
Dima Zavin81fa6d52009-08-05 17:51:29 -0700117 unsigned int type;
118 unsigned int timestamp;
119};
Ben Cheng4b29af02012-03-07 16:14:53 -0800120
Dima Zavin9a96aaa2009-10-03 16:38:49 -0700121#define IOCTL_KGSL_CMDSTREAM_READTIMESTAMP _IOR(KGSL_IOC_TYPE, 0x11, struct kgsl_cmdstream_readtimestamp)
Ben Cheng4b29af02012-03-07 16:14:53 -0800122
Dima Zavin9a96aaa2009-10-03 16:38:49 -0700123struct kgsl_cmdstream_freememontimestamp {
Dima Zavin81fa6d52009-08-05 17:51:29 -0700124 unsigned int gpuaddr;
125 unsigned int type;
126 unsigned int timestamp;
127};
Ben Cheng4b29af02012-03-07 16:14:53 -0800128
Dima Zavin9a96aaa2009-10-03 16:38:49 -0700129#define IOCTL_KGSL_CMDSTREAM_FREEMEMONTIMESTAMP _IOR(KGSL_IOC_TYPE, 0x12, struct kgsl_cmdstream_freememontimestamp)
Ben Cheng4b29af02012-03-07 16:14:53 -0800130
Dima Zavin81fa6d52009-08-05 17:51:29 -0700131struct kgsl_drawctxt_create {
132 unsigned int flags;
133 unsigned int drawctxt_id;
134};
Ben Cheng4b29af02012-03-07 16:14:53 -0800135
Dima Zavin81fa6d52009-08-05 17:51:29 -0700136#define IOCTL_KGSL_DRAWCTXT_CREATE _IOWR(KGSL_IOC_TYPE, 0x13, struct kgsl_drawctxt_create)
Ben Cheng4b29af02012-03-07 16:14:53 -0800137
Dima Zavin81fa6d52009-08-05 17:51:29 -0700138struct kgsl_drawctxt_destroy {
139 unsigned int drawctxt_id;
140};
Ben Cheng4b29af02012-03-07 16:14:53 -0800141
Dima Zavin81fa6d52009-08-05 17:51:29 -0700142#define IOCTL_KGSL_DRAWCTXT_DESTROY _IOW(KGSL_IOC_TYPE, 0x14, struct kgsl_drawctxt_destroy)
Ben Cheng4b29af02012-03-07 16:14:53 -0800143
Dima Zavin81fa6d52009-08-05 17:51:29 -0700144struct kgsl_sharedmem_from_pmem {
145 int pmem_fd;
146 unsigned int gpuaddr;
Dima Zavin7b12b4a2009-11-19 09:55:56 -0800147 unsigned int len;
148 unsigned int offset;
Dima Zavin81fa6d52009-08-05 17:51:29 -0700149};
Ben Cheng4b29af02012-03-07 16:14:53 -0800150
Dima Zavin81fa6d52009-08-05 17:51:29 -0700151#define IOCTL_KGSL_SHAREDMEM_FROM_PMEM _IOWR(KGSL_IOC_TYPE, 0x20, struct kgsl_sharedmem_from_pmem)
Ben Cheng4b29af02012-03-07 16:14:53 -0800152
Dima Zavin81fa6d52009-08-05 17:51:29 -0700153struct kgsl_sharedmem_free {
154 unsigned int gpuaddr;
155};
Ben Cheng4b29af02012-03-07 16:14:53 -0800156
Dima Zavin81fa6d52009-08-05 17:51:29 -0700157#define IOCTL_KGSL_SHAREDMEM_FREE _IOW(KGSL_IOC_TYPE, 0x21, struct kgsl_sharedmem_free)
Ben Cheng4b29af02012-03-07 16:14:53 -0800158
Dima Zavin9a96aaa2009-10-03 16:38:49 -0700159struct kgsl_gmem_desc {
160 unsigned int x;
161 unsigned int y;
162 unsigned int width;
163 unsigned int height;
164 unsigned int pitch;
165};
Ben Cheng4b29af02012-03-07 16:14:53 -0800166
Dima Zavin9a96aaa2009-10-03 16:38:49 -0700167struct kgsl_buffer_desc {
168 void *hostptr;
169 unsigned int gpuaddr;
170 int size;
171 unsigned int format;
172 unsigned int pitch;
173 unsigned int enabled;
174};
Ben Cheng4b29af02012-03-07 16:14:53 -0800175
Dima Zavin9a96aaa2009-10-03 16:38:49 -0700176struct kgsl_bind_gmem_shadow {
177 unsigned int drawctxt_id;
178 struct kgsl_gmem_desc gmem_desc;
179 unsigned int shadow_x;
180 unsigned int shadow_y;
181 struct kgsl_buffer_desc shadow_buffer;
182 unsigned int buffer_id;
183};
Ben Cheng4b29af02012-03-07 16:14:53 -0800184
Dima Zavin9a96aaa2009-10-03 16:38:49 -0700185#define IOCTL_KGSL_DRAWCTXT_BIND_GMEM_SHADOW _IOW(KGSL_IOC_TYPE, 0x22, struct kgsl_bind_gmem_shadow)
Ben Cheng4b29af02012-03-07 16:14:53 -0800186
Dima Zavin9a96aaa2009-10-03 16:38:49 -0700187struct kgsl_sharedmem_from_vmalloc {
188 unsigned int gpuaddr;
189 unsigned int hostptr;
Ben Cheng4b29af02012-03-07 16:14:53 -0800190
Dima Zavin9a96aaa2009-10-03 16:38:49 -0700191 int force_no_low_watermark;
192};
Ben Cheng4b29af02012-03-07 16:14:53 -0800193
Dima Zavin9a96aaa2009-10-03 16:38:49 -0700194#define IOCTL_KGSL_SHAREDMEM_FROM_VMALLOC _IOWR(KGSL_IOC_TYPE, 0x23, struct kgsl_sharedmem_from_vmalloc)
Ben Cheng4b29af02012-03-07 16:14:53 -0800195
Dima Zavin9a96aaa2009-10-03 16:38:49 -0700196#define IOCTL_KGSL_SHAREDMEM_FLUSH_CACHE _IOW(KGSL_IOC_TYPE, 0x24, struct kgsl_sharedmem_free)
Ben Cheng4b29af02012-03-07 16:14:53 -0800197
Dima Zavin110044b2009-11-13 02:29:17 -0800198struct kgsl_drawctxt_set_bin_base_offset {
199 unsigned int drawctxt_id;
200 unsigned int offset;
201};
Ben Cheng4b29af02012-03-07 16:14:53 -0800202
Dima Zavin110044b2009-11-13 02:29:17 -0800203#define IOCTL_KGSL_DRAWCTXT_SET_BIN_BASE_OFFSET _IOW(KGSL_IOC_TYPE, 0x25, struct kgsl_drawctxt_set_bin_base_offset)
Ben Cheng4b29af02012-03-07 16:14:53 -0800204
Dima Zavin81fa6d52009-08-05 17:51:29 -0700205#endif
Ben Cheng4b29af02012-03-07 16:14:53 -0800206