ASoC: Use inline function for type safety in snd_soc_substream_to_rtd()
authorKrzysztof Kozlowski <krzysztof.kozlowski@linaro.org>
Wed, 1 May 2024 17:51:27 +0000 (19:51 +0200)
committerMark Brown <broonie@kernel.org>
Thu, 2 May 2024 03:57:25 +0000 (12:57 +0900)
commit9723cab054d59d770cd1927f92fe315c26cc6a78
tree30bd54ce233eb0d281f22de9f1a7d21b4f700a76
parent9f6bdb0aa1e9527e86b8640de5bb30f925b3774e
ASoC: Use inline function for type safety in snd_soc_substream_to_rtd()

A common pattern in sound drivers is getting 'struct snd_soc_pcm_runtime'
from 'struct snd_pcm_substream' opaque pointer private_data field with
snd_soc_substream_to_rtd().  However 'private_data' appears in several
other structures as well, including 'struct snd_compr_stream'.  The
field might not hold the same type for every structure, although seems
the case at least for 'struct snd_compr_stream', so code can easily make
a mistake by using macro for wrong structure passed as argument.

Switch from macro to inline function, so such mistake will be build-time
detectable.

Signed-off-by: Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org>
Link: https://lore.kernel.org/r/20240501175127.34301-1-krzysztof.kozlowski@linaro.org
Signed-off-by: Mark Brown <broonie@kernel.org>
include/sound/soc.h