Loading soc/swr-mstr-ctrl.c +9 −2 Original line number Diff line number Diff line Loading @@ -493,9 +493,9 @@ static int swrm_cmd_fifo_wr_cmd(struct swr_mstr_ctrl *swrm, u8 cmd_data, dev_dbg(swrm->dev, "%s: reg: 0x%x, cmd_id: 0x%x,wcmd_id: 0x%x, \ dev_num: 0x%x, cmd_data: 0x%x\n", __func__, reg_addr, cmd_id, swrm->wcmd_id,dev_addr, cmd_data); swr_master_write(swrm, SWRM_CMD_FIFO_WR_CMD, val); /* wait for FIFO WR command to complete to avoid overflow */ usleep_range(250, 255); swr_master_write(swrm, SWRM_CMD_FIFO_WR_CMD, val); if (cmd_id == 0xF) { /* * sleep for 10ms for MSM soundwire variant to allow broadcast Loading Loading @@ -1430,12 +1430,17 @@ static irqreturn_t swrm_wakeup_interrupt(int irq, void *dev) return ret; } mutex_unlock(&swrm->devlock); if (unlikely(swrm_lock_sleep(swrm) == false)) { dev_err(swrm->dev, "%s Failed to hold suspend\n", __func__); goto exit; } if (swrm->wake_irq > 0) disable_irq_nosync(swrm->wake_irq); pm_runtime_get_sync(swrm->dev); pm_runtime_mark_last_busy(swrm->dev); pm_runtime_put_autosuspend(swrm->dev); swrm_unlock_sleep(swrm); exit: return ret; } Loading Loading @@ -2042,6 +2047,7 @@ static int swrm_runtime_resume(struct device *dev) if (swrm_clk_request(swrm, true)) goto exit; if (!swrm->clk_stop_mode0_supp || swrm->state == SWR_MSTR_SSR) { enable_bank_switch(swrm, 0, SWR_ROW_50, SWR_MIN_COL); list_for_each_entry(swr_dev, &mstr->devices, dev_list) { ret = swr_device_up(swr_dev); if (ret) { Loading Loading @@ -2096,6 +2102,7 @@ static int swrm_runtime_suspend(struct device *dev) goto exit; } if (!swrm->clk_stop_mode0_supp || swrm->state == SWR_MSTR_SSR) { enable_bank_switch(swrm, 0, SWR_ROW_50, SWR_MIN_COL); swrm_clk_pause(swrm); swr_master_write(swrm, SWRM_COMP_CFG_ADDR, 0x00); list_for_each_entry(swr_dev, &mstr->devices, dev_list) { Loading Loading
soc/swr-mstr-ctrl.c +9 −2 Original line number Diff line number Diff line Loading @@ -493,9 +493,9 @@ static int swrm_cmd_fifo_wr_cmd(struct swr_mstr_ctrl *swrm, u8 cmd_data, dev_dbg(swrm->dev, "%s: reg: 0x%x, cmd_id: 0x%x,wcmd_id: 0x%x, \ dev_num: 0x%x, cmd_data: 0x%x\n", __func__, reg_addr, cmd_id, swrm->wcmd_id,dev_addr, cmd_data); swr_master_write(swrm, SWRM_CMD_FIFO_WR_CMD, val); /* wait for FIFO WR command to complete to avoid overflow */ usleep_range(250, 255); swr_master_write(swrm, SWRM_CMD_FIFO_WR_CMD, val); if (cmd_id == 0xF) { /* * sleep for 10ms for MSM soundwire variant to allow broadcast Loading Loading @@ -1430,12 +1430,17 @@ static irqreturn_t swrm_wakeup_interrupt(int irq, void *dev) return ret; } mutex_unlock(&swrm->devlock); if (unlikely(swrm_lock_sleep(swrm) == false)) { dev_err(swrm->dev, "%s Failed to hold suspend\n", __func__); goto exit; } if (swrm->wake_irq > 0) disable_irq_nosync(swrm->wake_irq); pm_runtime_get_sync(swrm->dev); pm_runtime_mark_last_busy(swrm->dev); pm_runtime_put_autosuspend(swrm->dev); swrm_unlock_sleep(swrm); exit: return ret; } Loading Loading @@ -2042,6 +2047,7 @@ static int swrm_runtime_resume(struct device *dev) if (swrm_clk_request(swrm, true)) goto exit; if (!swrm->clk_stop_mode0_supp || swrm->state == SWR_MSTR_SSR) { enable_bank_switch(swrm, 0, SWR_ROW_50, SWR_MIN_COL); list_for_each_entry(swr_dev, &mstr->devices, dev_list) { ret = swr_device_up(swr_dev); if (ret) { Loading Loading @@ -2096,6 +2102,7 @@ static int swrm_runtime_suspend(struct device *dev) goto exit; } if (!swrm->clk_stop_mode0_supp || swrm->state == SWR_MSTR_SSR) { enable_bank_switch(swrm, 0, SWR_ROW_50, SWR_MIN_COL); swrm_clk_pause(swrm); swr_master_write(swrm, SWRM_COMP_CFG_ADDR, 0x00); list_for_each_entry(swr_dev, &mstr->devices, dev_list) { Loading