diff options
author | Charles Keepax <ckeepax@opensource.cirrus.com> | 2023-06-02 11:11:36 +0100 |
---|---|---|
committer | Vinod Koul <vkoul@kernel.org> | 2023-06-08 17:08:04 +0530 |
commit | 58d95889f3c2064c6139ee94bb0e4d86e1ad4eab (patch) | |
tree | 09fa738913bf6f069d9f3f6b961ddbf3762bda86 /drivers | |
parent | 99e09b9c0ab43346c52f2787ca4e5c4b1798362e (diff) | |
download | lwn-58d95889f3c2064c6139ee94bb0e4d86e1ad4eab.tar.gz lwn-58d95889f3c2064c6139ee94bb0e4d86e1ad4eab.zip |
soundwire: stream: Add missing clear of alloc_slave_rt
The current path that skips allocating the slave runtime does not clear
the alloc_slave_rt flag, this is clearly incorrect. Add the missing
clear, so the runtime won't be erroneously cleaned up.
Fixes: f3016b891c8c ("soundwire: stream: sdw_stream_add_ functions can be called multiple times")
Reviewed-by: Pierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
Signed-off-by: Charles Keepax <ckeepax@opensource.cirrus.com>
Link: https://lore.kernel.org/r/20230602101140.2040141-1-ckeepax@opensource.cirrus.com
Signed-off-by: Vinod Koul <vkoul@kernel.org>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/soundwire/stream.c | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/drivers/soundwire/stream.c b/drivers/soundwire/stream.c index c2191c07442b..379228f22186 100644 --- a/drivers/soundwire/stream.c +++ b/drivers/soundwire/stream.c @@ -2021,8 +2021,10 @@ int sdw_stream_add_slave(struct sdw_slave *slave, skip_alloc_master_rt: s_rt = sdw_slave_rt_find(slave, stream); - if (s_rt) + if (s_rt) { + alloc_slave_rt = false; goto skip_alloc_slave_rt; + } s_rt = sdw_slave_rt_alloc(slave, m_rt); if (!s_rt) { |