spi: spi-mem: avoid mutating op template in spi_mem_supports_op()
spi_mem_supports_op() accepts a const struct spi_mem_op pointer but
casts away const internally to call spi_mem_adjust_op_freq(). This
mutates the caller's op template, which causes stale max_freq values
when callers reuse persistent templates - subsequent calls won't
re-apply the device frequency cap since spi_mem_adjust_op_freq()
skips non-zero values.
Fix by operating on a stack-local copy instead.
Fixes: a4f8e70d75 ("spi: spi-mem: add spi_mem_adjust_op_freq() in spi_mem_supports_op()")
Cc: Tianyu Xu <xtydtc@gmail.com>
Cc: stable@vger.kernel.org
Signed-off-by: Santhosh Kumar K <s-k6@ti.com>
Reviewed-by: Miquel Raynal <miquel.raynal@bootlin.com>
Link: https://patch.msgid.link/20260527173736.2243004-1-s-k6@ti.com
Signed-off-by: Mark Brown <broonie@kernel.org>
master
parent
60474437af
commit
79378db6a8
|
|
@ -279,13 +279,20 @@ static bool spi_mem_internal_supports_op(struct spi_mem *mem,
|
||||||
*/
|
*/
|
||||||
bool spi_mem_supports_op(struct spi_mem *mem, const struct spi_mem_op *op)
|
bool spi_mem_supports_op(struct spi_mem *mem, const struct spi_mem_op *op)
|
||||||
{
|
{
|
||||||
/* Make sure the operation frequency is correct before going futher */
|
struct spi_mem_op eval_op = *op;
|
||||||
spi_mem_adjust_op_freq(mem, (struct spi_mem_op *)op);
|
|
||||||
|
|
||||||
if (spi_mem_check_op(op))
|
/*
|
||||||
|
* Work on a local copy; this is a pure capability check and must
|
||||||
|
* not modify the caller's op. Stored templates with max_freq == 0
|
||||||
|
* must remain unset so their frequency is always re-capped to the
|
||||||
|
* current device maximum at execution time.
|
||||||
|
*/
|
||||||
|
spi_mem_adjust_op_freq(mem, &eval_op);
|
||||||
|
|
||||||
|
if (spi_mem_check_op(&eval_op))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
return spi_mem_internal_supports_op(mem, op);
|
return spi_mem_internal_supports_op(mem, &eval_op);
|
||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(spi_mem_supports_op);
|
EXPORT_SYMBOL_GPL(spi_mem_supports_op);
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue