1*dbf21777SIcenowy Zheng /* SPDX-License-Identifier: GPL-2.0-only */ 2*dbf21777SIcenowy Zheng /* 3*dbf21777SIcenowy Zheng * Copyright (C) 2025 Icenowy Zheng <uwu@icenowy.me> 4*dbf21777SIcenowy Zheng * 5*dbf21777SIcenowy Zheng * Based on vs_dc_hw.h, which is: 6*dbf21777SIcenowy Zheng * Copyright (C) 2023 VeriSilicon Holdings Co., Ltd. 7*dbf21777SIcenowy Zheng */ 8*dbf21777SIcenowy Zheng 9*dbf21777SIcenowy Zheng #ifndef _VS_PRIMARY_PLANE_REGS_H_ 10*dbf21777SIcenowy Zheng #define _VS_PRIMARY_PLANE_REGS_H_ 11*dbf21777SIcenowy Zheng 12*dbf21777SIcenowy Zheng #include <linux/bits.h> 13*dbf21777SIcenowy Zheng 14*dbf21777SIcenowy Zheng #define VSDC_FB_ADDRESS(n) (0x1400 + 0x4 * (n)) 15*dbf21777SIcenowy Zheng 16*dbf21777SIcenowy Zheng #define VSDC_FB_STRIDE(n) (0x1408 + 0x4 * (n)) 17*dbf21777SIcenowy Zheng 18*dbf21777SIcenowy Zheng #define VSDC_FB_CONFIG(n) (0x1518 + 0x4 * (n)) 19*dbf21777SIcenowy Zheng #define VSDC_FB_CONFIG_CLEAR_EN BIT(8) 20*dbf21777SIcenowy Zheng #define VSDC_FB_CONFIG_ROT_MASK GENMASK(13, 11) 21*dbf21777SIcenowy Zheng #define VSDC_FB_CONFIG_ROT(v) ((v) << 11) 22*dbf21777SIcenowy Zheng #define VSDC_FB_CONFIG_YUV_SPACE_MASK GENMASK(16, 14) 23*dbf21777SIcenowy Zheng #define VSDC_FB_CONFIG_YUV_SPACE(v) ((v) << 14) 24*dbf21777SIcenowy Zheng #define VSDC_FB_CONFIG_TILE_MODE_MASK GENMASK(21, 17) 25*dbf21777SIcenowy Zheng #define VSDC_FB_CONFIG_TILE_MODE(v) ((v) << 14) 26*dbf21777SIcenowy Zheng #define VSDC_FB_CONFIG_SCALE_EN BIT(22) 27*dbf21777SIcenowy Zheng #define VSDC_FB_CONFIG_SWIZZLE_MASK GENMASK(24, 23) 28*dbf21777SIcenowy Zheng #define VSDC_FB_CONFIG_SWIZZLE(v) ((v) << 23) 29*dbf21777SIcenowy Zheng #define VSDC_FB_CONFIG_UV_SWIZZLE_EN BIT(25) 30*dbf21777SIcenowy Zheng #define VSDC_FB_CONFIG_FMT_MASK GENMASK(31, 26) 31*dbf21777SIcenowy Zheng #define VSDC_FB_CONFIG_FMT(v) ((v) << 26) 32*dbf21777SIcenowy Zheng 33*dbf21777SIcenowy Zheng #define VSDC_FB_SIZE(n) (0x1810 + 0x4 * (n)) 34*dbf21777SIcenowy Zheng /* Fill with value generated with VSDC_MAKE_PLANE_SIZE(w, h) */ 35*dbf21777SIcenowy Zheng 36*dbf21777SIcenowy Zheng #define VSDC_FB_CONFIG_EX(n) (0x1CC0 + 0x4 * (n)) 37*dbf21777SIcenowy Zheng #define VSDC_FB_CONFIG_EX_COMMIT BIT(12) 38*dbf21777SIcenowy Zheng #define VSDC_FB_CONFIG_EX_FB_EN BIT(13) 39*dbf21777SIcenowy Zheng #define VSDC_FB_CONFIG_EX_ZPOS_MASK GENMASK(18, 16) 40*dbf21777SIcenowy Zheng #define VSDC_FB_CONFIG_EX_ZPOS(v) ((v) << 16) 41*dbf21777SIcenowy Zheng #define VSDC_FB_CONFIG_EX_DISPLAY_ID_MASK GENMASK(19, 19) 42*dbf21777SIcenowy Zheng #define VSDC_FB_CONFIG_EX_DISPLAY_ID(v) ((v) << 19) 43*dbf21777SIcenowy Zheng 44*dbf21777SIcenowy Zheng #define VSDC_FB_TOP_LEFT(n) (0x24D8 + 0x4 * (n)) 45*dbf21777SIcenowy Zheng /* Fill with value generated with VSDC_MAKE_PLANE_POS(x, y) */ 46*dbf21777SIcenowy Zheng 47*dbf21777SIcenowy Zheng #define VSDC_FB_BOTTOM_RIGHT(n) (0x24E0 + 0x4 * (n)) 48*dbf21777SIcenowy Zheng /* Fill with value generated with VSDC_MAKE_PLANE_POS(x, y) */ 49*dbf21777SIcenowy Zheng 50*dbf21777SIcenowy Zheng #define VSDC_FB_BLEND_CONFIG(n) (0x2510 + 0x4 * (n)) 51*dbf21777SIcenowy Zheng #define VSDC_FB_BLEND_CONFIG_BLEND_DISABLE BIT(1) 52*dbf21777SIcenowy Zheng 53*dbf21777SIcenowy Zheng #endif /* _VS_PRIMARY_PLANE_REGS_H_ */ 54