public inbox for patches@lists.linux.dev
 help / color / mirror / Atom feed
From: Sasha Levin <sashal@kernel.org>
To: patches@lists.linux.dev
Cc: Narayana Murty N <nnmlinux@linux.ibm.com>,
	Sourabh Jain <sourabhjain@linux.ibm.com>,
	Mahesh Salgaonkar <mahesh@linux.ibm.com>,
	Madhavan Srinivasan <maddy@linux.ibm.com>,
	Sasha Levin <sashal@kernel.org>
Subject: [PATCH 5.10 039/147] powerpc/eeh: fix recursive pci_lock_rescan_remove locking in EEH event handling
Date: Sat, 28 Feb 2026 13:15:47 -0500	[thread overview]
Message-ID: <20260228181736.1605592-39-sashal@kernel.org> (raw)
In-Reply-To: <20260228181736.1605592-1-sashal@kernel.org>

From: Narayana Murty N <nnmlinux@linux.ibm.com>

[ Upstream commit 815a8d2feb5615ae7f0b5befd206af0b0160614c ]

The recent commit 1010b4c012b0 ("powerpc/eeh: Make EEH driver device
hotplug safe") restructured the EEH driver to improve synchronization
with the PCI hotplug layer.

However, it inadvertently moved pci_lock_rescan_remove() outside its
intended scope in eeh_handle_normal_event(), leading to broken PCI
error reporting and improper EEH event triggering. Specifically,
eeh_handle_normal_event() acquired pci_lock_rescan_remove() before
calling eeh_pe_bus_get(), but eeh_pe_bus_get() itself attempts to
acquire the same lock internally, causing nested locking and disrupting
normal EEH event handling paths.

This patch adds a boolean parameter do_lock to _eeh_pe_bus_get(),
with two public wrappers:
    eeh_pe_bus_get() with locking enabled.
    eeh_pe_bus_get_nolock() that skips locking.

Callers that already hold pci_lock_rescan_remove() now use
eeh_pe_bus_get_nolock() to avoid recursive lock acquisition.

Additionally, pci_lock_rescan_remove() calls are restored to the correct
position—after eeh_pe_bus_get() and immediately before iterating affected
PEs and devices. This ensures EEH-triggered PCI removes occur under proper
bus rescan locking without recursive lock contention.

The eeh_pe_loc_get() function has been split into two functions:
    eeh_pe_loc_get(struct eeh_pe *pe) which retrieves the loc for given PE.
    eeh_pe_loc_get_bus(struct pci_bus *bus) which retrieves the location
    code for given bus.

This resolves lockdep warnings such as:
<snip>
[   84.964298] [    T928] ============================================
[   84.964304] [    T928] WARNING: possible recursive locking detected
[   84.964311] [    T928] 6.18.0-rc3 #51 Not tainted
[   84.964315] [    T928] --------------------------------------------
[   84.964320] [    T928] eehd/928 is trying to acquire lock:
[   84.964324] [    T928] c000000003b29d58 (pci_rescan_remove_lock){+.+.}-{3:3}, at: pci_lock_rescan_remove+0x28/0x40
[   84.964342] [    T928]
                       but task is already holding lock:
[   84.964347] [    T928] c000000003b29d58 (pci_rescan_remove_lock){+.+.}-{3:3}, at: pci_lock_rescan_remove+0x28/0x40
[   84.964357] [    T928]
                       other info that might help us debug this:
[   84.964363] [    T928]  Possible unsafe locking scenario:

[   84.964367] [    T928]        CPU0
[   84.964370] [    T928]        ----
[   84.964373] [    T928]   lock(pci_rescan_remove_lock);
[   84.964378] [    T928]   lock(pci_rescan_remove_lock);
[   84.964383] [    T928]
                       *** DEADLOCK ***

[   84.964388] [    T928]  May be due to missing lock nesting notation

[   84.964393] [    T928] 1 lock held by eehd/928:
[   84.964397] [    T928]  #0: c000000003b29d58 (pci_rescan_remove_lock){+.+.}-{3:3}, at: pci_lock_rescan_remove+0x28/0x40
[   84.964408] [    T928]
                       stack backtrace:
[   84.964414] [    T928] CPU: 2 UID: 0 PID: 928 Comm: eehd Not tainted 6.18.0-rc3 #51 VOLUNTARY
[   84.964417] [    T928] Hardware name: IBM,9080-HEX POWER10 (architected) 0x800200 0xf000006 of:IBM,FW1060.00 (NH1060_022) hv:phyp pSeries
[   84.964419] [    T928] Call Trace:
[   84.964420] [    T928] [c0000011a7157990] [c000000001705de4] dump_stack_lvl+0xc8/0x130 (unreliable)
[   84.964424] [    T928] [c0000011a71579d0] [c0000000002f66e0] print_deadlock_bug+0x430/0x440
[   84.964428] [    T928] [c0000011a7157a70] [c0000000002fd0c0] __lock_acquire+0x1530/0x2d80
[   84.964431] [    T928] [c0000011a7157ba0] [c0000000002fea54] lock_acquire+0x144/0x410
[   84.964433] [    T928] [c0000011a7157cb0] [c0000011a7157cb0] __mutex_lock+0xf4/0x1050
[   84.964436] [    T928] [c0000011a7157e00] [c000000000de21d8] pci_lock_rescan_remove+0x28/0x40
[   84.964439] [    T928] [c0000011a7157e20] [c00000000004ed98] eeh_pe_bus_get+0x48/0xc0
[   84.964442] [    T928] [c0000011a7157e50] [c000000000050434] eeh_handle_normal_event+0x64/0xa60
[   84.964446] [    T928] [c0000011a7157f30] [c000000000051de8] eeh_event_handler+0xf8/0x190
[   84.964450] [    T928] [c0000011a7157f90] [c0000000002747ac] kthread+0x16c/0x180
[   84.964453] [    T928] [c0000011a7157fe0] [c00000000000ded8] start_kernel_thread+0x14/0x18
</snip>

Fixes: 1010b4c012b0 ("powerpc/eeh: Make EEH driver device hotplug safe")
Signed-off-by: Narayana Murty N <nnmlinux@linux.ibm.com>
Reviewed-by: Sourabh Jain <sourabhjain@linux.ibm.com>
Reviewed-by: Mahesh Salgaonkar <mahesh@linux.ibm.com>
Signed-off-by: Madhavan Srinivasan <maddy@linux.ibm.com>
Link: https://patch.msgid.link/20251210142559.8874-1-nnmlinux@linux.ibm.com
Signed-off-by: Sasha Levin <sashal@kernel.org>
---
 arch/powerpc/include/asm/eeh.h   |  2 +
 arch/powerpc/kernel/eeh_driver.c | 11 ++---
 arch/powerpc/kernel/eeh_pe.c     | 74 ++++++++++++++++++++++++++++++--
 3 files changed, 78 insertions(+), 9 deletions(-)

diff --git a/arch/powerpc/include/asm/eeh.h b/arch/powerpc/include/asm/eeh.h
index b1a5bba2e0b94..2c9dc733accfd 100644
--- a/arch/powerpc/include/asm/eeh.h
+++ b/arch/powerpc/include/asm/eeh.h
@@ -289,6 +289,8 @@ void eeh_pe_dev_traverse(struct eeh_pe *root,
 void eeh_pe_restore_bars(struct eeh_pe *pe);
 const char *eeh_pe_loc_get(struct eeh_pe *pe);
 struct pci_bus *eeh_pe_bus_get(struct eeh_pe *pe);
+const char *eeh_pe_loc_get_bus(struct pci_bus *bus);
+struct pci_bus *eeh_pe_bus_get_nolock(struct eeh_pe *pe);
 
 void eeh_show_enabled(void);
 int __init eeh_init(struct eeh_ops *ops);
diff --git a/arch/powerpc/kernel/eeh_driver.c b/arch/powerpc/kernel/eeh_driver.c
index 2f13d906e1fcb..20106e490b9c6 100644
--- a/arch/powerpc/kernel/eeh_driver.c
+++ b/arch/powerpc/kernel/eeh_driver.c
@@ -847,7 +847,7 @@ void eeh_handle_normal_event(struct eeh_pe *pe)
 
 	pci_lock_rescan_remove();
 
-	bus = eeh_pe_bus_get(pe);
+	bus = eeh_pe_bus_get_nolock(pe);
 	if (!bus) {
 		pr_err("%s: Cannot find PCI bus for PHB#%x-PE#%x\n",
 			__func__, pe->phb->global_number, pe->addr);
@@ -878,14 +878,15 @@ void eeh_handle_normal_event(struct eeh_pe *pe)
 	/* Log the event */
 	if (pe->type & EEH_PE_PHB) {
 		pr_err("EEH: Recovering PHB#%x, location: %s\n",
-			pe->phb->global_number, eeh_pe_loc_get(pe));
+			pe->phb->global_number, eeh_pe_loc_get_bus(bus));
 	} else {
 		struct eeh_pe *phb_pe = eeh_phb_pe_get(pe->phb);
 
 		pr_err("EEH: Recovering PHB#%x-PE#%x\n",
 		       pe->phb->global_number, pe->addr);
 		pr_err("EEH: PE location: %s, PHB location: %s\n",
-		       eeh_pe_loc_get(pe), eeh_pe_loc_get(phb_pe));
+		       eeh_pe_loc_get_bus(bus),
+		       eeh_pe_loc_get_bus(eeh_pe_bus_get_nolock(phb_pe)));
 	}
 
 #ifdef CONFIG_STACKTRACE
@@ -1093,7 +1094,7 @@ void eeh_handle_normal_event(struct eeh_pe *pe)
 		eeh_pe_state_clear(pe, EEH_PE_PRI_BUS, true);
 		eeh_pe_dev_mode_mark(pe, EEH_DEV_REMOVED);
 
-		bus = eeh_pe_bus_get(pe);
+		bus = eeh_pe_bus_get_nolock(pe);
 		if (bus)
 			pci_hp_remove_devices(bus);
 		else
@@ -1217,7 +1218,7 @@ void eeh_handle_special_event(void)
 				    (phb_pe->state & EEH_PE_RECOVERING))
 					continue;
 
