Changelog in Linux kernel 6.6.114

 
accel/qaic: Treat remaining == 0 as error in find_and_map_user_pages() [+ + +]
Author: Youssef Samir <quic_yabdulra@quicinc.com>
Date:   Tue Oct 7 14:23:20 2025 +0200

    accel/qaic: Treat remaining == 0 as error in find_and_map_user_pages()
    
    [ Upstream commit 11f08c30a3e4157305ba692f1d44cca5fc9a8fca ]
    
    Currently, if find_and_map_user_pages() takes a DMA xfer request from the
    user with a length field set to 0, or in a rare case, the host receives
    QAIC_TRANS_DMA_XFER_CONT from the device where resources->xferred_dma_size
    is equal to the requested transaction size, the function will return 0
    before allocating an sgt or setting the fields of the dma_xfer struct.
    In that case, encode_addr_size_pairs() will try to access the sgt which
    will lead to a general protection fault.
    
    Return an EINVAL in case the user provides a zero-sized ALP, or the device
    requests continuation after all of the bytes have been transferred.
    
    Fixes: 96d3c1cadedb ("accel/qaic: Clean up integer overflow checking in map_user_pages()")
    Signed-off-by: Youssef Samir <quic_yabdulra@quicinc.com>
    Signed-off-by: Youssef Samir <youssef.abdulrahman@oss.qualcomm.com>
    Reviewed-by: Jeff Hugo <jeff.hugo@oss.qualcomm.com>
    Reviewed-by: Carl Vanderlip <carl.vanderlip@oss.qualcomm.com>
    Signed-off-by: Jeff Hugo <jeff.hugo@oss.qualcomm.com>
    Link: https://lore.kernel.org/r/20251007122320.339654-1-youssef.abdulrahman@oss.qualcomm.com
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
ALSA: firewire: amdtp-stream: fix enum kernel-doc warnings [+ + +]
Author: Randy Dunlap <rdunlap@infradead.org>
Date:   Mon Oct 13 20:05:52 2025 -0700

    ALSA: firewire: amdtp-stream: fix enum kernel-doc warnings
    
    [ Upstream commit d41f68dff783d181a8fd462e612bda0fbab7f735 ]
    
    Fix spelling of CIP_NO_HEADER to prevent a kernel-doc warning.
    
    Warning: amdtp-stream.h:57 Enum value 'CIP_NO_HEADER' not described in enum 'cip_flags'
    Warning: amdtp-stream.h:57 Excess enum value '%CIP_NO_HEADERS' description in 'cip_flags'
    
    Fixes: 3b196c394dd9f ("ALSA: firewire-lib: add no-header packet processing")
    Signed-off-by: Randy Dunlap <rdunlap@infradead.org>
    Reviewed-by: Takashi Sakamoto <o-takashi@sakamocchi.jp>
    Signed-off-by: Takashi Iwai <tiwai@suse.de>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

ALSA: usb-audio: Fix NULL pointer deference in try_to_register_card [+ + +]
Author: Jiaming Zhang <r772577952@gmail.com>
Date:   Wed Oct 15 13:16:45 2025 +0800

    ALSA: usb-audio: Fix NULL pointer deference in try_to_register_card
    
    [ Upstream commit 28412b489b088fb88dff488305fd4e56bd47f6e4 ]
    
    In try_to_register_card(), the return value of usb_ifnum_to_if() is
    passed directly to usb_interface_claimed() without a NULL check, which
    will lead to a NULL pointer dereference when creating an invalid
    USB audio device. Fix this by adding a check to ensure the interface
    pointer is valid before passing it to usb_interface_claimed().
    
    Fixes: 39efc9c8a973 ("ALSA: usb-audio: Fix last interface check for registration")
    Closes: https://lore.kernel.org/all/CANypQFYtQxHL5ghREs-BujZG413RPJGnO5TH=xjFBKpPts33tA@mail.gmail.com/
    Signed-off-by: Jiaming Zhang <r772577952@gmail.com>
    Signed-off-by: Takashi Iwai <tiwai@suse.de>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
amd-xgbe: Avoid spurious link down messages during interface toggle [+ + +]
Author: Raju Rangoju <Raju.Rangoju@amd.com>
Date:   Fri Oct 10 12:21:42 2025 +0530

    amd-xgbe: Avoid spurious link down messages during interface toggle
    
    [ Upstream commit 2616222e423398bb374ffcb5d23dea4ba2c3e524 ]
    
    During interface toggle operations (ifdown/ifup), the driver currently
    resets the local helper variable 'phy_link' to -1. This causes the link
    state machine to incorrectly interpret the state as a link change event,
    resulting in spurious "Link is down" messages being logged when the
    interface is brought back up.
    
    Preserve the phy_link state across interface toggles to avoid treating
    the -1 sentinel value as a legitimate link state transition.
    
    Fixes: 88131a812b16 ("amd-xgbe: Perform phy connect/disconnect at dev open/stop")
    Signed-off-by: Raju Rangoju <Raju.Rangoju@amd.com>
    Reviewed-by: Dawid Osuchowski <dawid.osuchowski@linux.intel.com>
    Link: https://patch.msgid.link/20251010065142.1189310-1-Raju.Rangoju@amd.com
    Signed-off-by: Paolo Abeni <pabeni@redhat.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
arm64: cputype: Add Neoverse-V3AE definitions [+ + +]
Author: Mark Rutland <mark.rutland@arm.com>
Date:   Fri Sep 19 15:58:28 2025 +0100

    arm64: cputype: Add Neoverse-V3AE definitions
    
    commit 3bbf004c4808e2c3241e5c1ad6cc102f38a03c39 upstream.
    
    Add cputype definitions for Neoverse-V3AE. These will be used for errata
    detection in subsequent patches.
    
    These values can be found in the Neoverse-V3AE TRM:
    
      https://developer.arm.com/documentation/SDEN-2615521/9-0/
    
    ... in section A.6.1 ("MIDR_EL1, Main ID Register").
    
    Signed-off-by: Mark Rutland <mark.rutland@arm.com>
    Cc: James Morse <james.morse@arm.com>
    Cc: Will Deacon <will@kernel.org>
    Cc: Catalin Marinas <catalin.marinas@arm.com>
    Signed-off-by: Ryan Roberts <ryan.roberts@arm.com>
    Signed-off-by: Will Deacon <will@kernel.org>
    Signed-off-by: Ryan Roberts <ryan.roberts@arm.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

arm64: errata: Apply workarounds for Neoverse-V3AE [+ + +]
Author: Mark Rutland <mark.rutland@arm.com>
Date:   Fri Sep 19 15:58:29 2025 +0100

    arm64: errata: Apply workarounds for Neoverse-V3AE
    
    commit 0c33aa1804d101c11ba1992504f17a42233f0e11 upstream.
    
    Neoverse-V3AE is also affected by erratum #3312417, as described in its
    Software Developer Errata Notice (SDEN) document:
    
      Neoverse V3AE (MP172) SDEN v9.0, erratum 3312417
      https://developer.arm.com/documentation/SDEN-2615521/9-0/
    
    Enable the workaround for Neoverse-V3AE, and document this.
    
    Signed-off-by: Mark Rutland <mark.rutland@arm.com>
    Cc: James Morse <james.morse@arm.com>
    Cc: Will Deacon <will@kernel.org>
    Cc: Catalin Marinas <catalin.marinas@arm.com>
    Signed-off-by: Ryan Roberts <ryan.roberts@arm.com>
    Signed-off-by: Will Deacon <will@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
ASoC: codecs: Fix gain setting ranges for Renesas IDT821034 codec [+ + +]
Author: Christophe Leroy <christophe.leroy@csgroup.eu>
Date:   Thu Oct 9 19:03:13 2025 +0200

    ASoC: codecs: Fix gain setting ranges for Renesas IDT821034 codec
    
    [ Upstream commit 6370a996f308ea3276030769b7482b346e7cc7c1 ]
    
    The gain ranges specified in Renesas IDT821034 codec documentation
    are [-3dB;+13dB] in the transmit path (ADC) and [-13dB;+3dB] in the
    receive path (DAC). Allthough the registers allow programming values
    outside those ranges, the signal S/N and distorsion are only
    guaranteed in the specified ranges.
    
    Set ranges to the specified ones.
    
    Fixes: e51166990e81 ("ASoC: codecs: Add support for the Renesas IDT821034 codec")
    Signed-off-by: Christophe Leroy <christophe.leroy@csgroup.eu>
    Link: https://patch.msgid.link/2bd547194f3398e6182f770d7d6be711c702b4b2.1760029099.git.christophe.leroy@csgroup.eu
    Signed-off-by: Mark Brown <broonie@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

ASoC: nau8821: Add DMI quirk to bypass jack debounce circuit [+ + +]
Author: Cristian Ciocaltea <cristian.ciocaltea@collabora.com>
Date:   Fri Oct 3 21:03:26 2025 +0300

    ASoC: nau8821: Add DMI quirk to bypass jack debounce circuit
    
    [ Upstream commit 2b4eda7bf7d8a4e2f7575a98f55d8336dec0f302 ]
    
    Stress testing the audio jack hotplug handling on a few Steam Deck units
    revealed that the debounce circuit is responsible for having a negative
    impact on the detection reliability, e.g. in some cases the ejection
    interrupt is not fired, while in other instances it goes into a kind of
    invalid state and generates a flood of misleading interrupts.
    
    Add new entries to the DMI table introduced via commit 1bc40efdaf4a
    ("ASoC: nau8821: Add DMI quirk mechanism for active-high jack-detect")
    and extend the quirk logic to allow bypassing the debounce circuit used
    for jack detection on Valve Steam Deck LCD and OLED models.
    
    While at it, rename existing NAU8821_JD_ACTIVE_HIGH quirk bitfield to
    NAU8821_QUIRK_JD_ACTIVE_HIGH.  This should help improve code readability
    by differentiating from similarly named register bits.
    
    Fixes: aab1ad11d69f ("ASoC: nau8821: new driver")
    Signed-off-by: Cristian Ciocaltea <cristian.ciocaltea@collabora.com>
    Link: https://patch.msgid.link/20251003-nau8821-jdet-fixes-v1-4-f7b0e2543f09@collabora.com
    Signed-off-by: Mark Brown <broonie@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

ASoC: nau8821: Cancel jdet_work before handling jack ejection [+ + +]
Author: Cristian Ciocaltea <cristian.ciocaltea@collabora.com>
Date:   Fri Oct 3 21:03:23 2025 +0300

    ASoC: nau8821: Cancel jdet_work before handling jack ejection
    
    [ Upstream commit 6e54919cb541fdf1063b16f3254c28d01bc9e5ff ]
    
    The microphone detection work scheduled by a prior jack insertion
    interrupt may still be in a pending state or under execution when a jack
    ejection interrupt has been fired.
    
    This might lead to a racing condition or nau8821_jdet_work() completing
    after nau8821_eject_jack(), which will override the currently
    disconnected state of the jack and incorrectly report the headphone or
    the headset as being connected.
    
    Cancel any pending jdet_work or wait for its execution to finish before
    attempting to handle the ejection interrupt.
    
    Proceed similarly before launching the eject handler as a consequence of
    detecting an invalid insert interrupt.
    
    Fixes: aab1ad11d69f ("ASoC: nau8821: new driver")
    Signed-off-by: Cristian Ciocaltea <cristian.ciocaltea@collabora.com>
    Link: https://patch.msgid.link/20251003-nau8821-jdet-fixes-v1-1-f7b0e2543f09@collabora.com
    Signed-off-by: Mark Brown <broonie@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

ASoC: nau8821: Generalize helper to clear IRQ status [+ + +]
Author: Cristian Ciocaltea <cristian.ciocaltea@collabora.com>
Date:   Fri Oct 3 21:03:24 2025 +0300

    ASoC: nau8821: Generalize helper to clear IRQ status
    
    [ Upstream commit 9273aa85b35cc02d0953a1ba3b7bd694e5a2c10e ]
    
    Instead of adding yet another utility function for dealing with the
    interrupt clearing register, generalize nau8821_int_status_clear_all()
    by renaming it to nau8821_irq_status_clear(), whilst introducing a
    second parameter to allow restricting the operation scope to a single
    interrupt instead of the whole range of active IRQs.
    
    While at it, also fix a spelling typo in the comment block.
    
    Note this is mainly a prerequisite for subsequent patches aiming to
    address some deficiencies in the implementation of the interrupt
    handler.  Thus the presence of the Fixes tag below is intentional, to
    facilitate backporting.
    
    Fixes: aab1ad11d69f ("ASoC: nau8821: new driver")
    Signed-off-by: Cristian Ciocaltea <cristian.ciocaltea@collabora.com>
    Link: https://patch.msgid.link/20251003-nau8821-jdet-fixes-v1-2-f7b0e2543f09@collabora.com
    Signed-off-by: Mark Brown <broonie@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
block: fix race between set_blocksize and read paths [+ + +]
Author: Darrick J. Wong <djwong@kernel.org>
Date:   Wed Apr 23 12:53:42 2025 -0700

    block: fix race between set_blocksize and read paths
    
    commit c0e473a0d226479e8e925d5ba93f751d8df628e9 upstream.
    
    With the new large sector size support, it's now the case that
    set_blocksize can change i_blksize and the folio order in a manner that
    conflicts with a concurrent reader and causes a kernel crash.
    
    Specifically, let's say that udev-worker calls libblkid to detect the
    labels on a block device.  The read call can create an order-0 folio to
    read the first 4096 bytes from the disk.  But then udev is preempted.
    
    Next, someone tries to mount an 8k-sectorsize filesystem from the same
    block device.  The filesystem calls set_blksize, which sets i_blksize to
    8192 and the minimum folio order to 1.
    
    Now udev resumes, still holding the order-0 folio it allocated.  It then
    tries to schedule a read bio and do_mpage_readahead tries to create
    bufferheads for the folio.  Unfortunately, blocks_per_folio == 0 because
    the page size is 4096 but the blocksize is 8192 so no bufferheads are
    attached and the bh walk never sets bdev.  We then submit the bio with a
    NULL block device and crash.
    
    Therefore, truncate the page cache after flushing but before updating
    i_blksize.  However, that's not enough -- we also need to lock out file
    IO and page faults during the update.  Take both the i_rwsem and the
    invalidate_lock in exclusive mode for invalidations, and in shared mode
    for read/write operations.
    
    I don't know if this is the correct fix, but xfs/259 found it.
    
    Signed-off-by: Darrick J. Wong <djwong@kernel.org>
    Reviewed-by: Christoph Hellwig <hch@lst.de>
    Reviewed-by: Luis Chamberlain <mcgrof@kernel.org>
    Tested-by: Shin'ichiro Kawasaki <shinichiro.kawasaki@wdc.com>
    Link: https://lore.kernel.org/r/174543795699.4139148.2086129139322431423.stgit@frogsfrogsfrogs
    Signed-off-by: Jens Axboe <axboe@kernel.dk>
    [ use bdev->bd_inode instead ]
    Signed-off-by: Mahmoud Adam <mngyadam@amazon.de>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
