diff options
| author | Clarence Ip <cip@codeaurora.org> | 2016-05-30 11:42:25 -0400 |
|---|---|---|
| committer | Dhaval Patel <pdhaval@codeaurora.org> | 2016-08-01 11:58:08 -0700 |
| commit | d0de496415cab8982f6ee585c1f32a8df454de23 (patch) | |
| tree | 367a506635e7a411c47fc0b74f28ad63cf33fb10 /include/uapi | |
| parent | 52f996dcb649c2eb1c0e2284a0571b03bdf89b20 (diff) | |
msm: sde: sde plane properties user definitions
Add structure definitions for planes blob properties for
supporting user configuration of pixel extension, scaler, and
color space conversion features.
Change-Id: I8527a6c25c20d1654124bc3247a6079c14884bb0
Signed-off-by: Clarence Ip <cip@codeaurora.org>
Diffstat (limited to 'include/uapi')
| -rw-r--r-- | include/uapi/drm/Kbuild | 1 | ||||
| -rw-r--r-- | include/uapi/drm/sde_drm.h | 223 |
2 files changed, 224 insertions, 0 deletions
diff --git a/include/uapi/drm/Kbuild b/include/uapi/drm/Kbuild index 38d437096c35..186b4cb37d5c 100644 --- a/include/uapi/drm/Kbuild +++ b/include/uapi/drm/Kbuild @@ -18,3 +18,4 @@ header-y += via_drm.h header-y += vmwgfx_drm.h header-y += msm_drm.h header-y += virtgpu_drm.h +header-y += sde_drm.h diff --git a/include/uapi/drm/sde_drm.h b/include/uapi/drm/sde_drm.h new file mode 100644 index 000000000000..668b4c965f5d --- /dev/null +++ b/include/uapi/drm/sde_drm.h @@ -0,0 +1,223 @@ +#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_ */ |
