Home | History | Annotate | Download | only in egl
      1 /*
      2  * Copyright (C) 2009 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_ANDROID_NATIVES_H
     18 #define ANDROID_ANDROID_NATIVES_H
     19 
     20 #include <sys/types.h>
     21 #include <string.h>
     22 
     23 #include <hardware/gralloc.h>
     24 
     25 #include <android/native_window.h>
     26 
     27 #ifdef __cplusplus
     28 extern "C" {
     29 #endif
     30 
     31 /*****************************************************************************/
     32 
     33 #define ANDROID_NATIVE_MAKE_CONSTANT(a,b,c,d) \
     34     (((unsigned)(a)<<24)|((unsigned)(b)<<16)|((unsigned)(c)<<8)|(unsigned)(d))
     35 
     36 #define ANDROID_NATIVE_WINDOW_MAGIC \
     37     ANDROID_NATIVE_MAKE_CONSTANT('_','w','n','d')
     38 
     39 #define ANDROID_NATIVE_BUFFER_MAGIC \
     40     ANDROID_NATIVE_MAKE_CONSTANT('_','b','f','r')
     41 
     42 // ---------------------------------------------------------------------------
     43 
     44 struct android_native_buffer_t;
     45 
     46 typedef struct android_native_rect_t
     47 {
     48     int32_t left;
     49     int32_t top;
     50     int32_t right;
     51     int32_t bottom;
     52 } android_native_rect_t;
     53 
     54 // ---------------------------------------------------------------------------
     55 
     56 typedef struct android_native_base_t
     57 {
     58     /* a magic value defined by the actual EGL native type */
     59     int magic;
     60 
     61     /* the sizeof() of the actual EGL native type */
     62     int version;
     63 
     64     void* reserved[4];
     65 
     66     /* reference-counting interface */
     67     void (*incRef)(struct android_native_base_t* base);
     68     void (*decRef)(struct android_native_base_t* base);
     69 } android_native_base_t;
     70 
     71 // ---------------------------------------------------------------------------
     72 
     73 /* attributes queriable with query() */
     74 enum {
     75     NATIVE_WINDOW_WIDTH     = 0,
     76     NATIVE_WINDOW_HEIGHT,
     77     NATIVE_WINDOW_FORMAT,
     78 };
     79 
     80 /* valid operations for the (*perform)() hook */
     81 enum {
     82     NATIVE_WINDOW_SET_USAGE  = 0,
     83     NATIVE_WINDOW_CONNECT,
     84     NATIVE_WINDOW_DISCONNECT,
     85     NATIVE_WINDOW_SET_CROP,
     86     NATIVE_WINDOW_SET_BUFFER_COUNT,
     87     NATIVE_WINDOW_SET_BUFFERS_GEOMETRY,
     88     NATIVE_WINDOW_SET_BUFFERS_TRANSFORM,
     89 };
     90 
     91 /* parameter for NATIVE_WINDOW_[DIS]CONNECT */
     92 enum {
     93     NATIVE_WINDOW_API_EGL = 1
     94 };
     95 
     96 /* parameter for NATIVE_WINDOW_SET_BUFFERS_TRANSFORM */
     97 enum {
     98     /* flip source image horizontally */
     99     NATIVE_WINDOW_TRANSFORM_FLIP_H = HAL_TRANSFORM_FLIP_H ,
    100     /* flip source image vertically */
    101     NATIVE_WINDOW_TRANSFORM_FLIP_V = HAL_TRANSFORM_FLIP_V,
    102     /* rotate source image 90 degrees clock-wise */
    103     NATIVE_WINDOW_TRANSFORM_ROT_90 = HAL_TRANSFORM_ROT_90,
    104     /* rotate source image 180 degrees */
    105     NATIVE_WINDOW_TRANSFORM_ROT_180 = HAL_TRANSFORM_ROT_180,
    106     /* rotate source image 270 degrees clock-wise */
    107     NATIVE_WINDOW_TRANSFORM_ROT_270 = HAL_TRANSFORM_ROT_270,
    108 };
    109 
    110 struct ANativeWindow
    111 {
    112 #ifdef __cplusplus
    113     ANativeWindow()
    114         : flags(0), minSwapInterval(0), maxSwapInterval(0), xdpi(0), ydpi(0)
    115     {
    116         common.magic = ANDROID_NATIVE_WINDOW_MAGIC;
    117         common.version = sizeof(ANativeWindow);
    118         memset(common.reserved, 0, sizeof(common.reserved));
    119     }
    120 
    121     // Implement the methods that sp<ANativeWindow> expects so that it
    122     // can be used to automatically refcount ANativeWindow's.
    123     void incStrong(const void* id) const {
    124         common.incRef(const_cast<android_native_base_t*>(&common));
    125     }
    126     void decStrong(const void* id) const {
    127         common.decRef(const_cast<android_native_base_t*>(&common));
    128     }
    129 #endif
    130 
    131     struct android_native_base_t common;
    132 
    133     /* flags describing some attributes of this surface or its updater */
    134     const uint32_t flags;
    135 
    136     /* min swap interval supported by this updated */
    137     const int   minSwapInterval;
    138 
    139     /* max swap interval supported by this updated */
    140     const int   maxSwapInterval;
    141 
    142     /* horizontal and vertical resolution in DPI */
    143     const float xdpi;
    144     const float ydpi;
    145 
    146     /* Some storage reserved for the OEM's driver. */
    147     intptr_t    oem[4];
    148 
    149 
    150     /*
    151      * Set the swap interval for this surface.
    152      *
    153      * Returns 0 on success or -errno on error.
    154      */
    155     int     (*setSwapInterval)(struct ANativeWindow* window,
    156                 int interval);
    157 
    158     /*
    159      * hook called by EGL to acquire a buffer. After this call, the buffer
    160      * is not locked, so its content cannot be modified.
    161      * this call may block if no buffers are available.
    162      *
    163      * Returns 0 on success or -errno on error.
    164      */
    165     int     (*dequeueBuffer)(struct ANativeWindow* window,
    166                 struct android_native_buffer_t** buffer);
    167 
    168     /*
    169      * hook called by EGL to lock a buffer. This MUST be called before modifying
    170      * the content of a buffer. The buffer must have been acquired with
    171      * dequeueBuffer first.
    172      *
    173      * Returns 0 on success or -errno on error.
    174      */
    175     int     (*lockBuffer)(struct ANativeWindow* window,
    176                 struct android_native_buffer_t* buffer);
    177    /*
    178     * hook called by EGL when modifications to the render buffer are done.
    179     * This unlocks and post the buffer.
    180     *
    181     * Buffers MUST be queued in the same order than they were dequeued.
    182     *
    183     * Returns 0 on success or -errno on error.
    184     */
    185     int     (*queueBuffer)(struct ANativeWindow* window,
    186                 struct android_native_buffer_t* buffer);
    187 
    188     /*
    189      * hook used to retrieve information about the native window.
    190      *
    191      * Returns 0 on success or -errno on error.
    192      */
    193     int     (*query)(struct ANativeWindow* window,
    194                 int what, int* value);
    195 
    196     /*
    197      * hook used to perform various operations on the surface.
    198      * (*perform)() is a generic mechanism to add functionality to
    199      * ANativeWindow while keeping backward binary compatibility.
    200      *
    201      * This hook should not be called directly, instead use the helper functions
    202      * defined below.
    203      *
    204      *  (*perform)() returns -ENOENT if the 'what' parameter is not supported
    205      *  by the surface's implementation.
    206      *
    207      * The valid operations are:
    208      *     NATIVE_WINDOW_SET_USAGE
    209      *     NATIVE_WINDOW_CONNECT
    210      *     NATIVE_WINDOW_DISCONNECT
    211      *     NATIVE_WINDOW_SET_CROP
    212      *     NATIVE_WINDOW_SET_BUFFER_COUNT
    213      *     NATIVE_WINDOW_SET_BUFFERS_GEOMETRY
    214      *     NATIVE_WINDOW_SET_BUFFERS_TRANSFORM
    215      *
    216      */
    217 
    218     int     (*perform)(struct ANativeWindow* window,
    219                 int operation, ... );
    220 
    221     /*
    222      * hook used to cancel a buffer that has been dequeued.
    223      * No synchronization is performed between dequeue() and cancel(), so
    224      * either external synchronization is needed, or these functions must be
    225      * called from the same thread.
    226      */
    227     int     (*cancelBuffer)(struct ANativeWindow* window,
    228                 struct android_native_buffer_t* buffer);
    229 
    230 
    231     void* reserved_proc[2];
    232 };
    233 
    234 // Backwards compatibility...  please switch to ANativeWindow.
    235 typedef struct ANativeWindow android_native_window_t;
    236 
    237 /*
    238  *  native_window_set_usage(..., usage)
    239  *  Sets the intended usage flags for the next buffers
    240  *  acquired with (*lockBuffer)() and on.
    241  *  By default (if this function is never called), a usage of
    242  *      GRALLOC_USAGE_HW_RENDER | GRALLOC_USAGE_HW_TEXTURE
    243  *  is assumed.
    244  *  Calling this function will usually cause following buffers to be
    245  *  reallocated.
    246  */
    247 
    248 static inline int native_window_set_usage(
    249         ANativeWindow* window, int usage)
    250 {
    251     return window->perform(window, NATIVE_WINDOW_SET_USAGE, usage);
    252 }
    253 
    254 /*
    255  * native_window_connect(..., NATIVE_WINDOW_API_EGL)
    256  * Must be called by EGL when the window is made current.
    257  * Returns -EINVAL if for some reason the window cannot be connected, which
    258  * can happen if it's connected to some other API.
    259  */
    260 static inline int native_window_connect(
    261         ANativeWindow* window, int api)
    262 {
    263     return window->perform(window, NATIVE_WINDOW_CONNECT, api);
    264 }
    265 
    266 /*
    267  * native_window_disconnect(..., NATIVE_WINDOW_API_EGL)
    268  * Must be called by EGL when the window is made not current.
    269  * An error is returned if for instance the window wasn't connected in the
    270  * first place.
    271  */
    272 static inline int native_window_disconnect(
    273         ANativeWindow* window, int api)
    274 {
    275     return window->perform(window, NATIVE_WINDOW_DISCONNECT, api);
    276 }
    277 
    278 /*
    279  * native_window_set_crop(..., crop)
    280  * Sets which region of the next queued buffers needs to be considered.
    281  * A buffer's crop region is scaled to match the surface's size.
    282  *
    283  * The specified crop region applies to all buffers queued after it is called.
    284  *
    285  * if 'crop' is NULL, subsequently queued buffers won't be cropped.
    286  *
    287  * An error is returned if for instance the crop region is invalid,
    288  * out of the buffer's bound or if the window is invalid.
    289  */
    290 static inline int native_window_set_crop(
    291         ANativeWindow* window,
    292         android_native_rect_t const * crop)
    293 {
    294     return window->perform(window, NATIVE_WINDOW_SET_CROP, crop);
    295 }
    296 
    297 /*
    298  * native_window_set_buffer_count(..., count)
    299  * Sets the number of buffers associated with this native window.
    300  */
    301 static inline int native_window_set_buffer_count(
    302         ANativeWindow* window,
    303         size_t bufferCount)
    304 {
    305     return window->perform(window, NATIVE_WINDOW_SET_BUFFER_COUNT, bufferCount);
    306 }
    307 
    308 /*
    309  * native_window_set_buffers_geometry(..., int w, int h, int format)
    310  * All buffers dequeued after this call will have the geometry specified.
    311  * In particular, all buffers will have a fixed-size, independent form the
    312  * native-window size. They will be appropriately scaled to the window-size
    313  * upon composition.
    314  *
    315  * If all parameters are 0, the normal behavior is restored. That is,
    316  * dequeued buffers following this call will be sized to the window's size.
    317  *
    318  */
    319 static inline int native_window_set_buffers_geometry(
    320         ANativeWindow* window,
    321         int w, int h, int format)
    322 {
    323     return window->perform(window, NATIVE_WINDOW_SET_BUFFERS_GEOMETRY,
    324             w, h, format);
    325 }
    326 
    327 /*
    328  * native_window_set_buffers_transform(..., int transform)
    329  * All buffers queued after this call will be displayed transformed according
    330  * to the transform parameter specified.
    331  */
    332 static inline int native_window_set_buffers_transform(
    333         ANativeWindow* window,
    334         int transform)
    335 {
    336     return window->perform(window, NATIVE_WINDOW_SET_BUFFERS_TRANSFORM,
    337             transform);
    338 }
    339 
    340 // ---------------------------------------------------------------------------
    341 
    342 /* FIXME: this is legacy for pixmaps */
    343 typedef struct egl_native_pixmap_t
    344 {
    345     int32_t     version;    /* must be 32 */
    346     int32_t     width;
    347     int32_t     height;
    348     int32_t     stride;
    349     uint8_t*    data;
    350     uint8_t     format;
    351     uint8_t     rfu[3];
    352     union {
    353         uint32_t    compressedFormat;
    354         int32_t     vstride;
    355     };
    356     int32_t     reserved;
    357 } egl_native_pixmap_t;
    358 
    359 /*****************************************************************************/
    360 
    361 #ifdef __cplusplus
    362 }
    363 #endif
    364 
    365 
    366 /*****************************************************************************/
    367 
    368 #ifdef __cplusplus
    369 
    370 #include <utils/RefBase.h>
    371 
    372 namespace android {
    373 
    374 /*
    375  * This helper class turns an EGL android_native_xxx type into a C++
    376  * reference-counted object; with proper type conversions.
    377  */
    378 template <typename NATIVE_TYPE, typename TYPE, typename REF>
    379 class EGLNativeBase : public NATIVE_TYPE, public REF
    380 {
    381 public:
    382     // Disambiguate between the incStrong in REF and NATIVE_TYPE
    383     void incStrong(const void* id) const {
    384         REF::incStrong(id);
    385     }
    386     void decStrong(const void* id) const {
    387         REF::decStrong(id);
    388     }
    389 
    390 protected:
    391     typedef EGLNativeBase<NATIVE_TYPE, TYPE, REF> BASE;
    392     EGLNativeBase() : NATIVE_TYPE(), REF() {
    393         NATIVE_TYPE::common.incRef = incRef;
    394         NATIVE_TYPE::common.decRef = decRef;
    395     }
    396     static inline TYPE* getSelf(NATIVE_TYPE* self) {
    397         return static_cast<TYPE*>(self);
    398     }
    399     static inline TYPE const* getSelf(NATIVE_TYPE const* self) {
    400         return static_cast<TYPE const *>(self);
    401     }
    402     static inline TYPE* getSelf(android_native_base_t* base) {
    403         return getSelf(reinterpret_cast<NATIVE_TYPE*>(base));
    404     }
    405     static inline TYPE const * getSelf(android_native_base_t const* base) {
    406         return getSelf(reinterpret_cast<NATIVE_TYPE const*>(base));
    407     }
    408     static void incRef(android_native_base_t* base) {
    409         EGLNativeBase* self = getSelf(base);
    410         self->incStrong(self);
    411     }
    412     static void decRef(android_native_base_t* base) {
    413         EGLNativeBase* self = getSelf(base);
    414         self->decStrong(self);
    415     }
    416 };
    417 
    418 } // namespace android
    419 #endif // __cplusplus
    420 
    421 /*****************************************************************************/
    422 
    423 #endif /* ANDROID_ANDROID_NATIVES_H */
    424