Bluetooth: btusb: Add USB ID 2001:332a for D-Link AX9U rev. A1 [+ + +]
Author: Zenm Chen <zenmchen@gmail.com>
Date:   Sat Jul 26 00:14:32 2025 +0800

    Bluetooth: btusb: Add USB ID 2001:332a for D-Link AX9U rev. A1
    
    commit 34ecb8760190606472f71ebf4ca2817928ce5d40 upstream.
    
    Add USB ID 2001:332a for D-Link AX9U rev. A1 which is based on a Realtek
    RTL8851BU chip.
    
    The information in /sys/kernel/debug/usb/devices about the Bluetooth
    device is listed as the below:
    
    T:  Bus=03 Lev=01 Prnt=01 Port=02 Cnt=01 Dev#=  2 Spd=480  MxCh= 0
    D:  Ver= 2.00 Cls=ef(misc ) Sub=02 Prot=01 MxPS=64 #Cfgs=  1
    P:  Vendor=2001 ProdID=332a Rev= 0.00
    S:  Manufacturer=Realtek
    S:  Product=802.11ax WLAN Adapter
    S:  SerialNumber=00e04c000001
    C:* #Ifs= 3 Cfg#= 1 Atr=e0 MxPwr=500mA
    A:  FirstIf#= 0 IfCount= 2 Cls=e0(wlcon) Sub=01 Prot=01
    I:* If#= 0 Alt= 0 #EPs= 3 Cls=e0(wlcon) Sub=01 Prot=01 Driver=btusb
    E:  Ad=81(I) Atr=03(Int.) MxPS=  16 Ivl=1ms
    E:  Ad=02(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
    E:  Ad=82(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
    I:* If#= 1 Alt= 0 #EPs= 2 Cls=e0(wlcon) Sub=01 Prot=01 Driver=btusb
    E:  Ad=03(O) Atr=01(Isoc) MxPS=   0 Ivl=1ms
    E:  Ad=83(I) Atr=01(Isoc) MxPS=   0 Ivl=1ms
    I:  If#= 1 Alt= 1 #EPs= 2 Cls=e0(wlcon) Sub=01 Prot=01 Driver=btusb
    E:  Ad=03(O) Atr=01(Isoc) MxPS=   9 Ivl=1ms
    E:  Ad=83(I) Atr=01(Isoc) MxPS=   9 Ivl=1ms
    I:  If#= 1 Alt= 2 #EPs= 2 Cls=e0(wlcon) Sub=01 Prot=01 Driver=btusb
    E:  Ad=03(O) Atr=01(Isoc) MxPS=  17 Ivl=1ms
    E:  Ad=83(I) Atr=01(Isoc) MxPS=  17 Ivl=1ms
    I:  If#= 1 Alt= 3 #EPs= 2 Cls=e0(wlcon) Sub=01 Prot=01 Driver=btusb
    E:  Ad=03(O) Atr=01(Isoc) MxPS=  25 Ivl=1ms
    E:  Ad=83(I) Atr=01(Isoc) MxPS=  25 Ivl=1ms
    I:  If#= 1 Alt= 4 #EPs= 2 Cls=e0(wlcon) Sub=01 Prot=01 Driver=btusb
    E:  Ad=03(O) Atr=01(Isoc) MxPS=  33 Ivl=1ms
    E:  Ad=83(I) Atr=01(Isoc) MxPS=  33 Ivl=1ms
    I:  If#= 1 Alt= 5 #EPs= 2 Cls=e0(wlcon) Sub=01 Prot=01 Driver=btusb
    E:  Ad=03(O) Atr=01(Isoc) MxPS=  49 Ivl=1ms
    E:  Ad=83(I) Atr=01(Isoc) MxPS=  49 Ivl=1ms
    I:  If#= 1 Alt= 6 #EPs= 2 Cls=e0(wlcon) Sub=01 Prot=01 Driver=btusb
    E:  Ad=03(O) Atr=01(Isoc) MxPS=  63 Ivl=1ms
    E:  Ad=83(I) Atr=01(Isoc) MxPS=  63 Ivl=1ms
    I:* If#= 2 Alt= 0 #EPs= 8 Cls=ff(vend.) Sub=ff Prot=ff Driver=rtw89_8851bu_git
    E:  Ad=84(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
    E:  Ad=05(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
    E:  Ad=06(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
    E:  Ad=07(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
    E:  Ad=09(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
    E:  Ad=0a(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
    E:  Ad=0b(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
    E:  Ad=0c(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
    
    Cc: stable@vger.kernel.org # 6.12.x
    Signed-off-by: Zenm Chen <zenmchen@gmail.com>
    Reviewed-by: Paul Menzel <pmenzel@molgen.mpg.de>
    Signed-off-by: Luiz Augusto von Dentz <luiz.von.dentz@intel.com>
    Signed-off-by: Zenm Chen <zenmchen@gmail.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
btrfs: do not assert we found block group item when creating free space tree [+ + +]
Author: Filipe Manana <fdmanana@suse.com>
Date:   Wed Oct 1 11:08:13 2025 +0100

    btrfs: do not assert we found block group item when creating free space tree
    
    commit a5a51bf4e9b7354ce7cd697e610d72c1b33fd949 upstream.
    
    Currently, when building a free space tree at populate_free_space_tree(),
    if we are not using the block group tree feature, we always expect to find
    block group items (either extent items or a block group item with key type
    BTRFS_BLOCK_GROUP_ITEM_KEY) when we search the extent tree with
    btrfs_search_slot_for_read(), so we assert that we found an item. However
    this expectation is wrong since we can have a new block group created in
    the current transaction which is still empty and for which we still have
    not added the block group's item to the extent tree, in which case we do
    not have any items in the extent tree associated to the block group.
    
    The insertion of a new block group's block group item in the extent tree
    happens at btrfs_create_pending_block_groups() when it calls the helper
    insert_block_group_item(). This typically is done when a transaction
    handle is released, committed or when running delayed refs (either as
    part of a transaction commit or when serving tickets for space reservation
    if we are low on free space).
    
    So remove the assertion at populate_free_space_tree() even when the block
    group tree feature is not enabled and update the comment to mention this
    case.
    
    Syzbot reported this with the following stack trace:
    
      BTRFS info (device loop3 state M): rebuilding free space tree
      assertion failed: ret == 0 :: 0, in fs/btrfs/free-space-tree.c:1115
      ------------[ cut here ]------------
      kernel BUG at fs/btrfs/free-space-tree.c:1115!
      Oops: invalid opcode: 0000 [#1] SMP KASAN PTI
      CPU: 1 UID: 0 PID: 6352 Comm: syz.3.25 Not tainted syzkaller #0 PREEMPT(full)
      Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 08/18/2025
      RIP: 0010:populate_free_space_tree+0x700/0x710 fs/btrfs/free-space-tree.c:1115
      Code: ff ff e8 d3 (...)
      RSP: 0018:ffffc9000430f780 EFLAGS: 00010246
      RAX: 0000000000000043 RBX: ffff88805b709630 RCX: fea61d0e2e79d000
      RDX: 0000000000000000 RSI: 0000000080000000 RDI: 0000000000000000
      RBP: ffffc9000430f8b0 R08: ffffc9000430f4a7 R09: 1ffff92000861e94
      R10: dffffc0000000000 R11: fffff52000861e95 R12: 0000000000000001
      R13: 1ffff92000861f00 R14: dffffc0000000000 R15: 0000000000000000
      FS:  00007f424d9fe6c0(0000) GS:ffff888125afc000(0000) knlGS:0000000000000000
      CS:  0010 DS: 0000 ES: 0000 CR0: 0000000080050033
      CR2: 00007fd78ad212c0 CR3: 0000000076d68000 CR4: 00000000003526f0
      Call Trace:
       <TASK>
       btrfs_rebuild_free_space_tree+0x1ba/0x6d0 fs/btrfs/free-space-tree.c:1364
       btrfs_start_pre_rw_mount+0x128f/0x1bf0 fs/btrfs/disk-io.c:3062
       btrfs_remount_rw fs/btrfs/super.c:1334 [inline]
       btrfs_reconfigure+0xaed/0x2160 fs/btrfs/super.c:1559
       reconfigure_super+0x227/0x890 fs/super.c:1076
       do_remount fs/namespace.c:3279 [inline]
       path_mount+0xd1a/0xfe0 fs/namespace.c:4027
       do_mount fs/namespace.c:4048 [inline]
       __do_sys_mount fs/namespace.c:4236 [inline]
       __se_sys_mount+0x313/0x410 fs/namespace.c:4213
       do_syscall_x64 arch/x86/entry/syscall_64.c:63 [inline]
       do_syscall_64+0xfa/0xfa0 arch/x86/entry/syscall_64.c:94
       entry_SYSCALL_64_after_hwframe+0x77/0x7f
       RIP: 0033:0x7f424e39066a
      Code: d8 64 89 02 (...)
      RSP: 002b:00007f424d9fde68 EFLAGS: 00000246 ORIG_RAX: 00000000000000a5
      RAX: ffffffffffffffda RBX: 00007f424d9fdef0 RCX: 00007f424e39066a
      RDX: 0000200000000180 RSI: 0000200000000380 RDI: 0000000000000000
      RBP: 0000200000000180 R08: 00007f424d9fdef0 R09: 0000000000000020
      R10: 0000000000000020 R11: 0000000000000246 R12: 0000200000000380
      R13: 00007f424d9fdeb0 R14: 0000000000000000 R15: 00002000000002c0
       </TASK>
      Modules linked in:
      ---[ end trace 0000000000000000 ]---
    
    Reported-by: syzbot+884dc4621377ba579a6f@syzkaller.appspotmail.com
    Link: https://lore.kernel.org/linux-btrfs/68dc3dab.a00a0220.102ee.004e.GAE@google.com/
    Fixes: a5ed91828518 ("Btrfs: implement the free space B-tree")
    CC: <stable@vger.kernel.org> # 6.1.x: 1961d20f6fa8: btrfs: fix assertion when building free space tree
    CC: <stable@vger.kernel.org> # 6.1.x
    Reviewed-by: Qu Wenruo <wqu@suse.com>
    Signed-off-by: Filipe Manana <fdmanana@suse.com>
    Signed-off-by: David Sterba <dsterba@suse.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

btrfs: fix clearing of BTRFS_FS_RELOC_RUNNING if relocation already running [+ + +]
Author: Filipe Manana <fdmanana@suse.com>
Date:   Wed Sep 24 16:10:38 2025 +0100

    btrfs: fix clearing of BTRFS_FS_RELOC_RUNNING if relocation already running
    
    commit 7e5a5983edda664e8e4bb20af17b80f5135c655c upstream.
    
    When starting relocation, at reloc_chunk_start(), if we happen to find
    the flag BTRFS_FS_RELOC_RUNNING is already set we return an error
    (-EINPROGRESS) to the callers, however the callers call reloc_chunk_end()
    which will clear the flag BTRFS_FS_RELOC_RUNNING, which is wrong since
    relocation was started by another task and still running.
    
    Finding the BTRFS_FS_RELOC_RUNNING flag already set is an unexpected
    scenario, but still our current behaviour is not correct.
    
    Fix this by never calling reloc_chunk_end() if reloc_chunk_start() has
    returned an error, which is what logically makes sense, since the general
    widespread pattern is to have end functions called only if the counterpart
    start functions succeeded. This requires changing reloc_chunk_start() to
    clear BTRFS_FS_RELOC_RUNNING if there's a pending cancel request.
    
    Fixes: 907d2710d727 ("btrfs: add cancellable chunk relocation support")
    CC: stable@vger.kernel.org # 5.15+
    Reviewed-by: Boris Burkov <boris@bur.io>
    Reviewed-by: Johannes Thumshirn <johannes.thumshirn@wdc.com>
    Reviewed-by: Qu Wenruo <wqu@suse.com>
    Signed-off-by: Filipe Manana <fdmanana@suse.com>
    Reviewed-by: David Sterba <dsterba@suse.com>
    Signed-off-by: David Sterba <dsterba@suse.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

btrfs: fix incorrect readahead expansion length [+ + +]
Author: Boris Burkov <boris@bur.io>
Date:   Tue Sep 30 21:05:17 2025 -0700

    btrfs: fix incorrect readahead expansion length
    
    commit 8ab2fa69691b2913a67f3c54fbb991247b3755be upstream.
    
    The intent of btrfs_readahead_expand() was to expand to the length of
    the current compressed extent being read. However, "ram_bytes" is *not*
    that, in the case where a single physical compressed extent is used for
    multiple file extents.
    
    Consider this case with a large compressed extent C and then later two
    non-compressed extents N1 and N2 written over C, leaving C1 and C2
    pointing to offset/len pairs of C:
    
    [               C                 ]
    [ N1 ][     C1     ][ N2 ][   C2  ]
    
    In such a case, ram_bytes for both C1 and C2 is the full uncompressed
    length of C. So starting readahead in C1 will expand the readahead past
    the end of C1, past N2, and into C2. This will then expand readahead
    again, to C2_start + ram_bytes, way past EOF. First of all, this is
    totally undesirable, we don't want to read the whole file in arbitrary
    chunks of the large underlying extent if it happens to exist. Secondly,
    it results in zeroing the range past the end of C2 up to ram_bytes. This
    is particularly unpleasant with fs-verity as it can zero and set
    uptodate pages in the verity virtual space past EOF. This incorrect
    readahead behavior can lead to verity verification errors, if we iterate
    in a way that happens to do the wrong readahead.
    
    Fix this by using em->len for readahead expansion, not em->ram_bytes,
    resulting in the expected behavior of stopping readahead at the extent
    boundary.
    
    Reported-by: Max Chernoff <git@maxchernoff.ca>
    Link: https://bugzilla.redhat.com/show_bug.cgi?id=2399898
    Fixes: 9e9ff875e417 ("btrfs: use readahead_expand() on compressed extents")
    CC: stable@vger.kernel.org # 6.17
    Reviewed-by: Filipe Manana <fdmanana@suse.com>
    Signed-off-by: Boris Burkov <boris@bur.io>
    Signed-off-by: David Sterba <dsterba@suse.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
can: gs_usb: gs_make_candev(): populate net_device->dev_port [+ + +]
Author: Celeste Liu <uwu@coelacanthus.name>
Date:   Tue Sep 30 14:53:39 2025 +0800

    can: gs_usb: gs_make_candev(): populate net_device->dev_port
    
    commit a12f0bc764da3781da2019c60826f47a6d7ed64f upstream.
    
    The gs_usb driver supports USB devices with more than 1 CAN channel.
    In old kernel before 3.15, it uses net_device->dev_id to distinguish
    different channel in userspace, which was done in commit
    acff76fa45b4 ("can: gs_usb: gs_make_candev(): set netdev->dev_id").
    But since 3.15, the correct way is populating net_device->dev_port.
    And according to documentation, if network device support multiple
    interface, lack of net_device->dev_port SHALL be treated as a bug.
    
    Fixes: acff76fa45b4 ("can: gs_usb: gs_make_candev(): set netdev->dev_id")
    Cc: stable@vger.kernel.org
    Signed-off-by: Celeste Liu <uwu@coelacanthus.name>
    Link: https://patch.msgid.link/20250930-gs-usb-populate-net_device-dev_port-v1-1-68a065de6937@coelacanthus.name
    Signed-off-by: Marc Kleine-Budde <mkl@pengutronix.de>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

can: gs_usb: increase max interface to U8_MAX [+ + +]
Author: Celeste Liu <uwu@coelacanthus.name>
Date:   Tue Sep 30 19:34:28 2025 +0800

    can: gs_usb: increase max interface to U8_MAX
    
    commit 2a27f6a8fb5722223d526843040f747e9b0e8060 upstream.
    
    This issue was found by Runcheng Lu when develop HSCanT USB to CAN FD
    converter[1]. The original developers may have only 3 interfaces
    device to test so they write 3 here and wait for future change.
    
    During the HSCanT development, we actually used 4 interfaces, so the
    limitation of 3 is not enough now. But just increase one is not
    future-proofed. Since the channel index type in gs_host_frame is u8,
    just make canch[] become a flexible array with a u8 index, so it
    naturally constraint by U8_MAX and avoid statically allocate 256
    pointer for every gs_usb device.
    
    [1]: https://github.com/cherry-embedded/HSCanT-hardware
    
    Fixes: d08e973a77d1 ("can: gs_usb: Added support for the GS_USB CAN devices")
    Reported-by: Runcheng Lu <runcheng.lu@hpmicro.com>
    Cc: stable@vger.kernel.org
    Reviewed-by: Vincent Mailhol <mailhol@kernel.org>
    Signed-off-by: Celeste Liu <uwu@coelacanthus.name>
    Link: https://patch.msgid.link/20250930-gs-usb-max-if-v5-1-863330bf6666@coelacanthus.name
    Signed-off-by: Marc Kleine-Budde <mkl@pengutronix.de>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

can: m_can: m_can_plat_remove(): add missing pm_runtime_disable() [+ + +]
Author: Marc Kleine-Budde <mkl@pengutronix.de>
Date:   Wed Aug 6 17:46:32 2025 +0200

    can: m_can: m_can_plat_remove(): add missing pm_runtime_disable()
    
    [ Upstream commit ba569fb07a7e9e9b71e9282e27e993ba859295c2 ]
    
    Commit 227619c3ff7c ("can: m_can: move runtime PM enable/disable to
    m_can_platform") moved the PM runtime enable from the m_can core
    driver into the m_can_platform.
    
    That patch forgot to move the pm_runtime_disable() to
    m_can_plat_remove(), so that unloading the m_can_platform driver
    causes an "Unbalanced pm_runtime_enable!" error message.
    
    Add the missing pm_runtime_disable() to m_can_plat_remove() to fix the
    problem.
    
    Cc: Patrik Flykt <patrik.flykt@linux.intel.com>
    Fixes: 227619c3ff7c ("can: m_can: move runtime PM enable/disable to m_can_platform")
    Reviewed-by: Markus Schneider-Pargmann <msp@baylibre.com>
    Link: https://patch.msgid.link/20250929-m_can-fix-state-handling-v4-1-682b49b49d9a@pengutronix.de
    Signed-off-by: Marc Kleine-Budde <mkl@pengutronix.de>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
cifs: parse_dfs_referrals: prevent oob on malformed input [+ + +]
Author: Eugene Korenevsky <ekorenevsky@aliyun.com>
Date:   Mon Oct 13 21:39:30 2025 +0300

    cifs: parse_dfs_referrals: prevent oob on malformed input
    
    commit 6447b0e355562a1ff748c4a2ffb89aae7e84d2c9 upstream.
    
    Malicious SMB server can send invalid reply to FSCTL_DFS_GET_REFERRALS
    
    - reply smaller than sizeof(struct get_dfs_referral_rsp)
    - reply with number of referrals smaller than NumberOfReferrals in the
    header
    
    Processing of such replies will cause oob.
    
    Return -EINVAL error on such replies to prevent oob-s.
    
    Signed-off-by: Eugene Korenevsky <ekorenevsky@aliyun.com>
    Cc: stable@vger.kernel.org
    Suggested-by: Nathan Chancellor <nathan@kernel.org>
    Acked-by: Paulo Alcantara (Red Hat) <pc@manguebit.org>
    Signed-off-by: Steve French <stfrench@microsoft.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
cpufreq: CPPC: Avoid using CPUFREQ_ETERNAL as transition delay [+ + +]
Author: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
Date:   Sat Oct 18 12:25:19 2025 -0400

    cpufreq: CPPC: Avoid using CPUFREQ_ETERNAL as transition delay
    
    [ Upstream commit f965d111e68f4a993cc44d487d416e3d954eea11 ]
    
    If cppc_get_transition_latency() returns CPUFREQ_ETERNAL to indicate a
    failure to retrieve the transition latency value from the platform
    firmware, the CPPC cpufreq driver will use that value (converted to
    microseconds) as the policy transition delay, but it is way too large
    for any practical use.
    
    Address this by making the driver use the cpufreq's default
    transition latency value (in microseconds) as the transition delay
    if CPUFREQ_ETERNAL is returned by cppc_get_transition_latency().
    
    Fixes: d4f3388afd48 ("cpufreq / CPPC: Set platform specific transition_delay_us")
    Cc: 5.19+ <stable@vger.kernel.org> # 5.19
    Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
    Reviewed-by: Mario Limonciello (AMD) <superm1@kernel.org>
    Reviewed-by: Jie Zhan <zhanjie9@hisilicon.com>
    Acked-by: Viresh Kumar <viresh.kumar@linaro.org>
    Reviewed-by: Qais Yousef <qyousef@layalina.io>
    [ added CPUFREQ_DEFAULT_TRANSITION_LATENCY_NS definition to include/linux/cpufreq.h ]
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
dax: skip read lock assertion for read-only filesystems [+ + +]
Author: Yuezhang Mo <Yuezhang.Mo@sony.com>
Date:   Tue Sep 30 13:42:57 2025 +0800

    dax: skip read lock assertion for read-only filesystems
    
    [ Upstream commit 154d1e7ad9e5ce4b2aaefd3862b3dba545ad978d ]
    
    The commit 168316db3583("dax: assert that i_rwsem is held
    exclusive for writes") added lock assertions to ensure proper
    locking in DAX operations. However, these assertions trigger
    false-positive lockdep warnings since read lock is unnecessary
    on read-only filesystems(e.g., erofs).
    
    This patch skips the read lock assertion for read-only filesystems,
    eliminating the spurious warnings while maintaining the integrity
    checks for writable filesystems.
    
    Fixes: 168316db3583 ("dax: assert that i_rwsem is held exclusive for writes")
    Signed-off-by: Yuezhang Mo <Yuezhang.Mo@sony.com>
    Reviewed-by: Friendy Su <friendy.su@sony.com>
    Reviewed-by: Daniel Palmer <daniel.palmer@sony.com>
    Reviewed-by: Gao Xiang <hsiangkao@linux.alibaba.com>
    Signed-off-by: Christian Brauner <brauner@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
doc: fix seg6_flowlabel path [+ + +]
Author: Nicolas Dichtel <nicolas.dichtel@6wind.com>
Date:   Fri Oct 10 16:18:59 2025 +0200

    doc: fix seg6_flowlabel path
    
    [ Upstream commit 0b4b77eff5f8cd9be062783a1c1e198d46d0a753 ]
    
    This sysctl is not per interface; it's global per netns.
    
    Fixes: 292ecd9f5a94 ("doc: move seg6_flowlabel to seg6-sysctl.rst")
    Reported-by: Philippe Guibert <philippe.guibert@6wind.com>
    Signed-off-by: Nicolas Dichtel <nicolas.dichtel@6wind.com>
    Reviewed-by: Simon Horman <horms@kernel.org>
    Signed-off-by: David S. Miller <davem@davemloft.net>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
drm/amd/powerplay: Fix CIK shutdown temperature [+ + +]
Author: Timur Kristóf <timur.kristof@gmail.com>
Date:   Mon Oct 13 08:06:42 2025 +0200

    drm/amd/powerplay: Fix CIK shutdown temperature
    
    [ Upstream commit 6917112af2ba36c5f19075eb9f2933ffd07e55bf ]
    
    Remove extra multiplication.
    
    CIK GPUs such as Hawaii appear to use PP_TABLE_V0 in which case
    the shutdown temperature is hardcoded in smu7_init_dpm_defaults
    and is already multiplied by 1000. The value was mistakenly
    multiplied another time by smu7_get_thermal_temperature_range.
    
    Fixes: 4ba082572a42 ("drm/amd/powerplay: export the thermal ranges of VI asics (V2)")
    Closes: https://gitlab.freedesktop.org/drm/amd/-/issues/1676
    Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
    Signed-off-by: Timur Kristóf <timur.kristof@gmail.com>
    Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
drm/amd: Check whether secure display TA loaded successfully [+ + +]
Author: Mario Limonciello <mario.limonciello@amd.com>
Date:   Thu Sep 25 14:10:57 2025 -0500

    drm/amd: Check whether secure display TA loaded successfully
    
    commit c760bcda83571e07b72c10d9da175db5051ed971 upstream.
    
    [Why]
    Not all renoir hardware supports secure display.  If the TA is present
    but the feature isn't supported it will fail to load or send commands.
    This shows ERR messages to the user that make it seems like there is
    a problem.
    
    [How]
    Check the resp_status of the context to see if there was an error
    before trying to send any secure display commands.
    
    Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
    Closes: https://gitlab.freedesktop.org/drm/amd/-/issues/1415
    Signed-off-by: Mario Limonciello <mario.limonciello@amd.com>
    Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
    Signed-off-by: Adrian Yip <adrian.ytw@gmail.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
drm/amdgpu: use atomic functions with memory barriers for vm fault info [+ + +]
Author: Gui-Dong Han <hanguidong02@gmail.com>
Date:   Wed Oct 8 03:43:27 2025 +0000

    drm/amdgpu: use atomic functions with memory barriers for vm fault info
    
    commit 6df8e84aa6b5b1812cc2cacd6b3f5ccbb18cda2b upstream.
    
    The atomic variable vm_fault_info_updated is used to synchronize access to
    adev->gmc.vm_fault_info between the interrupt handler and
    get_vm_fault_info().
    
    The default atomic functions like atomic_set() and atomic_read() do not
    provide memory barriers. This allows for CPU instruction reordering,
    meaning the memory accesses to vm_fault_info and the vm_fault_info_updated
    flag are not guaranteed to occur in the intended order. This creates a
    race condition that can lead to inconsistent or stale data being used.
    
    The previous implementation, which used an explicit mb(), was incomplete
    and inefficient. It failed to account for all potential CPU reorderings,
    such as the access of vm_fault_info being reordered before the atomic_read
    of the flag. This approach is also more verbose and less performant than
    using the proper atomic functions with acquire/release semantics.
    
    Fix this by switching to atomic_set_release() and atomic_read_acquire().
    These functions provide the necessary acquire and release semantics,
    which act as memory barriers to ensure the correct order of operations.
    It is also more efficient and idiomatic than using explicit full memory
    barriers.
    
    Fixes: b97dfa27ef3a ("drm/amdgpu: save vm fault information for amdkfd")
    Cc: stable@vger.kernel.org
    Signed-off-by: Gui-Dong Han <hanguidong02@gmail.com>
    Signed-off-by: Felix Kuehling <felix.kuehling@amd.com>
    Reviewed-by: Felix Kuehling <felix.kuehling@amd.com>
    Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
drm/bridge: lt9211: Drop check for last nibble of version register [+ + +]
Author: Marek Vasut <marek.vasut@mailbox.org>
Date:   Sat Oct 11 12:59:53 2025 +0200

    drm/bridge: lt9211: Drop check for last nibble of version register
    
    [ Upstream commit db74b04edce1bc86b9a5acc724c7ca06f427ab60 ]
    
    There is now a new LT9211 rev. U5, which reports chip ID 0x18 0x01 0xe4 .
    The previous LT9211 reported chip ID 0x18 0x01 0xe3 , which is what the
    driver checks for right now. Since there is a possibility there will be
    yet another revision of the LT9211 in the future, drop the last version
    nibble check to allow all future revisions of the chip to work with this
    driver.
    
    This fix makes LT9211 rev. U5 work with this driver.
    
    Fixes: 8ce4129e3de4 ("drm/bridge: lt9211: Add Lontium LT9211 bridge driver")
    Signed-off-by: Marek Vasut <marek.vasut@mailbox.org>
    Reviewed-by: Dmitry Baryshkov <dmitry.baryshkov@oss.qualcomm.com>
    Link: https://lore.kernel.org/r/20251011110017.12521-1-marek.vasut@mailbox.org
    Signed-off-by: Dmitry Baryshkov <dmitry.baryshkov@oss.qualcomm.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
drm/exynos: exynos7_drm_decon: fix uninitialized crtc reference in functions [+ + +]
Author: Kaustabh Chakraborty <kauschluss@disroot.org>
Date:   Fri Oct 17 22:18:17 2025 -0400

    drm/exynos: exynos7_drm_decon: fix uninitialized crtc reference in functions
    
    [ Upstream commit d31bbacf783daf1e71fbe5c68df93550c446bf44 ]
    
    Modify the functions to accept a pointer to struct decon_context
    instead.
    
    Signed-off-by: Kaustabh Chakraborty <kauschluss@disroot.org>
    Signed-off-by: Inki Dae <inki.dae@samsung.com>
    Stable-dep-of: e1361a4f1be9 ("drm/exynos: exynos7_drm_decon: remove ctx->suspended")
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

drm/exynos: exynos7_drm_decon: properly clear channels during bind [+ + +]
Author: Kaustabh Chakraborty <kauschluss@disroot.org>
Date:   Fri Oct 17 22:18:18 2025 -0400

    drm/exynos: exynos7_drm_decon: properly clear channels during bind
    
    [ Upstream commit 5f1a453974204175f20b3788824a0fe23cc36f79 ]
    
    The DECON channels are not cleared properly as the windows aren't
    shadow protected. When accompanied with an IOMMU, it pagefaults, and
    the kernel panics.
    
    Implement shadow protect/unprotect, along with a standalone update,
    for channel clearing to properly take effect.
    
    Signed-off-by: Kaustabh Chakraborty <kauschluss@disroot.org>
    Signed-off-by: Inki Dae <inki.dae@samsung.com>
    Stable-dep-of: e1361a4f1be9 ("drm/exynos: exynos7_drm_decon: remove ctx->suspended")
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

drm/exynos: exynos7_drm_decon: remove ctx->suspended [+ + +]
Author: Kaustabh Chakraborty <kauschluss@disroot.org>
Date:   Fri Oct 17 22:18:19 2025 -0400

    drm/exynos: exynos7_drm_decon: remove ctx->suspended
    
    [ Upstream commit e1361a4f1be9cb69a662c6d7b5ce218007d6e82b ]
    
    Condition guards are found to be redundant, as the call flow is properly
    managed now, as also observed in the Exynos5433 DECON driver. Since
    state checking is no longer necessary, remove it.
    
    This also fixes an issue which prevented decon_commit() from
    decon_atomic_enable() due to an incorrect state change setting.
    
    Fixes: 96976c3d9aff ("drm/exynos: Add DECON driver")
    Cc: stable@vger.kernel.org
    Suggested-by: Inki Dae <inki.dae@samsung.com>
    Signed-off-by: Kaustabh Chakraborty <kauschluss@disroot.org>
    Signed-off-by: Inki Dae <inki.dae@samsung.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
drm/i915/guc: Skip communication warning on reset in progress [+ + +]
Author: Zhanjun Dong <zhanjun.dong@intel.com>
Date:   Mon Sep 29 11:29:04 2025 -0400

    drm/i915/guc: Skip communication warning on reset in progress
    
    [ Upstream commit 1696b0cfcf004a3af34ffe4c57a14e837ef18144 ]
    
    GuC IRQ and tasklet handler receive just single G2H message, and let other
    messages to be received from next tasklet. During this chained tasklet
    process, if reset process started, communication will be disabled.
    Skip warning for this condition.
    
    Fixes: 65dd4ed0f4e1 ("drm/i915/guc: Don't receive all G2H messages in irq handler")
    Closes: https://gitlab.freedesktop.org/drm/i915/kernel/-/issues/15018
    Signed-off-by: Zhanjun Dong <zhanjun.dong@intel.com>
    Reviewed-by: Vinay Belgaumkar <vinay.belgaumkar@intel.com>
    Signed-off-by: Daniele Ceraolo Spurio <daniele.ceraolospurio@intel.com>
    Link: https://lore.kernel.org/r/20250929152904.269776-1-zhanjun.dong@intel.com
    (cherry picked from commit 604b5ee4a653a70979ce689dbd6a5d942eb016bf)
    Signed-off-by: Rodrigo Vivi <rodrigo.vivi@intel.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
drm/msm/a6xx: Fix PDC sleep sequence [+ + +]
Author: Akhil P Oommen <akhilpo@oss.qualcomm.com>
Date:   Fri Oct 17 23:24:08 2025 -0400

    drm/msm/a6xx: Fix PDC sleep sequence
    
    [ Upstream commit f248d5d5159a88ded55329f0b1b463d0f4094228 ]
    
    Since the PDC resides out of the GPU subsystem and cannot be reset in
    case it enters bad state, utmost care must be taken to trigger the PDC
    wake/sleep routines in the correct order.
    
    The PDC wake sequence can be exercised only after a PDC sleep sequence.
    Additionally, GMU firmware should initialize a few registers before the
    KMD can trigger a PDC sleep sequence. So PDC sleep can't be done if the
    GMU firmware has not initialized. Track these dependencies using a new
    status variable and trigger PDC sleep/wake sequences appropriately.
    
    Cc: stable@vger.kernel.org
    Fixes: 4b565ca5a2cb ("drm/msm: Add A6XX device support")
    Signed-off-by: Akhil P Oommen <akhilpo@oss.qualcomm.com>
    Patchwork: https://patchwork.freedesktop.org/patch/673362/
    Signed-off-by: Rob Clark <robin.clark@oss.qualcomm.com>
    [ omitted A7XX GPU logic and newer struct fields ]
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
drm/msm/adreno: De-spaghettify the use of memory barriers [+ + +]
Author: Konrad Dybcio <konradybcio@kernel.org>
Date:   Fri Oct 17 23:24:07 2025 -0400

    drm/msm/adreno: De-spaghettify the use of memory barriers
    
    [ Upstream commit 43ec1a202cfa9f765412d325b93873284e7c3d82 ]
    
    Memory barriers help ensure instruction ordering, NOT time and order
    of actual write arrival at other observers (e.g. memory-mapped IP).
    On architectures employing weak memory ordering, the latter can be a
    giant pain point, and it has been as part of this driver.
    
    Moreover, the gpu_/gmu_ accessors already use non-relaxed versions of
    readl/writel, which include r/w (respectively) barriers.
    
    Replace the barriers with a readback (or drop altogether where possible)
    that ensures the previous writes have exited the write buffer (as the CPU
    must flush the write to the register it's trying to read back).
    
    Signed-off-by: Konrad Dybcio <konrad.dybcio@linaro.org>
    Patchwork: https://patchwork.freedesktop.org/patch/600869/
    Reviewed-by: Akhil P Oommen <quic_akhilpo@quicinc.com>
    Signed-off-by: Rob Clark <robdclark@chromium.org>
    Stable-dep-of: f248d5d5159a ("drm/msm/a6xx: Fix PDC sleep sequence")
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
drm/rockchip: vop2: use correct destination rectangle height check [+ + +]
Author: Alok Tiwari <alok.a.tiwari@oracle.com>
Date:   Sun Oct 12 07:20:01 2025 -0700

    drm/rockchip: vop2: use correct destination rectangle height check
    
    [ Upstream commit 7f38a1487555604bc4e210fa7cc9b1bce981c40e ]
    
    The vop2_plane_atomic_check() function incorrectly checks
    drm_rect_width(dest) twice instead of verifying both width and height.
    Fix the second condition to use drm_rect_height(dest) so that invalid
    destination rectangles with height < 4 are correctly rejected.
    
    Fixes: 604be85547ce ("drm/rockchip: Add VOP2 driver")
    Signed-off-by: Alok Tiwari <alok.a.tiwari@oracle.com>
    Reviewed-by: Andy Yan <andy.yan@rock-chips.com>
    Signed-off-by: Heiko Stuebner <heiko@sntech.de>
    Link: https://lore.kernel.org/r/20251012142005.660727-1-alok.a.tiwari@oracle.com
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
drm/sched: Fix potential double free in drm_sched_job_add_resv_dependencies [+ + +]
Author: Tvrtko Ursulin <tvrtko.ursulin@igalia.com>
Date:   Wed Oct 15 09:40:15 2025 +0100

    drm/sched: Fix potential double free in drm_sched_job_add_resv_dependencies
    
    commit 5801e65206b065b0b2af032f7f1eef222aa2fd83 upstream.
    
    When adding dependencies with drm_sched_job_add_dependency(), that
    function consumes the fence reference both on success and failure, so in
    the latter case the dma_fence_put() on the error path (xarray failed to
    expand) is a double free.
    
    Interestingly this bug appears to have been present ever since
    commit ebd5f74255b9 ("drm/sched: Add dependency tracking"), since the code
    back then looked like this:
    
    drm_sched_job_add_implicit_dependencies():
    ...
           for (i = 0; i < fence_count; i++) {
                   ret = drm_sched_job_add_dependency(job, fences[i]);
                   if (ret)
                           break;
           }
    
           for (; i < fence_count; i++)
                   dma_fence_put(fences[i]);
    
    Which means for the failing 'i' the dma_fence_put was already a double
    free. Possibly there were no users at that time, or the test cases were
    insufficient to hit it.
    
    The bug was then only noticed and fixed after
    commit 9c2ba265352a ("drm/scheduler: use new iterator in drm_sched_job_add_implicit_dependencies v2")
    landed, with its fixup of
    commit 4eaf02d6076c ("drm/scheduler: fix drm_sched_job_add_implicit_dependencies").
    
    At that point it was a slightly different flavour of a double free, which
    commit 963d0b356935 ("drm/scheduler: fix drm_sched_job_add_implicit_dependencies harder")
    noticed and attempted to fix.
    
    But it only moved the double free from happening inside the
    drm_sched_job_add_dependency(), when releasing the reference not yet
    obtained, to the caller, when releasing the reference already released by
    the former in the failure case.
    
    As such it is not easy to identify the right target for the fixes tag so
    lets keep it simple and just continue the chain.
    
    While fixing we also improve the comment and explain the reason for taking
    the reference and not dropping it.
    
    Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@igalia.com>
    Fixes: 963d0b356935 ("drm/scheduler: fix drm_sched_job_add_implicit_dependencies harder")
    Reported-by: Dan Carpenter <dan.carpenter@linaro.org>
    Closes: https://lore.kernel.org/dri-devel/aNFbXq8OeYl3QSdm@stanley.mountain/
    Cc: Christian König <christian.koenig@amd.com>
    Cc: Rob Clark <robdclark@chromium.org>
    Cc: Daniel Vetter <daniel.vetter@ffwll.ch>
    Cc: Matthew Brost <matthew.brost@intel.com>
    Cc: Danilo Krummrich <dakr@kernel.org>
    Cc: Philipp Stanner <phasta@kernel.org>
    Cc: Christian König <ckoenig.leichtzumerken@gmail.com>
    Cc: dri-devel@lists.freedesktop.org
    Cc: stable@vger.kernel.org # v5.16+
    Signed-off-by: Philipp Stanner <phasta@kernel.org>
    Link: https://lore.kernel.org/r/20251015084015.6273-1-tvrtko.ursulin@igalia.com
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
epoll: Remove ep_scan_ready_list() in comments [+ + +]
Author: Huang Xiaojia <huangxiaojia2@huawei.com>
Date:   Sat Oct 18 15:36:27 2025 -0400

    epoll: Remove ep_scan_ready_list() in comments
    
    [ Upstream commit e6f7958042a7b1dc9a4dfc19fca74217bc0c4865 ]
    
    Since commit 443f1a042233 ("lift the calls of ep_send_events_proc()
    into the callers"), ep_scan_ready_list() has been removed.
    But there are still several in comments. All of them should
    be replaced with other caller functions.
    
    Signed-off-by: Huang Xiaojia <huangxiaojia2@huawei.com>
    Link: https://lore.kernel.org/r/20240206014353.4191262-1-huangxiaojia2@huawei.com
    Reviewed-by: Jan Kara <jack@suse.cz>
    Signed-off-by: Christian Brauner <brauner@kernel.org>
    Stable-dep-of: 0c43094f8cc9 ("eventpoll: Replace rwlock with spinlock")
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
eventpoll: Replace rwlock with spinlock [+ + +]
Author: Nam Cao <namcao@linutronix.de>
Date:   Sat Oct 18 15:36:28 2025 -0400

    eventpoll: Replace rwlock with spinlock
    
    [ Upstream commit 0c43094f8cc9d3d99d835c0ac9c4fe1ccc62babd ]
    
    The ready event list of an epoll object is protected by read-write
    semaphore:
    
      - The consumer (waiter) acquires the write lock and takes items.
      - the producer (waker) takes the read lock and adds items.
    
    The point of this design is enabling epoll to scale well with large number
    of producers, as multiple producers can hold the read lock at the same
    time.
    
    Unfortunately, this implementation may cause scheduling priority inversion
    problem. Suppose the consumer has higher scheduling priority than the
    producer. The consumer needs to acquire the write lock, but may be blocked
    by the producer holding the read lock. Since read-write semaphore does not
    support priority-boosting for the readers (even with CONFIG_PREEMPT_RT=y),
    we have a case of priority inversion: a higher priority consumer is blocked
    by a lower priority producer. This problem was reported in [1].
    
    Furthermore, this could also cause stall problem, as described in [2].
    
    Fix this problem by replacing rwlock with spinlock.
    
    This reduces the event bandwidth, as the producers now have to contend with
    each other for the spinlock. According to the benchmark from
    https://github.com/rouming/test-tools/blob/master/stress-epoll.c:
    
        On 12 x86 CPUs:
                      Before     After        Diff
            threads  events/ms  events/ms
                  8       7162       4956     -31%
                 16       8733       5383     -38%
                 32       7968       5572     -30%
                 64      10652       5739     -46%
                128      11236       5931     -47%
    
        On 4 riscv CPUs:
                      Before     After        Diff
            threads  events/ms  events/ms
                  8       2958       2833      -4%
                 16       3323       3097      -7%
                 32       3451       3240      -6%
                 64       3554       3178     -11%
                128       3601       3235     -10%
    
    Although the numbers look bad, it should be noted that this benchmark
    creates multiple threads who do nothing except constantly generating new
    epoll events, thus contention on the spinlock is high. For real workload,
    the event rate is likely much lower, and the performance drop is not as
    bad.
    
    Using another benchmark (perf bench epoll wait) where spinlock contention
    is lower, improvement is even observed on x86:
    
        On 12 x86 CPUs:
            Before: Averaged 110279 operations/sec (+- 1.09%), total secs = 8
            After:  Averaged 114577 operations/sec (+- 2.25%), total secs = 8
    
        On 4 riscv CPUs:
            Before: Averaged 175767 operations/sec (+- 0.62%), total secs = 8
            After:  Averaged 167396 operations/sec (+- 0.23%), total secs = 8
    
    In conclusion, no one is likely to be upset over this change. After all,
    spinlock was used originally for years, and the commit which converted to
    rwlock didn't mention a real workload, just that the benchmark numbers are
    nice.
    
    This patch is not exactly the revert of commit a218cc491420 ("epoll: use
    rwlock in order to reduce ep_poll_callback() contention"), because git
    revert conflicts in some places which are not obvious on the resolution.
    This patch is intended to be backported, therefore go with the obvious
    approach:
    
      - Replace rwlock_t with spinlock_t one to one
    
      - Delete list_add_tail_lockless() and chain_epi_lockless(). These were
        introduced to allow producers to concurrently add items to the list.
        But now that spinlock no longer allows producers to touch the event
        list concurrently, these two functions are not necessary anymore.
    
    Fixes: a218cc491420 ("epoll: use rwlock in order to reduce ep_poll_callback() contention")
    Signed-off-by: Nam Cao <namcao@linutronix.de>
    Link: https://lore.kernel.org/ec92458ea357ec503c737ead0f10b2c6e4c37d47.1752581388.git.namcao@linutronix.de
    Tested-by: K Prateek Nayak <kprateek.nayak@amd.com>
    Cc: stable@vger.kernel.org
    Reported-by: Frederic Weisbecker <frederic@kernel.org>
    Closes: https://lore.kernel.org/linux-rt-users/20210825132754.GA895675@lothringen/ [1]
    Reported-by: Valentin Schneider <vschneid@redhat.com>
    Closes: https://lore.kernel.org/linux-rt-users/xhsmhttqvnall.mognet@vschneid.remote.csb/ [2]
    Signed-off-by: Christian Brauner <brauner@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
ext4: avoid potential buffer over-read in parse_apply_sb_mount_options() [+ + +]
Author: Theodore Ts'o <tytso@mit.edu>
Date:   Tue Oct 21 12:44:18 2025 -0400

    ext4: avoid potential buffer over-read in parse_apply_sb_mount_options()
    
    [ Upstream commit 8ecb790ea8c3fc69e77bace57f14cf0d7c177bd8 ]
    
    Unlike other strings in the ext4 superblock, we rely on tune2fs to
    make sure s_mount_opts is NUL terminated.  Harden
    parse_apply_sb_mount_options() by treating s_mount_opts as a potential
    __nonstring.
    
    Cc: stable@vger.kernel.org
    Fixes: 8b67f04ab9de ("ext4: Add mount options in superblock")
    Reviewed-by: Jan Kara <jack@suse.cz>
    Reviewed-by: Darrick J. Wong <djwong@kernel.org>
    Signed-off-by: Theodore Ts'o <tytso@mit.edu>
    Message-ID: <20250916-tune2fs-v2-1-d594dc7486f0@mit.edu>
    Signed-off-by: Theodore Ts'o <tytso@mit.edu>
    [ added sizeof() third argument to strscpy_pad() ]
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

ext4: detect invalid INLINE_DATA + EXTENTS flag combination [+ + +]
Author: Deepanshu Kartikey <kartikey406@gmail.com>
Date:   Tue Sep 30 16:58:10 2025 +0530

    ext4: detect invalid INLINE_DATA + EXTENTS flag combination
    
    commit 1d3ad183943b38eec2acf72a0ae98e635dc8456b upstream.
    
    syzbot reported a BUG_ON in ext4_es_cache_extent() when opening a verity
    file on a corrupted ext4 filesystem mounted without a journal.
    
    The issue is that the filesystem has an inode with both the INLINE_DATA
    and EXTENTS flags set:
    
        EXT4-fs error (device loop0): ext4_cache_extents:545: inode #15:
        comm syz.0.17: corrupted extent tree: lblk 0 < prev 66
    
    Investigation revealed that the inode has both flags set:
        DEBUG: inode 15 - flag=1, i_inline_off=164, has_inline=1, extents_flag=1
    
    This is an invalid combination since an inode should have either:
    - INLINE_DATA: data stored directly in the inode
    - EXTENTS: data stored in extent-mapped blocks
    
    Having both flags causes ext4_has_inline_data() to return true, skipping
    extent tree validation in __ext4_iget(). The unvalidated out-of-order
    extents then trigger a BUG_ON in ext4_es_cache_extent() due to integer
    underflow when calculating hole sizes.
    
    Fix this by detecting this invalid flag combination early in ext4_iget()
    and rejecting the corrupted inode.
    
    Cc: stable@kernel.org
    Reported-and-tested-by: syzbot+038b7bf43423e132b308@syzkaller.appspotmail.com
    Closes: https://syzkaller.appspot.com/bug?extid=038b7bf43423e132b308
    Suggested-by: Zhang Yi <yi.zhang@huawei.com>
    Signed-off-by: Deepanshu Kartikey <kartikey406@gmail.com>
    Reviewed-by: Zhang Yi <yi.zhang@huawei.com>
    Message-ID: <20250930112810.315095-1-kartikey406@gmail.com>
    Signed-off-by: Theodore Ts'o <tytso@mit.edu>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

ext4: wait for ongoing I/O to complete before freeing blocks [+ + +]
Author: Zhang Yi <yi.zhang@huawei.com>
Date:   Tue Sep 16 17:33:37 2025 +0800

    ext4: wait for ongoing I/O to complete before freeing blocks
    
    commit 328a782cb138029182e521c08f50eb1587db955d upstream.
    
    When freeing metadata blocks in nojournal mode, ext4_forget() calls
    bforget() to clear the dirty flag on the buffer_head and remvoe
    associated mappings. This is acceptable if the metadata has not yet
    begun to be written back. However, if the write-back has already started
    but is not yet completed, ext4_forget() will have no effect.
    Subsequently, ext4_mb_clear_bb() will immediately return the block to
    the mb allocator. This block can then be reallocated immediately,
    potentially causing an data corruption issue.
    
    Fix this by clearing the buffer's dirty flag and waiting for the ongoing
    I/O to complete, ensuring that no further writes to stale data will
    occur.
    
    Fixes: 16e08b14a455 ("ext4: cleanup clean_bdev_aliases() calls")
    Cc: stable@kernel.org
    Reported-by: Gao Xiang <hsiangkao@linux.alibaba.com>
    Closes: https://lore.kernel.org/linux-ext4/a9417096-9549-4441-9878-b1955b899b4e@huaweicloud.com/
    Signed-off-by: Zhang Yi <yi.zhang@huawei.com>
    Reviewed-by: Jan Kara <jack@suse.cz>
    Message-ID: <20250916093337.3161016-3-yi.zhang@huaweicloud.com>
    Signed-off-by: Theodore Ts'o <tytso@mit.edu>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
f2fs: fix wrong block mapping for multi-devices [+ + +]
Author: Jaegeuk Kim <jaegeuk@kernel.org>
Date:   Tue Oct 7 03:32:30 2025 +0000

    f2fs: fix wrong block mapping for multi-devices
    
    commit 9d5c4f5c7a2c7677e1b3942772122b032c265aae upstream.
    
    Assuming the disk layout as below,
    
    disk0: 0            --- 0x00035abfff
    disk1: 0x00035ac000 --- 0x00037abfff
    disk2: 0x00037ac000 --- 0x00037ebfff
    
    and we want to read data from offset=13568 having len=128 across the block
    devices, we can illustrate the block addresses like below.
    
    0 .. 0x00037ac000 ------------------- 0x00037ebfff, 0x00037ec000 -------
              |          ^            ^                                ^
              |   fofs   0            13568                            13568+128
              |       ------------------------------------------------------
              |   LBA    0x37e8aa9    0x37ebfa9                        0x37ec029
              --- map    0x3caa9      0x3ffa9
    
    In this example, we should give the relative map of the target block device
    ranging from 0x3caa9 to 0x3ffa9 where the length should be calculated by
    0x37ebfff + 1 - 0x37ebfa9.
    
    In the below equation, however, map->m_pblk was supposed to be the original
    address instead of the one from the target block address.
    
     - map->m_len = min(map->m_len, dev->end_blk + 1 - map->m_pblk);
    
    Cc: stable@vger.kernel.org
    Fixes: 71f2c8206202 ("f2fs: multidevice: support direct IO")
    Reviewed-by: Chao Yu <chao@kernel.org>
    Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
fs: quota: create dedicated workqueue for quota_release_work [+ + +]
Author: Shashank A P <shashank.ap@samsung.com>
Date:   Mon Oct 20 12:16:05 2025 -0400

    fs: quota: create dedicated workqueue for quota_release_work
    
    [ Upstream commit 72b7ceca857f38a8ca7c5629feffc63769638974 ]
    
    There is a kernel panic due to WARN_ONCE when panic_on_warn is set.
    
    This issue occurs when writeback is triggered due to sync call for an
    opened file(ie, writeback reason is WB_REASON_SYNC). When f2fs balance
    is needed at sync path, flush for quota_release_work is triggered.
    By default quota_release_work is queued to "events_unbound" queue which
    does not have WQ_MEM_RECLAIM flag. During f2fs balance "writeback"
    workqueue tries to flush quota_release_work causing kernel panic due to
    MEM_RECLAIM flag mismatch errors.
    
    This patch creates dedicated workqueue with WQ_MEM_RECLAIM flag
    for work quota_release_work.
    
    ------------[ cut here ]------------
    WARNING: CPU: 4 PID: 14867 at kernel/workqueue.c:3721 check_flush_dependency+0x13c/0x148
    Call trace:
     check_flush_dependency+0x13c/0x148
     __flush_work+0xd0/0x398
     flush_delayed_work+0x44/0x5c
     dquot_writeback_dquots+0x54/0x318
     f2fs_do_quota_sync+0xb8/0x1a8
     f2fs_write_checkpoint+0x3cc/0x99c
     f2fs_gc+0x190/0x750
     f2fs_balance_fs+0x110/0x168
     f2fs_write_single_data_page+0x474/0x7dc
     f2fs_write_data_pages+0x7d0/0xd0c
     do_writepages+0xe0/0x2f4
     __writeback_single_inode+0x44/0x4ac
     writeback_sb_inodes+0x30c/0x538
     wb_writeback+0xf4/0x440
     wb_workfn+0x128/0x5d4
     process_scheduled_works+0x1c4/0x45c
     worker_thread+0x32c/0x3e8
     kthread+0x11c/0x1b0
     ret_from_fork+0x10/0x20
    Kernel panic - not syncing: kernel: panic_on_warn set ...
    
    Fixes: ac6f420291b3 ("quota: flush quota_release_work upon quota writeback")
    CC: stable@vger.kernel.org
    Signed-off-by: Shashank A P <shashank.ap@samsung.com>
    Link: https://patch.msgid.link/20250901092905.2115-1-shashank.ap@samsung.com
    Signed-off-by: Jan Kara <jack@suse.cz>
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
hfsplus: fix slab-out-of-bounds read in hfsplus_strcasecmp() [+ + +]
Author: Viacheslav Dubeyko <slava@dubeyko.com>
Date:   Fri Sep 19 12:12:44 2025 -0700

    hfsplus: fix slab-out-of-bounds read in hfsplus_strcasecmp()
    
    commit 42520df65bf67189541a425f7d36b0b3e7bd7844 upstream.
    
    The hfsplus_strcasecmp() logic can trigger the issue:
    
    [  117.317703][ T9855] ==================================================================
    [  117.318353][ T9855] BUG: KASAN: slab-out-of-bounds in hfsplus_strcasecmp+0x1bc/0x490
    [  117.318991][ T9855] Read of size 2 at addr ffff88802160f40c by task repro/9855
    [  117.319577][ T9855]
    [  117.319773][ T9855] CPU: 0 UID: 0 PID: 9855 Comm: repro Not tainted 6.17.0-rc6 #33 PREEMPT(full)
    [  117.319780][ T9855] Hardware name: QEMU Ubuntu 24.04 PC (i440FX + PIIX, 1996), BIOS 1.16.3-debian-1.16.3-2 04/01/2014
    [  117.319783][ T9855] Call Trace:
    [  117.319785][ T9855]  <TASK>
    [  117.319788][ T9855]  dump_stack_lvl+0x1c1/0x2a0
    [  117.319795][ T9855]  ? __virt_addr_valid+0x1c8/0x5c0
    [  117.319803][ T9855]  ? __pfx_dump_stack_lvl+0x10/0x10
    [  117.319808][ T9855]  ? rcu_is_watching+0x15/0xb0
    [  117.319816][ T9855]  ? lock_release+0x4b/0x3e0
    [  117.319821][ T9855]  ? __kasan_check_byte+0x12/0x40
    [  117.319828][ T9855]  ? __virt_addr_valid+0x1c8/0x5c0
    [  117.319835][ T9855]  ? __virt_addr_valid+0x4a5/0x5c0
    [  117.319842][ T9855]  print_report+0x17e/0x7e0
    [  117.319848][ T9855]  ? __virt_addr_valid+0x1c8/0x5c0
    [  117.319855][ T9855]  ? __virt_addr_valid+0x4a5/0x5c0
    [  117.319862][ T9855]  ? __phys_addr+0xd3/0x180
    [  117.319869][ T9855]  ? hfsplus_strcasecmp+0x1bc/0x490
    [  117.319876][ T9855]  kasan_report+0x147/0x180
    [  117.319882][ T9855]  ? hfsplus_strcasecmp+0x1bc/0x490
    [  117.319891][ T9855]  hfsplus_strcasecmp+0x1bc/0x490
    [  117.319900][ T9855]  ? __pfx_hfsplus_cat_case_cmp_key+0x10/0x10
    [  117.319906][ T9855]  hfs_find_rec_by_key+0xa9/0x1e0
    [  117.319913][ T9855]  __hfsplus_brec_find+0x18e/0x470
    [  117.319920][ T9855]  ? __pfx_hfsplus_bnode_find+0x10/0x10
    [  117.319926][ T9855]  ? __pfx_hfs_find_rec_by_key+0x10/0x10
    [  117.319933][ T9855]  ? __pfx___hfsplus_brec_find+0x10/0x10
    [  117.319942][ T9855]  hfsplus_brec_find+0x28f/0x510
    [  117.319949][ T9855]  ? __pfx_hfs_find_rec_by_key+0x10/0x10
    [  117.319956][ T9855]  ? __pfx_hfsplus_brec_find+0x10/0x10
    [  117.319963][ T9855]  ? __kmalloc_noprof+0x2a9/0x510
    [  117.319969][ T9855]  ? hfsplus_find_init+0x8c/0x1d0
    [  117.319976][ T9855]  hfsplus_brec_read+0x2b/0x120
    [  117.319983][ T9855]  hfsplus_lookup+0x2aa/0x890
    [  117.319990][ T9855]  ? __pfx_hfsplus_lookup+0x10/0x10
    [  117.320003][ T9855]  ? d_alloc_parallel+0x2f0/0x15e0
    [  117.320008][ T9855]  ? __lock_acquire+0xaec/0xd80
    [  117.320013][ T9855]  ? __pfx_d_alloc_parallel+0x10/0x10
    [  117.320019][ T9855]  ? __raw_spin_lock_init+0x45/0x100
    [  117.320026][ T9855]  ? __init_waitqueue_head+0xa9/0x150
    [  117.320034][ T9855]  __lookup_slow+0x297/0x3d0
    [  117.320039][ T9855]  ? __pfx___lookup_slow+0x10/0x10
    [  117.320045][ T9855]  ? down_read+0x1ad/0x2e0
    [  117.320055][ T9855]  lookup_slow+0x53/0x70
    [  117.320065][ T9855]  walk_component+0x2f0/0x430
    [  117.320073][ T9855]  path_lookupat+0x169/0x440
    [  117.320081][ T9855]  filename_lookup+0x212/0x590
    [  117.320089][ T9855]  ? __pfx_filename_lookup+0x10/0x10
    [  117.320098][ T9855]  ? strncpy_from_user+0x150/0x290
    [  117.320105][ T9855]  ? getname_flags+0x1e5/0x540
    [  117.320112][ T9855]  user_path_at+0x3a/0x60
    [  117.320117][ T9855]  __x64_sys_umount+0xee/0x160
    [  117.320123][ T9855]  ? __pfx___x64_sys_umount+0x10/0x10
    [  117.320129][ T9855]  ? do_syscall_64+0xb7/0x3a0
    [  117.320135][ T9855]  ? entry_SYSCALL_64_after_hwframe+0x77/0x7f
    [  117.320141][ T9855]  ? entry_SYSCALL_64_after_hwframe+0x77/0x7f
    [  117.320145][ T9855]  do_syscall_64+0xf3/0x3a0
    [  117.320150][ T9855]  ? exc_page_fault+0x9f/0xf0
    [  117.320154][ T9855]  entry_SYSCALL_64_after_hwframe+0x77/0x7f
    [  117.320158][ T9855] RIP: 0033:0x7f7dd7908b07
    [  117.320163][ T9855] Code: 23 0d 00 f7 d8 64 89 01 48 83 c8 ff c3 66 0f 1f 44 00 00 31 f6 e9 09 00 00 00 66 0f 1f 84 00 00 08
    [  117.320167][ T9855] RSP: 002b:00007ffd5ebd9698 EFLAGS: 00000202 ORIG_RAX: 00000000000000a6
    [  117.320172][ T9855] RAX: ffffffffffffffda RBX: 0000000000000000 RCX: 00007f7dd7908b07
    [  117.320176][ T9855] RDX: 0000000000000009 RSI: 0000000000000009 RDI: 00007ffd5ebd9740
    [  117.320179][ T9855] RBP: 00007ffd5ebda780 R08: 0000000000000005 R09: 00007ffd5ebd9530
    [  117.320181][ T9855] R10: 00007f7dd799bfc0 R11: 0000000000000202 R12: 000055e2008b32d0
    [  117.320184][ T9855] R13: 0000000000000000 R14: 0000000000000000 R15: 0000000000000000
    [  117.320189][ T9855]  </TASK>
    [  117.320190][ T9855]
    [  117.351311][ T9855] Allocated by task 9855:
    [  117.351683][ T9855]  kasan_save_track+0x3e/0x80
    [  117.352093][ T9855]  __kasan_kmalloc+0x8d/0xa0
    [  117.352490][ T9855]  __kmalloc_noprof+0x288/0x510
    [  117.352914][ T9855]  hfsplus_find_init+0x8c/0x1d0
    [  117.353342][ T9855]  hfsplus_lookup+0x19c/0x890
    [  117.353747][ T9855]  __lookup_slow+0x297/0x3d0
    [  117.354148][ T9855]  lookup_slow+0x53/0x70
    [  117.354514][ T9855]  walk_component+0x2f0/0x430
    [  117.354921][ T9855]  path_lookupat+0x169/0x440
    [  117.355325][ T9855]  filename_lookup+0x212/0x590
    [  117.355740][ T9855]  user_path_at+0x3a/0x60
    [  117.356115][ T9855]  __x64_sys_umount+0xee/0x160
    [  117.356529][ T9855]  do_syscall_64+0xf3/0x3a0
    [  117.356920][ T9855]  entry_SYSCALL_64_after_hwframe+0x77/0x7f
    [  117.357429][ T9855]
    [  117.357636][ T9855] The buggy address belongs to the object at ffff88802160f000
    [  117.357636][ T9855]  which belongs to the cache kmalloc-2k of size 2048
    [  117.358827][ T9855] The buggy address is located 0 bytes to the right of
    [  117.358827][ T9855]  allocated 1036-byte region [ffff88802160f000, ffff88802160f40c)
    [  117.360061][ T9855]
    [  117.360266][ T9855] The buggy address belongs to the physical page:
    [  117.360813][ T9855] page: refcount:0 mapcount:0 mapping:0000000000000000 index:0x0 pfn:0x21608
    [  117.361562][ T9855] head: order:3 mapcount:0 entire_mapcount:0 nr_pages_mapped:0 pincount:0
    [  117.362285][ T9855] flags: 0xfff00000000040(head|node=0|zone=1|lastcpupid=0x7ff)
    [  117.362929][ T9855] page_type: f5(slab)
    [  117.363282][ T9855] raw: 00fff00000000040 ffff88801a842f00 ffffea0000932000 dead000000000002
    [  117.364015][ T9855] raw: 0000000000000000 0000000080080008 00000000f5000000 0000000000000000
    [  117.364750][ T9855] head: 00fff00000000040 ffff88801a842f00 ffffea0000932000 dead000000000002
    [  117.365491][ T9855] head: 0000000000000000 0000000080080008 00000000f5000000 0000000000000000
    [  117.366232][ T9855] head: 00fff00000000003 ffffea0000858201 00000000ffffffff 00000000ffffffff
    [  117.366968][ T9855] head: ffffffffffffffff 0000000000000000 00000000ffffffff 0000000000000008
    [  117.367711][ T9855] page dumped because: kasan: bad access detected
    [  117.368259][ T9855] page_owner tracks the page as allocated
    [  117.368745][ T9855] page last allocated via order 3, migratetype Unmovable, gfp_mask 0xd20c0(__GFP_IO|__GFP_FS|__GFP_NOWARN1
    [  117.370541][ T9855]  post_alloc_hook+0x240/0x2a0
    [  117.370954][ T9855]  get_page_from_freelist+0x2101/0x21e0
    [  117.371435][ T9855]  __alloc_frozen_pages_noprof+0x274/0x380
    [  117.371935][ T9855]  alloc_pages_mpol+0x241/0x4b0
    [  117.372360][ T9855]  allocate_slab+0x8d/0x380
    [  117.372752][ T9855]  ___slab_alloc+0xbe3/0x1400
    [  117.373159][ T9855]  __kmalloc_cache_noprof+0x296/0x3d0
    [  117.373621][ T9855]  nexthop_net_init+0x75/0x100
    [  117.374038][ T9855]  ops_init+0x35c/0x5c0
    [  117.374400][ T9855]  setup_net+0x10c/0x320
    [  117.374768][ T9855]  copy_net_ns+0x31b/0x4d0
    [  117.375156][ T9855]  create_new_namespaces+0x3f3/0x720
    [  117.375613][ T9855]  unshare_nsproxy_namespaces+0x11c/0x170
    [  117.376094][ T9855]  ksys_unshare+0x4ca/0x8d0
    [  117.376477][ T9855]  __x64_sys_unshare+0x38/0x50
    [  117.376879][ T9855]  do_syscall_64+0xf3/0x3a0
    [  117.377265][ T9855] page last free pid 9110 tgid 9110 stack trace:
    [  117.377795][ T9855]  __free_frozen_pages+0xbeb/0xd50
    [  117.378229][ T9855]  __put_partials+0x152/0x1a0
    [  117.378625][ T9855]  put_cpu_partial+0x17c/0x250
    [  117.379026][ T9855]  __slab_free+0x2d4/0x3c0
    [  117.379404][ T9855]  qlist_free_all+0x97/0x140
    [  117.379790][ T9855]  kasan_quarantine_reduce+0x148/0x160
    [  117.380250][ T9855]  __kasan_slab_alloc+0x22/0x80
    [  117.380662][ T9855]  __kmalloc_noprof+0x232/0x510
    [  117.381074][ T9855]  tomoyo_supervisor+0xc0a/0x1360
    [  117.381498][ T9855]  tomoyo_env_perm+0x149/0x1e0
    [  117.381903][ T9855]  tomoyo_find_next_domain+0x15ad/0x1b90
    [  117.382378][ T9855]  tomoyo_bprm_check_security+0x11c/0x180
    [  117.382859][ T9855]  security_bprm_check+0x89/0x280
    [  117.383289][ T9855]  bprm_execve+0x8f1/0x14a0
    [  117.383673][ T9855]  do_execveat_common+0x528/0x6b0
    [  117.384103][ T9855]  __x64_sys_execve+0x94/0xb0
    [  117.384500][ T9855]
    [  117.384706][ T9855] Memory state around the buggy address:
    [  117.385179][ T9855]  ffff88802160f300: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
    [  117.385854][ T9855]  ffff88802160f380: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
    [  117.386534][ T9855] >ffff88802160f400: 00 04 fc fc fc fc fc fc fc fc fc fc fc fc fc fc
    [  117.387204][ T9855]                       ^
    [  117.387566][ T9855]  ffff88802160f480: fc fc fc fc fc fc fc fc fc fc fc fc fc fc fc fc
    [  117.388243][ T9855]  ffff88802160f500: fc fc fc fc fc fc fc fc fc fc fc fc fc fc fc fc
    [  117.388918][ T9855] ==================================================================
    
    The issue takes place if the length field of struct hfsplus_unistr
    is bigger than HFSPLUS_MAX_STRLEN. The patch simply checks
    the length of comparing strings. And if the strings' length
    is bigger than HFSPLUS_MAX_STRLEN, then it is corrected
    to this value.
    
    v2
    The string length correction has been added for hfsplus_strcmp().
    
    Reported-by: Jiaming Zhang <r772577952@gmail.com>
    Signed-off-by: Viacheslav Dubeyko <slava@dubeyko.com>
    cc: John Paul Adrian Glaubitz <glaubitz@physik.fu-berlin.de>
    cc: Yangtao Li <frank.li@vivo.com>
    cc: linux-fsdevel@vger.kernel.org
    cc: syzkaller@googlegroups.com
    Link: https://lore.kernel.org/r/20250919191243.1370388-1-slava@dubeyko.com
    Signed-off-by: Viacheslav Dubeyko <slava@dubeyko.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
HID: hid-input: only ignore 0 battery events for digitizers [+ + +]
Author: Dmitry Torokhov <dmitry.torokhov@gmail.com>
Date:   Tue Oct 14 21:28:44 2025 -0700

    HID: hid-input: only ignore 0 battery events for digitizers
    
    [ Upstream commit 0187c08058da3e7f11b356ac27e0c427d36f33f2 ]
    
    Commit 581c4484769e ("HID: input: map digitizer battery usage") added
    handling of battery events for digitizers (typically for batteries
    presented in stylii). Digitizers typically report correct battery levels
    only when stylus is actively touching the surface, and in other cases
    they may report battery level of 0. To avoid confusing consumers of the
    battery information the code was added to filer out reports with 0
    battery levels.
    
    However there exist other kinds of devices that may legitimately report
    0 battery levels. Fix this by filtering out 0-level reports only for
    digitizer usages, and continue reporting them for other kinds of devices
    (Smart Batteries, etc).
    
    Reported-by: 卢国宏 <luguohong@xiaomi.com>
    Fixes: 581c4484769e ("HID: input: map digitizer battery usage")
    Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
    Signed-off-by: Jiri Kosina <jkosina@suse.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

HID: multitouch: fix name of Stylus input devices [+ + +]
Author: Thadeu Lima de Souza Cascardo <cascardo@igalia.com>
Date:   Wed Oct 8 09:40:33 2025 -0300

    HID: multitouch: fix name of Stylus input devices
    
    [ Upstream commit aa4daea418ee4215dca5c8636090660c545cb233 ]
    
    HID_DG_PEN devices should have a suffix of "Stylus", as pointed out by
    commit c0ee1d571626 ("HID: hid-input: Add suffix also for HID_DG_PEN").
    However, on multitouch devices, these suffixes may be overridden. Before
    that commit, HID_DG_PEN devices would get the "Stylus" suffix, but after
    that, multitouch would override them to have an "UNKNOWN" suffix. Just add
    HID_DG_PEN to the list of non-overriden suffixes in multitouch.
    
    Before this fix:
    
    [    0.470981] input: ELAN9008:00 04F3:2E14 UNKNOWN as /devices/pci0000:00/0000:00:15.1/i2c_designware.1/i2c-16/i2c-ELAN9008:00/0018:04F3:2E14.0001/input/input8
    ELAN9008:00 04F3:2E14 UNKNOWN
    
    After this fix:
    
    [    0.474332] input: ELAN9008:00 04F3:2E14 Stylus as /devices/pci0000:00/0000:00:15.1/i2c_designware.1/i2c-16/i2c-ELAN9008:00/0018:04F3:2E14.0001/input/input8
    
    ELAN9008:00 04F3:2E14 Stylus
    
    Fixes: c0ee1d571626 ("HID: hid-input: Add suffix also for HID_DG_PEN")
    Signed-off-by: Thadeu Lima de Souza Cascardo <cascardo@igalia.com>
    Reviewed-by: Mika Westerberg <mika.westerberg@linux.intel.com>
    Signed-off-by: Jiri Kosina <jkosina@suse.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

HID: multitouch: fix sticky fingers [+ + +]
Author: Benjamin Tissoires <bentiss@kernel.org>
Date:   Wed Oct 8 16:06:58 2025 +0200

    HID: multitouch: fix sticky fingers
    
    commit 46f781e0d151844589dc2125c8cce3300546f92a upstream.
    
    The sticky fingers quirk (MT_QUIRK_STICKY_FINGERS) was only considering
    the case when slots were not released during the last report.
    This can be problematic if the firmware forgets to release a finger
    while others are still present.
    
    This was observed on the Synaptics DLL0945 touchpad found on the Dell
    XPS 9310 and the Dell Inspiron 5406.
    
    Fixes: 4f4001bc76fd ("HID: multitouch: fix rare Win 8 cases when the touch up event gets missing")
    Cc: stable@vger.kernel.org
    Signed-off-by: Benjamin Tissoires <bentiss@kernel.org>
    Signed-off-by: Jiri Kosina <jkosina@suse.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
iio: imu: inv_icm42600: Avoid configuring if already pm_runtime suspended [+ + +]
Author: Sean Nyekjaer <sean@geanix.com>
Date:   Mon Oct 20 09:09:00 2025 -0400

    iio: imu: inv_icm42600: Avoid configuring if already pm_runtime suspended
    
    [ Upstream commit 466f7a2fef2a4e426f809f79845a1ec1aeb558f4 ]
    
    Do as in suspend, skip resume configuration steps if the device is already
    pm_runtime suspended. This avoids reconfiguring a device that is already
    in the correct low-power state and ensures that pm_runtime handles the
    power state transitions properly.
    
    Fixes: 31c24c1e93c3 ("iio: imu: inv_icm42600: add core of new inv_icm42600 driver")
    Signed-off-by: Sean Nyekjaer <sean@geanix.com>
    Link: https://patch.msgid.link/20250901-icm42pmreg-v3-3-ef1336246960@geanix.com
    Cc: <Stable@vger.kernel.org>
    Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
    [ adjusted context due to missing APEX/WoM features in older kernel version ]
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

iio: imu: inv_icm42600: reorganize DMA aligned buffers in structure [+ + +]
Author: Jean-Baptiste Maneyrol <jean-baptiste.maneyrol@tdk.com>
Date:   Mon Oct 20 09:08:59 2025 -0400

    iio: imu: inv_icm42600: reorganize DMA aligned buffers in structure
    
    [ Upstream commit 0c122c280e78150b0c666fb69db0000cdd1d7e0a ]
    
    Move all DMA aligned buffers together at the end of the structure.
    
    1. Timestamp anynomous structure is not used with DMA so it doesn't
    belong after __aligned(IIO_DMA_MINALIGN).
    2. struct inv_icm42600_fifo contains it's own __aligned(IIO_DMA_MINALIGN)
    within it at the end so it should not be after __aligned(IIO_DMA_MINALIGN)
    in the outer struct either.
    3. Normally 1 would have been considered a bug, but because of the extra
    alignment from 2, it actually was OK, but we shouldn't be relying on such
    quirks.
    
    Signed-off-by: Jean-Baptiste Maneyrol <jean-baptiste.maneyrol@tdk.com>
    Link: https://patch.msgid.link/20250630-losd-3-inv-icm42600-add-wom-support-v6-1-5bb0c84800d9@tdk.com
    Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
    Stable-dep-of: 466f7a2fef2a ("iio: imu: inv_icm42600: Avoid configuring if already pm_runtime suspended")
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

iio: imu: inv_icm42600: Simplify pm_runtime setup [+ + +]
Author: Sean Nyekjaer <sean@geanix.com>
Date:   Mon Oct 20 09:03:03 2025 -0400

    iio: imu: inv_icm42600: Simplify pm_runtime setup
    
    [ Upstream commit 0792c1984a45ccd7a296d6b8cb78088bc99a212e ]
    
    Rework the power management in inv_icm42600_core_probe() to use
    devm_pm_runtime_set_active_enabled(), which simplifies the runtime PM
    setup by handling activation and enabling in one step.
    Remove the separate inv_icm42600_disable_pm callback, as it's no longer
    needed with the devm-managed approach.
    Using devm_pm_runtime_enable() also fixes the missing disable of
    autosuspend.
    Update inv_icm42600_disable_vddio_reg() to only disable the regulator if
    the device is not suspended i.e. powered-down, preventing unbalanced
    disables.
    Also remove redundant error msg on regulator_disable(), the regulator
    framework already emits an error message when regulator_disable() fails.
    
    This simplifies the PM setup and avoids manipulating the usage counter
    unnecessarily.
    
    Fixes: 31c24c1e93c3 ("iio: imu: inv_icm42600: add core of new inv_icm42600 driver")
    Signed-off-by: Sean Nyekjaer <sean@geanix.com>
    Link: https://patch.msgid.link/20250901-icm42pmreg-v3-1-ef1336246960@geanix.com
    Cc: <Stable@vger.kernel.org>
    Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
ixgbevf: Add support for Intel(R) E610 device [+ + +]
Author: Piotr Kwapulinski <piotr.kwapulinski@intel.com>
Date:   Mon Oct 20 14:10:26 2025 -0400

    ixgbevf: Add support for Intel(R) E610 device
    
    [ Upstream commit 4c44b450c69b676955c2790dcf467c1f969d80f1 ]
    
    Add support for Intel(R) E610 Series of network devices. The E610
    is based on X550 but adds firmware managed link, enhanced security
    capabilities and support for updated server manageability
    
    Reviewed-by: Przemek Kitszel <przemyslaw.kitszel@intel.com>
    Signed-off-by: Piotr Kwapulinski <piotr.kwapulinski@intel.com>
    Reviewed-by: Simon Horman <horms@kernel.org>
    Tested-by: Rafal Romanowski <rafal.romanowski@intel.com>
    Signed-off-by: Tony Nguyen <anthony.l.nguyen@intel.com>
    Stable-dep-of: a7075f501bd3 ("ixgbevf: fix mailbox API compatibility by negotiating supported features")
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

ixgbevf: fix getting link speed data for E610 devices [+ + +]
Author: Jedrzej Jagielski <jedrzej.jagielski@intel.com>
Date:   Mon Oct 20 14:10:27 2025 -0400

    ixgbevf: fix getting link speed data for E610 devices
    
    [ Upstream commit 53f0eb62b4d23d40686f2dd51776b8220f2887bb ]
    
    E610 adapters no longer use the VFLINKS register to read PF's link
    speed and linkup state. As a result VF driver cannot get actual link
    state and it incorrectly reports 10G which is the default option.
    It leads to a situation where even 1G adapters print 10G as actual
    link speed. The same happens when PF driver set speed different than 10G.
    
    Add new mailbox operation to let the VF driver request a PF driver
    to provide actual link data. Update the mailbox api to v1.6.
    
    Incorporate both ways of getting link status within the legacy
    ixgbe_check_mac_link_vf() function.
    
    Fixes: 4c44b450c69b ("ixgbevf: Add support for Intel(R) E610 device")
    Co-developed-by: Andrzej Wilczynski <andrzejx.wilczynski@intel.com>
    Signed-off-by: Andrzej Wilczynski <andrzejx.wilczynski@intel.com>
    Reviewed-by: Przemek Kitszel <przemyslaw.kitszel@intel.com>
    Reviewed-by: Aleksandr Loktionov <aleksandr.loktionov@intel.com>
    Cc: stable@vger.kernel.org
    Signed-off-by: Jedrzej Jagielski <jedrzej.jagielski@intel.com>
    Tested-by: Rafal Romanowski <rafal.romanowski@intel.com>
    Signed-off-by: Jacob Keller <jacob.e.keller@intel.com>
    Link: https://patch.msgid.link/20251009-jk-iwl-net-2025-10-01-v3-2-ef32a425b92a@intel.com
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Stable-dep-of: a7075f501bd3 ("ixgbevf: fix mailbox API compatibility by negotiating supported features")
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

ixgbevf: fix mailbox API compatibility by negotiating supported features [+ + +]
Author: Jedrzej Jagielski <jedrzej.jagielski@intel.com>
Date:   Mon Oct 20 14:10:28 2025 -0400

    ixgbevf: fix mailbox API compatibility by negotiating supported features
    
    [ Upstream commit a7075f501bd33c93570af759b6f4302ef0175168 ]
    
    There was backward compatibility in the terms of mailbox API. Various
    drivers from various OSes supporting 10G adapters from Intel portfolio
    could easily negotiate mailbox API.
    
    This convention has been broken since introducing API 1.4.
    Commit 0062e7cc955e ("ixgbevf: add VF IPsec offload code") added support
    for IPSec which is specific only for the kernel ixgbe driver. None of the
    rest of the Intel 10G PF/VF drivers supports it. And actually lack of
    support was not included in the IPSec implementation - there were no such
    code paths. No possibility to negotiate support for the feature was
    introduced along with introduction of the feature itself.
    
    Commit 339f28964147 ("ixgbevf: Add support for new mailbox communication
    between PF and VF") increasing API version to 1.5 did the same - it
    introduced code supported specifically by the PF ESX driver. It altered API
    version for the VF driver in the same time not touching the version
    defined for the PF ixgbe driver. It led to additional discrepancies,
    as the code provided within API 1.6 cannot be supported for Linux ixgbe
    driver as it causes crashes.
    
    The issue was noticed some time ago and mitigated by Jake within the commit
    d0725312adf5 ("ixgbevf: stop attempting IPSEC offload on Mailbox API 1.5").
    As a result we have regression for IPsec support and after increasing API
    to version 1.6 ixgbevf driver stopped to support ESX MBX.
    
    To fix this mess add new mailbox op asking PF driver about supported
    features. Basing on a response determine whether to set support for IPSec
    and ESX-specific enhanced mailbox.
    
    New mailbox op, for compatibility purposes, must be added within new API
    revision, as API version of OOT PF & VF drivers is already increased to
    1.6 and doesn't incorporate features negotiate op.
    
    Features negotiation mechanism gives possibility to be extended with new
    features when needed in the future.
    
    Reported-by: Jacob Keller <jacob.e.keller@intel.com>
    Closes: https://lore.kernel.org/intel-wired-lan/20241101-jk-ixgbevf-mailbox-v1-5-fixes-v1-0-f556dc9a66ed@intel.com/
    Fixes: 0062e7cc955e ("ixgbevf: add VF IPsec offload code")
    Fixes: 339f28964147 ("ixgbevf: Add support for new mailbox communication between PF and VF")
    Reviewed-by: Jacob Keller <jacob.e.keller@intel.com>
    Reviewed-by: Przemek Kitszel <przemyslaw.kitszel@intel.com>
    Reviewed-by: Aleksandr Loktionov <aleksandr.loktionov@intel.com>
    Cc: stable@vger.kernel.org
    Signed-off-by: Jedrzej Jagielski <jedrzej.jagielski@intel.com>
    Tested-by: Rafal Romanowski <rafal.romanowski@intel.com>
    Signed-off-by: Jacob Keller <jacob.e.keller@intel.com>
    Link: https://patch.msgid.link/20251009-jk-iwl-net-2025-10-01-v3-4-ef32a425b92a@intel.com
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
jbd2: ensure that all ongoing I/O complete before freeing blocks [+ + +]
Author: Zhang Yi <yi.zhang@huawei.com>
Date:   Tue Sep 16 17:33:36 2025 +0800

    jbd2: ensure that all ongoing I/O complete before freeing blocks
    
    commit 3c652c3a71de1d30d72dc82c3bead8deb48eb749 upstream.
    
    When releasing file system metadata blocks in jbd2_journal_forget(), if
    this buffer has not yet been checkpointed, it may have already been
    written back, currently be in the process of being written back, or has
    not yet written back.  jbd2_journal_forget() calls
    jbd2_journal_try_remove_checkpoint() to check the buffer's status and
    add it to the current transaction if it has not been written back. This
    buffer can only be reallocated after the transaction is committed.
    
    jbd2_journal_try_remove_checkpoint() attempts to lock the buffer and
    check its dirty status while holding the buffer lock. If the buffer has
    already been written back, everything proceeds normally. However, there
    are two issues. First, the function returns immediately if the buffer is
    locked by the write-back process. It does not wait for the write-back to
    complete. Consequently, until the current transaction is committed and
    the block is reallocated, there is no guarantee that the I/O will
    complete. This means that ongoing I/O could write stale metadata to the
    newly allocated block, potentially corrupting data. Second, the function
    unlocks the buffer as soon as it detects that the buffer is still dirty.
    If a concurrent write-back occurs immediately after this unlocking and
    before clear_buffer_dirty() is called in jbd2_journal_forget(), data
    corruption can theoretically still occur.
    
    Although these two issues are unlikely to occur in practice since the
    undergoing metadata writeback I/O does not take this long to complete,
    it's better to explicitly ensure that all ongoing I/O operations are
    completed.
    
    Fixes: 597599268e3b ("jbd2: discard dirty data when forgetting an un-journalled buffer")
    Cc: stable@kernel.org
    Suggested-by: Jan Kara <jack@suse.cz>
    Signed-off-by: Zhang Yi <yi.zhang@huawei.com>
    Reviewed-by: Jan Kara <jack@suse.cz>
    Message-ID: <20250916093337.3161016-2-yi.zhang@huaweicloud.com>
    Signed-off-by: Theodore Ts'o <tytso@mit.edu>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
ksmbd: browse interfaces list on FSCTL_QUERY_INTERFACE_INFO IOCTL [+ + +]
Author: Namjae Jeon <linkinjeon@kernel.org>
Date:   Fri Jan 10 13:37:05 2025 +0900

    ksmbd: browse interfaces list on FSCTL_QUERY_INTERFACE_INFO IOCTL
    
    commit b2d99376c5d61eb60ffdb6c503e4b6c8f9712ddd upstream.
    
    ksmbd.mount will give each interfaces list and bind_interfaces_only flags
    to ksmbd server. Previously, the interfaces list was sent only
    when bind_interfaces_only was enabled.
    ksmbd server browse only interfaces list given from ksmbd.conf on
    FSCTL_QUERY_INTERFACE_INFO IOCTL.
    
    Signed-off-by: Namjae Jeon <linkinjeon@kernel.org>
    Signed-off-by: Steve French <stfrench@microsoft.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
Linux: Linux 6.6.114 [+ + +]
Author: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Date:   Thu Oct 23 16:16:45 2025 +0200

    Linux 6.6.114
    
    Link: https://lore.kernel.org/r/20251021195021.492915002@linuxfoundation.org
    Tested-by: Florian Fainelli <florian.fainelli@broadcom.com>
    Tested-by: Hardik Garg <hargar@linux.microsoft.com>
    Tested-by: Peter Schneider <pschneider1968@googlemail.com>
    Tested-by: Brett A C Sheffield <bacs@librecast.net>
    Tested-by: Ron Economos <re@w6rz.net>
    Tested-by: Linux Kernel Functional Testing <lkft@linaro.org>
    Tested-by: Pavel Machek (CIP) <pavel@denx.de>
    Tested-by: Mark Brown <broonie@kernel.org>
    Tested-by: Jon Hunter <jonathanh@nvidia.com>
    Tested-by: Shuah Khan <skhan@linuxfoundation.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
media: nxp: imx8-isi: Drop unused argument to mxc_isi_channel_chain() [+ + +]
Author: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
Date:   Fri Oct 17 19:31:54 2025 -0400

    media: nxp: imx8-isi: Drop unused argument to mxc_isi_channel_chain()
    
    [ Upstream commit 9a21ffeade25cbf310f5db39a1f9932695dd41bb ]
    
    The bypass argument to the mxc_isi_channel_chain() function is unused.
    Drop it.
    
    Link: https://lore.kernel.org/r/20250813225501.20762-1-laurent.pinchart@ideasonboard.com
    Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
    Reviewed-by: Frank Li <Frank.Li@nxp.com>
    Signed-off-by: Hans Verkuil <hverkuil+cisco@kernel.org>
    Stable-dep-of: 178aa3360220 ("media: nxp: imx8-isi: m2m: Fix streaming cleanup on release")
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

media: nxp: imx8-isi: m2m: Fix streaming cleanup on release [+ + +]
Author: Guoniu Zhou <guoniu.zhou@nxp.com>
Date:   Fri Oct 17 19:31:55 2025 -0400

    media: nxp: imx8-isi: m2m: Fix streaming cleanup on release
    
    [ Upstream commit 178aa3360220231dd91e7dbc2eb984525886c9c1 ]
    
    If streamon/streamoff calls are imbalanced, such as when exiting an
    application with Ctrl+C when streaming, the m2m usage_count will never
    reach zero and the ISI channel won't be freed. Besides from that, if the
    input line width is more than 2K, it will trigger a WARN_ON():
    
    [ 59.222120] ------------[ cut here ]------------
    [ 59.226758] WARNING: drivers/media/platform/nxp/imx8-isi/imx8-isi-hw.c:631 at mxc_isi_channel_chain+0xa4/0x120, CPU#4: v4l2-ctl/654
    [ 59.238569] Modules linked in: ap1302
    [ 59.242231] CPU: 4 UID: 0 PID: 654 Comm: v4l2-ctl Not tainted 6.16.0-rc4-next-20250704-06511-gff0e002d480a-dirty #258 PREEMPT
    [ 59.253597] Hardware name: NXP i.MX95 15X15 board (DT)
    [ 59.258720] pstate: 80400009 (Nzcv daif +PAN -UAO -TCO -DIT -SSBS BTYPE=--)
    [ 59.265669] pc : mxc_isi_channel_chain+0xa4/0x120
    [ 59.270358] lr : mxc_isi_channel_chain+0x44/0x120
    [ 59.275047] sp : ffff8000848c3b40
    [ 59.278348] x29: ffff8000848c3b40 x28: ffff0000859b4c98 x27: ffff800081939f00
    [ 59.285472] x26: 000000000000000a x25: ffff0000859b4cb8 x24: 0000000000000001
    [ 59.292597] x23: ffff0000816f4760 x22: ffff0000816f4258 x21: ffff000084ceb780
    [ 59.299720] x20: ffff000084342ff8 x19: ffff000084340000 x18: 0000000000000000
    [ 59.306845] x17: 0000000000000000 x16: 0000000000000000 x15: 0000ffffdb369e1c
    [ 59.313969] x14: 0000000000000000 x13: 0000000000000000 x12: 0000000000000000
    [ 59.321093] x11: 0000000000000000 x10: 0000000000000000 x9 : 0000000000000000
    [ 59.328217] x8 : ffff8000848c3d48 x7 : ffff800081930b30 x6 : ffff800081930b30
    [ 59.335340] x5 : ffff0000859b6000 x4 : ffff80008193ae80 x3 : ffff800081022420
    [ 59.342464] x2 : ffff0000852f6900 x1 : 0000000000000001 x0 : ffff000084341000
    [ 59.349590] Call trace:
    [ 59.352025]  mxc_isi_channel_chain+0xa4/0x120 (P)
    [ 59.356722]  mxc_isi_m2m_streamon+0x160/0x20c
    [ 59.361072]  v4l_streamon+0x24/0x30
    [ 59.364556]  __video_do_ioctl+0x40c/0x4a0
    [ 59.368560]  video_usercopy+0x2bc/0x690
    [ 59.372382]  video_ioctl2+0x18/0x24
    [ 59.375857]  v4l2_ioctl+0x40/0x60
    [ 59.379168]  __arm64_sys_ioctl+0xac/0x104
    [ 59.383172]  invoke_syscall+0x48/0x104
    [ 59.386916]  el0_svc_common.constprop.0+0xc0/0xe0
    [ 59.391613]  do_el0_svc+0x1c/0x28
    [ 59.394915]  el0_svc+0x34/0xf4
    [ 59.397966]  el0t_64_sync_handler+0xa0/0xe4
    [ 59.402143]  el0t_64_sync+0x198/0x19c
    [ 59.405801] ---[ end trace 0000000000000000 ]---
    
    Address this issue by moving the streaming preparation and cleanup to
    the vb2 .prepare_streaming() and .unprepare_streaming() operations. This
    also simplifies the driver by allowing direct usage of the
    v4l2_m2m_ioctl_streamon() and v4l2_m2m_ioctl_streamoff() helpers.
    
    Fixes: cf21f328fcaf ("media: nxp: Add i.MX8 ISI driver")
    Cc: stable@vger.kernel.org
    Link: https://lore.kernel.org/r/20250821135123.29462-1-laurent.pinchart@ideasonboard.com
    Signed-off-by: Guoniu Zhou <guoniu.zhou@nxp.com>
    Co-developed-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
    Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
    Tested-by: Guoniu Zhou <guoniu.zhou@nxp.com>
    Reviewed-by: Frank Li <Frank.Li@nxp.com>
    Signed-off-by: Hans Verkuil <hverkuil+cisco@kernel.org>
    [ Adjust context ]
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
mm/ksm: fix flag-dropping behavior in ksm_madvise [+ + +]
Author: Jakub Acs <acsjakub@amazon.de>
Date:   Wed Oct 1 09:03:52 2025 +0000

    mm/ksm: fix flag-dropping behavior in ksm_madvise
    
    commit f04aad36a07cc17b7a5d5b9a2d386ce6fae63e93 upstream.
    
    syzkaller discovered the following crash: (kernel BUG)
    
    [   44.607039] ------------[ cut here ]------------
    [   44.607422] kernel BUG at mm/userfaultfd.c:2067!
    [   44.608148] Oops: invalid opcode: 0000 [#1] SMP DEBUG_PAGEALLOC KASAN NOPTI
    [   44.608814] CPU: 1 UID: 0 PID: 2475 Comm: reproducer Not tainted 6.16.0-rc6 #1 PREEMPT(none)
    [   44.609635] Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS rel-1.16.3-0-ga6ed6b701f0a-prebuilt.qemu.org 04/01/2014
    [   44.610695] RIP: 0010:userfaultfd_release_all+0x3a8/0x460
    
    <snip other registers, drop unreliable trace>
    
    [   44.617726] Call Trace:
    [   44.617926]  <TASK>
    [   44.619284]  userfaultfd_release+0xef/0x1b0
    [   44.620976]  __fput+0x3f9/0xb60
    [   44.621240]  fput_close_sync+0x110/0x210
    [   44.622222]  __x64_sys_close+0x8f/0x120
    [   44.622530]  do_syscall_64+0x5b/0x2f0
    [   44.622840]  entry_SYSCALL_64_after_hwframe+0x76/0x7e
    [   44.623244] RIP: 0033:0x7f365bb3f227
    
    Kernel panics because it detects UFFD inconsistency during
    userfaultfd_release_all().  Specifically, a VMA which has a valid pointer
    to vma->vm_userfaultfd_ctx, but no UFFD flags in vma->vm_flags.
    
    The inconsistency is caused in ksm_madvise(): when user calls madvise()
    with MADV_UNMEARGEABLE on a VMA that is registered for UFFD in MINOR mode,
    it accidentally clears all flags stored in the upper 32 bits of
    vma->vm_flags.
    
    Assuming x86_64 kernel build, unsigned long is 64-bit and unsigned int and
    int are 32-bit wide.  This setup causes the following mishap during the &=
    ~VM_MERGEABLE assignment.
    
    VM_MERGEABLE is a 32-bit constant of type unsigned int, 0x8000'0000.
    After ~ is applied, it becomes 0x7fff'ffff unsigned int, which is then
    promoted to unsigned long before the & operation.  This promotion fills
    upper 32 bits with leading 0s, as we're doing unsigned conversion (and
    even for a signed conversion, this wouldn't help as the leading bit is 0).
    & operation thus ends up AND-ing vm_flags with 0x0000'0000'7fff'ffff
    instead of intended 0xffff'ffff'7fff'ffff and hence accidentally clears
    the upper 32-bits of its value.
    
    Fix it by changing `VM_MERGEABLE` constant to unsigned long, using the
    BIT() macro.
    
    Note: other VM_* flags are not affected: This only happens to the
    VM_MERGEABLE flag, as the other VM_* flags are all constants of type int
    and after ~ operation, they end up with leading 1 and are thus converted
    to unsigned long with leading 1s.
    
    Note 2:
    After commit 31defc3b01d9 ("userfaultfd: remove (VM_)BUG_ON()s"), this is
    no longer a kernel BUG, but a WARNING at the same place:
    
    [   45.595973] WARNING: CPU: 1 PID: 2474 at mm/userfaultfd.c:2067
    
    but the root-cause (flag-drop) remains the same.
    
    [akpm@linux-foundation.org: rust bindgen wasn't able to handle BIT(), from Miguel]
      Link: https://lore.kernel.org/oe-kbuild-all/202510030449.VfSaAjvd-lkp@intel.com/
    Link: https://lkml.kernel.org/r/20251001090353.57523-2-acsjakub@amazon.de
    Fixes: 7677f7fd8be7 ("userfaultfd: add minor fault registration mode")
    Signed-off-by: Jakub Acs <acsjakub@amazon.de>
    Signed-off-by: Miguel Ojeda <miguel.ojeda.sandonis@gmail.com>
    Acked-by: David Hildenbrand <david@redhat.com>
    Acked-by: SeongJae Park <sj@kernel.org>
    Tested-by: Alice Ryhl <aliceryhl@google.com>
    Tested-by: Miguel Ojeda <miguel.ojeda.sandonis@gmail.com>
    Cc: Xu Xin <xu.xin16@zte.com.cn>
    Cc: Chengming Zhou <chengming.zhou@linux.dev>
    Cc: Peter Xu <peterx@redhat.com>
    Cc: Axel Rasmussen <axelrasmussen@google.com>
    Cc: <stable@vger.kernel.org>
    Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
    [acsjakub@amazon.de: adapt rust bindgen const to older versions]
    Signed-off-by: Jakub Acs <acsjakub@amazon.de>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
net/ip6_tunnel: Prevent perpetual tunnel growth [+ + +]
Author: Dmitry Safonov <0x7f454c46@gmail.com>
Date:   Thu Oct 9 16:02:19 2025 +0100

    net/ip6_tunnel: Prevent perpetual tunnel growth
    
    [ Upstream commit 21f4d45eba0b2dcae5dbc9e5e0ad08735c993f16 ]
    
    Similarly to ipv4 tunnel, ipv6 version updates dev->needed_headroom, too.
    While ipv4 tunnel headroom adjustment growth was limited in
    commit 5ae1e9922bbd ("net: ip_tunnel: prevent perpetual headroom growth"),
    ipv6 tunnel yet increases the headroom without any ceiling.
    
    Reflect ipv4 tunnel headroom adjustment limit on ipv6 version.
    
    Credits to Francesco Ruggeri, who was originally debugging this issue
    and wrote local Arista-specific patch and a reproducer.
    
    Fixes: 8eb30be0352d ("ipv6: Create ip6_tnl_xmit")
    Cc: Florian Westphal <fw@strlen.de>
    Cc: Francesco Ruggeri <fruggeri05@gmail.com>
    Signed-off-by: Dmitry Safonov <dima@arista.com>
    Link: https://patch.msgid.link/20251009-ip6_tunnel-headroom-v2-1-8e4dbd8f7e35@arista.com
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
net: dlink: handle dma_map_single() failure properly [+ + +]
Author: Yeounsu Moon <yyyynoom@gmail.com>
Date:   Fri Oct 10 00:57:16 2025 +0900

    net: dlink: handle dma_map_single() failure properly
    
    [ Upstream commit 65946eac6d888d50ae527c4e5c237dbe5cc3a2f2 ]
    
    There is no error handling for `dma_map_single()` failures.
    
    Add error handling by checking `dma_mapping_error()` and freeing
    the `skb` using `dev_kfree_skb()` (process context) when it fails.
    
    Fixes: 1da177e4c3f4 ("Linux-2.6.12-rc2")
    Signed-off-by: Yeounsu Moon <yyyynoom@gmail.com>
    Tested-on: D-Link DGE-550T Rev-A3
    Suggested-by: Simon Horman <horms@kernel.org>
    Reviewed-by: Simon Horman <horms@kernel.org>
    Signed-off-by: David S. Miller <davem@davemloft.net>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

net: tls: wait for async completion on last message [+ + +]
Author: Sascha Hauer <s.hauer@pengutronix.de>
Date:   Wed Sep 4 14:17:41 2024 +0200

    net: tls: wait for async completion on last message
    
    [ Upstream commit 54001d0f2fdbc7852136a00f3e6fc395a9547ae5 ]
    
    When asynchronous encryption is used KTLS sends out the final data at
    proto->close time. This becomes problematic when the task calling
    close() receives a signal. In this case it can happen that
    tcp_sendmsg_locked() called at close time returns -ERESTARTSYS and the
    final data is not sent.
    
    The described situation happens when KTLS is used in conjunction with
    io_uring, as io_uring uses task_work_add() to add work to the current
    userspace task. A discussion of the problem along with a reproducer can
    be found in [1] and [2]
    
    Fix this by waiting for the asynchronous encryption to be completed on
    the final message. With this there is no data left to be sent at close
    time.
    
    [1] https://lore.kernel.org/all/20231010141932.GD3114228@pengutronix.de/
    [2] https://lore.kernel.org/all/20240315100159.3898944-1-s.hauer@pengutronix.de/
    
    Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>
    Link: https://patch.msgid.link/20240904-ktls-wait-async-v1-1-a62892833110@pengutronix.de
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Stable-dep-of: b014a4e066c5 ("tls: wait for async encrypt in case of error during latter iterations of sendmsg")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

net: usb: lan78xx: Add error handling to lan78xx_init_mac_address [+ + +]
Author: Oleksij Rempel <o.rempel@pengutronix.de>
Date:   Mon Dec 9 14:07:42 2024 +0100

    net: usb: lan78xx: Add error handling to lan78xx_init_mac_address
    
    [ Upstream commit 6f31135894ec96481e2bda93a1da70712f5e57c1 ]
    
    Convert `lan78xx_init_mac_address` to return error codes and handle
    failures in register read and write operations. Update `lan78xx_reset`
    to check for errors during MAC address initialization and propagate them
    appropriately.
    
    Signed-off-by: Oleksij Rempel <o.rempel@pengutronix.de>
    Reviewed-by: Andrew Lunn <andrew@lunn.ch>
    Link: https://patch.msgid.link/20241209130751.703182-3-o.rempel@pengutronix.de
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Stable-dep-of: 8d93ff40d49d ("net: usb: lan78xx: fix use of improperly initialized dev->chipid in lan78xx_reset")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

net: usb: lan78xx: fix use of improperly initialized dev->chipid in lan78xx_reset [+ + +]
Author: I Viswanath <viswanathiyyappan@gmail.com>
Date:   Mon Oct 13 23:46:48 2025 +0530

    net: usb: lan78xx: fix use of improperly initialized dev->chipid in lan78xx_reset
    
    [ Upstream commit 8d93ff40d49d70e05c82a74beae31f883fe0eaf8 ]
    
    dev->chipid is used in lan78xx_init_mac_address before it's initialized:
    
    lan78xx_reset() {
        lan78xx_init_mac_address()
            lan78xx_read_eeprom()
                lan78xx_read_raw_eeprom() <- dev->chipid is used here
    
        dev->chipid = ... <- dev->chipid is initialized correctly here
    }
    
    Reorder initialization so that dev->chipid is set before calling
    lan78xx_init_mac_address().
    
    Fixes: a0db7d10b76e ("lan78xx: Add to handle mux control per chip id")
    Signed-off-by: I Viswanath <viswanathiyyappan@gmail.com>
    Reviewed-by: Vadim Fedorenko <vadim.fedorenko@linux.dev>
    Reviewed-by: Khalid Aziz <khalid@kernel.org>
    Link: https://patch.msgid.link/20251013181648.35153-1-viswanathiyyappan@gmail.com
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
nfsd: decouple the xprtsec policy check from check_nfsd_access() [+ + +]
Author: Scott Mayhew <smayhew@redhat.com>
Date:   Mon Oct 20 16:50:04 2025 -0400

    nfsd: decouple the xprtsec policy check from check_nfsd_access()
    
    [ Upstream commit e4f574ca9c6dfa66695bb054ff5df43ecea873ec ]
    
    This is a backport of e4f574ca9c6d specifically for the 6.6-stable
    kernel.  It differs from the upstream version mainly in that it's
    working around the absence of some 6.12-era commits:
    - 1459ad57673b nfsd: Move error code mapping to per-version proc code.
    - 0a183f24a7ae NFSD: Handle @rqstp == NULL in check_nfsd_access()
    - 5e66d2d92a1c nfsd: factor out __fh_verify to allow NULL rqstp to be
      passed
    
    A while back I had reported that an NFSv3 client could successfully
    mount using '-o xprtsec=none' an export that had been exported with
    'xprtsec=tls:mtls'.  By "successfully" I mean that the mount command
    would succeed and the mount would show up in /proc/mount.  Attempting
    to do anything futher with the mount would be met with NFS3ERR_ACCES.
    
    Transport Layer Security isn't an RPC security flavor or pseudo-flavor,
    so we shouldn't be conflating them when determining whether the access
    checks can be bypassed.  Split check_nfsd_access() into two helpers, and
    have fh_verify() call the helpers directly since fh_verify() has
    logic that allows one or both of the checks to be skipped.  All other
    sites will continue to call check_nfsd_access().
    
    Link: https://lore.kernel.org/linux-nfs/ZjO3Qwf_G87yNXb2@aion/
    Fixes: 9280c5774314 ("NFSD: Handle new xprtsec= export option")
    Signed-off-by: Scott Mayhew <smayhew@redhat.com>
    Acked-by: Chuck Lever <chuck.lever@oracle.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
NFSD: Define a proc_layoutcommit for the FlexFiles layout type [+ + +]
Author: Chuck Lever <chuck.lever@oracle.com>
Date:   Mon Oct 20 17:50:14 2025 -0400

    NFSD: Define a proc_layoutcommit for the FlexFiles layout type
    
    [ Upstream commit 4b47a8601b71ad98833b447d465592d847b4dc77 ]
    
    Avoid a crash if a pNFS client should happen to send a LAYOUTCOMMIT
    operation on a FlexFiles layout.
    
    Reported-by: Robert Morris <rtm@csail.mit.edu>
    Closes: https://lore.kernel.org/linux-nfs/152f99b2-ba35-4dec-93a9-4690e625dccd@oracle.com/T/#t
    Cc: Thomas Haynes <loghyr@hammerspace.com>
    Cc: stable@vger.kernel.org
    Fixes: 9b9960a0ca47 ("nfsd: Add a super simple flex file server")
    Signed-off-by: Chuck Lever <chuck.lever@oracle.com>
    [ removed struct svc_rqst parameter from nfsd4_ff_proc_layoutcommit ]
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

NFSD: Fix last write offset handling in layoutcommit [+ + +]
Author: Sergey Bashirov <sergeybashirov@gmail.com>
Date:   Mon Oct 20 08:54:07 2025 -0400

    NFSD: Fix last write offset handling in layoutcommit
    
    [ Upstream commit d68886bae76a4b9b3484d23e5b7df086f940fa38 ]
    
    The data type of loca_last_write_offset is newoffset4 and is switched
    on a boolean value, no_newoffset, that indicates if a previous write
    occurred or not. If no_newoffset is FALSE, an offset is not given.
    This means that client does not try to update the file size. Thus,
    server should not try to calculate new file size and check if it fits
    into the segment range. See RFC 8881, section 12.5.4.2.
    
    Sometimes the current incorrect logic may cause clients to hang when
    trying to sync an inode. If layoutcommit fails, the client marks the
    inode as dirty again.
    
    Fixes: 9cf514ccfacb ("nfsd: implement pNFS operations")
    Cc: stable@vger.kernel.org
    Co-developed-by: Konstantin Evtushenko <koevtushenko@yandex.com>
    Signed-off-by: Konstantin Evtushenko <koevtushenko@yandex.com>
    Signed-off-by: Sergey Bashirov <sergeybashirov@gmail.com>
    Reviewed-by: Christoph Hellwig <hch@lst.de>
    Reviewed-by: Jeff Layton <jlayton@kernel.org>
    Signed-off-by: Chuck Lever <chuck.lever@oracle.com>
    [ removed rqstp parameter from proc_layoutcommit ]
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

NFSD: Minor cleanup in layoutcommit processing [+ + +]
Author: Sergey Bashirov <sergeybashirov@gmail.com>
Date:   Mon Oct 20 08:54:06 2025 -0400

    NFSD: Minor cleanup in layoutcommit processing
    
    [ Upstream commit 274365a51d88658fb51cca637ba579034e90a799 ]
    
    Remove dprintk in nfsd4_layoutcommit. These are not needed
    in day to day usage, and the information is also available
    in Wireshark when capturing NFS traffic.
    
    Reviewed-by: Christoph Hellwig <hch@lst.de>
    Signed-off-by: Sergey Bashirov <sergeybashirov@gmail.com>
    Signed-off-by: Chuck Lever <chuck.lever@oracle.com>
    Stable-dep-of: d68886bae76a ("NFSD: Fix last write offset handling in layoutcommit")
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

NFSD: Rework encoding and decoding of nfsd4_deviceid [+ + +]
Author: Sergey Bashirov <sergeybashirov@gmail.com>
Date:   Mon Oct 20 08:54:05 2025 -0400

    NFSD: Rework encoding and decoding of nfsd4_deviceid
    
    [ Upstream commit 832738e4b325b742940761e10487403f9aad13e8 ]
    
    Compilers may optimize the layout of C structures, so we should not rely
    on sizeof struct and memcpy to encode and decode XDR structures. The byte
    order of the fields should also be taken into account.
    
    This patch adds the correct functions to handle the deviceid4 structure
    and removes the pad field, which is currently not used by NFSD, from the
    runtime state. The server's byte order is preserved because the deviceid4
    blob on the wire is only used as a cookie by the client.
    
    Signed-off-by: Sergey Bashirov <sergeybashirov@gmail.com>
    Signed-off-by: Chuck Lever <chuck.lever@oracle.com>
    Stable-dep-of: d68886bae76a ("NFSD: Fix last write offset handling in layoutcommit")
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
nilfs2: fix deadlock warnings caused by lock dependency in init_nilfs() [+ + +]
Author: Ryusuke Konishi <konishi.ryusuke@gmail.com>
Date:   Sat May 3 14:33:14 2025 +0900

    nilfs2: fix deadlock warnings caused by lock dependency in init_nilfs()
    
    commit fb881cd7604536b17a1927fb0533f9a6982ffcc5 upstream.
    
    After commit c0e473a0d226 ("block: fix race between set_blocksize and read
    paths") was merged, set_blocksize() called by sb_set_blocksize() now locks
    the inode of the backing device file.  As a result of this change, syzbot
    started reporting deadlock warnings due to a circular dependency involving
    the semaphore "ns_sem" of the nilfs object, the inode lock of the backing
    device file, and the locks that this inode lock is transitively dependent
    on.
    
    This is caused by a new lock dependency added by the above change, since
    init_nilfs() calls sb_set_blocksize() in the lock section of "ns_sem".
    However, these warnings are false positives because init_nilfs() is called
    in the early stage of the mount operation and the filesystem has not yet
    started.
    
    The reason why "ns_sem" is locked in init_nilfs() was to avoid a race
    condition in nilfs_fill_super() caused by sharing a nilfs object among
    multiple filesystem instances (super block structures) in the early
    implementation.  However, nilfs objects and super block structures have
    long ago become one-to-one, and there is no longer any need to use the
    semaphore there.
    
    So, fix this issue by removing the use of the semaphore "ns_sem" in
    init_nilfs().
    
    Link: https://lkml.kernel.org/r/20250503053327.12294-1-konishi.ryusuke@gmail.com
    Fixes: c0e473a0d226 ("block: fix race between set_blocksize and read paths")
    Signed-off-by: Ryusuke Konishi <konishi.ryusuke@gmail.com>
    Reported-by: syzbot+00f7f5b884b117ee6773@syzkaller.appspotmail.com
    Closes: https://syzkaller.appspot.com/bug?extid=00f7f5b884b117ee6773
    Tested-by: syzbot+00f7f5b884b117ee6773@syzkaller.appspotmail.com
    Reported-by: syzbot+f30591e72bfc24d4715b@syzkaller.appspotmail.com
    Closes: https://syzkaller.appspot.com/bug?extid=f30591e72bfc24d4715b
    Tested-by: syzbot+f30591e72bfc24d4715b@syzkaller.appspotmail.com>
    Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
    Signed-off-by: Mahmoud Adam <mngyadam@amazon.de>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
nvme-multipath: Skip nr_active increments in RETRY disposition [+ + +]
Author: Amit Chaudhary <achaudhary@purestorage.com>
Date:   Fri Sep 26 12:08:22 2025 -0700

    nvme-multipath: Skip nr_active increments in RETRY disposition
    
    [ Upstream commit bb642e2d300ee27dcede65cda7ffc47a7047bd69 ]
    
    For queue-depth I/O policy, this patch fixes unbalanced I/Os across
    nvme multipaths.
    
    Issue Description:
    
    The RETRY disposition incorrectly increments ns->ctrl->nr_active
    counter and reinitializes iostat start-time. In such cases nr_active
    counter never goes back to zero until that path disconnects and
    reconnects.
    
    Such a path is not chosen for new I/Os if multiple RETRY cases on a given
    a path cause its queue-depth counter to be artificially higher compared
    to other paths. This leads to unbalanced I/Os across paths.
    
    The patch skips incrementing nr_active if NVME_MPATH_CNT_ACTIVE is already
    set. And it skips restarting io stats if NVME_MPATH_IO_STATS is already set.
    
    base-commit: e989a3da2d371a4b6597ee8dee5c72e407b4db7a
    Fixes: d4d957b53d91eeb ("nvme-multipath: support io stats on the mpath device")
    Signed-off-by: Amit Chaudhary <achaudhary@purestorage.com>
    Reviewed-by: Randy Jennings <randyj@purestorage.com>
    Signed-off-by: Keith Busch <kbusch@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
padata: Reset next CPU when reorder sequence wraps around [+ + +]
Author: Xiao Liang <shaw.leon@gmail.com>
Date:   Mon Oct 20 11:37:54 2025 -0400

    padata: Reset next CPU when reorder sequence wraps around
    
    [ Upstream commit 501302d5cee0d8e8ec2c4a5919c37e0df9abc99b ]
    
    When seq_nr wraps around, the next reorder job with seq 0 is hashed to
    the first CPU in padata_do_serial(). Correspondingly, need reset pd->cpu
    to the first one when pd->processed wraps around. Otherwise, if the
    number of used CPUs is not a power of 2, padata_find_next() will be
    checking a wrong list, hence deadlock.
    
    Fixes: 6fc4dbcf0276 ("padata: Replace delayed timer with immediate workqueue in padata_reorder")
    Cc: <stable@vger.kernel.org>
    Signed-off-by: Xiao Liang <shaw.leon@gmail.com>
    Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
    [ relocated fix from padata_reorder() function to padata_find_next() ]
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
PCI/sysfs: Ensure devices are powered for config reads (part 2) [+ + +]
Author: Brian Norris <briannorris@google.com>
Date:   Mon Oct 20 13:41:36 2025 -0700

    PCI/sysfs: Ensure devices are powered for config reads (part 2)
    
    Commit 48991e493507 ("PCI/sysfs: Ensure devices are powered for config
    reads") was applied to various linux-stable trees. However, prior to
    6.12.y, we do not have commit d2bd39c0456b ("PCI: Store all PCIe
    Supported Link Speeds"). Therefore, we also need to apply the change to
    max_link_speed_show().
    
    This was pointed out here:
    
      Re: Patch "PCI/sysfs: Ensure devices are powered for config reads" has been added to the 6.6-stable tree
      https://lore.kernel.org/all/aPEMIreBYZ7yk3cm@google.com/
    
    Original change description follows:
    
        The "max_link_width", "current_link_speed", "current_link_width",
        "secondary_bus_number", and "subordinate_bus_number" sysfs files all access
        config registers, but they don't check the runtime PM state. If the device
        is in D3cold or a parent bridge is suspended, we may see -EINVAL, bogus
        values, or worse, depending on implementation details.
    
        Wrap these access in pci_config_pm_runtime_{get,put}() like most of the
        rest of the similar sysfs attributes.
    
        Notably, "max_link_speed" does not access config registers; it returns a
        cached value since d2bd39c0456b ("PCI: Store all PCIe Supported Link
        Speeds").
    
    Fixes: 56c1af4606f0 ("PCI: Add sysfs max_link_speed/width, current_link_speed/width, etc")
    Link: https://lore.kernel.org/all/aPEMIreBYZ7yk3cm@google.com/
    Signed-off-by: Brian Norris <briannorris@google.com>
    Signed-off-by: Brian Norris <briannorris@chromium.org>
    Cc: stable@vger.kernel.org
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
PCI: Add PCI_VDEVICE_SUB helper macro [+ + +]
Author: Piotr Kwapulinski <piotr.kwapulinski@intel.com>
Date:   Mon Oct 20 14:10:25 2025 -0400

    PCI: Add PCI_VDEVICE_SUB helper macro
    
    [ Upstream commit 208fff3f567e2a3c3e7e4788845e90245c3891b4 ]
    
    PCI_VDEVICE_SUB generates the pci_device_id struct layout for
    the specific PCI device/subdevice. Private data may follow the
    output.
    
    Reviewed-by: Przemek Kitszel <przemyslaw.kitszel@intel.com>
    Signed-off-by: Piotr Kwapulinski <piotr.kwapulinski@intel.com>
    Acked-by: Bjorn Helgaas <bhelgaas@google.com>
    Tested-by: Rafal Romanowski <rafal.romanowski@intel.com>
    Signed-off-by: Tony Nguyen <anthony.l.nguyen@intel.com>
    Stable-dep-of: a7075f501bd3 ("ixgbevf: fix mailbox API compatibility by negotiating supported features")
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

PCI: j721e: Enable ACSPCIE Refclk if "ti,syscon-acspcie-proxy-ctrl" exists [+ + +]
Author: Siddharth Vadapalli <s-vadapalli@ti.com>
Date:   Tue Oct 21 14:37:21 2025 -0400

    PCI: j721e: Enable ACSPCIE Refclk if "ti,syscon-acspcie-proxy-ctrl" exists
    
    [ Upstream commit 82c4be4168e26a5593aaa1002b5678128a638824 ]
    
    The ACSPCIE module is capable of driving the reference clock required by
    the PCIe Endpoint device. It is an alternative to on-board and external
    reference clock generators. Enabling the output from the ACSPCIE module's
    PAD IO Buffers requires clearing the "PAD IO disable" bits of the
    ACSPCIE_PROXY_CTRL register in the CTRL_MMR register space.
    
    Add support to enable the ACSPCIE reference clock output using the optional
    device-tree property "ti,syscon-acspcie-proxy-ctrl".
    
    Link: https://lore.kernel.org/linux-pci/20240829105316.1483684-3-s-vadapalli@ti.com
    Signed-off-by: Siddharth Vadapalli <s-vadapalli@ti.com>
    Signed-off-by: Krzysztof Wilczyński <kwilczynski@kernel.org>
    Reviewed-by: Manivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
    Stable-dep-of: f842d3313ba1 ("PCI: j721e: Fix programming sequence of "strap" settings")
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

PCI: j721e: Fix programming sequence of "strap" settings [+ + +]
Author: Siddharth Vadapalli <s-vadapalli@ti.com>
Date:   Tue Oct 21 14:37:22 2025 -0400

    PCI: j721e: Fix programming sequence of "strap" settings
    
    [ Upstream commit f842d3313ba179d4005096357289c7ad09cec575 ]
    
    The Cadence PCIe Controller integrated in the TI K3 SoCs supports both
    Root-Complex and Endpoint modes of operation. The Glue Layer allows
    "strapping" the Mode of operation of the Controller, the Link Speed
    and the Link Width. This is enabled by programming the "PCIEn_CTRL"
    register (n corresponds to the PCIe instance) within the CTRL_MMR
    memory-mapped register space. The "reset-values" of the registers are
    also different depending on the mode of operation.
    
    Since the PCIe Controller latches onto the "reset-values" immediately
    after being powered on, if the Glue Layer configuration is not done while
    the PCIe Controller is off, it will result in the PCIe Controller latching
    onto the wrong "reset-values". In practice, this will show up as a wrong
    representation of the PCIe Controller's capability structures in the PCIe
    Configuration Space. Some such capabilities which are supported by the PCIe
    Controller in the Root-Complex mode but are incorrectly latched onto as
    being unsupported are:
    - Link Bandwidth Notification
    - Alternate Routing ID (ARI) Forwarding Support
    - Next capability offset within Advanced Error Reporting (AER) capability
    
    Fix this by powering off the PCIe Controller before programming the "strap"
    settings and powering it on after that. The runtime PM APIs namely
    pm_runtime_put_sync() and pm_runtime_get_sync() will decrement and
    increment the usage counter respectively, causing GENPD to power off and
    power on the PCIe Controller.
    
    Fixes: f3e25911a430 ("PCI: j721e: Add TI J721E PCIe driver")
    Signed-off-by: Siddharth Vadapalli <s-vadapalli@ti.com>
    Signed-off-by: Manivannan Sadhasivam <mani@kernel.org>
    Cc: stable@vger.kernel.org
    Link: https://patch.msgid.link/20250908120828.1471776-1-s-vadapalli@ti.com
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

PCI: tegra194: Reset BARs when running in PCIe endpoint mode [+ + +]
Author: Niklas Cassel <cassel@kernel.org>
Date:   Tue Oct 21 14:25:01 2025 -0400

    PCI: tegra194: Reset BARs when running in PCIe endpoint mode
    
    [ Upstream commit 42f9c66a6d0cc45758dab77233c5460e1cf003df ]
    
    Tegra already defines all BARs except BAR0 as BAR_RESERVED.  This is
    sufficient for pci-epf-test to not allocate backing memory and to not call
    set_bar() for those BARs. However, marking a BAR as BAR_RESERVED does not
    mean that the BAR gets disabled.
    
    The host side driver, pci_endpoint_test, simply does an ioremap for all
    enabled BARs and will run tests against all enabled BARs, so it will run
    tests against the BARs marked as BAR_RESERVED.
    
    After running the BAR tests (which will write to all enabled BARs), the
    inbound address translation is broken. This is because the tegra controller
    exposes the ATU Port Logic Structure in BAR4, so when BAR4 is written, the
    inbound address translation settings get overwritten.
    
    To avoid this, implement the dw_pcie_ep_ops .init() callback and start off
    by disabling all BARs (pci-epf-test will later enable/configure BARs that
    are not defined as BAR_RESERVED).
    
    This matches the behavior of other PCIe endpoint drivers: dra7xx, imx6,
    layerscape-ep, artpec6, dw-rockchip, qcom-ep, rcar-gen4, and uniphier-ep.
    
    With this, the PCI endpoint kselftest test case CONSECUTIVE_BAR_TEST (which
    was specifically made to detect address translation issues) passes.
    
    Fixes: c57247f940e8 ("PCI: tegra: Add support for PCIe endpoint mode in Tegra194")
    Signed-off-by: Niklas Cassel <cassel@kernel.org>
    Signed-off-by: Manivannan Sadhasivam <mani@kernel.org>
    Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
    Cc: stable@vger.kernel.org
    Link: https://patch.msgid.link/20250922140822.519796-7-cassel@kernel.org
    [ changed .init field to .ep_init in pcie_ep_ops struct ]
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
phy: cadence: cdns-dphy: Fix PLL lock and O_CMN_READY polling [+ + +]
Author: Devarsh Thakkar <devarsht@ti.com>
Date:   Mon Oct 20 08:59:35 2025 -0400

    phy: cadence: cdns-dphy: Fix PLL lock and O_CMN_READY polling
    
    [ Upstream commit 284fb19a3ffb1083c3ad9c00d29749d09dddb99c ]
    
    PLL lockup and O_CMN_READY assertion can only happen after common state
    machine gets enabled by programming DPHY_CMN_SSM register, but driver was
    polling them before the common state machine was enabled which is
    incorrect.  This is as per the DPHY initialization sequence as mentioned in
    J721E TRM [1] at section "12.7.2.4.1.2.1 Start-up Sequence Timing Diagram".
    It shows O_CMN_READY polling at the end after common configuration pin
    setup where the common configuration pin setup step enables state machine
    as referenced in "Table 12-1533. Common Configuration-Related Setup
    mentions state machine"
    
    To fix this :
    - Add new function callbacks for polling on PLL lock and O_CMN_READY
      assertion.
    - As state machine and clocks get enabled in power_on callback only, move
      the clock related programming part from configure callback to power_on
    callback and poll for the PLL lockup and O_CMN_READY assertion after state
    machine gets enabled.
    - The configure callback only saves the PLL configuration received from the
      client driver which will be applied later on in power_on callback.
    - Add checks to ensure configure is called before power_on and state
      machine is in disabled state before power_on callback is called.
    - Disable state machine in power_off so that client driver can re-configure
      the PLL by following up a power_off, configure, power_on sequence.
    
    [1]: https://www.ti.com/lit/zip/spruil1
    
    Cc: stable@vger.kernel.org
    Fixes: 7a343c8bf4b5 ("phy: Add Cadence D-PHY support")
    Signed-off-by: Devarsh Thakkar <devarsht@ti.com>
    Tested-by: Harikrishna Shenoy <h-shenoy@ti.com>
    Reviewed-by: Tomi Valkeinen <tomi.valkeinen@ideasonboard.com>
    Link: https://lore.kernel.org/r/20250704125915.1224738-2-devarsht@ti.com
    Signed-off-by: Vinod Koul <vkoul@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

phy: cadence: cdns-dphy: Update calibration wait time for startup state machine [+ + +]
Author: Devarsh Thakkar <devarsht@ti.com>
Date:   Tue Oct 21 12:50:53 2025 -0400

    phy: cadence: cdns-dphy: Update calibration wait time for startup state machine
    
    [ Upstream commit 2c27aaee934a1b5229152fe33a14f1fdf50da143 ]
    
    Do read-modify-write so that we re-use the characterized reset value as
    specified in TRM [1] to program calibration wait time which defines number
    of cycles to wait for after startup state machine is in bandgap enable
    state.
    
    This fixes PLL lock timeout error faced while using RPi DSI Panel on TI's
    AM62L and J721E SoC since earlier calibration wait time was getting
    overwritten to zero value thus failing the PLL to lockup and causing
    timeout.
    
    [1] AM62P TRM (Section 14.8.6.3.2.1.1 DPHY_TX_DPHYTX_CMN0_CMN_DIG_TBIT2):
    Link: https://www.ti.com/lit/pdf/spruj83
    
    Cc: stable@vger.kernel.org
    Fixes: 7a343c8bf4b5 ("phy: Add Cadence D-PHY support")
    Signed-off-by: Devarsh Thakkar <devarsht@ti.com>
    Tested-by: Harikrishna Shenoy <h-shenoy@ti.com>
    Reviewed-by: Tomi Valkeinen <tomi.valkeinen@ideasonboard.com>
    Link: https://lore.kernel.org/r/20250704125915.1224738-3-devarsht@ti.com
    Signed-off-by: Vinod Koul <vkoul@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

phy: cdns-dphy: Store hs_clk_rate and return it [+ + +]
Author: Tomi Valkeinen <tomi.valkeinen@ideasonboard.com>
Date:   Mon Oct 20 08:59:34 2025 -0400

    phy: cdns-dphy: Store hs_clk_rate and return it
    
    [ Upstream commit 689a54acb56858c85de8c7285db82b8ae6dbf683 ]
    
    The DPHY driver does not return the actual hs_clk_rate, so the DSI
    driver has no idea what clock was actually achieved. Set the realized
    hs_clk_rate to the opts struct, so that the DSI driver gets it back.
    
    Reviewed-by: Aradhya Bhatia <aradhya.bhatia@linux.dev>
    Tested-by: Parth Pancholi <parth.pancholi@toradex.com>
    Tested-by: Jayesh Choudhary <j-choudhary@ti.com>
    Acked-by: Vinod Koul <vkoul@kernel.org>
    Reviewed-by: Devarsh Thakkar <devarsht@ti.com>
    Signed-off-by: Tomi Valkeinen <tomi.valkeinen@ideasonboard.com>
    Link: https://lore.kernel.org/r/20250723-cdns-dphy-hs-clk-rate-fix-v1-1-d4539d44cbe7@ideasonboard.com
    Signed-off-by: Vinod Koul <vkoul@kernel.org>
    Stable-dep-of: 284fb19a3ffb ("phy: cadence: cdns-dphy: Fix PLL lock and O_CMN_READY polling")
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
PM: runtime: Add new devm functions [+ + +]
Author: Bence Csókás <bence98@sch.bme.hu>
Date:   Mon Oct 20 09:03:02 2025 -0400

    PM: runtime: Add new devm functions
    
    [ Upstream commit 73db799bf5efc5a04654bb3ff6c9bf63a0dfa473 ]
    
    Add `devm_pm_runtime_set_active_enabled()` and
    `devm_pm_runtime_get_noresume()` for simplifying
    common cases in drivers.
    
    Signed-off-by: Bence Csókás <csokas.bence@prolan.hu>
    Link: https://patch.msgid.link/20250327195928.680771-3-csokas.bence@prolan.hu
    Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
    Stable-dep-of: 0792c1984a45 ("iio: imu: inv_icm42600: Simplify pm_runtime setup")
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
quota: remove unneeded return value of register_quota_format [+ + +]
Author: Kemeng Shi <shikemeng@huaweicloud.com>
Date:   Mon Oct 20 12:16:04 2025 -0400

    quota: remove unneeded return value of register_quota_format
    
    [ Upstream commit a838e5dca63d1dc701e63b2b1176943c57485c45 ]
    
    The register_quota_format always returns 0, simply remove unneeded return
    value.
    
    Link: https://patch.msgid.link/20240715130534.2112678-3-shikemeng@huaweicloud.com
    Signed-off-by: Kemeng Shi <shikemeng@huaweicloud.com>
    Reviewed-by: Joseph Qi <joseph.qi@linux.alibaba.com>
    Signed-off-by: Jan Kara <jack@suse.cz>
    Stable-dep-of: 72b7ceca857f ("fs: quota: create dedicated workqueue for quota_release_work")
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
r8152: add error handling in rtl8152_driver_init [+ + +]
Author: Yi Cong <yicong@kylinos.cn>
Date:   Sat Oct 11 16:24:15 2025 +0800

    r8152: add error handling in rtl8152_driver_init
    
    commit 75527d61d60d493d1eb064f335071a20ca581f54 upstream.
    
    rtl8152_driver_init() is missing the error handling.
    When rtl8152_driver registration fails, rtl8152_cfgselector_driver
    should be deregistered.
    
    Fixes: ec51fbd1b8a2 ("r8152: add USB device driver for config selection")
    Cc: stable@vger.kernel.org
    Signed-off-by: Yi Cong <yicong@kylinos.cn>
    Reviewed-by: Simon Horman <horms@kernel.org>
    Link: https://patch.msgid.link/20251011082415.580740-1-yicongsrfy@163.com
    [pabeni@redhat.com: clarified the commit message]
    Signed-off-by: Paolo Abeni <pabeni@redhat.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
r8169: fix packet truncation after S4 resume on RTL8168H/RTL8111H [+ + +]
Author: Linmao Li <lilinmao@kylinos.cn>
Date:   Thu Oct 9 20:25:49 2025 +0800

    r8169: fix packet truncation after S4 resume on RTL8168H/RTL8111H
    
    [ Upstream commit 70f92ab97042f243e1c8da1c457ff56b9b3e49f1 ]
    
    After resume from S4 (hibernate), RTL8168H/RTL8111H truncates incoming
    packets. Packet captures show messages like "IP truncated-ip - 146 bytes
    missing!".
    
    The issue is caused by RxConfig not being properly re-initialized after
    resume. Re-initializing the RxConfig register before the chip
    re-initialization sequence avoids the truncation and restores correct
    packet reception.
    
    This follows the same pattern as commit ef9da46ddef0 ("r8169: fix data
    corruption issue on RTL8402").
    
    Fixes: 6e1d0b898818 ("r8169:add support for RTL8168H and RTL8107E")
    Signed-off-by: Linmao Li <lilinmao@kylinos.cn>
    Reviewed-by: Jacob Keller <jacob.e.keller@intel.com>
    Reviewed-by: Heiner Kallweit <hkallweit1@gmail.com>
    Link: https://patch.msgid.link/20251009122549.3955845-1-lilinmao@kylinos.cn
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
riscv: kprobes: Fix probe address validation [+ + +]
Author: Fabian Vogt <fvogt@suse.de>
Date:   Wed Sep 10 17:25:13 2025 +0200

    riscv: kprobes: Fix probe address validation
    
    [ Upstream commit 9e68bd803fac49274fde914466fd3b07c4d602c8 ]
    
    When adding a kprobe such as "p:probe/tcp_sendmsg _text+15392192",
    arch_check_kprobe would start iterating all instructions starting from
    _text until the probed address. Not only is this very inefficient, but
    literal values in there (e.g. left by function patching) are
    misinterpreted in a way that causes a desync.
    
    Fix this by doing it like x86: start the iteration at the closest
    preceding symbol instead of the given starting point.
    
    Fixes: 87f48c7ccc73 ("riscv: kprobe: Fixup kernel panic when probing an illegal position")
    Signed-off-by: Fabian Vogt <fvogt@suse.de>
    Signed-off-by: Marvin Friedrich <marvin.friedrich@suse.com>
    Acked-by: Guo Ren <guoren@kernel.org>
    Link: https://lore.kernel.org/r/6191817.lOV4Wx5bFT@fvogt-thinkpad
    Signed-off-by: Paul Walmsley <pjw@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
sched/balancing: Rename newidle_balance() => sched_balance_newidle() [+ + +]
Author: Ingo Molnar <mingo@kernel.org>
Date:   Fri Mar 8 12:18:16 2024 +0100

    sched/balancing: Rename newidle_balance() => sched_balance_newidle()
    
    [ Upstream commit 7d058285cd77cc1411c91efd1b1673530bb1bee8 ]
    
    Standardize scheduler load-balancing function names on the
    sched_balance_() prefix.
    
    Signed-off-by: Ingo Molnar <mingo@kernel.org>
    Reviewed-by: Shrikanth Hegde <sshegde@linux.ibm.com>
    Link: https://lore.kernel.org/r/20240308111819.1101550-11-mingo@kernel.org
    Stable-dep-of: 17e3e88ed0b6 ("sched/fair: Fix pelt lost idle time detection")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
sched/fair: Fix pelt lost idle time detection [+ + +]
Author: Vincent Guittot <vincent.guittot@linaro.org>
Date:   Wed Oct 8 15:12:14 2025 +0200

    sched/fair: Fix pelt lost idle time detection
    
    [ Upstream commit 17e3e88ed0b6318fde0d1c14df1a804711cab1b5 ]
    
    The check for some lost idle pelt time should be always done when
    pick_next_task_fair() fails to pick a task and not only when we call it
    from the fair fast-path.
    
    The case happens when the last running task on rq is a RT or DL task. When
    the latter goes to sleep and the /Sum of util_sum of the rq is at the max
    value, we don't account the lost of idle time whereas we should.
    
    Fixes: 67692435c411 ("sched: Rework pick_next_task() slow-path")
    Signed-off-by: Vincent Guittot <vincent.guittot@linaro.org>
    Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
selftests/bpf: make arg_parsing.c more robust to crashes [+ + +]
Author: Andrii Nakryiko <andrii@kernel.org>
Date:   Tue Oct 14 13:20:37 2025 -0700

    selftests/bpf: make arg_parsing.c more robust to crashes
    
    [ Upstream commit e603a342cf7ecd64ef8f36207dfe1caacb9e2583 ]
    
    We started getting a crash in BPF CI, which seems to originate from
    test_parse_test_list_file() test and is happening at this line:
    
      ASSERT_OK(strcmp("test_with_spaces", set.tests[0].name), "test 0 name");
    
    One way we can crash there is if set.cnt zero, which is checked for with
    ASSERT_EQ() above, but we proceed after this regardless of the outcome.
    Instead of crashing, we should bail out with test failure early.
    
    Similarly, if parse_test_list_file() fails, we shouldn't be even looking
    at set, so bail even earlier if ASSERT_OK() fails.
    
    Fixes: 64276f01dce8 ("selftests/bpf: Test_progs can read test lists from file")
    Signed-off-by: Andrii Nakryiko <andrii@kernel.org>
    Tested-by: Ihor Solodrai <ihor.solodrai@linux.dev>
    Link: https://lore.kernel.org/r/20251014202037.72922-1-andrii@kernel.org
    Signed-off-by: Alexei Starovoitov <ast@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
selftests: arg_parsing: Ensure data is flushed to disk before reading. [+ + +]
Author: Xing Guo <higuoxing@gmail.com>
Date:   Thu Oct 16 11:53:30 2025 +0800

    selftests: arg_parsing: Ensure data is flushed to disk before reading.
    
    [ Upstream commit 0c1999ed33722f85476a248186d6e0eb2bf3dd2a ]
    
    test_parse_test_list_file writes some data to
    /tmp/bpf_arg_parsing_test.XXXXXX and parse_test_list_file() will read
    the data back.  However, after writing data to that file, we forget to
    call fsync() and it's causing testing failure in my laptop.  This patch
    helps fix it by adding the missing fsync() call.
    
    Fixes: 64276f01dce8 ("selftests/bpf: Test_progs can read test lists from file")
    Signed-off-by: Xing Guo <higuoxing@gmail.com>
    Signed-off-by: Andrii Nakryiko <andrii@kernel.org>
    Link: https://lore.kernel.org/bpf/20251016035330.3217145-1-higuoxing@gmail.com
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
smb: client: Fix refcount leak for cifs_sb_tlink [+ + +]
Author: Shuhao Fu <sfual@cse.ust.hk>
Date:   Thu Oct 16 02:52:55 2025 +0000

    smb: client: Fix refcount leak for cifs_sb_tlink
    
    commit c2b77f42205ef485a647f62082c442c1cd69d3fc upstream.
    
    Fix three refcount inconsistency issues related to `cifs_sb_tlink`.
    
    Comments for `cifs_sb_tlink` state that `cifs_put_tlink()` needs to be
    called after successful calls to `cifs_sb_tlink()`. Three calls fail to
    update refcount accordingly, leading to possible resource leaks.
    
    Fixes: 8ceb98437946 ("CIFS: Move rename to ops struct")
    Fixes: 2f1afe25997f ("cifs: Use smb 2 - 3 and cifsacl mount options getacl functions")
    Fixes: 366ed846df60 ("cifs: Use smb 2 - 3 and cifsacl mount options setacl function")
    Cc: stable@vger.kernel.org
    Signed-off-by: Shuhao Fu <sfual@cse.ust.hk>
    Signed-off-by: Steve French <stfrench@microsoft.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
 
tcp: fix tcp_tso_should_defer() vs large RTT [+ + +]
Author: Eric Dumazet <edumazet@google.com>
Date:   Sat Oct 11 11:57:42 2025 +0000

    tcp: fix tcp_tso_should_defer() vs large RTT
    
    [ Upstream commit 295ce1eb36ae47dc862d6c8a1012618a25516208 ]
    
    Neal reported that using neper tcp_stream with TCP_TX_DELAY
    set to 50ms would often lead to flows stuck in a small cwnd mode,
    regardless of the congestion control.
    
    While tcp_stream sets TCP_TX_DELAY too late after the connect(),
    it highlighted two kernel bugs.
    
    The following heuristic in tcp_tso_should_defer() seems wrong
    for large RTT:
    
    delta = tp->tcp_clock_cache - head->tstamp;
    /* If next ACK is likely to come too late (half srtt), do not defer */
    if ((s64)(delta - (u64)NSEC_PER_USEC * (tp->srtt_us >> 4)) < 0)
          goto send_now;
    
    If next ACK is expected to come in more than 1 ms, we should
    not defer because we prefer a smooth ACK clocking.
    
    While blamed commit was a step in the good direction, it was not
    generic enough.
    
    Another patch fixing TCP_TX_DELAY for established flows
    will be proposed when net-next reopens.
    
    Fixes: 50c8339e9299 ("tcp: tso: restore IW10 after TSO autosizing")
    Reported-by: Neal Cardwell <ncardwell@google.com>
    Signed-off-by: Eric Dumazet <edumazet@google.com>
    Reviewed-by: Neal Cardwell <ncardwell@google.com>
    Tested-by: Neal Cardwell <ncardwell@google.com>
    Link: https://patch.msgid.link/20251011115742.1245771-1-edumazet@google.com
    [pabeni@redhat.com: fixed whitespace issue]
    Signed-off-by: Paolo Abeni <pabeni@redhat.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
tg3: prevent use of uninitialized remote_adv and local_adv variables [+ + +]
Author: Alexey Simakov <bigalex934@gmail.com>
Date:   Tue Oct 14 19:47:38 2025 +0300

    tg3: prevent use of uninitialized remote_adv and local_adv variables
    
    [ Upstream commit 0c3f2e62815a43628e748b1e4ad97a1c46cce703 ]
    
    Some execution paths that jump to the fiber_setup_done label
    could leave the remote_adv and local_adv variables uninitialized
    and then use it.
    
    Initialize this variables at the point of definition to avoid this.
    
    Fixes: 85730a631f0c ("tg3: Add SGMII phy support for 5719/5718 serdes")
    Co-developed-by: Alexandr Sapozhnikov <alsp705@gmail.com>
    Signed-off-by: Alexandr Sapozhnikov <alsp705@gmail.com>
    Signed-off-by: Alexey Simakov <bigalex934@gmail.com>
    Reviewed-by: Pavan Chebbi <pavan.chebbi@broadcom.com>
    Link: https://patch.msgid.link/20251014164736.5890-1-bigalex934@gmail.com
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
tls: always set record_type in tls_process_cmsg [+ + +]
Author: Sabrina Dubroca <sd@queasysnail.net>
Date:   Tue Oct 14 11:16:58 2025 +0200

    tls: always set record_type in tls_process_cmsg
    
    [ Upstream commit b6fe4c29bb51cf239ecf48eacf72b924565cb619 ]
    
    When userspace wants to send a non-DATA record (via the
    TLS_SET_RECORD_TYPE cmsg), we need to send any pending data from a
    previous MSG_MORE send() as a separate DATA record. If that DATA record
    is encrypted asynchronously, tls_handle_open_record will return
    -EINPROGRESS. This is currently treated as an error by
    tls_process_cmsg, and it will skip setting record_type to the correct
    value, but the caller (tls_sw_sendmsg_locked) handles that return
    value correctly and proceeds with sending the new message with an
    incorrect record_type (DATA instead of whatever was requested in the
    cmsg).
    
    Always set record_type before handling the open record. If
    tls_handle_open_record returns an error, record_type will be
    ignored. If it succeeds, whether with synchronous crypto (returning 0)
    or asynchronous (returning -EINPROGRESS), the caller will proceed
    correctly.
    
    Fixes: a42055e8d2c3 ("net/tls: Add support for async encryption of records for performance")
    Reported-by: Jann Horn <jannh@google.com>
    Signed-off-by: Sabrina Dubroca <sd@queasysnail.net>
    Link: https://patch.msgid.link/0457252e578a10a94e40c72ba6288b3a64f31662.1760432043.git.sd@queasysnail.net
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

tls: don't rely on tx_work during send() [+ + +]
Author: Sabrina Dubroca <sd@queasysnail.net>
Date:   Tue Oct 14 11:17:00 2025 +0200

    tls: don't rely on tx_work during send()
    
    [ Upstream commit 7f846c65ca11e63d2409868ff039081f80e42ae4 ]
    
    With async crypto, we rely on tx_work to actually transmit records
    once encryption completes. But while send() is running, both the
    tx_lock and socket lock are held, so tx_work_handler cannot process
    the queue of encrypted records, and simply reschedules itself. During
    a large send(), this could last a long time, and use a lot of memory.
    
    Transmit any pending encrypted records before restarting the main
    loop of tls_sw_sendmsg_locked.
    
    Fixes: a42055e8d2c3 ("net/tls: Add support for async encryption of records for performance")
    Reported-by: Jann Horn <jannh@google.com>
    Signed-off-by: Sabrina Dubroca <sd@queasysnail.net>
    Link: https://patch.msgid.link/8396631478f70454b44afb98352237d33f48d34d.1760432043.git.sd@queasysnail.net
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

tls: trim encrypted message to match the plaintext on short splice [+ + +]
Author: Sabrina Dubroca <sd@queasysnail.net>
Date:   Tue Oct 14 11:16:56 2025 +0200

    tls: trim encrypted message to match the plaintext on short splice
    
    [ Upstream commit ce5af41e3234425a40974696682163edfd21128c ]
    
    During tls_sw_sendmsg_locked, we pre-allocate the encrypted message
    for the size we're expecting to send during the current iteration, but
    we may end up sending less, for example when splicing: if we're
    getting the data from small fragments of memory, we may fill up all
    the slots in the skmsg with less data than expected.
    
    In this case, we need to trim the encrypted message to only the length
    we actually need, to avoid pushing uninitialized bytes down the
    underlying TCP socket.
    
    Fixes: fe1e81d4f73b ("tls/sw: Support MSG_SPLICE_PAGES")
    Reported-by: Jann Horn <jannh@google.com>
    Signed-off-by: Sabrina Dubroca <sd@queasysnail.net>
    Link: https://patch.msgid.link/66a0ae99c9efc15f88e9e56c1f58f902f442ce86.1760432043.git.sd@queasysnail.net
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

tls: wait for async encrypt in case of error during latter iterations of sendmsg [+ + +]
Author: Sabrina Dubroca <sd@queasysnail.net>
Date:   Tue Oct 14 11:16:57 2025 +0200

    tls: wait for async encrypt in case of error during latter iterations of sendmsg
    
    [ Upstream commit b014a4e066c555185b7c367efacdc33f16695495 ]
    
    If we hit an error during the main loop of tls_sw_sendmsg_locked (eg
    failed allocation), we jump to send_end and immediately
    return. Previous iterations may have queued async encryption requests
    that are still pending. We should wait for those before returning, as
    we could otherwise be reading from memory that userspace believes
    we're not using anymore, which would be a sort of use-after-free.
    
    This is similar to what tls_sw_recvmsg already does: failures during
    the main loop jump to the "wait for async" code, not straight to the
    unlock/return.
    
    Fixes: a42055e8d2c3 ("net/tls: Add support for async encryption of records for performance")
    Reported-by: Jann Horn <jannh@google.com>
    Signed-off-by: Sabrina Dubroca <sd@queasysnail.net>
    Link: https://patch.msgid.link/c793efe9673b87f808d84fdefc0f732217030c52.1760432043.git.sd@queasysnail.net
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

tls: wait for pending async decryptions if tls_strp_msg_hold fails [+ + +]
Author: Sabrina Dubroca <sd@queasysnail.net>
Date:   Tue Oct 14 11:16:59 2025 +0200

    tls: wait for pending async decryptions if tls_strp_msg_hold fails
    
    [ Upstream commit b8a6ff84abbcbbc445463de58704686011edc8e1 ]
    
    Async decryption calls tls_strp_msg_hold to create a clone of the
    input skb to hold references to the memory it uses. If we fail to
    allocate that clone, proceeding with async decryption can lead to
    various issues (UAF on the skb, writing into userspace memory after
    the recv() call has returned).
    
    In this case, wait for all pending decryption requests.
    
    Fixes: 84c61fe1a75b ("tls: rx: do not use the standard strparser")
    Reported-by: Jann Horn <jannh@google.com>
    Signed-off-by: Sabrina Dubroca <sd@queasysnail.net>
    Link: https://patch.msgid.link/b9fe61dcc07dab15da9b35cf4c7d86382a98caf2.1760432043.git.sd@queasysnail.net
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
usb: gadget: f_acm: Refactor bind path to use __free() [+ + +]
Author: Kuen-Han Tsai <khtsai@google.com>
Date:   Fri Oct 17 20:52:33 2025 -0400

    usb: gadget: f_acm: Refactor bind path to use __free()
    
    [ Upstream commit 47b2116e54b4a854600341487e8b55249e926324 ]
    
    After an bind/unbind cycle, the acm->notify_req is left stale. If a
    subsequent bind fails, the unified error label attempts to free this
    stale request, leading to a NULL pointer dereference when accessing
    ep->ops->free_request.
    
    Refactor the error handling in the bind path to use the __free()
    automatic cleanup mechanism.
    
    Unable to handle kernel NULL pointer dereference at virtual address 0000000000000020
    Call trace:
     usb_ep_free_request+0x2c/0xec
     gs_free_req+0x30/0x44
     acm_bind+0x1b8/0x1f4
     usb_add_function+0xcc/0x1f0
     configfs_composite_bind+0x468/0x588
     gadget_bind_driver+0x104/0x270
     really_probe+0x190/0x374
     __driver_probe_device+0xa0/0x12c
     driver_probe_device+0x3c/0x218
     __device_attach_driver+0x14c/0x188
     bus_for_each_drv+0x10c/0x168
     __device_attach+0xfc/0x198
     device_initial_probe+0x14/0x24
     bus_probe_device+0x94/0x11c
     device_add+0x268/0x48c
     usb_add_gadget+0x198/0x28c
     dwc3_gadget_init+0x700/0x858
     __dwc3_set_mode+0x3cc/0x664
     process_scheduled_works+0x1d8/0x488
     worker_thread+0x244/0x334
     kthread+0x114/0x1bc
     ret_from_fork+0x10/0x20
    
    Fixes: 1f1ba11b6494 ("usb gadget: issue notifications from ACM function")
    Cc: stable@kernel.org
    Signed-off-by: Kuen-Han Tsai <khtsai@google.com>
    Link: https://lore.kernel.org/r/20250916-ready-v1-4-4997bf277548@google.com
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
    Link: https://lore.kernel.org/r/20250916-ready-v1-4-4997bf277548@google.com
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

usb: gadget: f_ecm: Refactor bind path to use __free() [+ + +]
Author: Kuen-Han Tsai <khtsai@google.com>
Date:   Fri Oct 17 21:02:55 2025 -0400

    usb: gadget: f_ecm: Refactor bind path to use __free()
    
    [ Upstream commit 42988380ac67c76bb9dff8f77d7ef3eefd50b7b5 ]
    
    After an bind/unbind cycle, the ecm->notify_req is left stale. If a
    subsequent bind fails, the unified error label attempts to free this
    stale request, leading to a NULL pointer dereference when accessing
    ep->ops->free_request.
    
    Refactor the error handling in the bind path to use the __free()
    automatic cleanup mechanism.
    
    Fixes: da741b8c56d6 ("usb ethernet gadget: split CDC Ethernet function")
    Cc: stable@kernel.org
    Signed-off-by: Kuen-Han Tsai <khtsai@google.com>
    Link: https://lore.kernel.org/r/20250916-ready-v1-5-4997bf277548@google.com
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
    Link: https://lore.kernel.org/r/20250916-ready-v1-5-4997bf277548@google.com
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

usb: gadget: f_ncm: Refactor bind path to use __free() [+ + +]
Author: Kuen-Han Tsai <khtsai@google.com>
Date:   Fri Oct 17 20:41:48 2025 -0400

    usb: gadget: f_ncm: Refactor bind path to use __free()
    
    [ Upstream commit 75a5b8d4ddd4eb6b16cb0b475d14ff4ae64295ef ]
    
    After an bind/unbind cycle, the ncm->notify_req is left stale. If a
    subsequent bind fails, the unified error label attempts to free this
    stale request, leading to a NULL pointer dereference when accessing
    ep->ops->free_request.
    
    Refactor the error handling in the bind path to use the __free()
    automatic cleanup mechanism.
    
    Unable to handle kernel NULL pointer dereference at virtual address 0000000000000020
    Call trace:
     usb_ep_free_request+0x2c/0xec
     ncm_bind+0x39c/0x3dc
     usb_add_function+0xcc/0x1f0
     configfs_composite_bind+0x468/0x588
     gadget_bind_driver+0x104/0x270
     really_probe+0x190/0x374
     __driver_probe_device+0xa0/0x12c
     driver_probe_device+0x3c/0x218
     __device_attach_driver+0x14c/0x188
     bus_for_each_drv+0x10c/0x168
     __device_attach+0xfc/0x198
     device_initial_probe+0x14/0x24
     bus_probe_device+0x94/0x11c
     device_add+0x268/0x48c
     usb_add_gadget+0x198/0x28c
     dwc3_gadget_init+0x700/0x858
     __dwc3_set_mode+0x3cc/0x664
     process_scheduled_works+0x1d8/0x488
     worker_thread+0x244/0x334
     kthread+0x114/0x1bc
     ret_from_fork+0x10/0x20
    
    Fixes: 9f6ce4240a2b ("usb: gadget: f_ncm.c added")
    Cc: stable@kernel.org
    Signed-off-by: Kuen-Han Tsai <khtsai@google.com>
    Link: https://lore.kernel.org/r/20250916-ready-v1-3-4997bf277548@google.com
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
    Link: https://lore.kernel.org/r/20250916-ready-v1-3-4997bf277548@google.com
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

usb: gadget: f_rndis: Refactor bind path to use __free() [+ + +]
Author: Kuen-Han Tsai <khtsai@google.com>
Date:   Fri Oct 17 22:18:22 2025 -0400

    usb: gadget: f_rndis: Refactor bind path to use __free()
    
    [ Upstream commit 08228941436047bdcd35a612c1aec0912a29d8cd ]
    
    After an bind/unbind cycle, the rndis->notify_req is left stale. If a
    subsequent bind fails, the unified error label attempts to free this
    stale request, leading to a NULL pointer dereference when accessing
    ep->ops->free_request.
    
    Refactor the error handling in the bind path to use the __free()
    automatic cleanup mechanism.
    
    Fixes: 45fe3b8e5342 ("usb ethernet gadget: split RNDIS function")
    Cc: stable@kernel.org
    Signed-off-by: Kuen-Han Tsai <khtsai@google.com>
    Link: https://lore.kernel.org/r/20250916-ready-v1-6-4997bf277548@google.com
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
    Link: https://lore.kernel.org/r/20250916-ready-v1-6-4997bf277548@google.com
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

usb: gadget: Introduce free_usb_request helper [+ + +]
Author: Kuen-Han Tsai <khtsai@google.com>
Date:   Fri Oct 17 20:41:47 2025 -0400

    usb: gadget: Introduce free_usb_request helper
    
    [ Upstream commit 201c53c687f2b55a7cc6d9f4000af4797860174b ]
    
    Introduce the free_usb_request() function that frees both the request's
    buffer and the request itself.
    
    This function serves as the cleanup callback for DEFINE_FREE() to enable
    automatic, scope-based cleanup for usb_request pointers.
    
    Signed-off-by: Kuen-Han Tsai <khtsai@google.com>
    Link: https://lore.kernel.org/r/20250916-ready-v1-2-4997bf277548@google.com
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
    Link: https://lore.kernel.org/r/20250916-ready-v1-2-4997bf277548@google.com
    Stable-dep-of: 75a5b8d4ddd4 ("usb: gadget: f_ncm: Refactor bind path to use __free()")
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

usb: gadget: Store endpoint pointer in usb_request [+ + +]
Author: Kuen-Han Tsai <khtsai@google.com>
Date:   Fri Oct 17 20:41:46 2025 -0400

    usb: gadget: Store endpoint pointer in usb_request
    
    [ Upstream commit bfb1d99d969fe3b892db30848aeebfa19d21f57f ]
    
    Gadget function drivers often have goto-based error handling in their
    bind paths, which can be bug-prone. Refactoring these paths to use
    __free() scope-based cleanup is desirable, but currently blocked.
    
    The blocker is that usb_ep_free_request(ep, req) requires two
    parameters, while the __free() mechanism can only pass a pointer to the
    request itself.
    
    Store an endpoint pointer in the struct usb_request. The pointer is
    populated centrally in usb_ep_alloc_request() on every successful
    allocation, making the request object self-contained.
    
    Signed-off-by: Kuen-Han Tsai <khtsai@google.com>
    Link: https://lore.kernel.org/r/20250916-ready-v1-1-4997bf277548@google.com
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
    Link: https://lore.kernel.org/r/20250916-ready-v1-1-4997bf277548@google.com
    Stable-dep-of: 75a5b8d4ddd4 ("usb: gadget: f_ncm: Refactor bind path to use __free()")
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
vfs: Don't leak disconnected dentries on umount [+ + +]
Author: Jan Kara <jack@suse.cz>
Date:   Mon Oct 20 17:51:25 2025 -0400

    vfs: Don't leak disconnected dentries on umount
    
    [ Upstream commit 56094ad3eaa21e6621396cc33811d8f72847a834 ]
    
    When user calls open_by_handle_at() on some inode that is not cached, we
    will create disconnected dentry for it. If such dentry is a directory,
    exportfs_decode_fh_raw() will then try to connect this dentry to the
    dentry tree through reconnect_path(). It may happen for various reasons
    (such as corrupted fs or race with rename) that the call to
    lookup_one_unlocked() in reconnect_one() will fail to find the dentry we
    are trying to reconnect and instead create a new dentry under the
    parent. Now this dentry will not be marked as disconnected although the
    parent still may well be disconnected (at least in case this
    inconsistency happened because the fs is corrupted and .. doesn't point
    to the real parent directory). This creates inconsistency in
    disconnected flags but AFAICS it was mostly harmless. At least until
    commit f1ee616214cb ("VFS: don't keep disconnected dentries on d_anon")
    which removed adding of most disconnected dentries to sb->s_anon list.
    Thus after this commit cleanup of disconnected dentries implicitely
    relies on the fact that dput() will immediately reclaim such dentries.
    However when some leaf dentry isn't marked as disconnected, as in the
    scenario described above, the reclaim doesn't happen and the dentries
    are "leaked". Memory reclaim can eventually reclaim them but otherwise
    they stay in memory and if umount comes first, we hit infamous "Busy
    inodes after unmount" bug. Make sure all dentries created under a
    disconnected parent are marked as disconnected as well.
    
    Reported-by: syzbot+1d79ebe5383fc016cf07@syzkaller.appspotmail.com
    Fixes: f1ee616214cb ("VFS: don't keep disconnected dentries on d_anon")
    CC: stable@vger.kernel.org
    Signed-off-by: Jan Kara <jack@suse.cz>
    Signed-off-by: Christian Brauner <brauner@kernel.org>
    [ relocated DCACHE_DISCONNECTED propagation from d_alloc_parallel() to d_alloc() ]
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
xfs: fix log CRC mismatches between i386 and other architectures [+ + +]
Author: Christoph Hellwig <hch@lst.de>
Date:   Mon Oct 20 08:47:23 2025 -0400

    xfs: fix log CRC mismatches between i386 and other architectures
    
    [ Upstream commit e747883c7d7306acb4d683038d881528fbfbe749 ]
    
    When mounting file systems with a log that was dirtied on i386 on
    other architectures or vice versa, log recovery is unhappy:
    
    [   11.068052] XFS (vdb): Torn write (CRC failure) detected at log block 0x2. Truncating head block from 0xc.
    
    This is because the CRCs generated by i386 and other architectures
    always diff.  The reason for that is that sizeof(struct xlog_rec_header)
    returns different values for i386 vs the rest (324 vs 328), because the
    struct is not sizeof(uint64_t) aligned, and i386 has odd struct size
    alignment rules.
    
    This issue goes back to commit 13cdc853c519 ("Add log versioning, and new
    super block field for the log stripe") in the xfs-import tree, which
    adds log v2 support and the h_size field that causes the unaligned size.
    At that time it only mattered for the crude debug only log header
    checksum, but with commit 0e446be44806 ("xfs: add CRC checks to the log")
    it became a real issue for v5 file system, because now there is a proper
    CRC, and regular builds actually expect it match.
    
    Fix this by allowing checksums with and without the padding.
    
    Fixes: 0e446be44806 ("xfs: add CRC checks to the log")
    Cc: <stable@vger.kernel.org> # v3.8
    Signed-off-by: Christoph Hellwig <hch@lst.de>
    Signed-off-by: Carlos Maiolino <cem@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

xfs: rename the old_crc variable in xlog_recover_process [+ + +]
Author: Christoph Hellwig <hch@lst.de>
Date:   Mon Oct 20 08:47:22 2025 -0400

    xfs: rename the old_crc variable in xlog_recover_process
    
    [ Upstream commit 0b737f4ac1d3ec093347241df74bbf5f54a7e16c ]
    
    old_crc is a very misleading name.  Rename it to expected_crc as that
    described the usage much better.
    
    Signed-off-by: Christoph Hellwig <hch@lst.de>
    Reviewed-by: Darrick J. Wong <djwong@kernel.org>
    Signed-off-by: Carlos Maiolino <cem@kernel.org>
    Stable-dep-of: e747883c7d73 ("xfs: fix log CRC mismatches between i386 and other architectures")
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

xfs: use deferred intent items for reaping crosslinked blocks [+ + +]
Author: Darrick J. Wong <djwong@kernel.org>
Date:   Mon Oct 20 11:51:16 2025 -0400

    xfs: use deferred intent items for reaping crosslinked blocks
    
    [ Upstream commit cd32a0c0dcdf634f2e0e71f41c272e19dece6264 ]
    
    When we're removing rmap records for crosslinked blocks, use deferred
    intent items so that we can try to free/unmap as many of the old data
    structure's blocks as we can in the same transaction as the commit.
    
    Cc: <stable@vger.kernel.org> # v6.6
    Fixes: 1c7ce115e52106 ("xfs: reap large AG metadata extents when possible")
    Signed-off-by: "Darrick J. Wong" <djwong@kernel.org>
    Reviewed-by: Christoph Hellwig <hch@lst.de>
    [ adjusted xfs_rmap_free_extent() and xfs_refcount_free_cow_extent() ]
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>