1Name 2 3 ANDROID_create_native_client_buffer 4 5Name Strings 6 7 EGL_ANDROID_create_native_client_buffer 8 9Contributors 10 11 Craig Donner 12 13Contact 14 15 Craig Donner, Google Inc. (cdonner 'at' google.com) 16 17Status 18 19 Draft 20 21Version 22 23 Version 1, January 19, 2016 24 25Number 26 27 EGL Extension #99 28 29Dependencies 30 31 Requires EGL 1.2. 32 33 EGL_ANDROID_image_native_buffer and EGL_KHR_image_base are required. 34 35 This extension is written against the wording of the EGL 1.2 36 Specification as modified by EGL_KHR_image_base and 37 EGL_ANDROID_image_native_buffer. 38 39Overview 40 41 This extension allows creating an EGLClientBuffer backed by an Android 42 window buffer (struct ANativeWindowBuffer) which can be later used to 43 create an EGLImage. 44 45New Types 46 47 None. 48 49New Procedures and Functions 50 51 EGLClientBuffer eglCreateNativeClientBufferANDROID( 52 const EGLint *attrib_list) 53 54New Tokens 55 56 EGL_NATIVE_BUFFER_USAGE_ANDROID 0x3143 57 EGL_NATIVE_BUFFER_USAGE_PROTECTED_BIT_ANDROID 0x00000001 58 EGL_NATIVE_BUFFER_USAGE_RENDERBUFFER_BIT_ANDROID 0x00000002 59 EGL_NATIVE_BUFFER_USAGE_TEXTURE_BIT_ANDROID 0x00000004 60 61Changes to Chapter 3 of the EGL 1.2 Specification (EGL Functions and Errors) 62 63 Add the following to section 2.5.1 "EGLImage Specification" (as modified by 64 the EGL_KHR_image_base and EGL_ANDROID_image_native_buffer specifications), 65 below the description of eglCreateImageKHR: 66 67 "The command 68 69 EGLClientBuffer eglCreateNativeClientBufferANDROID( 70 const EGLint *attrib_list) 71 72 may be used to create an EGLClientBuffer backed by an ANativeWindowBuffer 73 struct. EGL implementations must guarantee that the lifetime of the 74 returned EGLClientBuffer is at least as long as the EGLImage(s) it is bound 75 to, following the lifetime semantics described below in section 2.5.2; the 76 EGLClientBuffer must be destroyed no earlier than when all of its associated 77 EGLImages are destroyed by eglDestroyImageKHR. <attrib_list> is a list of 78 attribute-value pairs which is used to specify the dimensions, format, and 79 usage of the underlying buffer structure. If <attrib_list> is non-NULL, the 80 last attribute specified in the list must be EGL_NONE. 81 82 Attribute names accepted in <attrib_list> are shown in Table aaa, 83 together with the <target> for which each attribute name is valid, and 84 the default value used for each attribute if it is not included in 85 <attrib_list>. 86 87 +---------------------------------+----------------------+---------------+ 88 | Attribute | Description | Default Value | 89 | | | | 90 +---------------------------------+----------------------+---------------+ 91 | EGL_NONE | Marks the end of the | N/A | 92 | | attribute-value list | | 93 | EGL_WIDTH | The width of the | 0 | 94 | | buffer data | | 95 | EGL_HEIGHT | The height of the | 0 | 96 | | buffer data | | 97 | EGL_RED_SIZE | The bits of Red in | 0 | 98 | | the color buffer | | 99 | EGL_GREEN_SIZE | The bits of Green in | 0 | 100 | | the color buffer | | 101 | EGL_BLUE_SIZE | The bits of Blue in | 0 | 102 | | the color buffer | | 103 | EGL_ALPHA_SIZE | The bits of Alpha in | 0 | 104 | | the color buffer | | 105 | | buffer data | | 106 | EGL_NATIVE_BUFFER_USAGE_ANDROID | The usage bits of | 0 | 107 | | the buffer data | | 108 +---------------------------------+----------------------+---------------+ 109 Table aaa. Legal attributes for eglCreateNativeClientBufferANDROID 110 <attrib_list> parameter. 111 112 The maximum width and height may depend on the amount of available memory, 113 which may also depend on the format and usage flags. The values of 114 EGL_RED_SIZE, EGL_GREEN_SIZE, and EGL_BLUE_SIZE must be non-zero and 115 correspond to a valid pixel format for the implementation. If EGL_ALPHA_SIZE 116 is non-zero then the combination of all four sizes must correspond to a 117 valid pixel format for the implementation. The 118 EGL_NATIVE_BUFFER_USAGE_ANDROID flag may include any of the following bits: 119 120 EGL_NATIVE_BUFFER_USAGE_PROTECTED_BIT_ANDROID: Indicates that the 121 created buffer must have a hardware-protected path to external display 122 sink. If a hardware-protected path is not available, then either don't 123 composite only this buffer (preferred) to the external sink, or (less 124 desirable) do not route the entire composition to the external sink. 125 126 EGL_NATIVE_BUFFER_USAGE_RENDERBUFFER_BIT_ANDROID: The buffer will be 127 used to create a renderbuffer. This flag must not be set if 128 EGL_NATIVE_BUFFER_USAGE_TEXTURE_BIT_ANDROID is set. 129 130 EGL_NATIVE_BUFFER_USAGE_TEXTURE_BIT_ANDROID: The buffer will be used to 131 create a texture. This flag must not be set if 132 EGL_NATIVE_BUFFER_USAGE_RENDERBUFFER_BIT_ANDROID is set. 133 134 Errors 135 136 If eglCreateNativeClientBufferANDROID fails, NULL will be returned, no 137 memory will be allocated, and one of the following errors will be 138 generated: 139 140 * If the value of EGL_WIDTH or EGL_HEIGHT is not positive, the error 141 EGL_BAD_PARAMETER is generated. 142 143 * If the combination of the values of EGL_RED_SIZE, EGL_GREEN_SIZE, 144 EGL_BLUE_SIZE, and EGL_ALPHA_SIZE is not a valid pixel format for the 145 EGL implementation, the error EGL_BAD_PARAMETER is generated. 146 147 * If the value of EGL_NATIVE_BUFFER_ANDROID is not a valid combination 148 of gralloc usage flags for the EGL implementation, or is incompatible 149 with the value of EGL_FORMAT, the error EGL_BAD_PARAMETER is 150 Generated. 151 152 * If both the EGL_NATIVE_BUFFER_USAGE_RENDERBUFFER_BIT_ANDROID and 153 EGL_NATIVE_BUFFER_USAGE_TEXTURE_BIT_ANDROID are set in the value of 154 EGL_NATIVE_BUFFER_USAGE_ANDROID, the error EGL_BAD_PARAMETER is 155 Generated." 156 157Issues 158 159 1. Should this extension define what combinations of formats and usage flags 160 EGL implementations are required to support? 161 162 RESOLVED: Partially. 163 164 The set of valid color combinations is implementation-specific and may 165 depend on additional EGL extensions, but generally RGB565 and RGBA888 should 166 be supported. The particular valid combinations for a given Android version 167 and implementation should be documented by that version. 168 169 2. Should there be an eglDestroyNativeClientBufferANDROID to destroy the 170 client buffers created by this extension? 171 172 RESOLVED: No. 173 174 A destroy function would add several complications: 175 176 a) ANativeWindowBuffer is a reference counted object, may be used 177 outside of EGL. 178 b) The same buffer may back multiple EGLImages, though this usage may 179 result in undefined behavior. 180 c) The interactions between the lifetimes of EGLImages and their 181 EGLClientBuffers would become needlessly complex. 182 183 Because ANativeWindowBuffer is a reference counted object, implementations 184 of this extension should ensure the buffer has a lifetime at least as long 185 as a generated EGLImage (via EGL_ANDROID_image_native_buffer). The simplest 186 method is to increment the reference count of the buffer in 187 eglCreateImagKHR, and then decrement it in eglDestroyImageKHR. This should 188 ensure proper lifetime semantics. 189 190Revision History 191 192#2 (Craig Donner, April 15, 2016) 193 - Set color formats and usage bits explicitly using additional attributes, 194 and add value for new token EGL_NATIVE_BUFFER_USAGE_ANDROID. 195 196#1 (Craig Donner, January 19, 2016) 197 - Initial draft. 198