-				bus = eeh_pe_bus_get(phb_pe);
+				bus = eeh_pe_bus_get_nolock(phb_pe);
 				if (!bus) {
 					pr_err("%s: Cannot find PCI bus for "
 					       "PHB#%x-PE#%x\n",
diff --git a/arch/powerpc/kernel/eeh_pe.c b/arch/powerpc/kernel/eeh_pe.c
index fea58e9546f98..6f69242142e0d 100644
--- a/arch/powerpc/kernel/eeh_pe.c
+++ b/arch/powerpc/kernel/eeh_pe.c
@@ -811,6 +811,24 @@ void eeh_pe_restore_bars(struct eeh_pe *pe)
 const char *eeh_pe_loc_get(struct eeh_pe *pe)
 {
 	struct pci_bus *bus = eeh_pe_bus_get(pe);
+	return eeh_pe_loc_get_bus(bus);
+}
+
+/**
+ * eeh_pe_loc_get_bus - Retrieve location code binding to the given PCI bus
+ * @bus: PCI bus
+ *
+ * Retrieve the location code associated with the given PCI bus. If the bus
+ * is a root bus, the location code is fetched from the PHB device tree node
+ * or root port. Otherwise, the location code is obtained from the device
+ * tree node of the upstream bridge of the bus. The function walks up the
+ * bus hierarchy if necessary, checking each node for the appropriate
+ * location code property ("ibm,io-base-loc-code" for root buses,
+ * "ibm,slot-location-code" for others). If no location code is found,
+ * returns "N/A".
+ */
+const char *eeh_pe_loc_get_bus(struct pci_bus *bus)
+{
 	struct device_node *dn;
 	const char *loc = NULL;
 
@@ -837,8 +855,9 @@ const char *eeh_pe_loc_get(struct eeh_pe *pe)
 }
 
 /**
- * eeh_pe_bus_get - Retrieve PCI bus according to the given PE
+ * _eeh_pe_bus_get - Retrieve PCI bus according to the given PE
  * @pe: EEH PE
+ * @do_lock: Is the caller already held the pci_lock_rescan_remove?
  *
  * Retrieve the PCI bus according to the given PE. Basically,
  * there're 3 types of PEs: PHB/Bus/Device. For PHB PE, the
@@ -846,7 +865,7 @@ const char *eeh_pe_loc_get(struct eeh_pe *pe)
  * returned for BUS PE. However, we don't have associated PCI
  * bus for DEVICE PE.
  */
-struct pci_bus *eeh_pe_bus_get(struct eeh_pe *pe)
+static struct pci_bus *_eeh_pe_bus_get(struct eeh_pe *pe, bool do_lock)
 {
 	struct eeh_dev *edev;
 	struct pci_dev *pdev;
@@ -861,11 +880,58 @@ struct pci_bus *eeh_pe_bus_get(struct eeh_pe *pe)
 
 	/* Retrieve the parent PCI bus of first (top) PCI device */
 	edev = list_first_entry_or_null(&pe->edevs, struct eeh_dev, entry);
-	pci_lock_rescan_remove();
+	if (do_lock)
+		pci_lock_rescan_remove();
 	pdev = eeh_dev_to_pci_dev(edev);
 	if (pdev)
 		bus = pdev->bus;
-	pci_unlock_rescan_remove();
+	if (do_lock)
+		pci_unlock_rescan_remove();
 
 	return bus;
 }
+
+/**
+ * eeh_pe_bus_get - Retrieve PCI bus associated with the given EEH PE, locking
+ * if needed
+ * @pe: Pointer to the EEH PE
+ *
+ * This function is a wrapper around _eeh_pe_bus_get(), which retrieves the PCI
+ * bus associated with the provided EEH PE structure. It acquires the PCI
+ * rescans lock to ensure safe access to shared data during the retrieval
+ * process. This function should be used when the caller requires the PCI bus
+ * while holding the rescan/remove lock, typically during operations that modify
+ * or inspect PCIe device state in a safe manner.
+ *
+ * RETURNS:
+ * A pointer to the PCI bus associated with the EEH PE, or NULL if none found.
+ */
+
+struct pci_bus *eeh_pe_bus_get(struct eeh_pe *pe)
+{
+	return _eeh_pe_bus_get(pe, true);
+}
+
+/**
+ * eeh_pe_bus_get_nolock - Retrieve PCI bus associated with the given EEH PE
+ * without locking
+ * @pe: Pointer to the EEH PE
+ *
+ * This function is a variant of _eeh_pe_bus_get() that retrieves the PCI bus
+ * associated with the specified EEH PE without acquiring the
+ * pci_lock_rescan_remove lock. It should only be used when the caller can
+ * guarantee safe access to PE structures without the need for that lock,
+ * typically in contexts where the lock is already held locking is otherwise
+ * managed.
+ *
+ * RETURNS:
+ * pointer to the PCI bus associated with the EEH PE, or NULL if none is found.
+ *
+ * NOTE:
+ * Use this function carefully to avoid race conditions and data corruption.
+ */
+
+struct pci_bus *eeh_pe_bus_get_nolock(struct eeh_pe *pe)
+{
+	return _eeh_pe_bus_get(pe, false);
+}
-- 
2.51.0


  parent reply	other threads:[~2026-02-28 18:18 UTC|newest]

Thread overview: 152+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2026-02-28 18:15 [PATCH 5.10 001/147] RDMA/siw: Fix potential NULL pointer dereference in header processing Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 002/147] RDMA/umad: Reject negative data_len in ib_umad_write Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 003/147] auxdisplay: arm-charlcd: fix release_mem_region() size Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 004/147] hfsplus: return error when node already exists in hfs_bnode_create Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 005/147] i3c: remove i2c board info from i2c_dev_desc Sasha Levin
2026-03-17 13:13   ` Ben Hutchings
2026-02-28 18:15 ` [PATCH 5.10 006/147] i3c: Move device name assignment after i3c_bus_init Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 007/147] fs: add <linux/init_task.h> for 'init_fs' Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 008/147] gfs2: Add new gfs2_iomap_get helper Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 009/147] gfs2: Turn gfs2_extent_map into gfs2_{get,alloc}_extent Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 010/147] gfs2: Replace gfs2_lblk_to_dblk with gfs2_get_extent Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 011/147] gfs2: Add wrapper for iomap_file_buffered_write Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 012/147] gfs2: Move the inode glock locking to gfs2_file_buffered_write Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 013/147] gfs2: Add metapath_dibh helper Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 014/147] gfs2: Fix use-after-free in iomap inline data write path Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 015/147] tpm: tpm_i2c_infineon: Fix locality leak on get_burstcount() failure Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 016/147] tpm: st33zp24: Fix missing cleanup on get_burstcount() error Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 017/147] btrfs: qgroup: return correct error when deleting qgroup relation item Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 018/147] md/raid10: fix any_working flag handling in raid10_sync_request Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 019/147] iomap: fix submission side handling of completion side errors Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 020/147] PM: wakeup: Handle empty list in wakeup_sources_walk_start() Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 021/147] PM: sleep: wakeirq: harden dev_pm_clear_wake_irq() against races Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 022/147] s390/cio: Fix device lifecycle handling in css_alloc_subchannel() Sasha Levin
2026-03-17 14:16   ` Ben Hutchings
2026-02-28 18:15 ` [PATCH 5.10 023/147] ARM: VDSO: Patch out __vdso_clock_getres() if unavailable Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 024/147] crypto: cavium - fix dma_free_coherent() size Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 025/147] crypto: octeontx " Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 026/147] hrtimer: Fix trace oddity Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 027/147] EDAC/altera: Remove IRQF_ONESHOT Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 028/147] mfd: wm8350-core: Use IRQF_ONESHOT Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 029/147] sched/rt: Skip currently executing CPU in rto_next_cpu() Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 030/147] pstore/ram: fix buffer overflow in persistent_ram_save_old() Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 031/147] EDAC/i5000: Fix snprintf() size calculation in calculate_dimm_size() Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 032/147] EDAC/i5400: Fix snprintf() limit " Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 033/147] clk: qcom: Return correct error code in qcom_cc_probe_by_index() Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 034/147] arm64: dts: qcom: sdm630: Add qfprom subnodes Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 035/147] arm64: dts: qcom: sdm630: correct QFPROM byte offsets Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 036/147] arm64: dts: qcom: sdm630: fix gpu_speed_bin size Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 037/147] ARM: dts: allwinner: sun5i-a13-utoo-p66: delete "power-gpios" property Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 038/147] soc: qcom: cmd-db: Use devm_memremap() to fix memory leak in cmd_db_dev_probe Sasha Levin
2026-02-28 18:15 ` Sasha Levin [this message]
2026-02-28 18:15 ` [PATCH 5.10 040/147] ARM: dts: lpc32xx: Set motor PWM #pwm-cells property value to 3 cells Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 041/147] arm: dts: lpc32xx: add clocks property to Motor Control PWM device tree node Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 042/147] arm64: dts: amlogic: axg: assign the MMC signal clocks Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 043/147] arm64: dts: amlogic: gx: " Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 044/147] arm64: dts: amlogic: g12: assign the MMC B and C " Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 045/147] arm64: dts: amlogic: g12: assign the MMC A signal clock Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 046/147] arm64: dts: qcom: sdm845-db845c: specify power for WiFi CH1 Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 047/147] smack: /smack/doi must be > 0 Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 048/147] smack: /smack/doi: accept previously used values Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 049/147] drm/amdgpu: Use explicit VCN instance 0 in SR-IOV init Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 050/147] regulator: core: Respect off_on_delay at startup Sasha Levin
2026-02-28 18:15 ` [PATCH 5.10 051/147] regulator: core: Fix off_on_delay handling Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 052/147] regulator: Flag uncontrollable regulators as always_on Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 053/147] regulator: core: Fix off-on-delay-us for always-on/boot-on regulators Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 054/147] regulator: core: Use ktime_get_boottime() to determine how long a regulator was off Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 055/147] regulator: core: Shorten off-on-delay-us for always-on/boot-on by time since booted Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 056/147] regulator: core: move supply check earlier in set_machine_constraints() Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 057/147] platform/chrome: cros_ec_lightbar: Fix response size initialization Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 058/147] spi: tools: Add include folder to .gitignore Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 059/147] Revert "hwmon: (ibmpex) fix use-after-free in high/low store" Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 060/147] PCI: mediatek: Fix IRQ domain leak when MSI allocation fails Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 061/147] PCI: Do not attempt to set ExtTag for VFs Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 062/147] PCI/portdrv: Fix potential resource leak Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 063/147] wifi: cfg80211: stop NAN and P2P in cfg80211_leave Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 064/147] netfilter: nf_conncount: make nf_conncount_gc_list() to disable BH Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 065/147] netfilter: nf_conncount: increase the connection clean up limit to 64 Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 066/147] netfilter: nf_conncount: fix tracking of connections from localhost Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 067/147] PCI: Mark 3ware-9650SA Root Port Extended Tags as broken Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 068/147] iommu/vt-d: Flush cache for PASID table before using it Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 069/147] nfsd: never defer requests during idmap lookup Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 070/147] fat: avoid parent link count underflow in rmdir Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 071/147] tcp: tcp_tx_timestamp() must look at the rtx queue Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 072/147] wifi: ath10k: sdio: add missing lock protection in ath10k_sdio_fw_crashed_dump() Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 073/147] PCI: Initialize RCB from pci_configure_device() Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 074/147] ucount: check for CAP_SYS_RESOURCE using ns_capable_noaudit() Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 075/147] octeontx2-af: Fix PF driver crash with kexec kernel booting Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 076/147] bonding: only set speed/duplex to unknown, if getting speed failed Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 077/147] netfilter: nft_set_hash: fix get operation on big endian Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 078/147] netfilter: nft_set_rbtree: check for partial overlaps in anonymous sets Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 079/147] procfs: fix missing RCU protection when reading real_parent in do_task_stat() Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 080/147] net: atm: fix crash due to unvalidated vcc pointer in sigd_send() Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 081/147] serial: caif: fix use-after-free in caif_serial ldisc_close() Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 082/147] ionic: Rate limit unknown xcvr type messages Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 083/147] RDMA/rtrs: server: remove dead code Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 084/147] power: supply: act8945a: Fix use-after-free in power_supply_changed() Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 085/147] power: supply: bq25980: " Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 086/147] power: supply: cpcap-battery: " Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 087/147] power: supply: goldfish: " Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 088/147] power: supply: rt9455: " Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 089/147] power: supply: sbs-battery: " Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 090/147] power: reset: nvmem-reboot-mode: respect cell size for nvmem_cell_write Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 091/147] power: supply: bq27xxx: fix wrong errno when bus ops are unsupported Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 092/147] power: supply: wm97xx_battery: Convert to GPIO descriptor Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 093/147] power: supply: wm97xx: Fix NULL pointer dereference in power_supply_changed() Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 094/147] RDMA/rxe: Fix double free in rxe_srq_from_init Sasha Levin
2026-03-23 12:37   ` Ben Hutchings
2026-03-23 18:15     ` Yanjun.Zhu
2026-02-28 18:16 ` [PATCH 5.10 095/147] mtd: rawnand: cadence: Fix return type of CDMA send-and-wait helper Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 096/147] PM: core: Redefine pm_ptr() macro Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 097/147] PM: core: Add new *_PM_OPS macros, deprecate old ones Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 098/147] crypto: ccp - Add an S4 restore flow Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 099/147] RDMA/uverbs: Validate wqe_size before using it in ib_uverbs_post_send Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 100/147] svcrdma: Add a batch Receive posting mechanism Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 101/147] svcrdma: Use svc_rdma_refresh_recvs() in wc_receive Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 102/147] svcrdma: Maintain a Receive water mark Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 103/147] RDMA/core: Fix a couple of obvious typos in comments Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 104/147] svcrdma: Remove queue-shortening warnings Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 105/147] svcrdma: Clean up comment in svc_rdma_accept() Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 106/147] svcrdma: Increase the per-transport rw_ctx count Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 107/147] svcrdma: Reduce the number of rdma_rw contexts per-QP Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 108/147] RDMA/core: add rdma_rw_max_sge() helper for SQ sizing Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 109/147] RDMA/uverbs: Add __GFP_NOWARN to ib_uverbs_unmarshall_recv() kmalloc Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 110/147] pNFS: fix a missing wake up while waiting on NFS_LAYOUT_DRAIN Sasha Levin
2026-02-28 18:16 ` [PATCH 5.10 111/147] scsi: csiostor: Fix dereference of null pointer rn Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 112/147] nvdimm: virtio_pmem: serialize flush requests Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 113/147] tracing: Remove duplicate ENABLE_EVENT_STR and DISABLE_EVENT_STR macros Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 114/147] fbdev: au1200fb: Fix a memory leak in au1200fb_drv_probe() Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 115/147] clk: meson: gxbb: Limit the HDMI PLL OD to /4 on GXL/GXM SoCs Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 116/147] clk: Move clk_{save,restore}_context() to COMMON_CLK section Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 117/147] clk: qcom: dispcc-sdm845: convert to parent data Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 118/147] clk: qcom: dispcc-sdm845: Enable parents for pixel clocks Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 119/147] dmaengine: mediatek: uart-apdma: Fix above 4G addressing TX/RX Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 120/147] dma: dma-axi-dmac: fix SW cyclic transfers Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 121/147] staging: greybus: lights: avoid NULL deref Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 122/147] serial: imx: change SERIAL_IMX_CONSOLE to bool Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 123/147] serial: SH_SCI: improve "DMA support" prompt Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 124/147] mmc: core: Initial support for SD express card/host Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 125/147] misc: rtsx: Add SD Express mode support for RTS5261 Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 126/147] mmc: rtsx_pci_sdmmc: increase power-on settling delay to 5ms Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 127/147] coresight: etm3x: Fix cpulocked warning on cpuhp Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 128/147] Revert "mmc: rtsx_pci_sdmmc: increase power-on settling delay to 5ms" Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 129/147] mfd: arizona: Fix regulator resource leak on wm5102_clear_write_sequencer() failure Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 130/147] drivers: iio: mpu3050: use dev_err_probe for regulator request Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 131/147] usb: bdc: fix sleep during atomic Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 132/147] pinctrl: equilibrium: Fix device node reference leak in pinbank_init() Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 133/147] ovl: Fix uninit-value in ovl_fill_real Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 134/147] iio: sca3000: Fix a resource leak in sca3000_probe() Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 135/147] pinctrl: single: fix refcount leak in pcs_add_gpio_func() Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 136/147] cpuidle: Skip governor when only one idle state is available Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 137/147] selftests: mlxsw: tc_restrictions: Fix test failure with new iproute2 Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 138/147] usbb: catc: use correct API for MAC addresses Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 139/147] net: usb: catc: enable basic endpoint checking Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 140/147] xen-netback: reject zero-queue configuration from guest Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 141/147] net/rds: rds_sendmsg should not discard payload_len Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 142/147] selftests: forwarding: vxlan_bridge_1d: fix test failure with br_netfilter enabled Sasha Levin
2026-03-23 18:48   ` Ben Hutchings
2026-02-28 18:17 ` [PATCH 5.10 143/147] netfilter: nf_conntrack_h323: don't pass uninitialised l3num value Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 144/147] ipv6: fix a race in ip6_sock_set_v6only() Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 145/147] selftests: forwarding: tc_actions: cleanup temporary files when test is aborted Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 146/147] selftests: forwarding: tc_actions: Use ncat instead of nc Sasha Levin
2026-02-28 18:17 ` [PATCH 5.10 147/147] Linux 5.10.252-rc1 Sasha Levin

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20260228181736.1605592-39-sashal@kernel.org \
    --to=sashal@kernel.org \
    --cc=maddy@linux.ibm.com \
    --cc=mahesh@linux.ibm.com \
    --cc=nnmlinux@linux.ibm.com \
    --cc=patches@lists.linux.dev \
    --cc=sourabhjain@linux.ibm.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox