blob: c39a4914ec9f0a8c143c05435b5922d42a35f03e [file] [log] [blame]
/*
* Copyright Samsung Electronics Co.,LTD.
* Copyright (C) 2017 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef __UAPI_G2D_H__
#define __UAPI_G2D_H__
#ifdef __cplusplus
extern "C" {
#endif
#define G2D_SWZ_MASK 0xFFFF
#define G2D_SWZ_ARGB 0x3210
#define G2D_SWZ_ABGR 0x3012
#define G2D_SWZ_xBGR 0x5012
#define G2D_SWZ_xRGB 0x5210
#define G2D_SWZ_ALPHA_MASK (0xF << 12)
#define G2D_SWZ_ALPHA_ONE (0x5 << 12)
#define G2D_YUVORDER_MASK (0x3 << 24)
#define G2D_YUV_UV ((1 << 24) | G2D_SWZ_ARGB)
#define G2D_YUV_VU ((0 << 24) | G2D_SWZ_ARGB)
#define G2D_YUV_YC (0 << 25)
#define G2D_YUV_CY (1 << 25)
#define G2D_DATAFORMAT_AFBC (1 << 20)
#define G2D_DATAFORMAT_UORDER (1 << 21)
#define G2D_DATAFORMAT_SBWC (1 << 22)
#define G2D_DATAFMT_SHIFT 16
#define G2D_DATAFMT_MASK (0xF << G2D_DATAFMT_SHIFT)
#define G2D_DATAFMT_8888 (0 << G2D_DATAFMT_SHIFT)
#define G2D_DATAFMT_565 (1 << G2D_DATAFMT_SHIFT)
#define G2D_DATAFMT_4444 (2 << G2D_DATAFMT_SHIFT)
#define G2D_DATAFMT_888 (3 << G2D_DATAFMT_SHIFT)
#define G2D_DATAFMT_1555 (4 << G2D_DATAFMT_SHIFT)
#define G2D_DATAFMT_5551 (5 << G2D_DATAFMT_SHIFT)
#define G2D_DATAFMT_RGB8_MAX (5 << G2D_DATAFMT_SHIFT)
#define G2D_DATAFMT_8 (6 << G2D_DATAFMT_SHIFT)
#define G2D_DATAFMT_RESERVED (7 << G2D_DATAFMT_SHIFT)
#define G2D_DATAFMT_YUV_MIN (8 << G2D_DATAFMT_SHIFT)
#define G2D_DATAFMT_YUV420SP (8 << G2D_DATAFMT_SHIFT)
#define G2D_DATAFMT_YUV420P (9 << G2D_DATAFMT_SHIFT)
#define G2D_DATAFMT_YUV422I (10 << G2D_DATAFMT_SHIFT)
#define G2D_DATAFMT_YUV422SP (11 << G2D_DATAFMT_SHIFT)
#define G2D_DATAFMT_P010_LGCY (12 << G2D_DATAFMT_SHIFT)
#define G2D_DATAFMT_YUV_MAX (12 << G2D_DATAFMT_SHIFT)
#define G2D_DATAFMT_ABGR2101010 (14 << G2D_DATAFMT_SHIFT)
#define G2D_FMT_YCBCR_BITDEPTH_SHIFT 28
#define G2D_FMT_YCBCR_BITDEPTH_MASK (0x3 << G2D_FMT_YCBCR_BITDEPTH_SHIFT)
#define G2D_FMT_YCBCR_8BIT (0 << G2D_FMT_YCBCR_BITDEPTH_SHIFT)
#define G2D_FMT_YCBCR_10BIT (1 << G2D_FMT_YCBCR_BITDEPTH_SHIFT)
#define G2D_FMT_ARGB8888 (G2D_DATAFMT_8888 | G2D_SWZ_ARGB)
#define G2D_FMT_ABGR8888 (G2D_DATAFMT_8888 | G2D_SWZ_ABGR)
#define G2D_FMT_XBGR8888 (G2D_DATAFMT_8888 | G2D_SWZ_xBGR)
#define G2D_FMT_RGB565 (G2D_DATAFMT_565 | G2D_SWZ_xRGB)
#define G2D_FMT_BGR565 (G2D_DATAFMT_565 | G2D_SWZ_xBGR)
#define G2D_FMT_RGB888 (G2D_DATAFMT_888 | G2D_SWZ_xRGB)
#define G2D_FMT_NV12 (G2D_DATAFMT_YUV420SP | G2D_YUV_UV)
#define G2D_FMT_NV21 (G2D_DATAFMT_YUV420SP | G2D_YUV_VU)
#define G2D_FMT_YUV420P (G2D_DATAFMT_YUV420P | G2D_YUV_UV)
#define G2D_FMT_YV12 (G2D_DATAFMT_YUV420P | G2D_YUV_VU)
#define G2D_FMT_YUYV (G2D_DATAFMT_YUV422I | G2D_YUV_YC | G2D_YUV_UV)
#define G2D_FMT_YVYU (G2D_DATAFMT_YUV422I | G2D_YUV_YC | G2D_YUV_VU)
#define G2D_FMT_UYVY (G2D_DATAFMT_YUV422I | G2D_YUV_CY | G2D_YUV_UV)
#define G2D_FMT_VYUY (G2D_DATAFMT_YUV422I | G2D_YUV_CY | G2D_YUV_VU)
#define G2D_FMT_NV16 (G2D_DATAFMT_YUV422SP | G2D_YUV_UV)
#define G2D_FMT_NV61 (G2D_DATAFMT_YUV422SP | G2D_YUV_VU)
#define G2D_FMT_NV12_P010_LGCY (G2D_DATAFMT_P010_LGCY | G2D_YUV_UV)
#define G2D_FMT_NV21_P010_LGCY (G2D_DATAFMT_P010_LGCY | G2D_YUV_VU)
#define G2D_FMT_NV12_P010 (G2D_DATAFMT_YUV420SP | G2D_FMT_YCBCR_10BIT | G2D_YUV_UV)
#define G2D_FMT_NV21_P010 (G2D_DATAFMT_YUV420SP | G2D_FMT_YCBCR_10BIT | G2D_YUV_VU)
#define G2D_FMT_NV16_P210 (G2D_DATAFMT_YUV422SP | G2D_FMT_YCBCR_10BIT | G2D_YUV_UV)
#define G2D_FMT_NV61_P210 (G2D_DATAFMT_YUV422SP | G2D_FMT_YCBCR_10BIT | G2D_YUV_VU)
#define G2D_FMT_ABGR2101010 (G2D_DATAFMT_ABGR2101010 | G2D_SWZ_ABGR)
#define G2D_FMT_NV12_SBWC (G2D_FMT_NV12 | G2D_DATAFORMAT_SBWC)
#define G2D_FMT_NV21_SBWC (G2D_FMT_NV21 | G2D_DATAFORMAT_SBWC)
#define G2D_FMT_NV12_SBWC_10B (G2D_FMT_NV12_P010 | G2D_DATAFORMAT_SBWC)
#define G2D_FMT_NV21_SBWC_10B (G2D_FMT_NV21_P010 | G2D_DATAFORMAT_SBWC)
#define G2D_YCBCRMODE_DITHER (1 << 2)
#define IS_YUV(fmt) ((((fmt) & G2D_DATAFMT_MASK) >= G2D_DATAFMT_YUV_MIN) && (((fmt) & G2D_DATAFMT_MASK) <= G2D_DATAFMT_YUV_MAX))
#define IS_RGB(fmt) ((((fmt) & G2D_DATAFMT_MASK) <= G2D_DATAFMT_RGB8_MAX) || (((fmt) & G2D_DATAFMT_MASK) > G2D_DATAFMT_YUV_MAX))
#define G2D_IMGFMT(value) ((value) & \
(G2D_DATAFMT_MASK | G2D_YUVORDER_MASK | G2D_SWZ_MASK))
#define G2D_MAX_PLANES 4
#define G2D_ROTATEDIR_FLIP_SHIFT 4
#define G2D_ROTATEDIR_ROT90CCW (1 << 0)
#define G2D_BLEND_NONE (2 | (2 << 4) | (2 << 8) | (2 << 12) | (1 << 18)) // Ga*Sa*Sc + (1-Sa*Ga)*Dc
#define G2D_BLEND_SRCOVER (6 | (2 << 8) | (2 << 12) | (1 << 18)) // Ga*Sc + (1-Sa*Ga)*Dc
#define G2D_BLEND_SRCCOPY (6 | (1 << 8) ) // Ga*Sc
#define G2D_LAYERCMD_PREMULT_GLOBALALPHA (2 << 24)
#define G2D_LAYERCMD_PREMULT_ALPHA (1 << 24)
#define G2D_LAYERCMD_ALPHABLEND (1 << 20)
#define G2D_LAYERCMD_OPAQUE (1 << 1)
#define G2D_LAYERCMD_VALID (1 << 0)
#define G2D_LAYERSEL_COLORFILL 1
#define G2D_LAYER_YCBCRMODE_WIDE (1 << 4)
#define G2D_LAYER_YCBCRMODE_OFFX (2 << 8)
#define G2D_LAYER_YCBCRMODE_OFFY (2 << 12)
#define G2D_SCALECONTROL_BILINEAR 2
#define G2D_SCALECONTROL_POLYPHASE 3
#define G2D_SCALECONTROL_FILTERCOEF_SHIFT 4
#define G2D_SCALEFACTOR_FRACBITS 16
#define G2D_LAYER_HDRMODE_DEMULT_ALPHA (1 << 12)
struct g2d_reg {
uint32_t offset;
uint32_t value;
};
enum g2dsfr_img_register {
G2DSFR_IMG_STRIDE,
G2DSFR_IMG_COLORMODE,
G2DSFR_IMG_LEFT,
G2DSFR_IMG_TOP,
G2DSFR_IMG_RIGHT,
G2DSFR_IMG_BOTTOM,
G2DSFR_IMG_WIDTH,
G2DSFR_IMG_HEIGHT,
G2DSFR_IMG_FIELD_COUNT,
};
/*
* The order of command list should be fixed.
* The new command item must be added from the bottom.
*/
enum g2dsfr_src_register {
G2DSFR_SRC_COMMAND = G2DSFR_IMG_FIELD_COUNT,
G2DSFR_SRC_SELECT,
G2DSFR_SRC_ROTATE,
G2DSFR_SRC_DSTLEFT,
G2DSFR_SRC_DSTTOP,
G2DSFR_SRC_DSTRIGHT,
G2DSFR_SRC_DSTBOTTOM,
G2DSFR_SRC_SCALECONTROL,
G2DSFR_SRC_XSCALE,
G2DSFR_SRC_YSCALE,
G2DSFR_SRC_XPHASE,
G2DSFR_SRC_YPHASE,
G2DSFR_SRC_COLOR,
G2DSFR_SRC_ALPHA,
G2DSFR_SRC_BLEND,
G2DSFR_SRC_YCBCRMODE,
G2DSFR_SRC_HDRMODE,
G2DSFR_SRC_Y_HEADER_STRIDE,
G2DSFR_SRC_Y_PAYLOAD_STRIDE,
G2DSFR_SRC_C_HEADER_STRIDE,
G2DSFR_SRC_C_PAYLOAD_STRIDE,
G2DSFR_SRC_SBWCINFO,
G2DSFR_SRC_FIELD_COUNT
};
enum g2dsfr_dst_register {
G2DSFR_DST_YCBCRMODE = G2DSFR_IMG_FIELD_COUNT,
G2DSFR_DST_COMPAT_FIELD_COUNT,
G2DSFR_DST_Y_HEADER_STRIDE = G2DSFR_DST_COMPAT_FIELD_COUNT,
G2DSFR_DST_Y_PAYLOAD_STRIDE,
G2DSFR_DST_C_HEADER_STRIDE,
G2DSFR_DST_C_PAYLOAD_STRIDE,
G2DSFR_DST_SBWCINFO,
G2DSFR_DST_FIELD_COUNT,
};
#define G2D_MAX_PLANES 4
#define G2D_MAX_SFR_COUNT 1024
#define G2D_MAX_BUFFERS 4
#define G2D_MAX_IMAGES 16
#define G2D_MAX_PRIORITY 3
#define G2D_MAX_RELEASE_FENCES (G2D_MAX_IMAGES + 1)
struct g2d_compat_commands {
uint32_t target[G2DSFR_DST_COMPAT_FIELD_COUNT];
uint32_t *source[G2D_MAX_IMAGES];
struct g2d_reg *extra;
uint32_t num_extra_regs;
};
#define G2D_BUFTYPE_NONE 0
#define G2D_BUFTYPE_EMPTY 1
#define G2D_BUFTYPE_USERPTR 2
#define G2D_BUFTYPE_DMABUF 3
#define G2D_BUFTYPE_VALID(type) !(((type) & G2D_BUFTYPE_DMABUF) == 0)
struct g2d_buffer {
union {
void *userptr;
struct {
int32_t fd;
uint32_t offset;
} dmabuf;
};
uint32_t length;
};
#define G2D_LAYERFLAG_ACQUIRE_FENCE (1 << 1)
#define G2D_LAYERFLAG_SECURE (1 << 2)
#define G2D_LAYERFLAG_COLORFILL (1 << 3)
#define G2D_LAYERFLAG_MFC_STRIDE (1 << 4)
#define G2D_LAYERFLAG_AFBC_WIDEBLK (1 << 5)
#define G2D_LAYERFLAG_NO_CACHECLEAN (1 << 16)
#define G2D_LAYERFLAG_NO_CACHEINV (1 << 17)
struct g2d_layer {
uint32_t flags;
int32_t fence;
uint32_t buffer_type;
uint32_t num_buffers;
struct g2d_buffer buffer[G2D_MAX_BUFFERS];
};
#define G2D_FLAG_DITHER (1 << 1)
#define G2D_FLAG_NONBLOCK (1 << 2)
#define G2D_FLAG_HWFC (1 << 3)
#define G2D_FLAG_APB (1 << 4)
#define G2D_FLAG_ERROR (1 << 5)
struct g2d_compat_task {
uint32_t version;
uint32_t flags;
uint32_t laptime_in_usec;
uint32_t priority;
uint32_t num_source;
uint32_t num_release_fences;
int32_t *release_fence;
struct g2d_layer target;
struct g2d_layer *source;
struct g2d_compat_commands commands;
};
/*
* Commands must be flexible because it may change according to H/W changes.
* The commands must be written in the promised order as version.
*/
struct g2d_commands {
uint32_t *target;
uint32_t *source[G2D_MAX_IMAGES];
struct g2d_reg *extra;
uint32_t num_extra_regs;
};
struct g2d_task {
uint32_t version;
uint32_t flags;
uint32_t laptime_in_usec;
uint32_t priority;
uint32_t num_source;
uint32_t num_release_fences;
int32_t *release_fence;
struct g2d_layer target;
struct g2d_layer *source;
struct g2d_commands commands;
};
#define G2D_PERF_LAYER_ROTATE (1 << 0)
#define G2D_PERF_LAYER_SCALING (1 << 1)
#define G2D_PERF_LAYER_YUV2P (1 << 4)
#define G2D_PERF_LAYER_SBWC (1 << 5)
#define G2D_PERF_LAYER_RGB_AFBC (1 << 6)
#define G2D_PERF_LAYER_YUV_AFBC (1 << 7)
struct g2d_performance_layer {
uint16_t crop_width;
uint16_t crop_height;
uint16_t window_width;
uint16_t window_height;
uint32_t layer_attr;
};
#define G2D_PERF_FRAME_SOLIDCOLORFILL (1 << 0)
struct g2d_performance_frame {
struct g2d_performance_layer layer[G2D_MAX_IMAGES];
uint32_t bandwidth_read;
uint32_t bandwidth_write;
uint32_t target_pixelcount;
uint32_t frame_rate;
uint32_t frame_attr;
uint32_t num_layers;
};
#define G2D_PERF_MAX_FRAMES 4
struct g2d_performance {
struct g2d_performance_frame frame[G2D_PERF_MAX_FRAMES];
uint32_t num_frame;
uint32_t reserved;
};
enum g2d_priority {
G2D_LOW_PRIORITY,
G2D_MEDIUM_PRIORITY,
G2D_DEFAULT_PRIORITY = G2D_MEDIUM_PRIORITY,
G2D_HIGH_PRIORITY,
G2D_HIGHEST_PRIORITY,
G2D_PRIORITY_END
};
#define G2D_IOC_PROCESS _IOWR('M', 3, struct g2d_task)
#define G2D_IOC_COMPAT_PROCESS _IOWR('M', 4, struct g2d_compat_task)
#define G2D_IOC_PRIORITY _IOR('M', 5, int32_t)
#define G2D_IOC_PERFORMANCE _IOR('M', 6, struct g2d_performance)
#define G2D_IOC_VERSION _IOR('M', 7, uint32_t)
#ifdef __cplusplus
}
#endif
#endif /* __UAPI_G2D_H__ */