| #ifndef _SDE_DRM_H_ |
| #define _SDE_DRM_H_ |
| |
| /* |
| * Each top level structure is of the following format: |
| * |
| * struct { |
| * uint64_t version; |
| * union { |
| * struct version v1; |
| * ... |
| * } u; |
| * |
| * Each top level structure maintains independent versioning and is defined |
| * as follows: |
| * |
| * #define STRUCTNAME_V1 0x1 |
| * ... |
| * #define STRUCTNAME_Vn 0x### |
| * #define STRUCTNAME_VERSION STRUCTNAME_Vn |
| * |
| * Version fields should ALWAYS be declared as type uint64_t. This is because |
| * 64-bit compilers tend to pad the structure to 64-bit align the start of |
| * union structure members. Having an explicit 64-bit version helps to maintain |
| * consistent structure layout between 32-bit and 64-bit compilers. |
| * |
| * Updates to the structures UAPI should always define a new sub-structure to |
| * place within the union, and update STRUCTNAME_VERSION to reference the |
| * new version number. |
| * |
| * User mode code should always set the 'version' field to STRUCTNAME_VERSION. |
| */ |
| |
| /* Total number of supported color planes */ |
| #define SDE_MAX_PLANES 4 |
| |
| /** |
| * Blend operations for "blend_op" property |
| * |
| * @SDE_DRM_BLEND_OP_NOT_DEFINED: No blend operation defined for the layer. |
| * @SDE_DRM_BLEND_OP_OPAQUE: Apply a constant blend operation. The layer |
| * would appear opaque in case fg plane alpha |
| * is 0xff. |
| * @SDE_DRM_BLEND_OP_PREMULTIPLIED: Apply source over blend rule. Layer already |
| * has alpha pre-multiplication done. If the fg |
| * plane alpha is less than 0xff, apply |
| * modulation as well. This operation is |
| * intended on layers having alpha channel. |
| * @SDE_DRM_BLEND_OP_COVERAGE: Apply source over blend rule. Layer is not |
| * alpha pre-multiplied. Apply |
| * pre-multiplication. If fg plane alpha is |
| * less than 0xff, apply modulation as well. |
| * @SDE_DRM_BLEND_OP_MAX: Used to track maximum blend operation |
| * possible by mdp. |
| */ |
| #define SDE_DRM_BLEND_OP_NOT_DEFINED 0 |
| #define SDE_DRM_BLEND_OP_OPAQUE 1 |
| #define SDE_DRM_BLEND_OP_PREMULTIPLIED 2 |
| #define SDE_DRM_BLEND_OP_COVERAGE 3 |
| #define SDE_DRM_BLEND_OP_MAX 4 |
| |
| /** |
| * Bit masks for "src_config" property |
| * construct bitmask via (1UL << SDE_DRM_<flag>) |
| */ |
| #define SDE_DRM_DEINTERLACE 0 /* Specifies interlaced input */ |
| |
| /* DRM bitmasks are restricted to 0..63 */ |
| #define SDE_DRM_BITMASK_COUNT 64 |
| |
| /** |
| * struct sde_drm_pix_ext_v1 - version 1 of pixel ext structure |
| * @num_pxls_start: Number of start pixels |
| * @num_pxls_end: Number of end pixels |
| * @ftch_start: Number of overfetch start pixels |
| * @ftch_end: Number of overfetch end pixels |
| * @rpt_start: Number of repeat start pixels |
| * @rpt_end: Number of repeat end pixels |
| * @roi: Input ROI settings |
| */ |
| struct sde_drm_pix_ext_v1 { |
| /* |
| * Number of pixels ext in left, right, top and bottom direction |
| * for all color components. This pixel value for each color |
| * component should be sum of fetch + repeat pixels. |
| */ |
| int32_t num_pxls_start[SDE_MAX_PLANES]; |
| int32_t num_pxls_end[SDE_MAX_PLANES]; |
| |
| /* |
| * Number of pixels needs to be overfetched in left, right, top |
| * and bottom directions from source image for scaling. |
| */ |
| int32_t ftch_start[SDE_MAX_PLANES]; |
| int32_t ftch_end[SDE_MAX_PLANES]; |
| |
| /* |
| * Number of pixels needs to be repeated in left, right, top and |
| * bottom directions for scaling. |
| */ |
| int32_t rpt_start[SDE_MAX_PLANES]; |
| int32_t rpt_end[SDE_MAX_PLANES]; |
| |
| uint32_t roi[SDE_MAX_PLANES]; |
| }; |
| |
| /** |
| * Enable mask bits for "scaler" property |
| * |
| * @SDE_DRM_SCALER_PIX_EXT: pix ext sub-structures are valid |
| * @SDE_DRM_SCALER_SCALER_2: scaler 2 sub-structures are valid |
| * @SDE_DRM_SCALER_SCALER_3: scaler 3 sub-structures are valid |
| * @SDE_DRM_SCALER_DECIMATE: decimation fields are valid |
| */ |
| #define SDE_DRM_SCALER_PIX_EXT 0x1 |
| #define SDE_DRM_SCALER_SCALER_2 0x2 |
| #define SDE_DRM_SCALER_SCALER_3 0x4 |
| #define SDE_DRM_SCALER_DECIMATE 0x8 |
| |
| /** |
| * struct sde_drm_scaler_v1 - version 1 of struct sde_drm_scaler |
| * @enable: Mask of SDE_DRM_SCALER_ bits |
| * @lr: Pixel extension settings for left/right |
| * @tb: Pixel extension settings for top/botton |
| * @horz_decimate: Horizontal decimation factor |
| * @vert_decimate: Vertical decimation factor |
| * @init_phase_x: Initial scaler phase values for x |
| * @phase_step_x: Phase step values for x |
| * @init_phase_y: Initial scaler phase values for y |
| * @phase_step_y: Phase step values for y |
| * @horz_filter: Horizontal filter array |
| * @vert_filter: Vertical filter array |
| */ |
| struct sde_drm_scaler_v1 { |
| /* |
| * General definitions |
| */ |
| uint32_t enable; |
| |
| /* |
| * Pix ext settings |
| */ |
| struct sde_drm_pix_ext_v1 lr; |
| struct sde_drm_pix_ext_v1 tb; |
| |
| /* |
| * Decimation settings |
| */ |
| uint32_t horz_decimate; |
| uint32_t vert_decimate; |
| |
| /* |
| * Phase settings |
| */ |
| int32_t init_phase_x[SDE_MAX_PLANES]; |
| int32_t phase_step_x[SDE_MAX_PLANES]; |
| int32_t init_phase_y[SDE_MAX_PLANES]; |
| int32_t phase_step_y[SDE_MAX_PLANES]; |
| |
| /* |
| * Filter type to be used for scaling in horizontal and vertical |
| * directions |
| */ |
| uint32_t horz_filter[SDE_MAX_PLANES]; |
| uint32_t vert_filter[SDE_MAX_PLANES]; |
| }; |
| |
| /* Scaler version definition, see top of file for guidelines */ |
| #define SDE_DRM_SCALER_V1 0x1 |
| #define SDE_DRM_SCALER_VERSION SDE_DRM_SCALER_V1 |
| |
| /** |
| * struct sde_drm_scaler - scaler structure |
| * @version: Structure version, set to SDE_DRM_SCALER_VERSION |
| * @v1: Version 1 of scaler structure |
| */ |
| struct sde_drm_scaler { |
| uint64_t version; |
| union { |
| struct sde_drm_scaler_v1 v1; |
| }; |
| }; |
| |
| /* |
| * Define constants for struct sde_drm_csc |
| */ |
| #define SDE_CSC_MATRIX_COEFF_SIZE 9 |
| #define SDE_CSC_CLAMP_SIZE 6 |
| #define SDE_CSC_BIAS_SIZE 3 |
| |
| /* CSC version definition, see top of file for guidelines */ |
| #define SDE_DRM_CSC_V1 0x1 |
| #define SDE_DRM_CSC_VERSION SDE_DRM_CSC_V1 |
| |
| /** |
| * struct sde_drm_csc_v1 - version 1 of struct sde_drm_csc |
| * @ctm_coeff: Matrix coefficients, in S31.32 format |
| * @pre_bias: Pre-bias array values |
| * @post_bias: Post-bias array values |
| * @pre_clamp: Pre-clamp array values |
| * @post_clamp: Post-clamp array values |
| */ |
| struct sde_drm_csc_v1 { |
| int64_t ctm_coeff[SDE_CSC_MATRIX_COEFF_SIZE]; |
| uint32_t pre_bias[SDE_CSC_BIAS_SIZE]; |
| uint32_t post_bias[SDE_CSC_BIAS_SIZE]; |
| uint32_t pre_clamp[SDE_CSC_CLAMP_SIZE]; |
| uint32_t post_clamp[SDE_CSC_CLAMP_SIZE]; |
| }; |
| |
| /** |
| * struct sde_drm_csc - CSC configuration structure |
| * @version: Structure version, set to SDE_DRM_CSC_VERSION |
| * @v1: Version 1 of csc structure |
| */ |
| struct sde_drm_csc { |
| uint64_t version; |
| union { |
| struct sde_drm_csc_v1 v1; |
| }; |
| }; |
| |
| #endif /* _SDE_DRM_H_ */ |