From: Greg Kroah-Hartman Date: Thu, 20 Jul 2023 17:04:34 +0000 (+0200) Subject: 5.4-stable patches X-Git-Tag: v5.15.121~105 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=c14963ec2177f77c5c1eeb9a784cbdb58b2adf37;p=thirdparty%2Fkernel%2Fstable-queue.git 5.4-stable patches added patches: net-lan743x-don-t-sleep-in-atomic-context.patch --- diff --git a/queue-5.4/net-lan743x-don-t-sleep-in-atomic-context.patch b/queue-5.4/net-lan743x-don-t-sleep-in-atomic-context.patch new file mode 100644 index 00000000000..90db667a7af --- /dev/null +++ b/queue-5.4/net-lan743x-don-t-sleep-in-atomic-context.patch @@ -0,0 +1,72 @@ +From 7a8227b2e76be506b2ac64d2beac950ca04892a5 Mon Sep 17 00:00:00 2001 +From: Moritz Fischer +Date: Tue, 27 Jun 2023 03:50:00 +0000 +Subject: net: lan743x: Don't sleep in atomic context + +From: Moritz Fischer + +commit 7a8227b2e76be506b2ac64d2beac950ca04892a5 upstream. + +dev_set_rx_mode() grabs a spin_lock, and the lan743x implementation +proceeds subsequently to go to sleep using readx_poll_timeout(). + +Introduce a helper wrapping the readx_poll_timeout_atomic() function +and use it to replace the calls to readx_polL_timeout(). + +Fixes: 23f0703c125b ("lan743x: Add main source files for new lan743x driver") +Cc: stable@vger.kernel.org +Cc: Bryan Whitehead +Cc: UNGLinuxDriver@microchip.com +Signed-off-by: Moritz Fischer +Reviewed-by: Andrew Lunn +Link: https://lore.kernel.org/r/20230627035000.1295254-1-moritzf@google.com +Signed-off-by: Paolo Abeni +Signed-off-by: Greg Kroah-Hartman +--- + drivers/net/ethernet/microchip/lan743x_main.c | 21 +++++++++++++++++---- + 1 file changed, 17 insertions(+), 4 deletions(-) + +--- a/drivers/net/ethernet/microchip/lan743x_main.c ++++ b/drivers/net/ethernet/microchip/lan743x_main.c +@@ -80,6 +80,18 @@ static int lan743x_csr_light_reset(struc + !(data & HW_CFG_LRST_), 100000, 10000000); + } + ++static int lan743x_csr_wait_for_bit_atomic(struct lan743x_adapter *adapter, ++ int offset, u32 bit_mask, ++ int target_value, int udelay_min, ++ int udelay_max, int count) ++{ ++ u32 data; ++ ++ return readx_poll_timeout_atomic(LAN743X_CSR_READ_OP, offset, data, ++ target_value == !!(data & bit_mask), ++ udelay_max, udelay_min * count); ++} ++ + static int lan743x_csr_wait_for_bit(struct lan743x_adapter *adapter, + int offset, u32 bit_mask, + int target_value, int usleep_min, +@@ -675,8 +687,8 @@ static int lan743x_dp_write(struct lan74 + u32 dp_sel; + int i; + +- if (lan743x_csr_wait_for_bit(adapter, DP_SEL, DP_SEL_DPRDY_, +- 1, 40, 100, 100)) ++ if (lan743x_csr_wait_for_bit_atomic(adapter, DP_SEL, DP_SEL_DPRDY_, ++ 1, 40, 100, 100)) + return -EIO; + dp_sel = lan743x_csr_read(adapter, DP_SEL); + dp_sel &= ~DP_SEL_MASK_; +@@ -687,8 +699,9 @@ static int lan743x_dp_write(struct lan74 + lan743x_csr_write(adapter, DP_ADDR, addr + i); + lan743x_csr_write(adapter, DP_DATA_0, buf[i]); + lan743x_csr_write(adapter, DP_CMD, DP_CMD_WRITE_); +- if (lan743x_csr_wait_for_bit(adapter, DP_SEL, DP_SEL_DPRDY_, +- 1, 40, 100, 100)) ++ if (lan743x_csr_wait_for_bit_atomic(adapter, DP_SEL, ++ DP_SEL_DPRDY_, ++ 1, 40, 100, 100)) + return -EIO; + } + diff --git a/queue-5.4/series b/queue-5.4/series index a5947971b8c..f99360b6889 100644 --- a/queue-5.4/series +++ b/queue-5.4/series @@ -192,3 +192,4 @@ netfilter-conntrack-avoid-nf_ct_helper_hash-uses-after-free.patch netfilter-nf_tables-prevent-oob-access-in-nft_byteorder_eval.patch tty-serial-fsl_lpuart-add-earlycon-for-imx8ulp-platform.patch block-partition-fix-signedness-issue-for-amiga-partitions.patch +net-lan743x-don-t-sleep-in-atomic-context.patch