Commit 4d728fd4 authored by Biju Das's avatar Biju Das Committed by Mauro Carvalho Chehab

media: renesas: vsp1: Add VSP1_HAS_NON_ZERO_LBA feature bit

As per HW manual V3M and RZ/G2L SoCs has nonzero LIF buffer
attributes. So, introduce a feature bit for handling the same.

This patch also adds separate device info structure for V3M and V3H
SoCs, as both these SoCs share the same model ID, but V3H does not
have VSP1_HAS_NON_ZERO_LBA feature bit.
Signed-off-by: default avatarBiju Das <biju.das.jz@bp.renesas.com>
Signed-off-by: default avatarLaurent Pinchart <laurent.pinchart+renesas@ideasonboard.com>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@kernel.org>
parent 9c639027
...@@ -55,6 +55,7 @@ struct vsp1_uif; ...@@ -55,6 +55,7 @@ struct vsp1_uif;
#define VSP1_HAS_HGT BIT(8) #define VSP1_HAS_HGT BIT(8)
#define VSP1_HAS_BRS BIT(9) #define VSP1_HAS_BRS BIT(9)
#define VSP1_HAS_EXT_DL BIT(10) #define VSP1_HAS_EXT_DL BIT(10)
#define VSP1_HAS_NON_ZERO_LBA BIT(11)
struct vsp1_device_info { struct vsp1_device_info {
u32 version; u32 version;
......
...@@ -788,6 +788,7 @@ static const struct vsp1_device_info vsp1_device_infos[] = { ...@@ -788,6 +788,7 @@ static const struct vsp1_device_info vsp1_device_infos[] = {
}, { }, {
.version = VI6_IP_VERSION_MODEL_VSPD_V3, .version = VI6_IP_VERSION_MODEL_VSPD_V3,
.model = "VSP2-D", .model = "VSP2-D",
.soc = VI6_IP_VERSION_SOC_V3H,
.gen = 3, .gen = 3,
.features = VSP1_HAS_BRS | VSP1_HAS_BRU, .features = VSP1_HAS_BRS | VSP1_HAS_BRU,
.lif_count = 1, .lif_count = 1,
...@@ -795,6 +796,17 @@ static const struct vsp1_device_info vsp1_device_infos[] = { ...@@ -795,6 +796,17 @@ static const struct vsp1_device_info vsp1_device_infos[] = {
.uif_count = 1, .uif_count = 1,
.wpf_count = 1, .wpf_count = 1,
.num_bru_inputs = 5, .num_bru_inputs = 5,
}, {
.version = VI6_IP_VERSION_MODEL_VSPD_V3,
.model = "VSP2-D",
.soc = VI6_IP_VERSION_SOC_V3M,
.gen = 3,
.features = VSP1_HAS_BRS | VSP1_HAS_BRU | VSP1_HAS_NON_ZERO_LBA,
.lif_count = 1,
.rpf_count = 5,
.uif_count = 1,
.wpf_count = 1,
.num_bru_inputs = 5,
}, { }, {
.version = VI6_IP_VERSION_MODEL_VSPDL_GEN3, .version = VI6_IP_VERSION_MODEL_VSPDL_GEN3,
.model = "VSP2-DL", .model = "VSP2-DL",
...@@ -822,6 +834,8 @@ static const struct vsp1_device_info *vsp1_lookup_info(struct vsp1_device *vsp1) ...@@ -822,6 +834,8 @@ 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;
unsigned int i; unsigned int i;
u32 model;
u32 soc;
/* /*
* Try the info stored in match data first for devices that don't have * Try the info stored in match data first for devices that don't have
...@@ -834,11 +848,13 @@ static const struct vsp1_device_info *vsp1_lookup_info(struct vsp1_device *vsp1) ...@@ -834,11 +848,13 @@ static const struct vsp1_device_info *vsp1_lookup_info(struct vsp1_device *vsp1)
} }
vsp1->version = vsp1_read(vsp1, VI6_IP_VERSION); vsp1->version = vsp1_read(vsp1, VI6_IP_VERSION);
model = vsp1->version & VI6_IP_VERSION_MODEL_MASK;
soc = vsp1->version & VI6_IP_VERSION_SOC_MASK;
for (i = 0; i < ARRAY_SIZE(vsp1_device_infos); ++i) { for (i = 0; i < ARRAY_SIZE(vsp1_device_infos); ++i) {
info = &vsp1_device_infos[i]; info = &vsp1_device_infos[i];
if ((vsp1->version & VI6_IP_VERSION_MODEL_MASK) == info->version) if (model == info->version && (!info->soc || soc == info->soc))
return info; return info;
} }
......
...@@ -135,8 +135,7 @@ static void lif_configure_stream(struct vsp1_entity *entity, ...@@ -135,8 +135,7 @@ static void lif_configure_stream(struct vsp1_entity *entity,
* may appear on the output). The value required by the manual is not * may appear on the output). The value required by the manual is not
* explained but is likely a buffer size or threshold. * explained but is likely a buffer size or threshold.
*/ */
if ((entity->vsp1->version & VI6_IP_VERSION_MASK) == if (vsp1_feature(entity->vsp1, VSP1_HAS_NON_ZERO_LBA))
(VI6_IP_VERSION_MODEL_VSPD_V3 | VI6_IP_VERSION_SOC_V3M))
vsp1_lif_write(lif, dlb, VI6_LIF_LBA, vsp1_lif_write(lif, dlb, VI6_LIF_LBA,
VI6_LIF_LBA_LBA0 | VI6_LIF_LBA_LBA0 |
(1536 << VI6_LIF_LBA_LBA1_SHIFT)); (1536 << VI6_LIF_LBA_LBA1_SHIFT));
......
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