1 /*
2  * Copyright 2015 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 #ifndef ANDROID_HARDWARE_GRALLOC1_H
18 #define ANDROID_HARDWARE_GRALLOC1_H
19 
20 #include <hardware/hardware.h>
21 #include <cutils/native_handle.h>
22 
23 __BEGIN_DECLS
24 
25 #define GRALLOC_MODULE_API_VERSION_1_0 HARDWARE_MODULE_API_VERSION(1, 0)
26 #define GRALLOC_HARDWARE_MODULE_ID "gralloc"
27 
28 /*
29  * Enums
30  */
31 
32 typedef enum {
33     GRALLOC1_CAPABILITY_INVALID = 0,
34 
35     /* If this capability is supported, then the outBuffers parameter to
36      * allocate may be NULL, which instructs the device to report whether the
37      * given allocation is possible or not. */
38     GRALLOC1_CAPABILITY_TEST_ALLOCATE = 1,
39 
40     /* If this capability is supported, then the implementation supports
41      * allocating buffers with more than one image layer. */
42     GRALLOC1_CAPABILITY_LAYERED_BUFFERS = 2,
43 
44     /* If this capability is supported, then the implementation always closes
45      * and deletes a buffer handle whenever the last reference is removed.
46      *
47      * Supporting this capability is strongly recommended.  It will become
48      * mandatory in future releases. */
49     GRALLOC1_CAPABILITY_RELEASE_IMPLY_DELETE = 3,
50 
51     GRALLOC1_LAST_CAPABILITY = 3,
52 } gralloc1_capability_t;
53 
54 typedef enum {
55     GRALLOC1_CONSUMER_USAGE_NONE = 0,
56     GRALLOC1_CONSUMER_USAGE_CPU_READ_NEVER = 0,
57     /* 1ULL << 0 */
58     GRALLOC1_CONSUMER_USAGE_CPU_READ = 1ULL << 1,
59     GRALLOC1_CONSUMER_USAGE_CPU_READ_OFTEN = 1ULL << 2 |
60             GRALLOC1_CONSUMER_USAGE_CPU_READ,
61     /* 1ULL << 3 */
62     /* 1ULL << 4 */
63     /* 1ULL << 5 */
64     /* 1ULL << 6 */
65     /* 1ULL << 7 */
66     GRALLOC1_CONSUMER_USAGE_GPU_TEXTURE = 1ULL << 8,
67     /* 1ULL << 9 */
68     /* 1ULL << 10 */
69     GRALLOC1_CONSUMER_USAGE_HWCOMPOSER = 1ULL << 11,
70     GRALLOC1_CONSUMER_USAGE_CLIENT_TARGET = 1ULL << 12,
71     /* 1ULL << 13 */
72     /* 1ULL << 14 */
73     GRALLOC1_CONSUMER_USAGE_CURSOR = 1ULL << 15,
74     GRALLOC1_CONSUMER_USAGE_VIDEO_ENCODER = 1ULL << 16,
75     /* 1ULL << 17 */
76     GRALLOC1_CONSUMER_USAGE_CAMERA = 1ULL << 18,
77     /* 1ULL << 19 */
78     GRALLOC1_CONSUMER_USAGE_RENDERSCRIPT = 1ULL << 20,
79 
80     /* Indicates that the consumer may attach buffers to their end of the
81      * BufferQueue, which means that the producer may never have seen a given
82      * dequeued buffer before. May be ignored by the gralloc device. */
83     GRALLOC1_CONSUMER_USAGE_FOREIGN_BUFFERS = 1ULL << 21,
84 
85     /* 1ULL << 22 */
86     GRALLOC1_CONSUMER_USAGE_GPU_DATA_BUFFER = 1ULL << 23,
87     /* 1ULL << 24 */
88     /* 1ULL << 25 */
89     /* 1ULL << 26 */
90     /* 1ULL << 27 */
91 
92     /* Bits reserved for implementation-specific usage flags */
93     GRALLOC1_CONSUMER_USAGE_PRIVATE_0 = 1ULL << 28,
94     GRALLOC1_CONSUMER_USAGE_PRIVATE_1 = 1ULL << 29,
95     GRALLOC1_CONSUMER_USAGE_PRIVATE_2 = 1ULL << 30,
96     GRALLOC1_CONSUMER_USAGE_PRIVATE_3 = 1ULL << 31,
97 
98     /* 1ULL << 32 */
99     /* 1ULL << 33 */
100     /* 1ULL << 34 */
101     /* 1ULL << 35 */
102     /* 1ULL << 36 */
103     /* 1ULL << 37 */
104     /* 1ULL << 38 */
105     /* 1ULL << 39 */
106     /* 1ULL << 40 */
107     /* 1ULL << 41 */
108     /* 1ULL << 42 */
109     /* 1ULL << 43 */
110     /* 1ULL << 44 */
111     /* 1ULL << 45 */
112     /* 1ULL << 46 */
113     /* 1ULL << 47 */
114 
115     /* Bits reserved for implementation-specific usage flags */
116     GRALLOC1_CONSUMER_USAGE_PRIVATE_19 = 1ULL << 48,
117     GRALLOC1_CONSUMER_USAGE_PRIVATE_18 = 1ULL << 49,
118     GRALLOC1_CONSUMER_USAGE_PRIVATE_17 = 1ULL << 50,
119     GRALLOC1_CONSUMER_USAGE_PRIVATE_16 = 1ULL << 51,
120     GRALLOC1_CONSUMER_USAGE_PRIVATE_15 = 1ULL << 52,
121     GRALLOC1_CONSUMER_USAGE_PRIVATE_14 = 1ULL << 53,
122     GRALLOC1_CONSUMER_USAGE_PRIVATE_13 = 1ULL << 54,
123     GRALLOC1_CONSUMER_USAGE_PRIVATE_12 = 1ULL << 55,
124     GRALLOC1_CONSUMER_USAGE_PRIVATE_11 = 1ULL << 56,
125     GRALLOC1_CONSUMER_USAGE_PRIVATE_10 = 1ULL << 57,
126     GRALLOC1_CONSUMER_USAGE_PRIVATE_9 = 1ULL << 58,
127     GRALLOC1_CONSUMER_USAGE_PRIVATE_8 = 1ULL << 59,
128     GRALLOC1_CONSUMER_USAGE_PRIVATE_7 = 1ULL << 60,
129     GRALLOC1_CONSUMER_USAGE_PRIVATE_6 = 1ULL << 61,
130     GRALLOC1_CONSUMER_USAGE_PRIVATE_5 = 1ULL << 62,
131     GRALLOC1_CONSUMER_USAGE_PRIVATE_4 = 1ULL << 63,
132 } gralloc1_consumer_usage_t;
133 
134 typedef enum {
135     GRALLOC1_FUNCTION_INVALID = 0,
136     GRALLOC1_FUNCTION_DUMP = 1,
137     GRALLOC1_FUNCTION_CREATE_DESCRIPTOR = 2,
138     GRALLOC1_FUNCTION_DESTROY_DESCRIPTOR = 3,
139     GRALLOC1_FUNCTION_SET_CONSUMER_USAGE = 4,
140     GRALLOC1_FUNCTION_SET_DIMENSIONS = 5,
141     GRALLOC1_FUNCTION_SET_FORMAT = 6,
142     GRALLOC1_FUNCTION_SET_PRODUCER_USAGE = 7,
143     GRALLOC1_FUNCTION_GET_BACKING_STORE = 8,
144     GRALLOC1_FUNCTION_GET_CONSUMER_USAGE = 9,
145     GRALLOC1_FUNCTION_GET_DIMENSIONS = 10,
146     GRALLOC1_FUNCTION_GET_FORMAT = 11,
147     GRALLOC1_FUNCTION_GET_PRODUCER_USAGE = 12,
148     GRALLOC1_FUNCTION_GET_STRIDE = 13,
149     GRALLOC1_FUNCTION_ALLOCATE = 14,
150     GRALLOC1_FUNCTION_RETAIN = 15,
151     GRALLOC1_FUNCTION_RELEASE = 16,
152     GRALLOC1_FUNCTION_GET_NUM_FLEX_PLANES = 17,
153     GRALLOC1_FUNCTION_LOCK = 18,
154     GRALLOC1_FUNCTION_LOCK_FLEX = 19,
155     GRALLOC1_FUNCTION_UNLOCK = 20,
156     GRALLOC1_FUNCTION_SET_LAYER_COUNT = 21,
157     GRALLOC1_FUNCTION_GET_LAYER_COUNT = 22,
158     GRALLOC1_FUNCTION_VALIDATE_BUFFER_SIZE = 23,
159     GRALLOC1_FUNCTION_GET_TRANSPORT_SIZE = 24,
160     GRALLOC1_FUNCTION_IMPORT_BUFFER = 25,
161     GRALLOC1_LAST_FUNCTION = 25,
162 } gralloc1_function_descriptor_t;
163 
164 typedef enum {
165     GRALLOC1_ERROR_NONE = 0,
166     GRALLOC1_ERROR_BAD_DESCRIPTOR = 1,
167     GRALLOC1_ERROR_BAD_HANDLE = 2,
168     GRALLOC1_ERROR_BAD_VALUE = 3,
169     GRALLOC1_ERROR_NOT_SHARED = 4,
170     GRALLOC1_ERROR_NO_RESOURCES = 5,
171     GRALLOC1_ERROR_UNDEFINED = 6,
172     GRALLOC1_ERROR_UNSUPPORTED = 7,
173 } gralloc1_error_t;
174 
175 typedef enum {
176     GRALLOC1_PRODUCER_USAGE_NONE = 0,
177     GRALLOC1_PRODUCER_USAGE_CPU_WRITE_NEVER = 0,
178     /* 1ULL << 0 */
179     GRALLOC1_PRODUCER_USAGE_CPU_READ = 1ULL << 1,
180     GRALLOC1_PRODUCER_USAGE_CPU_READ_OFTEN = 1ULL << 2 |
181             GRALLOC1_PRODUCER_USAGE_CPU_READ,
182     /* 1ULL << 3 */
183     /* 1ULL << 4 */
184     GRALLOC1_PRODUCER_USAGE_CPU_WRITE = 1ULL << 5,
185     GRALLOC1_PRODUCER_USAGE_CPU_WRITE_OFTEN = 1ULL << 6 |
186             GRALLOC1_PRODUCER_USAGE_CPU_WRITE,
187     /* 1ULL << 7 */
188     /* 1ULL << 8 */
189     GRALLOC1_PRODUCER_USAGE_GPU_RENDER_TARGET = 1ULL << 9,
190     /* 1ULL << 10 */
191     /* 1ULL << 11 */
192     /* 1ULL << 12 */
193     /* 1ULL << 13 */
194 
195     /* The consumer must have a hardware-protected path to an external display
196      * sink for this buffer. If a hardware-protected path is not available, then
197      * do not attempt to display this buffer. */
198     GRALLOC1_PRODUCER_USAGE_PROTECTED = 1ULL << 14,
199 
200     /* 1ULL << 15 */
201     /* 1ULL << 16 */
202     GRALLOC1_PRODUCER_USAGE_CAMERA = 1ULL << 17,
203     /* 1ULL << 18 */
204     /* 1ULL << 19 */
205     /* 1ULL << 20 */
206     /* 1ULL << 21 */
207     GRALLOC1_PRODUCER_USAGE_VIDEO_DECODER = 1ULL << 22,
208     GRALLOC1_PRODUCER_USAGE_SENSOR_DIRECT_DATA = 1ULL << 23,
209     /* 1ULL << 24 */
210     /* 1ULL << 25 */
211     /* 1ULL << 26 */
212     /* 1ULL << 27 */
213 
214     /* Bits reserved for implementation-specific usage flags */
215     GRALLOC1_PRODUCER_USAGE_PRIVATE_0 = 1ULL << 28,
216     GRALLOC1_PRODUCER_USAGE_PRIVATE_1 = 1ULL << 29,
217     GRALLOC1_PRODUCER_USAGE_PRIVATE_2 = 1ULL << 30,
218     GRALLOC1_PRODUCER_USAGE_PRIVATE_3 = 1ULL << 31,
219 
220     /* 1ULL << 32 */
221     /* 1ULL << 33 */
222     /* 1ULL << 34 */
223     /* 1ULL << 35 */
224     /* 1ULL << 36 */
225     /* 1ULL << 37 */
226     /* 1ULL << 38 */
227     /* 1ULL << 39 */
228     /* 1ULL << 40 */
229     /* 1ULL << 41 */
230     /* 1ULL << 42 */
231     /* 1ULL << 43 */
232     /* 1ULL << 44 */
233     /* 1ULL << 45 */
234     /* 1ULL << 46 */
235     /* 1ULL << 47 */
236 
237     /* Bits reserved for implementation-specific usage flags */
238     GRALLOC1_PRODUCER_USAGE_PRIVATE_19 = 1ULL << 48,
239     GRALLOC1_PRODUCER_USAGE_PRIVATE_18 = 1ULL << 49,
240     GRALLOC1_PRODUCER_USAGE_PRIVATE_17 = 1ULL << 50,
241     GRALLOC1_PRODUCER_USAGE_PRIVATE_16 = 1ULL << 51,
242     GRALLOC1_PRODUCER_USAGE_PRIVATE_15 = 1ULL << 52,
243     GRALLOC1_PRODUCER_USAGE_PRIVATE_14 = 1ULL << 53,
244     GRALLOC1_PRODUCER_USAGE_PRIVATE_13 = 1ULL << 54,
245     GRALLOC1_PRODUCER_USAGE_PRIVATE_12 = 1ULL << 55,
246     GRALLOC1_PRODUCER_USAGE_PRIVATE_11 = 1ULL << 56,
247     GRALLOC1_PRODUCER_USAGE_PRIVATE_10 = 1ULL << 57,
248     GRALLOC1_PRODUCER_USAGE_PRIVATE_9 = 1ULL << 58,
249     GRALLOC1_PRODUCER_USAGE_PRIVATE_8 = 1ULL << 59,
250     GRALLOC1_PRODUCER_USAGE_PRIVATE_7 = 1ULL << 60,
251     GRALLOC1_PRODUCER_USAGE_PRIVATE_6 = 1ULL << 61,
252     GRALLOC1_PRODUCER_USAGE_PRIVATE_5 = 1ULL << 62,
253     GRALLOC1_PRODUCER_USAGE_PRIVATE_4 = 1ULL << 63,
254 } gralloc1_producer_usage_t;
255 
256 /*
257  * Typedefs
258  */
259 
260 typedef void (*gralloc1_function_pointer_t)();
261 
262 typedef uint64_t gralloc1_backing_store_t;
263 typedef uint64_t gralloc1_buffer_descriptor_t;
264 
265 /*
266  * Device Struct
267  */
268 
269 typedef struct gralloc1_device {
270     /* Must be the first member of this struct, since a pointer to this struct
271      * will be generated by casting from a hw_device_t* */
272     struct hw_device_t common;
273 
274     /* getCapabilities(..., outCount, outCapabilities)
275      *
276      * Provides a list of capabilities (described in the definition of
277      * gralloc1_capability_t above) supported by this device. This list must not
278      * change after the device has been loaded.
279      *
280      * Parameters:
281      *   outCount - if outCapabilities was NULL, the number of capabilities
282      *       which would have been returned; if outCapabilities was not NULL,
283      *       the number of capabilities returned, which must not exceed the
284      *       value stored in outCount prior to the call
285      *   outCapabilities - a list of capabilities supported by this device; may
286      *       be NULL, in which case this function must write into outCount the
287      *       number of capabilities which would have been written into
288      *       outCapabilities
289      */
290     void (*getCapabilities)(struct gralloc1_device* device, uint32_t* outCount,
291             int32_t* /*gralloc1_capability_t*/ outCapabilities);
292 
293     /* getFunction(..., descriptor)
294      *
295      * Returns a function pointer which implements the requested description.
296      *
297      * Parameters:
298      *   descriptor - the function to return
299      *
300      * Returns either a function pointer implementing the requested descriptor
301      *   or NULL if the described function is not supported by this device.
302      */
303     gralloc1_function_pointer_t (*getFunction)(struct gralloc1_device* device,
304             int32_t /*gralloc1_function_descriptor_t*/ descriptor);
305 } gralloc1_device_t;
306 
gralloc1_open(const struct hw_module_t * module,gralloc1_device_t ** device)307 static inline int gralloc1_open(const struct hw_module_t* module,
308         gralloc1_device_t** device) {
309     return module->methods->open(module, GRALLOC_HARDWARE_MODULE_ID,
310             TO_HW_DEVICE_T_OPEN(device));
311 }
312 
gralloc1_close(gralloc1_device_t * device)313 static inline int gralloc1_close(gralloc1_device_t* device) {
314     return device->common.close(&device->common);
315 }
316 
317 /* dump(..., outSize, outBuffer)
318  * Function descriptor: GRALLOC1_FUNCTION_DUMP
319  * Must be provided by all gralloc1 devices
320  *
321  * Retrieves implementation-defined debug information, which will be displayed
322  * during, for example, `dumpsys SurfaceFlinger`.
323  *
324  * If called with outBuffer == NULL, the device should store a copy of the
325  * desired output and return its length in bytes in outSize. If the device
326  * already has a stored copy, that copy should be purged and replaced with a
327  * fresh copy.
328  *
329  * If called with outBuffer != NULL, the device should copy its stored version
330  * of the output into outBuffer and store how many bytes of data it copied into
331  * outSize. Prior to this call, the client will have populated outSize with the
332  * maximum number of bytes outBuffer can hold. The device must not write more
333  * than this amount into outBuffer. If the device does not currently have a
334  * stored copy, then it should return 0 in outSize.
335  *
336  * Any data written into outBuffer need not be null-terminated.
337  *
338  * Parameters:
339  *   outSize - if outBuffer was NULL, the number of bytes needed to copy the
340  *       device's stored output; if outBuffer was not NULL, the number of bytes
341  *       written into it, which must not exceed the value stored in outSize
342  *       prior to the call; pointer will be non-NULL
343  *   outBuffer - the buffer to write the dump output into; may be NULL as
344  *       described above; data written into this buffer need not be
345  *       null-terminated
346  */
347 typedef void (*GRALLOC1_PFN_DUMP)(gralloc1_device_t* device, uint32_t* outSize,
348         char* outBuffer);
349 
350 /*
351  * Buffer descriptor lifecycle functions
352  *
353  * All of these functions take as their first parameter a device pointer, so
354  * this parameter is omitted from the described parameter lists.
355  */
356 
357 /* createDescriptor(..., outDescriptor)
358  * Function descriptor: GRALLOC1_FUNCTION_CREATE_DESCRIPTOR
359  * Must be provided by all gralloc1 devices
360  *
361  * Creates a new, empty buffer descriptor.
362  *
363  * Parameters:
364  *   outDescriptor - the new buffer descriptor
365  *
366  * Returns GRALLOC1_ERROR_NONE or one of the following errors:
367  *   GRALLOC1_ERROR_NO_RESOURCES - no more descriptors can currently be created
368  */
369 typedef int32_t /*gralloc1_error_t*/ (*GRALLOC1_PFN_CREATE_DESCRIPTOR)(
370         gralloc1_device_t* device, gralloc1_buffer_descriptor_t* outDescriptor);
371 
372 /* destroyDescriptor(..., descriptor)
373  * Function descriptor: GRALLOC1_FUNCTION_DESTROY_DESCRIPTOR
374  * Must be provided by all gralloc1 devices
375  *
376  * Destroys an existing buffer descriptor.
377  *
378  * Parameters:
379  *   descriptor - the buffer descriptor to destroy
380  *
381  * Returns GRALLOC1_ERROR_NONE or one of the following errors:
382  *   GRALLOC1_ERROR_BAD_DESCRIPTOR - descriptor does not refer to a valid
383  *       buffer descriptor
384  */
385 typedef int32_t /*gralloc1_error_t*/ (*GRALLOC1_PFN_DESTROY_DESCRIPTOR)(
386         gralloc1_device_t* device, gralloc1_buffer_descriptor_t descriptor);
387 
388 /*
389  * Buffer descriptor modification functions
390  *
391  * All of these functions take as their first two parameters a device pointer
392  * and a buffer descriptor, so these parameters are omitted from the described
393  * parameter lists.
394  */
395 
396 /* setConsumerUsage(..., usage)
397  * Function descriptor: GRALLOC1_FUNCTION_SET_CONSUMER_USAGE
398  * Must be provided by all gralloc1 devices
399  *
400  * Sets the desired consumer usage flags of the buffer.
401  *
402  * Valid usage flags can be found in the definition of gralloc1_consumer_usage_t
403  * above.
404  *
405  * Parameters:
406  *   usage - the desired consumer usage flags
407  *
408  * Returns GRALLOC1_ERROR_NONE or one of the following errors:
409  *   GRALLOC1_ERROR_BAD_DESCRIPTOR - the buffer descriptor is invalid
410  *   GRALLOC1_ERROR_BAD_VALUE - an invalid usage flag was passed in
411  */
412 typedef int32_t /*gralloc1_error_t*/ (*GRALLOC1_PFN_SET_CONSUMER_USAGE)(
413         gralloc1_device_t* device, gralloc1_buffer_descriptor_t descriptor,
414         uint64_t /*gralloc1_consumer_usage_t*/ usage);
415 
416 /* setDimensions(..., width, height)
417  * Function descriptor: GRALLOC1_FUNCTION_SET_DIMENSIONS
418  * Must be provided by all gralloc1 devices
419  *
420  * Sets the desired width and height of the buffer in pixels.
421  *
422  * The width specifies how many columns of pixels should be in the allocated
423  * buffer, but does not necessarily represent the offset in columns between the
424  * same column in adjacent rows. If this offset is required, consult getStride
425  * below.
426  *
427  * The height specifies how many rows of pixels should be in the allocated
428  * buffer.
429  *
430  * Parameters:
431  *   width - the desired width in pixels
432  *   height - the desired height in pixels
433  *
434  * Returns GRALLOC1_ERROR_NONE or one of the following errors:
435  *   GRALLOC1_ERROR_BAD_DESCRIPTOR - the buffer descriptor is invalid
436  */
437 typedef int32_t /*gralloc1_error_t*/ (*GRALLOC1_PFN_SET_DIMENSIONS)(
438         gralloc1_device_t* device, gralloc1_buffer_descriptor_t descriptor,
439         uint32_t width, uint32_t height);
440 
441 /* setFormat(..., format)
442  * Function descriptor: GRALLOC1_FUNCTION_SET_FORMAT
443  * Must be provided by all gralloc1 devices
444  *
445  * Sets the desired format of the buffer.
446  *
447  * The valid formats can be found in <system/graphics.h>.
448  *
449  * Parameters:
450  *   format - the desired format
451  *
452  * Returns GRALLOC1_ERROR_NONE or one of the following errors:
453  *   GRALLOC1_ERROR_BAD_DESCRIPTOR - the buffer descriptor is invalid
454  *   GRALLOC1_ERROR_BAD_VALUE - format is invalid
455  */
456 typedef int32_t /*gralloc1_error_t*/ (*GRALLOC1_PFN_SET_FORMAT)(
457         gralloc1_device_t* device, gralloc1_buffer_descriptor_t descriptor,
458         int32_t /*android_pixel_format_t*/ format);
459 
460 /* setLayerCount(..., layerCount)
461  * Function descriptor: GRALLOC1_FUNCTION_SET_LAYER_COUNT
462  * Must be provided by all gralloc1 devices that provide the
463  * GRALLOC1_CAPABILITY_LAYERED_BUFFERS capability.
464  *
465  * Sets the number of layers in the buffer.
466  *
467  * A buffer with multiple layers may be used as the backing store of an array
468  * texture. All layers of a buffer share the same characteristics (e.g.,
469  * dimensions, format, usage). Devices that do not support
470  * GRALLOC1_CAPABILITY_LAYERED_BUFFERS must allocate only buffers with a single
471  * layer.
472  *
473  * Parameters:
474  *   layerCount - the desired number of layers, must be non-zero
475  *
476  * Returns GRALLOC1_ERROR_NONE or one of the following errors:
477  *   GRALLOC1_ERROR_BAD_DESCRIPTOR - the buffer descriptor is invalid
478  *   GRALLOC1_ERROR_BAD_VALUE - the layer count is invalid
479  */
480 typedef int32_t /*gralloc1_error_t*/ (*GRALLOC1_PFN_SET_LAYER_COUNT)(
481         gralloc1_device_t* device, gralloc1_buffer_descriptor_t descriptor,
482         uint32_t layerCount);
483 
484 /* setProducerUsage(..., usage)
485  * Function descriptor: GRALLOC1_FUNCTION_SET_PRODUCER_USAGE
486  * Must be provided by all gralloc1 devices
487  *
488  * Sets the desired producer usage flags of the buffer.
489  *
490  * Valid usage flags can be found in the definition of gralloc1_producer_usage_t
491  * above.
492  *
493  * Parameters:
494  *   usage - the desired producer usage flags
495  *
496  * Returns GRALLOC1_ERROR_NONE or one of the following errors:
497  *   GRALLOC1_ERROR_BAD_DESCRIPTOR - the buffer descriptor is invalid
498  *   GRALLOC1_ERROR_BAD_VALUE - an invalid usage flag was passed in
499  */
500 typedef int32_t /*gralloc1_error_t*/ (*GRALLOC1_PFN_SET_PRODUCER_USAGE)(
501         gralloc1_device_t* device, gralloc1_buffer_descriptor_t descriptor,
502         uint64_t /*gralloc1_producer_usage_t*/ usage);
503 
504 /*
505  * Buffer handle query functions
506  *
507  * All of these functions take as their first two parameters a device pointer
508  * and a buffer handle, so these parameters are omitted from the described
509  * parameter lists.
510  *
511  * [1] Currently many of these functions may return GRALLOC1_ERROR_UNSUPPORTED,
512  * which means that the device is not able to retrieve the requested information
513  * from the buffer. This is necessary to enable a smooth transition from earlier
514  * versions of the gralloc HAL, but gralloc1 implementers are strongly
515  * discouraged from returning this value, as future versions of the platform
516  * code will require all of these functions to succeed given a valid handle.
517  */
518 
519 /* getBackingStore(..., outStore)
520  * Function descriptor: GRALLOC1_FUNCTION_GET_BACKING_STORE
521  * Must be provided by all gralloc1 devices
522  *
523  * Gets a value that uniquely identifies the backing store of the given buffer.
524  *
525  * Buffers which share a backing store should return the same value from this
526  * function. If the buffer is present in more than one process, the backing
527  * store value for that buffer is not required to be the same in every process.
528  *
529  * Parameters:
530  *   outStore - the backing store identifier for this buffer
531  *
532  * Returns GRALLOC1_ERROR_NONE or one of the following errors:
533  *   GRALLOC1_ERROR_BAD_HANDLE - the buffer handle is invalid
534  *   GRALLOC1_ERROR_UNSUPPORTED - the device is unable to retrieve the
535  *       backing store identifier from the buffer; see note [1] in this
536  *       section's header for more information
537  */
538 typedef int32_t /*gralloc1_error_t*/ (*GRALLOC1_PFN_GET_BACKING_STORE)(
539         gralloc1_device_t* device, buffer_handle_t buffer,
540         gralloc1_backing_store_t* outStore);
541 
542 /* getConsumerUsage(..., outUsage)
543  * Function descriptor: GRALLOC1_FUNCTION_GET_CONSUMER_USAGE
544  * Must be provided by all gralloc1 devices
545  *
546  * Gets the consumer usage flags which were used to allocate this buffer.
547  *
548  * Usage flags can be found in the definition of gralloc1_consumer_usage_t above
549  *
550  * Parameters:
551  *   outUsage - the consumer usage flags used to allocate this buffer; must be
552  *       non-NULL
553  *
554  * Returns GRALLOC1_ERROR_NONE or one of the following errors:
555  *   GRALLOC1_ERROR_BAD_HANDLE - the buffer handle is invalid
556  *   GRALLOC1_ERROR_UNSUPPORTED - the device is unable to retrieve the
557  *       dimensions from the buffer; see note [1] in this section's header for
558  *       more information
559  */
560 typedef int32_t /*gralloc1_error_t*/ (*GRALLOC1_PFN_GET_CONSUMER_USAGE)(
561         gralloc1_device_t* device, buffer_handle_t buffer,
562         uint64_t* /*gralloc1_consumer_usage_t*/ outUsage);
563 
564 /* getDimensions(..., outWidth, outHeight)
565  * Function descriptor: GRALLOC1_FUNCTION_GET_DIMENSIONS
566  * Must be provided by all gralloc1 devices
567  *
568  * Gets the width and height of the buffer in pixels.
569  *
570  * See setDimensions for more information about these values.
571  *
572  * Parameters:
573  *   outWidth - the width of the buffer in pixels, must be non-NULL
574  *   outHeight - the height of the buffer in pixels, must be non-NULL
575  *
576  * Returns GRALLOC1_ERROR_NONE or one of the following errors:
577  *   GRALLOC1_ERROR_BAD_HANDLE - the buffer handle is invalid
578  *   GRALLOC1_ERROR_UNSUPPORTED - the device is unable to retrieve the
579  *       dimensions from the buffer; see note [1] in this section's header for
580  *       more information
581  */
582 typedef int32_t /*gralloc1_error_t*/ (*GRALLOC1_PFN_GET_DIMENSIONS)(
583         gralloc1_device_t* device, buffer_handle_t buffer, uint32_t* outWidth,
584         uint32_t* outHeight);
585 
586 /* getFormat(..., outFormat)
587  * Function descriptor: GRALLOC1_FUNCTION_GET_FORMAT
588  * Must be provided by all gralloc1 devices
589  *
590  * Gets the format of the buffer.
591  *
592  * The valid formats can be found in the HAL_PIXEL_FORMAT_* enum in
593  * system/graphics.h.
594  *
595  * Parameters:
596  *   outFormat - the format of the buffer; must be non-NULL
597  *
598  * Returns GRALLOC1_ERROR_NONE or one of the following errors:
599  *   GRALLOC1_ERROR_BAD_HANDLE - the buffer handle is invalid
600  *   GRALLOC1_ERROR_UNSUPPORTED - the device is unable to retrieve the format
601  *       from the buffer; see note [1] in this section's header for more
602  *       information
603  */
604 typedef int32_t /*gralloc1_error_t*/ (*GRALLOC1_PFN_GET_FORMAT)(
605         gralloc1_device_t* device, buffer_handle_t descriptor,
606         int32_t* outFormat);
607 
608 /* getLayerCount(..., outLayerCount)
609  * Function descriptor: GRALLOC1_FUNCTION_GET_LAYER_COUNT
610  * Must be provided by all gralloc1 devices that provide the
611  * GRALLOC1_CAPABILITY_LAYERED_BUFFERS capability.
612  *
613  * Gets the number of layers of the buffer.
614  *
615  * See setLayerCount for more information about this value.
616  *
617  * Parameters:
618  *   outLayerCount - the number of layers in the image, must be non-NULL
619  *
620  * Returns GRALLOC1_ERROR_NONE or one of the following errors:
621  *   GRALLOC1_ERROR_BAD_HANDLE - the buffer handle is invalid
622  *   GRALLOC1_ERROR_UNSUPPORTED - the device is unable to retrieve the
623  *       layer count from the buffer; see note [1] in this section's header for
624  *       more information
625  */
626 typedef int32_t /*gralloc1_error_t*/ (*GRALLOC1_PFN_GET_LAYER_COUNT)(
627         gralloc1_device_t* device, buffer_handle_t buffer,
628         uint32_t* outLayerCount);
629 
630 /* getProducerUsage(..., outUsage)
631  * Function descriptor: GRALLOC1_FUNCTION_GET_PRODUCER_USAGE
632  * Must be provided by all gralloc1 devices
633  *
634  * Gets the producer usage flags which were used to allocate this buffer.
635  *
636  * Usage flags can be found in the definition of gralloc1_producer_usage_t above
637  *
638  * Parameters:
639  *   outUsage - the producer usage flags used to allocate this buffer; must be
640  *       non-NULL
641  *
642  * Returns GRALLOC1_ERROR_NONE or one of the following errors:
643  *   GRALLOC1_ERROR_BAD_HANDLE - the buffer handle is invalid
644  *   GRALLOC1_ERROR_UNSUPPORTED - the device is unable to retrieve the usage
645  *       from the buffer; see note [1] in this section's header for more
646  *       information
647  */
648 typedef int32_t /*gralloc1_error_t*/ (*GRALLOC1_PFN_GET_PRODUCER_USAGE)(
649         gralloc1_device_t* device, buffer_handle_t buffer,
650         uint64_t* /*gralloc1_producer_usage_t*/ outUsage);
651 
652 /* getStride(..., outStride)
653  * Function descriptor: GRALLOC1_FUNCTION_GET_STRIDE
654  * Must be provided by all gralloc1 devices
655  *
656  * Gets the stride of the buffer in pixels.
657  *
658  * The stride is the offset in pixel-sized elements between the same column in
659  * two adjacent rows of pixels. This may not be equal to the width of the
660  * buffer.
661  *
662  * Parameters:
663  *   outStride - the stride in pixels; must be non-NULL
664  *
665  * Returns GRALLOC1_ERROR_NONE or one of the following errors:
666  *   GRALLOC1_ERROR_BAD_HANDLE - the buffer handle is invalid
667  *   GRALLOC1_ERROR_UNDEFINED - the notion of a stride is not meaningful for
668  *       this format
669  *   GRALLOC1_ERROR_UNSUPPORTED - the device is unable to retrieve the stride
670  *       from the descriptor; see note [1] in this section's header for more
671  *       information
672  */
673 typedef int32_t /*gralloc1_error_t*/ (*GRALLOC1_PFN_GET_STRIDE)(
674         gralloc1_device_t* device, buffer_handle_t buffer, uint32_t* outStride);
675 
676 /* getTransportSize(..., outNumFds, outNumInts)
677  * Function descriptor: GRALLOC1_FUNCTION_GET_TRANSPORT_SIZE
678  * This function is optional for all gralloc1 devices.
679  *
680  * Get the transport size of a buffer. An imported buffer handle is a raw
681  * buffer handle with the process-local runtime data appended. This
682  * function, for example, allows a caller to omit the process-local
683  * runtime data at the tail when serializing the imported buffer handle.
684  *
685  * Note that a client might or might not omit the process-local runtime
686  * data when sending an imported buffer handle. The mapper must support
687  * both cases on the receiving end.
688  *
689  * Parameters:
690  *   outNumFds - the number of file descriptors needed for transport
691  *   outNumInts - the number of integers needed for transport
692  *
693  * Returns GRALLOC1_ERROR_NONE or one of the following errors:
694  *   GRALLOC1_ERROR_BAD_HANDLE - the buffer handle is invalid
695  *   GRALLOC1_ERROR_UNSUPPORTED - the device is unable to retrieve the numFds
696  *       and numInts; see note [1] in this section's header for more information
697  */
698 typedef int32_t /*gralloc1_error_t*/ (*GRALLOC1_PFN_GET_TRANSPORT_SIZE)(
699         gralloc1_device_t* device, buffer_handle_t buffer, uint32_t *outNumFds,
700         uint32_t *outNumInts);
701 
702 typedef struct gralloc1_buffer_descriptor_info {
703     uint32_t width;
704     uint32_t height;
705     uint32_t layerCount;
706     int32_t /*android_pixel_format_t*/ format;
707     uint64_t producerUsage;
708     uint64_t consumerUsage;
709 } gralloc1_buffer_descriptor_info_t;
710 
711 /* validateBufferSize(..., )
712  * Function descriptor: GRALLOC1_FUNCTION_VALIDATE_BUFFER_SIZE
713  * This function is optional for all gralloc1 devices.
714  *
715  * Validate that the buffer can be safely accessed by a caller who assumes
716  * the specified descriptorInfo and stride. This must at least validate
717  * that the buffer size is large enough. Validating the buffer against
718  * individual buffer attributes is optional.
719  *
720  * Parameters:
721  *   descriptor - specifies the attributes of the buffer
722  *   stride - the buffer stride returned by IAllocator::allocate
723  *
724  * Returns GRALLOC1_ERROR_NONE or one of the following errors:
725  *   GRALLOC1_ERROR_BAD_HANDLE - the buffer handle is invalid
726  *   GRALLOC1_ERROR_BAD_VALUE - when buffer cannot be safely accessed
727  *   GRALLOC1_ERROR_UNSUPPORTED - the device is unable to validate the buffer
728  *       size; see note [1] in this section's header for more information
729  */
730 typedef int32_t /*gralloc1_error_t*/ (*GRALLOC1_PFN_VALIDATE_BUFFER_SIZE)(
731         gralloc1_device_t* device, buffer_handle_t buffer,
732         const gralloc1_buffer_descriptor_info_t* descriptorInfo,
733         uint32_t stride);
734 
735 /*
736  * Buffer management functions
737  */
738 
739 /* allocate(..., numDescriptors, descriptors, outBuffers)
740  * Function descriptor: GRALLOC1_FUNCTION_ALLOCATE
741  * Must be provided by all gralloc1 devices
742  *
743  * Attempts to allocate a number of buffers sharing a backing store.
744  *
745  * Each buffer will correspond to one of the descriptors passed into the
746  * function. If the device is unable to share the backing store between the
747  * buffers, it should attempt to allocate the buffers with different backing
748  * stores and return GRALLOC1_ERROR_NOT_SHARED if it is successful.
749  *
750  * If this call is successful, the client is responsible for freeing the
751  * buffer_handle_t using release() when it is finished with the buffer. It is
752  * not necessary to call retain() on the returned buffers, as they must have a
753  * reference added by the device before returning.
754  *
755  * If GRALLOC1_CAPABILITY_TEST_ALLOCATE is supported by this device, outBuffers
756  * may be NULL. In this case, the device must not attempt to allocate any
757  * buffers, but instead must return either GRALLOC1_ERROR_NONE if such an
758  * allocation is possible (ignoring potential resource contention which might
759  * lead to a GRALLOC1_ERROR_NO_RESOURCES error), GRALLOC1_ERROR_NOT_SHARED if
760  * the buffers can be allocated, but cannot share a backing store, or
761  * GRALLOC1_ERROR_UNSUPPORTED if one or more of the descriptors can never be
762  * allocated by the device.
763  *
764  * Parameters:
765  *   numDescriptors - the number of buffer descriptors, which must also be equal
766  *       to the size of the outBuffers array
767  *   descriptors - the buffer descriptors to attempt to allocate
768  *   outBuffers - the allocated buffers; must be non-NULL unless the device
769  *       supports GRALLOC1_CAPABILITY_TEST_ALLOCATE (see above), and must not be
770  *       modified by the device if allocation is unsuccessful
771  *
772  * Returns GRALLOC1_ERROR_NONE or one of the following errors:
773  *   GRALLOC1_ERROR_BAD_DESCRIPTOR - one of the descriptors does not refer to a
774  *      valid buffer descriptor
775  *   GRALLOC1_ERROR_NOT_SHARED - allocation was successful, but required more
776  *       than one backing store to satisfy all of the buffer descriptors
777  *   GRALLOC1_ERROR_NO_RESOURCES - allocation failed because one or more of the
778  *       backing stores could not be created at this time (but this allocation
779  *       might succeed at a future time)
780  *   GRALLOC1_ERROR_UNSUPPORTED - one or more of the descriptors can never be
781  *       satisfied by the device
782  */
783 typedef int32_t /*gralloc1_error_t*/ (*GRALLOC1_PFN_ALLOCATE)(
784         gralloc1_device_t* device, uint32_t numDescriptors,
785         const gralloc1_buffer_descriptor_t* descriptors,
786         buffer_handle_t* outBuffers);
787 
788 /* importBuffer(..., rawHandle, outBuffer);
789  * Function descriptor: GRALLOC1_FUNCTION_IMPORT_BUFFER
790  * This function is optional for all gralloc1 devices.
791  * When supported, GRALLOC1_CAPABILITY_RELEASE_IMPLY_DELETE must also be
792  * supported.
793  *
794  * Explictly imports a buffer into a proccess.
795  *
796  * This function can be called in place of retain when a raw buffer handle is
797  * received by a remote process. Import producess a import handle that can
798  * be used to access the underlying graphic buffer. The new import handle has a
799  * ref count of 1.
800  *
801  * This function must at least validate the raw handle before creating the
802  * imported handle. It must also support importing the same raw handle
803  * multiple times to create multiple imported handles. The imported handle
804  * must be considered valid everywhere in the process.
805  *
806  * Parameters:
807  *   rawHandle - the raw buffer handle to import
808  *   outBuffer - a handle to the newly imported buffer
809  *
810  * Returns GRALLOC1_ERROR_NONE or one of the following errors:
811  *   GRALLOC1_ERROR_BAD_HANDLE - the buffer handle is invalid
812  *   GRALLOC1_ERROR_NO_RESOURCES - it is not possible to add a import to this
813  *       buffer at this time
814  */
815 typedef int32_t /*gralloc1_error_t*/ (*GRALLOC1_PFN_IMPORT_BUFFER)(
816         gralloc1_device_t* device, const buffer_handle_t rawHandle,
817         buffer_handle_t* outBuffer);
818 
819 /* retain(..., buffer)
820  * Function descriptor: GRALLOC1_FUNCTION_RETAIN
821  * Must be provided by all gralloc1 devices
822  *
823  * Adds a reference to the given buffer.
824  *
825  * This function must be called when a buffer_handle_t is received from a remote
826  * process to prevent the buffer's data from being freed when the remote process
827  * releases the buffer. It may also be called to increase the reference count if
828  * two components in the same process want to interact with the buffer
829  * independently.
830  *
831  * Parameters:
832  *   buffer - the buffer to which a reference should be added
833  *
834  * Returns GRALLOC1_ERROR_NONE or one of the following errors:
835  *   GRALLOC1_ERROR_BAD_HANDLE - the buffer handle is invalid
836  *   GRALLOC1_ERROR_NO_RESOURCES - it is not possible to add a reference to this
837  *       buffer at this time
838  */
839 typedef int32_t /*gralloc1_error_t*/ (*GRALLOC1_PFN_RETAIN)(
840         gralloc1_device_t* device, buffer_handle_t buffer);
841 
842 /* release(..., buffer)
843  * Function descriptor: GRALLOC1_FUNCTION_RELEASE
844  * Must be provided by all gralloc1 devices
845  *
846  * Removes a reference from the given buffer.
847  *
848  * If no references remain, the buffer should be freed. When the last buffer
849  * referring to a particular backing store is freed, that backing store should
850  * also be freed.
851  *
852  * When GRALLOC1_CAPABILITY_RELEASE_IMPLY_DELETE is supported,
853  * native_handle_close and native_handle_delete must always be called by the
854  * implementation whenever the last reference is removed.  Otherwise, a call
855  * to release() will be followed by native_handle_close and native_handle_delete
856  * by the caller when the buffer is not allocated locally through allocate().
857  *
858  * Parameters:
859  *   buffer - the buffer from which a reference should be removed
860  *
861  * Returns GRALLOC1_ERROR_NONE or one of the following errors:
862  *   GRALLOC1_ERROR_BAD_HANDLE - the buffer handle is invalid
863  */
864 typedef int32_t /*gralloc1_error_t*/ (*GRALLOC1_PFN_RELEASE)(
865         gralloc1_device_t* device, buffer_handle_t buffer);
866 
867 /*
868  * Buffer access functions
869  *
870  * All of these functions take as their first parameter a device pointer, so
871  * this parameter is omitted from the described parameter lists.
872  */
873 
874 typedef struct gralloc1_rect {
875     int32_t left;
876     int32_t top;
877     int32_t width;
878     int32_t height;
879 } gralloc1_rect_t;
880 
881 /* getNumFlexPlanes(..., buffer, outNumPlanes)
882  * Function descriptor: GRALLOC1_FUNCTION_GET_NUM_FLEX_PLANES
883  * Must be provided by all gralloc1 devices
884  *
885  * Returns the number of flex layout planes which are needed to represent the
886  * given buffer. This may be used to efficiently allocate only as many plane
887  * structures as necessary before calling into lockFlex.
888  *
889  * If the given buffer cannot be locked as a flex format, this function may
890  * return GRALLOC1_ERROR_UNSUPPORTED (as lockFlex would).
891  *
892  * Parameters:
893  *   buffer - the buffers for which the number of planes should be queried
894  *   outNumPlanes - the number of flex planes required to describe the given
895  *       buffer; must be non-NULL
896  *
897  * Returns GRALLOC1_ERROR_NONE or one of the following errors:
898  *   GRALLOC1_ERROR_BAD_HANDLE - the buffer handle is invalid
899  *   GRALLOC1_ERROR_UNSUPPORTED - the buffer's format cannot be represented in a
900  *       flex layout
901  */
902 typedef int32_t /*gralloc1_error_t*/ (*GRALLOC1_PFN_GET_NUM_FLEX_PLANES)(
903         gralloc1_device_t* device, buffer_handle_t buffer,
904         uint32_t* outNumPlanes);
905 
906 /* lock(..., buffer, producerUsage, consumerUsage, accessRegion, outData,
907  *     acquireFence)
908  * Function descriptor: GRALLOC1_FUNCTION_LOCK
909  * Must be provided by all gralloc1 devices
910  *
911  * Locks the given buffer for the specified CPU usage.
912  *
913  * Exactly one of producerUsage and consumerUsage must be *_USAGE_NONE. The
914  * usage which is not *_USAGE_NONE must be one of the *_USAGE_CPU_* values, as
915  * applicable. Locking a buffer for a non-CPU usage is not supported.
916  *
917  * Locking the same buffer simultaneously from multiple threads is permitted,
918  * but if any of the threads attempt to lock the buffer for writing, the
919  * behavior is undefined, except that it must not cause process termination or
920  * block the client indefinitely. Leaving the buffer content in an indeterminate
921  * state or returning an error are both acceptable.
922  *
923  * The client must not modify the content of the buffer outside of accessRegion,
924  * and the device need not guarantee that content outside of accessRegion is
925  * valid for reading. The result of reading or writing outside of accessRegion
926  * is undefined, except that it must not cause process termination.
927  *
928  * outData must be a non-NULL pointer, the contents of which which will be
929  * filled with a pointer to the locked buffer memory. This address will
930  * represent the top-left corner of the entire buffer, even if accessRegion does
931  * not begin at the top-left corner.
932  *
933  * acquireFence is a file descriptor referring to a acquire sync fence object,
934  * which will be signaled when it is safe for the device to access the contents
935  * of the buffer (prior to locking). If it is already safe to access the buffer
936  * contents, -1 may be passed instead.
937  *
938  * Parameters:
939  *   buffer - the buffer to lock
940  *   producerUsage - the producer usage flags to request; either this or
941  *       consumerUsage must be GRALLOC1_*_USAGE_NONE, and the other must be a
942  *       CPU usage
943  *   consumerUsage - the consumer usage flags to request; either this or
944  *       producerUsage must be GRALLOC1_*_USAGE_NONE, and the other must be a
945  *       CPU usage
946  *   accessRegion - the portion of the buffer that the client intends to access;
947  *       must be non-NULL
948  *   outData - will be filled with a CPU-accessible pointer to the buffer data;
949  *       must be non-NULL
950  *   acquireFence - a sync fence file descriptor as described above
951  *
952  * Returns GRALLOC1_ERROR_NONE or one of the following errors:
953  *   GRALLOC1_ERROR_BAD_HANDLE - the buffer handle is invalid
954  *   GRALLOC1_ERROR_BAD_VALUE - neither or both of producerUsage and
955  *       consumerUsage were GRALLOC1_*_USAGE_NONE, or the usage which was not
956  *       *_USAGE_NONE was not a CPU usage
957  *   GRALLOC1_ERROR_NO_RESOURCES - the buffer cannot be locked at this time, but
958  *       locking may succeed at a future time
959  *   GRALLOC1_ERROR_UNSUPPORTED - the buffer cannot be locked with the given
960  *       usage, and any future attempts at locking will also fail
961  */
962 typedef int32_t /*gralloc1_error_t*/ (*GRALLOC1_PFN_LOCK)(
963         gralloc1_device_t* device, buffer_handle_t buffer,
964         uint64_t /*gralloc1_producer_usage_t*/ producerUsage,
965         uint64_t /*gralloc1_consumer_usage_t*/ consumerUsage,
966         const gralloc1_rect_t* accessRegion, void** outData,
967         int32_t acquireFence);
968 
969 /* lockFlex(..., buffer, producerUsage, consumerUsage, accessRegion,
970  *     outFlexLayout, outAcquireFence)
971  * Function descriptor: GRALLOC1_FUNCTION_LOCK_FLEX
972  * Must be provided by all gralloc1 devices
973  *
974  * This is largely the same as lock(), except that instead of returning a
975  * pointer directly to the buffer data, it returns an android_flex_layout
976  * struct describing how to access the data planes.
977  *
978  * This function must work on buffers with HAL_PIXEL_FORMAT_YCbCr_*_888 if
979  * supported by the device, as well as with any other formats requested by
980  * multimedia codecs when they are configured with a flexible-YUV-compatible
981  * color format.
982  *
983  * This function may also be called on buffers of other formats, including
984  * non-YUV formats, but if the buffer format is not compatible with a flexible
985  * representation, it may return GRALLOC1_ERROR_UNSUPPORTED.
986  *
987  * Parameters:
988  *   buffer - the buffer to lock
989  *   producerUsage - the producer usage flags to request; either this or
990  *       consumerUsage must be GRALLOC1_*_USAGE_NONE, and the other must be a
991  *       CPU usage
992  *   consumerUsage - the consumer usage flags to request; either this or
993  *       producerUsage must be GRALLOC1_*_USAGE_NONE, and the other must be a
994  *       CPU usage
995  *   accessRegion - the portion of the buffer that the client intends to access;
996  *      must be non-NULL
997  *   outFlexLayout - will be filled with the description of the planes in the
998  *       buffer
999  *   acquireFence - a sync fence file descriptor as described in lock()
1000  *
1001  * Returns GRALLOC1_ERROR_NONE or one of the following errors:
1002  *   GRALLOC1_ERROR_BAD_HANDLE - the buffer handle is invalid
1003  *   GRALLOC1_ERROR_BAD_VALUE - neither or both of producerUsage and
1004  *       consumerUsage were *_USAGE_NONE, or the usage which was not
1005  *       *_USAGE_NONE was not a CPU usage
1006  *   GRALLOC1_ERROR_NO_RESOURCES - the buffer cannot be locked at this time, but
1007  *       locking may succeed at a future time
1008  *   GRALLOC1_ERROR_UNSUPPORTED - the buffer cannot be locked with the given
1009  *       usage, and any future attempts at locking will also fail
1010  */
1011 typedef int32_t /*gralloc1_error_t*/ (*GRALLOC1_PFN_LOCK_FLEX)(
1012         gralloc1_device_t* device, buffer_handle_t buffer,
1013         uint64_t /*gralloc1_producer_usage_t*/ producerUsage,
1014         uint64_t /*gralloc1_consumer_usage_t*/ consumerUsage,
1015         const gralloc1_rect_t* accessRegion,
1016         struct android_flex_layout* outFlexLayout, int32_t acquireFence);
1017 
1018 /* unlock(..., buffer, releaseFence)
1019  * Function descriptor: GRALLOC1_FUNCTION_UNLOCK
1020  * Must be provided by all gralloc1 devices
1021  *
1022  * This function indicates to the device that the client will be done with the
1023  * buffer when releaseFence signals.
1024  *
1025  * outReleaseFence will be filled with a file descriptor referring to a release
1026  * sync fence object, which will be signaled when it is safe to access the
1027  * contents of the buffer (after the buffer has been unlocked). If it is already
1028  * safe to access the buffer contents, then -1 may be returned instead.
1029  *
1030  * This function is used to unlock both buffers locked by lock() and those
1031  * locked by lockFlex().
1032  *
1033  * Parameters:
1034  *   buffer - the buffer to unlock
1035  *   outReleaseFence - a sync fence file descriptor as described above
1036  *
1037  * Returns GRALLOC1_ERROR_NONE or one of the following errors:
1038  *   GRALLOC1_ERROR_BAD_HANDLE - the buffer handle is invalid
1039  */
1040 typedef int32_t /*gralloc1_error_t*/ (*GRALLOC1_PFN_UNLOCK)(
1041         gralloc1_device_t* device, buffer_handle_t buffer,
1042         int32_t* outReleaseFence);
1043 
1044 __END_DECLS
1045 
1046 #endif
1047