1 /**************************************************************************** 2 **************************************************************************** 3 *** 4 *** This header was automatically generated from a Linux kernel header 5 *** of the same name, to make information necessary for userspace to 6 *** call into the kernel available to libc. It contains only constants, 7 *** structures, and macros generated from the original header, and thus, 8 *** contains no copyrightable information. 9 *** 10 *** To edit the content of this header, modify the corresponding 11 *** source file (e.g. under external/kernel-headers/original/) then 12 *** run bionic/libc/kernel/tools/update_all.py 13 *** 14 *** Any manual change here will be lost the next time this script will 15 *** be run. You've been warned! 16 *** 17 **************************************************************************** 18 ****************************************************************************/ 19 #ifndef _MSM_MDP_EXT_H_ 20 #define _MSM_MDP_EXT_H_ 21 #include <linux/msm_mdp.h> 22 #define MDP_IOCTL_MAGIC 'S' 23 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 24 #define MSMFB_ATOMIC_COMMIT _IOWR(MDP_IOCTL_MAGIC, 128, void *) 25 #define MSMFB_ASYNC_POSITION_UPDATE _IOWR(MDP_IOCTL_MAGIC, 129, struct mdp_position_update) 26 #define MSMFB_MDP_SET_CFG _IOW(MDP_IOCTL_MAGIC, 130, struct mdp_set_cfg) 27 #ifdef __LP64 28 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 29 #define MDP_LAYER_COMMIT_V1_PAD 3 30 #else 31 #define MDP_LAYER_COMMIT_V1_PAD 4 32 #endif 33 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 34 #define MDP_LAYER_FLIP_LR 0x1 35 #define MDP_LAYER_FLIP_UD 0x2 36 #define MDP_LAYER_ENABLE_PIXEL_EXT 0x4 37 #define MDP_LAYER_FORGROUND 0x8 38 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 39 #define MDP_LAYER_SECURE_SESSION 0x10 40 #define MDP_LAYER_SOLID_FILL 0x20 41 #define MDP_LAYER_DEINTERLACE 0x40 42 #define MDP_LAYER_BWC 0x80 43 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 44 #define MDP_LAYER_ASYNC 0x100 45 #define MDP_LAYER_PP 0x200 46 #define MDP_LAYER_SECURE_DISPLAY_SESSION 0x400 47 #define MDP_LAYER_ENABLE_QSEED3_SCALE 0x800 48 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 49 #define MDP_DESTSCALER_ENABLE 0x1 50 #define MDP_DESTSCALER_SCALE_UPDATE 0x2 51 #define MDP_DESTSCALER_ENHANCER_UPDATE 0x4 52 #define MDP_LAYER_MULTIRECT_ENABLE 0x1000 53 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 54 #define MDP_LAYER_MULTIRECT_PARALLEL_MODE 0x2000 55 #define MDP_VALIDATE_LAYER 0x01 56 #define MDP_COMMIT_WAIT_FOR_FINISH 0x02 57 #define MDP_COMMIT_SYNC_FENCE_WAIT 0x04 58 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 59 #define MDP_COMMIT_VERSION_1_0 0x00010000 60 #define OUT_LAYER_COLOR_SPACE 61 struct mdp_layer_plane { 62 int fd; 63 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 64 uint32_t offset; 65 uint32_t stride; 66 }; 67 struct mdp_layer_buffer { 68 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 69 uint32_t width; 70 uint32_t height; 71 uint32_t format; 72 struct mdp_layer_plane planes[MAX_PLANES]; 73 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 74 uint32_t plane_count; 75 struct mult_factor comp_ratio; 76 int fence; 77 uint32_t reserved; 78 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 79 }; 80 struct mdp_input_layer { 81 uint32_t flags; 82 uint32_t pipe_ndx; 83 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 84 uint8_t horz_deci; 85 uint8_t vert_deci; 86 uint8_t alpha; 87 uint16_t z_order; 88 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 89 uint32_t transp_mask; 90 uint32_t bg_color; 91 enum mdss_mdp_blend_op blend_op; 92 enum mdp_color_space color_space; 93 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 94 struct mdp_rect src_rect; 95 struct mdp_rect dst_rect; 96 void __user * scale; 97 struct mdp_layer_buffer buffer; 98 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 99 void __user * pp_info; 100 int error_code; 101 uint32_t reserved[6]; 102 }; 103 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 104 struct mdp_output_layer { 105 uint32_t flags; 106 uint32_t writeback_ndx; 107 struct mdp_layer_buffer buffer; 108 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 109 enum mdp_color_space color_space; 110 uint32_t reserved[5]; 111 }; 112 struct mdp_destination_scaler_data { 113 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 114 uint32_t flags; 115 uint32_t dest_scaler_ndx; 116 uint32_t lm_width; 117 uint32_t lm_height; 118 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 119 uint64_t __user scale; 120 }; 121 struct mdp_layer_commit_v1 { 122 uint32_t flags; 123 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 124 int release_fence; 125 struct mdp_rect left_roi; 126 struct mdp_rect right_roi; 127 struct mdp_input_layer __user * input_layers; 128 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 129 uint32_t input_layer_cnt; 130 struct mdp_output_layer __user * output_layer; 131 int retire_fence; 132 void __user * dest_scaler; 133 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 134 uint32_t dest_scaler_cnt; 135 uint32_t reserved[MDP_LAYER_COMMIT_V1_PAD]; 136 }; 137 struct mdp_layer_commit { 138 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 139 uint32_t version; 140 union { 141 struct mdp_layer_commit_v1 commit_v1; 142 }; 143 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 144 }; 145 struct mdp_point { 146 uint32_t x; 147 uint32_t y; 148 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 149 }; 150 struct mdp_async_layer { 151 uint32_t flags; 152 uint32_t pipe_ndx; 153 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 154 struct mdp_point src; 155 struct mdp_point dst; 156 int error_code; 157 uint32_t reserved[3]; 158 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 159 }; 160 struct mdp_position_update { 161 struct mdp_async_layer __user * input_layers; 162 uint32_t input_layer_cnt; 163 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 164 }; 165 #define MAX_DET_CURVES 3 166 struct mdp_det_enhance_data { 167 uint32_t enable; 168 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 169 int16_t sharpen_level1; 170 int16_t sharpen_level2; 171 uint16_t clip; 172 uint16_t limit; 173 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 174 uint16_t thr_quiet; 175 uint16_t thr_dieout; 176 uint16_t thr_low; 177 uint16_t thr_high; 178 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 179 uint16_t prec_shift; 180 int16_t adjust_a[MAX_DET_CURVES]; 181 int16_t adjust_b[MAX_DET_CURVES]; 182 int16_t adjust_c[MAX_DET_CURVES]; 183 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 184 }; 185 #define ENABLE_SCALE 0x1 186 #define ENABLE_DETAIL_ENHANCE 0x2 187 #define ENABLE_DIRECTION_DETECTION 0x4 188 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 189 #define SCALER_LUT_SWAP 0x1 190 #define SCALER_LUT_DIR_WR 0x2 191 #define SCALER_LUT_Y_CIR_WR 0x4 192 #define SCALER_LUT_UV_CIR_WR 0x8 193 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 194 #define SCALER_LUT_Y_SEP_WR 0x10 195 #define SCALER_LUT_UV_SEP_WR 0x20 196 #define FILTER_EDGE_DIRECTED_2D 0x0 197 #define FILTER_CIRCULAR_2D 0x1 198 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 199 #define FILTER_SEPARABLE_1D 0x2 200 #define FILTER_BILINEAR 0x3 201 #define FILTER_ALPHA_DROP_REPEAT 0x0 202 #define FILTER_ALPHA_BILINEAR 0x1 203 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 204 struct mdp_scale_data_v2 { 205 uint32_t enable; 206 int32_t init_phase_x[MAX_PLANES]; 207 int32_t phase_step_x[MAX_PLANES]; 208 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 209 int32_t init_phase_y[MAX_PLANES]; 210 int32_t phase_step_y[MAX_PLANES]; 211 uint32_t num_ext_pxls_left[MAX_PLANES]; 212 uint32_t num_ext_pxls_right[MAX_PLANES]; 213 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 214 uint32_t num_ext_pxls_top[MAX_PLANES]; 215 uint32_t num_ext_pxls_btm[MAX_PLANES]; 216 int32_t left_ftch[MAX_PLANES]; 217 int32_t left_rpt[MAX_PLANES]; 218 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 219 int32_t right_ftch[MAX_PLANES]; 220 int32_t right_rpt[MAX_PLANES]; 221 uint32_t top_rpt[MAX_PLANES]; 222 uint32_t btm_rpt[MAX_PLANES]; 223 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 224 uint32_t top_ftch[MAX_PLANES]; 225 uint32_t btm_ftch[MAX_PLANES]; 226 uint32_t roi_w[MAX_PLANES]; 227 uint32_t preload_x[MAX_PLANES]; 228 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 229 uint32_t preload_y[MAX_PLANES]; 230 uint32_t src_width[MAX_PLANES]; 231 uint32_t src_height[MAX_PLANES]; 232 uint32_t dst_width; 233 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 234 uint32_t dst_height; 235 uint32_t y_rgb_filter_cfg; 236 uint32_t uv_filter_cfg; 237 uint32_t alpha_filter_cfg; 238 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 239 uint32_t blend_cfg; 240 uint32_t lut_flag; 241 uint32_t dir_lut_idx; 242 uint32_t y_rgb_cir_lut_idx; 243 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 244 uint32_t uv_cir_lut_idx; 245 uint32_t y_rgb_sep_lut_idx; 246 uint32_t uv_sep_lut_idx; 247 struct mdp_det_enhance_data detail_enhance; 248 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 249 uint64_t reserved[8]; 250 }; 251 struct mdp_scale_luts_info { 252 uint64_t __user dir_lut; 253 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 254 uint64_t __user cir_lut; 255 uint64_t __user sep_lut; 256 uint32_t dir_lut_size; 257 uint32_t cir_lut_size; 258 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 259 uint32_t sep_lut_size; 260 }; 261 #define MDP_QSEED3_LUT_CFG 0x1 262 struct mdp_set_cfg { 263 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 264 uint64_t flags; 265 uint32_t len; 266 uint64_t __user payload; 267 }; 268 /* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 269 #endif 270 271