soundwire: qcom: wait for enumeration to be complete in probe
authorSrinivas Kandagatla <srinivas.kandagatla@linaro.org>
Tue, 30 Mar 2021 14:47:19 +0000 (15:47 +0100)
committerVinod Koul <vkoul@kernel.org>
Tue, 30 Mar 2021 17:25:07 +0000 (22:55 +0530)
Signed-off-by: Srinivas Kandagatla <srinivas.kandagatla@linaro.org>
Reviewed-by: Pierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
Link: https://lore.kernel.org/r/20210330144719.13284-10-srinivas.kandagatla@linaro.org
Signed-off-by: Vinod Koul <vkoul@kernel.org>
drivers/soundwire/qcom.c

index b1dbaf8263e5b70f878e4af64fa718d713aa2045..b08ecb9b418c6be183bcdd603dd629fe109a17ab 100644 (file)
@@ -123,6 +123,7 @@ struct qcom_swrm_ctrl {
        struct regmap *regmap;
        void __iomem *mmio;
        struct completion broadcast;
+       struct completion enumeration;
        struct work_struct slave_work;
        /* Port alloc/free lock */
        struct mutex port_lock;
@@ -418,6 +419,7 @@ static int qcom_swrm_enumerate(struct sdw_bus *bus)
                }
        }
 
+       complete(&ctrl->enumeration);
        return 0;
 }
 
@@ -1139,6 +1141,7 @@ static int qcom_swrm_probe(struct platform_device *pdev)
        dev_set_drvdata(&pdev->dev, ctrl);
        mutex_init(&ctrl->port_lock);
        init_completion(&ctrl->broadcast);
+       init_completion(&ctrl->enumeration);
 
        ctrl->bus.ops = &qcom_swrm_ops;
        ctrl->bus.port_ops = &qcom_swrm_port_ops;
@@ -1185,6 +1188,8 @@ static int qcom_swrm_probe(struct platform_device *pdev)
        }
 
        qcom_swrm_init(ctrl);
+       wait_for_completion_timeout(&ctrl->enumeration,
+                                   msecs_to_jiffies(TIMEOUT_MS));
        ret = qcom_swrm_register_dais(ctrl);
        if (ret)
                goto err_master_add;