Commit be11096d authored by Vladimir Zapolskiy's avatar Vladimir Zapolskiy Committed by Mauro Carvalho Chehab

media: camss: Collect information about a number of lite VFEs

VFE lite IPs are found on CAMSS with TITAN_TOP power domains, and in
some aspects these types of VFEs are different, in particular there
is no need to enable VFE power domains to operate over VFE lite IPs.
Signed-off-by: default avatarVladimir Zapolskiy <vladimir.zapolskiy@linaro.org>
Reviewed-by: default avatarRobert Foss <robert.foss@linaro.org>
Signed-off-by: default avatarHans Verkuil <hverkuil-cisco@xs4all.nl>
Signed-off-by: default avatarMauro Carvalho Chehab <mchehab@kernel.org>
parent 3d658980
...@@ -1170,7 +1170,7 @@ static int camss_init_subdevices(struct camss *camss) ...@@ -1170,7 +1170,7 @@ static int camss_init_subdevices(struct camss *camss)
} }
/* note: SM8250 requires VFE to be initialized before CSID */ /* note: SM8250 requires VFE to be initialized before CSID */
for (i = 0; i < camss->vfe_num; i++) { for (i = 0; i < camss->vfe_num + camss->vfe_lite_num; i++) {
ret = msm_vfe_subdev_init(camss, &camss->vfe[i], ret = msm_vfe_subdev_init(camss, &camss->vfe[i],
&vfe_res[i], i); &vfe_res[i], i);
if (ret < 0) { if (ret < 0) {
...@@ -1242,7 +1242,7 @@ static int camss_register_entities(struct camss *camss) ...@@ -1242,7 +1242,7 @@ static int camss_register_entities(struct camss *camss)
goto err_reg_ispif; goto err_reg_ispif;
} }
for (i = 0; i < camss->vfe_num; i++) { for (i = 0; i < camss->vfe_num + camss->vfe_lite_num; i++) {
ret = msm_vfe_register_entities(&camss->vfe[i], ret = msm_vfe_register_entities(&camss->vfe[i],
&camss->v4l2_dev); &camss->v4l2_dev);
if (ret < 0) { if (ret < 0) {
...@@ -1314,7 +1314,7 @@ static int camss_register_entities(struct camss *camss) ...@@ -1314,7 +1314,7 @@ static int camss_register_entities(struct camss *camss)
} }
} else { } else {
for (i = 0; i < camss->csid_num; i++) for (i = 0; i < camss->csid_num; i++)
for (k = 0; k < camss->vfe_num; k++) for (k = 0; k < camss->vfe_num + camss->vfe_lite_num; k++)
for (j = 0; j < camss->vfe[k].line_num; j++) { for (j = 0; j < camss->vfe[k].line_num; j++) {
struct v4l2_subdev *csid = &camss->csid[i].subdev; struct v4l2_subdev *csid = &camss->csid[i].subdev;
struct v4l2_subdev *vfe = &camss->vfe[k].line[j].subdev; struct v4l2_subdev *vfe = &camss->vfe[k].line[j].subdev;
...@@ -1338,7 +1338,7 @@ static int camss_register_entities(struct camss *camss) ...@@ -1338,7 +1338,7 @@ static int camss_register_entities(struct camss *camss)
return 0; return 0;
err_link: err_link:
i = camss->vfe_num; i = camss->vfe_num + camss->vfe_lite_num;
err_reg_vfe: err_reg_vfe:
for (i--; i >= 0; i--) for (i--; i >= 0; i--)
msm_vfe_unregister_entities(&camss->vfe[i]); msm_vfe_unregister_entities(&camss->vfe[i]);
...@@ -1377,7 +1377,7 @@ static void camss_unregister_entities(struct camss *camss) ...@@ -1377,7 +1377,7 @@ static void camss_unregister_entities(struct camss *camss)
msm_ispif_unregister_entities(camss->ispif); msm_ispif_unregister_entities(camss->ispif);
for (i = 0; i < camss->vfe_num; i++) for (i = 0; i < camss->vfe_num + camss->vfe_lite_num; i++)
msm_vfe_unregister_entities(&camss->vfe[i]); msm_vfe_unregister_entities(&camss->vfe[i]);
} }
...@@ -1579,13 +1579,15 @@ static int camss_probe(struct platform_device *pdev) ...@@ -1579,13 +1579,15 @@ static int camss_probe(struct platform_device *pdev)
camss->version = CAMSS_845; camss->version = CAMSS_845;
camss->csiphy_num = 4; camss->csiphy_num = 4;
camss->csid_num = 3; camss->csid_num = 3;
camss->vfe_num = 3; camss->vfe_num = 2;
camss->vfe_lite_num = 1;
} else if (of_device_is_compatible(dev->of_node, } else if (of_device_is_compatible(dev->of_node,
"qcom,sm8250-camss")) { "qcom,sm8250-camss")) {
camss->version = CAMSS_8250; camss->version = CAMSS_8250;
camss->csiphy_num = 6; camss->csiphy_num = 6;
camss->csid_num = 4; camss->csid_num = 4;
camss->vfe_num = 4; camss->vfe_num = 2;
camss->vfe_lite_num = 2;
} else { } else {
return -EINVAL; return -EINVAL;
} }
...@@ -1607,8 +1609,8 @@ static int camss_probe(struct platform_device *pdev) ...@@ -1607,8 +1609,8 @@ static int camss_probe(struct platform_device *pdev)
return -ENOMEM; return -ENOMEM;
} }
camss->vfe = devm_kcalloc(dev, camss->vfe_num, sizeof(*camss->vfe), camss->vfe = devm_kcalloc(dev, camss->vfe_num + camss->vfe_lite_num,
GFP_KERNEL); sizeof(*camss->vfe), GFP_KERNEL);
if (!camss->vfe) if (!camss->vfe)
return -ENOMEM; return -ENOMEM;
......
...@@ -97,6 +97,7 @@ struct camss { ...@@ -97,6 +97,7 @@ struct camss {
struct csid_device *csid; struct csid_device *csid;
struct ispif_device *ispif; struct ispif_device *ispif;
int vfe_num; int vfe_num;
int vfe_lite_num;
struct vfe_device *vfe; struct vfe_device *vfe;
atomic_t ref_count; atomic_t ref_count;
int genpd_num; int genpd_num;
......
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