Commit 882bda18 authored by Biju Das's avatar Biju Das Committed by Mauro Carvalho Chehab

media: renesas: vsp1: Add support for RZ/G2L VSPD

The RZ/G2L VSPD provides a single VSPD instance. It has the following
sub modules MAU, CTU, RPF, DPR, LUT, BRS, WPF and LIF.

The VSPD block on RZ/G2L SoCs does not have a version register, so
added a new compatible string "renesas,r9a07g044-vsp2" with a data
pointer containing the info structure. Also the reset line is shared
with the DU module.
Signed-off-by: default avatarBiju Das <biju.das.jz@bp.renesas.com>
Reviewed-by: default avatarLad Prabhakar <prabhakar.mahadev-lad.rj@bp.renesas.com>
Reviewed-by: default avatarGeert Uytterhoeven <geert+renesas@glider.be>
Reviewed-by: default avatarKieran Bingham <kieran.bingham+renesas@ideasonboard.com>
Signed-off-by: default avatarLaurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@kernel.org>
parent 4d728fd4
...@@ -830,6 +830,18 @@ static const struct vsp1_device_info vsp1_device_infos[] = { ...@@ -830,6 +830,18 @@ static const struct vsp1_device_info vsp1_device_infos[] = {
}, },
}; };
static const struct vsp1_device_info rzg2l_vsp2_device_info = {
.version = VI6_IP_VERSION_MODEL_VSPD_RZG2L,
.model = "VSP2-D",
.soc = VI6_IP_VERSION_SOC_RZG2L,
.gen = 3,
.features = VSP1_HAS_BRS | VSP1_HAS_WPF_VFLIP | VSP1_HAS_EXT_DL
| VSP1_HAS_NON_ZERO_LBA,
.lif_count = 1,
.rpf_count = 2,
.wpf_count = 1,
};
static const struct vsp1_device_info *vsp1_lookup_info(struct vsp1_device *vsp1) static const struct vsp1_device_info *vsp1_lookup_info(struct vsp1_device *vsp1)
{ {
const struct vsp1_device_info *info; const struct vsp1_device_info *info;
...@@ -980,6 +992,7 @@ static int vsp1_remove(struct platform_device *pdev) ...@@ -980,6 +992,7 @@ static int vsp1_remove(struct platform_device *pdev)
static const struct of_device_id vsp1_of_match[] = { static const struct of_device_id vsp1_of_match[] = {
{ .compatible = "renesas,vsp1" }, { .compatible = "renesas,vsp1" },
{ .compatible = "renesas,vsp2" }, { .compatible = "renesas,vsp2" },
{ .compatible = "renesas,r9a07g044-vsp2", .data = &rzg2l_vsp2_device_info },
{ }, { },
}; };
MODULE_DEVICE_TABLE(of, vsp1_of_match); MODULE_DEVICE_TABLE(of, vsp1_of_match);
......
...@@ -107,6 +107,7 @@ static void lif_configure_stream(struct vsp1_entity *entity, ...@@ -107,6 +107,7 @@ static void lif_configure_stream(struct vsp1_entity *entity,
case VI6_IP_VERSION_MODEL_VSPDL_GEN3: case VI6_IP_VERSION_MODEL_VSPDL_GEN3:
case VI6_IP_VERSION_MODEL_VSPD_V3: case VI6_IP_VERSION_MODEL_VSPD_V3:
case VI6_IP_VERSION_MODEL_VSPD_RZG2L:
hbth = 0; hbth = 0;
obth = 1500; obth = 1500;
lbth = 0; lbth = 0;
...@@ -130,10 +131,10 @@ static void lif_configure_stream(struct vsp1_entity *entity, ...@@ -130,10 +131,10 @@ static void lif_configure_stream(struct vsp1_entity *entity,
VI6_LIF_CTRL_REQSEL | VI6_LIF_CTRL_LIF_EN); VI6_LIF_CTRL_REQSEL | VI6_LIF_CTRL_LIF_EN);
/* /*
* On R-Car V3M the LIF0 buffer attribute register has to be set to a * On R-Car V3M and RZ/G2L the LIF0 buffer attribute register has to be
* non-default value to guarantee proper operation (otherwise artifacts * set to a non-default value to guarantee proper operation (otherwise
* may appear on the output). The value required by the manual is not * artifacts may appear on the output). The value required by the
* explained but is likely a buffer size or threshold. * manual is not explained but is likely a buffer size or threshold.
*/ */
if (vsp1_feature(entity->vsp1, VSP1_HAS_NON_ZERO_LBA)) if (vsp1_feature(entity->vsp1, VSP1_HAS_NON_ZERO_LBA))
vsp1_lif_write(lif, dlb, VI6_LIF_LBA, vsp1_lif_write(lif, dlb, VI6_LIF_LBA,
......
...@@ -767,6 +767,8 @@ ...@@ -767,6 +767,8 @@
#define VI6_IP_VERSION_MODEL_VSPDL_GEN3 (0x19 << 8) #define VI6_IP_VERSION_MODEL_VSPDL_GEN3 (0x19 << 8)
#define VI6_IP_VERSION_MODEL_VSPBS_GEN3 (0x1a << 8) #define VI6_IP_VERSION_MODEL_VSPBS_GEN3 (0x1a << 8)
#define VI6_IP_VERSION_MODEL_VSPD_V3U (0x1c << 8) #define VI6_IP_VERSION_MODEL_VSPD_V3U (0x1c << 8)
/* RZ/G2L SoCs have no version register, So use 0x80 as the model version */
#define VI6_IP_VERSION_MODEL_VSPD_RZG2L (0x80 << 8)
#define VI6_IP_VERSION_SOC_MASK (0xff << 0) #define VI6_IP_VERSION_SOC_MASK (0xff << 0)
#define VI6_IP_VERSION_SOC_H2 (0x01 << 0) #define VI6_IP_VERSION_SOC_H2 (0x01 << 0)
...@@ -780,6 +782,8 @@ ...@@ -780,6 +782,8 @@
#define VI6_IP_VERSION_SOC_M3N (0x04 << 0) #define VI6_IP_VERSION_SOC_M3N (0x04 << 0)
#define VI6_IP_VERSION_SOC_E3 (0x04 << 0) #define VI6_IP_VERSION_SOC_E3 (0x04 << 0)
#define VI6_IP_VERSION_SOC_V3U (0x05 << 0) #define VI6_IP_VERSION_SOC_V3U (0x05 << 0)
/* RZ/G2L SoCs have no version register, So use 0x80 for SoC Identification */
#define VI6_IP_VERSION_SOC_RZG2L (0x80 << 0)
#define VI6_IP_VERSION_VSP_SW (0xfffe << 16) /* SW VSP version */ #define VI6_IP_VERSION_VSP_SW (0xfffe << 16) /* SW VSP version */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment