Commit 9402e25d authored by Pierre-Louis Bossart's avatar Pierre-Louis Bossart Committed by Vinod Koul

soundwire: cadence: add helpers to access IP_MCP registers

The latest Cadence IP splits some of the existing registers into two,
separated by a fixed offset. The bitfields themselves remain at the
same position, so we can use new helpers to dynamically add the fixed
offset.

For example, the existing MCP_CONFIG is now split in two with
MCP_CONFIG and IP_MCP_CONFIG (the naming comes directly from the
design document).

This patch adds helpers to access registers with the IP_ prefix. The
addition of the 'ip' prefix for helpers, registers and bitfields is
intentional to help reviewers spot any mistake.

For existing solutions, the offset is exactly zero so there's no
functional change - the MCP_CONFIG and IP_MCP_CONFIG are aliased to
the same address.
Signed-off-by: default avatarPierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
Reviewed-by: default avatarRander Wang <rander.wang@intel.com>
Signed-off-by: default avatarBard Liao <yung-chuan.liao@linux.intel.com>
Link: https://lore.kernel.org/r/20230314015410.487311-13-yung-chuan.liao@linux.intel.comSigned-off-by: default avatarVinod Koul <vkoul@kernel.org>
parent f117e908
...@@ -205,6 +205,16 @@ static inline void cdns_writel(struct sdw_cdns *cdns, int offset, u32 value) ...@@ -205,6 +205,16 @@ static inline void cdns_writel(struct sdw_cdns *cdns, int offset, u32 value)
writel(value, cdns->registers + offset); writel(value, cdns->registers + offset);
} }
static inline u32 cdns_ip_readl(struct sdw_cdns *cdns, int offset)
{
return cdns_readl(cdns, cdns->ip_offset + offset);
}
static inline void cdns_ip_writel(struct sdw_cdns *cdns, int offset, u32 value)
{
return cdns_writel(cdns, cdns->ip_offset + offset, value);
}
static inline void cdns_updatel(struct sdw_cdns *cdns, static inline void cdns_updatel(struct sdw_cdns *cdns,
int offset, u32 mask, u32 val) int offset, u32 mask, u32 val)
{ {
...@@ -215,6 +225,12 @@ static inline void cdns_updatel(struct sdw_cdns *cdns, ...@@ -215,6 +225,12 @@ static inline void cdns_updatel(struct sdw_cdns *cdns,
cdns_writel(cdns, offset, tmp); cdns_writel(cdns, offset, tmp);
} }
static inline void cdns_ip_updatel(struct sdw_cdns *cdns,
int offset, u32 mask, u32 val)
{
cdns_updatel(cdns, cdns->ip_offset + offset, mask, val);
}
static int cdns_set_wait(struct sdw_cdns *cdns, int offset, u32 mask, u32 value) static int cdns_set_wait(struct sdw_cdns *cdns, int offset, u32 mask, u32 value)
{ {
int timeout = 10; int timeout = 10;
......
...@@ -107,6 +107,7 @@ struct sdw_cdns_dai_runtime { ...@@ -107,6 +107,7 @@ struct sdw_cdns_dai_runtime {
* @dev: Linux device * @dev: Linux device
* @bus: Bus handle * @bus: Bus handle
* @instance: instance number * @instance: instance number
* @ip_offset: version-dependent offset to access IP_MCP registers and fields
* @response_buf: SoundWire response buffer * @response_buf: SoundWire response buffer
* @tx_complete: Tx completion * @tx_complete: Tx completion
* @ports: Data ports * @ports: Data ports
...@@ -122,6 +123,8 @@ struct sdw_cdns { ...@@ -122,6 +123,8 @@ struct sdw_cdns {
struct sdw_bus bus; struct sdw_bus bus;
unsigned int instance; unsigned int instance;
u32 ip_offset;
/* /*
* The datasheet says the RX FIFO AVAIL can be 2 entries more * The datasheet says the RX FIFO AVAIL can be 2 entries more
* than the FIFO capacity, so allow for this. * than the FIFO capacity, so allow for this.
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment