óÐÉÓÏË ÉÚÍÅÎÅÎÉÊ × Linux 6.5.7

 
arm64: Add Cortex-A520 CPU part definition [+ + +]
Author: Rob Herring <robh@kernel.org>
Date:   Thu Sep 21 14:41:51 2023 -0500

    arm64: Add Cortex-A520 CPU part definition
    
    commit a654a69b9f9c06b2e56387d0b99f0e3e6b0ff4ef upstream.
    
    Add the CPU Part number for the new Arm design.
    
    Cc: stable@vger.kernel.org
    Signed-off-by: Rob Herring <robh@kernel.org>
    Link: https://lore.kernel.org/r/20230921194156.1050055-1-robh@kernel.org
    Signed-off-by: Will Deacon <will@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

arm64: add HWCAP for FEAT_HBC (hinted conditional branches) [+ + +]
Author: Joey Gouly <joey.gouly@arm.com>
Date:   Fri Aug 4 15:37:45 2023 +0100

    arm64: add HWCAP for FEAT_HBC (hinted conditional branches)
    
    [ Upstream commit 7f86d128e437990fd08d9e66ae7c1571666cff8a ]
    
    Add a HWCAP for FEAT_HBC, so that userspace can make a decision on using
    this feature.
    
    Signed-off-by: Joey Gouly <joey.gouly@arm.com>
    Cc: Catalin Marinas <catalin.marinas@arm.com>
    Cc: Will Deacon <will@kernel.org>
    Link: https://lore.kernel.org/r/20230804143746.3900803-2-joey.gouly@arm.com
    Signed-off-by: Will Deacon <will@kernel.org>
    Stable-dep-of: 479965a2b7ec ("arm64: cpufeature: Fix CLRBHB and BC detection")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

arm64: cpufeature: Fix CLRBHB and BC detection [+ + +]
Author: Kristina Martsenko <kristina.martsenko@arm.com>
Date:   Tue Sep 12 14:34:29 2023 +0100

    arm64: cpufeature: Fix CLRBHB and BC detection
    
    [ Upstream commit 479965a2b7ec481737df0cadf553331063b9c343 ]
    
    ClearBHB support is indicated by the CLRBHB field in ID_AA64ISAR2_EL1.
    Following some refactoring the kernel incorrectly checks the BC field
    instead. Fix the detection to use the right field.
    
    (Note: The original ClearBHB support had it as FTR_HIGHER_SAFE, but this
    patch uses FTR_LOWER_SAFE, which seems more correct.)
    
    Also fix the detection of BC (hinted conditional branches) to use
    FTR_LOWER_SAFE, so that it is not reported on mismatched systems.
    
    Fixes: 356137e68a9f ("arm64/sysreg: Make BHB clear feature defines match the architecture")
    Fixes: 8fcc8285c0e3 ("arm64/sysreg: Convert ID_AA64ISAR2_EL1 to automatic generation")
    Cc: stable@vger.kernel.org
    Signed-off-by: Kristina Martsenko <kristina.martsenko@arm.com>
    Reviewed-by: Mark Brown <broonie@kernel.org>
    Link: https://lore.kernel.org/r/20230912133429.2606875-1-kristina.martsenko@arm.com
    Signed-off-by: Will Deacon <will@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

arm64: errata: Add Cortex-A520 speculative unprivileged load workaround [+ + +]
Author: Rob Herring <robh@kernel.org>
Date:   Thu Sep 21 14:41:52 2023 -0500

    arm64: errata: Add Cortex-A520 speculative unprivileged load workaround
    
    commit 471470bc7052d28ce125901877dd10e4c048e513 upstream.
    
    Implement the workaround for ARM Cortex-A520 erratum 2966298. On an
    affected Cortex-A520 core, a speculatively executed unprivileged load
    might leak data from a privileged load via a cache side channel. The
    issue only exists for loads within a translation regime with the same
    translation (e.g. same ASID and VMID). Therefore, the issue only affects
    the return to EL0.
    
    The workaround is to execute a TLBI before returning to EL0 after all
    loads of privileged data. A non-shareable TLBI to any address is
    sufficient.
    
    The workaround isn't necessary if page table isolation (KPTI) is
    enabled, but for simplicity it will be. Page table isolation should
    normally be disabled for Cortex-A520 as it supports the CSV3 feature
    and the E0PD feature (used when KASLR is enabled).
    
    Cc: stable@vger.kernel.org
    Signed-off-by: Rob Herring <robh@kernel.org>
    Link: https://lore.kernel.org/r/20230921194156.1050055-2-robh@kernel.org
    Signed-off-by: Will Deacon <will@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
ASoC: soc-utils: Export snd_soc_dai_is_dummy() symbol [+ + +]
Author: Sameer Pujar <spujar@nvidia.com>
Date:   Thu Sep 7 20:32:24 2023 +0530

    ASoC: soc-utils: Export snd_soc_dai_is_dummy() symbol
    
    [ Upstream commit f101583fa9f8c3f372d4feb61d67da0ccbf4d9a5 ]
    
    Export symbol snd_soc_dai_is_dummy() for usage outside core driver
    modules. This is required by Tegra ASoC machine driver.
    
    Signed-off-by: Sameer Pujar <spujar@nvidia.com>
    Link: https://lore.kernel.org/r/1694098945-32760-2-git-send-email-spujar@nvidia.com
    Signed-off-by: Mark Brown <broonie@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>
ASoC: tegra: Fix redundant PLLA and PLLA_OUT0 updates [+ + +]
Author: Sameer Pujar <spujar@nvidia.com>
Date:   Thu Sep 7 20:32:25 2023 +0530

    ASoC: tegra: Fix redundant PLLA and PLLA_OUT0 updates
    
    [ Upstream commit e765886249c533e1bb5cbc3cd741bad677417312 ]
    
    Tegra audio graph card has many DAI links which connects internal
    AHUB modules and external audio codecs. Since these are DPCM links,
    hw_params() call in the machine driver happens for each connected
    BE link and PLLA is updated every time. This is not really needed
    for all links as only I/O link DAIs derive respective clocks from
    PLLA_OUT0 and thus from PLLA. Hence add checks to limit the clock
    updates to DAIs over I/O links.
    
    This found to be fixing a DMIC clock discrepancy which is suspected
    to happen because of back to back quick PLLA and PLLA_OUT0 rate
    updates. This was observed on Jetson TX2 platform where DMIC clock
    ended up with unexpected value.
    
    Fixes: 202e2f774543 ("ASoC: tegra: Add audio graph based card driver")
    Cc: stable@vger.kernel.org
    Signed-off-by: Sameer Pujar <spujar@nvidia.com>
    Link: https://lore.kernel.org/r/1694098945-32760-3-git-send-email-spujar@nvidia.com
    Signed-off-by: Mark Brown <broonie@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
ata: libata-scsi: Fix delayed scsi_rescan_device() execution [+ + +]
Author: Damien Le Moal <dlemoal@kernel.org>
Date:   Tue Sep 5 09:06:23 2023 +0900

    ata: libata-scsi: Fix delayed scsi_rescan_device() execution
    
    [ Upstream commit 8b4d9469d0b0e553208ee6f62f2807111fde18b9 ]
    
    Commit 6aa0365a3c85 ("ata: libata-scsi: Avoid deadlock on rescan after
    device resume") modified ata_scsi_dev_rescan() to check the scsi device
    "is_suspended" power field to ensure that the scsi device associated
    with an ATA device is fully resumed when scsi_rescan_device() is
    executed. However, this fix is problematic as:
    1) It relies on a PM internal field that should not be used without PM
       device locking protection.
    2) The check for is_suspended and the call to scsi_rescan_device() are
       not atomic and a suspend PM event may be triggered between them,
       casuing scsi_rescan_device() to be called on a suspended device and
       in that function blocking while holding the scsi device lock. This
       would deadlock a following resume operation.
    These problems can trigger PM deadlocks on resume, especially with
    resume operations triggered quickly after or during suspend operations.
    E.g., a simple bash script like:
    
    for (( i=0; i<10; i++ )); do
            echo "+2 > /sys/class/rtc/rtc0/wakealarm
            echo mem > /sys/power/state
    done
    
    that triggers a resume 2 seconds after starting suspending a system can
    quickly lead to a PM deadlock preventing the system from correctly
    resuming.
    
    Fix this by replacing the check on is_suspended with a check on the
    return value given by scsi_rescan_device() as that function will fail if
    called against a suspended device. Also make sure rescan tasks already
    scheduled are first cancelled before suspending an ata port.
    
    Fixes: 6aa0365a3c85 ("ata: libata-scsi: Avoid deadlock on rescan after device resume")
    Cc: stable@vger.kernel.org
    Signed-off-by: Damien Le Moal <dlemoal@kernel.org>
    Reviewed-by: Hannes Reinecke <hare@suse.de>
    Reviewed-by: Niklas Cassel <niklas.cassel@wdc.com>
    Tested-by: Geert Uytterhoeven <geert+renesas@glider.be>
    Reviewed-by: Martin K. Petersen <martin.petersen@oracle.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
Bluetooth: Delete unused hci_req_prepare_suspend() declaration [+ + +]
Author: Yao Xiao <xiaoyao@rock-chips.com>
Date:   Sat Aug 26 16:13:13 2023 +0800

    Bluetooth: Delete unused hci_req_prepare_suspend() declaration
    
    [ Upstream commit cbaabbcdcbd355f0a1ccc09a925575c51c270750 ]
    
    hci_req_prepare_suspend() has been deprecated in favor of
    hci_suspend_sync().
    
    Fixes: 182ee45da083 ("Bluetooth: hci_sync: Rework hci_suspend_notifier")
    Signed-off-by: Yao Xiao <xiaoyao@rock-chips.com>
    Signed-off-by: Luiz Augusto von Dentz <luiz.von.dentz@intel.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

