Soc: soundwire: Update hw_ctl on HCLK at bootup
For soundwire version 1.6, HCLK remove HW controlled
at bootup before soundwire frame generation status check.
Change-Id: Idc2420d086261766ea4e79f69320f12c4d6b2259
Signed-off-by: Laxminath Kasam <lkasam@codeaurora.org>
diff --git a/soc/swr-mstr-ctrl.c b/soc/swr-mstr-ctrl.c
index 981060c..1f61bad 100644
--- a/soc/swr-mstr-ctrl.c
+++ b/soc/swr-mstr-ctrl.c
@@ -2337,7 +2337,7 @@
static int swrm_master_init(struct swr_mstr_ctrl *swrm)
{
- int ret = 0;
+ int ret = 0, i = 0;
u32 val;
u8 row_ctrl = SWR_ROW_50;
u8 col_ctrl = SWR_MIN_COL;
@@ -2348,6 +2348,18 @@
u32 temp = 0;
int len = 0;
+ /* SW workaround to gate hw_ctl for SWR version >=1.6 */
+ if (swrm->version >= SWRM_VERSION_1_6) {
+ if (swrm->swrm_hctl_reg) {
+ temp = ioread32(swrm->swrm_hctl_reg);
+ temp &= 0xFFFFFFFD;
+ iowrite32(temp, swrm->swrm_hctl_reg);
+ usleep_range(500, 505);
+ temp = ioread32(swrm->swrm_hctl_reg);
+ dev_dbg(swrm->dev, "%s: hctl_reg val: 0x%x\n",
+ __func__, temp);
+ }
+ }
ssp_period = swrm_get_ssp_period(swrm, SWRM_ROW_50,
SWRM_COL_02, SWRM_FRAME_SYNC_SEL);
dev_dbg(swrm->dev, "%s: ssp_period: %d\n", __func__, ssp_period);
@@ -2403,6 +2415,13 @@
dev_err(swrm->dev,
"%s: swr link failed to connect\n",
__func__);
+ for (i = 0; i < len; i++) {
+ usleep_range(50, 55);
+ dev_err(swrm->dev,
+ "%s:reg:0x%x val:0x%x\n",
+ __func__,
+ reg[i], swr_master_read(swrm, reg[i]));
+ }
return -EINVAL;
}
/*
@@ -2415,14 +2434,6 @@
(swr_master_read(swrm,
SWRM_CMD_FIFO_CFG_ADDR) | 0x80000000));
- /* SW workaround to gate hw_ctl for SWR version >=1.6 */
- if (swrm->version >= SWRM_VERSION_1_6) {
- if (swrm->swrm_hctl_reg) {
- temp = ioread32(swrm->swrm_hctl_reg);
- temp &= 0xFFFFFFFD;
- iowrite32(temp, swrm->swrm_hctl_reg);
- }
- }
return ret;
}
@@ -2755,6 +2766,7 @@
"%s: Error in master Initialization , err %d\n",
__func__, ret);
mutex_unlock(&swrm->mlock);
+ ret = -EPROBE_DEFER;
goto err_mstr_init_fail;
}
@@ -2803,11 +2815,17 @@
err_mstr_init_fail:
swr_unregister_master(&swrm->master);
err_mstr_fail:
- if (swrm->reg_irq)
+ if (swrm->reg_irq) {
swrm->reg_irq(swrm->handle, swr_mstr_interrupt,
swrm, SWR_IRQ_FREE);
- else if (swrm->irq)
+ } else if (swrm->irq) {
free_irq(swrm->irq, swrm);
+ irqd_set_trigger_type(
+ irq_get_irq_data(swrm->irq),
+ IRQ_TYPE_NONE);
+ }
+ if (swrm->swr_irq_wakeup_capable)
+ irq_set_irq_wake(swrm->irq, 0);
err_irq_fail:
mutex_destroy(&swrm->irq_lock);
mutex_destroy(&swrm->mlock);
@@ -2827,13 +2845,17 @@
{
struct swr_mstr_ctrl *swrm = platform_get_drvdata(pdev);
- if (swrm->reg_irq)
+ if (swrm->reg_irq) {
swrm->reg_irq(swrm->handle, swr_mstr_interrupt,
swrm, SWR_IRQ_FREE);
- else if (swrm->irq)
+ } else if (swrm->irq) {
free_irq(swrm->irq, swrm);
- else if (swrm->wake_irq > 0)
+ irqd_set_trigger_type(
+ irq_get_irq_data(swrm->irq),
+ IRQ_TYPE_NONE);
+ } else if (swrm->wake_irq > 0) {
free_irq(swrm->wake_irq, swrm);
+ }
if (swrm->swr_irq_wakeup_capable)
irq_set_irq_wake(swrm->irq, 0);
cancel_work_sync(&swrm->wakeup_work);