spi: tegra210-quad: Protect curr_xfer assignment in tegra_qspi_setup_transfer_one

When the timeout handler processes a completed transfer and signals
completion, the transfer thread can immediately set up the next transfer
and assign curr_xfer to point to it.

If a delayed ISR from the previous transfer then runs, it checks if
(!tqspi->curr_xfer) (currently without the lock also -- to be fixed
soon) to detect stale interrupts, but this check passes because
curr_xfer now points to the new transfer. The ISR then incorrectly
processes the new transfer's context.

Protect the curr_xfer assignment with the spinlock to ensure the ISR
either sees NULL (and bails out) or sees the new value only after the
assignment is complete.

Fixes: 921fc1838fb0 ("spi: tegra210-quad: Add support for Tegra210 QSPI controller")
Signed-off-by: Breno Leitao <leitao@debian.org>
Tested-by: Jon Hunter <jonathanh@nvidia.com>
Acked-by: Jon Hunter <jonathanh@nvidia.com>
Acked-by: Thierry Reding <treding@nvidia.com>
Link: https://patch.msgid.link/20260126-tegra_xfer-v2-3-6d2115e4f387@debian.org
Signed-off-by: Mark Brown <broonie@kernel.org>

authored by Breno Leitao and committed by Mark Brown f5a4d7f5 ef13ba35

+3
+3
drivers/spi/spi-tegra210-quad.c
··· 839 u32 command1, command2, speed = t->speed_hz; 840 u8 bits_per_word = t->bits_per_word; 841 u32 tx_tap = 0, rx_tap = 0; 842 int req_mode; 843 844 if (!has_acpi_companion(tqspi->dev) && speed != tqspi->cur_speed) { ··· 847 tqspi->cur_speed = speed; 848 } 849 850 tqspi->cur_pos = 0; 851 tqspi->cur_rx_pos = 0; 852 tqspi->cur_tx_pos = 0; 853 tqspi->curr_xfer = t; 854 855 if (is_first_of_msg) { 856 tegra_qspi_mask_clear_irq(tqspi);
··· 839 u32 command1, command2, speed = t->speed_hz; 840 u8 bits_per_word = t->bits_per_word; 841 u32 tx_tap = 0, rx_tap = 0; 842 + unsigned long flags; 843 int req_mode; 844 845 if (!has_acpi_companion(tqspi->dev) && speed != tqspi->cur_speed) { ··· 846 tqspi->cur_speed = speed; 847 } 848 849 + spin_lock_irqsave(&tqspi->lock, flags); 850 tqspi->cur_pos = 0; 851 tqspi->cur_rx_pos = 0; 852 tqspi->cur_tx_pos = 0; 853 tqspi->curr_xfer = t; 854 + spin_unlock_irqrestore(&tqspi->lock, flags); 855 856 if (is_first_of_msg) { 857 tegra_qspi_mask_clear_irq(tqspi);