hwcomposer_defs.h revision 3f5b522ac9a472de756c08b16f357acd6dc26e34
1e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian/*
2e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian * Copyright (C) 2010 The Android Open Source Project
3e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian *
4e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian * Licensed under the Apache License, Version 2.0 (the "License");
5e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian * you may not use this file except in compliance with the License.
6e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian * You may obtain a copy of the License at
7e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian *
8e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian *      http://www.apache.org/licenses/LICENSE-2.0
9e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian *
10e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian * Unless required by applicable law or agreed to in writing, software
11e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian * distributed under the License is distributed on an "AS IS" BASIS,
12e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian * See the License for the specific language governing permissions and
14e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian * limitations under the License.
15e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian */
16e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian
17e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian#ifndef ANDROID_INCLUDE_HARDWARE_HWCOMPOSER_DEFS_H
18e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian#define ANDROID_INCLUDE_HARDWARE_HWCOMPOSER_DEFS_H
19e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian
20e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian#include <stdint.h>
21e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian#include <sys/cdefs.h>
22e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian
23e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian#include <hardware/gralloc.h>
24e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian#include <hardware/hardware.h>
25e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian#include <cutils/native_handle.h>
26e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian
27e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian__BEGIN_DECLS
28e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian
29e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian/*****************************************************************************/
30e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian
313f5b522ac9a472de756c08b16f357acd6dc26e34Jesse Hall#define HWC_HEADER_VERSION          1
32e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian
333f5b522ac9a472de756c08b16f357acd6dc26e34Jesse Hall#define HWC_MODULE_API_VERSION_0_1  HARDWARE_MODULE_API_VERSION_2(0, 1, HWC_HEADER_VERSION)
343f5b522ac9a472de756c08b16f357acd6dc26e34Jesse Hall
353f5b522ac9a472de756c08b16f357acd6dc26e34Jesse Hall#define HWC_DEVICE_API_VERSION_0_1  HARDWARE_DEVICE_API_VERSION_2(0, 1, HWC_HEADER_VERSION)
363f5b522ac9a472de756c08b16f357acd6dc26e34Jesse Hall#define HWC_DEVICE_API_VERSION_0_2  HARDWARE_DEVICE_API_VERSION_2(0, 2, HWC_HEADER_VERSION)
373f5b522ac9a472de756c08b16f357acd6dc26e34Jesse Hall#define HWC_DEVICE_API_VERSION_0_3  HARDWARE_DEVICE_API_VERSION_2(0, 3, HWC_HEADER_VERSION)
383f5b522ac9a472de756c08b16f357acd6dc26e34Jesse Hall#define HWC_DEVICE_API_VERSION_1_0  HARDWARE_DEVICE_API_VERSION_2(1, 0, HWC_HEADER_VERSION)
393f5b522ac9a472de756c08b16f357acd6dc26e34Jesse Hall#define HWC_DEVICE_API_VERSION_1_1  HARDWARE_DEVICE_API_VERSION_2(1, 1, HWC_HEADER_VERSION)
403f5b522ac9a472de756c08b16f357acd6dc26e34Jesse Hall#define HWC_DEVICE_API_VERSION_1_2  HARDWARE_DEVICE_API_VERSION_2(1, 2, HWC_HEADER_VERSION)
41e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian
42e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopianenum {
43e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    /* hwc_composer_device_t::set failed in EGL */
44e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    HWC_EGL_ERROR = -1
45e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian};
46e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian
47e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian/*
48e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian * hwc_layer_t::hints values
49e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian * Hints are set by the HAL and read by SurfaceFlinger
50e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian */
51e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopianenum {
52e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    /*
53e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian     * HWC can set the HWC_HINT_TRIPLE_BUFFER hint to indicate to SurfaceFlinger
54e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian     * that it should triple buffer this layer. Typically HWC does this when
55e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian     * the layer will be unavailable for use for an extended period of time,
56e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian     * e.g. if the display will be fetching data directly from the layer and
57e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian     * the layer can not be modified until after the next set().
58e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian     */
59e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    HWC_HINT_TRIPLE_BUFFER  = 0x00000001,
60e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian
61e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    /*
62e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian     * HWC sets HWC_HINT_CLEAR_FB to tell SurfaceFlinger that it should clear the
63e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian     * framebuffer with transparent pixels where this layer would be.
64e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian     * SurfaceFlinger will only honor this flag when the layer has no blending
65e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian     *
66e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian     */
67e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    HWC_HINT_CLEAR_FB       = 0x00000002
68e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian};
69e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian
70e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian/*
71e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian * hwc_layer_t::flags values
72e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian * Flags are set by SurfaceFlinger and read by the HAL
73e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian */
74e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopianenum {
75e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    /*
76e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian     * HWC_SKIP_LAYER is set by SurfaceFlnger to indicate that the HAL
77e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian     * shall not consider this layer for composition as it will be handled
78e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian     * by SurfaceFlinger (just as if compositionType was set to HWC_OVERLAY).
79e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian     */
80e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    HWC_SKIP_LAYER = 0x00000001,
81e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian};
82e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian
83e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian/*
84e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian * hwc_layer_t::compositionType values
85e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian */
86e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopianenum {
87e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    /* this layer is to be drawn into the framebuffer by SurfaceFlinger */
88e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    HWC_FRAMEBUFFER = 0,
89e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian
90e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    /* this layer will be handled in the HWC */
91e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    HWC_OVERLAY = 1,
92e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian
93e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    /* this is the background layer. it's used to set the background color.
94e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian     * there is only a single background layer */
95e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    HWC_BACKGROUND = 2,
96d18c83fc044a5f1d74ebe59bea7763b75c4d00d7Jesse Hall
97d18c83fc044a5f1d74ebe59bea7763b75c4d00d7Jesse Hall    /* this layer holds the result of compositing the HWC_FRAMEBUFFER layers.
98d18c83fc044a5f1d74ebe59bea7763b75c4d00d7Jesse Hall     * Added in HWC_DEVICE_API_VERSION_1_1. */
99d18c83fc044a5f1d74ebe59bea7763b75c4d00d7Jesse Hall    HWC_FRAMEBUFFER_TARGET = 3,
100e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian};
101e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian
102e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian/*
103e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian * hwc_layer_t::blending values
104e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian */
105e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopianenum {
106e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    /* no blending */
107e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    HWC_BLENDING_NONE     = 0x0100,
108e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian
109e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    /* ONE / ONE_MINUS_SRC_ALPHA */
110e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    HWC_BLENDING_PREMULT  = 0x0105,
111e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian
112e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    /* SRC_ALPHA / ONE_MINUS_SRC_ALPHA */
113e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    HWC_BLENDING_COVERAGE = 0x0405
114e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian};
115e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian
116e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian/*
117e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian * hwc_layer_t::transform values
118e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian */
119e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopianenum {
120e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    /* flip source image horizontally */
121e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    HWC_TRANSFORM_FLIP_H = HAL_TRANSFORM_FLIP_H,
122e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    /* flip source image vertically */
123e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    HWC_TRANSFORM_FLIP_V = HAL_TRANSFORM_FLIP_V,
124e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    /* rotate source image 90 degrees clock-wise */
125e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    HWC_TRANSFORM_ROT_90 = HAL_TRANSFORM_ROT_90,
126e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    /* rotate source image 180 degrees */
127e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    HWC_TRANSFORM_ROT_180 = HAL_TRANSFORM_ROT_180,
128e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    /* rotate source image 270 degrees clock-wise */
129e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    HWC_TRANSFORM_ROT_270 = HAL_TRANSFORM_ROT_270,
130e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian};
131e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian
132e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian/* attributes queriable with query() */
133e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopianenum {
134e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    /*
135e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian     * availability: HWC_DEVICE_API_VERSION_0_2
136e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian     * must return 1 if the background layer is supported, 0 otherwise
137e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian     */
138e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    HWC_BACKGROUND_LAYER_SUPPORTED      = 0,
139e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian
140e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    /*
141e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian     * availability: HWC_DEVICE_API_VERSION_0_3
142e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian     * returns the vsync period in nanosecond
143e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian     */
144e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    HWC_VSYNC_PERIOD                    = 1,
14543b51d9fdd7a447c9de7bf30960a1963c93ff5c3Jesse Hall
14643b51d9fdd7a447c9de7bf30960a1963c93ff5c3Jesse Hall    /*
14743b51d9fdd7a447c9de7bf30960a1963c93ff5c3Jesse Hall     * availability: HWC_DEVICE_API_VERSION_1_1
14843b51d9fdd7a447c9de7bf30960a1963c93ff5c3Jesse Hall     * returns a mask of supported display types
14943b51d9fdd7a447c9de7bf30960a1963c93ff5c3Jesse Hall     */
15043b51d9fdd7a447c9de7bf30960a1963c93ff5c3Jesse Hall    HWC_DISPLAY_TYPES_SUPPORTED         = 2,
151e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian};
152e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian
153e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian/* Allowed events for hwc_methods::eventControl() */
154e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopianenum {
155e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian    HWC_EVENT_VSYNC     = 0
156e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian};
157e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian
15843b51d9fdd7a447c9de7bf30960a1963c93ff5c3Jesse Hall/* Display types and associated mask bits. */
15943b51d9fdd7a447c9de7bf30960a1963c93ff5c3Jesse Hallenum {
16043b51d9fdd7a447c9de7bf30960a1963c93ff5c3Jesse Hall    HWC_DISPLAY_PRIMARY     = 0,
16143b51d9fdd7a447c9de7bf30960a1963c93ff5c3Jesse Hall    HWC_DISPLAY_EXTERNAL    = 1,    // HDMI, DP, etc.
16243b51d9fdd7a447c9de7bf30960a1963c93ff5c3Jesse Hall    HWC_NUM_DISPLAY_TYPES
16343b51d9fdd7a447c9de7bf30960a1963c93ff5c3Jesse Hall};
16443b51d9fdd7a447c9de7bf30960a1963c93ff5c3Jesse Hall
16543b51d9fdd7a447c9de7bf30960a1963c93ff5c3Jesse Hallenum {
16643b51d9fdd7a447c9de7bf30960a1963c93ff5c3Jesse Hall    HWC_DISPLAY_PRIMARY_BIT     = 1 << HWC_DISPLAY_PRIMARY,
16743b51d9fdd7a447c9de7bf30960a1963c93ff5c3Jesse Hall    HWC_DISPLAY_EXTERNAL_BIT    = 1 << HWC_DISPLAY_EXTERNAL,
16843b51d9fdd7a447c9de7bf30960a1963c93ff5c3Jesse Hall};
16943b51d9fdd7a447c9de7bf30960a1963c93ff5c3Jesse Hall
170e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian/*****************************************************************************/
171e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian
172e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian__END_DECLS
173e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian
174e291f71e0a25ac9bb39fb754c599b710ab8f59d5Mathias Agopian#endif /* ANDROID_INCLUDE_HARDWARE_HWCOMPOSER_DEFS_H */
175