stable.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH AUTOSEL 4.9 01/66] s390/qeth: invoke softirqs after napi_schedule()
@ 2019-11-10  2:47 Sasha Levin
  2019-11-10  2:47 ` [PATCH AUTOSEL 4.9 02/66] PCI/ACPI: Correct error message for ASPM disabling Sasha Levin
                   ` (64 more replies)
  0 siblings, 65 replies; 66+ messages in thread
From: Sasha Levin @ 2019-11-10  2:47 UTC (permalink / raw)
  To: linux-kernel, stable
  Cc: Julian Wiedmann, David S . Miller, Sasha Levin, linux-s390

From: Julian Wiedmann <jwi@linux.ibm.com>

[ Upstream commit 4d19db777a2f32c9b76f6fd517ed8960576cb43e ]

Calling napi_schedule() from process context does not ensure that the
NET_RX softirq is run in a timely fashion. So trigger it manually.

This is no big issue with current code. A call to ndo_open() is usually
followed by a ndo_set_rx_mode() call, and for qeth this contains a
spin_unlock_bh(). Except for OSN, where qeth_l2_set_rx_mode() bails out
early.
Nevertheless it's best to not depend on this behaviour, and just fix
the issue at its source like all other drivers do. For instance see
commit 83a0c6e58901 ("i40e: Invoke softirqs after napi_reschedule").

Fixes: a1c3ed4c9ca0 ("qeth: NAPI support for l2 and l3 discipline")
Signed-off-by: Julian Wiedmann <jwi@linux.ibm.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Sasha Levin <sashal@kernel.org>
---
 drivers/s390/net/qeth_l2_main.c | 3 +++
 drivers/s390/net/qeth_l3_main.c | 3 +++
 2 files changed, 6 insertions(+)

diff --git a/drivers/s390/net/qeth_l2_main.c b/drivers/s390/net/qeth_l2_main.c
index 6ba4e921d2fd3..51152681aba6e 100644
--- a/drivers/s390/net/qeth_l2_main.c
+++ b/drivers/s390/net/qeth_l2_main.c
@@ -991,7 +991,10 @@ static int __qeth_l2_open(struct net_device *dev)
 
 	if (qdio_stop_irq(card->data.ccwdev, 0) >= 0) {
 		napi_enable(&card->napi);
+		local_bh_disable();
 		napi_schedule(&card->napi);
+		/* kick-start the NAPI softirq: */
+		local_bh_enable();
 	} else
 		rc = -EIO;
 	return rc;
diff --git a/drivers/s390/net/qeth_l3_main.c b/drivers/s390/net/qeth_l3_main.c
index 6e6ba1baf9c48..b40a61d9ad9ec 100644
--- a/drivers/s390/net/qeth_l3_main.c
+++ b/drivers/s390/net/qeth_l3_main.c
@@ -3005,7 +3005,10 @@ static int __qeth_l3_open(struct net_device *dev)
 
 	if (qdio_stop_irq(card->data.ccwdev, 0) >= 0) {
 		napi_enable(&card->napi);
+		local_bh_disable();
 		napi_schedule(&card->napi);
+		/* kick-start the NAPI softirq: */
+		local_bh_enable();
 	} else
 		rc = -EIO;
 	return rc;
-- 
2.20.1


^ permalink raw reply related	[flat|nested] 66+ messages in thread

end of thread, other threads:[~2019-11-10  3:03 UTC | newest]

