mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-09 22:50:41 +00:00
soundwire: cadence: split access to IP_MCP_CONTROL fields
The latest Cadence IP splits the MCP_CONTROL fields in two registers: MCP_CONTROL and IP_MCP_CONTROL. Rename the relevant fields and change the access methods used for those fields. For existing solutions, this is an iso-functionality change. Signed-off-by: Pierre-Louis Bossart <pierre-louis.bossart@linux.intel.com> Reviewed-by: Rander Wang <rander.wang@intel.com> Signed-off-by: Bard Liao <yung-chuan.liao@linux.intel.com> Link: https://lore.kernel.org/r/20230314015410.487311-15-yung-chuan.liao@linux.intel.com Signed-off-by: Vinod Koul <vkoul@kernel.org>
This commit is contained in:
parent
c5753714fa
commit
4dc953bcad
@ -41,15 +41,18 @@ MODULE_PARM_DESC(cdns_mcp_int_mask, "Cadence MCP IntMask");
|
|||||||
|
|
||||||
#define CDNS_MCP_CONTROL 0x4
|
#define CDNS_MCP_CONTROL 0x4
|
||||||
|
|
||||||
#define CDNS_MCP_CONTROL_RST_DELAY GENMASK(10, 8)
|
|
||||||
#define CDNS_MCP_CONTROL_CMD_RST BIT(7)
|
#define CDNS_MCP_CONTROL_CMD_RST BIT(7)
|
||||||
#define CDNS_MCP_CONTROL_SOFT_RST BIT(6)
|
#define CDNS_MCP_CONTROL_SOFT_RST BIT(6)
|
||||||
#define CDNS_MCP_CONTROL_SW_RST BIT(5)
|
|
||||||
#define CDNS_MCP_CONTROL_HW_RST BIT(4)
|
#define CDNS_MCP_CONTROL_HW_RST BIT(4)
|
||||||
#define CDNS_MCP_CONTROL_CLK_PAUSE BIT(3)
|
|
||||||
#define CDNS_MCP_CONTROL_CLK_STOP_CLR BIT(2)
|
#define CDNS_MCP_CONTROL_CLK_STOP_CLR BIT(2)
|
||||||
#define CDNS_MCP_CONTROL_CMD_ACCEPT BIT(1)
|
|
||||||
#define CDNS_MCP_CONTROL_BLOCK_WAKEUP BIT(0)
|
#define CDNS_IP_MCP_CONTROL 0x4 /* IP offset added at run-time */
|
||||||
|
|
||||||
|
#define CDNS_IP_MCP_CONTROL_RST_DELAY GENMASK(10, 8)
|
||||||
|
#define CDNS_IP_MCP_CONTROL_SW_RST BIT(5)
|
||||||
|
#define CDNS_IP_MCP_CONTROL_CLK_PAUSE BIT(3)
|
||||||
|
#define CDNS_IP_MCP_CONTROL_CMD_ACCEPT BIT(1)
|
||||||
|
#define CDNS_IP_MCP_CONTROL_BLOCK_WAKEUP BIT(0)
|
||||||
|
|
||||||
#define CDNS_MCP_CMDCTRL 0x8
|
#define CDNS_MCP_CMDCTRL 0x8
|
||||||
|
|
||||||
@ -1050,6 +1053,7 @@ update_status:
|
|||||||
void sdw_cdns_check_self_clearing_bits(struct sdw_cdns *cdns, const char *string,
|
void sdw_cdns_check_self_clearing_bits(struct sdw_cdns *cdns, const char *string,
|
||||||
bool initial_delay, int reset_iterations)
|
bool initial_delay, int reset_iterations)
|
||||||
{
|
{
|
||||||
|
u32 ip_mcp_control;
|
||||||
u32 mcp_control;
|
u32 mcp_control;
|
||||||
u32 mcp_config_update;
|
u32 mcp_config_update;
|
||||||
int i;
|
int i;
|
||||||
@ -1057,6 +1061,12 @@ void sdw_cdns_check_self_clearing_bits(struct sdw_cdns *cdns, const char *string
|
|||||||
if (initial_delay)
|
if (initial_delay)
|
||||||
usleep_range(1000, 1500);
|
usleep_range(1000, 1500);
|
||||||
|
|
||||||
|
ip_mcp_control = cdns_ip_readl(cdns, CDNS_IP_MCP_CONTROL);
|
||||||
|
|
||||||
|
/* the following bits should be cleared immediately */
|
||||||
|
if (ip_mcp_control & CDNS_IP_MCP_CONTROL_SW_RST)
|
||||||
|
dev_err(cdns->dev, "%s failed: IP_MCP_CONTROL_SW_RST is not cleared\n", string);
|
||||||
|
|
||||||
mcp_control = cdns_readl(cdns, CDNS_MCP_CONTROL);
|
mcp_control = cdns_readl(cdns, CDNS_MCP_CONTROL);
|
||||||
|
|
||||||
/* the following bits should be cleared immediately */
|
/* the following bits should be cleared immediately */
|
||||||
@ -1064,10 +1074,9 @@ void sdw_cdns_check_self_clearing_bits(struct sdw_cdns *cdns, const char *string
|
|||||||
dev_err(cdns->dev, "%s failed: MCP_CONTROL_CMD_RST is not cleared\n", string);
|
dev_err(cdns->dev, "%s failed: MCP_CONTROL_CMD_RST is not cleared\n", string);
|
||||||
if (mcp_control & CDNS_MCP_CONTROL_SOFT_RST)
|
if (mcp_control & CDNS_MCP_CONTROL_SOFT_RST)
|
||||||
dev_err(cdns->dev, "%s failed: MCP_CONTROL_SOFT_RST is not cleared\n", string);
|
dev_err(cdns->dev, "%s failed: MCP_CONTROL_SOFT_RST is not cleared\n", string);
|
||||||
if (mcp_control & CDNS_MCP_CONTROL_SW_RST)
|
|
||||||
dev_err(cdns->dev, "%s failed: MCP_CONTROL_SW_RST is not cleared\n", string);
|
|
||||||
if (mcp_control & CDNS_MCP_CONTROL_CLK_STOP_CLR)
|
if (mcp_control & CDNS_MCP_CONTROL_CLK_STOP_CLR)
|
||||||
dev_err(cdns->dev, "%s failed: MCP_CONTROL_CLK_STOP_CLR is not cleared\n", string);
|
dev_err(cdns->dev, "%s failed: MCP_CONTROL_CLK_STOP_CLR is not cleared\n", string);
|
||||||
|
|
||||||
mcp_config_update = cdns_readl(cdns, CDNS_MCP_CONFIG_UPDATE);
|
mcp_config_update = cdns_readl(cdns, CDNS_MCP_CONFIG_UPDATE);
|
||||||
if (mcp_config_update & CDNS_MCP_CONFIG_UPDATE_BIT)
|
if (mcp_config_update & CDNS_MCP_CONFIG_UPDATE_BIT)
|
||||||
dev_err(cdns->dev, "%s failed: MCP_CONFIG_UPDATE_BIT is not cleared\n", string);
|
dev_err(cdns->dev, "%s failed: MCP_CONFIG_UPDATE_BIT is not cleared\n", string);
|
||||||
@ -1344,8 +1353,8 @@ int sdw_cdns_init(struct sdw_cdns *cdns)
|
|||||||
CDNS_MCP_CONTROL_CMD_RST);
|
CDNS_MCP_CONTROL_CMD_RST);
|
||||||
|
|
||||||
/* Set cmd accept mode */
|
/* Set cmd accept mode */
|
||||||
cdns_updatel(cdns, CDNS_MCP_CONTROL, CDNS_MCP_CONTROL_CMD_ACCEPT,
|
cdns_ip_updatel(cdns, CDNS_IP_MCP_CONTROL, CDNS_IP_MCP_CONTROL_CMD_ACCEPT,
|
||||||
CDNS_MCP_CONTROL_CMD_ACCEPT);
|
CDNS_IP_MCP_CONTROL_CMD_ACCEPT);
|
||||||
|
|
||||||
/* Configure mcp config */
|
/* Configure mcp config */
|
||||||
val = cdns_readl(cdns, CDNS_MCP_CONFIG);
|
val = cdns_readl(cdns, CDNS_MCP_CONFIG);
|
||||||
@ -1606,9 +1615,9 @@ int sdw_cdns_clock_stop(struct sdw_cdns *cdns, bool block_wake)
|
|||||||
* in clock stop state
|
* in clock stop state
|
||||||
*/
|
*/
|
||||||
if (block_wake)
|
if (block_wake)
|
||||||
cdns_updatel(cdns, CDNS_MCP_CONTROL,
|
cdns_ip_updatel(cdns, CDNS_IP_MCP_CONTROL,
|
||||||
CDNS_MCP_CONTROL_BLOCK_WAKEUP,
|
CDNS_IP_MCP_CONTROL_BLOCK_WAKEUP,
|
||||||
CDNS_MCP_CONTROL_BLOCK_WAKEUP);
|
CDNS_IP_MCP_CONTROL_BLOCK_WAKEUP);
|
||||||
|
|
||||||
list_for_each_entry(slave, &cdns->bus.slaves, node) {
|
list_for_each_entry(slave, &cdns->bus.slaves, node) {
|
||||||
if (slave->status == SDW_SLAVE_ATTACHED ||
|
if (slave->status == SDW_SLAVE_ATTACHED ||
|
||||||
@ -1681,11 +1690,11 @@ int sdw_cdns_clock_restart(struct sdw_cdns *cdns, bool bus_reset)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
cdns_updatel(cdns, CDNS_MCP_CONTROL,
|
cdns_ip_updatel(cdns, CDNS_IP_MCP_CONTROL,
|
||||||
CDNS_MCP_CONTROL_BLOCK_WAKEUP, 0);
|
CDNS_IP_MCP_CONTROL_BLOCK_WAKEUP, 0);
|
||||||
|
|
||||||
cdns_updatel(cdns, CDNS_MCP_CONTROL, CDNS_MCP_CONTROL_CMD_ACCEPT,
|
cdns_ip_updatel(cdns, CDNS_IP_MCP_CONTROL, CDNS_IP_MCP_CONTROL_CMD_ACCEPT,
|
||||||
CDNS_MCP_CONTROL_CMD_ACCEPT);
|
CDNS_IP_MCP_CONTROL_CMD_ACCEPT);
|
||||||
|
|
||||||
if (!bus_reset) {
|
if (!bus_reset) {
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user