blob: 67056df58f09ec6e2703f4c1b92ef3f832b17b57 [file] [log] [blame]
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -07001#ifndef _MSM_KGSL_H
2#define _MSM_KGSL_H
3
4#define KGSL_VERSION_MAJOR 3
Vijay Krishnamoorthye80c3462012-08-27 14:07:32 -07005#define KGSL_VERSION_MINOR 14
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -07006
7/*context flags */
Carter Cooper7e7f02e2012-02-15 09:36:31 -07008#define KGSL_CONTEXT_SAVE_GMEM 0x00000001
9#define KGSL_CONTEXT_NO_GMEM_ALLOC 0x00000002
10#define KGSL_CONTEXT_SUBMIT_IB_LIST 0x00000004
11#define KGSL_CONTEXT_CTX_SWITCH 0x00000008
12#define KGSL_CONTEXT_PREAMBLE 0x00000010
13#define KGSL_CONTEXT_TRASH_STATE 0x00000020
14#define KGSL_CONTEXT_PER_CONTEXT_TS 0x00000040
Vijay Krishnamoorthye80c3462012-08-27 14:07:32 -070015#define KGSL_CONTEXT_USER_GENERATED_TS 0x00000080
Tarun Karra83297222013-02-05 19:45:49 -080016#define KGSL_CONTEXT_NO_FAULT_TOLERANCE 0x00000200
17
Carter Cooper7e7f02e2012-02-15 09:36:31 -070018
19#define KGSL_CONTEXT_INVALID 0xffffffff
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070020
21/* Memory allocayion flags */
22#define KGSL_MEMFLAGS_GPUREADONLY 0x01000000
23
Jeremy Gebben3e626ff2012-09-24 13:05:39 -060024#define KGSL_MEMTYPE_MASK 0x0000FF00
25#define KGSL_MEMTYPE_SHIFT 8
26
27/* Memory types for which allocations are made */
28#define KGSL_MEMTYPE_OBJECTANY 0
29#define KGSL_MEMTYPE_FRAMEBUFFER 1
30#define KGSL_MEMTYPE_RENDERBUFFER 2
31#define KGSL_MEMTYPE_ARRAYBUFFER 3
32#define KGSL_MEMTYPE_ELEMENTARRAYBUFFER 4
33#define KGSL_MEMTYPE_VERTEXARRAYBUFFER 5
34#define KGSL_MEMTYPE_TEXTURE 6
35#define KGSL_MEMTYPE_SURFACE 7
36#define KGSL_MEMTYPE_EGL_SURFACE 8
37#define KGSL_MEMTYPE_GL 9
38#define KGSL_MEMTYPE_CL 10
39#define KGSL_MEMTYPE_CL_BUFFER_MAP 11
40#define KGSL_MEMTYPE_CL_BUFFER_NOMAP 12
41#define KGSL_MEMTYPE_CL_IMAGE_MAP 13
42#define KGSL_MEMTYPE_CL_IMAGE_NOMAP 14
43#define KGSL_MEMTYPE_CL_KERNEL_STACK 15
44#define KGSL_MEMTYPE_COMMAND 16
45#define KGSL_MEMTYPE_2D 17
46#define KGSL_MEMTYPE_EGL_IMAGE 18
47#define KGSL_MEMTYPE_EGL_SHADOW 19
48#define KGSL_MEMTYPE_MULTISAMPLE 20
49#define KGSL_MEMTYPE_KERNEL 255
50
Rajeev Kulkarni8dfdc3362012-11-22 00:22:32 -080051/*
52 * Alignment hint, passed as the power of 2 exponent.
53 * i.e 4k (2^12) would be 12, 64k (2^16)would be 16.
54 */
55#define KGSL_MEMALIGN_MASK 0x00FF0000
56#define KGSL_MEMALIGN_SHIFT 16
57
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070058/* generic flag values */
59#define KGSL_FLAGS_NORMALMODE 0x00000000
60#define KGSL_FLAGS_SAFEMODE 0x00000001
61#define KGSL_FLAGS_INITIALIZED0 0x00000002
62#define KGSL_FLAGS_INITIALIZED 0x00000004
63#define KGSL_FLAGS_STARTED 0x00000008
64#define KGSL_FLAGS_ACTIVE 0x00000010
65#define KGSL_FLAGS_RESERVED0 0x00000020
66#define KGSL_FLAGS_RESERVED1 0x00000040
67#define KGSL_FLAGS_RESERVED2 0x00000080
68#define KGSL_FLAGS_SOFT_RESET 0x00000100
Carter Cooper7e7f02e2012-02-15 09:36:31 -070069#define KGSL_FLAGS_PER_CONTEXT_TIMESTAMPS 0x00000200
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070070
Lucille Sylvesterdce84cd2011-10-12 14:15:37 -060071/* Clock flags to show which clocks should be controled by a given platform */
72#define KGSL_CLK_SRC 0x00000001
73#define KGSL_CLK_CORE 0x00000002
74#define KGSL_CLK_IFACE 0x00000004
75#define KGSL_CLK_MEM 0x00000008
76#define KGSL_CLK_MEM_IFACE 0x00000010
77#define KGSL_CLK_AXI 0x00000020
78
Vijay Krishnamoorthye80c3462012-08-27 14:07:32 -070079/* Server Side Sync Timeout in milliseconds */
80#define KGSL_SYNCOBJ_SERVER_TIMEOUT 2000
81
Shubhraprakash Das2dfe5dd2012-02-10 13:49:53 -070082/*
83 * Reset status values for context
84 */
85enum kgsl_ctx_reset_stat {
86 KGSL_CTX_STAT_NO_ERROR = 0x00000000,
87 KGSL_CTX_STAT_GUILTY_CONTEXT_RESET_EXT = 0x00000001,
88 KGSL_CTX_STAT_INNOCENT_CONTEXT_RESET_EXT = 0x00000002,
89 KGSL_CTX_STAT_UNKNOWN_CONTEXT_RESET_EXT = 0x00000003
90};
91
Suman Tatiraju0123d182011-09-30 14:59:06 -070092#define KGSL_CONVERT_TO_MBPS(val) \
93 (val*1000*1000U)
94
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070095/* device id */
96enum kgsl_deviceid {
97 KGSL_DEVICE_3D0 = 0x00000000,
98 KGSL_DEVICE_2D0 = 0x00000001,
99 KGSL_DEVICE_2D1 = 0x00000002,
100 KGSL_DEVICE_MAX = 0x00000003
101};
102
103enum kgsl_user_mem_type {
104 KGSL_USER_MEM_TYPE_PMEM = 0x00000000,
105 KGSL_USER_MEM_TYPE_ASHMEM = 0x00000001,
Jordan Crouse8eab35a2011-10-12 16:57:48 -0600106 KGSL_USER_MEM_TYPE_ADDR = 0x00000002,
107 KGSL_USER_MEM_TYPE_ION = 0x00000003,
Lynus Vaz31b5290e2012-01-18 19:20:24 +0530108 KGSL_USER_MEM_TYPE_MAX = 0x00000004,
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700109};
110
111struct kgsl_devinfo {
112
113 unsigned int device_id;
114 /* chip revision id
115 * coreid:8 majorrev:8 minorrev:8 patch:8
116 */
117 unsigned int chip_id;
118 unsigned int mmu_enabled;
119 unsigned int gmem_gpubaseaddr;
120 /*
121 * This field contains the adreno revision
122 * number 200, 205, 220, etc...
123 */
124 unsigned int gpu_id;
125 unsigned int gmem_sizebytes;
126};
127
128/* this structure defines the region of memory that can be mmap()ed from this
129 driver. The timestamp fields are volatile because they are written by the
130 GPU
131*/
132struct kgsl_devmemstore {
133 volatile unsigned int soptimestamp;
134 unsigned int sbz;
135 volatile unsigned int eoptimestamp;
136 unsigned int sbz2;
137 volatile unsigned int ts_cmp_enable;
138 unsigned int sbz3;
139 volatile unsigned int ref_wait_ts;
140 unsigned int sbz4;
141 unsigned int current_context;
142 unsigned int sbz5;
143};
144
Carter Cooper7e7f02e2012-02-15 09:36:31 -0700145#define KGSL_MEMSTORE_OFFSET(ctxt_id, field) \
146 ((ctxt_id)*sizeof(struct kgsl_devmemstore) + \
147 offsetof(struct kgsl_devmemstore, field))
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700148
149/* timestamp id*/
150enum kgsl_timestamp_type {
151 KGSL_TIMESTAMP_CONSUMED = 0x00000001, /* start-of-pipeline timestamp */
152 KGSL_TIMESTAMP_RETIRED = 0x00000002, /* end-of-pipeline timestamp*/
Jordan Crousec659f382012-04-16 11:10:41 -0600153 KGSL_TIMESTAMP_QUEUED = 0x00000003,
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700154};
155
156/* property types - used with kgsl_device_getproperty */
157enum kgsl_property_type {
158 KGSL_PROP_DEVICE_INFO = 0x00000001,
159 KGSL_PROP_DEVICE_SHADOW = 0x00000002,
160 KGSL_PROP_DEVICE_POWER = 0x00000003,
161 KGSL_PROP_SHMEM = 0x00000004,
162 KGSL_PROP_SHMEM_APERTURES = 0x00000005,
163 KGSL_PROP_MMU_ENABLE = 0x00000006,
164 KGSL_PROP_INTERRUPT_WAITS = 0x00000007,
165 KGSL_PROP_VERSION = 0x00000008,
Jordan Crousef7370f82012-04-18 09:31:07 -0600166 KGSL_PROP_GPU_RESET_STAT = 0x00000009,
167 KGSL_PROP_PWRCTRL = 0x0000000E,
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700168};
169
170struct kgsl_shadowprop {
171 unsigned int gpuaddr;
172 unsigned int size;
173 unsigned int flags; /* contains KGSL_FLAGS_ values */
174};
175
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700176struct kgsl_version {
177 unsigned int drv_major;
178 unsigned int drv_minor;
179 unsigned int dev_major;
180 unsigned int dev_minor;
181};
182
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700183/* structure holds list of ibs */
184struct kgsl_ibdesc {
185 unsigned int gpuaddr;
186 void *hostptr;
187 unsigned int sizedwords;
188 unsigned int ctrl;
189};
190
191/* ioctls */
192#define KGSL_IOC_TYPE 0x09
193
194/* get misc info about the GPU
195 type should be a value from enum kgsl_property_type
196 value points to a structure that varies based on type
197 sizebytes is sizeof() that structure
198 for KGSL_PROP_DEVICE_INFO, use struct kgsl_devinfo
199 this structure contaings hardware versioning info.
200 for KGSL_PROP_DEVICE_SHADOW, use struct kgsl_shadowprop
201 this is used to find mmap() offset and sizes for mapping
202 struct kgsl_memstore into userspace.
203*/
204struct kgsl_device_getproperty {
205 unsigned int type;
206 void *value;
207 unsigned int sizebytes;
208};
209
210#define IOCTL_KGSL_DEVICE_GETPROPERTY \
211 _IOWR(KGSL_IOC_TYPE, 0x2, struct kgsl_device_getproperty)
212
Harsh Vardhan Dwivedib6cebfe2012-03-15 18:20:59 -0600213/* IOCTL_KGSL_DEVICE_READ (0x3) - removed 03/2012
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700214 */
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700215
216/* block until the GPU has executed past a given timestamp
217 * timeout is in milliseconds.
218 */
219struct kgsl_device_waittimestamp {
220 unsigned int timestamp;
221 unsigned int timeout;
222};
223
224#define IOCTL_KGSL_DEVICE_WAITTIMESTAMP \
225 _IOW(KGSL_IOC_TYPE, 0x6, struct kgsl_device_waittimestamp)
226
Carter Cooper7e7f02e2012-02-15 09:36:31 -0700227struct kgsl_device_waittimestamp_ctxtid {
228 unsigned int context_id;
229 unsigned int timestamp;
230 unsigned int timeout;
231};
232
233#define IOCTL_KGSL_DEVICE_WAITTIMESTAMP_CTXTID \
234 _IOW(KGSL_IOC_TYPE, 0x7, struct kgsl_device_waittimestamp_ctxtid)
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700235
236/* issue indirect commands to the GPU.
237 * drawctxt_id must have been created with IOCTL_KGSL_DRAWCTXT_CREATE
238 * ibaddr and sizedwords must specify a subset of a buffer created
239 * with IOCTL_KGSL_SHAREDMEM_FROM_PMEM
240 * flags may be a mask of KGSL_CONTEXT_ values
241 * timestamp is a returned counter value which can be passed to
242 * other ioctls to determine when the commands have been executed by
243 * the GPU.
244 */
245struct kgsl_ringbuffer_issueibcmds {
246 unsigned int drawctxt_id;
247 unsigned int ibdesc_addr;
248 unsigned int numibs;
249 unsigned int timestamp; /*output param */
250 unsigned int flags;
251};
252
253#define IOCTL_KGSL_RINGBUFFER_ISSUEIBCMDS \
254 _IOWR(KGSL_IOC_TYPE, 0x10, struct kgsl_ringbuffer_issueibcmds)
255
256/* read the most recently executed timestamp value
257 * type should be a value from enum kgsl_timestamp_type
258 */
259struct kgsl_cmdstream_readtimestamp {
260 unsigned int type;
261 unsigned int timestamp; /*output param */
262};
263
Jason Varbedian80ba33d2011-07-11 17:29:05 -0700264#define IOCTL_KGSL_CMDSTREAM_READTIMESTAMP_OLD \
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700265 _IOR(KGSL_IOC_TYPE, 0x11, struct kgsl_cmdstream_readtimestamp)
266
Jason Varbedian80ba33d2011-07-11 17:29:05 -0700267#define IOCTL_KGSL_CMDSTREAM_READTIMESTAMP \
268 _IOWR(KGSL_IOC_TYPE, 0x11, struct kgsl_cmdstream_readtimestamp)
269
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700270/* free memory when the GPU reaches a given timestamp.
271 * gpuaddr specify a memory region created by a
272 * IOCTL_KGSL_SHAREDMEM_FROM_PMEM call
273 * type should be a value from enum kgsl_timestamp_type
274 */
275struct kgsl_cmdstream_freememontimestamp {
276 unsigned int gpuaddr;
277 unsigned int type;
278 unsigned int timestamp;
279};
280
281#define IOCTL_KGSL_CMDSTREAM_FREEMEMONTIMESTAMP \
282 _IOW(KGSL_IOC_TYPE, 0x12, struct kgsl_cmdstream_freememontimestamp)
283
284/* Previous versions of this header had incorrectly defined
285 IOCTL_KGSL_CMDSTREAM_FREEMEMONTIMESTAMP as a read-only ioctl instead
286 of a write only ioctl. To ensure binary compatability, the following
287 #define will be used to intercept the incorrect ioctl
288*/
289
290#define IOCTL_KGSL_CMDSTREAM_FREEMEMONTIMESTAMP_OLD \
291 _IOR(KGSL_IOC_TYPE, 0x12, struct kgsl_cmdstream_freememontimestamp)
292
293/* create a draw context, which is used to preserve GPU state.
294 * The flags field may contain a mask KGSL_CONTEXT_* values
295 */
296struct kgsl_drawctxt_create {
297 unsigned int flags;
298 unsigned int drawctxt_id; /*output param */
299};
300
301#define IOCTL_KGSL_DRAWCTXT_CREATE \
302 _IOWR(KGSL_IOC_TYPE, 0x13, struct kgsl_drawctxt_create)
303
304/* destroy a draw context */
305struct kgsl_drawctxt_destroy {
306 unsigned int drawctxt_id;
307};
308
309#define IOCTL_KGSL_DRAWCTXT_DESTROY \
310 _IOW(KGSL_IOC_TYPE, 0x14, struct kgsl_drawctxt_destroy)
311
312/* add a block of pmem, fb, ashmem or user allocated address
313 * into the GPU address space */
314struct kgsl_map_user_mem {
315 int fd;
316 unsigned int gpuaddr; /*output param */
317 unsigned int len;
318 unsigned int offset;
319 unsigned int hostptr; /*input param */
320 enum kgsl_user_mem_type memtype;
Jeremy Gebben3e626ff2012-09-24 13:05:39 -0600321 unsigned int flags;
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700322};
323
324#define IOCTL_KGSL_MAP_USER_MEM \
325 _IOWR(KGSL_IOC_TYPE, 0x15, struct kgsl_map_user_mem)
326
Carter Cooper7e7f02e2012-02-15 09:36:31 -0700327struct kgsl_cmdstream_readtimestamp_ctxtid {
328 unsigned int context_id;
329 unsigned int type;
330 unsigned int timestamp; /*output param */
331};
332
333#define IOCTL_KGSL_CMDSTREAM_READTIMESTAMP_CTXTID \
334 _IOWR(KGSL_IOC_TYPE, 0x16, struct kgsl_cmdstream_readtimestamp_ctxtid)
335
336struct kgsl_cmdstream_freememontimestamp_ctxtid {
337 unsigned int context_id;
338 unsigned int gpuaddr;
339 unsigned int type;
340 unsigned int timestamp;
341};
342
343#define IOCTL_KGSL_CMDSTREAM_FREEMEMONTIMESTAMP_CTXTID \
344 _IOW(KGSL_IOC_TYPE, 0x17, \
345 struct kgsl_cmdstream_freememontimestamp_ctxtid)
346
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700347/* add a block of pmem or fb into the GPU address space */
348struct kgsl_sharedmem_from_pmem {
349 int pmem_fd;
350 unsigned int gpuaddr; /*output param */
351 unsigned int len;
352 unsigned int offset;
353};
354
355#define IOCTL_KGSL_SHAREDMEM_FROM_PMEM \
356 _IOWR(KGSL_IOC_TYPE, 0x20, struct kgsl_sharedmem_from_pmem)
357
358/* remove memory from the GPU's address space */
359struct kgsl_sharedmem_free {
360 unsigned int gpuaddr;
361};
362
363#define IOCTL_KGSL_SHAREDMEM_FREE \
364 _IOW(KGSL_IOC_TYPE, 0x21, struct kgsl_sharedmem_free)
365
Sushmita Susheelendra41f8fa32011-05-11 17:15:58 -0600366struct kgsl_cff_user_event {
367 unsigned char cff_opcode;
368 unsigned int op1;
369 unsigned int op2;
370 unsigned int op3;
371 unsigned int op4;
372 unsigned int op5;
373 unsigned int __pad[2];
374};
375
376#define IOCTL_KGSL_CFF_USER_EVENT \
377 _IOW(KGSL_IOC_TYPE, 0x31, struct kgsl_cff_user_event)
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700378
379struct kgsl_gmem_desc {
380 unsigned int x;
381 unsigned int y;
382 unsigned int width;
383 unsigned int height;
384 unsigned int pitch;
385};
386
387struct kgsl_buffer_desc {
388 void *hostptr;
389 unsigned int gpuaddr;
390 int size;
391 unsigned int format;
392 unsigned int pitch;
393 unsigned int enabled;
394};
395
396struct kgsl_bind_gmem_shadow {
397 unsigned int drawctxt_id;
398 struct kgsl_gmem_desc gmem_desc;
399 unsigned int shadow_x;
400 unsigned int shadow_y;
401 struct kgsl_buffer_desc shadow_buffer;
402 unsigned int buffer_id;
403};
404
405#define IOCTL_KGSL_DRAWCTXT_BIND_GMEM_SHADOW \
406 _IOW(KGSL_IOC_TYPE, 0x22, struct kgsl_bind_gmem_shadow)
407
408/* add a block of memory into the GPU address space */
Jordan Crousedb8cf392012-09-11 16:38:14 -0600409
410/*
411 * IOCTL_KGSL_SHAREDMEM_FROM_VMALLOC deprecated 09/2012
412 * use IOCTL_KGSL_GPUMEM_ALLOC instead
413 */
414
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700415struct kgsl_sharedmem_from_vmalloc {
416 unsigned int gpuaddr; /*output param */
417 unsigned int hostptr;
418 unsigned int flags;
419};
420
421#define IOCTL_KGSL_SHAREDMEM_FROM_VMALLOC \
422 _IOWR(KGSL_IOC_TYPE, 0x23, struct kgsl_sharedmem_from_vmalloc)
423
424#define IOCTL_KGSL_SHAREDMEM_FLUSH_CACHE \
425 _IOW(KGSL_IOC_TYPE, 0x24, struct kgsl_sharedmem_free)
426
427struct kgsl_drawctxt_set_bin_base_offset {
428 unsigned int drawctxt_id;
429 unsigned int offset;
430};
431
432#define IOCTL_KGSL_DRAWCTXT_SET_BIN_BASE_OFFSET \
433 _IOW(KGSL_IOC_TYPE, 0x25, struct kgsl_drawctxt_set_bin_base_offset)
434
435enum kgsl_cmdwindow_type {
436 KGSL_CMDWINDOW_MIN = 0x00000000,
437 KGSL_CMDWINDOW_2D = 0x00000000,
438 KGSL_CMDWINDOW_3D = 0x00000001, /* legacy */
439 KGSL_CMDWINDOW_MMU = 0x00000002,
440 KGSL_CMDWINDOW_ARBITER = 0x000000FF,
441 KGSL_CMDWINDOW_MAX = 0x000000FF,
442};
443
444/* write to the command window */
445struct kgsl_cmdwindow_write {
446 enum kgsl_cmdwindow_type target;
447 unsigned int addr;
448 unsigned int data;
449};
450
451#define IOCTL_KGSL_CMDWINDOW_WRITE \
452 _IOW(KGSL_IOC_TYPE, 0x2e, struct kgsl_cmdwindow_write)
453
454struct kgsl_gpumem_alloc {
455 unsigned long gpuaddr;
456 size_t size;
457 unsigned int flags;
458};
459
460#define IOCTL_KGSL_GPUMEM_ALLOC \
461 _IOWR(KGSL_IOC_TYPE, 0x2f, struct kgsl_gpumem_alloc)
462
Jeremy Gebbena7423e42011-04-18 15:11:21 -0600463struct kgsl_cff_syncmem {
464 unsigned int gpuaddr;
465 unsigned int len;
466 unsigned int __pad[2]; /* For future binary compatibility */
467};
468
469#define IOCTL_KGSL_CFF_SYNCMEM \
470 _IOW(KGSL_IOC_TYPE, 0x30, struct kgsl_cff_syncmem)
471
Jordan Croused4bc9d22011-11-17 13:39:21 -0700472/*
473 * A timestamp event allows the user space to register an action following an
Jeff Boodyfe6c39c2012-08-09 13:54:50 -0600474 * expired timestamp. Note IOCTL_KGSL_TIMESTAMP_EVENT has been redefined to
475 * _IOWR to support fences which need to return a fd for the priv parameter.
Jordan Croused4bc9d22011-11-17 13:39:21 -0700476 */
477
478struct kgsl_timestamp_event {
479 int type; /* Type of event (see list below) */
480 unsigned int timestamp; /* Timestamp to trigger event on */
481 unsigned int context_id; /* Context for the timestamp */
482 void *priv; /* Pointer to the event specific blob */
483 size_t len; /* Size of the event specific blob */
484};
485
Jeff Boodyfe6c39c2012-08-09 13:54:50 -0600486#define IOCTL_KGSL_TIMESTAMP_EVENT_OLD \
Jordan Croused4bc9d22011-11-17 13:39:21 -0700487 _IOW(KGSL_IOC_TYPE, 0x31, struct kgsl_timestamp_event)
488
489/* A genlock timestamp event releases an existing lock on timestamp expire */
490
491#define KGSL_TIMESTAMP_EVENT_GENLOCK 1
492
493struct kgsl_timestamp_event_genlock {
494 int handle; /* Handle of the genlock lock to release */
495};
496
Jeff Boodyfe6c39c2012-08-09 13:54:50 -0600497/* A fence timestamp event releases an existing lock on timestamp expire */
498
499#define KGSL_TIMESTAMP_EVENT_FENCE 2
500
501struct kgsl_timestamp_event_fence {
502 int fence_fd; /* Fence to signal */
503};
504
Jordan Crouseed7dd7f2012-03-29 13:16:02 -0600505/*
506 * Set a property within the kernel. Uses the same structure as
507 * IOCTL_KGSL_GETPROPERTY
508 */
509
510#define IOCTL_KGSL_SETPROPERTY \
511 _IOW(KGSL_IOC_TYPE, 0x32, struct kgsl_device_getproperty)
512
Jeff Boodyfe6c39c2012-08-09 13:54:50 -0600513#define IOCTL_KGSL_TIMESTAMP_EVENT \
514 _IOWR(KGSL_IOC_TYPE, 0x33, struct kgsl_timestamp_event)
515
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -0700516#ifdef __KERNEL__
517#ifdef CONFIG_MSM_KGSL_DRM
518int kgsl_gem_obj_addr(int drm_fd, int handle, unsigned long *start,
519 unsigned long *len);
520#else
521#define kgsl_gem_obj_addr(...) 0
522#endif
523#endif
524#endif /* _MSM_KGSL_H */