chaviw | 1d04428 | 2017-09-27 12:19:28 -0700 | [diff] [blame] | 1 | // Definitions for SurfaceFlinger layers. |
| 2 | |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 3 | syntax = "proto3"; |
chaviw | 1d04428 | 2017-09-27 12:19:28 -0700 | [diff] [blame] | 4 | option optimize_for = LITE_RUNTIME; |
| 5 | package android.surfaceflinger; |
| 6 | |
| 7 | // Contains a list of all layers. |
| 8 | message LayersProto { |
| 9 | repeated LayerProto layers = 1; |
| 10 | } |
| 11 | |
Alec Mouri | 6b9e991 | 2020-01-21 10:50:24 -0800 | [diff] [blame] | 12 | // Must match definition in the IComposerClient HAL |
| 13 | enum HwcCompositionType { |
| 14 | // Invalid composition type |
| 15 | INVALID = 0; |
| 16 | // Layer was composited by the client into the client target buffer |
| 17 | CLIENT = 1; |
| 18 | // Layer was composited by the device through hardware overlays |
| 19 | DEVICE = 2; |
| 20 | // Layer was composited by the device using a color |
| 21 | SOLID_COLOR = 3; |
| 22 | // Similar to DEVICE, but the layer position may have been asynchronously set |
| 23 | // through setCursorPosition |
| 24 | CURSOR = 4; |
| 25 | // Layer was composited by the device via a sideband stream. |
| 26 | SIDEBAND = 5; |
| 27 | } |
| 28 | |
chaviw | 1d04428 | 2017-09-27 12:19:28 -0700 | [diff] [blame] | 29 | // Information about each layer. |
| 30 | message LayerProto { |
| 31 | // unique id per layer. |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 32 | int32 id = 1; |
chaviw | 1d04428 | 2017-09-27 12:19:28 -0700 | [diff] [blame] | 33 | // unique name per layer. |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 34 | string name = 2; |
chaviw | 1d04428 | 2017-09-27 12:19:28 -0700 | [diff] [blame] | 35 | // list of children this layer may have. May be empty. |
| 36 | repeated int32 children = 3; |
| 37 | // list of layers that are z order relative to this layer. |
| 38 | repeated int32 relatives = 4; |
| 39 | // The type of layer, ex Color, Layer |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 40 | string type = 5; |
| 41 | RegionProto transparent_region = 6; |
| 42 | RegionProto visible_region = 7; |
| 43 | RegionProto damage_region = 8; |
| 44 | uint32 layer_stack = 9; |
chaviw | 1d04428 | 2017-09-27 12:19:28 -0700 | [diff] [blame] | 45 | // The layer's z order. Can be z order in layer stack, relative to parent, |
| 46 | // or relative to another layer specified in zOrderRelative. |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 47 | int32 z = 10; |
chaviw | 1d04428 | 2017-09-27 12:19:28 -0700 | [diff] [blame] | 48 | // The layer's position on the display. |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 49 | PositionProto position = 11; |
chaviw | 1d04428 | 2017-09-27 12:19:28 -0700 | [diff] [blame] | 50 | // The layer's requested position. |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 51 | PositionProto requested_position = 12; |
chaviw | 1d04428 | 2017-09-27 12:19:28 -0700 | [diff] [blame] | 52 | // The layer's size. |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 53 | SizeProto size = 13; |
chaviw | 1d04428 | 2017-09-27 12:19:28 -0700 | [diff] [blame] | 54 | // The layer's crop in it's own bounds. |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 55 | RectProto crop = 14; |
chaviw | 1d04428 | 2017-09-27 12:19:28 -0700 | [diff] [blame] | 56 | // The layer's crop in it's parent's bounds. |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 57 | RectProto final_crop = 15 [deprecated=true]; |
| 58 | bool is_opaque = 16; |
| 59 | bool invalidate = 17; |
| 60 | string dataspace = 18; |
| 61 | string pixel_format = 19; |
chaviw | 1d04428 | 2017-09-27 12:19:28 -0700 | [diff] [blame] | 62 | // The layer's actual color. |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 63 | ColorProto color = 20; |
chaviw | 1d04428 | 2017-09-27 12:19:28 -0700 | [diff] [blame] | 64 | // The layer's requested color. |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 65 | ColorProto requested_color = 21; |
chaviw | 1d04428 | 2017-09-27 12:19:28 -0700 | [diff] [blame] | 66 | // Can be any combination of |
| 67 | // hidden = 0x01 |
| 68 | // opaque = 0x02, |
| 69 | // secure = 0x80, |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 70 | uint32 flags = 22; |
chaviw | 1d04428 | 2017-09-27 12:19:28 -0700 | [diff] [blame] | 71 | // The layer's actual transform |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 72 | TransformProto transform = 23; |
chaviw | 1d04428 | 2017-09-27 12:19:28 -0700 | [diff] [blame] | 73 | // The layer's requested transform. |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 74 | TransformProto requested_transform = 24; |
chaviw | 1d04428 | 2017-09-27 12:19:28 -0700 | [diff] [blame] | 75 | // The parent layer. This value can be null if there is no parent. |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 76 | int32 parent = 25; |
chaviw | 1d04428 | 2017-09-27 12:19:28 -0700 | [diff] [blame] | 77 | // The layer that this layer has a z order relative to. This value can be null. |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 78 | int32 z_order_relative_of = 26; |
chaviw | 1d04428 | 2017-09-27 12:19:28 -0700 | [diff] [blame] | 79 | // This value can be null if there's nothing to draw. |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 80 | ActiveBufferProto active_buffer = 27; |
chaviw | 1d04428 | 2017-09-27 12:19:28 -0700 | [diff] [blame] | 81 | // The number of frames available. |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 82 | int32 queued_frames = 28; |
| 83 | bool refresh_pending = 29; |
Yiwei Zhang | 7124ad3 | 2018-02-21 13:02:45 -0800 | [diff] [blame] | 84 | // The layer's composer backend destination frame |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 85 | RectProto hwc_frame = 30; |
Yiwei Zhang | 7124ad3 | 2018-02-21 13:02:45 -0800 | [diff] [blame] | 86 | // The layer's composer backend source crop |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 87 | FloatRectProto hwc_crop = 31; |
Yiwei Zhang | 7124ad3 | 2018-02-21 13:02:45 -0800 | [diff] [blame] | 88 | // The layer's composer backend transform |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 89 | int32 hwc_transform = 32; |
| 90 | int32 window_type = 33 [deprecated=true]; |
| 91 | int32 app_id = 34 [deprecated=true]; |
Yiwei Zhang | 60d1a19 | 2018-03-07 14:52:28 -0800 | [diff] [blame] | 92 | // The layer's composition type |
Alec Mouri | 6b9e991 | 2020-01-21 10:50:24 -0800 | [diff] [blame] | 93 | HwcCompositionType hwc_composition_type = 35; |
Yiwei Zhang | 60d1a19 | 2018-03-07 14:52:28 -0800 | [diff] [blame] | 94 | // If it's a buffer layer, indicate if the content is protected |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 95 | bool is_protected = 36; |
chaviw | adc40c2 | 2018-07-10 16:57:27 -0700 | [diff] [blame] | 96 | // Current frame number being rendered. |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 97 | uint64 curr_frame = 37; |
chaviw | adc40c2 | 2018-07-10 16:57:27 -0700 | [diff] [blame] | 98 | // A list of barriers that the layer is waiting to update state. |
Vishnu Nair | 9978b93 | 2018-08-22 09:11:49 -0700 | [diff] [blame] | 99 | repeated BarrierLayerProto barrier_layer = 38; |
| 100 | // If active_buffer is not null, record its transform. |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 101 | TransformProto buffer_transform = 39; |
| 102 | int32 effective_scaling_mode = 40; |
Lucas Dupin | 1b6531c | 2018-07-05 17:18:21 -0700 | [diff] [blame] | 103 | // Layer's corner radius. |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 104 | float corner_radius = 41; |
Evan Rosky | 1f6d6d5 | 2018-12-06 10:47:26 -0800 | [diff] [blame] | 105 | // Metadata map. May be empty. |
| 106 | map<int32, bytes> metadata = 42; |
Vishnu Nair | 4351ad5 | 2019-02-11 14:13:02 -0800 | [diff] [blame] | 107 | |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 108 | TransformProto effective_transform = 43; |
| 109 | FloatRectProto source_bounds = 44; |
| 110 | FloatRectProto bounds = 45; |
| 111 | FloatRectProto screen_bounds = 46; |
Vishnu Nair | 9245d3b | 2019-03-22 13:38:56 -0700 | [diff] [blame] | 112 | |
| 113 | InputWindowInfoProto input_window_info = 47; |
Vishnu Nair | 95a1ed4 | 2019-12-06 12:25:11 -0800 | [diff] [blame] | 114 | |
| 115 | // Crop used to draw the rounded corner. |
| 116 | FloatRectProto corner_radius_crop = 48; |
| 117 | |
| 118 | // length of the shadow to draw around the layer, it may be set on the |
| 119 | // layer or set by a parent layer. |
| 120 | float shadow_radius = 49; |
chaviw | ddeae26 | 2020-01-06 10:31:23 -0800 | [diff] [blame] | 121 | ColorTransformProto color_transform = 50; |
chaviw | 08f3cb2 | 2020-01-13 13:17:21 -0800 | [diff] [blame] | 122 | |
| 123 | bool is_relative_of = 51; |
Lucas Dupin | 19c8f0e | 2019-11-25 17:55:44 -0800 | [diff] [blame] | 124 | // Layer's background blur radius in pixels. |
| 125 | int32 background_blur_radius = 52; |
chaviw | 250bcbb | 2020-08-05 11:17:54 -0700 | [diff] [blame] | 126 | |
| 127 | uint32 owner_uid = 53; |
chaviw | 1d04428 | 2017-09-27 12:19:28 -0700 | [diff] [blame] | 128 | } |
| 129 | |
| 130 | message PositionProto { |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 131 | float x = 1; |
| 132 | float y = 2; |
chaviw | 1d04428 | 2017-09-27 12:19:28 -0700 | [diff] [blame] | 133 | } |
| 134 | |
| 135 | message SizeProto { |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 136 | int32 w = 1; |
| 137 | int32 h = 2; |
chaviw | 1d04428 | 2017-09-27 12:19:28 -0700 | [diff] [blame] | 138 | } |
| 139 | |
| 140 | message TransformProto { |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 141 | float dsdx = 1; |
| 142 | float dtdx = 2; |
| 143 | float dsdy = 3; |
| 144 | float dtdy = 4; |
Nataniel Borges | 797b0e4 | 2019-02-15 14:11:58 -0800 | [diff] [blame] | 145 | int32 type = 5; |
chaviw | 1d04428 | 2017-09-27 12:19:28 -0700 | [diff] [blame] | 146 | } |
| 147 | |
| 148 | message RegionProto { |
Nataniel Borges | 1c0d91c | 2019-02-15 15:29:39 -0800 | [diff] [blame] | 149 | reserved 1; // Previously: uint64 id |
chaviw | 1d04428 | 2017-09-27 12:19:28 -0700 | [diff] [blame] | 150 | repeated RectProto rect = 2; |
| 151 | } |
| 152 | |
| 153 | message RectProto { |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 154 | int32 left = 1; |
| 155 | int32 top = 2; |
| 156 | int32 right = 3; |
| 157 | int32 bottom = 4; |
chaviw | 1d04428 | 2017-09-27 12:19:28 -0700 | [diff] [blame] | 158 | } |
| 159 | |
Yiwei Zhang | 7124ad3 | 2018-02-21 13:02:45 -0800 | [diff] [blame] | 160 | message FloatRectProto { |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 161 | float left = 1; |
| 162 | float top = 2; |
| 163 | float right = 3; |
| 164 | float bottom = 4; |
Yiwei Zhang | 7124ad3 | 2018-02-21 13:02:45 -0800 | [diff] [blame] | 165 | } |
| 166 | |
chaviw | 1d04428 | 2017-09-27 12:19:28 -0700 | [diff] [blame] | 167 | message ActiveBufferProto { |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 168 | uint32 width = 1; |
| 169 | uint32 height = 2; |
| 170 | uint32 stride = 3; |
| 171 | int32 format = 4; |
chaviw | 1d04428 | 2017-09-27 12:19:28 -0700 | [diff] [blame] | 172 | } |
| 173 | |
| 174 | message ColorProto { |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 175 | float r = 1; |
| 176 | float g = 2; |
| 177 | float b = 3; |
| 178 | float a = 4; |
Yiwei Zhang | 7124ad3 | 2018-02-21 13:02:45 -0800 | [diff] [blame] | 179 | } |
chaviw | adc40c2 | 2018-07-10 16:57:27 -0700 | [diff] [blame] | 180 | |
| 181 | message BarrierLayerProto { |
| 182 | // layer id the barrier is waiting on. |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 183 | int32 id = 1; |
chaviw | adc40c2 | 2018-07-10 16:57:27 -0700 | [diff] [blame] | 184 | // frame number the barrier is waiting on. |
Nataniel Borges | dcc0bab | 2019-02-15 13:22:03 -0800 | [diff] [blame] | 185 | uint64 frame_number = 2; |
chaviw | adc40c2 | 2018-07-10 16:57:27 -0700 | [diff] [blame] | 186 | } |
Vishnu Nair | 9245d3b | 2019-03-22 13:38:56 -0700 | [diff] [blame] | 187 | |
| 188 | message InputWindowInfoProto { |
| 189 | uint32 layout_params_flags = 1; |
| 190 | uint32 layout_params_type = 2; |
| 191 | RectProto frame = 3; |
| 192 | RegionProto touchable_region = 4; |
| 193 | |
| 194 | uint32 surface_inset = 5; |
| 195 | bool visible = 6; |
Vishnu Nair | 47074b8 | 2020-08-14 11:54:47 -0700 | [diff] [blame] | 196 | bool can_receive_keys = 7 [deprecated=true]; |
| 197 | bool focusable = 8; |
Vishnu Nair | 9245d3b | 2019-03-22 13:38:56 -0700 | [diff] [blame] | 198 | bool has_wallpaper = 9; |
| 199 | |
| 200 | float global_scale_factor = 10; |
chaviw | 1ff3d1e | 2020-07-01 15:53:47 -0700 | [diff] [blame] | 201 | float window_x_scale = 11 [deprecated=true]; |
| 202 | float window_y_scale = 12 [deprecated=true]; |
Vishnu Nair | 9245d3b | 2019-03-22 13:38:56 -0700 | [diff] [blame] | 203 | |
| 204 | uint32 crop_layer_id = 13; |
| 205 | bool replace_touchable_region_with_crop = 14; |
| 206 | RectProto touchable_region_crop = 15; |
chaviw | 1ff3d1e | 2020-07-01 15:53:47 -0700 | [diff] [blame] | 207 | TransformProto transform = 16; |
Vishnu Nair | 9245d3b | 2019-03-22 13:38:56 -0700 | [diff] [blame] | 208 | } |
chaviw | ddeae26 | 2020-01-06 10:31:23 -0800 | [diff] [blame] | 209 | |
| 210 | message ColorTransformProto { |
| 211 | // This will be a 4x4 matrix of float values |
| 212 | repeated float val = 1; |
Alec Mouri | 6b9e991 | 2020-01-21 10:50:24 -0800 | [diff] [blame] | 213 | } |