This is an automatic generated email to let you know that the following patch 
were queued:

Subject: media: ti-vpe: cal: Iterate over correct number of CAMERARX instances
Author:  Laurent Pinchart <[email protected]>
Date:    Mon Dec 7 00:53:35 2020 +0100

When performing operations on all CAMERARX instances, code usually
iterates over all cal->phy[] entries and skips the NULL pointers. The
number of available CAMERARX instances is however available through
cal->data->num_csi2_phy. Use it instead.

Signed-off-by: Laurent Pinchart <[email protected]>
Reviewed-by: Benoit Parrot <[email protected]>
Signed-off-by: Hans Verkuil <[email protected]>
Signed-off-by: Mauro Carvalho Chehab <[email protected]>

 drivers/media/platform/ti-vpe/cal.c | 20 +++++++++-----------
 1 file changed, 9 insertions(+), 11 deletions(-)

---

diff --git a/drivers/media/platform/ti-vpe/cal.c 
b/drivers/media/platform/ti-vpe/cal.c
index b9ee535513e8..5d073d9cd8b5 100644
--- a/drivers/media/platform/ti-vpe/cal.c
+++ b/drivers/media/platform/ti-vpe/cal.c
@@ -263,12 +263,9 @@ void cal_quickdump_regs(struct cal_dev *cal)
                       (__force const void *)cal->base,
                       resource_size(cal->res), false);
 
-       for (i = 0; i < ARRAY_SIZE(cal->phy); ++i) {
+       for (i = 0; i < cal->data->num_csi2_phy; ++i) {
                struct cal_camerarx *phy = cal->phy[i];
 
-               if (!phy)
-                       continue;
-
                cal_info(cal, "CSI2 Core %u Registers @ %pa:\n", i,
                         &phy->res->start);
                print_hex_dump(KERN_INFO, "", DUMP_PREFIX_OFFSET, 16, 4,
@@ -464,7 +461,7 @@ static irqreturn_t cal_irq(int irq_cal, void *data)
                if (status & CAL_HL_IRQ_OCPO_ERR_MASK)
                        dev_err_ratelimited(cal->dev, "OCPO ERROR\n");
 
-               for (i = 0; i < CAL_NUM_CSI2_PORTS; ++i) {
+               for (i = 0; i < cal->data->num_csi2_phy; ++i) {
                        if (status & CAL_HL_IRQ_CIO_MASK(i)) {
                                u32 cio_stat = cal_read(cal,
                                                        
CAL_CSI2_COMPLEXIO_IRQSTATUS(i));
@@ -608,13 +605,13 @@ static int cal_async_notifier_register(struct cal_dev 
*cal)
        v4l2_async_notifier_init(&cal->notifier);
        cal->notifier.ops = &cal_async_notifier_ops;
 
-       for (i = 0; i < ARRAY_SIZE(cal->phy); ++i) {
+       for (i = 0; i < cal->data->num_csi2_phy; ++i) {
                struct cal_camerarx *phy = cal->phy[i];
                struct cal_v4l2_async_subdev *casd;
                struct v4l2_async_subdev *asd;
                struct fwnode_handle *fwnode;
 
-               if (!phy || !phy->sensor_node)
+               if (!phy->sensor_node)
                        continue;
 
                fwnode = of_fwnode_handle(phy->sensor_node);
@@ -997,7 +994,7 @@ error_context:
        }
 
 error_camerarx:
-       for (i = 0; i < ARRAY_SIZE(cal->phy); i++)
+       for (i = 0; i < cal->data->num_csi2_phy; i++)
                cal_camerarx_destroy(cal->phy[i]);
 
        cal_media_cleanup(cal);
@@ -1026,7 +1023,7 @@ static int cal_remove(struct platform_device *pdev)
 
        cal_media_cleanup(cal);
 
-       for (i = 0; i < ARRAY_SIZE(cal->phy); i++)
+       for (i = 0; i < cal->data->num_csi2_phy; i++)
                cal_camerarx_destroy(cal->phy[i]);
 
        pm_runtime_put_sync(&pdev->dev);
@@ -1038,14 +1035,15 @@ static int cal_remove(struct platform_device *pdev)
 static int cal_runtime_resume(struct device *dev)
 {
        struct cal_dev *cal = dev_get_drvdata(dev);
+       unsigned int i;
 
        if (cal->data->flags & DRA72_CAL_PRE_ES2_LDO_DISABLE) {
                /*
                 * Apply errata on both port everytime we (re-)enable
                 * the clock
                 */
-               cal_camerarx_i913_errata(cal->phy[0]);
-               cal_camerarx_i913_errata(cal->phy[1]);
+               for (i = 0; i < cal->data->num_csi2_phy; i++)
+                       cal_camerarx_i913_errata(cal->phy[i]);
        }
 
        return 0;

_______________________________________________
linuxtv-commits mailing list
[email protected]
https://www.linuxtv.org/cgi-bin/mailman/listinfo/linuxtv-commits

Reply via email to