15d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin/**************************************************************************** 25d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin **************************************************************************** 35d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin *** 45d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin *** This header was automatically generated from a Linux kernel header 55d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin *** of the same name, to make information necessary for userspace to 65d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin *** call into the kernel available to libc. It contains only constants, 75d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin *** structures, and macros generated from the original header, and thus, 85d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin *** contains no copyrightable information. 95d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin *** 105d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin *** To edit the content of this header, modify the corresponding 115d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin *** source file (e.g. under external/kernel-headers/original/) then 125d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin *** run bionic/libc/kernel/tools/update_all.py 135d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin *** 145d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin *** Any manual change here will be lost the next time this script will 155d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin *** be run. You've been warned! 165d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin *** 175d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin **************************************************************************** 185d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin ****************************************************************************/ 195d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin#ifndef _MSM_MDP_EXT_H_ 205d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin#define _MSM_MDP_EXT_H_ 215d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin#include <linux/msm_mdp.h> 225d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin#define MDP_IOCTL_MAGIC 'S' 235d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 245d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin#define MSMFB_ATOMIC_COMMIT _IOWR(MDP_IOCTL_MAGIC, 128, void *) 255d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin#define MSMFB_ASYNC_POSITION_UPDATE _IOWR(MDP_IOCTL_MAGIC, 129, struct mdp_position_update) 261688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch#define MSMFB_MDP_SET_CFG _IOW(MDP_IOCTL_MAGIC, 130, struct mdp_set_cfg) 271688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch#ifdef __LP64 281688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 291688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch#define MDP_LAYER_COMMIT_V1_PAD 3 301688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch#else 311688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch#define MDP_LAYER_COMMIT_V1_PAD 4 321688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch#endif 331688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 345d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin#define MDP_LAYER_FLIP_LR 0x1 355d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin#define MDP_LAYER_FLIP_UD 0x2 365d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin#define MDP_LAYER_ENABLE_PIXEL_EXT 0x4 375d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin#define MDP_LAYER_FORGROUND 0x8 381688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 395d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin#define MDP_LAYER_SECURE_SESSION 0x10 405d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin#define MDP_LAYER_SOLID_FILL 0x20 415d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin#define MDP_LAYER_DEINTERLACE 0x40 425d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin#define MDP_LAYER_BWC 0x80 431688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 445d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin#define MDP_LAYER_ASYNC 0x100 455d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin#define MDP_LAYER_PP 0x200 465d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin#define MDP_LAYER_SECURE_DISPLAY_SESSION 0x400 471688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch#define MDP_LAYER_ENABLE_QSEED3_SCALE 0x800 481688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 491688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch#define MDP_DESTSCALER_ENABLE 0x1 501688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch#define MDP_DESTSCALER_SCALE_UPDATE 0x2 511688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch#define MDP_DESTSCALER_ENHANCER_UPDATE 0x4 521688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch#define MDP_LAYER_MULTIRECT_ENABLE 0x1000 531688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 541688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch#define MDP_LAYER_MULTIRECT_PARALLEL_MODE 0x2000 555d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin#define MDP_VALIDATE_LAYER 0x01 565d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin#define MDP_COMMIT_WAIT_FOR_FINISH 0x02 575d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin#define MDP_COMMIT_SYNC_FENCE_WAIT 0x04 585d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 595d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin#define MDP_COMMIT_VERSION_1_0 0x00010000 6070bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch#define OUT_LAYER_COLOR_SPACE 615d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjinstruct mdp_layer_plane { 625d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin int fd; 635d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 6470bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch uint32_t offset; 655d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin uint32_t stride; 665d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin}; 675d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjinstruct mdp_layer_buffer { 685d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 6970bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch uint32_t width; 705d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin uint32_t height; 715d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin uint32_t format; 725d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin struct mdp_layer_plane planes[MAX_PLANES]; 735d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 7470bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch uint32_t plane_count; 755d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin struct mult_factor comp_ratio; 765d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin int fence; 775d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin uint32_t reserved; 785d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 7970bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch}; 805d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjinstruct mdp_input_layer { 815d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin uint32_t flags; 825d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin uint32_t pipe_ndx; 835d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 8470bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch uint8_t horz_deci; 855d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin uint8_t vert_deci; 865d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin uint8_t alpha; 875d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin uint16_t z_order; 885d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 8970bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch uint32_t transp_mask; 905d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin uint32_t bg_color; 915d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin enum mdss_mdp_blend_op blend_op; 925d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin enum mdp_color_space color_space; 935d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 9470bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch struct mdp_rect src_rect; 955d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin struct mdp_rect dst_rect; 961688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch void __user * scale; 975d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin struct mdp_layer_buffer buffer; 985d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 9970bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch void __user * pp_info; 1005d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin int error_code; 1015d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin uint32_t reserved[6]; 1025d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin}; 1035d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 10470bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetschstruct mdp_output_layer { 1055d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin uint32_t flags; 1065d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin uint32_t writeback_ndx; 1075d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin struct mdp_layer_buffer buffer; 1085d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 10970bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch enum mdp_color_space color_space; 11070bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch uint32_t reserved[5]; 1115d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin}; 1121688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetschstruct mdp_destination_scaler_data { 11370bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 1141688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t flags; 1151688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t dest_scaler_ndx; 1161688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t lm_width; 1171688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t lm_height; 11870bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 1191688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint64_t __user scale; 1201688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch}; 1215d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjinstruct mdp_layer_commit_v1 { 1225d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin uint32_t flags; 12370bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 1245d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin int release_fence; 1255d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin struct mdp_rect left_roi; 1265d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin struct mdp_rect right_roi; 127d9ec20e66310e5fa84a1de1c3303748f6b690542Patrick Tjin struct mdp_input_layer __user * input_layers; 12870bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 1295d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin uint32_t input_layer_cnt; 130d9ec20e66310e5fa84a1de1c3303748f6b690542Patrick Tjin struct mdp_output_layer __user * output_layer; 1315d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin int retire_fence; 1321688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch void __user * dest_scaler; 13370bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 1341688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t dest_scaler_cnt; 1351688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t reserved[MDP_LAYER_COMMIT_V1_PAD]; 1361688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch}; 1375d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjinstruct mdp_layer_commit { 13870bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 1395d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin uint32_t version; 1405d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin union { 1411688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch struct mdp_layer_commit_v1 commit_v1; 1425d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin }; 14370bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 1445d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin}; 1455d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjinstruct mdp_point { 1461688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t x; 1475d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin uint32_t y; 14870bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 1495d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin}; 1505d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjinstruct mdp_async_layer { 1511688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t flags; 1525d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin uint32_t pipe_ndx; 15370bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 1545d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin struct mdp_point src; 1555d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin struct mdp_point dst; 1561688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch int error_code; 1575d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin uint32_t reserved[3]; 15870bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 1595d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin}; 1605d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjinstruct mdp_position_update { 1611688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch struct mdp_async_layer __user * input_layers; 1625d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin uint32_t input_layer_cnt; 16370bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 1645d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin}; 1651688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch#define MAX_DET_CURVES 3 1661688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetschstruct mdp_det_enhance_data { 1671688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t enable; 16870bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 1691688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch int16_t sharpen_level1; 1701688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch int16_t sharpen_level2; 1711688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint16_t clip; 1721688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint16_t limit; 17370bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 1741688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint16_t thr_quiet; 1751688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint16_t thr_dieout; 1761688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint16_t thr_low; 1771688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint16_t thr_high; 17870bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 1791688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint16_t prec_shift; 1801688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch int16_t adjust_a[MAX_DET_CURVES]; 1811688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch int16_t adjust_b[MAX_DET_CURVES]; 1821688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch int16_t adjust_c[MAX_DET_CURVES]; 18370bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 1841688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch}; 1851688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch#define ENABLE_SCALE 0x1 1861688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch#define ENABLE_DETAIL_ENHANCE 0x2 1871688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch#define ENABLE_DIRECTION_DETECTION 0x4 18870bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 1891688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch#define SCALER_LUT_SWAP 0x1 1901688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch#define SCALER_LUT_DIR_WR 0x2 1911688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch#define SCALER_LUT_Y_CIR_WR 0x4 1921688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch#define SCALER_LUT_UV_CIR_WR 0x8 19370bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 1941688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch#define SCALER_LUT_Y_SEP_WR 0x10 1951688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch#define SCALER_LUT_UV_SEP_WR 0x20 1961688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch#define FILTER_EDGE_DIRECTED_2D 0x0 1971688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch#define FILTER_CIRCULAR_2D 0x1 19870bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 1991688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch#define FILTER_SEPARABLE_1D 0x2 2001688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch#define FILTER_BILINEAR 0x3 2011688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch#define FILTER_ALPHA_DROP_REPEAT 0x0 2021688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch#define FILTER_ALPHA_BILINEAR 0x1 20370bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 2041688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetschstruct mdp_scale_data_v2 { 2051688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t enable; 2061688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch int32_t init_phase_x[MAX_PLANES]; 2071688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch int32_t phase_step_x[MAX_PLANES]; 20870bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 2091688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch int32_t init_phase_y[MAX_PLANES]; 2101688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch int32_t phase_step_y[MAX_PLANES]; 2111688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t num_ext_pxls_left[MAX_PLANES]; 2121688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t num_ext_pxls_right[MAX_PLANES]; 21370bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 2141688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t num_ext_pxls_top[MAX_PLANES]; 2151688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t num_ext_pxls_btm[MAX_PLANES]; 2161688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch int32_t left_ftch[MAX_PLANES]; 2171688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch int32_t left_rpt[MAX_PLANES]; 21870bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 2191688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch int32_t right_ftch[MAX_PLANES]; 2201688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch int32_t right_rpt[MAX_PLANES]; 2211688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t top_rpt[MAX_PLANES]; 2221688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t btm_rpt[MAX_PLANES]; 22370bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 2241688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t top_ftch[MAX_PLANES]; 2251688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t btm_ftch[MAX_PLANES]; 2261688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t roi_w[MAX_PLANES]; 2271688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t preload_x[MAX_PLANES]; 22870bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 2291688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t preload_y[MAX_PLANES]; 2301688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t src_width[MAX_PLANES]; 2311688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t src_height[MAX_PLANES]; 2321688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t dst_width; 23370bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 2341688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t dst_height; 2351688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t y_rgb_filter_cfg; 2361688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t uv_filter_cfg; 2371688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t alpha_filter_cfg; 23870bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 2391688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t blend_cfg; 2401688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t lut_flag; 2411688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t dir_lut_idx; 2421688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t y_rgb_cir_lut_idx; 24370bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 2441688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t uv_cir_lut_idx; 2451688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t y_rgb_sep_lut_idx; 2461688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t uv_sep_lut_idx; 2471688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch struct mdp_det_enhance_data detail_enhance; 24870bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 2491688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint64_t reserved[8]; 2501688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch}; 2511688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetschstruct mdp_scale_luts_info { 2521688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint64_t __user dir_lut; 25370bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 2541688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint64_t __user cir_lut; 2551688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint64_t __user sep_lut; 2561688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t dir_lut_size; 2571688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t cir_lut_size; 25870bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 2591688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t sep_lut_size; 2601688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch}; 2611688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch#define MDP_QSEED3_LUT_CFG 0x1 2621688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetschstruct mdp_set_cfg { 26370bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 2641688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint64_t flags; 2651688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint32_t len; 2661688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch uint64_t __user payload; 2671688fb6e5ddfd11823f34bc2cf9674e8ff134ebaSteve Pfetsch}; 26870bade28d96ab8dd0b37b87b2d42db10d6ed5562Steve Pfetsch/* WARNING: DO NOT EDIT, AUTO-GENERATED CODE - SEE TOP FOR INSTRUCTIONS */ 2695d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin#endif 2705d6a7fb6f1a9ff1d898b290fc7c0b2695cf22229Patrick Tjin 271