ded874ece2
This introduces two macros: RGA_COLOR_FMT_IS_YUV and RGA_COLOR_FMT_IS_RGB which allow quick checking of the colorspace familily of a RGA color format. These macros are then used to refactor the logic for CSC mode selection. The two nested tests for input colorspace are simplified into a single one, with a logical and, making the whole more readable. Signed-off-by: Paul Kocialkowski <paul.kocialkowski@bootlin.com> Reviewed-by: Ezequiel Garcia <ezequiel@collabora.com> Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl> Signed-off-by: Mauro Carvalho Chehab <mchehab+huawei@kernel.org>
435 lines
9.4 KiB
C
435 lines
9.4 KiB
C
/* SPDX-License-Identifier: GPL-2.0-only */
|
|
/*
|
|
* Copyright (C) Fuzhou Rockchip Electronics Co.Ltd
|
|
* Author: Jacob Chen <jacob-chen@iotwrt.com>
|
|
*/
|
|
#ifndef __RGA_HW_H__
|
|
#define __RGA_HW_H__
|
|
|
|
#define RGA_CMDBUF_SIZE 0x20
|
|
|
|
/* Hardware limits */
|
|
#define MAX_WIDTH 8192
|
|
#define MAX_HEIGHT 8192
|
|
|
|
#define MIN_WIDTH 34
|
|
#define MIN_HEIGHT 34
|
|
|
|
#define DEFAULT_WIDTH 100
|
|
#define DEFAULT_HEIGHT 100
|
|
|
|
#define RGA_TIMEOUT 500
|
|
|
|
/* Registers address */
|
|
#define RGA_SYS_CTRL 0x0000
|
|
#define RGA_CMD_CTRL 0x0004
|
|
#define RGA_CMD_BASE 0x0008
|
|
#define RGA_INT 0x0010
|
|
#define RGA_MMU_CTRL0 0x0014
|
|
#define RGA_VERSION_INFO 0x0028
|
|
|
|
#define RGA_MODE_BASE_REG 0x0100
|
|
#define RGA_MODE_MAX_REG 0x017C
|
|
|
|
#define RGA_MODE_CTRL 0x0100
|
|
#define RGA_SRC_INFO 0x0104
|
|
#define RGA_SRC_Y_RGB_BASE_ADDR 0x0108
|
|
#define RGA_SRC_CB_BASE_ADDR 0x010c
|
|
#define RGA_SRC_CR_BASE_ADDR 0x0110
|
|
#define RGA_SRC1_RGB_BASE_ADDR 0x0114
|
|
#define RGA_SRC_VIR_INFO 0x0118
|
|
#define RGA_SRC_ACT_INFO 0x011c
|
|
#define RGA_SRC_X_FACTOR 0x0120
|
|
#define RGA_SRC_Y_FACTOR 0x0124
|
|
#define RGA_SRC_BG_COLOR 0x0128
|
|
#define RGA_SRC_FG_COLOR 0x012c
|
|
#define RGA_SRC_TR_COLOR0 0x0130
|
|
#define RGA_SRC_TR_COLOR1 0x0134
|
|
|
|
#define RGA_DST_INFO 0x0138
|
|
#define RGA_DST_Y_RGB_BASE_ADDR 0x013c
|
|
#define RGA_DST_CB_BASE_ADDR 0x0140
|
|
#define RGA_DST_CR_BASE_ADDR 0x0144
|
|
#define RGA_DST_VIR_INFO 0x0148
|
|
#define RGA_DST_ACT_INFO 0x014c
|
|
|
|
#define RGA_ALPHA_CTRL0 0x0150
|
|
#define RGA_ALPHA_CTRL1 0x0154
|
|
#define RGA_FADING_CTRL 0x0158
|
|
#define RGA_PAT_CON 0x015c
|
|
#define RGA_ROP_CON0 0x0160
|
|
#define RGA_ROP_CON1 0x0164
|
|
#define RGA_MASK_BASE 0x0168
|
|
|
|
#define RGA_MMU_CTRL1 0x016C
|
|
#define RGA_MMU_SRC_BASE 0x0170
|
|
#define RGA_MMU_SRC1_BASE 0x0174
|
|
#define RGA_MMU_DST_BASE 0x0178
|
|
|
|
/* Registers value */
|
|
#define RGA_MODE_RENDER_BITBLT 0
|
|
#define RGA_MODE_RENDER_COLOR_PALETTE 1
|
|
#define RGA_MODE_RENDER_RECTANGLE_FILL 2
|
|
#define RGA_MODE_RENDER_UPDATE_PALETTE_LUT_RAM 3
|
|
|
|
#define RGA_MODE_BITBLT_MODE_SRC_TO_DST 0
|
|
#define RGA_MODE_BITBLT_MODE_SRC_SRC1_TO_DST 1
|
|
|
|
#define RGA_MODE_CF_ROP4_SOLID 0
|
|
#define RGA_MODE_CF_ROP4_PATTERN 1
|
|
|
|
#define RGA_COLOR_FMT_ABGR8888 0
|
|
#define RGA_COLOR_FMT_XBGR8888 1
|
|
#define RGA_COLOR_FMT_RGB888 2
|
|
#define RGA_COLOR_FMT_BGR565 4
|
|
#define RGA_COLOR_FMT_ABGR1555 5
|
|
#define RGA_COLOR_FMT_ABGR4444 6
|
|
#define RGA_COLOR_FMT_YUV422SP 8
|
|
#define RGA_COLOR_FMT_YUV422P 9
|
|
#define RGA_COLOR_FMT_YUV420SP 10
|
|
#define RGA_COLOR_FMT_YUV420P 11
|
|
/* SRC_COLOR Palette */
|
|
#define RGA_COLOR_FMT_CP_1BPP 12
|
|
#define RGA_COLOR_FMT_CP_2BPP 13
|
|
#define RGA_COLOR_FMT_CP_4BPP 14
|
|
#define RGA_COLOR_FMT_CP_8BPP 15
|
|
#define RGA_COLOR_FMT_MASK 15
|
|
|
|
#define RGA_COLOR_FMT_IS_YUV(fmt) \
|
|
(((fmt) >= RGA_COLOR_FMT_YUV422SP) && ((fmt) < RGA_COLOR_FMT_CP_1BPP))
|
|
#define RGA_COLOR_FMT_IS_RGB(fmt) \
|
|
((fmt) < RGA_COLOR_FMT_YUV422SP)
|
|
|
|
#define RGA_COLOR_NONE_SWAP 0
|
|
#define RGA_COLOR_RB_SWAP 1
|
|
#define RGA_COLOR_ALPHA_SWAP 2
|
|
#define RGA_COLOR_UV_SWAP 4
|
|
|
|
#define RGA_SRC_CSC_MODE_BYPASS 0
|
|
#define RGA_SRC_CSC_MODE_BT601_R0 1
|
|
#define RGA_SRC_CSC_MODE_BT601_R1 2
|
|
#define RGA_SRC_CSC_MODE_BT709_R0 3
|
|
#define RGA_SRC_CSC_MODE_BT709_R1 4
|
|
|
|
#define RGA_SRC_ROT_MODE_0_DEGREE 0
|
|
#define RGA_SRC_ROT_MODE_90_DEGREE 1
|
|
#define RGA_SRC_ROT_MODE_180_DEGREE 2
|
|
#define RGA_SRC_ROT_MODE_270_DEGREE 3
|
|
|
|
#define RGA_SRC_MIRR_MODE_NO 0
|
|
#define RGA_SRC_MIRR_MODE_X 1
|
|
#define RGA_SRC_MIRR_MODE_Y 2
|
|
#define RGA_SRC_MIRR_MODE_X_Y 3
|
|
|
|
#define RGA_SRC_HSCL_MODE_NO 0
|
|
#define RGA_SRC_HSCL_MODE_DOWN 1
|
|
#define RGA_SRC_HSCL_MODE_UP 2
|
|
|
|
#define RGA_SRC_VSCL_MODE_NO 0
|
|
#define RGA_SRC_VSCL_MODE_DOWN 1
|
|
#define RGA_SRC_VSCL_MODE_UP 2
|
|
|
|
#define RGA_SRC_TRANS_ENABLE_R 1
|
|
#define RGA_SRC_TRANS_ENABLE_G 2
|
|
#define RGA_SRC_TRANS_ENABLE_B 4
|
|
#define RGA_SRC_TRANS_ENABLE_A 8
|
|
|
|
#define RGA_SRC_BIC_COE_SELEC_CATROM 0
|
|
#define RGA_SRC_BIC_COE_SELEC_MITCHELL 1
|
|
#define RGA_SRC_BIC_COE_SELEC_HERMITE 2
|
|
#define RGA_SRC_BIC_COE_SELEC_BSPLINE 3
|
|
|
|
#define RGA_DST_DITHER_MODE_888_TO_666 0
|
|
#define RGA_DST_DITHER_MODE_888_TO_565 1
|
|
#define RGA_DST_DITHER_MODE_888_TO_555 2
|
|
#define RGA_DST_DITHER_MODE_888_TO_444 3
|
|
|
|
#define RGA_DST_CSC_MODE_BYPASS 0
|
|
#define RGA_DST_CSC_MODE_BT601_R0 1
|
|
#define RGA_DST_CSC_MODE_BT601_R1 2
|
|
#define RGA_DST_CSC_MODE_BT709_R0 3
|
|
|
|
#define RGA_ALPHA_ROP_MODE_2 0
|
|
#define RGA_ALPHA_ROP_MODE_3 1
|
|
#define RGA_ALPHA_ROP_MODE_4 2
|
|
|
|
#define RGA_ALPHA_SELECT_ALPHA 0
|
|
#define RGA_ALPHA_SELECT_ROP 1
|
|
|
|
#define RGA_ALPHA_MASK_BIG_ENDIAN 0
|
|
#define RGA_ALPHA_MASK_LITTLE_ENDIAN 1
|
|
|
|
#define RGA_ALPHA_NORMAL 0
|
|
#define RGA_ALPHA_REVERSE 1
|
|
|
|
#define RGA_ALPHA_BLEND_GLOBAL 0
|
|
#define RGA_ALPHA_BLEND_NORMAL 1
|
|
#define RGA_ALPHA_BLEND_MULTIPLY 2
|
|
|
|
#define RGA_ALPHA_CAL_CUT 0
|
|
#define RGA_ALPHA_CAL_NORMAL 1
|
|
|
|
#define RGA_ALPHA_FACTOR_ZERO 0
|
|
#define RGA_ALPHA_FACTOR_ONE 1
|
|
#define RGA_ALPHA_FACTOR_OTHER 2
|
|
#define RGA_ALPHA_FACTOR_OTHER_REVERSE 3
|
|
#define RGA_ALPHA_FACTOR_SELF 4
|
|
|
|
#define RGA_ALPHA_COLOR_NORMAL 0
|
|
#define RGA_ALPHA_COLOR_MULTIPLY_CAL 1
|
|
|
|
/* Registers union */
|
|
union rga_mode_ctrl {
|
|
unsigned int val;
|
|
struct {
|
|
/* [0:2] */
|
|
unsigned int render:3;
|
|
/* [3:6] */
|
|
unsigned int bitblt:1;
|
|
unsigned int cf_rop4_pat:1;
|
|
unsigned int alpha_zero_key:1;
|
|
unsigned int gradient_sat:1;
|
|
/* [7:31] */
|
|
unsigned int reserved:25;
|
|
} data;
|
|
};
|
|
|
|
union rga_src_info {
|
|
unsigned int val;
|
|
struct {
|
|
/* [0:3] */
|
|
unsigned int format:4;
|
|
/* [4:7] */
|
|
unsigned int swap:3;
|
|
unsigned int cp_endian:1;
|
|
/* [8:17] */
|
|
unsigned int csc_mode:2;
|
|
unsigned int rot_mode:2;
|
|
unsigned int mir_mode:2;
|
|
unsigned int hscl_mode:2;
|
|
unsigned int vscl_mode:2;
|
|
/* [18:22] */
|
|
unsigned int trans_mode:1;
|
|
unsigned int trans_enable:4;
|
|
/* [23:25] */
|
|
unsigned int dither_up_en:1;
|
|
unsigned int bic_coe_sel:2;
|
|
/* [26:31] */
|
|
unsigned int reserved:6;
|
|
} data;
|
|
};
|
|
|
|
union rga_src_vir_info {
|
|
unsigned int val;
|
|
struct {
|
|
/* [0:15] */
|
|
unsigned int vir_width:15;
|
|
unsigned int reserved:1;
|
|
/* [16:25] */
|
|
unsigned int vir_stride:10;
|
|
/* [26:31] */
|
|
unsigned int reserved1:6;
|
|
} data;
|
|
};
|
|
|
|
union rga_src_act_info {
|
|
unsigned int val;
|
|
struct {
|
|
/* [0:15] */
|
|
unsigned int act_width:13;
|
|
unsigned int reserved:3;
|
|
/* [16:31] */
|
|
unsigned int act_height:13;
|
|
unsigned int reserved1:3;
|
|
} data;
|
|
};
|
|
|
|
union rga_src_x_factor {
|
|
unsigned int val;
|
|
struct {
|
|
/* [0:15] */
|
|
unsigned int down_scale_factor:16;
|
|
/* [16:31] */
|
|
unsigned int up_scale_factor:16;
|
|
} data;
|
|
};
|
|
|
|
union rga_src_y_factor {
|
|
unsigned int val;
|
|
struct {
|
|
/* [0:15] */
|
|
unsigned int down_scale_factor:16;
|
|
/* [16:31] */
|
|
unsigned int up_scale_factor:16;
|
|
} data;
|
|
};
|
|
|
|
/* Alpha / Red / Green / Blue */
|
|
union rga_src_cp_gr_color {
|
|
unsigned int val;
|
|
struct {
|
|
/* [0:15] */
|
|
unsigned int gradient_x:16;
|
|
/* [16:31] */
|
|
unsigned int gradient_y:16;
|
|
} data;
|
|
};
|
|
|
|
union rga_src_transparency_color0 {
|
|
unsigned int val;
|
|
struct {
|
|
/* [0:7] */
|
|
unsigned int trans_rmin:8;
|
|
/* [8:15] */
|
|
unsigned int trans_gmin:8;
|
|
/* [16:23] */
|
|
unsigned int trans_bmin:8;
|
|
/* [24:31] */
|
|
unsigned int trans_amin:8;
|
|
} data;
|
|
};
|
|
|
|
union rga_src_transparency_color1 {
|
|
unsigned int val;
|
|
struct {
|
|
/* [0:7] */
|
|
unsigned int trans_rmax:8;
|
|
/* [8:15] */
|
|
unsigned int trans_gmax:8;
|
|
/* [16:23] */
|
|
unsigned int trans_bmax:8;
|
|
/* [24:31] */
|
|
unsigned int trans_amax:8;
|
|
} data;
|
|
};
|
|
|
|
union rga_dst_info {
|
|
unsigned int val;
|
|
struct {
|
|
/* [0:3] */
|
|
unsigned int format:4;
|
|
/* [4:6] */
|
|
unsigned int swap:3;
|
|
/* [7:9] */
|
|
unsigned int src1_format:3;
|
|
/* [10:11] */
|
|
unsigned int src1_swap:2;
|
|
/* [12:15] */
|
|
unsigned int dither_up_en:1;
|
|
unsigned int dither_down_en:1;
|
|
unsigned int dither_down_mode:2;
|
|
/* [16:18] */
|
|
unsigned int csc_mode:2;
|
|
unsigned int csc_clip:1;
|
|
/* [19:31] */
|
|
unsigned int reserved:13;
|
|
} data;
|
|
};
|
|
|
|
union rga_dst_vir_info {
|
|
unsigned int val;
|
|
struct {
|
|
/* [0:15] */
|
|
unsigned int vir_stride:15;
|
|
unsigned int reserved:1;
|
|
/* [16:31] */
|
|
unsigned int src1_vir_stride:15;
|
|
unsigned int reserved1:1;
|
|
} data;
|
|
};
|
|
|
|
union rga_dst_act_info {
|
|
unsigned int val;
|
|
struct {
|
|
/* [0:15] */
|
|
unsigned int act_width:12;
|
|
unsigned int reserved:4;
|
|
/* [16:31] */
|
|
unsigned int act_height:12;
|
|
unsigned int reserved1:4;
|
|
} data;
|
|
};
|
|
|
|
union rga_alpha_ctrl0 {
|
|
unsigned int val;
|
|
struct {
|
|
/* [0:3] */
|
|
unsigned int rop_en:1;
|
|
unsigned int rop_select:1;
|
|
unsigned int rop_mode:2;
|
|
/* [4:11] */
|
|
unsigned int src_fading_val:8;
|
|
/* [12:20] */
|
|
unsigned int dst_fading_val:8;
|
|
unsigned int mask_endian:1;
|
|
/* [21:31] */
|
|
unsigned int reserved:11;
|
|
} data;
|
|
};
|
|
|
|
union rga_alpha_ctrl1 {
|
|
unsigned int val;
|
|
struct {
|
|
/* [0:1] */
|
|
unsigned int dst_color_m0:1;
|
|
unsigned int src_color_m0:1;
|
|
/* [2:7] */
|
|
unsigned int dst_factor_m0:3;
|
|
unsigned int src_factor_m0:3;
|
|
/* [8:9] */
|
|
unsigned int dst_alpha_cal_m0:1;
|
|
unsigned int src_alpha_cal_m0:1;
|
|
/* [10:13] */
|
|
unsigned int dst_blend_m0:2;
|
|
unsigned int src_blend_m0:2;
|
|
/* [14:15] */
|
|
unsigned int dst_alpha_m0:1;
|
|
unsigned int src_alpha_m0:1;
|
|
/* [16:21] */
|
|
unsigned int dst_factor_m1:3;
|
|
unsigned int src_factor_m1:3;
|
|
/* [22:23] */
|
|
unsigned int dst_alpha_cal_m1:1;
|
|
unsigned int src_alpha_cal_m1:1;
|
|
/* [24:27] */
|
|
unsigned int dst_blend_m1:2;
|
|
unsigned int src_blend_m1:2;
|
|
/* [28:29] */
|
|
unsigned int dst_alpha_m1:1;
|
|
unsigned int src_alpha_m1:1;
|
|
/* [30:31] */
|
|
unsigned int reserved:2;
|
|
} data;
|
|
};
|
|
|
|
union rga_fading_ctrl {
|
|
unsigned int val;
|
|
struct {
|
|
/* [0:7] */
|
|
unsigned int fading_offset_r:8;
|
|
/* [8:15] */
|
|
unsigned int fading_offset_g:8;
|
|
/* [16:23] */
|
|
unsigned int fading_offset_b:8;
|
|
/* [24:31] */
|
|
unsigned int fading_en:1;
|
|
unsigned int reserved:7;
|
|
} data;
|
|
};
|
|
|
|
union rga_pat_con {
|
|
unsigned int val;
|
|
struct {
|
|
/* [0:7] */
|
|
unsigned int width:8;
|
|
/* [8:15] */
|
|
unsigned int height:8;
|
|
/* [16:23] */
|
|
unsigned int offset_x:8;
|
|
/* [24:31] */
|
|
unsigned int offset_y:8;
|
|
} data;
|
|
};
|
|
|
|
#endif
|