Bluetooth: Fix hci_link_tx_to RCU lock usage [+ + +]
Author: Ying Hsu <yinghsu@chromium.org>
Date:   Mon Sep 4 14:11:51 2023 +0000

    Bluetooth: Fix hci_link_tx_to RCU lock usage
    
    [ Upstream commit c7eaf80bfb0c8cef852cce9501b95dd5a6bddcb9 ]
    
    Syzbot found a bug "BUG: sleeping function called from invalid context
    at kernel/locking/mutex.c:580". It is because hci_link_tx_to holds an
    RCU read lock and calls hci_disconnect which would hold a mutex lock
    since the commit a13f316e90fd ("Bluetooth: hci_conn: Consolidate code
    for aborting connections"). Here's an example call trace:
    
       __dump_stack lib/dump_stack.c:88 [inline]
       dump_stack_lvl+0xfc/0x174 lib/dump_stack.c:106
       ___might_sleep+0x4a9/0x4d3 kernel/sched/core.c:9663
       __mutex_lock_common kernel/locking/mutex.c:576 [inline]
       __mutex_lock+0xc7/0x6e7 kernel/locking/mutex.c:732
       hci_cmd_sync_queue+0x3a/0x287 net/bluetooth/hci_sync.c:388
       hci_abort_conn+0x2cd/0x2e4 net/bluetooth/hci_conn.c:1812
       hci_disconnect+0x207/0x237 net/bluetooth/hci_conn.c:244
       hci_link_tx_to net/bluetooth/hci_core.c:3254 [inline]
       __check_timeout net/bluetooth/hci_core.c:3419 [inline]
       __check_timeout+0x310/0x361 net/bluetooth/hci_core.c:3399
       hci_sched_le net/bluetooth/hci_core.c:3602 [inline]
       hci_tx_work+0xe8f/0x12d0 net/bluetooth/hci_core.c:3652
       process_one_work+0x75c/0xba1 kernel/workqueue.c:2310
       worker_thread+0x5b2/0x73a kernel/workqueue.c:2457
       kthread+0x2f7/0x30b kernel/kthread.c:319
       ret_from_fork+0x1f/0x30 arch/x86/entry/entry_64.S:298
    
    This patch releases RCU read lock before calling hci_disconnect and
    reacquires it afterward to fix the bug.
    
    Fixes: a13f316e90fd ("Bluetooth: hci_conn: Consolidate code for aborting connections")
    Signed-off-by: Ying Hsu <yinghsu@chromium.org>
    Signed-off-by: Luiz Augusto von Dentz <luiz.von.dentz@intel.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

Bluetooth: hci_codec: Fix leaking content of local_codecs [+ + +]
Author: Luiz Augusto von Dentz <luiz.von.dentz@intel.com>
Date:   Fri Sep 15 13:24:47 2023 -0700

    Bluetooth: hci_codec: Fix leaking content of local_codecs
    
    commit b938790e70540bf4f2e653dcd74b232494d06c8f upstream.
    
    The following memory leak can be observed when the controller supports
    codecs which are stored in local_codecs list but the elements are never
    freed:
    
    unreferenced object 0xffff88800221d840 (size 32):
      comm "kworker/u3:0", pid 36, jiffies 4294898739 (age 127.060s)
      hex dump (first 32 bytes):
        f8 d3 02 03 80 88 ff ff 80 d8 21 02 80 88 ff ff  ..........!.....
        00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00  ................
      backtrace:
        [<ffffffffb324f557>] __kmalloc+0x47/0x120
        [<ffffffffb39ef37d>] hci_codec_list_add.isra.0+0x2d/0x160
        [<ffffffffb39ef643>] hci_read_codec_capabilities+0x183/0x270
        [<ffffffffb39ef9ab>] hci_read_supported_codecs+0x1bb/0x2d0
        [<ffffffffb39f162e>] hci_read_local_codecs_sync+0x3e/0x60
        [<ffffffffb39ff1b3>] hci_dev_open_sync+0x943/0x11e0
        [<ffffffffb396d55d>] hci_power_on+0x10d/0x3f0
        [<ffffffffb30c99b4>] process_one_work+0x404/0x800
        [<ffffffffb30ca134>] worker_thread+0x374/0x670
        [<ffffffffb30d9108>] kthread+0x188/0x1c0
        [<ffffffffb304db6b>] ret_from_fork+0x2b/0x50
        [<ffffffffb300206a>] ret_from_fork_asm+0x1a/0x30
    
    Cc: stable@vger.kernel.org
    Fixes: 8961987f3f5f ("Bluetooth: Enumerate local supported codec and cache details")
    Signed-off-by: Luiz Augusto von Dentz <luiz.von.dentz@intel.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

Bluetooth: hci_sync: Fix handling of HCI_QUIRK_STRICT_DUPLICATE_FILTER [+ + +]
Author: Luiz Augusto von Dentz <luiz.von.dentz@intel.com>
Date:   Tue Aug 29 13:50:06 2023 -0700

    Bluetooth: hci_sync: Fix handling of HCI_QUIRK_STRICT_DUPLICATE_FILTER
    
    commit 941c998b42f5c90384f49da89a6e11233de567cf upstream.
    
    When HCI_QUIRK_STRICT_DUPLICATE_FILTER is set LE scanning requires
    periodic restarts of the scanning procedure as the controller would
    consider device previously found as duplicated despite of RSSI changes,
    but in order to set the scan timeout properly set le_scan_restart needs
    to be synchronous so it shall not use hci_cmd_sync_queue which defers
    the command processing to cmd_sync_work.
    
    Cc: stable@vger.kernel.org
    Link: https://lore.kernel.org/linux-bluetooth/578e6d7afd676129decafba846a933f5@agner.ch/#t
    Fixes: 27d54b778ad1 ("Bluetooth: Rework le_scan_restart for hci_sync")
    Signed-off-by: Luiz Augusto von Dentz <luiz.von.dentz@intel.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

Bluetooth: ISO: Fix handling of listen for unicast [+ + +]
Author: Luiz Augusto von Dentz <luiz.von.dentz@intel.com>
Date:   Mon Aug 28 13:05:45 2023 -0700

    Bluetooth: ISO: Fix handling of listen for unicast
    
    [ Upstream commit e0275ea52169412b8faccb4e2f4fed8a057844c6 ]
    
    iso_listen_cis shall only return -EADDRINUSE if the listening socket has
    the destination set to BDADDR_ANY otherwise if the destination is set to
    a specific address it is for broadcast which shall be ignored.
    
    Fixes: f764a6c2c1e4 ("Bluetooth: ISO: Add broadcast support")
    Signed-off-by: Luiz Augusto von Dentz <luiz.von.dentz@intel.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
bpf, sockmap: Do not inc copied_seq when PEEK flag set [+ + +]
Author: John Fastabend <john.fastabend@gmail.com>
Date:   Mon Sep 25 20:52:59 2023 -0700

    bpf, sockmap: Do not inc copied_seq when PEEK flag set
    
    [ Upstream commit da9e915eaf5dadb1963b7738cdfa42ed55212445 ]
    
    When data is peek'd off the receive queue we shouldn't considered it
    copied from tcp_sock side. When we increment copied_seq this will confuse
    tcp_data_ready() because copied_seq can be arbitrarily increased. From
    application side it results in poll() operations not waking up when
    expected.
    
    Notice tcp stack without BPF recvmsg programs also does not increment
    copied_seq.
    
    We broke this when we moved copied_seq into recvmsg to only update when
    actual copy was happening. But, it wasn't working correctly either before
    because the tcp_data_ready() tried to use the copied_seq value to see
    if data was read by user yet. See fixes tags.
    
    Fixes: e5c6de5fa0258 ("bpf, sockmap: Incorrectly handling copied_seq")
    Fixes: 04919bed948dc ("tcp: Introduce tcp_read_skb()")
    Signed-off-by: John Fastabend <john.fastabend@gmail.com>
    Signed-off-by: Daniel Borkmann <daniel@iogearbox.net>
    Reviewed-by: Jakub Sitnicki <jakub@cloudflare.com>
    Link: https://lore.kernel.org/bpf/20230926035300.135096-3-john.fastabend@gmail.com
    Signed-off-by: Sasha Levin <sashal@kernel.org>

bpf, sockmap: Reject sk_msg egress redirects to non-TCP sockets [+ + +]
Author: Jakub Sitnicki <jakub@cloudflare.com>
Date:   Wed Sep 20 12:20:55 2023 +0200

    bpf, sockmap: Reject sk_msg egress redirects to non-TCP sockets
    
    [ Upstream commit b80e31baa43614e086a9d29dc1151932b1bd7fc5 ]
    
    With a SOCKMAP/SOCKHASH map and an sk_msg program user can steer messages
    sent from one TCP socket (s1) to actually egress from another TCP
    socket (s2):
    
    tcp_bpf_sendmsg(s1)             // = sk_prot->sendmsg
      tcp_bpf_send_verdict(s1)      // __SK_REDIRECT case
        tcp_bpf_sendmsg_redir(s2)
          tcp_bpf_push_locked(s2)
            tcp_bpf_push(s2)
              tcp_rate_check_app_limited(s2) // expects tcp_sock
              tcp_sendmsg_locked(s2)         // ditto
    
    There is a hard-coded assumption in the call-chain, that the egress
    socket (s2) is a TCP socket.
    
    However in commit 122e6c79efe1 ("sock_map: Update sock type checks for
    UDP") we have enabled redirects to non-TCP sockets. This was done for the
    sake of BPF sk_skb programs. There was no indention to support sk_msg
    send-to-egress use case.
    
    As a result, attempts to send-to-egress through a non-TCP socket lead to a
    crash due to invalid downcast from sock to tcp_sock:
    
     BUG: kernel NULL pointer dereference, address: 000000000000002f
     ...
     Call Trace:
      <TASK>
      ? show_regs+0x60/0x70
      ? __die+0x1f/0x70
      ? page_fault_oops+0x80/0x160
      ? do_user_addr_fault+0x2d7/0x800
      ? rcu_is_watching+0x11/0x50
      ? exc_page_fault+0x70/0x1c0
      ? asm_exc_page_fault+0x27/0x30
      ? tcp_tso_segs+0x14/0xa0
      tcp_write_xmit+0x67/0xce0
      __tcp_push_pending_frames+0x32/0xf0
      tcp_push+0x107/0x140
      tcp_sendmsg_locked+0x99f/0xbb0
      tcp_bpf_push+0x19d/0x3a0
      tcp_bpf_sendmsg_redir+0x55/0xd0
      tcp_bpf_send_verdict+0x407/0x550
      tcp_bpf_sendmsg+0x1a1/0x390
      inet_sendmsg+0x6a/0x70
      sock_sendmsg+0x9d/0xc0
      ? sockfd_lookup_light+0x12/0x80
      __sys_sendto+0x10e/0x160
      ? syscall_enter_from_user_mode+0x20/0x60
      ? __this_cpu_preempt_check+0x13/0x20
      ? lockdep_hardirqs_on+0x82/0x110
      __x64_sys_sendto+0x1f/0x30
      do_syscall_64+0x38/0x90
      entry_SYSCALL_64_after_hwframe+0x63/0xcd
    
    Reject selecting a non-TCP sockets as redirect target from a BPF sk_msg
    program to prevent the crash. When attempted, user will receive an EACCES
    error from send/sendto/sendmsg() syscall.
    
    Fixes: 122e6c79efe1 ("sock_map: Update sock type checks for UDP")
    Signed-off-by: Jakub Sitnicki <jakub@cloudflare.com>
    Signed-off-by: Daniel Borkmann <daniel@iogearbox.net>
    Acked-by: John Fastabend <john.fastabend@gmail.com>
    Link: https://lore.kernel.org/bpf/20230920102055.42662-1-jakub@cloudflare.com
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
bpf: Fix tr dereferencing [+ + +]
Author: Leon Hwang <hffilwlqm@gmail.com>
Date:   Sun Sep 17 23:38:46 2023 +0800

    bpf: Fix tr dereferencing
    
    [ Upstream commit b724a6418f1f853bcb39c8923bf14a50c7bdbd07 ]
    
    Fix 'tr' dereferencing bug when CONFIG_BPF_JIT is turned off.
    
    When CONFIG_BPF_JIT is turned off, 'bpf_trampoline_get()' returns NULL,
    which is same as the cases when CONFIG_BPF_JIT is turned on.
    
    Closes: https://lore.kernel.org/r/202309131936.5Nc8eUD0-lkp@intel.com/
    Fixes: f7b12b6fea00 ("bpf: verifier: refactor check_attach_btf_id()")
    Reported-by: kernel test robot <lkp@intel.com>
    Reported-by: Dan Carpenter <dan.carpenter@linaro.org>
    Signed-off-by: Leon Hwang <hffilwlqm@gmail.com>
    Signed-off-by: Andrii Nakryiko <andrii@kernel.org>
    Link: https://lore.kernel.org/bpf/20230917153846.88732-1-hffilwlqm@gmail.com
    Signed-off-by: Sasha Levin <sashal@kernel.org>

bpf: tcp_read_skb needs to pop skb regardless of seq [+ + +]
Author: John Fastabend <john.fastabend@gmail.com>
Date:   Mon Sep 25 20:52:58 2023 -0700

    bpf: tcp_read_skb needs to pop skb regardless of seq
    
    [ Upstream commit 9b7177b1df64b8d7f85700027c324aadd6aded00 ]
    
    Before fix e5c6de5fa0258 tcp_read_skb() would increment the tp->copied-seq
    value. This (as described in the commit) would cause an error for apps
    because once that is incremented the application might believe there is no
    data to be read. Then some apps would stall or abort believing no data is
    available.
    
    However, the fix is incomplete because it introduces another issue in
    the skb dequeue. The loop does tcp_recv_skb() in a while loop to consume
    as many skbs as possible. The problem is the call is ...
    
      tcp_recv_skb(sk, seq, &offset)
    
    ... where 'seq' is:
    
      u32 seq = tp->copied_seq;
    
    Now we can hit a case where we've yet incremented copied_seq from BPF side,
    but then tcp_recv_skb() fails this test ...
    
     if (offset < skb->len || (TCP_SKB_CB(skb)->tcp_flags & TCPHDR_FIN))
    
    ... so that instead of returning the skb we call tcp_eat_recv_skb() which
    frees the skb. This is because the routine believes the SKB has been collapsed
    per comment:
    
     /* This looks weird, but this can happen if TCP collapsing
      * splitted a fat GRO packet, while we released socket lock
      * in skb_splice_bits()
      */
    
    This can't happen here we've unlinked the full SKB and orphaned it. Anyways
    it would confuse any BPF programs if the data were suddenly moved underneath
    it.
    
    To fix this situation do simpler operation and just skb_peek() the data
    of the queue followed by the unlink. It shouldn't need to check this
    condition and tcp_read_skb() reads entire skbs so there is no need to
    handle the 'offset!=0' case as we would see in tcp_read_sock().
    
    Fixes: e5c6de5fa0258 ("bpf, sockmap: Incorrectly handling copied_seq")
    Fixes: 04919bed948dc ("tcp: Introduce tcp_read_skb()")
    Signed-off-by: John Fastabend <john.fastabend@gmail.com>
    Signed-off-by: Daniel Borkmann <daniel@iogearbox.net>
    Reviewed-by: Jakub Sitnicki <jakub@cloudflare.com>
    Link: https://lore.kernel.org/bpf/20230926035300.135096-2-john.fastabend@gmail.com
    Signed-off-by: Sasha Levin <sashal@kernel.org>

bpf: unconditionally reset backtrack_state masks on global func exit [+ + +]
Author: Andrii Nakryiko <andrii@kernel.org>
Date:   Mon Sep 18 14:01:10 2023 -0700

    bpf: unconditionally reset backtrack_state masks on global func exit
    
    [ Upstream commit 81335f90e8a88b81932df011105c46e708744f44 ]
    
    In mark_chain_precision() logic, when we reach the entry to a global
    func, it is expected that R1-R5 might be still requested to be marked
    precise. This would correspond to some integer input arguments being
    tracked as precise. This is all expected and handled as a special case.
    
    What's not expected is that we'll leave backtrack_state structure with
    some register bits set. This is because for subsequent precision
    propagations backtrack_state is reused without clearing masks, as all
    code paths are carefully written in a way to leave empty backtrack_state
    with zeroed out masks, for speed.
    
    The fix is trivial, we always clear register bit in the register mask, and
    then, optionally, set reg->precise if register is SCALAR_VALUE type.
    
    Reported-by: Chris Mason <clm@meta.com>
    Fixes: be2ef8161572 ("bpf: allow precision tracking for programs with subprogs")
    Signed-off-by: Andrii Nakryiko <andrii@kernel.org>
    Link: https://lore.kernel.org/r/20230918210110.2241458-1-andrii@kernel.org
    Signed-off-by: Alexei Starovoitov <ast@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
btrfs: always print transaction aborted messages with an error level [+ + +]
Author: Filipe Manana <fdmanana@suse.com>
Date:   Tue Sep 26 19:31:19 2023 +0100

    btrfs: always print transaction aborted messages with an error level
    
    commit f8d1b011ca8c9d64ce32da431a8420635a96958a upstream.
    
    Commit b7af0635c87f ("btrfs: print transaction aborted messages with an
    error level") changed the log level of transaction aborted messages from
    a debug level to an error level, so that such messages are always visible
    even on production systems where the log level is normally above the debug
    level (and also on some syzbot reports).
    
    Later, commit fccf0c842ed4 ("btrfs: move btrfs_abort_transaction to
    transaction.c") changed the log level back to debug level when the error
    number for a transaction abort should not have a stack trace printed.
    This happened for absolutely no reason. It's always useful to print
    transaction abort messages with an error level, regardless of whether
    the error number should cause a stack trace or not.
    
    So change back the log level to error level.
    
    Fixes: fccf0c842ed4 ("btrfs: move btrfs_abort_transaction to transaction.c")
    CC: stable@vger.kernel.org # 6.5+
    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: don't clear uptodate on write errors [+ + +]
Author: Josef Bacik <josef@toxicpanda.com>
Date:   Fri Sep 8 15:31:39 2023 -0400

    btrfs: don't clear uptodate on write errors
    
    [ Upstream commit b595d25996329427b2c09d4b90395a165fb3ef8e ]
    
    We have been consistently seeing hangs with generic/648 in our subpage
    GitHub CI setup.  This is a classic deadlock, we are calling
    btrfs_read_folio() on a folio, which requires holding the folio lock on
    the folio, and then finding a ordered extent that overlaps that range
    and calling btrfs_start_ordered_extent(), which then tries to write out
    the dirty page, which requires taking the folio lock and then we
    deadlock.
    
    The hang happens because we're writing to range [1271750656, 1271767040),
    page index [77621, 77622], and page 77621 is !Uptodate.  It is also Dirty,
    so we call btrfs_read_folio() for 77621 and which does
    btrfs_lock_and_flush_ordered_range() for that range, and we find an ordered
    extent which is [1271644160, 1271746560), page index [77615, 77621].
    The page indexes overlap, but the actual bytes don't overlap.  We're
    holding the page lock for 77621, then call
    btrfs_lock_and_flush_ordered_range() which tries to flush the dirty
    page, and tries to lock 77621 again and then we deadlock.
    
    The byte ranges do not overlap, but with subpage support if we clear
    uptodate on any portion of the page we mark the entire thing as not
    uptodate.
    
    We have been clearing page uptodate on write errors, but no other file
    system does this, and is in fact incorrect.  This doesn't hurt us in the
    !subpage case because we can't end up with overlapped ranges that don't
    also overlap on the page.
    
    Fix this by not clearing uptodate when we have a write error.  The only
    thing we should be doing in this case is setting the mapping error and
    carrying on.  This makes it so we would no longer call
    btrfs_read_folio() on the page as it's uptodate and eliminates the
    deadlock.
    
    With this patch we're now able to make it through a full fstests run on
    our subpage blocksize VMs.
    
    Note for stable backports: this probably goes beyond 6.1 but the code
    has been cleaned up and clearing the uptodate bit must be verified on
    each version independently.
    
    CC: stable@vger.kernel.org # 6.1+
    Reviewed-by: Qu Wenruo <wqu@suse.com>
    Signed-off-by: Josef Bacik <josef@toxicpanda.com>
    Signed-off-by: David Sterba <dsterba@suse.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

btrfs: remove btrfs_writepage_endio_finish_ordered [+ + +]
Author: Christoph Hellwig <hch@lst.de>
Date:   Wed Jun 28 17:31:25 2023 +0200

    btrfs: remove btrfs_writepage_endio_finish_ordered
    
    [ Upstream commit 6648cedd86135db197410e56b5372b2945f2b311 ]
    
    btrfs_writepage_endio_finish_ordered is a small wrapper around
    btrfs_mark_ordered_io_finished that just changs the argument passing
    slightly, and adds a tracepoint.
    
    Move the tracpoint to btrfs_mark_ordered_io_finished, which means
    it now also covers the error handling in btrfs_cleanup_ordered_extent
    and switch all callers to just call btrfs_mark_ordered_io_finished
    directly.
    
    Reviewed-by: Josef Bacik <josef@toxicpanda.com>
    Signed-off-by: Christoph Hellwig <hch@lst.de>
    Reviewed-by: David Sterba <dsterba@suse.com>
    Signed-off-by: David Sterba <dsterba@suse.com>
    Stable-dep-of: b595d2599632 ("btrfs: don't clear uptodate on write errors")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

btrfs: remove end_extent_writepage [+ + +]
Author: Christoph Hellwig <hch@lst.de>
Date:   Wed Jun 28 17:31:26 2023 +0200

    btrfs: remove end_extent_writepage
    
    [ Upstream commit 9783e4deed7291996459858a1a16f41a8988dd60 ]
    
    end_extent_writepage is a small helper that combines a call to
    btrfs_mark_ordered_io_finished with conditional error-only calls to
    btrfs_page_clear_uptodate and mapping_set_error with a somewhat
    unfortunate calling convention that passes and inclusive end instead
    of the len expected by the underlying functions.
    
    Remove end_extent_writepage and open code it in the 4 callers. Out
    of those two already are error-only and thus don't need the extra
    conditional, and one already has the mapping_set_error, so a duplicate
    call can be avoided.
    
    Reviewed-by: Josef Bacik <josef@toxicpanda.com>
    Signed-off-by: Christoph Hellwig <hch@lst.de>
    Reviewed-by: David Sterba <dsterba@suse.com>
    Signed-off-by: David Sterba <dsterba@suse.com>
    Stable-dep-of: b595d2599632 ("btrfs: don't clear uptodate on write errors")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
dm zoned: free dmz->ddev array in dmz_put_zoned_devices [+ + +]
Author: Fedor Pchelkin <pchelkin@ispras.ru>
Date:   Wed Sep 20 13:51:16 2023 +0300

    dm zoned: free dmz->ddev array in dmz_put_zoned_devices
    
    commit 9850ccd5dd88075b2b7fd28d96299d5535f58cc5 upstream.
    
    Commit 4dba12881f88 ("dm zoned: support arbitrary number of devices")
    made the pointers to additional zoned devices to be stored in a
    dynamically allocated dmz->ddev array. However, this array is not freed.
    
    Rename dmz_put_zoned_device to dmz_put_zoned_devices and fix it to
    free the dmz->ddev array when cleaning up zoned device information.
    Remove NULL assignment for all dmz->ddev elements and just free the
    dmz->ddev array instead.
    
    Found by Linux Verification Center (linuxtesting.org).
    
    Fixes: 4dba12881f88 ("dm zoned: support arbitrary number of devices")
    Cc: stable@vger.kernel.org
    Signed-off-by: Fedor Pchelkin <pchelkin@ispras.ru>
    Signed-off-by: Mike Snitzer <snitzer@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
drivers/net: process the result of hdlc_open() and add call of hdlc_close() in uhdlc_close() [+ + +]
Author: Alexandra Diupina <adiupina@astralinux.ru>
Date:   Tue Sep 19 17:25:02 2023 +0300

    drivers/net: process the result of hdlc_open() and add call of hdlc_close() in uhdlc_close()
    
    [ Upstream commit a59addacf899b1b21a7b7449a1c52c98704c2472 ]
    
    Process the result of hdlc_open() and call uhdlc_close()
    in case of an error. It is necessary to pass the error
    code up the control flow, similar to a possible
    error in request_irq().
    Also add a hdlc_close() call to the uhdlc_close()
    because the comment to hdlc_close() says it must be called
    by the hardware driver when the HDLC device is being closed
    
    Found by Linux Verification Center (linuxtesting.org) with SVACE.
    
    Fixes: c19b6d246a35 ("drivers/net: support hdlc function for QE-UCC")
    Signed-off-by: Alexandra Diupina <adiupina@astralinux.ru>
    Reviewed-by: Christophe Leroy <christophe.leroy@csgroup.eu>
    Signed-off-by: David S. Miller <davem@davemloft.net>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
drm/amd: Fix detection of _PR3 on the PCIe root port [+ + +]
Author: Mario Limonciello <mario.limonciello@amd.com>
Date:   Tue Sep 26 17:59:53 2023 -0500

    drm/amd: Fix detection of _PR3 on the PCIe root port
    
    commit 134b8c5d8674e7cde380f82e9aedfd46dcdd16f7 upstream.
    
    On some systems with Navi3x dGPU will attempt to use BACO for runtime
    PM but fails to resume properly.  This is because on these systems
    the root port goes into D3cold which is incompatible with BACO.
    
    This happens because in this case dGPU is connected to a bridge between
    root port which causes BOCO detection logic to fail.  Fix the intent of
    the logic by looking at root port, not the immediate upstream bridge for
    _PR3.
    
    Cc: stable@vger.kernel.org
    Suggested-by: Jun Ma <Jun.Ma2@amd.com>
    Tested-by: David Perry <David.Perry@amd.com>
    Fixes: b10c1c5b3a4e ("drm/amdgpu: add check for ACPI power resources")
    Signed-off-by: Mario Limonciello <mario.limonciello@amd.com>
    Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
    Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

drm/amd: Fix logic error in sienna_cichlid_update_pcie_parameters() [+ + +]
Author: Mario Limonciello <mario.limonciello@amd.com>
Date:   Tue Sep 26 21:07:43 2023 -0500

    drm/amd: Fix logic error in sienna_cichlid_update_pcie_parameters()
    
    commit 2a1fe39a5be785e962e387146aed34fa9a829f3f upstream.
    
    While aligning SMU11 with SMU13 implementation an assumption was made that
    `dpm_context->dpm_tables.pcie_table` was populated in dpm table initialization
    like in SMU13 but it isn't.
    
    So restore some of the original logic and instead just check for
    amdgpu_device_pcie_dynamic_switching_supported() to decide whether to hardcode
    values; erring on the side of performance.
    
    Cc: stable@vger.kernel.org # 6.1+
    Reported-and-tested-by: Umio Yasuno <coelacanth_dream@protonmail.com>
    Closes: https://gitlab.freedesktop.org/drm/amd/-/issues/1447#note_2101382
    Fixes: e701156ccc6c ("drm/amd: Align SMU11 SMU_MSG_OverridePcieParameters implementation with SMU13")
    Signed-off-by: Mario Limonciello <mario.limonciello@amd.com>
    Reviewed-by: Alex Deucher <alexander.deucher@amd.com>
    Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
drm/i915: Don't set PIPE_CONTROL_FLUSH_L3 for aux inval [+ + +]
Author: Nirmoy Das <nirmoy.das@intel.com>
Date:   Tue Sep 26 16:24:01 2023 +0200

    drm/i915: Don't set PIPE_CONTROL_FLUSH_L3 for aux inval
    
    commit 128c20eda73bd3e78505c574fb17adb46195c98b upstream.
    
    PIPE_CONTROL_FLUSH_L3 is not needed for aux invalidation
    so don't set that.
    
    Fixes: 78a6ccd65fa3 ("drm/i915/gt: Ensure memory quiesced before invalidation")
    Cc: Jonathan Cavitt <jonathan.cavitt@intel.com>
    Cc: Andi Shyti <andi.shyti@linux.intel.com>
    Cc: <stable@vger.kernel.org> # v5.8+
    Cc: Andrzej Hajda <andrzej.hajda@intel.com>
    Cc: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
    Cc: Matt Roper <matthew.d.roper@intel.com>
    Cc: Tejas Upadhyay <tejas.upadhyay@intel.com>
    Cc: Lucas De Marchi <lucas.demarchi@intel.com>
    Cc: Prathap Kumar Valsan <prathap.kumar.valsan@intel.com>
    Cc: Tapani Pälli <tapani.palli@intel.com>
    Cc: Mark Janes <mark.janes@intel.com>
    Cc: Rodrigo Vivi <rodrigo.vivi@intel.com>
    Signed-off-by: Nirmoy Das <nirmoy.das@intel.com>
    Acked-by: Matt Roper <matthew.d.roper@intel.com>
    Reviewed-by: Andi Shyti <andi.shyti@linux.intel.com>
    Tested-by: Tapani Pälli <tapani.palli@intel.com>
    Reviewed-by: Andrzej Hajda <andrzej.hajda@intel.com>
    Link: https://patchwork.freedesktop.org/patch/msgid/20230926142401.25687-1-nirmoy.das@intel.com
    (cherry picked from commit 03d681412b38558aefe4fb0f46e36efa94bb21ef)
    Signed-off-by: Rodrigo Vivi <rodrigo.vivi@intel.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
erofs: allow empty device tags in flatdev mode [+ + +]
Author: Jingbo Xu <jefflexu@linux.alibaba.com>
Date:   Fri Sep 15 16:27:28 2023 +0800

    erofs: allow empty device tags in flatdev mode
    
    [ Upstream commit f939aeea7ab7d96cd321e7ac107f5a070836b66f ]
    
    Device tags aren't actually required in flatdev mode, thus fix mount
    failure due to empty device tags in flatdev mode.
    
    Signed-off-by: Jingbo Xu <jefflexu@linux.alibaba.com>
    Fixes: 8b465fecc35a ("erofs: support flattened block device for multi-blob images")
    Reviewed-by: Jia Zhu <zhujia.zj@bytedance.com>
    Reviewed-by: Gao Xiang <hsiangkao@linux.alibaba.com>
    Link: https://lore.kernel.org/r/20230915082728.56588-1-jefflexu@linux.alibaba.com
    Signed-off-by: Gao Xiang <hsiangkao@linux.alibaba.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

erofs: fix memory leak of LZMA global compressed deduplication [+ + +]
Author: Gao Xiang <xiang@kernel.org>
Date:   Thu Sep 7 13:05:42 2023 +0800

    erofs: fix memory leak of LZMA global compressed deduplication
    
    [ Upstream commit 75a5221630fe5aa3fedba7a06be618db0f79ba1e ]
    
    When stressing microLZMA EROFS images with the new global compressed
    deduplication feature enabled (`-Ededupe`), I found some short-lived
    temporary pages weren't properly released, which could slowly cause
    unexpected OOMs hours later.
    
    Let's fix it now (LZ4 and DEFLATE don't have this issue.)
    
    Fixes: 5c2a64252c5d ("erofs: introduce partial-referenced pclusters")
    Signed-off-by: Gao Xiang <hsiangkao@linux.alibaba.com>
    Link: https://lore.kernel.org/r/20230907050542.97152-1-hsiangkao@linux.alibaba.com
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
ethtool: plca: fix plca enable data type while parsing the value [+ + +]
Author: Parthiban Veerasooran <Parthiban.Veerasooran@microchip.com>
Date:   Fri Sep 8 10:15:48 2023 +0530

    ethtool: plca: fix plca enable data type while parsing the value
    
    [ Upstream commit 8957261cd8149ed9d0738c01c0320bcbff989407 ]
    
    The ETHTOOL_A_PLCA_ENABLED data type is u8. But while parsing the
    value from the attribute, nla_get_u32() is used in the plca_update_sint()
    function instead of nla_get_u8(). So plca_cfg.enabled variable is updated
    with some garbage value instead of 0 or 1 and always enables plca even
    though plca is disabled through ethtool application. This bug has been
    fixed by parsing the values based on the attributes type in the policy.
    
    Fixes: 8580e16c28f3 ("net/ethtool: add netlink interface for the PLCA RS")
    Signed-off-by: Parthiban Veerasooran <Parthiban.Veerasooran@microchip.com>
    Reviewed-by: Andrew Lunn <andrew@lunn.ch>
    Link: https://lore.kernel.org/r/20230908044548.5878-1-Parthiban.Veerasooran@microchip.com
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
gpio: aspeed: fix the GPIO number passed to pinctrl_gpio_set_config() [+ + +]
Author: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
Date:   Tue Oct 3 09:39:26 2023 +0200

    gpio: aspeed: fix the GPIO number passed to pinctrl_gpio_set_config()
    
    commit f9315f17bf778cb8079a29639419fcc8a41a3c84 upstream.
    
    pinctrl_gpio_set_config() expects the GPIO number from the global GPIO
    numberspace, not the controller-relative offset, which needs to be added
    to the chip base.
    
    Fixes: 5ae4cb94b313 ("gpio: aspeed: Add debounce support")
    Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
    Reviewed-by: Andy Shevchenko <andy@kernel.org>
    Reviewed-by: Andrew Jeffery <andrew@codeconstruct.com.au>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

gpio: pxa: disable pinctrl calls for MMP_GPIO [+ + +]
Author: Duje Mihanović <duje.mihanovic@skole.hr>
Date:   Fri Sep 29 17:41:57 2023 +0200

    gpio: pxa: disable pinctrl calls for MMP_GPIO
    
    commit f0575116507b981e6a810e78ce3c9040395b958b upstream.
    
    Similarly to PXA3xx and MMP2, pinctrl-single isn't capable of setting
    pin direction on MMP either.
    
    Fixes: a770d946371e ("gpio: pxa: add pin control gpio direction and request")
    Signed-off-by: Duje Mihanović <duje.mihanovic@skole.hr>
    Reviewed-by: Andy Shevchenko <andy@kernel.org>
    Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
HID: intel-ish-hid: ipc: Disable and reenable ACPI GPE bit [+ + +]
Author: Srinivas Pandruvada <srinivas.pandruvada@linux.intel.com>
Date:   Tue Oct 3 08:53:32 2023 -0700

    HID: intel-ish-hid: ipc: Disable and reenable ACPI GPE bit
    
    [ Upstream commit 8f02139ad9a7e6e5c05712f8c1501eebed8eacfd ]
    
    The EHL (Elkhart Lake) based platforms provide a OOB (Out of band)
    service, which allows to wakup device when the system is in S5 (Soft-Off
    state). This OOB service can be enabled/disabled from BIOS settings. When
    enabled, the ISH device gets PME wake capability. To enable PME wakeup,
    driver also needs to enable ACPI GPE bit.
    
    On resume, BIOS will clear the wakeup bit. So driver need to re-enable it
    in resume function to keep the next wakeup capability. But this BIOS
    clearing of wakeup bit doesn't decrement internal OS GPE reference count,
    so this reenabling on every resume will cause reference count to overflow.
    
    So first disable and reenable ACPI GPE bit using acpi_disable_gpe().
    
    Fixes: 2e23a70edabe ("HID: intel-ish-hid: ipc: finish power flow for EHL OOB")
    Reported-by: Kai-Heng Feng <kai.heng.feng@canonical.com>
    Closes: https://lore.kernel.org/lkml/CAAd53p4=oLYiH2YbVSmrPNj1zpMcfp=Wxbasb5vhMXOWCArLCg@mail.gmail.com/T/
    Tested-by: Kai-Heng Feng <kai.heng.feng@canonical.com>
    Signed-off-by: Srinivas Pandruvada <srinivas.pandruvada@linux.intel.com>
    Signed-off-by: Jiri Kosina <jkosina@suse.cz>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

HID: nvidia-shield: add LEDS_CLASS dependency [+ + +]
Author: Randy Dunlap <rdunlap@infradead.org>
Date:   Wed Sep 13 17:05:17 2023 -0700

    HID: nvidia-shield: add LEDS_CLASS dependency
    
    [ Upstream commit 058574879853260a22bbec1f94221dfc5149d85c ]
    
    The hid-nvidia-shield driver uses functions that are built
    only when LEDS_CLASS is set, so make the driver depend on that
    symbol to prevent build errors.
    
    riscv32-linux-ld: drivers/hid/hid-nvidia-shield.o: in function `.L11':
    hid-nvidia-shield.c:(.text+0x192): undefined reference to `led_classdev_unregister'
    riscv32-linux-ld: drivers/hid/hid-nvidia-shield.o: in function `.L113':
    hid-nvidia-shield.c:(.text+0xfa4): undefined reference to `led_classdev_register_ext'
    
    Fixes: 09308562d4af ("HID: nvidia-shield: Initial driver implementation with Thunderstrike support")
    Signed-off-by: Randy Dunlap <rdunlap@infradead.org>
    Cc: Rahul Rameshbabu <rrameshbabu@nvidia.com>
    Cc: Jiri Kosina <jkosina@suse.cz>
    Cc: Benjamin Tissoires <benjamin.tissoires@redhat.com>
    Cc: linux-input@vger.kernel.org
    Reviewed-by: Rahul Rameshbabu <rrameshbabu@nvidia.com>
    Signed-off-by: Jiri Kosina <jkosina@suse.cz>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

HID: nvidia-shield: Fix a missing led_classdev_unregister() in the probe error handling path [+ + +]
Author: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
Date:   Mon Sep 18 04:54:30 2023 -0700

    HID: nvidia-shield: Fix a missing led_classdev_unregister() in the probe error handling path
    
    [ Upstream commit b07b6b27a50e3a740c9aa6260ee4bb3ab29515ab ]
    
    The commit in Fixes updated the error handling path of
    thunderstrike_create() and the remove function but not the error handling
    path of shield_probe(), should an error occur after a successful
    thunderstrike_create() call.
    
    Add the missing call. Make sure it is safe to call in the probe error
    handling path by preventing the led_classdev from attempting to set the LED
    brightness to the off state on unregister.
    
    Fixes: f88af60e74a5 ("HID: nvidia-shield: Support LED functionality for Thunderstrike")
    Signed-off-by: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
    Reviewed-by: Rahul Rameshbabu <rrameshbabu@nvidia.com>
    Signed-off-by: Jiri Kosina <jkosina@suse.cz>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

HID: sony: Fix a potential memory leak in sony_probe() [+ + +]
Author: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
Date:   Sun Sep 3 18:04:00 2023 +0200

    HID: sony: Fix a potential memory leak in sony_probe()
    
    [ Upstream commit e1cd4004cde7c9b694bbdd8def0e02288ee58c74 ]
    
    If an error occurs after a successful usb_alloc_urb() call, usb_free_urb()
    should be called.
    
    Fixes: fb1a79a6b6e1 ("HID: sony: fix freeze when inserting ghlive ps3/wii dongles")
    Signed-off-by: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
    Signed-off-by: Jiri Kosina <jkosina@suse.cz>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

HID: sony: remove duplicate NULL check before calling usb_free_urb() [+ + +]
Author: Jiri Kosina <jkosina@suse.cz>
Date:   Wed Oct 4 21:10:41 2023 +0200

    HID: sony: remove duplicate NULL check before calling usb_free_urb()
    
    [ Upstream commit b328dd02e19cb9d3b35de4322f5363516a20ac8c ]
    
    usb_free_urb() does the NULL check itself, so there is no need to duplicate
    it prior to calling.
    
    Reported-by: kernel test robot <lkp@intel.com>
    Fixes: e1cd4004cde7c9 ("HID: sony: Fix a potential memory leak in sony_probe()")
    Signed-off-by: Jiri Kosina <jkosina@suse.cz>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
IB/mlx4: Fix the size of a buffer in add_port_entries() [+ + +]
Author: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
Date:   Sat Sep 23 07:55:56 2023 +0200

    IB/mlx4: Fix the size of a buffer in add_port_entries()
    
    commit d7f393430a17c2bfcdf805462a5aa80be4285b27 upstream.
    
    In order to be sure that 'buff' is never truncated, its size should be
    12, not 11.
    
    When building with W=1, this fixes the following warnings:
    
      drivers/infiniband/hw/mlx4/sysfs.c: In function ‘add_port_entries’:
      drivers/infiniband/hw/mlx4/sysfs.c:268:34: error: ‘sprintf’ may write a terminating nul past the end of the destination [-Werror=format-overflow=]
        268 |                 sprintf(buff, "%d", i);
            |                                  ^
      drivers/infiniband/hw/mlx4/sysfs.c:268:17: note: ‘sprintf’ output between 2 and 12 bytes into a destination of size 11
        268 |                 sprintf(buff, "%d", i);
            |                 ^~~~~~~~~~~~~~~~~~~~~~
      drivers/infiniband/hw/mlx4/sysfs.c:286:34: error: ‘sprintf’ may write a terminating nul past the end of the destination [-Werror=format-overflow=]
        286 |                 sprintf(buff, "%d", i);
            |                                  ^
      drivers/infiniband/hw/mlx4/sysfs.c:286:17: note: ‘sprintf’ output between 2 and 12 bytes into a destination of size 11
        286 |                 sprintf(buff, "%d", i);
            |                 ^~~~~~~~~~~~~~~~~~~~~~
    
    Fixes: c1e7e466120b ("IB/mlx4: Add iov directory in sysfs under the ib device")
    Signed-off-by: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
    Link: https://lore.kernel.org/r/0bb1443eb47308bc9be30232cc23004c4d4cf43e.1695448530.git.christophe.jaillet@wanadoo.fr
    Signed-off-by: Leon Romanovsky <leon@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
ibmveth: Remove condition to recompute TCP header checksum. [+ + +]
Author: David Wilder <dwilder@us.ibm.com>
Date:   Tue Sep 26 16:42:51 2023 -0500

    ibmveth: Remove condition to recompute TCP header checksum.
    
    [ Upstream commit 51e7a66666e0ca9642c59464ef8359f0ac604d41 ]
    
    In some OVS environments the TCP pseudo header checksum may need to be
    recomputed. Currently this is only done when the interface instance is
    configured for "Trunk Mode". We found the issue also occurs in some
    Kubernetes environments, these environments do not use "Trunk Mode",
    therefor the condition is removed.
    
    Performance tests with this change show only a fractional decrease in
    throughput (< 0.2%).
    
    Fixes: 7525de2516fb ("ibmveth: Set CHECKSUM_PARTIAL if NULL TCP CSUM.")
    Signed-off-by: David Wilder <dwilder@us.ibm.com>
    Reviewed-by: Nick Child <nnac123@linux.ibm.com>
    Reviewed-by: Jacob Keller <jacob.e.keller@intel.com>
    Signed-off-by: David S. Miller <davem@davemloft.net>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
ice: always add legacy 32byte RXDID in supported_rxdids [+ + +]
Author: Michal Schmidt <mschmidt@redhat.com>
Date:   Wed Sep 20 13:54:38 2023 +0200

    ice: always add legacy 32byte RXDID in supported_rxdids
    
    [ Upstream commit c070e51db5e2a98d3aef7c324b15209ba47f3dca ]
    
    When the PF and VF drivers both support flexible rx descriptors and have
    negotiated the VIRTCHNL_VF_OFFLOAD_RX_FLEX_DESC capability, the VF driver
    queries the PF for the list of supported descriptor formats
    (VIRTCHNL_OP_GET_SUPPORTED_RXDIDS). The PF driver is supposed to set the
    supported_rxdids bits that correspond to the descriptor formats the
    firmware implements. The legacy 32-byte rx desc format is always
    supported, even though it is not expressed in GLFLXP_RXDID_FLAGS.
    
    The ice driver does not advertise the legacy 32-byte rx desc support,
    which leads to this failure to bring up the VF using the Intel
    out-of-tree iavf driver:
     iavf 0000:41:01.0: PF does not list support for default Rx descriptor format
     ...
     iavf 0000:41:01.0: PF returned error -5 (VIRTCHNL_STATUS_ERR_PARAM) to our request 6
    
    The in-tree iavf driver does not expose this bug, because it does not
    yet implement VIRTCHNL_VF_OFFLOAD_RX_FLEX_DESC.
    
    The ice driver must always set the ICE_RXDID_LEGACY_1 bit in
    supported_rxdids. The Intel out-of-tree ice driver and the ice driver in
    DPDK both do this.
    
    I copied this piece of the code and the comment text from the Intel
    out-of-tree driver.
    
    Fixes: e753df8fbca5 ("ice: Add support Flex RXD")
    Signed-off-by: Michal Schmidt <mschmidt@redhat.com>
    Reviewed-by: Przemek Kitszel <przemyslaw.kitszel@intel.com>
    Link: https://lore.kernel.org/r/20230920115439.61172-1-mschmidt@redhat.com
    Signed-off-by: Paolo Abeni <pabeni@redhat.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
ima: Finish deprecation of IMA_TRUSTED_KEYRING Kconfig [+ + +]
Author: Oleksandr Tymoshenko <ovt@google.com>
Date:   Thu Sep 21 06:45:05 2023 +0000

    ima: Finish deprecation of IMA_TRUSTED_KEYRING Kconfig
    
    [ Upstream commit be210c6d3597faf330cb9af33b9f1591d7b2a983 ]
    
    The removal of IMA_TRUSTED_KEYRING made IMA_LOAD_X509
    and IMA_BLACKLIST_KEYRING unavailable because the latter
    two depend on the former. Since IMA_TRUSTED_KEYRING was
    deprecated in favor of INTEGRITY_TRUSTED_KEYRING use it
    as a dependency for the two Kconfigs affected by the
    deprecation.
    
    Fixes: 5087fd9e80e5 ("ima: Remove deprecated IMA_TRUSTED_KEYRING Kconfig")
    Signed-off-by: Oleksandr Tymoshenko <ovt@google.com>
    Reviewed-by: Nayna Jain <nayna@linux.ibm.com>
    Signed-off-by: Mimi Zohar <zohar@linux.ibm.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

ima: rework CONFIG_IMA dependency block [+ + +]
Author: Arnd Bergmann <arnd@arndb.de>
Date:   Wed Sep 27 09:22:14 2023 +0200

    ima: rework CONFIG_IMA dependency block
    
    [ Upstream commit 91e326563ee34509c35267808a4b1b3ea3db62a8 ]
    
    Changing the direct dependencies of IMA_BLACKLIST_KEYRING and
    IMA_LOAD_X509 caused them to no longer depend on IMA, but a
    a configuration without IMA results in link failures:
    
    arm-linux-gnueabi-ld: security/integrity/iint.o: in function `integrity_load_keys':
    iint.c:(.init.text+0xd8): undefined reference to `ima_load_x509'
    
    aarch64-linux-ld: security/integrity/digsig_asymmetric.o: in function `asymmetric_verify':
    digsig_asymmetric.c:(.text+0x104): undefined reference to `ima_blacklist_keyring'
    
    Adding explicit dependencies on IMA would fix this, but a more reliable
    way to do this is to enclose the entire Kconfig file in an 'if IMA' block.
    This also allows removing the existing direct dependencies.
    
    Fixes: be210c6d3597f ("ima: Finish deprecation of IMA_TRUSTED_KEYRING Kconfig")
    Signed-off-by: Arnd Bergmann <arnd@arndb.de>
    Signed-off-by: Mimi Zohar <zohar@linux.ibm.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
io_uring/kbuf: don't allow registered buffer rings on highmem pages [+ + +]
Author: Jens Axboe <axboe@kernel.dk>
Date:   Mon Oct 2 18:14:08 2023 -0600

    io_uring/kbuf: don't allow registered buffer rings on highmem pages
    
    commit f8024f1f36a30a082b0457d5779c8847cea57f57 upstream.
    
    syzbot reports that registering a mapped buffer ring on arm32 can
    trigger an OOPS. Registered buffer rings have two modes, one of them
    is the application passing in the memory that the buffer ring should
    reside in. Once those pages are mapped, we use page_address() to get
    a virtual address. This will obviously fail on highmem pages, which
    aren't mapped.
    
    Add a check if we have any highmem pages after mapping, and fail the
    attempt to register a provided buffer ring if we do. This will return
    the same error as kernels that don't support provided buffer rings to
    begin with.
    
    Link: https://lore.kernel.org/io-uring/000000000000af635c0606bcb889@google.com/
    Fixes: c56e022c0a27 ("io_uring: add support for user mapped provided buffer ring")
    Cc: stable@vger.kernel.org
    Reported-by: syzbot+2113e61b8848fa7951d8@syzkaller.appspotmail.com
    Signed-off-by: Jens Axboe <axboe@kernel.dk>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
io_uring: don't allow IORING_SETUP_NO_MMAP rings on highmem pages [+ + +]
Author: Jens Axboe <axboe@kernel.dk>
Date:   Tue Oct 3 09:59:58 2023 -0600

    io_uring: don't allow IORING_SETUP_NO_MMAP rings on highmem pages
    
    commit 223ef474316466e9f61f6e0064f3a6fe4923a2c5 upstream.
    
    On at least arm32, but presumably any arch with highmem, if the
    application passes in memory that resides in highmem for the rings,
    then we should fail that ring creation. We fail it with -EINVAL, which
    is what kernels that don't support IORING_SETUP_NO_MMAP will do as well.
    
    Cc: stable@vger.kernel.org
    Fixes: 03d89a2de25b ("io_uring: support for user allocated memory for rings/sqes")
    Signed-off-by: Jens Axboe <axboe@kernel.dk>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

io_uring: ensure io_lockdep_assert_cq_locked() handles disabled rings [+ + +]
Author: Jens Axboe <axboe@kernel.dk>
Date:   Mon Oct 2 19:51:38 2023 -0600

    io_uring: ensure io_lockdep_assert_cq_locked() handles disabled rings
    
    commit 1658633c04653578429ff5dfc62fdc159203a8f2 upstream.
    
    io_lockdep_assert_cq_locked() checks that locking is correctly done when
    a CQE is posted. If the ring is setup in a disabled state with
    IORING_SETUP_R_DISABLED, then ctx->submitter_task isn't assigned until
    the ring is later enabled. We generally don't post CQEs in this state,
    as no SQEs can be submitted. However it is possible to generate a CQE
    if tagged resources are being updated. If this happens and PROVE_LOCKING
    is enabled, then the locking check helper will dereference
    ctx->submitter_task, which hasn't been set yet.
    
    Fixup io_lockdep_assert_cq_locked() to handle this case correctly. While
    at it, convert it to a static inline as well, so that generated line
    offsets will actually reflect which condition failed, rather than just
    the line offset for io_lockdep_assert_cq_locked() itself.
    
    Reported-and-tested-by: syzbot+efc45d4e7ba6ab4ef1eb@syzkaller.appspotmail.com
    Fixes: f26cc9593581 ("io_uring: lockdep annotate CQ locking")
    Cc: stable@vger.kernel.org
    Signed-off-by: Jens Axboe <axboe@kernel.dk>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
iommu/apple-dart: Handle DMA_FQ domains in attach_dev() [+ + +]
Author: Hector Martin <marcan@marcan.st>
Date:   Fri Sep 22 23:55:23 2023 +0900

    iommu/apple-dart: Handle DMA_FQ domains in attach_dev()
    
    commit c7bd8a1f45bada7725d11266df7fd5cb549b3098 upstream.
    
    Commit a4fdd9762272 ("iommu: Use flush queue capability") hid the
    IOMMU_DOMAIN_DMA_FQ domain type from domain allocation. A check was
    introduced in iommu_dma_init_domain() to fall back if not supported, but
    this check runs too late: by that point, devices have been attached to
    the IOMMU, and apple-dart's attach_dev() callback does not expect
    IOMMU_DOMAIN_DMA_FQ domains.
    
    Change the logic so the IOMMU_DOMAIN_DMA codepath is the default,
    instead of explicitly enumerating all types.
    
    Fixes an apple-dart regression in v6.5.
    
    Cc: regressions@lists.linux.dev
    Cc: stable@vger.kernel.org
    Suggested-by: Robin Murphy <robin.murphy@arm.com>
    Fixes: a4fdd9762272 ("iommu: Use flush queue capability")
    Signed-off-by: Hector Martin <marcan@marcan.st>
    Reviewed-by: Neal Gompa <neal@gompa.dev>
    Reviewed-by: Jason Gunthorpe <jgg@nvidia.com>
    Link: https://lore.kernel.org/r/20230922-iommu-type-regression-v2-1-689b2ba9b673@marcan.st
    Signed-off-by: Joerg Roedel <jroedel@suse.de>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
iommu/arm-smmu-v3: Avoid constructing invalid range commands [+ + +]
Author: Robin Murphy <robin.murphy@arm.com>
Date:   Mon Sep 11 12:57:04 2023 +0100

    iommu/arm-smmu-v3: Avoid constructing invalid range commands
    
    [ Upstream commit eb6c97647be227822c7ce23655482b05e348fba5 ]
    
    Although io-pgtable's non-leaf invalidations are always for full tables,
    I missed that SVA also uses non-leaf invalidations, while being at the
    mercy of whatever range the MMU notifier throws at it. This means it
    definitely wants the previous TTL fix as well, since it also doesn't
    know exactly which leaf level(s) may need invalidating, but it can also
    give us less-aligned ranges wherein certain corners may lead to building
    an invalid command where TTL, Num and Scale are all 0. It should be fine
    to handle this by over-invalidating an extra page, since falling back to
    a non-range command opens up a whole can of errata-flavoured worms.
    
    Fixes: 6833b8f2e199 ("iommu/arm-smmu-v3: Set TTL invalidation hint better")
    Reported-by: Rui Zhu <zhurui3@huawei.com>
    Signed-off-by: Robin Murphy <robin.murphy@arm.com>
    Link: https://lore.kernel.org/r/b99cfe71af2bd93a8a2930f20967fb2a4f7748dd.1694432734.git.robin.murphy@arm.com
    Signed-off-by: Will Deacon <will@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
iommu/mediatek: Fix share pgtable for iova over 4GB [+ + +]
Author: Yong Wu <yong.wu@mediatek.com>
Date:   Sat Aug 19 16:14:43 2023 +0800

    iommu/mediatek: Fix share pgtable for iova over 4GB
    
    [ Upstream commit b07eba71a512eb196cbcc29765c29c8c29b11b59 ]
    
    In mt8192/mt8186, there is only one MM IOMMU that supports 16GB iova
    space, which is shared by display, vcodec and camera. These two SoC use
    one pgtable and have not the flag SHARE_PGTABLE, we should also keep
    share pgtable for this case.
    
    In mtk_iommu_domain_finalise, MM IOMMU always share pgtable, thus remove
    the flag SHARE_PGTABLE checking. Infra IOMMU always uses independent
    pgtable.
    
    Fixes: cf69ef46dbd9 ("iommu/mediatek: Fix two IOMMU share pagetable issue")
    Reported-by: Laura Nao <laura.nao@collabora.com>
    Closes: https://lore.kernel.org/linux-iommu/20230818154156.314742-1-laura.nao@collabora.com/
    Signed-off-by: Yong Wu <yong.wu@mediatek.com>
    Reviewed-by: AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
    Tested-by: Laura Nao <laura.nao@collabora.com>
    Link: https://lore.kernel.org/r/20230819081443.8333-1-yong.wu@mediatek.com
    Signed-off-by: Joerg Roedel <jroedel@suse.de>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
iommu/vt-d: Avoid memory allocation in iommu_suspend() [+ + +]
Author: Zhang Rui <rui.zhang@intel.com>
Date:   Mon Sep 25 20:04:17 2023 +0800

    iommu/vt-d: Avoid memory allocation in iommu_suspend()
    
    commit 59df44bfb0ca4c3ee1f1c3c5d0ee8e314844799e upstream.
    
    The iommu_suspend() syscore suspend callback is invoked with IRQ disabled.
    Allocating memory with the GFP_KERNEL flag may re-enable IRQs during
    the suspend callback, which can cause intermittent suspend/hibernation
    problems with the following kernel traces:
    
    Calling iommu_suspend+0x0/0x1d0
    ------------[ cut here ]------------
    WARNING: CPU: 0 PID: 15 at kernel/time/timekeeping.c:868 ktime_get+0x9b/0xb0
    ...
    CPU: 0 PID: 15 Comm: rcu_preempt Tainted: G     U      E      6.3-intel #r1
    RIP: 0010:ktime_get+0x9b/0xb0
    ...
    Call Trace:
     <IRQ>
     tick_sched_timer+0x22/0x90
     ? __pfx_tick_sched_timer+0x10/0x10
     __hrtimer_run_queues+0x111/0x2b0
     hrtimer_interrupt+0xfa/0x230
     __sysvec_apic_timer_interrupt+0x63/0x140
     sysvec_apic_timer_interrupt+0x7b/0xa0
     </IRQ>
     <TASK>
     asm_sysvec_apic_timer_interrupt+0x1f/0x30
    ...
    ------------[ cut here ]------------
    Interrupts enabled after iommu_suspend+0x0/0x1d0
    WARNING: CPU: 0 PID: 27420 at drivers/base/syscore.c:68 syscore_suspend+0x147/0x270
    CPU: 0 PID: 27420 Comm: rtcwake Tainted: G     U  W   E      6.3-intel #r1
    RIP: 0010:syscore_suspend+0x147/0x270
    ...
    Call Trace:
     <TASK>
     hibernation_snapshot+0x25b/0x670
     hibernate+0xcd/0x390
     state_store+0xcf/0xe0
     kobj_attr_store+0x13/0x30
     sysfs_kf_write+0x3f/0x50
     kernfs_fop_write_iter+0x128/0x200
     vfs_write+0x1fd/0x3c0
     ksys_write+0x6f/0xf0
     __x64_sys_write+0x1d/0x30
     do_syscall_64+0x3b/0x90
     entry_SYSCALL_64_after_hwframe+0x72/0xdc
    
    Given that only 4 words memory is needed, avoid the memory allocation in
    iommu_suspend().
    
    CC: stable@kernel.org
    Fixes: 33e07157105e ("iommu/vt-d: Avoid GFP_ATOMIC where it is not needed")
    Signed-off-by: Zhang Rui <rui.zhang@intel.com>
    Tested-by: Ooi, Chin Hao <chin.hao.ooi@intel.com>
    Link: https://lore.kernel.org/r/20230921093956.234692-1-rui.zhang@intel.com
    Signed-off-by: Lu Baolu <baolu.lu@linux.intel.com>
    Link: https://lore.kernel.org/r/20230925120417.55977-2-baolu.lu@linux.intel.com
    Signed-off-by: Joerg Roedel <jroedel@suse.de>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
ipv4, ipv6: Fix handling of transhdrlen in __ip{,6}_append_data() [+ + +]
Author: David Howells <dhowells@redhat.com>
Date:   Thu Sep 21 11:41:19 2023 +0100

    ipv4, ipv6: Fix handling of transhdrlen in __ip{,6}_append_data()
    
    [ Upstream commit 9d4c75800f61e5d75c1659ba201b6c0c7ead3070 ]
    
    Including the transhdrlen in length is a problem when the packet is
    partially filled (e.g. something like send(MSG_MORE) happened previously)
    when appending to an IPv4 or IPv6 packet as we don't want to repeat the
    transport header or account for it twice.  This can happen under some
    circumstances, such as splicing into an L2TP socket.
    
    The symptom observed is a warning in __ip6_append_data():
    
        WARNING: CPU: 1 PID: 5042 at net/ipv6/ip6_output.c:1800 __ip6_append_data.isra.0+0x1be8/0x47f0 net/ipv6/ip6_output.c:1800
    
    that occurs when MSG_SPLICE_PAGES is used to append more data to an already
    partially occupied skbuff.  The warning occurs when 'copy' is larger than
    the amount of data in the message iterator.  This is because the requested
    length includes the transport header length when it shouldn't.  This can be
    triggered by, for example:
    
            sfd = socket(AF_INET6, SOCK_DGRAM, IPPROTO_L2TP);
            bind(sfd, ...); // ::1
            connect(sfd, ...); // ::1 port 7
            send(sfd, buffer, 4100, MSG_MORE);
            sendfile(sfd, dfd, NULL, 1024);
    
    Fix this by only adding transhdrlen into the length if the write queue is
    empty in l2tp_ip6_sendmsg(), analogously to how UDP does things.
    
    l2tp_ip_sendmsg() looks like it won't suffer from this problem as it builds
    the UDP packet itself.
    
    Fixes: a32e0eec7042 ("l2tp: introduce L2TPv3 IP encapsulation support for IPv6")
    Reported-by: syzbot+62cbf263225ae13ff153@syzkaller.appspotmail.com
    Link: https://lore.kernel.org/r/0000000000001c12b30605378ce8@google.com/
    Suggested-by: Willem de Bruijn <willemdebruijn.kernel@gmail.com>
    Signed-off-by: David Howells <dhowells@redhat.com>
    cc: Eric Dumazet <edumazet@google.com>
    cc: Willem de Bruijn <willemdebruijn.kernel@gmail.com>
    cc: "David S. Miller" <davem@davemloft.net>
    cc: David Ahern <dsahern@kernel.org>
    cc: Paolo Abeni <pabeni@redhat.com>
    cc: Jakub Kicinski <kuba@kernel.org>
    cc: netdev@vger.kernel.org
    cc: bpf@vger.kernel.org
    cc: syzkaller-bugs@googlegroups.com
    Reviewed-by: Eric Dumazet <edumazet@google.com>
    Signed-off-by: David S. Miller <davem@davemloft.net>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
ipv4: Set offload_failed flag in fibmatch results [+ + +]
Author: Benjamin Poirier <bpoirier@nvidia.com>
Date:   Tue Sep 26 14:27:30 2023 -0400

    ipv4: Set offload_failed flag in fibmatch results
    
    [ Upstream commit 0add5c597f3253a9c6108a0a81d57f44ab0d9d30 ]
    
    Due to a small omission, the offload_failed flag is missing from ipv4
    fibmatch results. Make sure it is set correctly.
    
    The issue can be witnessed using the following commands:
    echo "1 1" > /sys/bus/netdevsim/new_device
    ip link add dummy1 up type dummy
    ip route add 192.0.2.0/24 dev dummy1
    echo 1 > /sys/kernel/debug/netdevsim/netdevsim1/fib/fail_route_offload
    ip route add 198.51.100.0/24 dev dummy1
    ip route
            # 192.168.15.0/24 has rt_trap
            # 198.51.100.0/24 has rt_offload_failed
    ip route get 192.168.15.1 fibmatch
            # Result has rt_trap
    ip route get 198.51.100.1 fibmatch
            # Result differs from the route shown by `ip route`, it is missing
            # rt_offload_failed
    ip link del dev dummy1
    echo 1 > /sys/bus/netdevsim/del_device
    
    Fixes: 36c5100e859d ("IPv4: Add "offload failed" indication to routes")
    Signed-off-by: Benjamin Poirier <bpoirier@nvidia.com>
    Reviewed-by: Ido Schimmel <idosch@nvidia.com>
    Reviewed-by: Simon Horman <horms@kernel.org>
    Reviewed-by: David Ahern <dsahern@kernel.org>
    Link: https://lore.kernel.org/r/20230926182730.231208-1-bpoirier@nvidia.com
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
ipv6: tcp: add a missing nf_reset_ct() in 3WHS handling [+ + +]
Author: Ilya Maximets <i.maximets@ovn.org>
Date:   Fri Sep 22 23:04:58 2023 +0200

    ipv6: tcp: add a missing nf_reset_ct() in 3WHS handling
    
    [ Upstream commit 9593c7cb6cf670ef724d17f7f9affd7a8d2ad0c5 ]
    
    Commit b0e214d21203 ("netfilter: keep conntrack reference until
    IPsecv6 policy checks are done") is a direct copy of the old
    commit b59c270104f0 ("[NETFILTER]: Keep conntrack reference until
    IPsec policy checks are done") but for IPv6.  However, it also
    copies a bug that this old commit had.  That is: when the third
    packet of 3WHS connection establishment contains payload, it is
    added into socket receive queue without the XFRM check and the
    drop of connection tracking context.
    
    That leads to nf_conntrack module being impossible to unload as
    it waits for all the conntrack references to be dropped while
    the packet release is deferred in per-cpu cache indefinitely, if
    not consumed by the application.
    
    The issue for IPv4 was fixed in commit 6f0012e35160 ("tcp: add a
    missing nf_reset_ct() in 3WHS handling") by adding a missing XFRM
    check and correctly dropping the conntrack context.  However, the
    issue was introduced to IPv6 code afterwards.  Fixing it the
    same way for IPv6 now.
    
    Fixes: b0e214d21203 ("netfilter: keep conntrack reference until IPsecv6 policy checks are done")
    Link: https://lore.kernel.org/netdev/d589a999-d4dd-2768-b2d5-89dec64a4a42@ovn.org/
    Signed-off-by: Ilya Maximets <i.maximets@ovn.org>
    Acked-by: Florian Westphal <fw@strlen.de>
    Reviewed-by: Eric Dumazet <edumazet@google.com>
    Link: https://lore.kernel.org/r/20230922210530.2045146-1-i.maximets@ovn.org
    Signed-off-by: Paolo Abeni <pabeni@redhat.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
iwlwifi: mvm: handle PS changes in vif_cfg_changed [+ + +]
Author: Gregory Greenman <gregory.greenman@intel.com>
Date:   Tue Sep 5 16:29:57 2023 +0300

    iwlwifi: mvm: handle PS changes in vif_cfg_changed
    
    [ Upstream commit 2d4caa1dbe915654d0e8845758d9c96e721377a8 ]
    
    Handling of BSS_CHANGED_PS was missing in vif_cfg_changed
    callback. Fix it.
    
    Fixes: 22c588343529 ("wifi: iwlwifi: mvm: replace bss_info_changed() with vif_cfg/link_info_changed()")
    Reported-by: Sultan Alsawaf <sultan@kerneltoast.com>
    Signed-off-by: Gregory Greenman <gregory.greenman@intel.com>
    Link: https://lore.kernel.org/r/20230905162939.5ef0c8230de6.Ieed265014988c50ec68fbff6d33821e4215f987f@changeid
    [note: patch looks bigger than it is due to reindentation]
    Signed-off-by: Johannes Berg <johannes.berg@intel.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
ksmbd: fix race condition between session lookup and expire [+ + +]
Author: Namjae Jeon <linkinjeon@kernel.org>
Date:   Wed Oct 4 18:25:01 2023 +0900

    ksmbd: fix race condition between session lookup and expire
    
    commit 53ff5cf89142b978b1a5ca8dc4d4425e6a09745f upstream.
    
     Thread A                        +  Thread B
     ksmbd_session_lookup            |  smb2_sess_setup
       sess = xa_load                |
                                     |
                                     |    xa_erase(&conn->sessions, sess->id);
                                     |
                                     |    ksmbd_session_destroy(sess) --> kfree(sess)
                                     |
       // UAF!                       |
       sess->last_active = jiffies   |
                                     +
    
    This patch add rwsem to fix race condition between ksmbd_session_lookup
    and ksmbd_expire_session.
    
    Reported-by: luosili <rootlab@huawei.com>
    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>

ksmbd: fix race condition from parallel smb2 lock requests [+ + +]
Author: Namjae Jeon <linkinjeon@kernel.org>
Date:   Wed Oct 4 18:31:03 2023 +0900

    ksmbd: fix race condition from parallel smb2 lock requests
    
    commit 75ac9a3dd65f7eab4d12b0a0f744234b5300a491 upstream.
    
    There is a race condition issue between parallel smb2 lock request.
    
                                                Time
                                                 +
    Thread A                                     | Thread A
    smb2_lock                                    | smb2_lock
                                                 |
     insert smb_lock to lock_list                |
     spin_unlock(&work->conn->llist_lock)        |
                                                 |
                                                 |   spin_lock(&conn->llist_lock);
                                                 |   kfree(cmp_lock);
                                                 |
     // UAF!                                     |
     list_add(&smb_lock->llist, &rollback_list)  +
    
    This patch swaps the line for adding the smb lock to the rollback list and
    adding the lock list of connection to fix the race issue.
    
    Reported-by: luosili <rootlab@huawei.com>
    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>

ksmbd: fix uaf in smb20_oplock_break_ack [+ + +]
Author: luosili <rootlab@huawei.com>
Date:   Wed Oct 4 18:29:36 2023 +0900

    ksmbd: fix uaf in smb20_oplock_break_ack
    
    commit c69813471a1ec081a0b9bf0c6bd7e8afd818afce upstream.
    
    drop reference after use opinfo.
    
    Signed-off-by: luosili <rootlab@huawei.com>
    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>

 
leds: Drop BUG_ON check for LED_COLOR_ID_MULTI [+ + +]
Author: Marek Behún <kabel@kernel.org>
Date:   Mon Sep 18 16:07:24 2023 +0200

    leds: Drop BUG_ON check for LED_COLOR_ID_MULTI
    
    [ Upstream commit 9dc1664fab2246bc2c3e9bf2cf21518a857f9b5b ]
    
    Commit c3f853184bed ("leds: Fix BUG_ON check for LED_COLOR_ID_MULTI that
    is always false") fixed a no-op BUG_ON. This turned out to cause a
    regression, since some in-tree device-tree files already use
    LED_COLOR_ID_MULTI.
    
    Drop the BUG_ON altogether.
    
    Fixes: c3f853184bed ("leds: Fix BUG_ON check for LED_COLOR_ID_MULTI that is always false")
    Reported-by: Da Xue <da@libre.computer>
    Closes: https://lore.kernel.org/linux-leds/ZQLelWcNjjp2xndY@duo.ucw.cz/T/
    Signed-off-by: Marek Behún <kabel@kernel.org>
    Link: https://lore.kernel.org/r/20230918140724.18634-1-kabel@kernel.org
    Signed-off-by: Lee Jones <lee@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
Linux: Linux 6.5.7 [+ + +]
Author: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Date:   Tue Oct 10 22:03:06 2023 +0200

    Linux 6.5.7
    
    Link: https://lore.kernel.org/r/20231009130124.021290599@linuxfoundation.org
    Tested-by: Ronald Warsow <rwarsow@gmx.de>
    Tested-by: SeongJae Park <sj@kernel.org>
    Tested-by: Shuah Khan <skhan@linuxfoundation.org>
    Tested-by: Florian Fainelli <florian.fainelli@broadcom.com>
    Tested-by: Bagas Sanjaya <bagasdotme@gmail.com>
    Tested-by: Ron Economos <re@w6rz.net>
    Tested-by: Jon Hunter <jonathanh@nvidia.com>
    Tested-by: Linux Kernel Functional Testing <lkft@linaro.org>
    Tested-by: Allen Pais <apais@linux.microsoft.com>
    Tested-by: Guenter Roeck <linux@roeck-us.net>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
maple_tree: add mas_is_active() to detect in-tree walks [+ + +]
Author: Liam R. Howlett <Liam.Howlett@oracle.com>
Date:   Thu Sep 21 14:12:35 2023 -0400

    maple_tree: add mas_is_active() to detect in-tree walks
    
    [ Upstream commit 5c590804b6b0ff933ed4e5cee5d76de3a5048d9f ]
    
    Patch series "maple_tree: Fix mas_prev() state regression".
    
    Pedro Falcato retported an mprotect regression [1] which was bisected back
    to the iterator changes for maple tree.  Root cause analysis showed the
    mas_prev() running off the end of the VMA space (previous from 0) followed
    by mas_find(), would skip the first value.
    
    This patchset introduces maple state underflow/overflow so the sequence of
    calls on the maple state will return what the user expects.
    
    Users who encounter this bug may see mprotect(), userfaultfd_register(),
    and mlock() fail on VMAs mapped with address 0.
    
    This patch (of 2):
    
    Instead of constantly checking each possibility of the maple state,
    create a fast path that will skip over checking unlikely states.
    
    Link: https://lkml.kernel.org/r/20230921181236.509072-1-Liam.Howlett@oracle.com
    Link: https://lkml.kernel.org/r/20230921181236.509072-2-Liam.Howlett@oracle.com
    Signed-off-by: Liam R. Howlett <Liam.Howlett@oracle.com>
    Cc: Pedro Falcato <pedro.falcato@gmail.com>
    Cc: <stable@vger.kernel.org>
    Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

maple_tree: add MAS_UNDERFLOW and MAS_OVERFLOW states [+ + +]
Author: Liam R. Howlett <Liam.Howlett@oracle.com>
Date:   Thu Sep 21 14:12:36 2023 -0400

    maple_tree: add MAS_UNDERFLOW and MAS_OVERFLOW states
    
    commit a8091f039c1ebf5cb0d5261e3613f18eb2a5d8b7 upstream.
    
    When updating the maple tree iterator to avoid rewalks, an issue was
    introduced when shifting beyond the limits.  This can be seen by trying to
    go to the previous address of 0, which would set the maple node to
    MAS_NONE and keep the range as the last entry.
    
    Subsequent calls to mas_find() would then search upwards from mas->last
    and skip the value at mas->index/mas->last.  This showed up as a bug in
    mprotect which skips the actual VMA at the current range after attempting
    to go to the previous VMA from 0.
    
    Since MAS_NONE may already be set when searching for a value that isn't
    contained within a node, changing the handling of MAS_NONE in mas_find()
    would make the code more complicated and error prone.  Furthermore, there
    was no way to tell which limit was hit, and thus which action to take
    (next or the entry at the current range).
    
    This solution is to add two states to track what happened with the
    previous iterator action.  This allows for the expected behaviour of the
    next command to return the correct item (either the item at the range
    requested, or the next/previous).
    
    Tests are also added and updated accordingly.
    
    Link: https://lkml.kernel.org/r/20230921181236.509072-3-Liam.Howlett@oracle.com
    Link: https://gist.github.com/heatd/85d2971fae1501b55b6ea401fbbe485b
    Link: https://lore.kernel.org/linux-mm/20230921181236.509072-1-Liam.Howlett@oracle.com/
    Fixes: 39193685d585 ("maple_tree: try harder to keep active node with mas_prev()")
    Signed-off-by: Liam R. Howlett <Liam.Howlett@oracle.com>
    Reported-by: Pedro Falcato <pedro.falcato@gmail.com>
    Closes: https://gist.github.com/heatd/85d2971fae1501b55b6ea401fbbe485b
    Closes: https://bugs.archlinux.org/task/79656
    Cc: <stable@vger.kernel.org>
    Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

maple_tree: reduce resets during store setup [+ + +]
Author: Liam R. Howlett <Liam.Howlett@oracle.com>
Date:   Mon Jul 24 14:31:56 2023 -0400

    maple_tree: reduce resets during store setup
    
    commit fec29364348fec535c55708b1f4025b321aba572 upstream.
    
    mas_prealloc() may walk partially down the tree before finding that a
    split or spanning store is needed.  When the write occurs, relax the
    logic on resetting the walk so that partial walks will not restart, but
    walks that have gone too far (a store that affects beyond the current
    node) should be restarted.
    
    Link: https://lkml.kernel.org/r/20230724183157.3939892-15-Liam.Howlett@oracle.com
    Signed-off-by: Liam R. Howlett <Liam.Howlett@oracle.com>
    Cc: Peng Zhang <zhangpeng.00@bytedance.com>
    Cc: Suren Baghdasaryan <surenb@google.com>
    Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
md/raid5: release batch_last before waiting for another stripe_head [+ + +]
Author: David Jeffery <djeffery@redhat.com>
Date:   Mon Oct 2 14:32:29 2023 -0400

    md/raid5: release batch_last before waiting for another stripe_head
    
    commit 2fd7b0f6d5ad655b1d947d3acdd82f687c31465e upstream.
    
    When raid5_get_active_stripe is called with a ctx containing a stripe_head in
    its batch_last pointer, it can cause a deadlock if the task sleeps waiting on
    another stripe_head to become available. The stripe_head held by batch_last
    can be blocking the advancement of other stripe_heads, leading to no
    stripe_heads being released so raid5_get_active_stripe waits forever.
    
    Like with the quiesce state handling earlier in the function, batch_last
    needs to be released by raid5_get_active_stripe before it waits for another
    stripe_head.
    
    Fixes: 3312e6c887fe ("md/raid5: Keep a reference to last stripe_head for batch")
    Cc: stable@vger.kernel.org # v6.0+
    Signed-off-by: David Jeffery <djeffery@redhat.com>
    Reviewed-by: Logan Gunthorpe <logang@deltatee.com>
    Signed-off-by: Song Liu <song@kernel.org>
    Link: https://lore.kernel.org/r/20231002183422.13047-1-djeffery@redhat.com
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
modpost: add missing else to the "of" check [+ + +]
Author: Mauricio Faria de Oliveira <mfo@canonical.com>
Date:   Thu Sep 28 17:28:07 2023 -0300

    modpost: add missing else to the "of" check
    
    [ Upstream commit cbc3d00cf88fda95dbcafee3b38655b7a8f2650a ]
    
    Without this 'else' statement, an "usb" name goes into two handlers:
    the first/previous 'if' statement _AND_ the for-loop over 'devtable',
    but the latter is useless as it has no 'usb' device_id entry anyway.
    
    Tested with allmodconfig before/after patch; no changes to *.mod.c:
    
        git checkout v6.6-rc3
        make -j$(nproc) allmodconfig
        make -j$(nproc) olddefconfig
    
        make -j$(nproc)
        find . -name '*.mod.c' | cpio -pd /tmp/before
    
        # apply patch
    
        make -j$(nproc)
        find . -name '*.mod.c' | cpio -pd /tmp/after
    
        diff -r /tmp/before/ /tmp/after/
        # no difference
    
    Fixes: acbef7b76629 ("modpost: fix module autoloading for OF devices with generic compatible property")
    Signed-off-by: Mauricio Faria de Oliveira <mfo@canonical.com>
    Signed-off-by: Masahiro Yamada <masahiroy@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
mptcp: fix dangling connection hang-up [+ + +]
Author: Paolo Abeni <pabeni@redhat.com>
Date:   Sat Sep 16 12:52:49 2023 +0200

    mptcp: fix dangling connection hang-up
    
    [ Upstream commit 27e5ccc2d5a50ed61bb73153edb1066104b108b3 ]
    
    According to RFC 8684 section 3.3:
    
      A connection is not closed unless [...] or an implementation-specific
      connection-level send timeout.
    
    Currently the MPTCP protocol does not implement such timeout, and
    connection timing-out at the TCP-level never move to close state.
    
    Introduces a catch-up condition at subflow close time to move the
    MPTCP socket to close, too.
    
    That additionally allows removing similar existing inside the worker.
    
    Finally, allow some additional timeout for plain ESTABLISHED mptcp
    sockets, as the protocol allows creating new subflows even at that
    point and making the connection functional again.
    
    This issue is actually present since the beginning, but it is basically
    impossible to solve without a long chain of functional pre-requisites
    topped by commit bbd49d114d57 ("mptcp: consolidate transition to
    TCP_CLOSE in mptcp_do_fastclose()"). When backporting this current
    patch, please also backport this other commit as well.
    
    Closes: https://github.com/multipath-tcp/mptcp_net-next/issues/430
    Fixes: e16163b6e2b7 ("mptcp: refactor shutdown and close")
    Cc: stable@vger.kernel.org
    Signed-off-by: Paolo Abeni <pabeni@redhat.com>
    Reviewed-by: Matthieu Baerts <matthieu.baerts@tessares.net>
    Reviewed-by: Mat Martineau <martineau@kernel.org>
    Signed-off-by: Matthieu Baerts <matthieu.baerts@tessares.net>
    Signed-off-by: David S. Miller <davem@davemloft.net>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

mptcp: fix delegated action races [+ + +]
Author: Paolo Abeni <pabeni@redhat.com>
Date:   Wed Oct 4 13:38:11 2023 -0700

    mptcp: fix delegated action races
    
    commit a5efdbcece83af94180e8d7c0a6e22947318499d upstream.
    
    The delegated action infrastructure is prone to the following
    race: different CPUs can try to schedule different delegated
    actions on the same subflow at the same time.
    
    Each of them will check different bits via mptcp_subflow_delegate(),
    and will try to schedule the action on the related per-cpu napi
    instance.
    
    Depending on the timing, both can observe an empty delegated list
    node, causing the same entry to be added simultaneously on two different
    lists.
    
    The root cause is that the delegated actions infra does not provide
    a single synchronization point. Address the issue reserving an additional
    bit to mark the subflow as scheduled for delegation. Acquiring such bit
    guarantee the caller to own the delegated list node, and being able to
    safely schedule the subflow.
    
    Clear such bit only when the subflow scheduling is completed, ensuring
    proper barrier in place.
    
    Additionally swap the meaning of the delegated_action bitmask, to allow
    the usage of the existing helper to set multiple bit at once.
    
    Fixes: bcd97734318d ("mptcp: use delegate action to schedule 3rd ack retrans")
    Cc: stable@vger.kernel.org
    Reviewed-by: Mat Martineau <martineau@kernel.org>
    Signed-off-by: Paolo Abeni <pabeni@redhat.com>
    Signed-off-by: Mat Martineau <martineau@kernel.org>
    Link: https://lore.kernel.org/r/20231004-send-net-20231004-v1-1-28de4ac663ae@kernel.org
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

mptcp: Remove unnecessary test for __mptcp_init_sock() [+ + +]
Author: Kuniyuki Iwashima <kuniyu@amazon.com>
Date:   Fri Aug 11 17:57:27 2023 +0200

    mptcp: Remove unnecessary test for __mptcp_init_sock()
    
    [ Upstream commit e263691773cd67d7c824eeee8b802f50c6e0c118 ]
    
    __mptcp_init_sock() always returns 0 because mptcp_init_sock() used
    to return the value directly.
    
    But after commit 18b683bff89d ("mptcp: queue data for mptcp level
    retransmission"), __mptcp_init_sock() need not return value anymore.
    
    Let's remove the unnecessary test for __mptcp_init_sock() and make
    it return void.
    
    Signed-off-by: Kuniyuki Iwashima <kuniyu@amazon.com>
    Reviewed-by: Matthieu Baerts <matthieu.baerts@tessares.net>
    Signed-off-by: Matthieu Baerts <matthieu.baerts@tessares.net>
    Signed-off-by: David S. Miller <davem@davemloft.net>
    Stable-dep-of: 27e5ccc2d5a5 ("mptcp: fix dangling connection hang-up")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

mptcp: rename timer related helper to less confusing names [+ + +]
Author: Paolo Abeni <pabeni@redhat.com>
Date:   Sat Sep 16 12:52:48 2023 +0200

    mptcp: rename timer related helper to less confusing names
    
    [ Upstream commit f6909dc1c1f4452879278128012da6c76bc186a5 ]
    
    The msk socket uses to different timeout to track close related
    events and retransmissions. The existing helpers do not indicate
    clearly which timer they actually touch, making the related code
    quite confusing.
    
    Change the existing helpers name to avoid such confusion. No
    functional change intended.
    
    This patch is linked to the next one ("mptcp: fix dangling connection
    hang-up"). The two patches are supposed to be backported together.
    
    Cc: stable@vger.kernel.org # v5.11+
    Signed-off-by: Paolo Abeni <pabeni@redhat.com>
    Reviewed-by: Matthieu Baerts <matthieu.baerts@tessares.net>
    Reviewed-by: Mat Martineau <martineau@kernel.org>
    Signed-off-by: Matthieu Baerts <matthieu.baerts@tessares.net>
    Signed-off-by: David S. Miller <davem@davemloft.net>
    Stable-dep-of: 27e5ccc2d5a5 ("mptcp: fix dangling connection hang-up")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

mptcp: userspace pm allow creating id 0 subflow [+ + +]
Author: Geliang Tang <geliang.tang@suse.com>
Date:   Wed Oct 4 13:38:12 2023 -0700

    mptcp: userspace pm allow creating id 0 subflow
    
    commit e5ed101a602873d65d2d64edaba93e8c73ec1b0f upstream.
    
    This patch drops id 0 limitation in mptcp_nl_cmd_sf_create() to allow
    creating additional subflows with the local addr ID 0.
    
    There is no reason not to allow additional subflows from this local
    address: we should be able to create new subflows from the initial
    endpoint. This limitation was breaking fullmesh support from userspace.
    
    Fixes: 702c2f646d42 ("mptcp: netlink: allow userspace-driven subflow establishment")
    Closes: https://github.com/multipath-tcp/mptcp_net-next/issues/391
    Cc: stable@vger.kernel.org
    Suggested-by: Matthieu Baerts <matthieu.baerts@tessares.net>
    Reviewed-by: Matthieu Baerts <matthieu.baerts@tessares.net>
    Signed-off-by: Geliang Tang <geliang.tang@suse.com>
    Signed-off-by: Mat Martineau <martineau@kernel.org>
    Link: https://lore.kernel.org/r/20231004-send-net-20231004-v1-2-28de4ac663ae@kernel.org
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
neighbour: fix data-races around n->output [+ + +]
Author: Eric Dumazet <edumazet@google.com>
Date:   Thu Sep 21 09:27:13 2023 +0000

    neighbour: fix data-races around n->output
    
    [ Upstream commit 5baa0433a15eadd729625004c37463acb982eca7 ]
    
    n->output field can be read locklessly, while a writer
    might change the pointer concurrently.
    
    Add missing annotations to prevent load-store tearing.
    
    Fixes: 1da177e4c3f4 ("Linux-2.6.12-rc2")
    Signed-off-by: Eric Dumazet <edumazet@google.com>
    Reviewed-by: David Ahern <dsahern@kernel.org>
    Signed-off-by: David S. Miller <davem@davemloft.net>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
net: add sysctl accept_ra_min_rtr_lft [+ + +]
Author: Patrick Rohr <prohr@google.com>
Date:   Wed Jul 19 07:52:13 2023 -0700

    net: add sysctl accept_ra_min_rtr_lft
    
    commit 1671bcfd76fdc0b9e65153cf759153083755fe4c upstream.
    
    This change adds a new sysctl accept_ra_min_rtr_lft to specify the
    minimum acceptable router lifetime in an RA. If the received RA router
    lifetime is less than the configured value (and not 0), the RA is
    ignored.
    This is useful for mobile devices, whose battery life can be impacted
    by networks that configure RAs with a short lifetime. On such networks,
    the device should never gain IPv6 provisioning and should attempt to
    drop RAs via hardware offload, if available.
    
    Signed-off-by: Patrick Rohr <prohr@google.com>
    Cc: Maciej Żenczykowski <maze@google.com>
    Cc: Lorenzo Colitti <lorenzo@google.com>
    Signed-off-by: David S. Miller <davem@davemloft.net>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

net: change accept_ra_min_rtr_lft to affect all RA lifetimes [+ + +]
Author: Patrick Rohr <prohr@google.com>
Date:   Wed Jul 26 16:07:01 2023 -0700

    net: change accept_ra_min_rtr_lft to affect all RA lifetimes
    
    commit 5027d54a9c30bc7ec808360378e2b4753f053f25 upstream.
    
    accept_ra_min_rtr_lft only considered the lifetime of the default route
    and discarded entire RAs accordingly.
    
    This change renames accept_ra_min_rtr_lft to accept_ra_min_lft, and
    applies the value to individual RA sections; in particular, router
    lifetime, PIO preferred lifetime, and RIO lifetime. If any of those
    lifetimes are lower than the configured value, the specific RA section
    is ignored.
    
    In order for the sysctl to be useful to Android, it should really apply
    to all lifetimes in the RA, since that is what determines the minimum
    frequency at which RAs must be processed by the kernel. Android uses
    hardware offloads to drop RAs for a fraction of the minimum of all
    lifetimes present in the RA (some networks have very frequent RAs (5s)
    with high lifetimes (2h)). Despite this, we have encountered networks
    that set the router lifetime to 30s which results in very frequent CPU
    wakeups. Instead of disabling IPv6 (and dropping IPv6 ethertype in the
    WiFi firmware) entirely on such networks, it seems better to ignore the
    misconfigured routers while still processing RAs from other IPv6 routers
    on the same network (i.e. to support IoT applications).
    
    The previous implementation dropped the entire RA based on router
    lifetime. This turned out to be hard to expand to the other lifetimes
    present in the RA in a consistent manner; dropping the entire RA based
    on RIO/PIO lifetimes would essentially require parsing the whole thing
    twice.
    
    Fixes: 1671bcfd76fd ("net: add sysctl accept_ra_min_rtr_lft")
    Cc: Lorenzo Colitti <lorenzo@google.com>
    Signed-off-by: Patrick Rohr <prohr@google.com>
    Reviewed-by: Maciej Żenczykowski <maze@google.com>
    Reviewed-by: David Ahern <dsahern@kernel.org>
    Link: https://lore.kernel.org/r/20230726230701.919212-1-prohr@google.com
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

net: dsa: mv88e6xxx: Avoid EEPROM timeout when EEPROM is absent [+ + +]
Author: Fabio Estevam <festevam@denx.de>
Date:   Fri Sep 22 09:47:41 2023 -0300

    net: dsa: mv88e6xxx: Avoid EEPROM timeout when EEPROM is absent
    
    [ Upstream commit 6ccf50d4d4741e064ba35511a95402c63bbe21a8 ]
    
    Since commit 23d775f12dcd ("net: dsa: mv88e6xxx: Wait for EEPROM done
    before HW reset") the following error is seen on a imx8mn board with
    a 88E6320 switch:
    
    mv88e6085 30be0000.ethernet-1:00: Timeout waiting for EEPROM done
    
    This board does not have an EEPROM attached to the switch though.
    
    This problem is well explained by Andrew Lunn:
    
    "If there is an EEPROM, and the EEPROM contains a lot of data, it could
    be that when we perform a hardware reset towards the end of probe, it
    interrupts an I2C bus transaction, leaving the I2C bus in a bad state,
    and future reads of the EEPROM do not work.
    
    The work around for this was to poll the EEInt status and wait for it
    to go true before performing the hardware reset.
    
    However, we have discovered that for some boards which do not have an
    EEPROM, EEInt never indicates complete. As a result,
    mv88e6xxx_g1_wait_eeprom_done() spins for a second and then prints a
    warning.
    
    We probably need a different solution than calling
    mv88e6xxx_g1_wait_eeprom_done(). The datasheet for 6352 documents the
    EEPROM Command register:
    
    bit 15 is:
    
      EEPROM Unit Busy. This bit must be set to a one to start an EEPROM
      operation (see EEOp below). Only one EEPROM operation can be
      executing at one time so this bit must be zero before setting it to
      a one.  When the requested EEPROM operation completes this bit will
      automatically be cleared to a zero. The transition of this bit from
      a one to a zero can be used to generate an interrupt (the EEInt in
      Global 1, offset 0x00).
    
    and more interesting is bit 11:
    
      Register Loader Running. This bit is set to one whenever the
      register loader is busy executing instructions contained in the
      EEPROM."
    
    Change to using mv88e6xxx_g2_eeprom_wait() to fix the timeout error
    when the EEPROM chip is not present.
    
    Fixes: 23d775f12dcd ("net: dsa: mv88e6xxx: Wait for EEPROM done before HW reset")
    Suggested-by: Andrew Lunn <andrew@lunn.ch>
    Signed-off-by: Fabio Estevam <festevam@denx.de>
    Reviewed-by: Florian Fainelli <florian.fainelli@broadcom.com>
    Reviewed-by: Andrew Lunn <andrew@lunn.ch>
    Signed-off-by: David S. Miller <davem@davemloft.net>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

net: ethernet: mediatek: disable irq before schedule napi [+ + +]
Author: Christian Marangi <ansuelsmth@gmail.com>
Date:   Mon Oct 2 16:08:05 2023 +0200

    net: ethernet: mediatek: disable irq before schedule napi
    
    commit fcdfc462881d8acf9db77f483b2c821e286ca97b upstream.
    
    While searching for possible refactor of napi_schedule_prep and
    __napi_schedule it was notice that the mtk eth driver disable the
    interrupt for rx and tx AFTER napi is scheduled.
    
    While this is a very hard to repro case it might happen to have
    situation where the interrupt is disabled and never enabled again as the
    napi completes and the interrupt is enabled before.
    
    This is caused by the fact that a napi driven by interrupt expect a
    logic with:
    1. interrupt received. napi prepared -> interrupt disabled -> napi
       scheduled
    2. napi triggered. ring cleared -> interrupt enabled -> wait for new
       interrupt
    
    To prevent this case, disable the interrupt BEFORE the napi is
    scheduled.
    
    Fixes: 656e705243fd ("net-next: mediatek: add support for MT7623 ethernet")
    Cc: stable@vger.kernel.org
    Signed-off-by: Christian Marangi <ansuelsmth@gmail.com>
    Link: https://lore.kernel.org/r/20231002140805.568-1-ansuelsmth@gmail.com
    Signed-off-by: Paolo Abeni <pabeni@redhat.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

net: ethernet: ti: am65-cpsw: Fix error code in am65_cpsw_nuss_init_tx_chns() [+ + +]
Author: Dan Carpenter <dan.carpenter@linaro.org>
Date:   Tue Sep 26 17:04:43 2023 +0300

    net: ethernet: ti: am65-cpsw: Fix error code in am65_cpsw_nuss_init_tx_chns()
    
    [ Upstream commit 37d4f55567982e445f86dc0ff4ecfa72921abfe8 ]
    
    This accidentally returns success, but it should return a negative error
    code.
    
    Fixes: 93a76530316a ("net: ethernet: ti: introduce am65x/j721e gigabit eth subsystem driver")
    Signed-off-by: Dan Carpenter <dan.carpenter@linaro.org>
    Reviewed-by: Roger Quadros <rogerq@kernel.org>
    Signed-off-by: David S. Miller <davem@davemloft.net>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

net: fix possible store tearing in neigh_periodic_work() [+ + +]
Author: Eric Dumazet <edumazet@google.com>
Date:   Thu Sep 21 08:46:26 2023 +0000

    net: fix possible store tearing in neigh_periodic_work()
    
    [ Upstream commit 25563b581ba3a1f263a00e8c9a97f5e7363be6fd ]
    
    While looking at a related syzbot report involving neigh_periodic_work(),
    I found that I forgot to add an annotation when deleting an
    RCU protected item from a list.
    
    Readers use rcu_deference(*np), we need to use either
    rcu_assign_pointer() or WRITE_ONCE() on writer side
    to prevent store tearing.
    
    I use rcu_assign_pointer() to have lockdep support,
    this was the choice made in neigh_flush_dev().
    
    Fixes: 767e97e1e0db ("neigh: RCU conversion of struct neighbour")
    Signed-off-by: Eric Dumazet <edumazet@google.com>
    Reviewed-by: David Ahern <dsahern@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: lan743x: also select PHYLIB [+ + +]
Author: Randy Dunlap <rdunlap@infradead.org>
Date:   Mon Oct 2 12:35:44 2023 -0700

    net: lan743x: also select PHYLIB
    
    [ Upstream commit 566aeed6871ac2189b5bfe03e1a5b3b7be5eca38 ]
    
    Since FIXED_PHY depends on PHYLIB, PHYLIB needs to be set to avoid
    a kconfig warning:
    
    WARNING: unmet direct dependencies detected for FIXED_PHY
      Depends on [n]: NETDEVICES [=y] && PHYLIB [=n]
      Selected by [y]:
      - LAN743X [=y] && NETDEVICES [=y] && ETHERNET [=y] && NET_VENDOR_MICROCHIP [=y] && PCI [=y] && PTP_1588_CLOCK_OPTIONAL [=y]
    
    Fixes: 73c4d1b307ae ("net: lan743x: select FIXED_PHY")
    Signed-off-by: Randy Dunlap <rdunlap@infradead.org>
    Reported-by: kernel test robot <lkp@intel.com>
    Closes: lore.kernel.org/r/202309261802.JPbRHwti-lkp@intel.com
    Cc: Bryan Whitehead <bryan.whitehead@microchip.com>
    Cc: UNGLinuxDriver@microchip.com
    Reviewed-by: Simon Horman <horms@kernel.org>
    Tested-by: Simon Horman <horms@kernel.org> # build-tested
    Link: https://lore.kernel.org/r/20231002193544.14529-1-rdunlap@infradead.org
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

net: mana: Fix oversized sge0 for GSO packets [+ + +]
Author: Haiyang Zhang <haiyangz@microsoft.com>
Date:   Fri Sep 29 13:42:27 2023 -0700

    net: mana: Fix oversized sge0 for GSO packets
    
    [ Upstream commit a43e8e9ffa0d1de058964edf1a0622cbb7e27cfe ]
    
    Handle the case when GSO SKB linear length is too large.
    
    MANA NIC requires GSO packets to put only the header part to SGE0,
    otherwise the TX queue may stop at the HW level.
    
    So, use 2 SGEs for the skb linear part which contains more than the
    packet header.
    
    Fixes: ca9c54d2d6a5 ("net: mana: Add a driver for Microsoft Azure Network Adapter (MANA)")
    Signed-off-by: Haiyang Zhang <haiyangz@microsoft.com>
    Reviewed-by: Simon Horman <horms@kernel.org>
    Reviewed-by: Shradha Gupta <shradhagupta@linux.microsoft.com>
    Signed-off-by: Paolo Abeni <pabeni@redhat.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

net: mana: Fix the tso_bytes calculation [+ + +]
Author: Haiyang Zhang <haiyangz@microsoft.com>
Date:   Fri Sep 29 13:42:26 2023 -0700

    net: mana: Fix the tso_bytes calculation
    
    commit 7a54de92657455210d0ca71d4176b553952c871a upstream.
    
    sizeof(struct hop_jumbo_hdr) is not part of tso_bytes, so remove
    the subtraction from header size.
    
    Cc: stable@vger.kernel.org
    Fixes: bd7fc6e1957c ("net: mana: Add new MANA VF performance counters for easier troubleshooting")
    Signed-off-by: Haiyang Zhang <haiyangz@microsoft.com>
    Reviewed-by: Simon Horman <horms@kernel.org>
    Reviewed-by: Shradha Gupta <shradhagupta@linux.microsoft.com>
    Signed-off-by: Paolo Abeni <pabeni@redhat.com>
    Stable-dep-of: a43e8e9ffa0d ("net: mana: Fix oversized sge0 for GSO packets")
    Signed-off-by: Sasha Levin <sashal@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

net: mana: Fix TX CQE error handling [+ + +]
Author: Haiyang Zhang <haiyangz@microsoft.com>
Date:   Fri Sep 29 13:42:25 2023 -0700

    net: mana: Fix TX CQE error handling
    
    commit b2b000069a4c307b09548dc2243f31f3ca0eac9c upstream.
    
    For an unknown TX CQE error type (probably from a newer hardware),
    still free the SKB, update the queue tail, etc., otherwise the
    accounting will be wrong.
    
    Also, TX errors can be triggered by injecting corrupted packets, so
    replace the WARN_ONCE to ratelimited error logging.
    
    Cc: stable@vger.kernel.org
    Fixes: ca9c54d2d6a5 ("net: mana: Add a driver for Microsoft Azure Network Adapter (MANA)")
    Signed-off-by: Haiyang Zhang <haiyangz@microsoft.com>
    Reviewed-by: Simon Horman <horms@kernel.org>
    Reviewed-by: Shradha Gupta <shradhagupta@linux.microsoft.com>
    Signed-off-by: Paolo Abeni <pabeni@redhat.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

net: nfc: llcp: Add lock when modifying device list [+ + +]
Author: Jeremy Cline <jeremy@jcline.org>
Date:   Fri Sep 8 19:58:53 2023 -0400

    net: nfc: llcp: Add lock when modifying device list
    
    [ Upstream commit dfc7f7a988dad34c3bf4c053124fb26aa6c5f916 ]
    
    The device list needs its associated lock held when modifying it, or the
    list could become corrupted, as syzbot discovered.
    
    Reported-and-tested-by: syzbot+c1d0a03d305972dbbe14@syzkaller.appspotmail.com
    Closes: https://syzkaller.appspot.com/bug?extid=c1d0a03d305972dbbe14
    Signed-off-by: Jeremy Cline <jeremy@jcline.org>
    Reviewed-by: Simon Horman <horms@kernel.org>
    Fixes: 6709d4b7bc2e ("net: nfc: Fix use-after-free caused by nfc_llcp_find_local")
    Link: https://lore.kernel.org/r/20230908235853.1319596-1-jeremy@jcline.org
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

net: prevent rewrite of msg_name in sock_sendmsg() [+ + +]
Author: Jordan Rife <jrife@google.com>
Date:   Thu Sep 21 18:46:41 2023 -0500

    net: prevent rewrite of msg_name in sock_sendmsg()
    
    commit 86a7e0b69bd5b812e48a20c66c2161744f3caa16 upstream.
    
    Callers of sock_sendmsg(), and similarly kernel_sendmsg(), in kernel
    space may observe their value of msg_name change in cases where BPF
    sendmsg hooks rewrite the send address. This has been confirmed to break
    NFS mounts running in UDP mode and has the potential to break other
    systems.
    
    This patch:
    
    1) Creates a new function called __sock_sendmsg() with same logic as the
       old sock_sendmsg() function.
    2) Replaces calls to sock_sendmsg() made by __sys_sendto() and
       __sys_sendmsg() with __sock_sendmsg() to avoid an unnecessary copy,
       as these system calls are already protected.
    3) Modifies sock_sendmsg() so that it makes a copy of msg_name if
       present before passing it down the stack to insulate callers from
       changes to the send address.
    
    Link: https://lore.kernel.org/netdev/20230912013332.2048422-1-jrife@google.com/
    Fixes: 1cedee13d25a ("bpf: Hooks for sys_sendmsg")
    Cc: stable@vger.kernel.org
    Reviewed-by: Willem de Bruijn <willemb@google.com>
    Signed-off-by: Jordan Rife <jrife@google.com>
    Reviewed-by: Simon Horman <horms@kernel.org>
    Signed-off-by: David S. Miller <davem@davemloft.net>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

net: release reference to inet6_dev pointer [+ + +]
Author: Patrick Rohr <prohr@google.com>
Date:   Fri Aug 18 11:22:49 2023 -0700

    net: release reference to inet6_dev pointer
    
    commit 5cb249686e67dbef3ffe53887fa725eefc5a7144 upstream.
    
    addrconf_prefix_rcv returned early without releasing the inet6_dev
    pointer when the PIO lifetime is less than accept_ra_min_lft.
    
    Fixes: 5027d54a9c30 ("net: change accept_ra_min_rtr_lft to affect all RA lifetimes")
    Cc: Maciej Żenczykowski <maze@google.com>
    Cc: Lorenzo Colitti <lorenzo@google.com>
    Cc: David Ahern <dsahern@kernel.org>
    Cc: Simon Horman <horms@kernel.org>
    Reviewed-by: Simon Horman <horms@kernel.org>
    Reviewed-by: Maciej Żenczykowski <maze@google.com>
    Signed-off-by: Patrick Rohr <prohr@google.com>
    Reviewed-by: Leon Romanovsky <leonro@nvidia.com>
    Signed-off-by: David S. Miller <davem@davemloft.net>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

net: renesas: rswitch: Add spin lock protection for irq {un}mask [+ + +]
Author: Yoshihiro Shimoda <yoshihiro.shimoda.uh@renesas.com>
Date:   Tue Sep 12 10:49:36 2023 +0900

    net: renesas: rswitch: Add spin lock protection for irq {un}mask
    
    [ Upstream commit c4f922e86c8e0f7c5fe94e0547e9835fc9711f08 ]
    
    Add spin lock protection for irq {un}mask registers' control.
    
    After napi_complete_done() and this protection were applied,
    a lot of redundant interrupts no longer occur.
    
    For example: when "iperf3 -c <ipaddr> -R" on R-Car S4-8 Spider
     Before the patches are applied: about 800,000 times happened
     After the patches were applied: about 100,000 times happened
    
    Fixes: 3590918b5d07 ("net: ethernet: renesas: Add support for "Ethernet Switch"")
    Signed-off-by: Yoshihiro Shimoda <yoshihiro.shimoda.uh@renesas.com>
    Reviewed-by: Simon Horman <horms@kernel.org>
    Signed-off-by: Paolo Abeni <pabeni@redhat.com>
    Stable-dep-of: a0c55bba0d0d ("rswitch: Fix PHY station management clock setting")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

net: replace calls to sock->ops->connect() with kernel_connect() [+ + +]
Author: Jordan Rife <jrife@google.com>
Date:   Thu Sep 21 18:46:40 2023 -0500

    net: replace calls to sock->ops->connect() with kernel_connect()
    
    commit 26297b4ce1ce4ea40bc9a48ec99f45da3f64d2e2 upstream.
    
    commit 0bdf399342c5 ("net: Avoid address overwrite in kernel_connect")
    ensured that kernel_connect() will not overwrite the address parameter
    in cases where BPF connect hooks perform an address rewrite. This change
    replaces direct calls to sock->ops->connect() in net with kernel_connect()
    to make these call safe.
    
    Link: https://lore.kernel.org/netdev/20230912013332.2048422-1-jrife@google.com/
    Fixes: d74bad4e74ee ("bpf: Hooks for sys_connect")
    Cc: stable@vger.kernel.org
    Reviewed-by: Willem de Bruijn <willemb@google.com>
    Signed-off-by: Jordan Rife <jrife@google.com>
    Reviewed-by: Simon Horman <horms@kernel.org>
    Signed-off-by: David S. Miller <davem@davemloft.net>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

net: stmmac: dwmac-stm32: fix resume on STM32 MCU [+ + +]
Author: Ben Wolsieffer <ben.wolsieffer@hefring.com>
Date:   Wed Sep 27 13:57:49 2023 -0400

    net: stmmac: dwmac-stm32: fix resume on STM32 MCU
    
    [ Upstream commit 6f195d6b0da3b689922ba9e302af2f49592fa9fc ]
    
    The STM32MP1 keeps clk_rx enabled during suspend, and therefore the
    driver does not enable the clock in stm32_dwmac_init() if the device was
    suspended. The problem is that this same code runs on STM32 MCUs, which
    do disable clk_rx during suspend, causing the clock to never be
    re-enabled on resume.
    
    This patch adds a variant flag to indicate that clk_rx remains enabled
    during suspend, and uses this to decide whether to enable the clock in
    stm32_dwmac_init() if the device was suspended.
    
    This approach fixes this specific bug with limited opportunity for
    unintended side-effects, but I have a follow up patch that will refactor
    the clock configuration and hopefully make it less error prone.
    
    Fixes: 6528e02cc9ff ("net: ethernet: stmmac: add adaptation for stm32mp157c.")
    Signed-off-by: Ben Wolsieffer <ben.wolsieffer@hefring.com>
    Reviewed-by: Jacob Keller <jacob.e.keller@intel.com>
    Link: https://lore.kernel.org/r/20230927175749.1419774-1-ben.wolsieffer@hefring.com
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

net: stmmac: platform: fix the incorrect parameter [+ + +]
Author: Clark Wang <xiaoning.wang@nxp.com>
Date:   Thu Sep 21 14:24:43 2023 +0800

    net: stmmac: platform: fix the incorrect parameter
    
    [ Upstream commit 6b09edc1b31762af58d3d95754354ca6a92d39c0 ]
    
    The second parameter of stmmac_pltfr_init() needs the pointer of
    "struct plat_stmmacenet_data". So, correct the parameter typo when calling the
    function.
    
    Otherwise, it may cause this alignment exception when doing suspend/resume.
    [   49.067201] CPU1 is up
    [   49.135258] Internal error: SP/PC alignment exception: 000000008a000000 [#1] PREEMPT SMP
    [   49.143346] Modules linked in: soc_imx9 crct10dif_ce polyval_ce nvmem_imx_ocotp_fsb_s400 polyval_generic layerscape_edac_mod snd_soc_fsl_asoc_card snd_soc_imx_audmux snd_soc_imx_card snd_soc_wm8962 el_enclave snd_soc_fsl_micfil rtc_pcf2127 rtc_pcf2131 flexcan can_dev snd_soc_fsl_xcvr snd_soc_fsl_sai imx8_media_dev(C) snd_soc_fsl_utils fuse
    [   49.173393] CPU: 0 PID: 565 Comm: sh Tainted: G         C         6.5.0-rc4-next-20230804-05047-g5781a6249dae #677
    [   49.183721] Hardware name: NXP i.MX93 11X11 EVK board (DT)
    [   49.189190] pstate: 60400009 (nZCv daif +PAN -UAO -TCO -DIT -SSBS BTYPE=--)
    [   49.196140] pc : 0x80800052
    [   49.198931] lr : stmmac_pltfr_resume+0x34/0x50
    [   49.203368] sp : ffff800082f8bab0
    [   49.206670] x29: ffff800082f8bab0 x28: ffff0000047d0ec0 x27: ffff80008186c170
    [   49.213794] x26: 0000000b5e4ff1ba x25: ffff800081e5fa74 x24: 0000000000000010
    [   49.220918] x23: ffff800081fe0000 x22: 0000000000000000 x21: 0000000000000000
    [   49.228042] x20: ffff0000001b4010 x19: ffff0000001b4010 x18: 0000000000000006
    [   49.235166] x17: ffff7ffffe007000 x16: ffff800080000000 x15: 0000000000000000
    [   49.242290] x14: 00000000000000fc x13: 0000000000000000 x12: 0000000000000000
    [   49.249414] x11: 0000000000000001 x10: 0000000000000a60 x9 : ffff800082f8b8c0
    [   49.256538] x8 : 0000000000000008 x7 : 0000000000000001 x6 : 000000005f54a200
    [   49.263662] x5 : 0000000001000000 x4 : ffff800081b93680 x3 : ffff800081519be0
    [   49.270786] x2 : 0000000080800052 x1 : 0000000000000000 x0 : ffff0000001b4000
    [   49.277911] Call trace:
    [   49.280346]  0x80800052
    [   49.282781]  platform_pm_resume+0x2c/0x68
    [   49.286785]  dpm_run_callback.constprop.0+0x74/0x134
    [   49.291742]  device_resume+0x88/0x194
    [   49.295391]  dpm_resume+0x10c/0x230
    [   49.298866]  dpm_resume_end+0x18/0x30
    [   49.302515]  suspend_devices_and_enter+0x2b8/0x624
    [   49.307299]  pm_suspend+0x1fc/0x348
    [   49.310774]  state_store+0x80/0x104
    [   49.314258]  kobj_attr_store+0x18/0x2c
    [   49.318002]  sysfs_kf_write+0x44/0x54
    [   49.321659]  kernfs_fop_write_iter+0x120/0x1ec
    [   49.326088]  vfs_write+0x1bc/0x300
    [   49.329485]  ksys_write+0x70/0x104
    [   49.332874]  __arm64_sys_write+0x1c/0x28
    [   49.336783]  invoke_syscall+0x48/0x114
    [   49.340527]  el0_svc_common.constprop.0+0xc4/0xe4
    [   49.345224]  do_el0_svc+0x38/0x98
    [   49.348526]  el0_svc+0x2c/0x84
    [   49.351568]  el0t_64_sync_handler+0x100/0x12c
    [   49.355910]  el0t_64_sync+0x190/0x194
    [   49.359567] Code: ???????? ???????? ???????? ???????? (????????)
    [   49.365644] ---[ end trace 0000000000000000 ]---
    
    Fixes: 97117eb51ec8 ("net: stmmac: platform: provide stmmac_pltfr_init()")
    Signed-off-by: Clark Wang <xiaoning.wang@nxp.com>
    Reviewed-by: Jacob Keller <jacob.e.keller@intel.com>
    Reviewed-by: Serge Semin <fancer.lancer@gmail.com>
    Signed-off-by: David S. Miller <davem@davemloft.net>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

net: usb: smsc75xx: Fix uninit-value access in __smsc75xx_read_reg [+ + +]
Author: Shigeru Yoshida <syoshida@redhat.com>
Date:   Sun Sep 24 02:35:49 2023 +0900

    net: usb: smsc75xx: Fix uninit-value access in __smsc75xx_read_reg
    
    [ Upstream commit e9c65989920f7c28775ec4e0c11b483910fb67b8 ]
    
    syzbot reported the following uninit-value access issue:
    
    =====================================================
    BUG: KMSAN: uninit-value in smsc75xx_wait_ready drivers/net/usb/smsc75xx.c:975 [inline]
    BUG: KMSAN: uninit-value in smsc75xx_bind+0x5c9/0x11e0 drivers/net/usb/smsc75xx.c:1482
    CPU: 0 PID: 8696 Comm: kworker/0:3 Not tainted 5.8.0-rc5-syzkaller #0
    Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 01/01/2011
    Workqueue: usb_hub_wq hub_event
    Call Trace:
     __dump_stack lib/dump_stack.c:77 [inline]
     dump_stack+0x21c/0x280 lib/dump_stack.c:118
     kmsan_report+0xf7/0x1e0 mm/kmsan/kmsan_report.c:121
     __msan_warning+0x58/0xa0 mm/kmsan/kmsan_instr.c:215
     smsc75xx_wait_ready drivers/net/usb/smsc75xx.c:975 [inline]
     smsc75xx_bind+0x5c9/0x11e0 drivers/net/usb/smsc75xx.c:1482
     usbnet_probe+0x1152/0x3f90 drivers/net/usb/usbnet.c:1737
     usb_probe_interface+0xece/0x1550 drivers/usb/core/driver.c:374
     really_probe+0xf20/0x20b0 drivers/base/dd.c:529
     driver_probe_device+0x293/0x390 drivers/base/dd.c:701
     __device_attach_driver+0x63f/0x830 drivers/base/dd.c:807
     bus_for_each_drv+0x2ca/0x3f0 drivers/base/bus.c:431
     __device_attach+0x4e2/0x7f0 drivers/base/dd.c:873
     device_initial_probe+0x4a/0x60 drivers/base/dd.c:920
     bus_probe_device+0x177/0x3d0 drivers/base/bus.c:491
     device_add+0x3b0e/0x40d0 drivers/base/core.c:2680
     usb_set_configuration+0x380f/0x3f10 drivers/usb/core/message.c:2032
     usb_generic_driver_probe+0x138/0x300 drivers/usb/core/generic.c:241
     usb_probe_device+0x311/0x490 drivers/usb/core/driver.c:272
     really_probe+0xf20/0x20b0 drivers/base/dd.c:529
     driver_probe_device+0x293/0x390 drivers/base/dd.c:701
     __device_attach_driver+0x63f/0x830 drivers/base/dd.c:807
     bus_for_each_drv+0x2ca/0x3f0 drivers/base/bus.c:431
     __device_attach+0x4e2/0x7f0 drivers/base/dd.c:873
     device_initial_probe+0x4a/0x60 drivers/base/dd.c:920
     bus_probe_device+0x177/0x3d0 drivers/base/bus.c:491
     device_add+0x3b0e/0x40d0 drivers/base/core.c:2680
     usb_new_device+0x1bd4/0x2a30 drivers/usb/core/hub.c:2554
     hub_port_connect drivers/usb/core/hub.c:5208 [inline]
     hub_port_connect_change drivers/usb/core/hub.c:5348 [inline]
     port_event drivers/usb/core/hub.c:5494 [inline]
     hub_event+0x5e7b/0x8a70 drivers/usb/core/hub.c:5576
     process_one_work+0x1688/0x2140 kernel/workqueue.c:2269
     worker_thread+0x10bc/0x2730 kernel/workqueue.c:2415
     kthread+0x551/0x590 kernel/kthread.c:292
     ret_from_fork+0x1f/0x30 arch/x86/entry/entry_64.S:293
    
    Local variable ----buf.i87@smsc75xx_bind created at:
     __smsc75xx_read_reg drivers/net/usb/smsc75xx.c:83 [inline]
     smsc75xx_wait_ready drivers/net/usb/smsc75xx.c:968 [inline]
     smsc75xx_bind+0x485/0x11e0 drivers/net/usb/smsc75xx.c:1482
     __smsc75xx_read_reg drivers/net/usb/smsc75xx.c:83 [inline]
     smsc75xx_wait_ready drivers/net/usb/smsc75xx.c:968 [inline]
     smsc75xx_bind+0x485/0x11e0 drivers/net/usb/smsc75xx.c:1482
    
    This issue is caused because usbnet_read_cmd() reads less bytes than requested
    (zero byte in the reproducer). In this case, 'buf' is not properly filled.
    
    This patch fixes the issue by returning -ENODATA if usbnet_read_cmd() reads
    less bytes than requested.
    
    Fixes: d0cad871703b ("smsc75xx: SMSC LAN75xx USB gigabit ethernet adapter driver")
    Reported-and-tested-by: syzbot+6966546b78d050bb0b5d@syzkaller.appspotmail.com
    Closes: https://syzkaller.appspot.com/bug?extid=6966546b78d050bb0b5d
    Signed-off-by: Shigeru Yoshida <syoshida@redhat.com>
    Reviewed-by: Simon Horman <horms@kernel.org>
    Link: https://lore.kernel.org/r/20230923173549.3284502-1-syoshida@redhat.com
    Signed-off-by: Paolo Abeni <pabeni@redhat.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
netfilter: handle the connecting collision properly in nf_conntrack_proto_sctp [+ + +]
Author: Xin Long <lucien.xin@gmail.com>
Date:   Tue Oct 3 13:17:53 2023 -0400

    netfilter: handle the connecting collision properly in nf_conntrack_proto_sctp
    
    [ Upstream commit 8e56b063c86569e51eed1c5681ce6361fa97fc7a ]
    
    In Scenario A and B below, as the delayed INIT_ACK always changes the peer
    vtag, SCTP ct with the incorrect vtag may cause packet loss.
    
    Scenario A: INIT_ACK is delayed until the peer receives its own INIT_ACK
    
      192.168.1.2 > 192.168.1.1: [INIT] [init tag: 1328086772]
        192.168.1.1 > 192.168.1.2: [INIT] [init tag: 1414468151]
        192.168.1.2 > 192.168.1.1: [INIT ACK] [init tag: 1328086772]
      192.168.1.1 > 192.168.1.2: [INIT ACK] [init tag: 1650211246] *
      192.168.1.2 > 192.168.1.1: [COOKIE ECHO]
        192.168.1.1 > 192.168.1.2: [COOKIE ECHO]
        192.168.1.2 > 192.168.1.1: [COOKIE ACK]
    
    Scenario B: INIT_ACK is delayed until the peer completes its own handshake
    
      192.168.1.2 > 192.168.1.1: sctp (1) [INIT] [init tag: 3922216408]
        192.168.1.1 > 192.168.1.2: sctp (1) [INIT] [init tag: 144230885]
        192.168.1.2 > 192.168.1.1: sctp (1) [INIT ACK] [init tag: 3922216408]
        192.168.1.1 > 192.168.1.2: sctp (1) [COOKIE ECHO]
        192.168.1.2 > 192.168.1.1: sctp (1) [COOKIE ACK]
      192.168.1.1 > 192.168.1.2: sctp (1) [INIT ACK] [init tag: 3914796021] *
    
    This patch fixes it as below:
    
    In SCTP_CID_INIT processing:
    - clear ct->proto.sctp.init[!dir] if ct->proto.sctp.init[dir] &&
      ct->proto.sctp.init[!dir]. (Scenario E)
    - set ct->proto.sctp.init[dir].
    
    In SCTP_CID_INIT_ACK processing:
    - drop it if !ct->proto.sctp.init[!dir] && ct->proto.sctp.vtag[!dir] &&
      ct->proto.sctp.vtag[!dir] != ih->init_tag. (Scenario B, Scenario C)
    - drop it if ct->proto.sctp.init[dir] && ct->proto.sctp.init[!dir] &&
      ct->proto.sctp.vtag[!dir] != ih->init_tag. (Scenario A)
    
    In SCTP_CID_COOKIE_ACK processing:
    - clear ct->proto.sctp.init[dir] and ct->proto.sctp.init[!dir].
      (Scenario D)
    
    Also, it's important to allow the ct state to move forward with cookie_echo
    and cookie_ack from the opposite dir for the collision scenarios.
    
    There are also other Scenarios where it should allow the packet through,
    addressed by the processing above:
    
    Scenario C: new CT is created by INIT_ACK.
    
    Scenario D: start INIT on the existing ESTABLISHED ct.
    
    Scenario E: start INIT after the old collision on the existing ESTABLISHED
    ct.
    
      192.168.1.2 > 192.168.1.1: sctp (1) [INIT] [init tag: 3922216408]
      192.168.1.1 > 192.168.1.2: sctp (1) [INIT] [init tag: 144230885]
      (both side are stopped, then start new connection again in hours)
      192.168.1.2 > 192.168.1.1: sctp (1) [INIT] [init tag: 242308742]
    
    Fixes: 9fb9cbb1082d ("[NETFILTER]: Add nf_conntrack subsystem.")
    Signed-off-by: Xin Long <lucien.xin@gmail.com>
    Signed-off-by: Florian Westphal <fw@strlen.de>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

netfilter: nf_tables: Deduplicate nft_register_obj audit logs [+ + +]
Author: Phil Sutter <phil@nwl.cc>
Date:   Sat Sep 23 03:53:50 2023 +0200

    netfilter: nf_tables: Deduplicate nft_register_obj audit logs
    
    [ Upstream commit 0d880dc6f032e0b541520e9926f398a77d3d433c ]
    
    When adding/updating an object, the transaction handler emits suitable
    audit log entries already, the one in nft_obj_notify() is redundant. To
    fix that (and retain the audit logging from objects' 'update' callback),
    Introduce an "audit log free" variant for internal use.
    
    Fixes: c520292f29b8 ("audit: log nftables configuration change events once per table")
    Signed-off-by: Phil Sutter <phil@nwl.cc>
    Reviewed-by: Richard Guy Briggs <rgb@redhat.com>
    Acked-by: Paul Moore <paul@paul-moore.com> (Audit)
    Signed-off-by: Florian Westphal <fw@strlen.de>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

netfilter: nf_tables: nft_set_rbtree: fix spurious insertion failure [+ + +]
Author: Florian Westphal <fw@strlen.de>
Date:   Thu Sep 28 15:12:44 2023 +0200

    netfilter: nf_tables: nft_set_rbtree: fix spurious insertion failure
    
    [ Upstream commit 087388278e0f301f4c61ddffb1911d3a180f84b8 ]
    
    nft_rbtree_gc_elem() walks back and removes the end interval element that
    comes before the expired element.
    
    There is a small chance that we've cached this element as 'rbe_ge'.
    If this happens, we hold and test a pointer that has been queued for
    freeing.
    
    It also causes spurious insertion failures:
    
    $ cat test-testcases-sets-0044interval_overlap_0.1/testout.log
    Error: Could not process rule: File exists
    add element t s {  0 -  2 }
                       ^^^^^^
    Failed to insert  0 -  2 given:
    table ip t {
            set s {
                    type inet_service
                    flags interval,timeout
                    timeout 2s
                    gc-interval 2s
            }
    }
    
    The set (rbtree) is empty. The 'failure' doesn't happen on next attempt.
    
    Reason is that when we try to insert, the tree may hold an expired
    element that collides with the range we're adding.
    While we do evict/erase this element, we can trip over this check:
    
    if (rbe_ge && nft_rbtree_interval_end(rbe_ge) && nft_rbtree_interval_end(new))
          return -ENOTEMPTY;
    
    rbe_ge was erased by the synchronous gc, we should not have done this
    check.  Next attempt won't find it, so retry results in successful
    insertion.
    
    Restart in-kernel to avoid such spurious errors.
    
    Such restart are rare, unless userspace intentionally adds very large
    numbers of elements with very short timeouts while setting a huge
    gc interval.
    
    Even in this case, this cannot loop forever, on each retry an existing
    element has been removed.
    
    As the caller is holding the transaction mutex, its impossible
    for a second entity to add more expiring elements to the tree.
    
    After this it also becomes feasible to remove the async gc worker
    and perform all garbage collection from the commit path.
    
    Fixes: c9e6978e2725 ("netfilter: nft_set_rbtree: Switch to node list walk for overlap detection")
    Signed-off-by: Florian Westphal <fw@strlen.de>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

netfilter: nft_payload: rebuild vlan header on h_proto access [+ + +]
Author: Florian Westphal <fw@strlen.de>
Date:   Fri Sep 29 10:42:10 2023 +0200

    netfilter: nft_payload: rebuild vlan header on h_proto access
    
    [ Upstream commit af84f9e447a65b4b9f79e7e5d69e19039b431c56 ]
    
    nft can perform merging of adjacent payload requests.
    This means that:
    
    ether saddr 00:11 ... ether type 8021ad ...
    
    is a single payload expression, for 8 bytes, starting at the
    ethernet source offset.
    
    Check that offset+length is fully within the source/destination mac
    addersses.
    
    This bug prevents 'ether type' from matching the correct h_proto in case
    vlan tag got stripped.
    
    Fixes: de6843be3082 ("netfilter: nft_payload: rebuild vlan header when needed")
    Reported-by: David Ward <david.ward@ll.mit.edu>
    Signed-off-by: Florian Westphal <fw@strlen.de>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
netlink: annotate data-races around sk->sk_err [+ + +]
Author: Eric Dumazet <edumazet@google.com>
Date:   Tue Oct 3 18:34:55 2023 +0000

    netlink: annotate data-races around sk->sk_err
    
    [ Upstream commit d0f95894fda7d4f895b29c1097f92d7fee278cb2 ]
    
    syzbot caught another data-race in netlink when
    setting sk->sk_err.
    
    Annotate all of them for good measure.
    
    BUG: KCSAN: data-race in netlink_recvmsg / netlink_recvmsg
    
    write to 0xffff8881613bb220 of 4 bytes by task 28147 on cpu 0:
    netlink_recvmsg+0x448/0x780 net/netlink/af_netlink.c:1994
    sock_recvmsg_nosec net/socket.c:1027 [inline]
    sock_recvmsg net/socket.c:1049 [inline]
    __sys_recvfrom+0x1f4/0x2e0 net/socket.c:2229
    __do_sys_recvfrom net/socket.c:2247 [inline]
    __se_sys_recvfrom net/socket.c:2243 [inline]
    __x64_sys_recvfrom+0x78/0x90 net/socket.c:2243
    do_syscall_x64 arch/x86/entry/common.c:50 [inline]
    do_syscall_64+0x41/0xc0 arch/x86/entry/common.c:80
    entry_SYSCALL_64_after_hwframe+0x63/0xcd
    
    write to 0xffff8881613bb220 of 4 bytes by task 28146 on cpu 1:
    netlink_recvmsg+0x448/0x780 net/netlink/af_netlink.c:1994
    sock_recvmsg_nosec net/socket.c:1027 [inline]
    sock_recvmsg net/socket.c:1049 [inline]
    __sys_recvfrom+0x1f4/0x2e0 net/socket.c:2229
    __do_sys_recvfrom net/socket.c:2247 [inline]
    __se_sys_recvfrom net/socket.c:2243 [inline]
    __x64_sys_recvfrom+0x78/0x90 net/socket.c:2243
    do_syscall_x64 arch/x86/entry/common.c:50 [inline]
    do_syscall_64+0x41/0xc0 arch/x86/entry/common.c:80
    entry_SYSCALL_64_after_hwframe+0x63/0xcd
    
    value changed: 0x00000000 -> 0x00000016
    
    Reported by Kernel Concurrency Sanitizer on:
    CPU: 1 PID: 28146 Comm: syz-executor.0 Not tainted 6.6.0-rc3-syzkaller-00055-g9ed22ae6be81 #0
    Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 09/06/2023
    
    Fixes: 1da177e4c3f4 ("Linux-2.6.12-rc2")
    Signed-off-by: Eric Dumazet <edumazet@google.com>
    Reported-by: syzbot <syzkaller@googlegroups.com>
    Reviewed-by: Simon Horman <horms@kernel.org>
    Link: https://lore.kernel.org/r/20231003183455.3410550-1-edumazet@google.com
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
NFSv4: Fix a nfs4_state_manager() race [+ + +]
Author: Trond Myklebust <trond.myklebust@hammerspace.com>
Date:   Sun Sep 17 19:05:50 2023 -0400

    NFSv4: Fix a nfs4_state_manager() race
    
    [ Upstream commit ed1cc05aa1f7fe8197d300e914afc28ab9818f89 ]
    
    If the NFS4CLNT_RUN_MANAGER flag got set just before we cleared
    NFS4CLNT_MANAGER_RUNNING, then we might have won the race against
    nfs4_schedule_state_manager(), and are responsible for handling the
    recovery situation.
    
    Fixes: aeabb3c96186 ("NFSv4: Fix a NFSv4 state manager deadlock")
    Signed-off-by: Trond Myklebust <trond.myklebust@hammerspace.com>
    Signed-off-by: Anna Schumaker <Anna.Schumaker@Netapp.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
of: dynamic: Fix potential memory leak in of_changeset_action() [+ + +]
Author: Dan Carpenter <dan.carpenter@linaro.org>
Date:   Fri Sep 8 10:03:50 2023 +0300

    of: dynamic: Fix potential memory leak in of_changeset_action()
    
    commit 55e95bfccf6db8d26a66c46e1de50d53c59a6774 upstream.
    
    Smatch complains that the error path where "action" is invalid leaks
    the "ce" allocation:
        drivers/of/dynamic.c:935 of_changeset_action()
        warn: possible memory leak of 'ce'
    
    Fix this by doing the validation before the allocation.
    
    Note that there is not any actual problem with upstream kernels. All
    callers of of_changeset_action() are static inlines with fixed action
    values.
    
    Fixes: 914d9d831e61 ("of: dynamic: Refactor action prints to not use "%pOF" inside devtree_lock")
    Reported-by: kernel test robot <lkp@intel.com>
    Closes: https://lore.kernel.org/r/202309011059.EOdr4im9-lkp@intel.com/
    Signed-off-by: Dan Carpenter <dan.carpenter@linaro.org>
    Reviewed-by: Geert Uytterhoeven <geert+renesas@glider.be>
    Link: https://lore.kernel.org/r/7dfaf999-30ad-491c-9615-fb1138db121c@moroto.mountain
    Signed-off-by: Rob Herring <robh@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
ovl: fetch inode once in ovl_dentry_revalidate_common() [+ + +]
Author: Al Viro <viro@zeniv.linux.org.uk>
Date:   Mon Oct 2 03:36:43 2023 +0100

    ovl: fetch inode once in ovl_dentry_revalidate_common()
    
    [ Upstream commit c54719c92aa3129f330cce81b88cf34f1627f756 ]
    
    d_inode_rcu() is right - we might be in rcu pathwalk;
    however, OVL_E() hides plain d_inode() on the same dentry...
    
    Fixes: a6ff2bc0be17 ("ovl: use OVL_E() and OVL_E_FLAGS() accessors")
    Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
    Signed-off-by: Amir Goldstein <amir73il@gmail.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

ovl: move freeing ovl_entry past rcu delay [+ + +]
Author: Al Viro <viro@zeniv.linux.org.uk>
Date:   Mon Oct 2 03:36:13 2023 +0100

    ovl: move freeing ovl_entry past rcu delay
    
    [ Upstream commit d9e8319a6e3538b430f692b5625a76ffa0758adc ]
    
    ... into ->free_inode(), that is.
    
    Fixes: 0af950f57fef "ovl: move ovl_entry into ovl_inode"
    Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
    Signed-off-by: Amir Goldstein <amir73il@gmail.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
parisc: Fix crash with nr_cpus=1 option [+ + +]
Author: Helge Deller <deller@gmx.de>
Date:   Tue Sep 19 15:26:35 2023 +0200

    parisc: Fix crash with nr_cpus=1 option
    
    commit d3b3c637e4eb8d3bbe53e5692aee66add72f9851 upstream.
    
    John David Anglin reported that giving "nr_cpus=1" on the command
    line causes a crash, while "maxcpus=1" works.
    
    Reported-by: John David Anglin <dave.anglin@bell.net>
    Signed-off-by: Helge Deller <deller@gmx.de>
    Cc: stable@vger.kernel.org # v5.18+
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

parisc: Restore __ldcw_align for PA-RISC 2.0 processors [+ + +]
Author: John David Anglin <dave@parisc-linux.org>
Date:   Tue Sep 19 17:51:40 2023 +0000

    parisc: Restore __ldcw_align for PA-RISC 2.0 processors
    
    commit 914988e099fc658436fbd7b8f240160c352b6552 upstream.
    
    Back in 2005, Kyle McMartin removed the 16-byte alignment for
    ldcw semaphores on PA 2.0 machines (CONFIG_PA20). This broke
    spinlocks on pre PA8800 processors. The main symptom was random
    faults in mmap'd memory (e.g., gcc compilations, etc).
    
    Unfortunately, the errata for this ldcw change is lost.
    
    The issue is the 16-byte alignment required for ldcw semaphore
    instructions can only be reduced to natural alignment when the
    ldcw operation can be handled coherently in cache. Only PA8800
    and PA8900 processors actually support doing the operation in
    cache.
    
    Aligning the spinlock dynamically adds two integer instructions
    to each spinlock.
    
    Tested on rp3440, c8000 and a500.
    
    Signed-off-by: John David Anglin <dave.anglin@bell.net>
    Link: https://lore.kernel.org/linux-parisc/6b332788-2227-127f-ba6d-55e99ecf4ed8@bell.net/T/#t
    Link: https://lore.kernel.org/linux-parisc/20050609050702.GB4641@roadwarrior.mcmartin.ca/
    Cc: stable@vger.kernel.org
    Signed-off-by: Helge Deller <deller@gmx.de>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
PCI/PM: Mark devices disconnected if upstream PCIe link is down on resume [+ + +]
Author: Mika Westerberg <mika.westerberg@linux.intel.com>
Date:   Mon Sep 18 08:30:41 2023 +0300

    PCI/PM: Mark devices disconnected if upstream PCIe link is down on resume
    
    commit c82458101d5490230d735caecce14c9c27b1010c upstream.
    
    Mark Blakeney reported that when suspending system with a Thunderbolt
    dock connected and then unplugging the dock before resume (which is
    pretty normal flow with laptops), resuming takes long time.
    
    What happens is that the PCIe link from the root port to the PCIe switch
    inside the Thunderbolt device does not train (as expected, the link is
    unplugged):
    
      pcieport 0000:00:07.2: restoring config space at offset 0x24 (was 0x3bf12001, writing 0x3bf12001)
      pcieport 0000:00:07.0: waiting 100 ms for downstream link
      pcieport 0000:01:00.0: not ready 1023ms after resume; giving up
    
    However, at this point we still try to resume the devices below that
    unplugged link:
    
      pcieport 0000:01:00.0: Unable to change power state from D3cold to D0, device inaccessible
      ...
      pcieport 0000:01:00.0: restoring config space at offset 0x38 (was 0xffffffff, writing 0x0)
      ...
      pcieport 0000:02:02.0: waiting 100 ms for downstream link, after activation
    
    And this is the link from PCIe switch downstream port to the xHCI on the
    dock:
    
      xhci_hcd 0000:03:00.0: not ready 65535ms after resume; giving up
      xhci_hcd 0000:03:00.0: Unable to change power state from D3cold to D0, device inaccessible
      xhci_hcd 0000:03:00.0: restoring config space at offset 0x3c (was 0xffffffff, writing 0x1ff)
    
    This ends up slowing down the resume time considerably. For this reason
    mark these devices as disconnected if the link above them did not train
    properly.
    
    Fixes: e8b908146d44 ("PCI/PM: Increase wait time after resume")
    Link: https://lore.kernel.org/r/20230918053041.1018876-1-mika.westerberg@linux.intel.com
    Reported-by: Mark Blakeney <mark.blakeney@bullet-systems.net>
    Closes: https://bugzilla.kernel.org/show_bug.cgi?id=217915
    Signed-off-by: Mika Westerberg <mika.westerberg@linux.intel.com>
    Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
    Reviewed-by: Lukas Wunner <lukas@wunner.de>
    Cc: stable@vger.kernel.org      # v6.4+
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
PCI: qcom: Fix IPQ8074 enumeration [+ + +]
Author: Sricharan Ramabadhran <quic_srichara@quicinc.com>
Date:   Tue Sep 19 15:59:48 2023 +0530

    PCI: qcom: Fix IPQ8074 enumeration
    
    commit 6a878a54d0053ef21f3b829dc267487c2302b012 upstream.
    
    PARF_SLV_ADDR_SPACE_SIZE_2_3_3 is used by qcom_pcie_post_init_2_3_3().
    This PCIe slave address space size register offset is 0x358 but was
    incorrectly changed to 0x16c by 39171b33f652 ("PCI: qcom: Remove PCIE20_
    prefix from register definitions").
    
    This prevented access to slave address space registers like iATU, etc.,
    so the IPQ8074 PCIe controller was not enumerated.
    
    Revert back to the correct 0x358 offset and remove the unused
    PARF_SLV_ADDR_SPACE_SIZE_2_3_3.
    
    Fixes: 39171b33f652 ("PCI: qcom: Remove PCIE20_ prefix from register definitions")
    Link: https://lore.kernel.org/r/20230919102948.1844909-1-quic_srichara@quicinc.com
    Tested-by: Robert Marko <robimarko@gmail.com>
    Signed-off-by: Sricharan Ramabadhran <quic_srichara@quicinc.com>
    [bhelgaas: commit log]
    Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
    Reviewed-by: Manivannan Sadhasivam <mani@kernel.org>
    Reviewed-by: Konrad Dybcio <konrad.dybcio@linaro.org>
    Cc: stable@vger.kernel.org      # v6.4+
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
perf/x86/amd/core: Fix overflow reset on hotplug [+ + +]
Author: Sandipan Das <sandipan.das@amd.com>
Date:   Thu Sep 14 19:36:04 2023 +0530

    perf/x86/amd/core: Fix overflow reset on hotplug
    
    [ Upstream commit 23d2626b841c2adccdeb477665313c02dff02dc3 ]
    
    Kernels older than v5.19 do not support PerfMonV2 and the PMI handler
    does not clear the overflow bits of the PerfCntrGlobalStatus register.
    Because of this, loading a recent kernel using kexec from an older
    kernel can result in inconsistent register states on Zen 4 systems.
    
    The PMI handler of the new kernel gets confused and shows a warning when
    an overflow occurs because some of the overflow bits are set even if the
    corresponding counters are inactive. These are remnants from overflows
    that were handled by the older kernel.
    
    During CPU hotplug, the PerfCntrGlobalCtl and PerfCntrGlobalStatus
    registers should always be cleared for PerfMonV2-capable processors.
    However, a condition used for NB event constaints applicable only to
    older processors currently prevents this from happening. Move the reset
    sequence to an appropriate place and also clear the LBR Freeze bit.
    
    Fixes: 21d59e3e2c40 ("perf/x86/amd/core: Detect PerfMonV2 support")
    Signed-off-by: Sandipan Das <sandipan.das@amd.com>
    Signed-off-by: Ingo Molnar <mingo@kernel.org>
    Link: https://lore.kernel.org/r/882a87511af40792ba69bb0e9026f19a2e71e8a3.1694696888.git.sandipan.das@amd.com
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
perf/x86/amd: Do not WARN() on every IRQ [+ + +]
Author: Breno Leitao <leitao@debian.org>
Date:   Thu Sep 14 19:58:40 2023 +0530

    perf/x86/amd: Do not WARN() on every IRQ
    
    [ Upstream commit 599522d9d2e19d6240e4312577f1c5f3ffca22f6 ]
    
    Zen 4 systems running buggy microcode can hit a WARN_ON() in the PMI
    handler, as shown below, several times while perf runs. A simple
    `perf top` run is enough to render the system unusable:
    
      WARNING: CPU: 18 PID: 20608 at arch/x86/events/amd/core.c:944 amd_pmu_v2_handle_irq+0x1be/0x2b0
    
    This happens because the Performance Counter Global Status Register
    (PerfCntGlobalStatus) has one or more bits set which are considered
    reserved according to the "AMD64 Architecture Programmer’s Manual,
    Volume 2: System Programming, 24593":
    
      https://www.amd.com/system/files/TechDocs/24593.pdf
    
    To make this less intrusive, warn just once if any reserved bit is set
    and prompt the user to update the microcode. Also sanitize the value to
    what the code is handling, so that the overflow events continue to be
    handled for the number of counters that are known to be sane.
    
    Going forward, the following microcode patch levels are recommended
    for Zen 4 processors in order to avoid such issues with reserved bits:
    
      Family=0x19 Model=0x11 Stepping=0x01: Patch=0x0a10113e
      Family=0x19 Model=0x11 Stepping=0x02: Patch=0x0a10123e
      Family=0x19 Model=0xa0 Stepping=0x01: Patch=0x0aa00116
      Family=0x19 Model=0xa0 Stepping=0x02: Patch=0x0aa00212
    
    Commit f2eb058afc57 ("linux-firmware: Update AMD cpu microcode") from
    the linux-firmware tree has binaries that meet the minimum required
    patch levels.
    
      [ sandipan: - add message to prompt users to update microcode
                  - rework commit message and call out required microcode levels ]
    
    Fixes: 7685665c390d ("perf/x86/amd/core: Add PerfMonV2 overflow handling")
    Reported-by: Jirka Hladky <jhladky@redhat.com>
    Signed-off-by: Breno Leitao <leitao@debian.org>
    Signed-off-by: Sandipan Das <sandipan.das@amd.com>
    Signed-off-by: Ingo Molnar <mingo@kernel.org>
    Link: https://lore.kernel.org/all/3540f985652f41041e54ee82aa53e7dbd55739ae.1694696888.git.sandipan.das@amd.com/
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
platform/x86/intel/ifs: release cpus_read_lock() [+ + +]
Author: Jithu Joseph <jithu.joseph@intel.com>
Date:   Wed Sep 27 11:48:24 2023 -0700

    platform/x86/intel/ifs: release cpus_read_lock()
    
    commit 2545deba314eec91dc5ca1a954fe97f91ef1cf07 upstream.
    
    Couple of error paths in do_core_test() was returning directly without
    doing a necessary cpus_read_unlock().
    
    Following lockdep warning was observed when exercising these scenarios
    with PROVE_RAW_LOCK_NESTING enabled:
    
    [  139.304775] ================================================
    [  139.311185] WARNING: lock held when returning to user space!
    [  139.317593] 6.6.0-rc2ifs01+ #11 Tainted: G S      W I
    [  139.324499] ------------------------------------------------
    [  139.330908] bash/11476 is leaving the kernel with locks still held!
    [  139.338000] 1 lock held by bash/11476:
    [  139.342262]  #0: ffffffffaa26c930 (cpu_hotplug_lock){++++}-{0:0}, at:
    do_core_test+0x35/0x1c0 [intel_ifs]
    
    Fix the flow so that all scenarios release the lock prior to returning
    from the function.
    
    Fixes: 5210fb4e1880 ("platform/x86/intel/ifs: Sysfs interface for Array BIST")
    Cc: stable@vger.kernel.org
    Signed-off-by: Jithu Joseph <jithu.joseph@intel.com>
    Link: https://lore.kernel.org/r/20230927184824.2566086-1-jithu.joseph@intel.com
    Reviewed-by: Hans de Goede <hdegoede@redhat.com>
    Signed-off-by: Hans de Goede <hdegoede@redhat.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
ptp: ocp: Fix error handling in ptp_ocp_device_init [+ + +]
Author: Dinghao Liu <dinghao.liu@zju.edu.cn>
Date:   Fri Sep 22 17:40:44 2023 +0800

    ptp: ocp: Fix error handling in ptp_ocp_device_init
    
    [ Upstream commit caa0578c1d487d39e4bb947a1b4965417053b409 ]
    
    When device_add() fails, ptp_ocp_dev_release() will be called
    after put_device(). Therefore, it seems that the
    ptp_ocp_dev_release() before put_device() is redundant.
    
    Fixes: 773bda964921 ("ptp: ocp: Expose various resources on the timecard.")
    Signed-off-by: Dinghao Liu <dinghao.liu@zju.edu.cn>
    Reviewed-by: Vadim Feodrenko <vadim.fedorenko@linux.dev>
    Signed-off-by: David S. Miller <davem@davemloft.net>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
qed/red_ll2: Fix undefined behavior bug in struct qed_ll2_info [+ + +]
Author: Gustavo A. R. Silva <gustavoars@kernel.org>
Date:   Sat Sep 23 19:15:59 2023 -0600

    qed/red_ll2: Fix undefined behavior bug in struct qed_ll2_info
    
    commit eea03d18af9c44235865a4bc9bec4d780ef6cf21 upstream.
    
    The flexible structure (a structure that contains a flexible-array member
    at the end) `qed_ll2_tx_packet` is nested within the second layer of
    `struct qed_ll2_info`:
    
    struct qed_ll2_tx_packet {
            ...
            /* Flexible Array of bds_set determined by max_bds_per_packet */
            struct {
                    struct core_tx_bd *txq_bd;
                    dma_addr_t tx_frag;
                    u16 frag_len;
            } bds_set[];
    };
    
    struct qed_ll2_tx_queue {
            ...
            struct qed_ll2_tx_packet cur_completing_packet;
    };
    
    struct qed_ll2_info {
            ...
            struct qed_ll2_tx_queue tx_queue;
            struct qed_ll2_cbs cbs;
    };
    
    The problem is that member `cbs` in `struct qed_ll2_info` is placed just
    after an object of type `struct qed_ll2_tx_queue`, which is in itself
    an implicit flexible structure, which by definition ends in a flexible
    array member, in this case `bds_set`. This causes an undefined behavior
    bug at run-time when dynamic memory is allocated for `bds_set`, which
    could lead to a serious issue if `cbs` in `struct qed_ll2_info` is
    overwritten by the contents of `bds_set`. Notice that the type of `cbs`
    is a structure full of function pointers (and a cookie :) ):
    
    include/linux/qed/qed_ll2_if.h:
    107 typedef
    108 void (*qed_ll2_complete_rx_packet_cb)(void *cxt,
    109                                       struct qed_ll2_comp_rx_data *data);
    110
    111 typedef
    112 void (*qed_ll2_release_rx_packet_cb)(void *cxt,
    113                                      u8 connection_handle,
    114                                      void *cookie,
    115                                      dma_addr_t rx_buf_addr,
    116                                      bool b_last_packet);
    117
    118 typedef
    119 void (*qed_ll2_complete_tx_packet_cb)(void *cxt,
    120                                       u8 connection_handle,
    121                                       void *cookie,
    122                                       dma_addr_t first_frag_addr,
    123                                       bool b_last_fragment,
    124                                       bool b_last_packet);
    125
    126 typedef
    127 void (*qed_ll2_release_tx_packet_cb)(void *cxt,
    128                                      u8 connection_handle,
    129                                      void *cookie,
    130                                      dma_addr_t first_frag_addr,
    131                                      bool b_last_fragment, bool b_last_packet);
    132
    133 typedef
    134 void (*qed_ll2_slowpath_cb)(void *cxt, u8 connection_handle,
    135                             u32 opaque_data_0, u32 opaque_data_1);
    136
    137 struct qed_ll2_cbs {
    138         qed_ll2_complete_rx_packet_cb rx_comp_cb;
    139         qed_ll2_release_rx_packet_cb rx_release_cb;
    140         qed_ll2_complete_tx_packet_cb tx_comp_cb;
    141         qed_ll2_release_tx_packet_cb tx_release_cb;
    142         qed_ll2_slowpath_cb slowpath_cb;
    143         void *cookie;
    144 };
    
    Fix this by moving the declaration of `cbs` to the  middle of its
    containing structure `qed_ll2_info`, preventing it from being
    overwritten by the contents of `bds_set` at run-time.
    
    This bug was introduced in 2017, when `bds_set` was converted to a
    one-element array, and started to be used as a Variable Length Object
    (VLO) at run-time.
    
    Fixes: f5823fe6897c ("qed: Add ll2 option to limit the number of bds per packet")
    Cc: stable@vger.kernel.org
    Signed-off-by: Gustavo A. R. Silva <gustavoars@kernel.org>
    Reviewed-by: Kees Cook <keescook@chromium.org>
    Reviewed-by: Simon Horman <horms@kernel.org>
    Link: https://lore.kernel.org/r/ZQ+Nz8DfPg56pIzr@work
    Signed-off-by: Paolo Abeni <pabeni@redhat.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
RDMA/bnxt_re: Fix the handling of control path response data [+ + +]
Author: Selvin Xavier <selvin.xavier@broadcom.com>
Date:   Wed Sep 20 01:41:19 2023 -0700

    RDMA/bnxt_re: Fix the handling of control path response data
    
    commit 9fc5f9a92fe6897dbed7b9295b234cb7e3cc9d11 upstream.
    
    Flag that indicate control path command completion should be cleared
    only after copying the command response data. As soon as the is_in_used
    flag is clear, the waiting thread can proceed with wrong response
    data.  This wrong data is causing multiple issues like wrong lkey
    used in data traffic and wrong AH Id etc.
    
    Use a memory barrier to ensure that the response data
    is copied and visible to the process waiting on a different
    cpu core before clearing the is_in_used flag.
    
    Clear the is_in_used after copying the command response.
    
    Fixes: bcfee4ce3e01 ("RDMA/bnxt_re: remove redundant cmdq_bitmap")
    Signed-off-by: Saravanan Vajravel <saravanan.vajravel@broadcom.com>
    Signed-off-by: Selvin Xavier <selvin.xavier@broadcom.com>
    Link: https://lore.kernel.org/r/1695199280-13520-2-git-send-email-selvin.xavier@broadcom.com
    Signed-off-by: Leon Romanovsky <leon@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
RDMA/cma: Fix truncation compilation warning in make_cma_ports [+ + +]
Author: Leon Romanovsky <leon@kernel.org>
Date:   Mon Sep 11 15:18:06 2023 +0300

    RDMA/cma: Fix truncation compilation warning in make_cma_ports
    
    commit 18126c767658ae8a831257c6cb7776c5ba5e7249 upstream.
    
    The following compilation error is false alarm as RDMA devices don't
    have such large amount of ports to actually cause to format truncation.
    
    drivers/infiniband/core/cma_configfs.c: In function ‘make_cma_ports’:
    drivers/infiniband/core/cma_configfs.c:223:57: error: ‘snprintf’ output may be truncated before the last format character [-Werror=format-truncation=]
      223 |                 snprintf(port_str, sizeof(port_str), "%u", i + 1);
          |                                                         ^
    drivers/infiniband/core/cma_configfs.c:223:17: note: ‘snprintf’ output between 2 and 11 bytes into a destination of size 10
      223 |                 snprintf(port_str, sizeof(port_str), "%u", i + 1);
          |                 ^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    cc1: all warnings being treated as errors
    make[5]: *** [scripts/Makefile.build:243: drivers/infiniband/core/cma_configfs.o] Error 1
    
    Fixes: 045959db65c6 ("IB/cma: Add configfs for rdma_cm")
    Link: https://lore.kernel.org/r/a7e3b347ee134167fa6a3787c56ef231a04bc8c2.1694434639.git.leonro@nvidia.com
    Signed-off-by: Leon Romanovsky <leonro@nvidia.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

RDMA/cma: Initialize ib_sa_multicast structure to 0 when join [+ + +]
Author: Mark Zhang <markzhang@nvidia.com>
Date:   Wed Sep 27 12:05:11 2023 +0300

    RDMA/cma: Initialize ib_sa_multicast structure to 0 when join
    
    commit e0fe97efdb00f0f32b038a4836406a82886aec9c upstream.
    
    Initialize the structure to 0 so that it's fields won't have random
    values. For example fields like rec.traffic_class (as well as
    rec.flow_label and rec.sl) is used to generate the user AH through:
      cma_iboe_join_multicast
        cma_make_mc_event
          ib_init_ah_from_mcmember
    
    And a random traffic_class causes a random IP DSCP in RoCEv2.
    
    Fixes: b5de0c60cc30 ("RDMA/cma: Fix use after free race in roce multicast join")
    Signed-off-by: Mark Zhang <markzhang@nvidia.com>
    Link: https://lore.kernel.org/r/20230927090511.603595-1-markzhang@nvidia.com
    Signed-off-by: Leon Romanovsky <leon@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
RDMA/core: Require admin capabilities to set system parameters [+ + +]
Author: Leon Romanovsky <leon@kernel.org>
Date:   Wed Oct 4 21:17:49 2023 +0300

    RDMA/core: Require admin capabilities to set system parameters
    
    commit c38d23a54445f9a8aa6831fafc9af0496ba02f9e upstream.
    
    Like any other set command, require admin permissions to do it.
    
    Cc: stable@vger.kernel.org
    Fixes: 2b34c5580226 ("RDMA/core: Add command to set ib_core device net namspace sharing mode")
    Link: https://lore.kernel.org/r/75d329fdd7381b52cbdf87910bef16c9965abb1f.1696443438.git.leon@kernel.org
    Reviewed-by: Parav Pandit <parav@nvidia.com>
    Signed-off-by: Leon Romanovsky <leonro@nvidia.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
RDMA/mlx5: Fix assigning access flags to cache mkeys [+ + +]
Author: Michael Guralnik <michaelgur@nvidia.com>
Date:   Wed Sep 20 13:01:54 2023 +0300

    RDMA/mlx5: Fix assigning access flags to cache mkeys
    
    commit 4f14c6c0213e1def48f0f887d35f44095416c67d upstream.
    
    After the change to use dynamic cache structure, new cache entries
    can be added and the mkey allocation can no longer assume that all
    mkeys created for the cache have access_flags equal to zero.
    
    Example of a flow that exposes the issue:
    A user registers MR with RO on a HCA that cannot UMR RO and the mkey is
    created outside of the cache. When the user deregisters the MR, a new
    cache entry is created to store mkeys with RO.
    
    Later, the user registers 2 MRs with RO. The first MR is reused from the
    new cache entry. When we try to get the second mkey from the cache we see
    the entry is empty so we go to the MR cache mkey allocation flow which
    would have allocated a mkey with no access flags, resulting the user getting
    a MR without RO.
    
    Fixes: dd1b913fb0d0 ("RDMA/mlx5: Cache all user cacheable mkeys on dereg MR flow")
    Reviewed-by: Edward Srouji <edwards@nvidia.com>
    Signed-off-by: Michael Guralnik <michaelgur@nvidia.com>
    Link: https://lore.kernel.org/r/8a802700b82def3ace3f77cd7a9ad9d734af87e7.1695203958.git.leonro@nvidia.com
    Signed-off-by: Leon Romanovsky <leon@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

RDMA/mlx5: Fix mkey cache possible deadlock on cleanup [+ + +]
Author: Shay Drory <shayd@nvidia.com>
Date:   Tue Sep 12 13:07:45 2023 +0300

    RDMA/mlx5: Fix mkey cache possible deadlock on cleanup
    
    commit 374012b0045780b7ad498be62e85153009bb7fe9 upstream.
    
    Fix the deadlock by refactoring the MR cache cleanup flow to flush the
    workqueue without holding the rb_lock.
    This adds a race between cache cleanup and creation of new entries which
    we solve by denied creation of new entries after cache cleanup started.
    
    Lockdep:
    WARNING: possible circular locking dependency detected
     [ 2785.326074 ] 6.2.0-rc6_for_upstream_debug_2023_01_31_14_02 #1 Not tainted
     [ 2785.339778 ] ------------------------------------------------------
     [ 2785.340848 ] devlink/53872 is trying to acquire lock:
     [ 2785.341701 ] ffff888124f8c0c8 ((work_completion)(&(&ent->dwork)->work)){+.+.}-{0:0}, at: __flush_work+0xc8/0x900
     [ 2785.343403 ]
     [ 2785.343403 ] but task is already holding lock:
     [ 2785.344464 ] ffff88817e8f1260 (&dev->cache.rb_lock){+.+.}-{3:3}, at: mlx5_mkey_cache_cleanup+0x77/0x250 [mlx5_ib]
     [ 2785.346273 ]
     [ 2785.346273 ] which lock already depends on the new lock.
     [ 2785.346273 ]
     [ 2785.347720 ]
     [ 2785.347720 ] the existing dependency chain (in reverse order) is:
     [ 2785.349003 ]
     [ 2785.349003 ] -> #1 (&dev->cache.rb_lock){+.+.}-{3:3}:
     [ 2785.350160 ]        __mutex_lock+0x14c/0x15c0
     [ 2785.350962 ]        delayed_cache_work_func+0x2d1/0x610 [mlx5_ib]
     [ 2785.352044 ]        process_one_work+0x7c2/0x1310
     [ 2785.352879 ]        worker_thread+0x59d/0xec0
     [ 2785.353636 ]        kthread+0x28f/0x330
     [ 2785.354370 ]        ret_from_fork+0x1f/0x30
     [ 2785.355135 ]
     [ 2785.355135 ] -> #0 ((work_completion)(&(&ent->dwork)->work)){+.+.}-{0:0}:
     [ 2785.356515 ]        __lock_acquire+0x2d8a/0x5fe0
     [ 2785.357349 ]        lock_acquire+0x1c1/0x540
     [ 2785.358121 ]        __flush_work+0xe8/0x900
     [ 2785.358852 ]        __cancel_work_timer+0x2c7/0x3f0
     [ 2785.359711 ]        mlx5_mkey_cache_cleanup+0xfb/0x250 [mlx5_ib]
     [ 2785.360781 ]        mlx5_ib_stage_pre_ib_reg_umr_cleanup+0x16/0x30 [mlx5_ib]
     [ 2785.361969 ]        __mlx5_ib_remove+0x68/0x120 [mlx5_ib]
     [ 2785.362960 ]        mlx5r_remove+0x63/0x80 [mlx5_ib]
     [ 2785.363870 ]        auxiliary_bus_remove+0x52/0x70
     [ 2785.364715 ]        device_release_driver_internal+0x3c1/0x600
     [ 2785.365695 ]        bus_remove_device+0x2a5/0x560
     [ 2785.366525 ]        device_del+0x492/0xb80
     [ 2785.367276 ]        mlx5_detach_device+0x1a9/0x360 [mlx5_core]
     [ 2785.368615 ]        mlx5_unload_one_devl_locked+0x5a/0x110 [mlx5_core]
     [ 2785.369934 ]        mlx5_devlink_reload_down+0x292/0x580 [mlx5_core]
     [ 2785.371292 ]        devlink_reload+0x439/0x590
     [ 2785.372075 ]        devlink_nl_cmd_reload+0xaef/0xff0
     [ 2785.372973 ]        genl_family_rcv_msg_doit.isra.0+0x1bd/0x290
     [ 2785.374011 ]        genl_rcv_msg+0x3ca/0x6c0
     [ 2785.374798 ]        netlink_rcv_skb+0x12c/0x360
     [ 2785.375612 ]        genl_rcv+0x24/0x40
     [ 2785.376295 ]        netlink_unicast+0x438/0x710
     [ 2785.377121 ]        netlink_sendmsg+0x7a1/0xca0
     [ 2785.377926 ]        sock_sendmsg+0xc5/0x190
     [ 2785.378668 ]        __sys_sendto+0x1bc/0x290
     [ 2785.379440 ]        __x64_sys_sendto+0xdc/0x1b0
     [ 2785.380255 ]        do_syscall_64+0x3d/0x90
     [ 2785.381031 ]        entry_SYSCALL_64_after_hwframe+0x46/0xb0
     [ 2785.381967 ]
     [ 2785.381967 ] other info that might help us debug this:
     [ 2785.381967 ]
     [ 2785.383448 ]  Possible unsafe locking scenario:
     [ 2785.383448 ]
     [ 2785.384544 ]        CPU0                    CPU1
     [ 2785.385383 ]        ----                    ----
     [ 2785.386193 ]   lock(&dev->cache.rb_lock);
     [ 2785.386940 ]                                lock((work_completion)(&(&ent->dwork)->work));
     [ 2785.388327 ]                                lock(&dev->cache.rb_lock);
     [ 2785.389425 ]   lock((work_completion)(&(&ent->dwork)->work));
     [ 2785.390414 ]
     [ 2785.390414 ]  *** DEADLOCK ***
     [ 2785.390414 ]
     [ 2785.391579 ] 6 locks held by devlink/53872:
     [ 2785.392341 ]  #0: ffffffff84c17a50 (cb_lock){++++}-{3:3}, at: genl_rcv+0x15/0x40
     [ 2785.393630 ]  #1: ffff888142280218 (&devlink->lock_key){+.+.}-{3:3}, at: devlink_get_from_attrs_lock+0x12d/0x2d0
     [ 2785.395324 ]  #2: ffff8881422d3c38 (&dev->lock_key){+.+.}-{3:3}, at: mlx5_unload_one_devl_locked+0x4a/0x110 [mlx5_core]
     [ 2785.397322 ]  #3: ffffffffa0e59068 (mlx5_intf_mutex){+.+.}-{3:3}, at: mlx5_detach_device+0x60/0x360 [mlx5_core]
     [ 2785.399231 ]  #4: ffff88810e3cb0e8 (&dev->mutex){....}-{3:3}, at: device_release_driver_internal+0x8d/0x600
     [ 2785.400864 ]  #5: ffff88817e8f1260 (&dev->cache.rb_lock){+.+.}-{3:3}, at: mlx5_mkey_cache_cleanup+0x77/0x250 [mlx5_ib]
    
    Fixes: b95845178328 ("RDMA/mlx5: Change the cache structure to an RB-tree")
    Signed-off-by: Shay Drory <shayd@nvidia.com>
    Signed-off-by: Michael Guralnik <michaelgur@nvidia.com>
    Signed-off-by: Leon Romanovsky <leonro@nvidia.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

RDMA/mlx5: Fix mutex unlocking on error flow for steering anchor creation [+ + +]
Author: Hamdan Igbaria <hamdani@nvidia.com>
Date:   Wed Sep 20 13:01:55 2023 +0300

    RDMA/mlx5: Fix mutex unlocking on error flow for steering anchor creation
    
    commit 2fad8f06a582cd431d398a0b3f9be21d069603ab upstream.
    
    The mutex was not unlocked on some of the error flows.
    Moved the unlock location to include all the error flow scenarios.
    
    Fixes: e1f4a52ac171 ("RDMA/mlx5: Create an indirect flow table for steering anchor")
    Reviewed-by: Mark Bloch <mbloch@nvidia.com>
    Signed-off-by: Hamdan Igbaria <hamdani@nvidia.com>
    Link: https://lore.kernel.org/r/1244a69d783da997c0af0b827c622eb00495492e.1695203958.git.leonro@nvidia.com
    Signed-off-by: Leon Romanovsky <leon@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

RDMA/mlx5: Fix NULL string error [+ + +]
Author: Shay Drory <shayd@nvidia.com>
Date:   Wed Sep 20 13:01:56 2023 +0300

    RDMA/mlx5: Fix NULL string error
    
    commit dab994bcc609a172bfdab15a0d4cb7e50e8b5458 upstream.
    
    checkpath is complaining about NULL string, change it to 'Unknown'.
    
    Fixes: 37aa5c36aa70 ("IB/mlx5: Add UARs write-combining and non-cached mapping")
    Signed-off-by: Shay Drory <shayd@nvidia.com>
    Link: https://lore.kernel.org/r/8638e5c14fadbde5fa9961874feae917073af920.1695203958.git.leonro@nvidia.com
    Signed-off-by: Leon Romanovsky <leon@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

RDMA/mlx5: Remove not-used cache disable flag [+ + +]
Author: Leon Romanovsky <leon@kernel.org>
Date:   Thu Sep 28 20:20:47 2023 +0300

    RDMA/mlx5: Remove not-used cache disable flag
    
    commit c99a7457e5bb873914a74307ba2df85f6799203b upstream.
    
    During execution of mlx5_mkey_cache_cleanup(), there is a guarantee
    that MR are not registered and/or destroyed. It means that we don't
    need newly introduced cache disable flag.
    
    Fixes: 374012b00457 ("RDMA/mlx5: Fix mkey cache possible deadlock on cleanup")
    Link: https://lore.kernel.org/r/c7e9c9f98c8ae4a7413d97d9349b29f5b0a23dbe.1695921626.git.leon@kernel.org
    Signed-off-by: Leon Romanovsky <leonro@nvidia.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
RDMA/siw: Fix connection failure handling [+ + +]
Author: Bernard Metzler <bmt@zurich.ibm.com>
Date:   Tue Sep 5 16:58:22 2023 +0200

    RDMA/siw: Fix connection failure handling
    
    commit 53a3f777049771496f791504e7dc8ef017cba590 upstream.
    
    In case immediate MPA request processing fails, the newly
    created endpoint unlinks the listening endpoint and is
    ready to be dropped. This special case was not handled
    correctly by the code handling the later TCP socket close,
    causing a NULL dereference crash in siw_cm_work_handler()
    when dereferencing a NULL listener. We now also cancel
    the useless MPA timeout, if immediate MPA request
    processing fails.
    
    This patch furthermore simplifies MPA processing in general:
    Scheduling a useless TCP socket read in sk_data_ready() upcall
    is now surpressed, if the socket is already moved out of
    TCP_ESTABLISHED state.
    
    Fixes: 6c52fdc244b5 ("rdma/siw: connection management")
    Signed-off-by: Bernard Metzler <bmt@zurich.ibm.com>
    Link: https://lore.kernel.org/r/20230905145822.446263-1-bmt@zurich.ibm.com
    Signed-off-by: Leon Romanovsky <leon@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
RDMA/srp: Do not call scsi_done() from srp_abort() [+ + +]
Author: Bart Van Assche <bvanassche@acm.org>
Date:   Wed Aug 23 13:57:27 2023 -0700

    RDMA/srp: Do not call scsi_done() from srp_abort()
    
    commit e193b7955dfad68035b983a0011f4ef3590c85eb upstream.
    
    After scmd_eh_abort_handler() has called the SCSI LLD eh_abort_handler
    callback, it performs one of the following actions:
    * Call scsi_queue_insert().
    * Call scsi_finish_command().
    * Call scsi_eh_scmd_add().
    Hence, SCSI abort handlers must not call scsi_done(). Otherwise all
    the above actions would trigger a use-after-free. Hence remove the
    scsi_done() call from srp_abort(). Keep the srp_free_req() call
    before returning SUCCESS because we may not see the command again if
    SUCCESS is returned.
    
    Cc: Bob Pearson <rpearsonhpe@gmail.com>
    Cc: Shinichiro Kawasaki <shinichiro.kawasaki@wdc.com>
    Fixes: d8536670916a ("IB/srp: Avoid having aborted requests hang")
    Signed-off-by: Bart Van Assche <bvanassche@acm.org>
    Link: https://lore.kernel.org/r/20230823205727.505681-1-bvanassche@acm.org
    Signed-off-by: Leon Romanovsky <leon@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
RDMA/uverbs: Fix typo of sizeof argument [+ + +]
Author: Konstantin Meskhidze <konstantin.meskhidze@huawei.com>
Date:   Tue Sep 5 18:32:58 2023 +0800

    RDMA/uverbs: Fix typo of sizeof argument
    
    commit c489800e0d48097fc6afebd862c6afa039110a36 upstream.
    
    Since size of 'hdr' pointer and '*hdr' structure is equal on 64-bit
    machines issue probably didn't cause any wrong behavior. But anyway,
    fixing of typo is required.
    
    Fixes: da0f60df7bd5 ("RDMA/uverbs: Prohibit write() calls with too small buffers")
    Co-developed-by: Ivanov Mikhail <ivanov.mikhail1@huawei-partners.com>
    Signed-off-by: Ivanov Mikhail <ivanov.mikhail1@huawei-partners.com>
    Signed-off-by: Konstantin Meskhidze <konstantin.meskhidze@huawei.com>
    Link: https://lore.kernel.org/r/20230905103258.1738246-1-konstantin.meskhidze@huawei.com
    Signed-off-by: Leon Romanovsky <leon@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
regmap: rbtree: Fix wrong register marked as in-cache when creating new node [+ + +]
Author: Richard Fitzgerald <rf@opensource.cirrus.com>
Date:   Fri Sep 22 16:37:11 2023 +0100

    regmap: rbtree: Fix wrong register marked as in-cache when creating new node
    
    [ Upstream commit 7a795ac8d49e2433e1b97caf5e99129daf8e1b08 ]
    
    When regcache_rbtree_write() creates a new rbtree_node it was passing the
    wrong bit number to regcache_rbtree_set_register(). The bit number is the
    offset __in number of registers__, but in the case of creating a new block
    regcache_rbtree_write() was not dividing by the address stride to get the
    number of registers.
    
    Fix this by dividing by map->reg_stride.
    Compare with regcache_rbtree_read() where the bit is checked.
    
    This bug meant that the wrong register was marked as present. The register
    that was written to the cache could not be read from the cache because it
    was not marked as cached. But a nearby register could be marked as having
    a cached value even if it was never written to the cache.
    
    Signed-off-by: Richard Fitzgerald <rf@opensource.cirrus.com>
    Fixes: 3f4ff561bc88 ("regmap: rbtree: Make cache_present bitmap per node")
    Link: https://lore.kernel.org/r/20230922153711.28103-1-rf@opensource.cirrus.com
    Signed-off-by: Mark Brown <broonie@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
regulator/core: regulator_register: set device->class earlier [+ + +]
Author: Michał Mirosław <mirq-linux@rere.qmqm.pl>
Date:   Tue Sep 19 00:50:26 2023 +0200

    regulator/core: regulator_register: set device->class earlier
    
    [ Upstream commit 8adb4e647a83cb5928c05dae95b010224aea0705 ]
    
    When fixing a memory leak in commit d3c731564e09 ("regulator: plug
    of_node leak in regulator_register()'s error path") it moved the
    device_initialize() call earlier, but did not move the `dev->class`
    initialization.  The bug was spotted and fixed by reverting part of
    the commit (in commit 5f4b204b6b81 "regulator: core: fix kobject
    release warning and memory leak in regulator_register()") but
    introducing a different bug: now early error paths use `kfree(dev)`
    instead of `put_device()` for an already initialized `struct device`.
    
    Move the missing assignments to just after `device_initialize()`.
    
    Fixes: d3c731564e09 ("regulator: plug of_node leak in regulator_register()'s error path")
    Signed-off-by: Michał Mirosław <mirq-linux@rere.qmqm.pl>
    Link: https://lore.kernel.org/r/b5b19cb458c40c9d02f3d5a7bd1ba7d97ba17279.1695077303.git.mirq-linux@rere.qmqm.pl
    Signed-off-by: Mark Brown <broonie@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
regulator: mt6358: split ops for buck and linear range LDO regulators [+ + +]
Author: Chen-Yu Tsai <wenst@chromium.org>
Date:   Wed Sep 20 16:53:34 2023 +0800

    regulator: mt6358: split ops for buck and linear range LDO regulators
    
    [ Upstream commit 7e37c851374eca2d1f6128de03195c9f7b4baaf2 ]
    
    The buck and linear range LDO (VSRAM_*) regulators share one set of ops.
    This set includes support for get/set mode. However this only makes
    sense for buck regulators, not LDOs. The callbacks were not checking
    whether the register offset and/or mask for mode setting was valid or
    not. This ends up making the kernel report "normal" mode operation for
    the LDOs.
    
    Create a new set of ops without the get/set mode callbacks for the
    linear range LDO regulators.
    
    Fixes: f67ff1bd58f0 ("regulator: mt6358: Add support for MT6358 regulator")
    Signed-off-by: Chen-Yu Tsai <wenst@chromium.org>
    Link: https://lore.kernel.org/r/20230920085336.136238-1-wenst@chromium.org
    Signed-off-by: Mark Brown <broonie@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
rswitch: Fix PHY station management clock setting [+ + +]
Author: Yoshihiro Shimoda <yoshihiro.shimoda.uh@renesas.com>
Date:   Tue Sep 26 21:30:54 2023 +0900

    rswitch: Fix PHY station management clock setting
    
    [ Upstream commit a0c55bba0d0d0b5591083f65f830940d8ae63f31 ]
    
    Fix the MPIC.PSMCS value following the programming example in the
    section 6.4.2 Management Data Clock (MDC) Setting, Ethernet MAC IP,
    S4 Hardware User Manual Rev.1.00.
    
    The value is calculated by
        MPIC.PSMCS = clk[MHz] / (MDC frequency[MHz] * 2) - 1
    with the input clock frequency from clk_get_rate() and MDC frequency
    of 2.5MHz. Otherwise, this driver cannot communicate PHYs on the R-Car
    S4 Starter Kit board.
    
    Fixes: 3590918b5d07 ("net: ethernet: renesas: Add support for "Ethernet Switch"")
    Reported-by: Tam Nguyen <tam.nguyen.xa@renesas.com>
    Signed-off-by: Yoshihiro Shimoda <yoshihiro.shimoda.uh@renesas.com>
    Tested-by: Kuninori Morimoto <kuninori.morimoto.gx@renesas.com>
    Reviewed-by: Andrew Lunn <andrew@lunn.ch>
    Link: https://lore.kernel.org/r/20230926123054.3976752-1-yoshihiro.shimoda.uh@renesas.com
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
rtla/timerlat: Do not stop user-space if a cpu is offline [+ + +]
Author: Daniel Bristot de Oliveira <bristot@kernel.org>
Date:   Fri Sep 15 15:02:32 2023 +0200

    rtla/timerlat: Do not stop user-space if a cpu is offline
    
    [ Upstream commit e8c44d3b713b96cda055a23b21e8c4f931dd159f ]
    
    If no CPU list is passed, timerlat in user-space will dispatch
    one thread per sysconf(_SC_NPROCESSORS_CONF). However, not all
    CPU might be available, for instance, if HT is disabled.
    
    Currently, rtla timerlat is stopping the session if an user-space
    thread cannot set affinity to a CPU, or if a running user-space
    thread is killed. However, this is too restrictive.
    
    So, reduce the error to a debug message, and rtla timerlat run as
    long as there is at least one user-space thread alive.
    
    Link: https://lore.kernel.org/lkml/59cf2c882900ab7de91c6ee33b382ac7fa6b4ed0.1694781909.git.bristot@kernel.org
    
    Fixes: cdca4f4e5e8e ("rtla/timerlat_top: Add timerlat user-space support")
    Signed-off-by: Daniel Bristot de Oliveira <bristot@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
rtla/timerlat_aa: Fix negative IRQ delay [+ + +]
Author: Daniel Bristot de Oliveira <bristot@kernel.org>
Date:   Fri Aug 4 17:52:12 2023 +0200

    rtla/timerlat_aa: Fix negative IRQ delay
    
    [ Upstream commit 6c73daf26420b97fb8b4a620e4ffee5c1f9d44d1 ]
    
    When estimating the IRQ timer delay, we are dealing with two different
    clock sources: the external clock source that timerlat uses as a reference
    and the clock used by the tracer. There are also two moments: the time
    reading the clock and the timer in which the event is placed in the
    buffer (the trace event timestamp).
    
    If the processor is slow or there is some hardware noise, the difference
    between the timestamp and the external clock, read can be longer than the
    IRQ handler delay, resulting in a negative time.
    
    If so, set IRQ to start delay as 0. In the end, it is less near-zero and relevant
    then the noise.
    
    Link: https://lore.kernel.org/lkml/a066fb667c7136d86dcddb3c7ccd72587db3e7c7.1691162043.git.bristot@kernel.org
    
    Fixes: 27e348b221f6 ("rtla/timerlat: Add auto-analysis core")
    Signed-off-by: Daniel Bristot de Oliveira <bristot@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

rtla/timerlat_aa: Fix previous IRQ delay for IRQs that happens after thread sample [+ + +]
Author: Daniel Bristot de Oliveira <bristot@kernel.org>
Date:   Fri Aug 4 17:52:13 2023 +0200

    rtla/timerlat_aa: Fix previous IRQ delay for IRQs that happens after thread sample
    
    [ Upstream commit 301deca09b254965661d3e971f1a60ac2ce41f5f ]
    
    timerlat auto-analysis takes note of all IRQs, before or after the
    execution of the timerlat thread.
    
    Because we cannot go backward in the trace (we will fix it when
    moving to trace-cmd lib?), timerlat aa take note of the last IRQ
    execution in the waiting for the IRQ state, and then print it
    if it is executed after the expected timer IRQ starting time.
    
    After the thread sample, the timerlat starts recording the next IRQs as
    "previous" irq for the next occurrence.
    
    However, if an IRQ happens after the thread measurement but before the
    tracing stops, it is classified as a previous IRQ. That is not
    wrong, as it can be "previous" for the subsequent activation. What is
    wrong is considering it as a potential source for the last activation.
    
    Ignore the IRQ interference that happens after the IRQ starting time for
    now. A future improvement for timerlat can be either keeping a list of
    previous IRQ execution or using the trace-cmd library. Still, it requires
    further investigation - it is a new feature.
    
    Link: https://lore.kernel.org/lkml/a44a3f5c801dcc697bacf7325b65d4a5b0460537.1691162043.git.bristot@kernel.org
    
    Fixes: 27e348b221f6 ("rtla/timerlat: Add auto-analysis core")
    Signed-off-by: Daniel Bristot de Oliveira <bristot@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

rtla/timerlat_aa: Zero thread sum after every sample analysis [+ + +]
Author: Daniel Bristot de Oliveira <bristot@kernel.org>
Date:   Fri Aug 4 17:52:11 2023 +0200

    rtla/timerlat_aa: Zero thread sum after every sample analysis
    
    [ Upstream commit 02d89917ef68acbe65c7cc2323f1db4429879878 ]
    
    The thread thread_thread_sum accounts for thread interference
    during a single activation. It was not being zeroed, so it was
    accumulating thread interference over all activations.
    
    It was not that visible when timerlat was the highest priority.
    
    Link: https://lore.kernel.org/lkml/97bff55b0141f2d01b47d9450a5672fde147b89a.1691162043.git.bristot@kernel.org
    
    Fixes: 27e348b221f6 ("rtla/timerlat: Add auto-analysis core")
    Signed-off-by: Daniel Bristot de Oliveira <bristot@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
s390/bpf: Let arch_prepare_bpf_trampoline return program size [+ + +]
Author: Song Liu <song@kernel.org>
Date:   Mon Sep 18 23:02:57 2023 -0700

    s390/bpf: Let arch_prepare_bpf_trampoline return program size
    
    [ Upstream commit cf094baa3e0f19f1f80ceaf205c80402b024386c ]
    
    arch_prepare_bpf_trampoline() for s390 currently returns 0 on success. This
    is not a problem for regular trampoline. However, struct_ops relies on the
    return value to advance "image" pointer:
    
    bpf_struct_ops_map_update_elem() {
        ...
        for_each_member(i, t, member) {
            ...
            err = bpf_struct_ops_prepare_trampoline();
            ...
            image += err;
        }
    }
    
    When arch_prepare_bpf_trampoline returns 0 on success, all members of the
    struct_ops will point to the same trampoline (the last one).
    
    Fix this by returning the program size in arch_prepare_bpf_trampoline (on
    success). This is the same behavior as other architectures.
    
    Signed-off-by: Song Liu <song@kernel.org>
    Fixes: 528eb2cb87bc ("s390/bpf: Implement arch_prepare_bpf_trampoline()")
    Reviewed-by: Ilya Leoshkevich <iii@linux.ibm.com>
    Link: https://lore.kernel.org/r/20230919060258.3237176-2-song@kernel.org
    Signed-off-by: Alexei Starovoitov <ast@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
scsi: core: Improve type safety of scsi_rescan_device() [+ + +]
Author: Bart Van Assche <bvanassche@acm.org>
Date:   Tue Aug 22 08:30:41 2023 -0700

    scsi: core: Improve type safety of scsi_rescan_device()
    
    [ Upstream commit 79519528a180c64a90863db2ce70887de6c49d16 ]
    
    Most callers of scsi_rescan_device() have the scsi_device pointer readily
    available. Pass a struct scsi_device pointer to scsi_rescan_device()
    instead of a struct device pointer. This change prevents that a pointer to
    another struct device would be passed accidentally to scsi_rescan_device().
    
    Remove the scsi_rescan_device() declaration from the scsi_priv.h header
    file since it duplicates the declaration in <scsi/scsi_host.h>.
    
    Reviewed-by: Hannes Reinecke <hare@suse.de>
    Reviewed-by: Damien Le Moal <damien.lemoal@opensource.wdc.com>
    Reviewed-by: John Garry <john.g.garry@oracle.com>
    Cc: Mike Christie <michael.christie@oracle.com>
    Cc: Ming Lei <ming.lei@redhat.com>
    Signed-off-by: Bart Van Assche <bvanassche@acm.org>
    Link: https://lore.kernel.org/r/20230822153043.4046244-1-bvanassche@acm.org
    Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
    Stable-dep-of: 8b4d9469d0b0 ("ata: libata-scsi: Fix delayed scsi_rescan_device() execution")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

scsi: Do not attempt to rescan suspended devices [+ + +]
Author: Damien Le Moal <dlemoal@kernel.org>
Date:   Fri Sep 15 15:00:13 2023 +0900

    scsi: Do not attempt to rescan suspended devices
    
    [ Upstream commit ff48b37802e5c134e2dfc4d091f10b2eb5065a72 ]
    
    scsi_rescan_device() takes a scsi device lock before executing a device
    handler and device driver rescan methods. Waiting for the completion of
    any command issued to the device by these methods will thus be done with
    the device lock held. As a result, there is a risk of deadlocking within
    the power management code if scsi_rescan_device() is called to handle a
    device resume with the associated scsi device not yet resumed.
    
    Avoid such situation by checking that the target scsi device is in the
    running state, that is, fully capable of executing commands, before
    proceeding with the rescan and bailout returning -EWOULDBLOCK otherwise.
    With this error return, the caller can retry rescaning the device after
    a delay.
    
    The state check is done with the device lock held and is thus safe
    against incoming suspend power management operations.
    
    Fixes: 6aa0365a3c85 ("ata: libata-scsi: Avoid deadlock on rescan after device resume")
    Cc: stable@vger.kernel.org
    Signed-off-by: Damien Le Moal <dlemoal@kernel.org>
    Reviewed-by: Hannes Reinecke <hare@suse.de>
    Reviewed-by: Niklas Cassel <niklas.cassel@wdc.com>
    Tested-by: Geert Uytterhoeven <geert+renesas@glider.be>
    Reviewed-by: Martin K. Petersen <martin.petersen@oracle.com>
    Reviewed-by: Bart Van Assche <bvanassche@acm.org>
    Stable-dep-of: 8b4d9469d0b0 ("ata: libata-scsi: Fix delayed scsi_rescan_device() execution")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

scsi: target: core: Fix deadlock due to recursive locking [+ + +]
Author: Junxiao Bi <junxiao.bi@oracle.com>
Date:   Mon Sep 18 15:58:48 2023 -0700

    scsi: target: core: Fix deadlock due to recursive locking
    
    [ Upstream commit a154f5f643c6ecddd44847217a7a3845b4350003 ]
    
    The following call trace shows a deadlock issue due to recursive locking of
    mutex "device_mutex". First lock acquire is in target_for_each_device() and
    second in target_free_device().
    
     PID: 148266   TASK: ffff8be21ffb5d00  CPU: 10   COMMAND: "iscsi_ttx"
      #0 [ffffa2bfc9ec3b18] __schedule at ffffffffa8060e7f
      #1 [ffffa2bfc9ec3ba0] schedule at ffffffffa8061224
      #2 [ffffa2bfc9ec3bb8] schedule_preempt_disabled at ffffffffa80615ee
      #3 [ffffa2bfc9ec3bc8] __mutex_lock at ffffffffa8062fd7
      #4 [ffffa2bfc9ec3c40] __mutex_lock_slowpath at ffffffffa80631d3
      #5 [ffffa2bfc9ec3c50] mutex_lock at ffffffffa806320c
      #6 [ffffa2bfc9ec3c68] target_free_device at ffffffffc0935998 [target_core_mod]
      #7 [ffffa2bfc9ec3c90] target_core_dev_release at ffffffffc092f975 [target_core_mod]
      #8 [ffffa2bfc9ec3ca0] config_item_put at ffffffffa79d250f
      #9 [ffffa2bfc9ec3cd0] config_item_put at ffffffffa79d2583
     #10 [ffffa2bfc9ec3ce0] target_devices_idr_iter at ffffffffc0933f3a [target_core_mod]
     #11 [ffffa2bfc9ec3d00] idr_for_each at ffffffffa803f6fc
     #12 [ffffa2bfc9ec3d60] target_for_each_device at ffffffffc0935670 [target_core_mod]
     #13 [ffffa2bfc9ec3d98] transport_deregister_session at ffffffffc0946408 [target_core_mod]
     #14 [ffffa2bfc9ec3dc8] iscsit_close_session at ffffffffc09a44a6 [iscsi_target_mod]
     #15 [ffffa2bfc9ec3df0] iscsit_close_connection at ffffffffc09a4a88 [iscsi_target_mod]
     #16 [ffffa2bfc9ec3df8] finish_task_switch at ffffffffa76e5d07
     #17 [ffffa2bfc9ec3e78] iscsit_take_action_for_connection_exit at ffffffffc0991c23 [iscsi_target_mod]
     #18 [ffffa2bfc9ec3ea0] iscsi_target_tx_thread at ffffffffc09a403b [iscsi_target_mod]
     #19 [ffffa2bfc9ec3f08] kthread at ffffffffa76d8080
     #20 [ffffa2bfc9ec3f50] ret_from_fork at ffffffffa8200364
    
    Fixes: 36d4cb460bcb ("scsi: target: Avoid that EXTENDED COPY commands trigger lock inversion")
    Signed-off-by: Junxiao Bi <junxiao.bi@oracle.com>
    Link: https://lore.kernel.org/r/20230918225848.66463-1-junxiao.bi@oracle.com
    Reviewed-by: Mike Christie <michael.christie@oracle.com>
    Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

scsi: zfcp: Fix a double put in zfcp_port_enqueue() [+ + +]
Author: Dinghao Liu <dinghao.liu@zju.edu.cn>
Date:   Sat Sep 23 18:37:23 2023 +0800

    scsi: zfcp: Fix a double put in zfcp_port_enqueue()
    
    commit b481f644d9174670b385c3a699617052cd2a79d3 upstream.
    
    When device_register() fails, zfcp_port_release() will be called after
    put_device(). As a result, zfcp_ccw_adapter_put() will be called twice: one
    in zfcp_port_release() and one in the error path after device_register().
    So the reference on the adapter object is doubly put, which may lead to a
    premature free. Fix this by adjusting the error tag after
    device_register().
    
    Fixes: f3450c7b9172 ("[SCSI] zfcp: Replace local reference counting with common kref")
    Signed-off-by: Dinghao Liu <dinghao.liu@zju.edu.cn>
    Link: https://lore.kernel.org/r/20230923103723.10320-1-dinghao.liu@zju.edu.cn
    Acked-by: Benjamin Block <bblock@linux.ibm.com>
    Cc: stable@vger.kernel.org # v2.6.33+
    Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
sctp: update hb timer immediately after users change hb_interval [+ + +]
Author: Xin Long <lucien.xin@gmail.com>
Date:   Sun Oct 1 11:04:20 2023 -0400

    sctp: update hb timer immediately after users change hb_interval
    
    [ Upstream commit 1f4e803cd9c9166eb8b6c8b0b8e4124f7499fc07 ]
    
    Currently, when hb_interval is changed by users, it won't take effect
    until the next expiry of hb timer. As the default value is 30s, users
    have to wait up to 30s to wait its hb_interval update to work.
    
    This becomes pretty bad in containers where a much smaller value is
    usually set on hb_interval. This patch improves it by resetting the
    hb timer immediately once the value of hb_interval is updated by users.
    
    Note that we don't address the already existing 'problem' when sending
    a heartbeat 'on demand' if one hb has just been sent(from the timer)
    mentioned in:
    
      https://www.mail-archive.com/linux-kernel@vger.kernel.org/msg590224.html
    
    Signed-off-by: Xin Long <lucien.xin@gmail.com>
    Reviewed-by: Simon Horman <horms@kernel.org>
    Fixes: 1da177e4c3f4 ("Linux-2.6.12-rc2")
    Link: https://lore.kernel.org/r/75465785f8ee5df2fb3acdca9b8fafdc18984098.1696172660.git.lucien.xin@gmail.com
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

sctp: update transport state when processing a dupcook packet [+ + +]
Author: Xin Long <lucien.xin@gmail.com>
Date:   Sun Oct 1 10:58:45 2023 -0400

    sctp: update transport state when processing a dupcook packet
    
    [ Upstream commit 2222a78075f0c19ca18db53fd6623afb4aff602d ]
    
    During the 4-way handshake, the transport's state is set to ACTIVE in
    sctp_process_init() when processing INIT_ACK chunk on client or
    COOKIE_ECHO chunk on server.
    
    In the collision scenario below:
    
      192.168.1.2 > 192.168.1.1: sctp (1) [INIT] [init tag: 3922216408]
        192.168.1.1 > 192.168.1.2: sctp (1) [INIT] [init tag: 144230885]
        192.168.1.2 > 192.168.1.1: sctp (1) [INIT ACK] [init tag: 3922216408]
        192.168.1.1 > 192.168.1.2: sctp (1) [COOKIE ECHO]
        192.168.1.2 > 192.168.1.1: sctp (1) [COOKIE ACK]
      192.168.1.1 > 192.168.1.2: sctp (1) [INIT ACK] [init tag: 3914796021]
    
    when processing COOKIE_ECHO on 192.168.1.2, as it's in COOKIE_WAIT state,
    sctp_sf_do_dupcook_b() is called by sctp_sf_do_5_2_4_dupcook() where it
    creates a new association and sets its transport to ACTIVE then updates
    to the old association in sctp_assoc_update().
    
    However, in sctp_assoc_update(), it will skip the transport update if it
    finds a transport with the same ipaddr already existing in the old asoc,
    and this causes the old asoc's transport state not to move to ACTIVE
    after the handshake.
    
    This means if DATA retransmission happens at this moment, it won't be able
    to enter PF state because of the check 'transport->state == SCTP_ACTIVE'
    in sctp_do_8_2_transport_strike().
    
    This patch fixes it by updating the transport in sctp_assoc_update() with
    sctp_assoc_add_peer() where it updates the transport state if there is
    already a transport with the same ipaddr exists in the old asoc.
    
    Signed-off-by: Xin Long <lucien.xin@gmail.com>
    Reviewed-by: Simon Horman <horms@kernel.org>
    Fixes: 1da177e4c3f4 ("Linux-2.6.12-rc2")
    Link: https://lore.kernel.org/r/fd17356abe49713ded425250cc1ae51e9f5846c6.1696172325.git.lucien.xin@gmail.com
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
selftests: netfilter: Extend nft_audit.sh [+ + +]
Author: Phil Sutter <phil@nwl.cc>
Date:   Sat Sep 23 03:53:49 2023 +0200

    selftests: netfilter: Extend nft_audit.sh
    
    [ Upstream commit 203bb9d39866d3c5a8135433ce3742fe4f9d5741 ]
    
    Add tests for sets and elements and deletion of all kinds. Also
    reorder rule reset tests: By moving the bulk rule add command up, the
    two 'reset rules' tests become identical.
    
    While at it, fix for a failing bulk rule add test's error status getting
    lost due to its use in a pipe. Avoid this by using a temporary file.
    
    Headings in diff output for failing tests contain no useful data, strip
    them.
    
    Signed-off-by: Phil Sutter <phil@nwl.cc>
    Signed-off-by: Florian Westphal <fw@strlen.de>
    Stable-dep-of: 0d880dc6f032 ("netfilter: nf_tables: Deduplicate nft_register_obj audit logs")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

selftests: netfilter: Test nf_tables audit logging [+ + +]
Author: Phil Sutter <phil@nwl.cc>
Date:   Wed Sep 13 15:51:37 2023 +0200

    selftests: netfilter: Test nf_tables audit logging
    
    [ Upstream commit e8dbde59ca3fe925d0105bfb380e8429928b16dd ]
    
    Compare NETFILTER_CFG type audit logs emitted from kernel upon ruleset
    modifications against expected output.
    
    Signed-off-by: Phil Sutter <phil@nwl.cc>
    Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
    Stable-dep-of: 0d880dc6f032 ("netfilter: nf_tables: Deduplicate nft_register_obj audit logs")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
smb: use kernel_connect() and kernel_bind() [+ + +]
Author: Jordan Rife <jrife@google.com>
Date:   Tue Oct 3 20:13:03 2023 -0500

    smb: use kernel_connect() and kernel_bind()
    
    commit cedc019b9f260facfadd20c6c490e403abf292e3 upstream.
    
    Recent changes to kernel_connect() and kernel_bind() ensure that
    callers are insulated from changes to the address parameter made by BPF
    SOCK_ADDR hooks. This patch wraps direct calls to ops->connect() and
    ops->bind() with kernel_connect() and kernel_bind() to ensure that SMB
    mounts do not see their mount address overwritten in such cases.
    
    Link: https://lore.kernel.org/netdev/9944248dba1bce861375fcce9de663934d933ba9.camel@redhat.com/
    Cc: <stable@vger.kernel.org> # 6.0+
    Signed-off-by: Jordan Rife <jrife@google.com>
    Acked-by: Paulo Alcantara (SUSE) <pc@manguebit.com>
    Signed-off-by: Steve French <stfrench@microsoft.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
tcp: fix delayed ACKs for MSS boundary condition [+ + +]
Author: Neal Cardwell <ncardwell@google.com>
Date:   Sun Oct 1 11:12:39 2023 -0400

    tcp: fix delayed ACKs for MSS boundary condition
    
    [ Upstream commit 4720852ed9afb1c5ab84e96135cb5b73d5afde6f ]
    
    This commit fixes poor delayed ACK behavior that can cause poor TCP
    latency in a particular boundary condition: when an application makes
    a TCP socket write that is an exact multiple of the MSS size.
    
    The problem is that there is painful boundary discontinuity in the
    current delayed ACK behavior. With the current delayed ACK behavior,
    we have:
    
    (1) If an app reads data when > 1*MSS is unacknowledged, then
        tcp_cleanup_rbuf() ACKs immediately because of:
    
         tp->rcv_nxt - tp->rcv_wup > icsk->icsk_ack.rcv_mss ||
    
    (2) If an app reads all received data, and the packets were < 1*MSS,
        and either (a) the app is not ping-pong or (b) we received two
        packets < 1*MSS, then tcp_cleanup_rbuf() ACKs immediately beecause
        of:
    
         ((icsk->icsk_ack.pending & ICSK_ACK_PUSHED2) ||
          ((icsk->icsk_ack.pending & ICSK_ACK_PUSHED) &&
           !inet_csk_in_pingpong_mode(sk))) &&
    
    (3) *However*: if an app reads exactly 1*MSS of data,
        tcp_cleanup_rbuf() does not send an immediate ACK. This is true
        even if the app is not ping-pong and the 1*MSS of data had the PSH
        bit set, suggesting the sending application completed an
        application write.
    
    Thus if the app is not ping-pong, we have this painful case where
    >1*MSS gets an immediate ACK, and <1*MSS gets an immediate ACK, but a
    write whose last skb is an exact multiple of 1*MSS can get a 40ms
    delayed ACK. This means that any app that transfers data in one
    direction and takes care to align write size or packet size with MSS
    can suffer this problem. With receive zero copy making 4KB MSS values
    more common, it is becoming more common to have application writes
    naturally align with MSS, and more applications are likely to
    encounter this delayed ACK problem.
    
    The fix in this commit is to refine the delayed ACK heuristics with a
    simple check: immediately ACK a received 1*MSS skb with PSH bit set if
    the app reads all data. Why? If an skb has a len of exactly 1*MSS and
    has the PSH bit set then it is likely the end of an application
    write. So more data may not be arriving soon, and yet the data sender
    may be waiting for an ACK if cwnd-bound or using TX zero copy. Thus we
    set ICSK_ACK_PUSHED in this case so that tcp_cleanup_rbuf() will send
    an ACK immediately if the app reads all of the data and is not
    ping-pong. Note that this logic is also executed for the case where
    len > MSS, but in that case this logic does not matter (and does not
    hurt) because tcp_cleanup_rbuf() will always ACK immediately if the
    app reads data and there is more than an MSS of unACKed data.
    
    Fixes: 1da177e4c3f4 ("Linux-2.6.12-rc2")
    Signed-off-by: Neal Cardwell <ncardwell@google.com>
    Reviewed-by: Yuchung Cheng <ycheng@google.com>
    Reviewed-by: Eric Dumazet <edumazet@google.com>
    Cc: Xin Guo <guoxin0309@gmail.com>
    Link: https://lore.kernel.org/r/20231001151239.1866845-2-ncardwell.sw@gmail.com
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

tcp: fix quick-ack counting to count actual ACKs of new data [+ + +]
Author: Neal Cardwell <ncardwell@google.com>
Date:   Sun Oct 1 11:12:38 2023 -0400

    tcp: fix quick-ack counting to count actual ACKs of new data
    
    [ Upstream commit 059217c18be6757b95bfd77ba53fb50b48b8a816 ]
    
    This commit fixes quick-ack counting so that it only considers that a
    quick-ack has been provided if we are sending an ACK that newly
    acknowledges data.
    
    The code was erroneously using the number of data segments in outgoing
    skbs when deciding how many quick-ack credits to remove. This logic
    does not make sense, and could cause poor performance in
    request-response workloads, like RPC traffic, where requests or
    responses can be multi-segment skbs.
    
    When a TCP connection decides to send N quick-acks, that is to
    accelerate the cwnd growth of the congestion control module
    controlling the remote endpoint of the TCP connection. That quick-ack
    decision is purely about the incoming data and outgoing ACKs. It has
    nothing to do with the outgoing data or the size of outgoing data.
    
    And in particular, an ACK only serves the intended purpose of allowing
    the remote congestion control to grow the congestion window quickly if
    the ACK is ACKing or SACKing new data.
    
    The fix is simple: only count packets as serving the goal of the
    quickack mechanism if they are ACKing/SACKing new data. We can tell
    whether this is the case by checking inet_csk_ack_scheduled(), since
    we schedule an ACK exactly when we are ACKing/SACKing new data.
    
    Fixes: fc6415bcb0f5 ("[TCP]: Fix quick-ack decrementing with TSO.")
    Signed-off-by: Neal Cardwell <ncardwell@google.com>
    Reviewed-by: Yuchung Cheng <ycheng@google.com>
    Reviewed-by: Eric Dumazet <edumazet@google.com>
    Link: https://lore.kernel.org/r/20231001151239.1866845-1-ncardwell.sw@gmail.com
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
tipc: fix a potential deadlock on &tx->lock [+ + +]
Author: Chengfeng Ye <dg573847474@gmail.com>
Date:   Wed Sep 27 18:14:14 2023 +0000

    tipc: fix a potential deadlock on &tx->lock
    
    [ Upstream commit 08e50cf071847323414df0835109b6f3560d44f5 ]
    
    It seems that tipc_crypto_key_revoke() could be be invoked by
    wokequeue tipc_crypto_work_rx() under process context and
    timer/rx callback under softirq context, thus the lock acquisition
    on &tx->lock seems better use spin_lock_bh() to prevent possible
    deadlock.
    
    This flaw was found by an experimental static analysis tool I am
    developing for irq-related deadlock.
    
    tipc_crypto_work_rx() <workqueue>
    --> tipc_crypto_key_distr()
    --> tipc_bcast_xmit()
    --> tipc_bcbase_xmit()
    --> tipc_bearer_bc_xmit()
    --> tipc_crypto_xmit()
    --> tipc_ehdr_build()
    --> tipc_crypto_key_revoke()
    --> spin_lock(&tx->lock)
    <timer interrupt>
       --> tipc_disc_timeout()
       --> tipc_bearer_xmit_skb()
       --> tipc_crypto_xmit()
       --> tipc_ehdr_build()
       --> tipc_crypto_key_revoke()
       --> spin_lock(&tx->lock) <deadlock here>
    
    Signed-off-by: Chengfeng Ye <dg573847474@gmail.com>
    Reviewed-by: Jacob Keller <jacob.e.keller@intel.com>
    Acked-by: Jon Maloy <jmaloy@redhat.com>
    Fixes: fc1b6d6de220 ("tipc: introduce TIPC encryption & authentication")
    Link: https://lore.kernel.org/r/20230927181414.59928-1-dg573847474@gmail.com
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
ubi: Refuse attaching if mtd's erasesize is 0 [+ + +]
Author: Zhihao Cheng <chengzhihao1@huawei.com>
Date:   Sun Apr 23 19:10:41 2023 +0800

    ubi: Refuse attaching if mtd's erasesize is 0
    
    [ Upstream commit 017c73a34a661a861712f7cc1393a123e5b2208c ]
    
    There exists mtd devices with zero erasesize, which will trigger a
    divide-by-zero exception while attaching ubi device.
    Fix it by refusing attaching if mtd's erasesize is 0.
    
    Fixes: 801c135ce73d ("UBI: Unsorted Block Images")
    Reported-by: Yu Hao <yhao016@ucr.edu>
    Link: https://lore.kernel.org/lkml/977347543.226888.1682011999468.JavaMail.zimbra@nod.at/T/
    Signed-off-by: Zhihao Cheng <chengzhihao1@huawei.com>
    Reviewed-by: Miquel Raynal <miquel.raynal@bootlin.com>
    Signed-off-by: Richard Weinberger <richard@nod.at>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

 
vringh: don't use vringh_kiov_advance() in vringh_iov_xfer() [+ + +]
Author: Stefano Garzarella <sgarzare@redhat.com>
Date:   Mon Sep 25 12:30:57 2023 +0200

    vringh: don't use vringh_kiov_advance() in vringh_iov_xfer()
    
    commit 7aed44babc7f97e82b38e9a68515e699692cc100 upstream.
    
    In the while loop of vringh_iov_xfer(), `partlen` could be 0 if one of
    the `iov` has 0 lenght.
    In this case, we should skip the iov and go to the next one.
    But calling vringh_kiov_advance() with 0 lenght does not cause the
    advancement, since it returns immediately if asked to advance by 0 bytes.
    
    Let's restore the code that was there before commit b8c06ad4d67d
    ("vringh: implement vringh_kiov_advance()"), avoiding using
    vringh_kiov_advance().
    
    Fixes: b8c06ad4d67d ("vringh: implement vringh_kiov_advance()")
    Cc: stable@vger.kernel.org
    Reported-by: Jason Wang <jasowang@redhat.com>
    Signed-off-by: Stefano Garzarella <sgarzare@redhat.com>
    Acked-by: Jason Wang <jasowang@redhat.com>
    Signed-off-by: David S. Miller <davem@davemloft.net>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
wifi: brcmfmac: Replace 1-element arrays with flexible arrays [+ + +]
Author: Juerg Haefliger <juerg.haefliger@canonical.com>
Date:   Thu Sep 14 09:02:27 2023 +0200

    wifi: brcmfmac: Replace 1-element arrays with flexible arrays
    
    commit 4fed494abcd4fde5c24de19160e93814f912fdb3 upstream.
    
    Since commit 2d47c6956ab3 ("ubsan: Tighten UBSAN_BOUNDS on GCC"),
    UBSAN_BOUNDS no longer pretends 1-element arrays are unbounded. Walking
    'element' and 'channel_list' will trigger warnings, so make them proper
    flexible arrays.
    
    False positive warnings were:
    
      UBSAN: array-index-out-of-bounds in drivers/net/wireless/broadcom/brcm80211/brcmfmac/cfg80211.c:6984:20
      index 1 is out of range for type '__le32 [1]'
    
      UBSAN: array-index-out-of-bounds in drivers/net/wireless/broadcom/brcm80211/brcmfmac/cfg80211.c:1126:27
      index 1 is out of range for type '__le16 [1]'
    
    for these lines of code:
    
      6884  ch.chspec = (u16)le32_to_cpu(list->element[i]);
    
      1126  params_le->channel_list[i] = cpu_to_le16(chanspec);
    
    Cc: stable@vger.kernel.org # 6.5+
    Signed-off-by: Juerg Haefliger <juerg.haefliger@canonical.com>
    Reviewed-by: Kees Cook <keescook@chromium.org>
    Reviewed-by: Gustavo A. R. Silva <gustavoars@kernel.org>
    Signed-off-by: Kalle Valo <kvalo@kernel.org>
    Link: https://lore.kernel.org/r/20230914070227.12028-1-juerg.haefliger@canonical.com
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

wifi: cfg80211/mac80211: hold link BSSes when assoc fails for MLO connection [+ + +]
Author: Wen Gong <quic_wgong@quicinc.com>
Date:   Fri Aug 25 03:00:55 2023 -0400

    wifi: cfg80211/mac80211: hold link BSSes when assoc fails for MLO connection
    
    [ Upstream commit 234249d88b091d006b82f8d570343aae5f383736 ]
    
    When connect to MLO AP with more than one link, and the assoc response of
    AP is not success, then cfg80211_unhold_bss() is not called for all the
    links' cfg80211_bss except the primary link which means the link used by
    the latest successful association request. Thus the hold value of the
    cfg80211_bss is not reset to 0 after the assoc fail, and then the
    __cfg80211_unlink_bss() will not be called for the cfg80211_bss by
    __cfg80211_bss_expire().
    
    Then the AP always looks exist even the AP is shutdown or reconfigured
    to another type, then it will lead error while connecting it again.
    
    The detail info are as below.
    
    When connect with muti-links AP, cfg80211_hold_bss() is called by
    cfg80211_mlme_assoc() for each cfg80211_bss of all the links. When
    assoc response from AP is not success(such as status_code==1), the
    ieee80211_link_data of non-primary link(sdata->link[link_id]) is NULL
    because ieee80211_assoc_success()->ieee80211_vif_update_links() is
    not called for the links.
    
    Then struct cfg80211_rx_assoc_resp resp in cfg80211_rx_assoc_resp() and
    struct cfg80211_connect_resp_params cr in __cfg80211_connect_result()
    will only have the data of the primary link, and finally function
    cfg80211_connect_result_release_bsses() only call cfg80211_unhold_bss()
    for the primary link. Then cfg80211_bss of the other links will never free
    because its hold is always > 0 now.
    
    Hence assign value for the bss and status from assoc_data since it is
    valid for this case. Also assign value of addr from assoc_data when the
    link is NULL because the addrs of assoc_data and link both represent the
    local link addr and they are same value for success connection.
    
    Fixes: 81151ce462e5 ("wifi: mac80211: support MLO authentication/association with one link")
    Signed-off-by: Wen Gong <quic_wgong@quicinc.com>
    Link: https://lore.kernel.org/r/20230825070055.28164-1-quic_wgong@quicinc.com
    Signed-off-by: Johannes Berg <johannes.berg@intel.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

wifi: cfg80211: add missing kernel-doc for cqm_rssi_work [+ + +]
Author: Johannes Berg <johannes.berg@intel.com>
Date:   Wed Sep 13 09:36:57 2023 +0200

    wifi: cfg80211: add missing kernel-doc for cqm_rssi_work
    
    [ Upstream commit d1383077c225ceb87ac7a3b56b2c505193f77ed7 ]
    
    As reported by Stephen, I neglected to add the kernel-doc
    for the new struct member. Fix that.
    
    Reported-by: Stephen Rothwell <sfr@canb.auug.org.au>
    Fixes: 37c20b2effe9 ("wifi: cfg80211: fix cqm_config access race")
    Signed-off-by: Johannes Berg <johannes.berg@intel.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

wifi: cfg80211: fix cqm_config access race [+ + +]
Author: Johannes Berg <johannes.berg@intel.com>
Date:   Wed Aug 16 15:38:04 2023 +0200

    wifi: cfg80211: fix cqm_config access race
    
    [ Upstream commit 37c20b2effe987b806c8de6d12978e4ffeff026f ]
    
    Max Schulze reports crashes with brcmfmac. The reason seems
    to be a race between userspace removing the CQM config and
    the driver calling cfg80211_cqm_rssi_notify(), where if the
    data is freed while cfg80211_cqm_rssi_notify() runs it will
    crash since it assumes wdev->cqm_config is set. This can't
    be fixed with a simple non-NULL check since there's nothing
    we can do for locking easily, so use RCU instead to protect
    the pointer, but that requires pulling the updates out into
    an asynchronous worker so they can sleep and call back into
    the driver.
    
    Since we need to change the free anyway, also change it to
    go back to the old settings if changing the settings fails.
    
    Reported-and-tested-by: Max Schulze <max.schulze@online.de>
    Closes: https://lore.kernel.org/r/ac96309a-8d8d-4435-36e6-6d152eb31876@online.de
    Fixes: 4a4b8169501b ("cfg80211: Accept multiple RSSI thresholds for CQM")
    Signed-off-by: Johannes Berg <johannes.berg@intel.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

wifi: iwlwifi: dbg_ini: fix structure packing [+ + +]
Author: Arnd Bergmann <arnd@arndb.de>
Date:   Fri Jun 16 11:03:34 2023 +0200

    wifi: iwlwifi: dbg_ini: fix structure packing
    
    [ Upstream commit 424c82e8ad56756bb98b08268ffcf68d12d183eb ]
    
    The iwl_fw_ini_error_dump_range structure has conflicting alignment
    requirements for the inner union and the outer struct:
    
    In file included from drivers/net/wireless/intel/iwlwifi/fw/dbg.c:9:
    drivers/net/wireless/intel/iwlwifi/fw/error-dump.h:312:2: error: field  within 'struct iwl_fw_ini_error_dump_range' is less aligned than 'union iwl_fw_ini_error_dump_range::(anonymous at drivers/net/wireless/intel/iwlwifi/fw/error-dump.h:312:2)' and is usually due to 'struct iwl_fw_ini_error_dump_range' being packed, which can lead to unaligned accesses [-Werror,-Wunaligned-access]
            union {
    
    As the original intention was apparently to make the entire structure
    unaligned, mark the innermost members the same way so the union
    becomes packed as well.
    
    Fixes: 973193554cae6 ("iwlwifi: dbg_ini: dump headers cleanup")
    Signed-off-by: Arnd Bergmann <arnd@arndb.de>
    Acked-by: Gregory Greenman <gregory.greenman@intel.com>
    Link: https://lore.kernel.org/r/20230616090343.2454061-1-arnd@kernel.org
    Signed-off-by: Johannes Berg <johannes.berg@intel.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

wifi: iwlwifi: mvm: Fix a memory corruption issue [+ + +]
Author: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
Date:   Sun Jul 23 22:24:59 2023 +0200

    wifi: iwlwifi: mvm: Fix a memory corruption issue
    
    [ Upstream commit 8ba438ef3cacc4808a63ed0ce24d4f0942cfe55d ]
    
    A few lines above, space is kzalloc()'ed for:
            sizeof(struct iwl_nvm_data) +
            sizeof(struct ieee80211_channel) +
            sizeof(struct ieee80211_rate)
    
    'mvm->nvm_data' is a 'struct iwl_nvm_data', so it is fine.
    
    At the end of this structure, there is the 'channels' flex array.
    Each element is of type 'struct ieee80211_channel'.
    So only 1 element is allocated in this array.
    
    When doing:
      mvm->nvm_data->bands[0].channels = mvm->nvm_data->channels;
    We point at the first element of the 'channels' flex array.
    So this is fine.
    
    However, when doing:
      mvm->nvm_data->bands[0].bitrates =
                            (void *)((u8 *)mvm->nvm_data->channels + 1);
    because of the "(u8 *)" cast, we add only 1 to the address of the beginning
    of the flex array.
    
    It is likely that we want point at the 'struct ieee80211_rate' allocated
    just after.
    
    Remove the spurious casting so that the pointer arithmetic works as
    expected.
    
    Fixes: 8ca151b568b6 ("iwlwifi: add the MVM driver")
    Signed-off-by: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
    Acked-by: Gregory Greenman <gregory.greenman@intel.com>
    Link: https://lore.kernel.org/r/23f0ec986ef1529055f4f93dcb3940a6cf8d9a94.1690143750.git.christophe.jaillet@wanadoo.fr
    Signed-off-by: Johannes Berg <johannes.berg@intel.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

wifi: iwlwifi: mvm: Fix incorrect usage of scan API [+ + +]
Author: Ilan Peer <ilan.peer@intel.com>
Date:   Tue Sep 26 16:55:50 2023 +0300

    wifi: iwlwifi: mvm: Fix incorrect usage of scan API
    
    [ Upstream commit 22061bfc57fe08c77141dc876b4af75603c4d61d ]
    
    The support for using link ID in the scan request API was only
    added in version 16. However, the code wrongly enabled this
    API usage also for older versions. Fix it.
    
    Reported-by: Antoine Beaupré <anarcat@debian.org>
    Fixes: e98b23d0d7b8 ("wifi: iwlwifi: mvm: Add support for SCAN API version 16")
    Signed-off-by: Ilan Peer <ilan.peer@intel.com>
    Signed-off-by: Gregory Greenman <gregory.greenman@intel.com>
    Link: https://lore.kernel.org/r/20230926165546.086e635fbbe6.Ia660f35ca0b1079f2c2ea92fd8d14d8101a89d03@changeid
    Signed-off-by: Johannes Berg <johannes.berg@intel.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

wifi: mac80211: Create resources for disabled links [+ + +]
Author: Benjamin Berg <benjamin.berg@intel.com>
Date:   Mon Sep 25 17:30:29 2023 +0200

    wifi: mac80211: Create resources for disabled links
    
    [ Upstream commit aaba3cd33fc9593a858beeee419c0e6671ee9551 ]
    
    When associating to an MLD AP, links may be disabled. Create all
    resources associated with a disabled link so that we can later enable it
    without having to create these resources on the fly.
    
    Fixes: 6d543b34dbcf ("wifi: mac80211: Support disabled links during association")
    Signed-off-by: Benjamin Berg <benjamin.berg@intel.com>
    Link: https://lore.kernel.org/r/20230925173028.f9afdb26f6c7.I4e6e199aaefc1bf017362d64f3869645fa6830b5@changeid
    Signed-off-by: Johannes Berg <johannes.berg@intel.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

wifi: mac80211: fix mesh id corruption on 32 bit systems [+ + +]
Author: Felix Fietkau <nbd@nbd.name>
Date:   Wed Sep 13 07:01:34 2023 +0200

    wifi: mac80211: fix mesh id corruption on 32 bit systems
    
    [ Upstream commit 6e48ebffc2db5419b3a51cfc509bde442252b356 ]
    
    Since the changed field size was increased to u64, mesh_bss_info_changed
    pulls invalid bits from the first 3 bytes of the mesh id, clears them, and
    passes them on to ieee80211_link_info_change_notify, because
    ifmsh->mbss_changed was not updated to match its size.
    Fix this by turning into ifmsh->mbss_changed into an unsigned long array with
    64 bit size.
    
    Fixes: 15ddba5f4311 ("wifi: mac80211: consistently use u64 for BSS changes")
    Reported-by: Thomas Hühn <thomas.huehn@hs-nordhausen.de>
    Signed-off-by: Felix Fietkau <nbd@nbd.name>
    Link: https://lore.kernel.org/r/20230913050134.53536-1-nbd@nbd.name
    Signed-off-by: Johannes Berg <johannes.berg@intel.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

wifi: mac80211: fix potential key use-after-free [+ + +]
Author: Johannes Berg <johannes.berg@intel.com>
Date:   Tue Sep 19 08:34:15 2023 +0200

    wifi: mac80211: fix potential key use-after-free
    
    [ Upstream commit 31db78a4923ef5e2008f2eed321811ca79e7f71b ]
    
    When ieee80211_key_link() is called by ieee80211_gtk_rekey_add()
    but returns 0 due to KRACK protection (identical key reinstall),
    ieee80211_gtk_rekey_add() will still return a pointer into the
    key, in a potential use-after-free. This normally doesn't happen
    since it's only called by iwlwifi in case of WoWLAN rekey offload
    which has its own KRACK protection, but still better to fix, do
    that by returning an error code and converting that to success on
    the cfg80211 boundary only, leaving the error for bad callers of
    ieee80211_gtk_rekey_add().
    
    Reported-by: Dan Carpenter <dan.carpenter@linaro.org>
    Fixes: fdf7cb4185b6 ("mac80211: accept key reinstall without changing anything")
    Signed-off-by: Johannes Berg <johannes.berg@intel.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

wifi: mt76: fix lock dependency problem for wed_lock [+ + +]
Author: Lorenzo Bianconi <lorenzo@kernel.org>
Date:   Mon Aug 28 15:16:11 2023 +0200

    wifi: mt76: fix lock dependency problem for wed_lock
    
    [ Upstream commit 195273147e520844c1aae9fbf85cb6eb0bc0fdd7 ]
    
    Fix the following kernel depency lock holding wed_lock with BH disabled.
    
    [   40.579696] mt798x-wmac 18000000.wifi: attaching wed device 0 version 2
    [   40.604648] platform 15010000.wed: MTK WED WO Firmware Version: DEV_000000, Build Time: 20221208202138
    [   40.613972] platform 15010000.wed: MTK WED WO Chip ID 00 Region 3
    [   40.943617]
    [   40.945118] ========================================================
    [   40.951457] WARNING: possible irq lock inversion dependency detected
    [   40.957797] 5.15.127 #0 Not tainted
    [   40.961276] --------------------------------------------------------
    [   40.967614] insmod/2329 just changed the state of lock:
    [   40.972827] ffffff8004003b08 (&dev->wed_lock){+.+.}-{2:2}, at: mt76_get_rxwi+0x1c/0xac [mt76]
    [   40.981387] but this lock was taken by another, SOFTIRQ-safe lock in the past:
    [   40.988592]  (&q->lock){+.-.}-{2:2}
    [   40.988602]
    [   40.988602]
    [   40.988602] and interrupts could create inverse lock ordering between them.
    [   40.988602]
    [   41.003445]
    [   41.003445] other info that might help us debug this:
    [   41.009957]  Possible interrupt unsafe locking scenario:
    [   41.009957]
    [   41.016729]        CPU0                    CPU1
    [   41.021245]        ----                    ----
    [   41.025761]   lock(&dev->wed_lock);
    [   41.029241]                                local_irq_disable();
    [   41.035145]                                lock(&q->lock);
    [   41.040620]                                lock(&dev->wed_lock);
    [   41.046616]   <Interrupt>
    [   41.049223]     lock(&q->lock);
    [   41.052356]
    [   41.052356]  *** DEADLOCK ***
    [   41.052356]
    [   41.058260] 1 lock held by insmod/2329:
    [   41.062085]  #0: ffffff80003b9988 (&dev->mutex){....}-{3:3}, at: __driver_attach+0x88/0x190
    [   41.070442]
    [   41.070442] the shortest dependencies between 2nd lock and 1st lock:
    [   41.078257]  -> (&q->lock){+.-.}-{2:2} {
    [   41.082177]     HARDIRQ-ON-W at:
    [   41.085396]                       lock_acquire+0xfc/0x2c0
    [   41.090787]                       _raw_spin_lock_bh+0x84/0xa0
    [   41.096525]                       mt76_dma_cleanup+0x24c/0x650 [mt76]
    [   41.102977]                       mt76_dma_cleanup+0x614/0x650 [mt76]
    [   41.109428]                       mt7915_eeprom_get_power_delta+0x1168/0x2464 [mt7915e]
    [   41.117435]                       mt7915_eeprom_init+0x40/0x340 [mt7915e]
    [   41.124222]                       cleanup_module+0x94/0xb28 [mt7915e]
    [   41.130662]                       platform_probe+0x64/0xbc
    [   41.136139]                       really_probe.part.0+0x98/0x2f4
    [   41.142134]                       __driver_probe_device+0x94/0x16c
    [   41.148303]                       driver_probe_device+0x40/0x120
    [   41.154299]                       __driver_attach+0x94/0x190
    [   41.159947]                       bus_for_each_dev+0x5c/0x94
    [   41.165594]                       driver_attach+0x20/0x30
    [   41.170983]                       bus_add_driver+0x104/0x1f4
    [   41.176631]                       driver_register+0x74/0x120
    [   41.182280]                       __platform_driver_register+0x24/0x30
    [   41.188797]                       0xffffffc000cb1074
    [   41.193754]                       do_one_initcall+0x70/0x2cc
    [   41.199403]                       do_init_module+0x44/0x240
    [   41.204968]                       load_module+0x1f5c/0x2874
    [   41.210532]                       __do_sys_init_module+0x1d8/0x2ac
    [   41.216702]                       __arm64_sys_init_module+0x18/0x20
    [   41.222958]                       invoke_syscall.constprop.0+0x4c/0xe0
    [   41.229474]                       do_el0_svc+0x50/0xf0
    [   41.234602]                       el0_svc+0x4c/0xcc
    [   41.239471]                       el0t_64_sync_handler+0xe0/0x110
    [   41.245556]                       el0t_64_sync+0x15c/0x160
    [   41.251029]     IN-SOFTIRQ-W at:
    [   41.254249]                       lock_acquire+0xfc/0x2c0
    [   41.259638]                       _raw_spin_lock_bh+0x84/0xa0
    [   41.265372]                       mt76_queue_tx_complete+0x34/0x70 [mt76]
    [   41.272170]                       mt76_free_pending_rxwi+0x36c/0x5d0 [mt76]
    [   41.279140]                       mt76_free_pending_rxwi+0x5c0/0x5d0 [mt76]
    [   41.286111]                       mt7915_eeprom_get_power_delta+0x620/0x2464 [mt7915e]
    [   41.294026]                       __napi_poll.constprop.0+0x5c/0x230
    [   41.300372]                       net_rx_action+0xe4/0x294
    [   41.305847]                       _stext+0x154/0x4cc
    [   41.310801]                       do_softirq+0xa4/0xbc
    [   41.315930]                       __local_bh_enable_ip+0x168/0x174
    [   41.322097]                       napi_threaded_poll+0xbc/0x140
    [   41.328007]                       kthread+0x13c/0x150
    [   41.333049]                       ret_from_fork+0x10/0x20
    [   41.338437]     INITIAL USE at:
    [   41.341568]                      lock_acquire+0xfc/0x2c0
    [   41.346869]                      _raw_spin_lock_bh+0x84/0xa0
    [   41.352519]                      mt76_dma_cleanup+0x24c/0x650 [mt76]
    [   41.358882]                      mt76_dma_cleanup+0x614/0x650 [mt76]
    [   41.365245]                      mt7915_eeprom_get_power_delta+0x1168/0x2464 [mt7915e]
    [   41.373160]                      mt7915_eeprom_init+0x40/0x340 [mt7915e]
    [   41.379860]                      cleanup_module+0x94/0xb28 [mt7915e]
    [   41.386213]                      platform_probe+0x64/0xbc
    [   41.391602]                      really_probe.part.0+0x98/0x2f4
    [   41.397511]                      __driver_probe_device+0x94/0x16c
    [   41.403594]                      driver_probe_device+0x40/0x120
    [   41.409502]                      __driver_attach+0x94/0x190
    [   41.415063]                      bus_for_each_dev+0x5c/0x94
    [   41.420625]                      driver_attach+0x20/0x30
    [   41.425926]                      bus_add_driver+0x104/0x1f4
    [   41.431487]                      driver_register+0x74/0x120
    [   41.437049]                      __platform_driver_register+0x24/0x30
    [   41.443479]                      0xffffffc000cb1074
    [   41.448346]                      do_one_initcall+0x70/0x2cc
    [   41.453907]                      do_init_module+0x44/0x240
    [   41.459383]                      load_module+0x1f5c/0x2874
    [   41.464860]                      __do_sys_init_module+0x1d8/0x2ac
    [   41.470944]                      __arm64_sys_init_module+0x18/0x20
    [   41.477113]                      invoke_syscall.constprop.0+0x4c/0xe0
    [   41.483542]                      do_el0_svc+0x50/0xf0
    [   41.488582]                      el0_svc+0x4c/0xcc
    [   41.493364]                      el0t_64_sync_handler+0xe0/0x110
    [   41.499361]                      el0t_64_sync+0x15c/0x160
    [   41.504748]   }
    [   41.506489]   ... key      at: [<ffffffc000c65ba0>] __this_module+0x3e0/0xffffffffffffa840 [mt76]
    [   41.515371]   ... acquired at:
    [   41.518413]    _raw_spin_lock+0x60/0x74
    [   41.522240]    mt76_get_rxwi+0x1c/0xac [mt76]
    [   41.526608]    mt76_dma_cleanup+0x3e0/0x650 [mt76]
    [   41.531410]    mt76_dma_cleanup+0x614/0x650 [mt76]
    [   41.536211]    mt7915_dma_init+0x408/0x7b0 [mt7915e]
    [   41.541177]    mt7915_register_device+0x310/0x620 [mt7915e]
    [   41.546749]    mt7915_mmio_probe+0xcec/0x1d44 [mt7915e]
    [   41.551973]    platform_probe+0x64/0xbc
    [   41.555802]    really_probe.part.0+0x98/0x2f4
    [   41.560149]    __driver_probe_device+0x94/0x16c
    [   41.564670]    driver_probe_device+0x40/0x120
    [   41.569017]    __driver_attach+0x94/0x190
    [   41.573019]    bus_for_each_dev+0x5c/0x94
    [   41.577018]    driver_attach+0x20/0x30
    [   41.580758]    bus_add_driver+0x104/0x1f4
    [   41.584758]    driver_register+0x74/0x120
    [   41.588759]    __platform_driver_register+0x24/0x30
    [   41.593628]    init_module+0x74/0x1000 [mt7915e]
    [   41.598248]    do_one_initcall+0x70/0x2cc
    [   41.602248]    do_init_module+0x44/0x240
    [   41.606162]    load_module+0x1f5c/0x2874
    [   41.610078]    __do_sys_init_module+0x1d8/0x2ac
    [   41.614600]    __arm64_sys_init_module+0x18/0x20
    [   41.619209]    invoke_syscall.constprop.0+0x4c/0xe0
    [   41.624076]    do_el0_svc+0x50/0xf0
    [   41.627555]    el0_svc+0x4c/0xcc
    [   41.630776]    el0t_64_sync_handler+0xe0/0x110
    [   41.635211]    el0t_64_sync+0x15c/0x160
    [   41.639037]
    [   41.640517] -> (&dev->wed_lock){+.+.}-{2:2} {
    [   41.644872]    HARDIRQ-ON-W at:
    [   41.648003]                     lock_acquire+0xfc/0x2c0
    [   41.653219]                     _raw_spin_lock+0x60/0x74
    [   41.658520]                     mt76_free_pending_rxwi+0xc0/0x5d0 [mt76]
    [   41.665232]                     mt76_dma_cleanup+0x1dc/0x650 [mt76]
    [   41.671508]                     mt7915_eeprom_get_power_delta+0x1830/0x2464 [mt7915e]
    [   41.679336]                     mt7915_unregister_device+0x5b4/0x910 [mt7915e]
    [   41.686555]                     mt7915_eeprom_get_target_power+0xb8/0x230 [mt7915e]
    [   41.694209]                     mt7986_wmac_enable+0xc30/0xcd0 [mt7915e]
    [   41.700909]                     platform_remove+0x4c/0x64
    [   41.706298]                     __device_release_driver+0x194/0x240
    [   41.712554]                     driver_detach+0xc0/0x100
    [   41.717857]                     bus_remove_driver+0x54/0xac
    [   41.723418]                     driver_unregister+0x2c/0x54
    [   41.728980]                     platform_driver_unregister+0x10/0x20
    [   41.735323]                     mt7915_ops+0x244/0xffffffffffffed58 [mt7915e]
    [   41.742457]                     __arm64_sys_delete_module+0x170/0x23c
    [   41.748887]                     invoke_syscall.constprop.0+0x4c/0xe0
    [   41.755229]                     do_el0_svc+0x50/0xf0
    [   41.760183]                     el0_svc+0x4c/0xcc
    [   41.764878]                     el0t_64_sync_handler+0xe0/0x110
    [   41.770788]                     el0t_64_sync+0x15c/0x160
    [   41.776088]    SOFTIRQ-ON-W at:
    [   41.779220]                     lock_acquire+0xfc/0x2c0
    [   41.784435]                     _raw_spin_lock+0x60/0x74
    [   41.789737]                     mt76_get_rxwi+0x1c/0xac [mt76]
    [   41.795580]                     mt7915_debugfs_rx_log+0x804/0xb74 [mt7915e]
    [   41.802540]                     mtk_wed_start+0x970/0xaa0
    [   41.807929]                     mt7915_dma_start+0x26c/0x630 [mt7915e]
    [   41.814455]                     mt7915_dma_start+0x5a4/0x630 [mt7915e]
    [   41.820981]                     mt7915_dma_init+0x45c/0x7b0 [mt7915e]
    [   41.827420]                     mt7915_register_device+0x310/0x620 [mt7915e]
    [   41.834467]                     mt7915_mmio_probe+0xcec/0x1d44 [mt7915e]
    [   41.841167]                     platform_probe+0x64/0xbc
    [   41.846469]                     really_probe.part.0+0x98/0x2f4
    [   41.852291]                     __driver_probe_device+0x94/0x16c
    [   41.858286]                     driver_probe_device+0x40/0x120
    [   41.864107]                     __driver_attach+0x94/0x190
    [   41.869582]                     bus_for_each_dev+0x5c/0x94
    [   41.875056]                     driver_attach+0x20/0x30
    [   41.880270]                     bus_add_driver+0x104/0x1f4
    [   41.885745]                     driver_register+0x74/0x120
    [   41.891221]                     __platform_driver_register+0x24/0x30
    [   41.897564]                     init_module+0x74/0x1000 [mt7915e]
    [   41.903657]                     do_one_initcall+0x70/0x2cc
    [   41.909130]                     do_init_module+0x44/0x240
    [   41.914520]                     load_module+0x1f5c/0x2874
    [   41.919909]                     __do_sys_init_module+0x1d8/0x2ac
    [   41.925905]                     __arm64_sys_init_module+0x18/0x20
    [   41.931989]                     invoke_syscall.constprop.0+0x4c/0xe0
    [   41.938331]                     do_el0_svc+0x50/0xf0
    [   41.943285]                     el0_svc+0x4c/0xcc
    [   41.947981]                     el0t_64_sync_handler+0xe0/0x110
    [   41.953892]                     el0t_64_sync+0x15c/0x160
    [   41.959192]    INITIAL USE at:
    [   41.962238]                    lock_acquire+0xfc/0x2c0
    [   41.967365]                    _raw_spin_lock+0x60/0x74
    [   41.972580]                    mt76_free_pending_rxwi+0xc0/0x5d0 [mt76]
    [   41.979206]                    mt76_dma_cleanup+0x1dc/0x650 [mt76]
    [   41.985395]                    mt7915_eeprom_get_power_delta+0x1830/0x2464 [mt7915e]
    [   41.993137]                    mt7915_unregister_device+0x5b4/0x910 [mt7915e]
    [   42.000270]                    mt7915_eeprom_get_target_power+0xb8/0x230 [mt7915e]
    [   42.007837]                    mt7986_wmac_enable+0xc30/0xcd0 [mt7915e]
    [   42.014450]                    platform_remove+0x4c/0x64
    [   42.019753]                    __device_release_driver+0x194/0x240
    [   42.025922]                    driver_detach+0xc0/0x100
    [   42.031137]                    bus_remove_driver+0x54/0xac
    [   42.036612]                    driver_unregister+0x2c/0x54
    [   42.042087]                    platform_driver_unregister+0x10/0x20
    [   42.048344]                    mt7915_ops+0x244/0xffffffffffffed58 [mt7915e]
    [   42.055391]                    __arm64_sys_delete_module+0x170/0x23c
    [   42.061735]                    invoke_syscall.constprop.0+0x4c/0xe0
    [   42.067990]                    do_el0_svc+0x50/0xf0
    [   42.072857]                    el0_svc+0x4c/0xcc
    [   42.077466]                    el0t_64_sync_handler+0xe0/0x110
    [   42.083289]                    el0t_64_sync+0x15c/0x160
    [   42.088503]  }
    [   42.090157]  ... key      at: [<ffffffc000c65c10>] __this_module+0x450/0xffffffffffffa840 [mt76]
    [   42.098951]  ... acquired at:
    [   42.101907]    __lock_acquire+0x718/0x1df0
    [   42.105994]    lock_acquire+0xfc/0x2c0
    [   42.109734]    _raw_spin_lock+0x60/0x74
    [   42.113561]    mt76_get_rxwi+0x1c/0xac [mt76]
    [   42.117929]    mt7915_debugfs_rx_log+0x804/0xb74 [mt7915e]
    [   42.123415]    mtk_wed_start+0x970/0xaa0
    [   42.127328]    mt7915_dma_start+0x26c/0x630 [mt7915e]
    [   42.132379]    mt7915_dma_start+0x5a4/0x630 [mt7915e]
    [   42.137430]    mt7915_dma_init+0x45c/0x7b0 [mt7915e]
    [   42.142395]    mt7915_register_device+0x310/0x620 [mt7915e]
    [   42.147967]    mt7915_mmio_probe+0xcec/0x1d44 [mt7915e]
    [   42.153192]    platform_probe+0x64/0xbc
    [   42.157019]    really_probe.part.0+0x98/0x2f4
    [   42.161367]    __driver_probe_device+0x94/0x16c
    [   42.165887]    driver_probe_device+0x40/0x120
    [   42.170234]    __driver_attach+0x94/0x190
    [   42.174235]    bus_for_each_dev+0x5c/0x94
    [   42.178235]    driver_attach+0x20/0x30
    [   42.181974]    bus_add_driver+0x104/0x1f4
    [   42.185974]    driver_register+0x74/0x120
    [   42.189974]    __platform_driver_register+0x24/0x30
    [   42.194842]    init_module+0x74/0x1000 [mt7915e]
    [   42.199460]    do_one_initcall+0x70/0x2cc
    [   42.203460]    do_init_module+0x44/0x240
    [   42.207376]    load_module+0x1f5c/0x2874
    [   42.211290]    __do_sys_init_module+0x1d8/0x2ac
    [   42.215813]    __arm64_sys_init_module+0x18/0x20
    [   42.220421]    invoke_syscall.constprop.0+0x4c/0xe0
    [   42.225288]    do_el0_svc+0x50/0xf0
    [   42.228768]    el0_svc+0x4c/0xcc
    [   42.231989]    el0t_64_sync_handler+0xe0/0x110
    [   42.236424]    el0t_64_sync+0x15c/0x160
    [   42.240249]
    [   42.241730]
    [   42.241730] stack backtrace:
    [   42.246074] CPU: 1 PID: 2329 Comm: insmod Not tainted 5.15.127 #0
    [   42.252157] Hardware name: GainStrong Oolite-MT7981B V1 Dev Board (NAND boot) (DT)
    [   42.259712] Call trace:
    [   42.262147]  dump_backtrace+0x0/0x174
    [   42.265802]  show_stack+0x14/0x20
    [   42.269108]  dump_stack_lvl+0x84/0xac
    [   42.272761]  dump_stack+0x14/0x2c
    [   42.276066]  print_irq_inversion_bug.part.0+0x1b0/0x1c4
    [   42.281285]  mark_lock+0x8b8/0x8bc
    [   42.284678]  __lock_acquire+0x718/0x1df0
    [   42.288592]  lock_acquire+0xfc/0x2c0
    [   42.292158]  _raw_spin_lock+0x60/0x74
    [   42.295811]  mt76_get_rxwi+0x1c/0xac [mt76]
    [   42.300008]  mt7915_debugfs_rx_log+0x804/0xb74 [mt7915e]
    [   42.305320]  mtk_wed_start+0x970/0xaa0
    [   42.309059]  mt7915_dma_start+0x26c/0x630 [mt7915e]
    [   42.313937]  mt7915_dma_start+0x5a4/0x630 [mt7915e]
    [   42.318815]  mt7915_dma_init+0x45c/0x7b0 [mt7915e]
    [   42.323606]  mt7915_register_device+0x310/0x620 [mt7915e]
    [   42.329005]  mt7915_mmio_probe+0xcec/0x1d44 [mt7915e]
    [   42.334056]  platform_probe+0x64/0xbc
    [   42.337711]  really_probe.part.0+0x98/0x2f4
    [   42.341885]  __driver_probe_device+0x94/0x16c
    [   42.346232]  driver_probe_device+0x40/0x120
    [   42.350407]  __driver_attach+0x94/0x190
    [   42.354234]  bus_for_each_dev+0x5c/0x94
    [   42.358061]  driver_attach+0x20/0x30
    [   42.361627]  bus_add_driver+0x104/0x1f4
    [   42.365454]  driver_register+0x74/0x120
    [   42.369282]  __platform_driver_register+0x24/0x30
    [   42.373977]  init_module+0x74/0x1000 [mt7915e]
    [   42.378423]  do_one_initcall+0x70/0x2cc
    [   42.382249]  do_init_module+0x44/0x240
    [   42.385990]  load_module+0x1f5c/0x2874
    [   42.389733]  __do_sys_init_module+0x1d8/0x2ac
    [   42.394082]  __arm64_sys_init_module+0x18/0x20
    [   42.398518]  invoke_syscall.constprop.0+0x4c/0xe0
    [   42.403211]  do_el0_svc+0x50/0xf0
    [   42.406517]  el0_svc+0x4c/0xcc
    [   42.409565]  el0t_64_sync_handler+0xe0/0x110
    [   42.413827]  el0t_64_sync+0x15c/0x160
    [   42.674858] mt798x-wmac 18000000.wifi: HW/SW Version: 0x8a108a10, Build Time: 20221208201745a
    [   42.674858]
    [   42.692078] mt798x-wmac 18000000.wifi: WM Firmware Version: ____000000, Build Time: 20221208201806
    [   42.735606] mt798x-wmac 18000000.wifi: WA Firmware Version: DEV_000000, Build Time: 20221208202048
    
    Tested-by: Daniel Golle <daniel@makrotopia.org>
    Fixes: 2666bece0905 ("wifi: mt76: introduce rxwi and rx token utility routines")
    Signed-off-by: Lorenzo Bianconi <lorenzo@kernel.org>
    Acked-by: Felix Fietkau <nbd@nbd.name>
    Signed-off-by: Kalle Valo <kvalo@kernel.org>
    Link: https://lore.kernel.org/r/ee80be41c2a8d8749d83c6950a272a5e77aadd45.1693228333.git.lorenzo@kernel.org
    Signed-off-by: Sasha Levin <sashal@kernel.org>

wifi: mt76: mt76x02: fix MT76x0 external LNA gain handling [+ + +]
Author: Felix Fietkau <nbd@nbd.name>
Date:   Tue Sep 19 21:47:47 2023 +0200

    wifi: mt76: mt76x02: fix MT76x0 external LNA gain handling
    
    [ Upstream commit 684e45e120b82deccaf8b85633905304a3bbf56d ]
    
    On MT76x0, LNA gain should be applied for both external and internal LNA.
    On MT76x2, LNA gain should be treated as 0 for external LNA.
    Move the LNA type based logic to mt76x2 in order to fix mt76x0.
    
    Fixes: 2daa67588f34 ("mt76x0: unify lna_gain parsing")
    Reported-by: Shiji Yang <yangshiji66@outlook.com>
    Signed-off-by: Felix Fietkau <nbd@nbd.name>
    Signed-off-by: Kalle Valo <kvalo@kernel.org>
    Link: https://lore.kernel.org/r/20230919194747.31647-1-nbd@nbd.name
    Signed-off-by: Sasha Levin <sashal@kernel.org>

wifi: mwifiex: Fix oob check condition in mwifiex_process_rx_packet [+ + +]
Author: Pin-yen Lin <treapking@chromium.org>
Date:   Fri Sep 8 18:41:12 2023 +0800

    wifi: mwifiex: Fix oob check condition in mwifiex_process_rx_packet
    
    [ Upstream commit aef7a0300047e7b4707ea0411dc9597cba108fc8 ]
    
    Only skip the code path trying to access the rfc1042 headers when the
    buffer is too small, so the driver can still process packets without
    rfc1042 headers.
    
    Fixes: 119585281617 ("wifi: mwifiex: Fix OOB and integer underflow when rx packets")
    Signed-off-by: Pin-yen Lin <treapking@chromium.org>
    Acked-by: Brian Norris <briannorris@chromium.org>
    Reviewed-by: Matthew Wang <matthewmwang@chromium.org>
    Signed-off-by: Kalle Valo <kvalo@kernel.org>
    Link: https://lore.kernel.org/r/20230908104308.1546501-1-treapking@chromium.org
    Signed-off-by: Sasha Levin <sashal@kernel.org>

wifi: mwifiex: Fix tlv_buf_left calculation [+ + +]
Author: Gustavo A. R. Silva <gustavoars@kernel.org>
Date:   Thu Aug 24 21:06:51 2023 -0600

    wifi: mwifiex: Fix tlv_buf_left calculation
    
    commit eec679e4ac5f47507774956fb3479c206e761af7 upstream.
    
    In a TLV encoding scheme, the Length part represents the length after
    the header containing the values for type and length. In this case,
    `tlv_len` should be:
    
    tlv_len == (sizeof(*tlv_rxba) - 1) - sizeof(tlv_rxba->header) + tlv_bitmap_len
    
    Notice that the `- 1` accounts for the one-element array `bitmap`, which
    1-byte size is already included in `sizeof(*tlv_rxba)`.
    
    So, if the above is correct, there is a double-counting of some members
    in `struct mwifiex_ie_types_rxba_sync`, when `tlv_buf_left` and `tmp`
    are calculated:
    
    968                 tlv_buf_left -= (sizeof(*tlv_rxba) + tlv_len);
    969                 tmp = (u8 *)tlv_rxba + tlv_len + sizeof(*tlv_rxba);
    
    in specific, members:
    
    drivers/net/wireless/marvell/mwifiex/fw.h:777
     777         u8 mac[ETH_ALEN];
     778         u8 tid;
     779         u8 reserved;
     780         __le16 seq_num;
     781         __le16 bitmap_len;
    
    This is clearly wrong, and affects the subsequent decoding of data in
    `event_buf` through `tlv_rxba`:
    
    970                 tlv_rxba = (struct mwifiex_ie_types_rxba_sync *)tmp;
    
    Fix this by using `sizeof(tlv_rxba->header)` instead of `sizeof(*tlv_rxba)`
    in the calculation of `tlv_buf_left` and `tmp`.
    
    This results in the following binary differences before/after changes:
    
    | drivers/net/wireless/marvell/mwifiex/11n_rxreorder.o
    | @@ -4698,11 +4698,11 @@
    |  drivers/net/wireless/marvell/mwifiex/11n_rxreorder.c:968
    |                 tlv_buf_left -= (sizeof(tlv_rxba->header) + tlv_len);
    | -    1da7:      lea    -0x11(%rbx),%edx
    | +    1da7:      lea    -0x4(%rbx),%edx
    |      1daa:      movzwl %bp,%eax
    |  drivers/net/wireless/marvell/mwifiex/11n_rxreorder.c:969
    |                 tmp = (u8 *)tlv_rxba  + sizeof(tlv_rxba->header) + tlv_len;
    | -    1dad:      lea    0x11(%r15,%rbp,1),%r15
    | +    1dad:      lea    0x4(%r15,%rbp,1),%r15
    
    The above reflects the desired change: avoid counting 13 too many bytes;
    which is the total size of the double-counted members in
    `struct mwifiex_ie_types_rxba_sync`:
    
    $ pahole -C mwifiex_ie_types_rxba_sync drivers/net/wireless/marvell/mwifiex/11n_rxreorder.o
    struct mwifiex_ie_types_rxba_sync {
            struct mwifiex_ie_types_header header;           /*     0     4 */
    
         |-----------------------------------------------------------------------
         |  u8                         mac[6];               /*     4     6 */  |
         |  u8                         tid;                  /*    10     1 */  |
         |  u8                         reserved;             /*    11     1 */  |
         |  __le16                     seq_num;              /*    12     2 */  |
         |  __le16                     bitmap_len;           /*    14     2 */  |
         |  u8                         bitmap[1];            /*    16     1 */  |
         |----------------------------------------------------------------------|
                                                                      | 13 bytes|
                                                                      -----------
    
            /* size: 17, cachelines: 1, members: 7 */
            /* last cacheline: 17 bytes */
    } __attribute__((__packed__));
    
    Fixes: 99ffe72cdae4 ("mwifiex: process rxba_sync event")
    Cc: stable@vger.kernel.org
    Signed-off-by: Gustavo A. R. Silva <gustavoars@kernel.org>
    Reviewed-by: Kees Cook <keescook@chromium.org>
    Signed-off-by: Kalle Valo <kvalo@kernel.org>
    Link: https://lore.kernel.org/r/06668edd68e7a26bbfeebd1201ae077a2a7a8bce.1692931954.git.gustavoars@kernel.org
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

wifi: rtw88: rtw8723d: Fix MAC address offset in EEPROM [+ + +]
Author: Sascha Hauer <s.hauer@pengutronix.de>
Date:   Thu Sep 7 09:16:14 2023 +0200

    wifi: rtw88: rtw8723d: Fix MAC address offset in EEPROM
    
    commit 2e1b3ae3e1f2cf5a3c9c05d5f961d7d4257b489f upstream.
    
    The MAC address is stored at offset 0x107 in the EEPROM, like correctly
    stated in the comment. Add a two bytes reserved field right before the
    MAC address to shift it from offset 0x105 to 0x107.
    
    With this the MAC address returned from my RTL8723du wifi stick can be
    correctly decoded as "Shenzhen Four Seas Global Link Network Technology
    Co., Ltd."
    
    Fixes: 87caeef032fc ("wifi: rtw88: Add rtw8723du chipset support")
    Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>
    Reported-by: Yanik Fuchs <Yanik.fuchs@mbv.ch>
    Cc: stable@vger.kernel.org
    Acked-by: Ping-Ke Shih <pkshih@realtek.com>
    Signed-off-by: Kalle Valo <kvalo@kernel.org>
    Link: https://lore.kernel.org/r/20230907071614.2032404-1-s.hauer@pengutronix.de
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
x86/sev: Change npages to unsigned long in snp_accept_memory() [+ + +]
Author: Tom Lendacky <thomas.lendacky@amd.com>
Date:   Thu Jun 22 08:45:05 2023 -0500

    x86/sev: Change npages to unsigned long in snp_accept_memory()
    
    commit 62d5e970d022ef4bde18948dd67247c3194384c1 upstream.
    
    In snp_accept_memory(), the npages variables value is calculated from
    phys_addr_t variables but is an unsigned int. A very large range passed
    into snp_accept_memory() could lead to truncating npages to zero. This
    doesn't happen at the moment but let's be prepared.
    
    Fixes: 6c3211796326 ("x86/sev: Add SNP-specific unaccepted memory support")
    Signed-off-by: Tom Lendacky <thomas.lendacky@amd.com>
    Signed-off-by: Borislav Petkov (AMD) <bp@alien8.de>
    Cc: <stable@kernel.org>
    Link: https://lore.kernel.org/r/6d511c25576494f682063c9fb6c705b526a3757e.1687441505.git.thomas.lendacky@amd.com
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

x86/sev: Use the GHCB protocol when available for SNP CPUID requests [+ + +]
Author: Tom Lendacky <thomas.lendacky@amd.com>
Date:   Fri Jul 28 16:09:26 2023 -0500

    x86/sev: Use the GHCB protocol when available for SNP CPUID requests
    
    commit 6bc6f7d9d7ac3cdbe9e8b0495538b4a0cc11f032 upstream.
    
    SNP retrieves the majority of CPUID information from the SNP CPUID page.
    But there are times when that information needs to be supplemented by the
    hypervisor, for example, obtaining the initial APIC ID of the vCPU from
    leaf 1.
    
    The current implementation uses the MSR protocol to retrieve the data from
    the hypervisor, even when a GHCB exists. The problem arises when an NMI
    arrives on return from the VMGEXIT. The NMI will be immediately serviced
    and may generate a #VC requiring communication with the hypervisor.
    
    Since a GHCB exists in this case, it will be used. As part of using the
    GHCB, the #VC handler will write the GHCB physical address into the GHCB
    MSR and the #VC will be handled.
    
    When the NMI completes, processing resumes at the site of the VMGEXIT
    which is expecting to read the GHCB MSR and find a CPUID MSR protocol
    response. Since the NMI handling overwrote the GHCB MSR response, the
    guest will see an invalid reply from the hypervisor and self-terminate.
    
    Fix this problem by using the GHCB when it is available. Any NMI
    received is properly handled because the GHCB contents are copied into
    a backup page and restored on NMI exit, thus preserving the active GHCB
    request or result.
    
      [ bp: Touchups. ]
    
    Fixes: ee0bfa08a345 ("x86/compressed/64: Add support for SEV-SNP CPUID table in #VC handlers")
    Signed-off-by: Tom Lendacky <thomas.lendacky@amd.com>
    Signed-off-by: Borislav Petkov (AMD) <bp@alien8.de>
    Cc: <stable@kernel.org>
    Link: https://lore.kernel.org/r/a5856fa1ebe3879de91a8f6298b6bbd901c61881.1690578565.git.thomas.lendacky@amd.com
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

 
xen/events: replace evtchn_rwlock with RCU [+ + +]
Author: Juergen Gross <jgross@suse.com>
Date:   Mon Aug 28 08:09:47 2023 +0200

    xen/events: replace evtchn_rwlock with RCU
    
    commit 87797fad6cce28ec9be3c13f031776ff4f104cfc upstream.
    
    In unprivileged Xen guests event handling can cause a deadlock with
    Xen console handling. The evtchn_rwlock and the hvc_lock are taken in
    opposite sequence in __hvc_poll() and in Xen console IRQ handling.
    Normally this is no problem, as the evtchn_rwlock is taken as a reader
    in both paths, but as soon as an event channel is being closed, the
    lock will be taken as a writer, which will cause read_lock() to block:
    
    CPU0                     CPU1                CPU2
    (IRQ handling)           (__hvc_poll())      (closing event channel)
    
    read_lock(evtchn_rwlock)
                             spin_lock(hvc_lock)
                                                 write_lock(evtchn_rwlock)
                                                     [blocks]
    spin_lock(hvc_lock)
        [blocks]
                            read_lock(evtchn_rwlock)
                                [blocks due to writer waiting,
                                 and not in_interrupt()]
    
    This issue can be avoided by replacing evtchn_rwlock with RCU in
    xen_free_irq(). Note that RCU is used only to delay freeing of the
    irq_info memory. There is no RCU based dereferencing or replacement of
    pointers involved.
    
    In order to avoid potential races between removing the irq_info
    reference and handling of interrupts, set the irq_info pointer to NULL
    only when freeing its memory. The IRQ itself must be freed at that
    time, too, as otherwise the same IRQ number could be allocated again
    before handling of the old instance would have been finished.
    
    This is XSA-441 / CVE-2023-34324.
    
    Fixes: 54c9de89895e ("xen/events: add a new "late EOI" evtchn framework")
    Reported-by: Marek Marczykowski-Górecki <marmarek@invisiblethingslab.com>
    Signed-off-by: Juergen Gross <jgross@suse.com>
    Reviewed-by: Julien Grall <jgrall@amazon.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>