Thread overview: 66+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2019-11-10  2:47 [PATCH AUTOSEL 4.9 01/66] s390/qeth: invoke softirqs after napi_schedule() Sasha Levin
2019-11-10  2:47 ` [PATCH AUTOSEL 4.9 02/66] PCI/ACPI: Correct error message for ASPM disabling Sasha Levin
2019-11-10  2:47 ` [PATCH AUTOSEL 4.9 03/66] serial: mxs-auart: Fix potential infinite loop Sasha Levin
2019-11-10  2:47 ` [PATCH AUTOSEL 4.9 04/66] powerpc/iommu: Avoid derefence before pointer check Sasha Levin
2019-11-10  2:47 ` [PATCH AUTOSEL 4.9 05/66] powerpc/64s/hash: Fix stab_rr off by one initialization Sasha Levin
2019-11-10  2:47 ` [PATCH AUTOSEL 4.9 06/66] powerpc/pseries: Disable CPU hotplug across migrations Sasha Levin
2019-11-10  2:47 ` [PATCH AUTOSEL 4.9 07/66] RDMA/i40iw: Fix incorrect iterator type Sasha Levin
2019-11-10  2:47 ` [PATCH AUTOSEL 4.9 08/66] libfdt: Ensure INT_MAX is defined in libfdt_env.h Sasha Levin
2019-11-10  2:47 ` [PATCH AUTOSEL 4.9 09/66] power: supply: twl4030_charger: fix charging current out-of-bounds Sasha Levin
2019-11-10  2:47 ` [PATCH AUTOSEL 4.9 10/66] power: supply: twl4030_charger: disable eoc interrupt on linear charge Sasha Levin
2019-11-10  2:47 ` [PATCH AUTOSEL 4.9 11/66] net: toshiba: fix return type of ndo_start_xmit function Sasha Levin
2019-11-10  2:47 ` [PATCH AUTOSEL 4.9 12/66] net: xilinx: " Sasha Levin
2019-11-10  2:47 ` [PATCH AUTOSEL 4.9 13/66] net: broadcom: " Sasha Levin
2019-11-10  2:47 ` [PATCH AUTOSEL 4.9 14/66] net: amd: " Sasha Levin
2019-11-10  2:47 ` [PATCH AUTOSEL 4.9 15/66] usb: chipidea: imx: enable OTG overcurrent in case USB subsystem is already started Sasha Levin
2019-11-10  2:47 ` [PATCH AUTOSEL 4.9 16/66] usb: chipidea: Fix otg event handler Sasha Levin
2019-11-10  2:47 ` [PATCH AUTOSEL 4.9 17/66] mlxsw: spectrum: Init shaper for TCs 8..15 Sasha Levin
2019-11-10  2:47 ` [PATCH AUTOSEL 4.9 18/66] ARM: dts: am335x-evm: fix number of cpsw Sasha Levin
2019-11-10  2:47 ` [PATCH AUTOSEL 4.9 19/66] f2fs: fix to recover inode's uid/gid during POR Sasha Levin
2019-11-10  2:47 ` [PATCH AUTOSEL 4.9 20/66] ARM: dts: ux500: Correct SCU unit address Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 21/66] ARM: dts: ux500: Fix LCDA clock line muxing Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 22/66] ARM: dts: ste: Fix SPI controller node names Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 23/66] spi: pic32: Use proper enum in dmaengine_prep_slave_rg Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 24/66] cpufeature: avoid warning when compiling with clang Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 25/66] ARM: dts: marvell: Fix SPI and I2C bus warnings Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 26/66] bnx2x: Ignore bandwidth attention in single function mode Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 27/66] net: micrel: fix return type of ndo_start_xmit function Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 28/66] x86/CPU: Use correct macros for Cyrix calls Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 29/66] MIPS: kexec: Relax memory restriction Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 30/66] media: pci: ivtv: Fix a sleep-in-atomic-context bug in ivtv_yuv_init() Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 31/66] media: au0828: Fix incorrect error messages Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 32/66] media: davinci: Fix implicit enum conversion warning Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 33/66] usb: gadget: uvc: configfs: Drop leaked references to config items Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 34/66] usb: gadget: uvc: configfs: Prevent format changes after linking header Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 35/66] phy: phy-twl4030-usb: fix denied runtime access Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 36/66] usb: gadget: uvc: Factor out video USB request queueing Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 37/66] usb: gadget: uvc: Only halt video streaming endpoint in bulk mode Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 38/66] coresight: Fix handling of sinks Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 39/66] coresight: etm4x: Configure EL2 exception level when kernel is running in HYP Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 40/66] coresight: tmc: Fix byte-address alignment for RRP Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 41/66] misc: kgdbts: Fix restrict error Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 42/66] misc: genwqe: should return proper error value Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 43/66] vfio/pci: Fix potential memory leak in vfio_msi_cap_len Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 44/66] vfio/pci: Mask buggy SR-IOV VF INTx support Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 45/66] scsi: libsas: always unregister the old device if going to discover new Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 46/66] ARM: dts: tegra30: fix xcvr-setup-use-fuses Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 47/66] ARM: tegra: apalis_t30: fix mmc1 cmd pull-up Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 48/66] ARM: dts: paz00: fix wakeup gpio keycode Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 49/66] net: smsc: fix return type of ndo_start_xmit function Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 50/66] EDAC: Raise the maximum number of memory controllers Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 51/66] ARM: dts: realview: Fix SPI controller node names Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 52/66] Bluetooth: L2CAP: Detect if remote is not able to use the whole MPS Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 53/66] crypto: s5p-sss: Fix Fix argument list alignment Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 54/66] crypto: fix a memory leak in rsa-kcs1pad's encryption mode Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 55/66] scsi: NCR5380: Clear all unissued commands on host reset Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 56/66] scsi: NCR5380: Use DRIVER_SENSE to indicate valid sense data Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 57/66] scsi: NCR5380: Check for invalid reselection target Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 58/66] scsi: NCR5380: Don't clear busy flag when abort fails Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 59/66] scsi: NCR5380: Don't call dsprintk() following reselection interrupt Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 60/66] scsi: NCR5380: Handle BUS FREE during reselection Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 61/66] arm64: dts: amd: Fix SPI bus warnings Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 62/66] arm64: dts: lg: Fix SPI controller node names Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 63/66] ARM: dts: lpc32xx: " Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 64/66] usb: xhci-mtk: fix ISOC error when interval is zero Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 65/66] fuse: use READ_ONCE on congestion_threshold and max_background Sasha Levin
2019-11-10  2:48 ` [PATCH AUTOSEL 4.9 66/66] IB/iser: Fix possible NULL deref at iser_inv_desc() Sasha Levin

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).