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