commit 714a286bf9ee3740260c61471ed72d10bd17336a
Author: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Date:   Thu Aug 3 10:26:15 2023 +0200

    Linux 6.4.8
    
    Link: https://lore.kernel.org/r/20230801091925.659598007@linuxfoundation.org
    Tested-by: Ronald Warsow <rwarsow@gmx.de>
    Tested-by: Jon Hunter <jonathanh@nvidia.com>
    Tested-by: Conor Dooley <conor.dooley@microchip.com>
    Tested-by: SeongJae Park <sj@kernel.org>
    Tested-by: Shuah Khan <skhan@linuxfoundation.org>
    Tested-by: Florian Fainelli <florian.fainelli@broadcom.com>
    Tested-by: Ron Economos <re@w6rz.net>
    Tested-by: Bagas Sanjaya <bagasdotme@gmail.com>
    Link: https://lore.kernel.org/r/20230802065501.780725463@linuxfoundation.org
    Tested-by: Chris Paterson (CIP) <chris.paterson2@renesas.com>
    Tested-by: Ronald Warsow <rwarsow@gmx.de>
    Tested-by: SeongJae Park <sj@kernel.org>
    Tested-by: Ron Economos <re@w6rz.net>
    Tested-by: Guenter Roeck <linux@roeck-us.net>
    Tested-by: Florian Fainelli <florian.fainelli@broadcom.com>
    Tested-by: Bagas Sanjaya <bagasdotme@gmail.com>
    Tested-by: Linux Kernel Functional Testing <lkft@linaro.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 3d308a163115e275eb18366beb45b8c7c513a822
Author: Dan Carpenter <dan.carpenter@linaro.org>
Date:   Thu Jul 6 15:37:51 2023 +0300

    dma-buf: fix an error pointer vs NULL bug
    
    commit 00ae1491f970acc454be0df63f50942d94825860 upstream.
    
    Smatch detected potential error pointer dereference.
    
        drivers/gpu/drm/drm_syncobj.c:888 drm_syncobj_transfer_to_timeline()
        error: 'fence' dereferencing possible ERR_PTR()
    
    The error pointer comes from dma_fence_allocate_private_stub().  One
    caller expected error pointers and one expected NULL pointers.  Change
    it to return NULL and update the caller which expected error pointers,
    drm_syncobj_assign_null_handle(), to check for NULL instead.
    
    Fixes: f781f661e8c9 ("dma-buf: keep the signaling time of merged fences v3")
    Signed-off-by: Dan Carpenter <dan.carpenter@linaro.org>
    Reviewed-by: Christian König <christian.koenig@amd.com>
    Reviewed-by: Sumit Semwal <sumit.semwal@linaro.org>
    Signed-off-by: Sumit Semwal <sumit.semwal@linaro.org>
    Link: https://patchwork.freedesktop.org/patch/msgid/b09f1996-3838-4fa2-9193-832b68262e43@moroto.mountain
    Cc: Jindong Yue <jindong.yue@nxp.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 6bd9952eade5bbcd099083ca782ad674f6b32637
Author: Christian König <christian.koenig@amd.com>
Date:   Tue Jun 13 10:09:20 2023 +0200

    dma-buf: keep the signaling time of merged fences v3
    
    commit f781f661e8c99b0cb34129f2e374234d61864e77 upstream.
    
    Some Android CTS is testing if the signaling time keeps consistent
    during merges.
    
    v2: use the current time if the fence is still in the signaling path and
    the timestamp not yet available.
    v3: improve comment, fix one more case to use the correct timestamp
    
    Signed-off-by: Christian König <christian.koenig@amd.com>
    Reviewed-by: Luben Tuikov <luben.tuikov@amd.com>
    Link: https://patchwork.freedesktop.org/patch/msgid/20230630120041.109216-1-christian.koenig@amd.com
    Cc: Jindong Yue <jindong.yue@nxp.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit e872d6b6ea4947fb87f0d6ea1ef814019dbed89e
Author: Jann Horn <jannh@google.com>
Date:   Fri Jul 28 06:13:21 2023 +0200

    mm/mempolicy: Take VMA lock before replacing policy
    
    commit 6c21e066f9256ea1df6f88768f6ae1080b7cf509 upstream.
    
    mbind() calls down into vma_replace_policy() without taking the per-VMA
    locks, replaces the VMA's vma->vm_policy pointer, and frees the old
    policy.  That's bad; a concurrent page fault might still be using the
    old policy (in vma_alloc_folio()), resulting in use-after-free.
    
    Normally this will manifest as a use-after-free read first, but it can
    result in memory corruption, including because vma_alloc_folio() can
    call mpol_cond_put() on the freed policy, which conditionally changes
    the policy's refcount member.
    
    This bug is specific to CONFIG_NUMA, but it does also affect non-NUMA
    systems as long as the kernel was built with CONFIG_NUMA.
    
    Signed-off-by: Jann Horn <jannh@google.com>
    Reviewed-by: Suren Baghdasaryan <surenb@google.com>
    Fixes: 5e31275cc997 ("mm: add per-VMA lock and helper functions to control it")
    Cc: stable@kernel.org
    Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit da84cd9b5e03464c177cabf9692853708626456f
Author: Sidhartha Kumar <sidhartha.kumar@oracle.com>
Date:   Mon Jul 17 11:18:12 2023 -0700

    mm/memory-failure: fix hardware poison check in unpoison_memory()
    
    commit 6c54312f9689fbe27c70db5d42eebd29d04b672e upstream.
    
    It was pointed out[1] that using folio_test_hwpoison() is wrong as we need
    to check the indiviual page that has poison.  folio_test_hwpoison() only
    checks the head page so go back to using PageHWPoison().
    
    User-visible effects include existing hwpoison-inject tests possibly
    failing as unpoisoning a single subpage could lead to unpoisoning an
    entire folio.  Memory unpoisoning could also not work as expected as
    the function will break early due to only checking the head page and
    not the actually poisoned subpage.
    
    [1]: https://lore.kernel.org/lkml/ZLIbZygG7LqSI9xe@casper.infradead.org/
    
    Link: https://lkml.kernel.org/r/20230717181812.167757-1-sidhartha.kumar@oracle.com
    Fixes: a6fddef49eef ("mm/memory-failure: convert unpoison_memory() to folios")
    Signed-off-by: Sidhartha Kumar <sidhartha.kumar@oracle.com>
    Reported-by: Matthew Wilcox (Oracle) <willy@infradead.org>
    Acked-by: Naoya Horiguchi <naoya.horiguchi@nec.com>
    Reviewed-by: Miaohe Lin <linmiaohe@huawei.com>
    Cc: <stable@vger.kernel.org>
    Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit bdb3106af2b26e8f10dee7353f0ef63bf84fd6de
Author: Jann Horn <jannh@google.com>
Date:   Sat Jul 22 00:51:07 2023 +0200

    mm: fix memory ordering for mm_lock_seq and vm_lock_seq
    
    commit b1f02b95758d05b799731d939e76a0bd6da312db upstream.
    
    mm->mm_lock_seq effectively functions as a read/write lock; therefore it
    must be used with acquire/release semantics.
    
    A specific example is the interaction between userfaultfd_register() and
    lock_vma_under_rcu().
    
    userfaultfd_register() does the following from the point where it changes
    a VMA's flags to the point where concurrent readers are permitted again
    (in a simple scenario where only a single private VMA is accessed and no
    merging/splitting is involved):
    
    userfaultfd_register
      userfaultfd_set_vm_flags
        vm_flags_reset
          vma_start_write
            down_write(&vma->vm_lock->lock)
            vma->vm_lock_seq = mm_lock_seq [marks VMA as busy]
            up_write(&vma->vm_lock->lock)
          vm_flags_init
            [sets VM_UFFD_* in __vm_flags]
      vma->vm_userfaultfd_ctx.ctx = ctx
      mmap_write_unlock
        vma_end_write_all
          WRITE_ONCE(mm->mm_lock_seq, mm->mm_lock_seq + 1) [unlocks VMA]
    
    There are no memory barriers in between the __vm_flags update and the
    mm->mm_lock_seq update that unlocks the VMA, so the unlock can be
    reordered to above the `vm_flags_init()` call, which means from the
    perspective of a concurrent reader, a VMA can be marked as a userfaultfd
    VMA while it is not VMA-locked.  That's bad, we definitely need a
    store-release for the unlock operation.
    
    The non-atomic write to vma->vm_lock_seq in vma_start_write() is mostly
    fine because all accesses to vma->vm_lock_seq that matter are always
    protected by the VMA lock.  There is a racy read in vma_start_read()
    though that can tolerate false-positives, so we should be using
    WRITE_ONCE() to keep things tidy and data-race-free (including for KCSAN).
    
    On the other side, lock_vma_under_rcu() works as follows in the relevant
    region for locking and userfaultfd check:
    
    lock_vma_under_rcu
      vma_start_read
        vma->vm_lock_seq == READ_ONCE(vma->vm_mm->mm_lock_seq) [early bailout]
        down_read_trylock(&vma->vm_lock->lock)
        vma->vm_lock_seq == READ_ONCE(vma->vm_mm->mm_lock_seq) [main check]
      userfaultfd_armed
        checks vma->vm_flags & __VM_UFFD_FLAGS
    
    Here, the interesting aspect is how far down the mm->mm_lock_seq read can
    be reordered - if this read is reordered down below the vma->vm_flags
    access, this could cause lock_vma_under_rcu() to partly operate on
    information that was read while the VMA was supposed to be locked.  To
    prevent this kind of downwards bleeding of the mm->mm_lock_seq read, we
    need to read it with a load-acquire.
    
    Some of the comment wording is based on suggestions by Suren.
    
    BACKPORT WARNING: One of the functions changed by this patch (which I've
    written against Linus' tree) is vma_try_start_write(), but this function
    no longer exists in mm/mm-everything.  I don't know whether the merged
    version of this patch will be ordered before or after the patch that
    removes vma_try_start_write().  If you're backporting this patch to a tree
    with vma_try_start_write(), make sure this patch changes that function.
    
    Link: https://lkml.kernel.org/r/20230721225107.942336-1-jannh@google.com
    Fixes: 5e31275cc997 ("mm: add per-VMA lock and helper functions to control it")
    Signed-off-by: Jann Horn <jannh@google.com>
    Reviewed-by: Suren Baghdasaryan <surenb@google.com>
    Cc: <stable@vger.kernel.org>
    Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit b53745bdb03e0cd45765ec4f7613c0069dce47e5
Author: Jann Horn <jannh@google.com>
Date:   Fri Jul 21 05:46:43 2023 +0200

    mm: lock VMA in dup_anon_vma() before setting ->anon_vma
    
    commit d8ab9f7b644a2c9b64de405c1953c905ff219dc9 upstream.
    
    When VMAs are merged, dup_anon_vma() is called with `dst` pointing to the
    VMA that is being expanded to cover the area previously occupied by
    another VMA.  This currently happens while `dst` is not write-locked.
    
    This means that, in the `src->anon_vma && !dst->anon_vma` case, as soon as
    the assignment `dst->anon_vma = src->anon_vma` has happened, concurrent
    page faults can happen on `dst` under the per-VMA lock.  This is already
    icky in itself, since such page faults can now install pages into `dst`
    that are attached to an `anon_vma` that is not yet tied back to the
    `anon_vma` with an `anon_vma_chain`.  But if `anon_vma_clone()` fails due
    to an out-of-memory error, things get much worse: `anon_vma_clone()` then
    reverts `dst->anon_vma` back to NULL, and `dst` remains completely
    unconnected to the `anon_vma`, even though we can have pages in the area
    covered by `dst` that point to the `anon_vma`.
    
    This means the `anon_vma` of such pages can be freed while the pages are
    still mapped into userspace, which leads to UAF when a helper like
    folio_lock_anon_vma_read() tries to look up the anon_vma of such a page.
    
    This theoretically is a security bug, but I believe it is really hard to
    actually trigger as an unprivileged user because it requires that you can
    make an order-0 GFP_KERNEL allocation fail, and the page allocator tries
    pretty hard to prevent that.
    
    I think doing the vma_start_write() call inside dup_anon_vma() is the most
    straightforward fix for now.
    
    For a kernel-assisted reproducer, see the notes section of the patch mail.
    
    Link: https://lkml.kernel.org/r/20230721034643.616851-1-jannh@google.com
    Fixes: 5e31275cc997 ("mm: add per-VMA lock and helper functions to control it")
    Signed-off-by: Jann Horn <jannh@google.com>
    Reviewed-by: Suren Baghdasaryan <surenb@google.com>
    Cc: <stable@vger.kernel.org>
    Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 58f4cbe0cc874fe0025352019238c6b4d59d0eba
Author: Ilya Dryomov <idryomov@gmail.com>
Date:   Sat Jul 22 20:28:08 2023 +0200

    rbd: retrieve and check lock owner twice before blocklisting
    
    commit 588159009d5b7a09c3e5904cffddbe4a4e170301 upstream.
    
    An attempt to acquire exclusive lock can race with the current lock
    owner closing the image:
    
    1. lock is held by client123, rbd_lock() returns -EBUSY
    2. get_lock_owner_info() returns client123 instance details
    3. client123 closes the image, lock is released
    4. find_watcher() returns 0 as there is no matching watcher anymore
    5. client123 instance gets erroneously blocklisted
    
    Particularly impacted is mirror snapshot scheduler in snapshot-based
    mirroring since it happens to open and close images a lot (images are
    opened only for as long as it takes to take the next mirror snapshot,
    the same client instance is used for all images).
    
    To reduce the potential for erroneous blocklisting, retrieve the lock
    owner again after find_watcher() returns 0.  If it's still there, make
    sure it matches the previously detected lock owner.
    
    Cc: stable@vger.kernel.org # f38cb9d9c204: rbd: make get_lock_owner_info() return a single locker or NULL
    Cc: stable@vger.kernel.org # 8ff2c64c9765: rbd: harden get_lock_owner_info() a bit
    Cc: stable@vger.kernel.org
    Signed-off-by: Ilya Dryomov <idryomov@gmail.com>
    Reviewed-by: Dongsheng Yang <dongsheng.yang@easystack.cn>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 44f442aa19f0c992728c5af79f6aa9e6df2ad01a
Author: Ilya Dryomov <idryomov@gmail.com>
Date:   Sat Jul 8 16:16:59 2023 +0200

    rbd: harden get_lock_owner_info() a bit
    
    commit 8ff2c64c9765446c3cef804fb99da04916603e27 upstream.
    
    - we want the exclusive lock type, so test for it directly
    - use sscanf() to actually parse the lock cookie and avoid admitting
      invalid handles
    - bail if locker has a blank address
    
    Signed-off-by: Ilya Dryomov <idryomov@gmail.com>
    Reviewed-by: Dongsheng Yang <dongsheng.yang@easystack.cn>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 0a83f816a8f1ed381907c99107652832965308bd
Author: Ilya Dryomov <idryomov@gmail.com>
Date:   Fri Jun 30 13:52:13 2023 +0200

    rbd: make get_lock_owner_info() return a single locker or NULL
    
    commit f38cb9d9c2045dad16eead4a2e1aedfddd94603b upstream.
    
    Make the "num_lockers can be only 0 or 1" assumption explicit and
    simplify the API by getting rid of output parameters in preparation
    for calling get_lock_owner_info() twice before blocklisting.
    
    Signed-off-by: Ilya Dryomov <idryomov@gmail.com>
    Reviewed-by: Dongsheng Yang <dongsheng.yang@easystack.cn>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 441b3dd88f78e2fdafde17aeac3b5771430d8b65
Author: Joe Thornber <ejt@redhat.com>
Date:   Tue Jul 25 11:44:41 2023 -0400

    dm cache policy smq: ensure IO doesn't prevent cleaner policy progress
    
    commit 1e4ab7b4c881cf26c1c72b3f56519e03475486fb upstream.
    
    When using the cleaner policy to decommission the cache, there is
    never any writeback started from the cache as it is constantly delayed
    due to normal I/O keeping the device busy. Meaning @idle=false was
    always being passed to clean_target_met()
    
    Fix this by adding a specific 'cleaner' flag that is set when the
    cleaner policy is configured. This flag serves to always allow the
    cleaner's writeback work to be queued until the cache is
    decommissioned (even if the cache isn't idle).
    
    Reported-by: David Jeffery <djeffery@redhat.com>
    Fixes: b29d4986d0da ("dm cache: significant rework to leverage dm-bio-prison-v2")
    Cc: stable@vger.kernel.org
    Signed-off-by: Joe Thornber <ejt@redhat.com>
    Signed-off-by: Mike Snitzer <snitzer@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit cf83bf01b5289661ae5baf5384bb2c9629ea3b4e
Author: Radhakrishna Sripada <radhakrishna.sripada@intel.com>
Date:   Tue Jul 18 15:51:18 2023 -0700

    drm/i915/dpt: Use shmem for dpt objects
    
    commit 3844ed5e78823eebb5f0f1edefc403310693d402 upstream.
    
    Dpt objects that are created from internal get evicted when there is
    memory pressure and do not get restored when pinned during scanout. The
    pinned page table entries look corrupted and programming the display
    engine with the incorrect pte's result in DE throwing pipe faults.
    
    Create DPT objects from shmem and mark the object as dirty when pinning so
    that the object is restored when shrinker evicts an unpinned buffer object.
    
    v2: Unconditionally mark the dpt objects dirty during pinning(Chris).
    
    Fixes: 0dc987b699ce ("drm/i915/display: Add smem fallback allocation for dpt")
    Cc: <stable@vger.kernel.org> # v6.0+
    Cc: Ville Syrjälä <ville.syrjala@linux.intel.com>
    Cc: Tvrtko Ursulin <tvrtko.ursulin@linux.intel.com>
    Suggested-by: Chris Wilson <chris.p.wilson@intel.com>
    Signed-off-by: Fei Yang <fei.yang@intel.com>
    Signed-off-by: Radhakrishna Sripada <radhakrishna.sripada@intel.com>
    Reviewed-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
    Link: https://patchwork.freedesktop.org/patch/msgid/20230718225118.2562132-1-radhakrishna.sripada@intel.com
    (cherry picked from commit e91a777a6e602ba0e3366e053e4e094a334a1244)
    Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit c5126152c6f627ee25915f5c15d3ab58b3a4d05a
Author: Xiubo Li <xiubli@redhat.com>
Date:   Thu Jul 20 11:33:55 2023 +0800

    ceph: never send metrics if disable_send_metrics is set
    
    commit 50164507f6b7b7ed85d8c3ac0266849fbd908db7 upstream.
    
    Even the 'disable_send_metrics' is true so when the session is
    being opened it will always trigger to send the metric for the
    first time.
    
    Cc: stable@vger.kernel.org
    Signed-off-by: Xiubo Li <xiubli@redhat.com>
    Reviewed-by: Venky Shankar <vshankar@redhat.com>
    Reviewed-by: Jeff Layton <jlayton@kernel.org>
    Signed-off-by: Ilya Dryomov <idryomov@gmail.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit adce49089412a9ae28f5c666e0bb12fbcd86b3f7
Author: Ahmad Fatoum <a.fatoum@pengutronix.de>
Date:   Sat Jul 8 13:27:20 2023 +0200

    thermal: of: fix double-free on unregistration
    
    commit ac4436a5b20e0ef1f608a9ef46c08d5d142f8da6 upstream.
    
    Since commit 3d439b1a2ad3 ("thermal/core: Alloc-copy-free the thermal
    zone parameters structure"), thermal_zone_device_register() allocates
    a copy of the tzp argument and frees it when unregistering, so
    thermal_of_zone_register() now ends up leaking its original tzp and
    double-freeing the tzp copy. Fix this by locating tzp on stack instead.
    
    Fixes: 3d439b1a2ad3 ("thermal/core: Alloc-copy-free the thermal zone parameters structure")
    Signed-off-by: Ahmad Fatoum <a.fatoum@pengutronix.de>
    Acked-by: Daniel Lezcano <daniel.lezcano@linaro.org>
    Cc: 6.4+ <stable@vger.kernel.org> # 6.4+: 8bcbb18c61d6: thermal: core: constify params in thermal_zone_device_register
    Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 5dac557301d868a55645c5681d14a48da2fde189
Author: Johan Hovold <johan+linaro@kernel.org>
Date:   Thu Jul 13 16:57:39 2023 +0200

    PM: sleep: wakeirq: fix wake irq arming
    
    commit 8527beb12087238d4387607597b4020bc393c4b4 upstream.
    
    The decision whether to enable a wake irq during suspend can not be done
    based on the runtime PM state directly as a driver may use wake irqs
    without implementing runtime PM. Such drivers specifically leave the
    state set to the default 'suspended' and the wake irq is thus never
    enabled at suspend.
    
    Add a new wake irq flag to track whether a dedicated wake irq has been
    enabled at runtime suspend and therefore must not be enabled at system
    suspend.
    
    Note that pm_runtime_enabled() can not be used as runtime PM is always
    disabled during late suspend.
    
    Fixes: 69728051f5bf ("PM / wakeirq: Fix unbalanced IRQ enable for wakeirq")
    Cc: 4.16+ <stable@vger.kernel.org> # 4.16+
    Signed-off-by: Johan Hovold <johan+linaro@kernel.org>
    Reviewed-by: Tony Lindgren <tony@atomide.com>
    Tested-by: Tony Lindgren <tony@atomide.com>
    Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 807ada0e4aa3c9090c66009a99fa530c462012c9
Author: Mark Brown <broonie@kernel.org>
Date:   Wed Jul 26 13:12:26 2023 +0100

    arm64/sme: Set new vector length before reallocating
    
    commit 05d881b85b48c7ac6a7c92ce00aa916c4a84d052 upstream.
    
    As part of fixing the allocation of the buffer for SVE state when changing
    SME vector length we introduced an immediate reallocation of the SVE state,
    this is also done when changing the SVE vector length for consistency.
    Unfortunately this reallocation is done prior to writing the new vector
    length to the task struct, meaning the allocation is done with the old
    vector length and can lead to memory corruption due to an undersized buffer
    being used.
    
    Move the update of the vector length before the allocation to ensure that
    the new vector length is taken into account.
    
    For some reason this isn't triggering any problems when running tests on
    the arm64 fixes branch (even after repeated tries) but is triggering
    issues very often after merge into mainline.
    
    Fixes: d4d5be94a878 ("arm64/fpsimd: Ensure SME storage is allocated after SVE VL changes")
    Signed-off-by: Mark Brown <broonie@kernel.org>
    Cc: <stable@vger.kernel.org>
    Link: https://lore.kernel.org/r/20230726-arm64-fix-sme-fix-v1-1-7752ec58af27@kernel.org
    Signed-off-by: Catalin Marinas <catalin.marinas@arm.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 684c1a948ece960bfa314a6c7ca77c4cd0e71785
Author: Mark Brown <broonie@kernel.org>
Date:   Sun Jul 23 00:27:22 2023 +0100

    ASoC: wm8904: Fill the cache for WM8904_ADC_TEST_0 register
    
    commit f061e2be8689057cb4ec0dbffa9f03e1a23cdcb2 upstream.
    
    The WM8904_ADC_TEST_0 register is modified as part of updating the OSR
    controls but does not have a cache default, leading to errors when we try
    to modify these controls in cache only mode with no prior read:
    
    wm8904 3-001a: ASoC: error at snd_soc_component_update_bits on wm8904.3-001a for register: [0x000000c6] -16
    
    Add a read of the register to probe() to fill the cache and avoid both the
    error messages and the misconfiguration of the chip which will result.
    
    Acked-by: Charles Keepax <ckeepax@opensource.cirrus.com>
    Signed-off-by: Mark Brown <broonie@kernel.org>
    Cc: stable@vger.kernel.org
    Link: https://lore.kernel.org/r/20230723-asoc-fix-wm8904-adc-test-read-v1-1-2cdf2edd83fd@kernel.org
    Signed-off-by: Mark Brown <broonie@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit c58951ccef60301225f0706a45802e19d8fc03e4
Author: Paolo Abeni <pabeni@redhat.com>
Date:   Tue Jul 25 11:34:56 2023 -0700

    mptcp: more accurate NL event generation
    
    commit 21d9b73a7d5241905367098d260a3c68b811da32 upstream.
    
    Currently the mptcp code generate a "new listener" event even
    if the actual listen() syscall fails. Address the issue moving
    the event generation call under the successful branch.
    
    Cc: stable@vger.kernel.org
    Fixes: f8c9dfbd875b ("mptcp: add pm listener events")
    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/20230725-send-net-20230725-v1-2-6f60fe7137a9@kernel.org
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 8aba7fb2544ac6de5ce18a66dd0b6f8c5ca6433c
Author: Stefan Haberland <sth@linux.ibm.com>
Date:   Fri Jul 21 21:36:47 2023 +0200

    s390/dasd: print copy pair message only for the correct error
    
    commit 856d8e3c633b183df23549ce760ae84478a7098d upstream.
    
    The DASD driver has certain types of requests that might be rejected by
    the storage server or z/VM because they are not supported. Since the
    missing support of the command is not a real issue there is no user
    visible kernel error message for this.
    
    For copy pair setups  there is a specific error that IO is not allowed on
    secondary devices. This error case is explicitly handled and an error
    message is printed.
    
    The code checking for the error did use a bitwise 'and' that is used to
    check for specific bits. But in this case the whole sense byte has to
    match.
    
    This leads to the problem that the copy pair related error message is
    erroneously printed for other error cases that are usually not reported.
    This might heavily confuse users and lead to follow on actions that might
    disrupt application processing.
    
    Fix by checking the sense byte for the exact value and not single bits.
    
    Cc: stable@vger.kernel.org # 6.1+
    Fixes: 1fca631a1185 ("s390/dasd: suppress generic error messages for PPRC secondary devices")
    Signed-off-by: Stefan Haberland <sth@linux.ibm.com>
    Reviewed-by: Jan Hoeppner <hoeppner@linux.ibm.com>
    Link: https://lore.kernel.org/r/20230721193647.3889634-5-sth@linux.ibm.com
    Signed-off-by: Jens Axboe <axboe@kernel.dk>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 274b5383e999576a0416269a1e6ecea580335969
Author: Stefan Haberland <sth@linux.ibm.com>
Date:   Fri Jul 21 21:36:44 2023 +0200

    s390/dasd: fix hanging device after quiesce/resume
    
    commit 05f1d8ed03f547054efbc4d29bb7991c958ede95 upstream.
    
    Quiesce and resume are functions that tell the DASD driver to stop/resume
    issuing I/Os to a specific DASD.
    
    On resume dasd_schedule_block_bh() is called to kick handling of IO
    requests again. This does unfortunately not cover internal requests which
    are used for path verification for example.
    
    This could lead to a hanging device when a path event or anything else
    that triggers internal requests occurs on a quiesced device.
    
    Fix by also calling dasd_schedule_device_bh() which triggers handling of
    internal requests on resume.
    
    Fixes: 8e09f21574ea ("[S390] dasd: add hyper PAV support to DASD device driver, part 1")
    
    Cc: stable@vger.kernel.org
    Signed-off-by: Stefan Haberland <sth@linux.ibm.com>
    Reviewed-by: Jan Hoeppner <hoeppner@linux.ibm.com>
    Link: https://lore.kernel.org/r/20230721193647.3889634-2-sth@linux.ibm.com
    Signed-off-by: Jens Axboe <axboe@kernel.dk>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 592b0c50e3fbec08affa6b3b6b82c5a18bcad220
Author: Eric Van Hensbergen <ericvh@kernel.org>
Date:   Wed Jul 19 16:22:33 2023 +0000

    fs/9p: remove unnecessary invalidate_inode_pages2
    
    commit 350cd9b959757e7c571f45fab29d116d5f67cbff upstream.
    
    There was an invalidate_inode_pages2 added to readonly mmap path
    that is unnecessary since that path is only entered when writeback
    cache is disabled on mount.
    
    Cc: stable@vger.kernel.org
    Fixes: 1543b4c5071c ("fs/9p: remove writeback fid and fix per-file modes")
    Reviewed-by: Christian Schoenebeck <linux_oss@crudebyte.com>
    Signed-off-by: Eric Van Hensbergen <ericvh@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit cd27c7f7905657dc7cb479d44face94e4e936f69
Author: Eric Van Hensbergen <ericvh@kernel.org>
Date:   Wed Jul 19 16:22:32 2023 +0000

    fs/9p: fix type mismatch in file cache mode helper
    
    commit 09430aba3a9ffd986834614a3406a13588170bde upstream.
    
    There were two flags (s_flags and s_cache) which had incorrect signed
    type in the parameters of the file cache mode helper function.
    
    Cc: stable@vger.kernel.org
    Fixes: 1543b4c5071c ("fs/9p: remove writeback fid and fix per-file modes")
    Reviewed-by: Dominique Martinet <asmadeus@codewreck.org>
    Signed-off-by: Eric Van Hensbergen <ericvh@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit f7fb8699068fce6c7d72891330825933e5a0b005
Author: Eric Van Hensbergen <ericvh@kernel.org>
Date:   Wed Jul 19 16:22:31 2023 +0000

    fs/9p: fix typo in comparison logic for cache mode
    
    commit 878cb3e0337d7c3096aee301a2a3cd358dc8aa81 upstream.
    
    There appears to be a typo in the comparison statement for the logic
    which sets a file's cache mode based on mount flags.
    
    Cc: stable@vger.kernel.org
    Fixes: 1543b4c5071c ("fs/9p: remove writeback fid and fix per-file modes")
    Reviewed-by: Christian Schoenebeck <linux_oss@crudebyte.com>
    Reviewed-by: Dominique Martinet <asmadeus@codewreck.org>
    Signed-off-by: Eric Van Hensbergen <ericvh@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 00c6ee38522e04ef9f83c331bed2cb34472c3011
Author: Eric Van Hensbergen <ericvh@kernel.org>
Date:   Wed Jul 19 16:22:30 2023 +0000

    fs/9p: remove unnecessary and overrestrictive check
    
    commit 75b396821cb71164dac3a1ad51dda4781ea8dbad upstream.
    
    This eliminates a check for shared that was overrestrictive and
    prevented read-only mmaps when writeback caches weren't enabled.
    
    Cc: stable@vger.kernel.org
    Fixes: 1543b4c5071c ("fs/9p: remove writeback fid and fix per-file modes")
    Reported-by: Robert Schwebel <r.schwebel@pengutronix.de>
    Closes: https://lore.kernel.org/v9fs/ZK25XZ%2BGpR3KHIB%2F@pengutronix.de
    Reviewed-by: Dominique Martinet <asmadeus@codewreck.org>
    Reviewed-by: Christian Schoenebeck <linux_oss@crudebyte.com>
    Signed-off-by: Eric Van Hensbergen <ericvh@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit f1e24c44ab4dce954e35fe3eaf16e8577fd99a00
Author: Dominique Martinet <asmadeus@codewreck.org>
Date:   Wed May 3 16:49:25 2023 +0900

    9p: fix ignored return value in v9fs_dir_release
    
    commit eee4a119e96c2f58cfd1b6d4de42095abc5f8877 upstream.
    
    retval from filemap_fdatawrite was immediately overwritten by the
    following p9_fid_put: preserve any error in fdatawrite if there
    was any first.
    
    This fixes the following scan-build warning:
    fs/9p/vfs_dir.c:220:4: warning: Value stored to 'retval' is never read [deadcode.DeadStores]
                            retval = filemap_fdatawrite(inode->i_mapping);
                            ^        ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
    
    Fixes: 89c58cb395ec ("fs/9p: fix error reporting in v9fs_dir_release")
    Cc: stable@vger.kernel.org
    Reviewed-by: Simon Horman <simon.horman@corigine.com>
    Signed-off-by: Dominique Martinet <asmadeus@codewreck.org>
    Signed-off-by: Eric Van Hensbergen <ericvh@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit c9d7e61044f5300dc5245fbe4bd951508c8e75d3
Author: Chenguang Zhao <zhaochenguang@kylinos.cn>
Date:   Fri Jul 28 10:30:42 2023 +0800

    LoongArch: BPF: Enable bpf_probe_read{, str}() on LoongArch
    
    commit de0e30bee86d0f99c696a1fea34474e556a946ec upstream.
    
    Currently nettrace does not work on LoongArch due to missing
    bpf_probe_read{,str}() support, with the error message:
    
         ERROR: failed to load kprobe-based eBPF
         ERROR: failed to load kprobe-based bpf
    
    According to commit 0ebeea8ca8a4d1d ("bpf: Restrict bpf_probe_read{,
    str}() only to archs where they work"), we only need to select
    CONFIG_ARCH_HAS_NON_OVERLAPPING_ADDRESS_SPACE to add said support,
    because LoongArch does have non-overlapping address ranges for kernel
    and userspace.
    
    Cc: stable@vger.kernel.org # 6.1
    Signed-off-by: Chenguang Zhao <zhaochenguang@kylinos.cn>
    Signed-off-by: Huacai Chen <chenhuacai@loongson.cn>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 47f0ef81b15e2ca24c91aad1585e52035e8225a1
Author: Tiezhu Yang <yangtiezhu@loongson.cn>
Date:   Fri Jul 28 10:30:42 2023 +0800

    LoongArch: BPF: Fix check condition to call lu32id in move_imm()
    
    commit 4eece7e6de94d833c8aeed2f438faf487cbf94ff upstream.
    
    As the code comment says, the initial aim is to reduce one instruction
    in some corner cases, if bit[51:31] is all 0 or all 1, no need to call
    lu32id. That is to say, it should call lu32id only if bit[51:31] is not
    all 0 and not all 1. The current code always call lu32id, the result is
    right but the logic is unexpected and wrong, fix it.
    
    Cc: stable@vger.kernel.org # 6.1
    Fixes: 5dc615520c4d ("LoongArch: Add BPF JIT support")
    Reported-by: Colin King (gmail) <colin.i.king@gmail.com>
    Closes: https://lore.kernel.org/all/bcf97046-e336-712a-ac68-7fd194f2953e@gmail.com/
    Signed-off-by: Tiezhu Yang <yangtiezhu@loongson.cn>
    Signed-off-by: Huacai Chen <chenhuacai@loongson.cn>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit a04cb0c40887f2c0881d9dcce00b65872d9fa71f
Author: WANG Rui <wangrui@loongson.cn>
Date:   Fri Jul 28 10:30:42 2023 +0800

    LoongArch: Fix return value underflow in exception path
    
    commit e66d511fc92201ba481392e54896f1aeadfcf0e9 upstream.
    
    This patch fixes an underflow issue in the return value within the
    exception path, specifically at .Llt8 when the remaining length is less
    than 8 bytes.
    
    Cc: stable@vger.kernel.org
    Fixes: 8941e93ca590 ("LoongArch: Optimize memory ops (memset/memcpy/memmove)")
    Reported-by: Weihao Li <liweihao@loongson.cn>
    Signed-off-by: WANG Rui <wangrui@loongson.cn>
    Signed-off-by: Huacai Chen <chenhuacai@loongson.cn>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 453af7c2cc90335ca3838f23a6e4e8fb0a5b0f27
Author: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
Date:   Mon Jul 24 17:31:31 2023 +0300

    Revert "um: Use swap() to make code cleaner"
    
    commit dddfa05eb58076ad60f9a66e7155a5b3502b2dd5 upstream.
    
    This reverts commit 9b0da3f22307af693be80f5d3a89dc4c7f360a85.
    
    The sigio.c is clearly user space code which is handled by
    arch/um/scripts/Makefile.rules (see USER_OBJS rule).
    
    The above mentioned commit simply broke this agreement,
    we may not use Linux kernel internal headers in them without
    thorough thinking.
    
    Hence, revert the wrong commit.
    
    Link: https://lkml.kernel.org/r/20230724143131.30090-1-andriy.shevchenko@linux.intel.com
    Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
    Reported-by: kernel test robot <lkp@intel.com>
    Closes: https://lore.kernel.org/oe-kbuild-all/202307212304.cH79zJp1-lkp@intel.com/
    Cc: Anton Ivanov <anton.ivanov@cambridgegreys.com>
    Cc: Herve Codina <herve.codina@bootlin.com>
    Cc: Jason A. Donenfeld <Jason@zx2c4.com>
    Cc: Johannes Berg <johannes@sipsolutions.net>
    Cc: Rasmus Villemoes <linux@rasmusvillemoes.dk>
    Cc: Richard Weinberger <richard@nod.at>
    Cc: Yang Guang <yang.guang5@zte.com.cn>
    Cc: <stable@vger.kernel.org>
    Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit c5265691cd065464d795de5666dcfb89c26b9bc1
Author: Johan Hovold <johan+linaro@kernel.org>
Date:   Wed Jul 5 14:30:11 2023 +0200

    soundwire: fix enumeration completion
    
    commit c40d6b3249b11d60e09d81530588f56233d9aa44 upstream.
    
    The soundwire subsystem uses two completion structures that allow
    drivers to wait for soundwire device to become enumerated on the bus and
    initialised by their drivers, respectively.
    
    The code implementing the signalling is currently broken as it does not
    signal all current and future waiters and also uses the wrong
    reinitialisation function, which can potentially lead to memory
    corruption if there are still waiters on the queue.
    
    Not signalling future waiters specifically breaks sound card probe
    deferrals as codec drivers can not tell that the soundwire device is
    already attached when being reprobed. Some codec runtime PM
    implementations suffer from similar problems as waiting for enumeration
    during resume can also timeout despite the device already having been
    enumerated.
    
    Fixes: fb9469e54fa7 ("soundwire: bus: fix race condition with enumeration_complete signaling")
    Fixes: a90def068127 ("soundwire: bus: fix race condition with initialization_complete signaling")
    Cc: stable@vger.kernel.org      # 5.7
    Cc: Pierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
    Cc: Rander Wang <rander.wang@linux.intel.com>
    Signed-off-by: Johan Hovold <johan+linaro@kernel.org>
    Reviewed-by: Pierre-Louis Bossart <pierre-louis.bossart@linux.intel.com>
    Link: https://lore.kernel.org/r/20230705123018.30903-2-johan+linaro@kernel.org
    Signed-off-by: Vinod Koul <vkoul@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit c9491c0b24f8543b53cebb099363db9dc903ce17
Author: Matthieu Baerts <matthieu.baerts@tessares.net>
Date:   Tue Jul 25 11:34:55 2023 -0700

    selftests: mptcp: join: only check for ip6tables if needed
    
    commit 016e7ba47f33064fbef8c4307a2485d2669dfd03 upstream.
    
    If 'iptables-legacy' is available, 'ip6tables-legacy' command will be
    used instead of 'ip6tables'. So no need to look if 'ip6tables' is
    available in this case.
    
    Cc: stable@vger.kernel.org
    Fixes: 0c4cd3f86a40 ("selftests: mptcp: join: use 'iptables-legacy' if available")
    Acked-by: Paolo Abeni <pabeni@redhat.com>
    Signed-off-by: Matthieu Baerts <matthieu.baerts@tessares.net>
    Signed-off-by: Mat Martineau <martineau@kernel.org>
    Link: https://lore.kernel.org/r/20230725-send-net-20230725-v1-1-6f60fe7137a9@kernel.org
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 176f36a376c417b58d19f79edfce20db9317eaa2
Author: Jason Gunthorpe <jgg@ziepe.ca>
Date:   Tue Jul 25 16:05:50 2023 -0300

    iommufd: Set end correctly when doing batch carry
    
    commit b7c822fa6b7701b17e139f1c562fc24135880ed4 upstream.
    
    Even though the test suite covers this it somehow became obscured that
    this wasn't working.
    
    The test iommufd_ioas.mock_domain.access_domain_destory would blow up
    rarely.
    
    end should be set to 1 because this just pushed an item, the carry, to the
    pfns list.
    
    Sometimes the test would blow up with:
    
      BUG: kernel NULL pointer dereference, address: 0000000000000000
      #PF: supervisor read access in kernel mode
      #PF: error_code(0x0000) - not-present page
      PGD 0 P4D 0
      Oops: 0000 [#1] SMP
      CPU: 5 PID: 584 Comm: iommufd Not tainted 6.5.0-rc1-dirty #1236
      Hardware name: QEMU Standard PC (Q35 + ICH9, 2009), BIOS rel-1.13.0-0-gf21b5a4aeb02-prebuilt.qemu.org 04/01/2014
      RIP: 0010:batch_unpin+0xa2/0x100 [iommufd]
      Code: 17 48 81 fe ff ff 07 00 77 70 48 8b 15 b7 be 97 e2 48 85 d2 74 14 48 8b 14 fa 48 85 d2 74 0b 40 0f b6 f6 48 c1 e6 04 48 01 f2 <48> 8b 3a 48 c1 e0 06 89 ca 48 89 de 48 83 e7 f0 48 01 c7 e8 96 dc
      RSP: 0018:ffffc90001677a58 EFLAGS: 00010246
      RAX: 00007f7e2646f000 RBX: 0000000000000000 RCX: 0000000000000001
      RDX: 0000000000000000 RSI: 00000000fefc4c8d RDI: 0000000000fefc4c
      RBP: ffffc90001677a80 R08: 0000000000000048 R09: 0000000000000200
      R10: 0000000000030b98 R11: ffffffff81f3bb40 R12: 0000000000000001
      R13: ffff888101f75800 R14: ffffc90001677ad0 R15: 00000000000001fe
      FS:  00007f9323679740(0000) GS:ffff8881ba540000(0000) knlGS:0000000000000000
      CS:  0010 DS: 0000 ES: 0000 CR0: 0000000080050033
      CR2: 0000000000000000 CR3: 0000000105ede003 CR4: 00000000003706a0
      DR0: 0000000000000000 DR1: 0000000000000000 DR2: 0000000000000000
      DR3: 0000000000000000 DR6: 00000000fffe0ff0 DR7: 0000000000000400
      Call Trace:
       <TASK>
       ? show_regs+0x5c/0x70
       ? __die+0x1f/0x60
       ? page_fault_oops+0x15d/0x440
       ? lock_release+0xbc/0x240
       ? exc_page_fault+0x4a4/0x970
       ? asm_exc_page_fault+0x27/0x30
       ? batch_unpin+0xa2/0x100 [iommufd]
       ? batch_unpin+0xba/0x100 [iommufd]
       __iopt_area_unfill_domain+0x198/0x430 [iommufd]
       ? __mutex_lock+0x8c/0xb80
       ? __mutex_lock+0x6aa/0xb80
       ? xa_erase+0x28/0x30
       ? iopt_table_remove_domain+0x162/0x320 [iommufd]
       ? lock_release+0xbc/0x240
       iopt_area_unfill_domain+0xd/0x10 [iommufd]
       iopt_table_remove_domain+0x195/0x320 [iommufd]
       iommufd_hw_pagetable_destroy+0xb3/0x110 [iommufd]
       iommufd_object_destroy_user+0x8e/0xf0 [iommufd]
       iommufd_device_detach+0xc5/0x140 [iommufd]
       iommufd_selftest_destroy+0x1f/0x70 [iommufd]
       iommufd_object_destroy_user+0x8e/0xf0 [iommufd]
       iommufd_destroy+0x3a/0x50 [iommufd]
       iommufd_fops_ioctl+0xfb/0x170 [iommufd]
       __x64_sys_ioctl+0x40d/0x9a0
       do_syscall_64+0x3c/0x80
       entry_SYSCALL_64_after_hwframe+0x46/0xb0
    
    Link: https://lore.kernel.org/r/3-v1-85aacb2af554+bc-iommufd_syz3_jgg@nvidia.com
    Cc: <stable@vger.kernel.org>
    Fixes: f394576eb11d ("iommufd: PFN handling for iopt_pages")
    Reviewed-by: Kevin Tian <kevin.tian@intel.com>
    Tested-by: Nicolin Chen <nicolinc@nvidia.com>
    Reported-by: Nicolin Chen <nicolinc@nvidia.com>
    Signed-off-by: Jason Gunthorpe <jgg@nvidia.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 45484d96d599ee1882d1b129899da18d79367f9c
Author: Jens Axboe <axboe@kernel.dk>
Date:   Mon Jul 24 11:28:17 2023 -0600

    io_uring: gate iowait schedule on having pending requests
    
    commit 7b72d661f1f2f950ab8c12de7e2bc48bdac8ed69 upstream.
    
    A previous commit made all cqring waits marked as iowait, as a way to
    improve performance for short schedules with pending IO. However, for
    use cases that have a special reaper thread that does nothing but
    wait on events on the ring, this causes a cosmetic issue where we
    know have one core marked as being "busy" with 100% iowait.
    
    While this isn't a grave issue, it is confusing to users. Rather than
    always mark us as being in iowait, gate setting of current->in_iowait
    to 1 by whether or not the waiting task has pending requests.
    
    Cc: stable@vger.kernel.org
    Link: https://lore.kernel.org/io-uring/CAMEGJJ2RxopfNQ7GNLhr7X9=bHXKo+G5OOe0LUq=+UgLXsv1Xg@mail.gmail.com/
    Link: https://bugzilla.kernel.org/show_bug.cgi?id=217699
    Link: https://bugzilla.kernel.org/show_bug.cgi?id=217700
    Reported-by: Oleksandr Natalenko <oleksandr@natalenko.name>
    Reported-by: Phil Elwell <phil@raspberrypi.com>
    Tested-by: Andres Freund <andres@anarazel.de>
    Fixes: 8a796565cec3 ("io_uring: Use io_schedule* in cqring wait")
    Signed-off-by: Jens Axboe <axboe@kernel.dk>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 29cf01eed50fb7a128a442c6194494276f3c2df9
Author: Christian Marangi <ansuelsmth@gmail.com>
Date:   Mon Jul 24 05:25:31 2023 +0200

    net: dsa: qca8k: fix mdb add/del case with 0 VID
    
    commit dfd739f182b00b02bd7470ed94d112684cc04fa2 upstream.
    
    The qca8k switch doesn't support using 0 as VID and require a default
    VID to be always set. MDB add/del function doesn't currently handle
    this and are currently setting the default VID.
    
    Fix this by correctly handling this corner case and internally use the
    default VID for VID 0 case.
    
    Fixes: ba8f870dfa63 ("net: dsa: qca8k: add support for mdb_add/del")
    Signed-off-by: Christian Marangi <ansuelsmth@gmail.com>
    Cc: stable@vger.kernel.org
    Signed-off-by: David S. Miller <davem@davemloft.net>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit bb7b454fff661bea9af0eb1fb6c63606bb0ffc0c
Author: Christian Marangi <ansuelsmth@gmail.com>
Date:   Mon Jul 24 05:25:30 2023 +0200

    net: dsa: qca8k: fix broken search_and_del
    
    commit ae70dcb9d9ecaf7d9836d3e1b5bef654d7ef5680 upstream.
    
    On deleting an MDB entry for a port, fdb_search_and_del is used.
    An FDB entry can't be modified so it needs to be deleted and readded
    again with the new portmap (and the port deleted as requested)
    
    We use the SEARCH operator to search the entry to edit by vid and mac
    address and then we check the aging if we actually found an entry.
    
    Currently the code suffer from a bug where the searched fdb entry is
    never read again with the found values (if found) resulting in the code
    always returning -EINVAL as aging was always 0.
    
    Fix this by correctly read the fdb entry after it was searched.
    
    Fixes: ba8f870dfa63 ("net: dsa: qca8k: add support for mdb_add/del")
    Signed-off-by: Christian Marangi <ansuelsmth@gmail.com>
    Cc: stable@vger.kernel.org
    Signed-off-by: David S. Miller <davem@davemloft.net>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 3797de3d4b0f7da0b62420bcd6bb1766a288fe1e
Author: Christian Marangi <ansuelsmth@gmail.com>
Date:   Mon Jul 24 05:25:29 2023 +0200

    net: dsa: qca8k: fix search_and_insert wrong handling of new rule
    
    commit 80248d4160894d7e40b04111bdbaa4ff93fc4bd7 upstream.
    
    On inserting a mdb entry, fdb_search_and_insert is used to add a port to
    the qca8k target entry in the FDB db.
    
    A FDB entry can't be modified so it needs to be removed and insert again
    with the new values.
    
    To detect if an entry already exist, the SEARCH operation is used and we
    check the aging of the entry. If the entry is not 0, the entry exist and
    we proceed to delete it.
    
    Current code have 2 main problem:
    - The condition to check if the FDB entry exist is wrong and should be
      the opposite.
    - When a FDB entry doesn't exist, aging was never actually set to the
      STATIC value resulting in allocating an invalid entry.
    
    Fix both problem by adding aging support to the function, calling the
    function with STATIC as aging by default and finally by correct the
    condition to check if the entry actually exist.
    
    Fixes: ba8f870dfa63 ("net: dsa: qca8k: add support for mdb_add/del")
    Signed-off-by: Christian Marangi <ansuelsmth@gmail.com>
    Cc: stable@vger.kernel.org
    Signed-off-by: David S. Miller <davem@davemloft.net>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit d04084d09f7c5ce3a85c7a922270a66393f4ff75
Author: Christian Marangi <ansuelsmth@gmail.com>
Date:   Mon Jul 24 05:25:28 2023 +0200

    net: dsa: qca8k: enable use_single_write for qca8xxx
    
    commit 2c39dd025da489cf87d26469d9f5ff19715324a0 upstream.
    
    The qca8xxx switch supports 2 way to write reg values, a slow way using
    mdio and a fast way by sending specially crafted mgmt packet to
    read/write reg.
    
    The fast way can support up to 32 bytes of data as eth packet are used
    to send/receive.
    
    This correctly works for almost the entire regmap of the switch but with
    the use of some kernel selftests for dsa drivers it was found a funny
    and interesting hw defect/limitation.
    
    For some specific reg, bulk write won't work and will result in writing
    only part of the requested regs resulting in half data written. This was
    especially hard to track and discover due to the total strangeness of
    the problem and also by the specific regs where this occurs.
    
    This occurs in the specific regs of the ATU table, where multiple entry
    needs to be written to compose the entire entry.
    It was discovered that with a bulk write of 12 bytes on
    QCA8K_REG_ATU_DATA0 only QCA8K_REG_ATU_DATA0 and QCA8K_REG_ATU_DATA2
    were written, but QCA8K_REG_ATU_DATA1 was always zero.
    Tcpdump was used to make sure the specially crafted packet was correct
    and this was confirmed.
    
    The problem was hard to track as the lack of QCA8K_REG_ATU_DATA1
    resulted in an entry somehow possible as the first bytes of the mac
    address are set in QCA8K_REG_ATU_DATA0 and the entry type is set in
    QCA8K_REG_ATU_DATA2.
    
    Funlly enough writing QCA8K_REG_ATU_DATA1 results in the same problem
    with QCA8K_REG_ATU_DATA2 empty and QCA8K_REG_ATU_DATA1 and
    QCA8K_REG_ATU_FUNC correctly written.
    A speculation on the problem might be that there are some kind of
    indirection internally when accessing these regs and they can't be
    accessed all together, due to the fact that it's really a table mapped
    somewhere in the switch SRAM.
    
    Even more funny is the fact that every other reg was tested with all
    kind of combination and they are not affected by this problem. Read
    operation was also tested and always worked so it's not affected by this
    problem.
    
    The problem is not present if we limit writing a single reg at times.
    
    To handle this hardware defect, enable use_single_write so that bulk
    api can correctly split the write in multiple different operation
    effectively reverting to a non-bulk write.
    
    Cc: Mark Brown <broonie@kernel.org>
    Fixes: c766e077d927 ("net: dsa: qca8k: convert to regmap read/write API")
    Signed-off-by: Christian Marangi <ansuelsmth@gmail.com>
    Cc: stable@vger.kernel.org
    Signed-off-by: David S. Miller <davem@davemloft.net>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit c00af3a818cc573e10100cc6770f0e47befa1fa4
Author: Alex Elder <elder@linaro.org>
Date:   Mon Jul 24 17:40:55 2023 -0500

    net: ipa: only reset hashed tables when supported
    
    commit e11ec2b868af2b351c6c1e2e50eb711cc5423a10 upstream.
    
    Last year, the code that manages GSI channel transactions switched
    from using spinlock-protected linked lists to using indexes into the
    ring buffer used for a channel.  Recently, Google reported seeing
    transaction reference count underflows occasionally during shutdown.
    
    Doug Anderson found a way to reproduce the issue reliably, and
    bisected the issue to the commit that eliminated the linked lists
    and the lock.  The root cause was ultimately determined to be
    related to unused transactions being committed as part of the modem
    shutdown cleanup activity.  Unused transactions are not normally
    expected (except in error cases).
    
    The modem uses some ranges of IPA-resident memory, and whenever it
    shuts down we zero those ranges.  In ipa_filter_reset_table() a
    transaction is allocated to zero modem filter table entries.  If
    hashing is not supported, hashed table memory should not be zeroed.
    But currently nothing prevents that, and the result is an unused
    transaction.  Something similar occurs when we zero routing table
    entries for the modem.
    
    By preventing any attempt to clear hashed tables when hashing is not
    supported, the reference count underflow is avoided in this case.
    
    Note that there likely remains an issue with properly freeing unused
    transactions (if they occur due to errors).  This patch addresses
    only the underflows that Google originally reported.
    
    Cc: <stable@vger.kernel.org> # 6.1.x
    Fixes: d338ae28d8a8 ("net: ipa: kill all other transaction lists")
    Tested-by: Douglas Anderson <dianders@chromium.org>
    Signed-off-by: Alex Elder <elder@linaro.org>
    Link: https://lore.kernel.org/r/20230724224055.1688854-1-elder@linaro.org
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 2488a91b54b5d64bb2e3328c562849761ae15109
Author: Jason Wang <jasowang@redhat.com>
Date:   Tue Jul 25 03:20:49 2023 -0400

    virtio-net: fix race between set queues and probe
    
    commit 25266128fe16d5632d43ada34c847d7b8daba539 upstream.
    
    A race were found where set_channels could be called after registering
    but before virtnet_set_queues() in virtnet_probe(). Fixing this by
    moving the virtnet_set_queues() before netdevice registering. While at
    it, use _virtnet_set_queues() to avoid holding rtnl as the device is
    not even registered at that time.
    
    Cc: stable@vger.kernel.org
    Fixes: a220871be66f ("virtio-net: correctly enable multiqueue")
    Signed-off-by: Jason Wang <jasowang@redhat.com>
    Acked-by: Michael S. Tsirkin <mst@redhat.com>
    Reviewed-by: Xuan Zhuo <xuanzhuo@linux.alibaba.com>
    Link: https://lore.kernel.org/r/20230725072049.617289-1-jasowang@redhat.com
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit c76d96c555895ac602c1587b001e5cf656abc371
Author: Demi Marie Obenour <demi@invisiblethingslab.com>
Date:   Wed Jul 26 12:52:41 2023 -0400

    xen: speed up grant-table reclaim
    
    commit c04e9894846c663f3278a414f34416e6e45bbe68 upstream.
    
    When a grant entry is still in use by the remote domain, Linux must put
    it on a deferred list.  Normally, this list is very short, because
    the PV network and block protocols expect the backend to unmap the grant
    first.  However, Qubes OS's GUI protocol is subject to the constraints
    of the X Window System, and as such winds up with the frontend unmapping
    the window first.  As a result, the list can grow very large, resulting
    in a massive memory leak and eventual VM freeze.
    
    To partially solve this problem, make the number of entries that the VM
    will attempt to free at each iteration tunable.  The default is still
    10, but it can be overridden via a module parameter.
    
    This is Cc: stable because (when combined with appropriate userspace
    changes) it fixes a severe performance and stability problem for Qubes
    OS users.
    
    Cc: stable@vger.kernel.org
    Signed-off-by: Demi Marie Obenour <demi@invisiblethingslab.com>
    Reviewed-by: Juergen Gross <jgross@suse.com>
    Link: https://lore.kernel.org/r/20230726165354.1252-1-demi@invisiblethingslab.com
    Signed-off-by: Juergen Gross <jgross@suse.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 6efc575dd2a64375a459fb07a19e3377f5d488a6
Author: Dan Carpenter <dan.carpenter@linaro.org>
Date:   Tue Jul 25 20:03:16 2023 +0300

    proc/vmcore: fix signedness bug in read_from_oldmem()
    
    commit 641db40f3afe7998011bfabc726dba3e698f8196 upstream.
    
    The bug is the error handling:
    
            if (tmp < nr_bytes) {
    
    "tmp" can hold negative error codes but because "nr_bytes" is type size_t
    the negative error codes are treated as very high positive values
    (success).  Fix this by changing "nr_bytes" to type ssize_t.  The
    "nr_bytes" variable is used to store values between 1 and PAGE_SIZE and
    they can fit in ssize_t without any issue.
    
    Link: https://lkml.kernel.org/r/b55f7eed-1c65-4adc-95d1-6c7c65a54a6e@moroto.mountain
    Fixes: 5d8de293c224 ("vmcore: convert copy_oldmem_page() to take an iov_iter")
    Signed-off-by: Dan Carpenter <dan.carpenter@linaro.org>
    Reviewed-by: Matthew Wilcox (Oracle) <willy@infradead.org>
    Acked-by: Baoquan He <bhe@redhat.com>
    Cc: Dave Young <dyoung@redhat.com>
    Cc: Vivek Goyal <vgoyal@redhat.com>
    Cc: Alexey Dobriyan <adobriyan@gmail.com>
    Cc: <stable@vger.kernel.org>
    Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit e7b25896f447578260eba01fa78339781a733e6f
Author: Peter Zijlstra <peterz@infradead.org>
Date:   Fri Jul 7 16:19:09 2023 +0200

    locking/rtmutex: Fix task->pi_waiters integrity
    
    [ Upstream commit f7853c34241807bb97673a5e97719123be39a09e ]
    
    Henry reported that rt_mutex_adjust_prio_check() has an ordering
    problem and puts the lie to the comment in [7]. Sharing the sort key
    between lock->waiters and owner->pi_waiters *does* create problems,
    since unlike what the comment claims, holding [L] is insufficient.
    
    Notably, consider:
    
            A
          /   \
         M1   M2
         |     |
         B     C
    
    That is, task A owns both M1 and M2, B and C block on them. In this
    case a concurrent chain walk (B & C) will modify their resp. sort keys
    in [7] while holding M1->wait_lock and M2->wait_lock. So holding [L]
    is meaningless, they're different Ls.
    
    This then gives rise to a race condition between [7] and [11], where
    the requeue of pi_waiters will observe an inconsistent tree order.
    
            B                               C
    
      (holds M1->wait_lock,         (holds M2->wait_lock,
       holds B->pi_lock)             holds A->pi_lock)
    
      [7]
      waiter_update_prio();
      ...
      [8]
      raw_spin_unlock(B->pi_lock);
      ...
      [10]
      raw_spin_lock(A->pi_lock);
    
                                    [11]
                                    rt_mutex_enqueue_pi();
                                    // observes inconsistent A->pi_waiters
                                    // tree order
    
    Fixing this means either extending the range of the owner lock from
    [10-13] to [6-13], with the immediate problem that this means [6-8]
    hold both blocked and owner locks, or duplicating the sort key.
    
    Since the locking in chain walk is horrible enough without having to
    consider pi_lock nesting rules, duplicate the sort key instead.
    
    By giving each tree their own sort key, the above race becomes
    harmless, if C sees B at the old location, then B will correct things
    (if they need correcting) when it walks up the chain and reaches A.
    
    Fixes: fb00aca47440 ("rtmutex: Turn the plist into an rb-tree")
    Reported-by: Henry Wu <triangletrap12@gmail.com>
    Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>
    Acked-by: Thomas Gleixner <tglx@linutronix.de>
    Tested-by: Henry Wu <triangletrap12@gmail.com>
    Link: https://lkml.kernel.org/r/20230707161052.GF2883469%40hirez.programming.kicks-ass.net
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 018be618bcdbf1cc26ab551b391a9b9c538ece43
Author: Marc Zyngier <maz@kernel.org>
Date:   Sat Jun 17 08:32:42 2023 +0100

    irqchip/gic-v4.1: Properly lock VPEs when doing a directLPI invalidation
    
    [ Upstream commit 926846a703cbf5d0635cc06e67d34b228746554b ]
    
    We normally rely on the irq_to_cpuid_[un]lock() primitives to make
    sure nothing will change col->idx while performing a LPI invalidation.
    
    However, these primitives do not cover VPE doorbells, and we have
    some open-coded locking for that. Unfortunately, this locking is
    pretty bogus.
    
    Instead, extend the above primitives to cover VPE doorbells and
    convert the whole thing to it.
    
    Fixes: f3a059219bc7 ("irqchip/gic-v4.1: Ensure mutual exclusion between vPE affinity change and RD access")
    Reported-by: Kunkun Jiang <jiangkunkun@huawei.com>
    Signed-off-by: Marc Zyngier <maz@kernel.org>
    Cc: Zenghui Yu <yuzenghui@huawei.com>
    Cc: wanghaibin.wang@huawei.com
    Tested-by: Kunkun Jiang <jiangkunkun@huawei.com>
    Reviewed-by: Zenghui Yu <yuzenghui@huawei.com>
    Link: https://lore.kernel.org/r/20230617073242.3199746-1-maz@kernel.org
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit a0c05710f0cb37e743ff20778c9b43216473eb5f
Author: Jonas Gorski <jonas.gorski@gmail.com>
Date:   Thu Jun 29 09:26:20 2023 +0200

    irq-bcm6345-l1: Do not assume a fixed block to cpu mapping
    
    [ Upstream commit 55ad24857341c36616ecc1d9580af5626c226cf1 ]
    
    The irq to block mapping is fixed, and interrupts from the first block
    will always be routed to the first parent IRQ. But the parent interrupts
    themselves can be routed to any available CPU.
    
    This is used by the bootloader to map the first parent interrupt to the
    boot CPU, regardless wether the boot CPU is the first one or the second
    one.
    
    When booting from the second CPU, the assumption that the first block's
    IRQ is mapped to the first CPU breaks, and the system hangs because
    interrupts do not get routed correctly.
    
    Fix this by passing the appropriate bcm6434_l1_cpu to the interrupt
    handler instead of the chip itself, so the handler always has the right
    block.
    
    Fixes: c7c42ec2baa1 ("irqchips/bmips: Add bcm6345-l1 interrupt controller")
    Signed-off-by: Jonas Gorski <jonas.gorski@gmail.com>
    Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
    Reviewed-by: Florian Fainelli <florian.fainelli@broadcom.com>
    Signed-off-by: Marc Zyngier <maz@kernel.org>
    Link: https://lore.kernel.org/r/20230629072620.62527-1-jonas.gorski@gmail.com
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit b077d6531a67de10e89a3fb04cc57e523b0494ab
Author: Alexander Steffen <Alexander.Steffen@infineon.com>
Date:   Tue Jun 13 20:02:56 2023 +0200

    tpm_tis: Explicitly check for error code
    
    commit 513253f8c293c0c8bd46d09d337fc892bf8f9f48 upstream.
    
    recv_data either returns the number of received bytes, or a negative value
    representing an error code. Adding the return value directly to the total
    number of received bytes therefore looks a little weird, since it might add
    a negative error code to a sum of bytes.
    
    The following check for size < expected usually makes the function return
    ETIME in that case, so it does not cause too many problems in practice. But
    to make the code look cleaner and because the caller might still be
    interested in the original error code, explicitly check for the presence of
    an error code and pass that through.
    
    Cc: stable@vger.kernel.org
    Fixes: cb5354253af2 ("[PATCH] tpm: spacing cleanups 2")
    Signed-off-by: Alexander Steffen <Alexander.Steffen@infineon.com>
    Reviewed-by: Jarkko Sakkinen <jarkko@kernel.org>
    Signed-off-by: Jarkko Sakkinen <jarkko@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 40c627dd6de33f635b6b42e6e11aedfb364924bc
Author: Guanghui Feng <guanghuifeng@linux.alibaba.com>
Date:   Mon Jul 17 19:33:45 2023 +0800

    ACPI/IORT: Remove erroneous id_count check in iort_node_get_rmr_info()
    
    commit 003e6b56d780095a9adc23efc9cb4b4b4717169b upstream.
    
    According to the ARM IORT specifications DEN 0049 issue E,
    the "Number of IDs" field in the ID mapping format reports
    the number of IDs in the mapping range minus one.
    
    In iort_node_get_rmr_info(), we erroneously skip ID mappings
    whose "Number of IDs" equal to 0, resulting in valid mapping
    nodes with a single ID to map being skipped, which is wrong.
    
    Fix iort_node_get_rmr_info() by removing the bogus id_count
    check.
    
    Fixes: 491cf4a6735a ("ACPI/IORT: Add support to retrieve IORT RMR reserved regions")
    Signed-off-by: Guanghui Feng <guanghuifeng@linux.alibaba.com>
    Cc: <stable@vger.kernel.org> # 6.0.x
    Acked-by: Lorenzo Pieralisi <lpieralisi@kernel.org>
    Tested-by: Hanjun Guo <guohanjun@huawei.com>
    Link: https://lore.kernel.org/r/1689593625-45213-1-git-send-email-guanghuifeng@linux.alibaba.com
    Signed-off-by: Catalin Marinas <catalin.marinas@arm.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 0e625d2733657377731a1d3503d3170d034edede
Author: Namjae Jeon <linkinjeon@kernel.org>
Date:   Mon Jul 17 08:37:40 2023 +0900

    ksmbd: check if a mount point is crossed during path lookup
    
    commit 2b57a4322b1b14348940744fdc02f9a86cbbdbeb upstream.
    
    Since commit 74d7970febf7 ("ksmbd: fix racy issue from using ->d_parent and
    ->d_name"), ksmbd can not lookup cross mount points. If last component is
    a cross mount point during path lookup, check if it is crossed to follow it
    down. And allow path lookup to cross a mount point when a crossmnt
    parameter is set to 'yes' in smb.conf.
    
    Cc: stable@vger.kernel.org
    Fixes: 74d7970febf7 ("ksmbd: fix racy issue from using ->d_parent and ->d_name")
    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>

commit 293f39e1d0ae3a4985e0276b76a48f3cde3de5b9
Author: Trond Myklebust <trond.myklebust@hammerspace.com>
Date:   Tue Jul 18 08:38:37 2023 -0400

    nfsd: Remove incorrect check in nfsd4_validate_stateid
    
    commit f75546f58a70da5cfdcec5a45ffc377885ccbee8 upstream.
    
    If the client is calling TEST_STATEID, then it is because some event
    occurred that requires it to check all the stateids for validity and
    call FREE_STATEID on the ones that have been revoked. In this case,
    either the stateid exists in the list of stateids associated with that
    nfs4_client, in which case it should be tested, or it does not. There
    are no additional conditions to be considered.
    
    Reported-by: "Frank Ch. Eigler" <fche@redhat.com>
    Fixes: 7df302f75ee2 ("NFSD: TEST_STATEID should not return NFS4ERR_STALE_STATEID")
    Cc: stable@vger.kernel.org # v5.7+
    Signed-off-by: Trond Myklebust <trond.myklebust@hammerspace.com>
    Reviewed-by: Jeff Layton <jlayton@kernel.org>
    Signed-off-by: Chuck Lever <chuck.lever@oracle.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit ab8160583f5690ff401216dc4ce0b794f99605c0
Author: Christian Brauner <brauner@kernel.org>
Date:   Mon Jul 24 17:00:49 2023 +0200

    file: always lock position for FMODE_ATOMIC_POS
    
    commit 20ea1e7d13c1b544fe67c4a8dc3943bb1ab33e6f upstream.
    
    The pidfd_getfd() system call allows a caller with ptrace_may_access()
    abilities on another process to steal a file descriptor from this
    process. This system call is used by debuggers, container runtimes,
    system call supervisors, networking proxies etc. So while it is a
    special interest system call it is used in common tools.
    
    That ability ends up breaking our long-time optimization in fdget_pos(),
    which "knew" that if we had exclusive access to the file descriptor
    nobody else could access it, and we didn't need the lock for the file
    position.
    
    That check for file_count(file) was always fairly subtle - it depended
    on __fdget() not incrementing the file count for single-threaded
    processes and thus included that as part of the rule - but it did mean
    that we didn't need to take the lock in all those traditional unix
    process contexts.
    
    So it's sad to see this go, and I'd love to have some way to re-instate
    the optimization. At the same time, the lock obviously isn't ever
    contended in the case we optimized, so all we were optimizing away is
    the atomics and the cacheline dirtying. Let's see if anybody even
    notices that the optimization is gone.
    
    Link: https://lore.kernel.org/linux-fsdevel/20230724-vfs-fdget_pos-v1-1-a4abfd7103f3@kernel.org/
    Fixes: 8649c322f75c ("pid: Implement pidfd_getfd syscall")
    Cc: stable@kernel.org
    Signed-off-by: Christian Brauner <brauner@kernel.org>
    Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit e96954065d7fa34d83babea84e27ce8adb614213
Author: Kim Phillips <kim.phillips@amd.com>
Date:   Thu Jul 20 14:47:27 2023 -0500

    x86/cpu: Enable STIBP on AMD if Automatic IBRS is enabled
    
    commit fd470a8beed88440b160d690344fbae05a0b9b1b upstream.
    
    Unlike Intel's Enhanced IBRS feature, AMD's Automatic IBRS does not
    provide protection to processes running at CPL3/user mode, see section
    "Extended Feature Enable Register (EFER)" in the APM v2 at
    https://bugzilla.kernel.org/attachment.cgi?id=304652
    
    Explicitly enable STIBP to protect against cross-thread CPL3
    branch target injections on systems with Automatic IBRS enabled.
    
    Also update the relevant documentation.
    
    Fixes: e7862eda309e ("x86/cpu: Support AMD Automatic IBRS")
    Reported-by: Tom Lendacky <thomas.lendacky@amd.com>
    Signed-off-by: Kim Phillips <kim.phillips@amd.com>
    Signed-off-by: Borislav Petkov (AMD) <bp@alien8.de>
    Cc: stable@vger.kernel.org
    Link: https://lore.kernel.org/r/20230720194727.67022-1-kim.phillips@amd.com
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit fdcd4b0d519717026788bba03e527df2de691b31
Author: Yazen Ghannam <yazen.ghannam@amd.com>
Date:   Mon Jun 6 19:45:56 2022 +0000

    x86/MCE/AMD: Decrement threshold_bank refcount when removing threshold blocks
    
    commit 3ba2e83334bed2b1980b59734e6e84dfaf96026c upstream.
    
    AMD systems from Family 10h to 16h share MCA bank 4 across multiple CPUs.
    Therefore, the threshold_bank structure for bank 4, and its threshold_block
    structures, will be initialized once at boot time. And the kobject for the
    shared bank will be added to each of the CPUs that share it. Furthermore,
    the threshold_blocks for the shared bank will be added again to the bank's
    kobject. These additions will increase the refcount for the bank's kobject.
    
    For example, a shared bank with two blocks and shared across two CPUs will
    be set up like this:
    
      CPU0 init
        bank create and add; bank refcount = 1; threshold_create_bank()
          block 0 init and add; bank refcount = 2; allocate_threshold_blocks()
          block 1 init and add; bank refcount = 3; allocate_threshold_blocks()
      CPU1 init
        bank add; bank refcount = 3; threshold_create_bank()
          block 0 add; bank refcount = 4; __threshold_add_blocks()
          block 1 add; bank refcount = 5; __threshold_add_blocks()
    
    Currently in threshold_remove_bank(), if the bank is shared then
    __threshold_remove_blocks() is called. Here the shared bank's kobject and
    the bank's blocks' kobjects are deleted. This is done on the first call
    even while the structures are still shared. Subsequent calls from other
    CPUs that share the structures will attempt to delete the kobjects.
    
    During kobject_del(), kobject->sd is removed. If the kobject is not part of
    a kset with default_groups, then subsequent kobject_del() calls seem safe
    even with kobject->sd == NULL.
    
    Originally, the AMD MCA thresholding structures did not use default_groups.
    And so the above behavior was not apparent.
    
    However, a recent change implemented default_groups for the thresholding
    structures. Therefore, kobject_del() will go down the sysfs_remove_groups()
    code path. In this case, the first kobject_del() may succeed and remove
    kobject->sd. But subsequent kobject_del() calls will give a WARNing in
    kernfs_remove_by_name_ns() since kobject->sd == NULL.
    
    Use kobject_put() on the shared bank's kobject when "removing" blocks. This
    decrements the bank's refcount while keeping kobjects enabled until the
    bank is no longer shared. At that point, kobject_put() will be called on
    the blocks which drives their refcount to 0 and deletes them and also
    decrementing the bank's refcount. And finally kobject_put() will be called
    on the bank driving its refcount to 0 and deleting it.
    
    The same example above:
    
      CPU1 shutdown
        bank is shared; bank refcount = 5; threshold_remove_bank()
          block 0 put parent bank; bank refcount = 4; __threshold_remove_blocks()
          block 1 put parent bank; bank refcount = 3; __threshold_remove_blocks()
      CPU0 shutdown
        bank is no longer shared; bank refcount = 3; threshold_remove_bank()
          block 0 put block; bank refcount = 2; deallocate_threshold_blocks()
          block 1 put block; bank refcount = 1; deallocate_threshold_blocks()
        put bank; bank refcount = 0; threshold_remove_bank()
    
    Fixes: 7f99cb5e6039 ("x86/CPU/AMD: Use default_groups in kobj_type")
    Reported-by: Mikulas Patocka <mpatocka@redhat.com>
    Signed-off-by: Yazen Ghannam <yazen.ghannam@amd.com>
    Signed-off-by: Borislav Petkov (AMD) <bp@alien8.de>
    Tested-by: Mikulas Patocka <mpatocka@redhat.com>
    Cc: <stable@kernel.org>
    Link: https://lore.kernel.org/r/alpine.LRH.2.02.2205301145540.25840@file01.intranet.prod.int.rdu2.redhat.com
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit db73d812bb952a87f5c8e7d3363975848129dac0
Author: Filipe Manana <fdmanana@suse.com>
Date:   Fri Jul 21 10:49:21 2023 +0100

    btrfs: check for commit error at btrfs_attach_transaction_barrier()
    
    commit b28ff3a7d7e97456fd86b68d24caa32e1cfa7064 upstream.
    
    btrfs_attach_transaction_barrier() is used to get a handle pointing to the
    current running transaction if the transaction has not started its commit
    yet (its state is < TRANS_STATE_COMMIT_START). If the transaction commit
    has started, then we wait for the transaction to commit and finish before
    returning - however we completely ignore if the transaction was aborted
    due to some error during its commit, we simply return ERR_PT(-ENOENT),
    which makes the caller assume everything is fine and no errors happened.
    
    This could make an fsync return success (0) to user space when in fact we
    had a transaction abort and the target inode changes were therefore not
    persisted.
    
    Fix this by checking for the return value from btrfs_wait_for_commit(),
    and if it returned an error, return it back to the caller.
    
    Fixes: d4edf39bd5db ("Btrfs: fix uncompleted transaction")
    CC: stable@vger.kernel.org # 4.19+
    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>

commit ec0a56ae9519e7768b16cdd58dc48bc35a39ae08
Author: Filipe Manana <fdmanana@suse.com>
Date:   Fri Jul 21 10:49:20 2023 +0100

    btrfs: check if the transaction was aborted at btrfs_wait_for_commit()
    
    commit bf7ecbe9875061bf3fce1883e3b26b77f847d1e8 upstream.
    
    At btrfs_wait_for_commit() we wait for a transaction to finish and then
    always return 0 (success) without checking if it was aborted, in which
    case the transaction didn't happen due to some critical error. Fix this
    by checking if the transaction was aborted.
    
    Fixes: 462045928bda ("Btrfs: add START_SYNC, WAIT_SYNC ioctls")
    CC: stable@vger.kernel.org # 4.19+
    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>

commit 1e8087589b5cf6fa17adaf57b64cf1656d77dfec
Author: Filipe Manana <fdmanana@suse.com>
Date:   Thu Jul 20 12:44:33 2023 +0100

    btrfs: account block group tree when calculating global reserve size
    
    commit 8dbfc14fc736eb701089aff09645c3d4ad3decb1 upstream.
    
    When using the block group tree feature, this tree is a critical tree just
    like the extent, csum and free space trees, and just like them it uses the
    delayed refs block reserve.
    
    So take into account the block group tree, and its current size, when
    calculating the size for the global reserve.
    
    CC: stable@vger.kernel.org # 6.1+
    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>

commit 2c28c5c52eaf10335e7b34ac3ea637ccf6858aee
Author: Naohiro Aota <naohiro.aota@wdc.com>
Date:   Thu Jun 29 17:37:31 2023 +0900

    btrfs: zoned: do not enable async discard
    
    commit 95ca6599a589ee84c69f02d0e1d928c8d1367fb1 upstream.
    
    The zoned mode need to reset a zone before using it. We rely on btrfs's
    original discard functionality (discarding unused block group range) to do
    the resetting.
    
    While the commit 63a7cb130718 ("btrfs: auto enable discard=async when
    possible") made the discard done in an async manner, a zoned reset do not
    need to be async, as it is fast enough.
    
    Even worth, delaying zone rests prevents using those zones again. So, let's
    disable async discard on the zoned mode.
    
    Fixes: 63a7cb130718 ("btrfs: auto enable discard=async when possible")
    CC: stable@vger.kernel.org # 6.3+
    Reviewed-by: Damien Le Moal <dlemoal@kernel.org>
    Reviewed-by: Christoph Hellwig <hch@lst.de>
    Signed-off-by: Naohiro Aota <naohiro.aota@wdc.com>
    Reviewed-by: David Sterba <dsterba@suse.com>
    [ update message text ]
    Signed-off-by: David Sterba <dsterba@suse.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 843b4e161773852b5917167fff5f3d32c43244e7
Author: Guenter Roeck <linux@roeck-us.net>
Date:   Wed Jul 26 20:18:13 2023 -0700

    hwmon: (pmbus_core) Fix Deadlock in pmbus_regulator_get_status
    
    commit b84000f2274520f73ac9dc59fd9403260b61c4e7 upstream.
    
    pmbus_regulator_get_status() acquires update_lock.
    pmbus_regulator_get_error_flags() acquires it again, resulting in an
    immediate deadlock.
    
    Call _pmbus_get_flags() from pmbus_regulator_get_status() directly
    to avoid the problem.
    
    Reported-by: Patrick Rudolph <patrick.rudolph@9elements.com>
    Closes: https://lore.kernel.org/linux-hwmon/b7a3ad85-aab4-4718-a001-1d8b1c0eef36@roeck-us.net/T/#u
    Cc: Naresh Solanki <Naresh.Solanki@9elements.com>
    Cc: stable@vger.kernel.org # v6.2+
    Fixes: c05f477c4ba3 ("hwmon: (pmbus/core) Implement regulator get_status")
    Signed-off-by: Guenter Roeck <linux@roeck-us.net>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 7444253cacd92412bc8d33d1c9b5401f52cdf0e2
Author: Patrick Rudolph <patrick.rudolph@9elements.com>
Date:   Tue Jul 25 14:54:26 2023 +0200

    hwmon: (pmbus_core) Fix NULL pointer dereference
    
    commit 0bd66784274a287beada2933c2c0fa3a0ddae0d7 upstream.
    
    Pass i2c_client to _pmbus_is_enabled to drop the assumption
    that a regulator device is passed in.
    
    This will fix the issue of a NULL pointer dereference when called from
    _pmbus_get_flags.
    
    Fixes: df5f6b6af01c ("hwmon: (pmbus/core) Generalise pmbus get status")
    Cc: stable@vger.kernel.org # v6.4
    Signed-off-by: Patrick Rudolph <patrick.rudolph@9elements.com>
    Signed-off-by: Naresh Solanki <Naresh.Solanki@9elements.com>
    Link: https://lore.kernel.org/r/20230725125428.3966803-2-Naresh.Solanki@9elements.com
    Signed-off-by: Guenter Roeck <linux@roeck-us.net>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit db11ee9b500f0372366f2be0e14175d6f5d476a5
Author: Patrick Rudolph <patrick.rudolph@9elements.com>
Date:   Tue Jul 25 14:54:25 2023 +0200

    hwmon: (pmbus_core) Fix pmbus_is_enabled()
    
    commit 55aab08f1856894d7d47d0ee23abbb4bc4854345 upstream.
    
    Refactor pmbus_is_enabled() to return the status without any additional
    processing as it is already done in _pmbus_is_enabled().
    
    Fixes: df5f6b6af01c ("hwmon: (pmbus/core) Generalise pmbus get status")
    Cc: stable@vger.kernel.org # v6.4
    Signed-off-by: Patrick Rudolph <patrick.rudolph@9elements.com>
    Signed-off-by: Naresh Solanki <Naresh.Solanki@9elements.com>
    Link: https://lore.kernel.org/r/20230725125428.3966803-1-Naresh.Solanki@9elements.com
    [groeck: Rephrased commit message]
    Signed-off-by: Guenter Roeck <linux@roeck-us.net>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 76f9deecf6ebe5a348b05a39a41e0ad18d1eb811
Author: Aleksa Savic <savicaleksa83@gmail.com>
Date:   Fri Jul 14 14:07:11 2023 +0200

    hwmon: (aquacomputer_d5next) Fix incorrect PWM value readout
    
    commit a746b3689546da27125da9ccaea62b1dbaaf927c upstream.
    
    Commit 662d20b3a5af ("hwmon: (aquacomputer_d5next) Add support for
    temperature sensor offsets") changed aqc_get_ctrl_val() to return
    the value through a parameter instead of through the return value,
    but didn't fix up a case that relied on the old behavior. Fix it
    to use the proper received value and not the return code.
    
    Fixes: 662d20b3a5af ("hwmon: (aquacomputer_d5next) Add support for temperature sensor offsets")
    Cc: stable@vger.kernel.org
    Signed-off-by: Aleksa Savic <savicaleksa83@gmail.com>
    Link: https://lore.kernel.org/r/20230714120712.16721-1-savicaleksa83@gmail.com
    Signed-off-by: Guenter Roeck <linux@roeck-us.net>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 7665493f77c9967170863dcff1d132fc4bfba69b
Author: Gilles Buloz <Gilles.Buloz@kontron.com>
Date:   Mon Jul 24 08:04:44 2023 +0000

    hwmon: (nct7802) Fix for temp6 (PECI1) processed even if PECI1 disabled
    
    commit 54685abe660a59402344d5045ce08c43c6a5ac42 upstream.
    
    Because of hex value 0x46 used instead of decimal 46, the temp6
    (PECI1) temperature is always declared visible and then displayed
    even if disabled in the chip
    
    Signed-off-by: Gilles Buloz <gilles.buloz@kontron.com>
    Link: https://lore.kernel.org/r/DU0PR10MB62526435ADBC6A85243B90E08002A@DU0PR10MB6252.EURPRD10.PROD.OUTLOOK.COM
    Fixes: fcdc5739dce03 ("hwmon: (nct7802) add temperature sensor type attribute")
    Cc: stable@vger.kernel.org
    Signed-off-by: Guenter Roeck <linux@roeck-us.net>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit c6790a9b035e5676044b65b380d05034c56ad5b4
Author: Baskaran Kannan <Baski.Kannan@amd.com>
Date:   Thu Jul 27 11:21:59 2023 -0500

    hwmon: (k10temp) Enable AMD3255 Proc to show negative temperature
    
    commit e146503ac68418859fb063a3a0cd9ec93bc52238 upstream.
    
    Industrial processor i3255 supports temperatures -40 deg celcius
    to 105 deg Celcius. The current implementation of k10temp_read_temp
    rounds off any negative temperatures to '0'. To fix this,
    the following changes have been made.
    
    A flag 'disp_negative' is added to struct k10temp_data to support
    AMD i3255 processors. Flag 'disp_negative' is set if 3255 processor
    is found during k10temp_probe.  Flag 'disp_negative' is used to
    determine whether to round off negative temperatures to '0' in
    k10temp_read_temp.
    
    Signed-off-by: Baskaran Kannan <Baski.Kannan@amd.com>
    Link: https://lore.kernel.org/r/20230727162159.1056136-1-Baski.Kannan@amd.com
    Fixes: aef17ca12719 ("hwmon: (k10temp) Only apply temperature offset if result is positive")
    Cc: stable@vger.kernel.org
    [groeck: Fixed multi-line comment]
    Signed-off-by: Guenter Roeck <linux@roeck-us.net>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit d205b153a4177d93566850e3908df72462992d48
Author: Luka Guzenko <l.guzenko@web.de>
Date:   Tue Jul 25 13:15:09 2023 +0200

    ALSA: hda/relatek: Enable Mute LED on HP 250 G8
    
    commit d510acb610e6aa07a04b688236868b2a5fd60deb upstream.
    
    This HP Notebook used ALC236 codec with COEF 0x07 idx 1 controlling
    the mute LED. Enable already existing quirk for this device.
    
    Signed-off-by: Luka Guzenko <l.guzenko@web.de>
    Cc: <stable@vger.kernel.org>
    Link: https://lore.kernel.org/r/20230725111509.623773-1-l.guzenko@web.de
    Signed-off-by: Takashi Iwai <tiwai@suse.de>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit a13620ff3b439d61f2604f0ab1450af4d470310d
Author: Pavel Asyutchenko <svenpavel@gmail.com>
Date:   Thu Jul 27 01:37:32 2023 +0300

    ALSA: hda/realtek: Support ASUS G713PV laptop
    
    commit 8019a4ab3d80c7af391a646cccff953753fc025f upstream.
    
    This laptop has CS35L41 amp connected via I2C.
    
    With this patch speakers begin to work if the
    missing _DSD properties are added to ACPI tables.
    
    Signed-off-by: Pavel Asyutchenko <svenpavel@gmail.com>
    Cc: <stable@vger.kernel.org>
    Link: https://lore.kernel.org/r/20230726223732.20775-1-svenpavel@gmail.com
    Signed-off-by: Takashi Iwai <tiwai@suse.de>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 6a007b16261037aeb7a1b17434ae0532e77fed89
Author: Oliver Neukum <oneukum@suse.com>
Date:   Thu Jul 13 13:28:10 2023 +0200

    Revert "xhci: add quirk for host controllers that don't update endpoint DCS"
    
    commit 5bef4b3cb95a5b883dfec8b3ffc0d671323d55bb upstream.
    
    This reverts commit 5255660b208aebfdb71d574f3952cf48392f4306.
    
    This quirk breaks at least the following hardware:
    
    0b:00.0 0c03: 1106:3483 (rev 01) (prog-if 30 [XHCI])
            Subsystem: 1106:3483
            Control: I/O+ Mem+ BusMaster+ SpecCycle- MemWINV- VGASnoop- ParErr- Stepping- SERR- FastB2B- DisINTx+
            Status: Cap+ 66MHz- UDF- FastB2B- ParErr- DEVSEL=fast >TAbort- <TAbort- <MAbort- >SERR- <PERR- INTx-
            Latency: 0, Cache Line Size: 64 bytes
            Interrupt: pin A routed to IRQ 66
            Region 0: Memory at fb400000 (64-bit, non-prefetchable) [size=4K]
            Capabilities: [80] Power Management version 3
                    Flags: PMEClk- DSI- D1- D2- AuxCurrent=375mA PME(D0+,D1+,D2+,D3hot+,D3cold+)
                    Status: D0 NoSoftRst- PME-Enable- DSel=0 DScale=0 PME-
            Capabilities: [90] MSI: Enable+ Count=1/4 Maskable- 64bit+
                    Address: 00000000fee007b8  Data: 0000
            Capabilities: [c4] Express (v2) Endpoint, MSI 00
                    DevCap: MaxPayload 256 bytes, PhantFunc 0, Latency L0s <64ns, L1 <1us
                            ExtTag- AttnBtn- AttnInd- PwrInd- RBE+ FLReset- SlotPowerLimit 89W
                    DevCtl: CorrErr- NonFatalErr- FatalErr- UnsupReq-
                            RlxdOrd- ExtTag- PhantFunc- AuxPwr- NoSnoop+
                            MaxPayload 128 bytes, MaxReadReq 512 bytes
                    DevSta: CorrErr- NonFatalErr- FatalErr- UnsupReq- AuxPwr+ TransPend-
                    LnkCap: Port #0, Speed 5GT/s, Width x1, ASPM L0s L1, Exit Latency L0s <2us, L1 <16us
                            ClockPM+ Surprise- LLActRep- BwNot- ASPMOptComp-
                    LnkCtl: ASPM Disabled; RCB 64 bytes, Disabled- CommClk+
                            ExtSynch- ClockPM- AutWidDis- BWInt- AutBWInt-
                    LnkSta: Speed 5GT/s, Width x1
                            TrErr- Train- SlotClk+ DLActive- BWMgmt- ABWMgmt-
                    DevCap2: Completion Timeout: Range B, TimeoutDis+ NROPrPrP- LTR-
                             10BitTagComp- 10BitTagReq- OBFF Not Supported, ExtFmt- EETLPPrefix-
                             EmergencyPowerReduction Not Supported, EmergencyPowerReductionInit-
                             FRS- TPHComp- ExtTPHComp-
                             AtomicOpsCap: 32bit- 64bit- 128bitCAS-
                    DevCtl2: Completion Timeout: 50us to 50ms, TimeoutDis- LTR- 10BitTagReq- OBFF Disabled,
                             AtomicOpsCtl: ReqEn-
                    LnkCtl2: Target Link Speed: 5GT/s, EnterCompliance- SpeedDis-
                             Transmit Margin: Normal Operating Range, EnterModifiedCompliance- ComplianceSOS-
                             Compliance Preset/De-emphasis: -6dB de-emphasis, 0dB preshoot
                    LnkSta2: Current De-emphasis Level: -6dB, EqualizationComplete- EqualizationPhase1-
                             EqualizationPhase2- EqualizationPhase3- LinkEqualizationRequest-
                             Retimer- 2Retimers- CrosslinkRes: unsupported
           Capabilities: [100 v1] Advanced Error Reporting
                    UESta:  DLP- SDES- TLP- FCP- CmpltTO- CmpltAbrt- UnxCmplt- RxOF- MalfTLP- ECRC- UnsupReq- ACSViol-
                    UEMsk:  DLP- SDES- TLP- FCP- CmpltTO- CmpltAbrt- UnxCmplt- RxOF- MalfTLP- ECRC- UnsupReq- ACSViol-
                    UESvrt: DLP+ SDES+ TLP- FCP+ CmpltTO- CmpltAbrt- UnxCmplt- RxOF+ MalfTLP+ ECRC- UnsupReq- ACSViol-
                    CESta:  RxErr- BadTLP- BadDLLP- Rollover- Timeout- AdvNonFatalErr-
                    CEMsk:  RxErr- BadTLP- BadDLLP- Rollover- Timeout- AdvNonFatalErr+
                    AERCap: First Error Pointer: 00, ECRCGenCap- ECRCGenEn- ECRCChkCap- ECRCChkEn-
                            MultHdrRecCap- MultHdrRecEn- TLPPfxPres- HdrLogCap-
                    HeaderLog: 00000000 00000000 00000000 00000000
            Kernel driver in use: xhci_hcd
            Kernel modules: xhci_pci
    
    with the quirk enabled it fails early with
    
    [    0.754373] pci 0000:0b:00.0: xHCI HW did not halt within 32000 usec status = 0x1000
    [    0.754419] pci 0000:0b:00.0: quirk_usb_early_handoff+0x0/0x7a0 took 31459 usecs
    [    2.228048] xhci_hcd 0000:0b:00.0: xHCI Host Controller
    [    2.228053] xhci_hcd 0000:0b:00.0: new USB bus registered, assigned bus number 7
    [    2.260073] xhci_hcd 0000:0b:00.0: Host halt failed, -110
    [    2.260079] xhci_hcd 0000:0b:00.0: can't setup: -110
    [    2.260551] xhci_hcd 0000:0b:00.0: USB bus 7 deregistered
    [    2.260624] xhci_hcd 0000:0b:00.0: init 0000:0b:00.0 fail, -110
    [    2.260639] xhci_hcd: probe of 0000:0b:00.0 failed with error -110
    
    The hardware in question is an external PCIe card. It looks to me like the quirk
    needs to be narrowed down. But this needs information about the hardware showing
    the issue this quirk is to fix. So for now a clean revert.
    
    Signed-off-by: Oliver Neukum <oneukum@suse.com>
    Fixes: 5255660b208a ("xhci: add quirk for host controllers that don't update endpoint DCS")
    Cc: stable <stable@kernel.org>
    Link: https://lore.kernel.org/r/20230713112830.21773-1-oneukum@suse.com
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 74a8d6f50cc90ed0061997db51dfa81a62b0f835
Author: Chaoyuan Peng <hedonistsmith@gmail.com>
Date:   Tue Jul 18 04:39:43 2023 +0000

    tty: n_gsm: fix UAF in gsm_cleanup_mux
    
    commit 9b9c8195f3f0d74a826077fc1c01b9ee74907239 upstream.
    
    In gsm_cleanup_mux() the 'gsm->dlci' pointer was not cleaned properly,
    leaving it a dangling pointer after gsm_dlci_release.
    This leads to use-after-free where 'gsm->dlci[0]' are freed and accessed
    by the subsequent gsm_cleanup_mux().
    
    Such is the case in the following call trace:
    
     <TASK>
     __dump_stack lib/dump_stack.c:88 [inline]
     dump_stack_lvl+0x1e3/0x2cb lib/dump_stack.c:106
     print_address_description+0x63/0x3b0 mm/kasan/report.c:248
     __kasan_report mm/kasan/report.c:434 [inline]
     kasan_report+0x16b/0x1c0 mm/kasan/report.c:451
     gsm_cleanup_mux+0x76a/0x850 drivers/tty/n_gsm.c:2397
     gsm_config drivers/tty/n_gsm.c:2653 [inline]
     gsmld_ioctl+0xaae/0x15b0 drivers/tty/n_gsm.c:2986
     tty_ioctl+0x8ff/0xc50 drivers/tty/tty_io.c:2816
     vfs_ioctl fs/ioctl.c:51 [inline]
     __do_sys_ioctl fs/ioctl.c:874 [inline]
     __se_sys_ioctl+0xf1/0x160 fs/ioctl.c:860
     do_syscall_x64 arch/x86/entry/common.c:50 [inline]
     do_syscall_64+0x3d/0xb0 arch/x86/entry/common.c:80
     entry_SYSCALL_64_after_hwframe+0x61/0xcb
     </TASK>
    
    Allocated by task 3501:
     kasan_save_stack mm/kasan/common.c:38 [inline]
     kasan_set_track mm/kasan/common.c:46 [inline]
     set_alloc_info mm/kasan/common.c:434 [inline]
     ____kasan_kmalloc+0xba/0xf0 mm/kasan/common.c:513
     kasan_kmalloc include/linux/kasan.h:264 [inline]
     kmem_cache_alloc_trace+0x143/0x290 mm/slub.c:3247
     kmalloc include/linux/slab.h:591 [inline]
     kzalloc include/linux/slab.h:721 [inline]
     gsm_dlci_alloc+0x53/0x3a0 drivers/tty/n_gsm.c:1932
     gsm_activate_mux+0x1c/0x330 drivers/tty/n_gsm.c:2438
     gsm_config drivers/tty/n_gsm.c:2677 [inline]
     gsmld_ioctl+0xd46/0x15b0 drivers/tty/n_gsm.c:2986
     tty_ioctl+0x8ff/0xc50 drivers/tty/tty_io.c:2816
     vfs_ioctl fs/ioctl.c:51 [inline]
     __do_sys_ioctl fs/ioctl.c:874 [inline]
     __se_sys_ioctl+0xf1/0x160 fs/ioctl.c:860
     do_syscall_x64 arch/x86/entry/common.c:50 [inline]
     do_syscall_64+0x3d/0xb0 arch/x86/entry/common.c:80
     entry_SYSCALL_64_after_hwframe+0x61/0xcb
    
    Freed by task 3501:
     kasan_save_stack mm/kasan/common.c:38 [inline]
     kasan_set_track+0x4b/0x80 mm/kasan/common.c:46
     kasan_set_free_info+0x1f/0x40 mm/kasan/generic.c:360
     ____kasan_slab_free+0xd8/0x120 mm/kasan/common.c:366
     kasan_slab_free include/linux/kasan.h:230 [inline]
     slab_free_hook mm/slub.c:1705 [inline]
     slab_free_freelist_hook+0xdd/0x160 mm/slub.c:1731
     slab_free mm/slub.c:3499 [inline]
     kfree+0xf1/0x270 mm/slub.c:4559
     dlci_put drivers/tty/n_gsm.c:1988 [inline]
     gsm_dlci_release drivers/tty/n_gsm.c:2021 [inline]
     gsm_cleanup_mux+0x574/0x850 drivers/tty/n_gsm.c:2415
     gsm_config drivers/tty/n_gsm.c:2653 [inline]
     gsmld_ioctl+0xaae/0x15b0 drivers/tty/n_gsm.c:2986
     tty_ioctl+0x8ff/0xc50 drivers/tty/tty_io.c:2816
     vfs_ioctl fs/ioctl.c:51 [inline]
     __do_sys_ioctl fs/ioctl.c:874 [inline]
     __se_sys_ioctl+0xf1/0x160 fs/ioctl.c:860
     do_syscall_x64 arch/x86/entry/common.c:50 [inline]
     do_syscall_64+0x3d/0xb0 arch/x86/entry/common.c:80
     entry_SYSCALL_64_after_hwframe+0x61/0xcb
    
    Fixes: aa371e96f05d ("tty: n_gsm: fix restart handling via CLD command")
    Signed-off-by: Chaoyuan Peng <hedonistsmith@gmail.com>
    Cc: stable <stable@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit b1b04b56745bc79286c80aa876fabfab1e08ebf1
Author: Zhang Shurong <zhang_shurong@foxmail.com>
Date:   Sun Jul 9 13:50:07 2023 +0800

    staging: ks7010: potential buffer overflow in ks_wlan_set_encode_ext()
    
    commit 5f1c7031e044cb2fba82836d55cc235e2ad619dc upstream.
    
    The "exc->key_len" is a u16 that comes from the user.  If it's over
    IW_ENCODING_TOKEN_MAX (64) that could lead to memory corruption.
    
    Fixes: b121d84882b9 ("staging: ks7010: simplify calls to memcpy()")
    Cc: stable <stable@kernel.org>
    Signed-off-by: Zhang Shurong <zhang_shurong@foxmail.com>
    Reviewed-by: Dan Carpenter <dan.carpenter@linaro.org>
    Link: https://lore.kernel.org/r/tencent_5153B668C0283CAA15AA518325346E026A09@qq.com
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 874555472c736813ba1f4baf0b4c09c8e26d81ea
Author: Larry Finger <Larry.Finger@lwfinger.net>
Date:   Fri Jul 14 12:54:17 2023 -0500

    staging: r8712: Fix memory leak in _r8712_init_xmit_priv()
    
    commit ac83631230f77dda94154ed0ebfd368fc81c70a3 upstream.
    
    In the above mentioned routine, memory is allocated in several places.
    If the first succeeds and a later one fails, the routine will leak memory.
    This patch fixes commit 2865d42c78a9 ("staging: r8712u: Add the new driver
    to the mainline kernel"). A potential memory leak in
    r8712_xmit_resource_alloc() is also addressed.
    
    Fixes: 2865d42c78a9 ("staging: r8712u: Add the new driver to the mainline kernel")
    Reported-by: syzbot+cf71097ffb6755df8251@syzkaller.appspotmail.com
    Closes: https://syzkaller.appspot.com/x/log.txt?x=11ac3fa0a80000
    Cc: stable@vger.kernel.org
    Cc: Nam Cao <namcaov@gmail.com>
    Signed-off-by: Larry Finger <Larry.Finger@lwfinger.net>
    Reviewed-by: Nam Cao <namcaov@gmail.com>
    Link: https://lore.kernel.org/r/20230714175417.18578-1-Larry.Finger@lwfinger.net
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 5d73dfff46d631cdbb11243f2af26adc39965471
Author: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Date:   Fri Jun 30 09:14:21 2023 +0200

    Documentation: security-bugs.rst: clarify CVE handling
    
    commit 3c1897ae4b6bc7cc586eda2feaa2cd68325ec29c upstream.
    
    The kernel security team does NOT assign CVEs, so document that properly
    and provide the "if you want one, ask MITRE for it" response that we
    give on a weekly basis in the document, so we don't have to constantly
    say it to everyone who asks.
    
    Link: https://lore.kernel.org/r/2023063022-retouch-kerosene-7e4a@gregkh
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 90cd6f5e91548bb2d83eede3350d12522a92bc79
Author: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Date:   Fri Jun 30 09:14:20 2023 +0200

    Documentation: security-bugs.rst: update preferences when dealing with the linux-distros group
    
    commit 4fee0915e649bd0cea56dece6d96f8f4643df33c upstream.
    
    Because the linux-distros group forces reporters to release information
    about reported bugs, and they impose arbitrary deadlines in having those
    bugs fixed despite not actually being kernel developers, the kernel
    security team recommends not interacting with them at all as this just
    causes confusion and the early-release of reported security problems.
    
    Reviewed-by: Kees Cook <keescook@chromium.org>
    Link: https://lore.kernel.org/r/2023063020-throat-pantyhose-f110@gregkh
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 14e8e4a3f3cf29e3ec9673cf7484e9f9cf59ade0
Author: Dan Carpenter <dan.carpenter@linaro.org>
Date:   Tue Jul 4 17:08:27 2023 +0300

    Revert "usb: xhci: tegra: Fix error check"
    
    commit 288b4fa1798e3637a9304c6e90a93d900e02369c upstream.
    
    This reverts commit 18fc7c435be3f17ea26a21b2e2312fcb9088e01f.
    
    The reverted commit was based on static analysis and a misunderstanding
    of how PTR_ERR() and NULLs are supposed to work.  When a function
    returns both pointer errors and NULL then normally the NULL means
    "continue operating without a feature because it was deliberately
    turned off".  The NULL should not be treated as a failure.  If a driver
    cannot work when that feature is disabled then the KConfig should
    enforce that the function cannot return NULL.  We should not need to
    test for it.
    
    In this code, the patch means that certain tegra_xusb_probe() will
    fail if the firmware supports power-domains but CONFIG_PM is disabled.
    
    Signed-off-by: Dan Carpenter <dan.carpenter@linaro.org>
    Fixes: 18fc7c435be3 ("usb: xhci: tegra: Fix error check")
    Cc: stable <stable@kernel.org>
    Link: https://lore.kernel.org/r/8baace8d-fb4b-41a4-ad5f-848ae643a23b@moroto.mountain
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 6068d152870a151067fbf14c960dbc3998137a64
Author: Ricardo Ribalda <ribalda@chromium.org>
Date:   Wed Jul 19 13:01:04 2023 +0000

    usb: xhci-mtk: set the dma max_seg_size
    
    commit 9fd10829a9eb482e192a845675ecc5480e0bfa10 upstream.
    
    Allow devices to have dma operations beyond 64K, and avoid warnings such
    as:
    
    DMA-API: xhci-mtk 11200000.usb: mapping sg segment longer than device claims to support [len=98304] [max=65536]
    
    Fixes: 0cbd4b34cda9 ("xhci: mediatek: support MTK xHCI host controller")
    Cc: stable <stable@kernel.org>
    Tested-by: Zubin Mithra <zsm@chromium.org>
    Reported-by: Zubin Mithra <zsm@chromium.org>
    Signed-off-by: Ricardo Ribalda <ribalda@chromium.org>
    Link: https://lore.kernel.org/r/20230628-mtk-usb-v2-1-c8c34eb9f229@chromium.org
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit d88c69c9e4cc203d37490348d601cff1a32d2213
Author: Frank Li <Frank.Li@nxp.com>
Date:   Fri Jul 7 19:00:15 2023 -0400

    usb: cdns3: fix incorrect calculation of ep_buf_size when more than one config
    
    commit 2627335a1329a0d39d8d277994678571c4f21800 upstream.
    
    Previously, the cdns3_gadget_check_config() function in the cdns3 driver
    mistakenly calculated the ep_buf_size by considering only one
    configuration's endpoint information because "claimed" will be clear after
    call usb_gadget_check_config().
    
    The fix involves checking the private flags EP_CLAIMED instead of relying
    on the "claimed" flag.
    
    Fixes: dce49449e04f ("usb: cdns3: allocate TX FIFO size according to composite EP number")
    Cc: stable <stable@kernel.org>
    Reported-by: Ravi Gunasekaran <r-gunasekaran@ti.com>
    Signed-off-by: Frank Li <Frank.Li@nxp.com>
    Acked-by: Peter Chen <peter.chen@kernel.org>
    Tested-by: Ravi Gunasekaran <r-gunasekaran@ti.com>
    Link: https://lore.kernel.org/r/20230707230015.494999-2-Frank.Li@nxp.com
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 15cea3344f789b0706fc443df7edf9bd082f54e2
Author: Łukasz Bartosik <lb@semihalf.com>
Date:   Mon Jul 24 13:29:11 2023 +0200

    USB: quirks: add quirk for Focusrite Scarlett
    
    commit 9dc162e22387080e2d06de708b89920c0e158c9a upstream.
    
    The Focusrite Scarlett audio device does not behave correctly during
    resumes. Below is what happens during every resume (captured with
    Beagle 5000):
    
    <Suspend>
    <Resume>
    <Reset>/<Chirp J>/<Tiny J>
    <Reset/Target disconnected>
    <High Speed>
    
    The Scarlett disconnects and is enumerated again.
    
    However from time to time it drops completely off the USB bus during
    resume. Below is captured occurrence of such an event:
    
    <Suspend>
    <Resume>
    <Reset>/<Chirp J>/<Tiny J>
    <Reset>/<Chirp K>/<Tiny K>
    <High Speed>
    <Corrupted packet>
    <Reset/Target disconnected>
    
    To fix the condition a user has to unplug and plug the device again.
    
    With USB_QUIRK_RESET_RESUME applied ("usbcore.quirks=1235:8211:b")
    for the Scarlett audio device the issue still reproduces.
    
    Applying USB_QUIRK_DISCONNECT_SUSPEND ("usbcore.quirks=1235:8211:m")
    fixed the issue and the Scarlett audio device didn't drop off the USB
    bus for ~5000 suspend/resume cycles where originally issue reproduced in
    ~100 or less suspend/resume cycles.
    
    Signed-off-by: Łukasz Bartosik <lb@semihalf.com>
    Cc: stable <stable@kernel.org>
    Link: https://lore.kernel.org/r/20230724112911.1802577-1-lb@semihalf.com
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit a4b763650261c731107d7e74e21bf0ec44460a98
Author: Guiting Shen <aarongt.shen@gmail.com>
Date:   Mon Jun 26 23:27:13 2023 +0800

    usb: ohci-at91: Fix the unhandle interrupt when resume
    
    commit c55afcbeaa7a6f4fffdbc999a9bf3f0b29a5186f upstream.
    
    The ohci_hcd_at91_drv_suspend() sets ohci->rh_state to OHCI_RH_HALTED when
    suspend which will let the ohci_irq() skip the interrupt after resume. And
    nobody to handle this interrupt.
    
    According to the comment in ohci_hcd_at91_drv_suspend(), it need to reset
    when resume from suspend(MEM) to fix by setting "hibernated" argument of
    ohci_resume().
    
    Signed-off-by: Guiting Shen <aarongt.shen@gmail.com>
    Cc: stable <stable@kernel.org>
    Reviewed-by: Alan Stern <stern@rowland.harvard.edu>
    Link: https://lore.kernel.org/r/20230626152713.18950-1-aarongt.shen@gmail.com
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit ef61d54319fc306a68f15a3d00c08536406ad4f6
Author: Xu Yang <xu.yang_2@nxp.com>
Date:   Wed Jul 5 17:52:31 2023 +0800

    usb: misc: ehset: fix wrong if condition
    
    commit 7f2327666a9080e428166964e37548b0168cd5e9 upstream.
    
    A negative number from ret means the host controller had failed to send
    usb message and 0 means succeed. Therefore, the if logic is wrong here
    and this patch will fix it.
    
    Fixes: f2b42379c576 ("usb: misc: ehset: Rework test mode entry")
    Cc: stable <stable@kernel.org>
    Signed-off-by: Xu Yang <xu.yang_2@nxp.com>
    Link: https://lore.kernel.org/r/20230705095231.457860-1-xu.yang_2@nxp.com
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 317d6e4c12b46bde61248ea4ab5e19f68cbd1c57
Author: Jisheng Zhang <jszhang@kernel.org>
Date:   Wed Jun 28 00:20:18 2023 +0800

    usb: dwc3: don't reset device side if dwc3 was configured as host-only
    
    commit e835c0a4e23c38531dcee5ef77e8d1cf462658c7 upstream.
    
    Commit c4a5153e87fd ("usb: dwc3: core: Power-off core/PHYs on
    system_suspend in host mode") replaces check for HOST only dr_mode with
    current_dr_role. But during booting, the current_dr_role isn't
    initialized, thus the device side reset is always issued even if dwc3
    was configured as host-only. What's more, on some platforms with host
    only dwc3, aways issuing device side reset by accessing device register
    block can cause kernel panic.
    
    Fixes: c4a5153e87fd ("usb: dwc3: core: Power-off core/PHYs on system_suspend in host mode")
    Cc: stable <stable@kernel.org>
    Signed-off-by: Jisheng Zhang <jszhang@kernel.org>
    Acked-by: Thinh Nguyen <Thinh.Nguyen@synopsys.com>
    Link: https://lore.kernel.org/r/20230627162018.739-1-jszhang@kernel.org
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 965b1f03e1d1b4220de45297a02361968b557012
Author: Gratian Crisan <gratian.crisan@ni.com>
Date:   Wed Jul 26 13:45:56 2023 -0500

    usb: dwc3: pci: skip BYT GPIO lookup table for hardwired phy
    
    commit b32b8f2b9542d8039f5468303a6ca78c1b5611a5 upstream.
    
    Hardware based on the Bay Trail / BYT SoCs require an external ULPI phy for
    USB device-mode. The phy chip usually has its 'reset' and 'chip select'
    lines connected to GPIOs described by ACPI fwnodes in the DSDT table.
    
    Because of hardware with missing ACPI resources for the 'reset' and 'chip
    select' GPIOs commit 5741022cbdf3 ("usb: dwc3: pci: Add GPIO lookup table
    on platforms without ACPI GPIO resources") introduced a fallback
    gpiod_lookup_table with hard-coded mappings for Bay Trail devices.
    
    However there are existing Bay Trail based devices, like the National
    Instruments cRIO-903x series, where the phy chip has its 'reset' and
    'chip-select' lines always asserted in hardware via resistor pull-ups. On
    this hardware the phy chip is always enabled and the ACPI dsdt table is
    missing information not only for the 'chip-select' and 'reset' lines but
    also for the BYT GPIO controller itself "INT33FC".
    
    With the introduction of the gpiod_lookup_table initializing the USB
    device-mode on these hardware now errors out. The error comes from the
    gpiod_get_optional() calls in dwc3_pci_quirks() which will now return an
    -ENOENT error due to the missing ACPI entry for the INT33FC gpio controller
    used in the aforementioned table.
    
    This hardware used to work before because gpiod_get_optional() will return
    NULL instead of -ENOENT if no GPIO has been assigned to the requested
    function. The dwc3_pci_quirks() code for setting the 'cs' and 'reset' GPIOs
    was then skipped (due to the NULL return). This is the correct behavior in
    cases where the phy chip is hardwired and there are no GPIOs to control.
    
    Since the gpiod_lookup_table relies on the presence of INT33FC fwnode
    in ACPI tables only add the table if we know the entry for the INT33FC
    gpio controller is present. This allows Bay Trail based devices with
    hardwired dwc3 ULPI phys to continue working.
    
    Fixes: 5741022cbdf3 ("usb: dwc3: pci: Add GPIO lookup table on platforms without ACPI GPIO resources")
    Cc: stable <stable@kernel.org>
    Signed-off-by: Gratian Crisan <gratian.crisan@ni.com>
    Reviewed-by: Hans de Goede <hdegoede@redhat.com>
    Link: https://lore.kernel.org/r/20230726184555.218091-2-gratian.crisan@ni.com
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 1590819eac4a660286ff82f80ac6c037114e811a
Author: Jakub Vanek <linuxtardis@gmail.com>
Date:   Fri Jul 14 14:24:19 2023 +0200

    Revert "usb: dwc3: core: Enable AutoRetry feature in the controller"
    
    commit 734ae15ab95a18d3d425fc9cb38b7a627d786f08 upstream.
    
    This reverts commit b138e23d3dff90c0494925b4c1874227b81bddf7.
    
    AutoRetry has been found to sometimes cause controller freezes when
    communicating with buggy USB devices.
    
    This controller feature allows the controller in host mode to send
    non-terminating/burst retry ACKs instead of terminating retry ACKs
    to devices when a transaction error (CRC error or overflow) occurs.
    
    Unfortunately, if the USB device continues to respond with a CRC error,
    the controller will not complete endpoint-related commands while it
    keeps trying to auto-retry. [3] The xHCI driver will notice this once
    it tries to abort the transfer using a Stop Endpoint command and
    does not receive a completion in time. [1]
    This situation is reported to dmesg:
    
    [sda] tag#29 uas_eh_abort_handler 0 uas-tag 1 inflight: CMD IN
    [sda] tag#29 CDB: opcode=0x28 28 00 00 69 42 80 00 00 48 00
    xhci-hcd: xHCI host not responding to stop endpoint command
    xhci-hcd: xHCI host controller not responding, assume dead
    xhci-hcd: HC died; cleaning up
    
    Some users observed this problem on an Odroid HC2 with the JMS578
    USB3-to-SATA bridge. The issue can be triggered by starting
    a read-heavy workload on an attached SSD. After a while, the host
    controller would die and the SSD would disappear from the system. [1]
    
    Further analysis by Synopsys determined that controller revisions
    other than the one in Odroid HC2 are also affected by this.
    The recommended solution was to disable AutoRetry altogether.
    This change does not have a noticeable performance impact. [2]
    
    Revert the enablement commit. This will keep the AutoRetry bit in
    the default state configured during SoC design [2].
    
    Fixes: b138e23d3dff ("usb: dwc3: core: Enable AutoRetry feature in the controller")
    Link: https://lore.kernel.org/r/a21f34c04632d250cd0a78c7c6f4a1c9c7a43142.camel@gmail.com/ [1]
    Link: https://lore.kernel.org/r/20230711214834.kyr6ulync32d4ktk@synopsys.com/ [2]
    Link: https://lore.kernel.org/r/20230712225518.2smu7wse6djc7l5o@synopsys.com/ [3]
    Cc: stable@vger.kernel.org
    Cc: Mauro Ribeiro <mauro.ribeiro@hardkernel.com>
    Cc: Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org>
    Suggested-by: Thinh Nguyen <Thinh.Nguyen@synopsys.com>
    Signed-off-by: Jakub Vanek <linuxtardis@gmail.com>
    Acked-by: Thinh Nguyen <Thinh.Nguyen@synopsys.com>
    Link: https://lore.kernel.org/r/20230714122419.27741-1-linuxtardis@gmail.com
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 816569fddc4e93589bbcbc9e0ff5bb1ae56a82cf
Author: Kyle Tso <kyletso@google.com>
Date:   Fri Jun 23 23:10:36 2023 +0800

    usb: typec: Use sysfs_emit_at when concatenating the string
    
    commit 609fded3f91972ada551c141c5d04a71704f8967 upstream.
    
    The buffer address used in sysfs_emit should be aligned to PAGE_SIZE.
    Use sysfs_emit_at instead to offset the buffer.
    
    Fixes: a7cff92f0635 ("usb: typec: USB Power Delivery helpers for ports and partners")
    Cc: stable@vger.kernel.org
    Signed-off-by: Kyle Tso <kyletso@google.com>
    Acked-by: Heikki Krogerus <heikki.krogerus@linux.intel.com>
    Link: https://lore.kernel.org/r/20230623151036.3955013-4-kyletso@google.com
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit bd90eafbacf412c551950bdb75773244d4daed16
Author: Kyle Tso <kyletso@google.com>
Date:   Fri Jun 23 23:10:35 2023 +0800

    usb: typec: Iterate pds array when showing the pd list
    
    commit 4b642dc9829507e4afabc03d32a18abbdb192c5e upstream.
    
    The pointers of each usb_power_delivery handles are stored in "pds"
    array returned from the pd_get ops but not in the adjacent memory
    calculated from "pd". Get the handles from "pds" array directly instead
    of deriving them from "pd".
    
    Fixes: a7cff92f0635 ("usb: typec: USB Power Delivery helpers for ports and partners")
    Cc: stable@vger.kernel.org
    Signed-off-by: Kyle Tso <kyletso@google.com>
    Acked-by: Heikki Krogerus <heikki.krogerus@linux.intel.com>
    Link: https://lore.kernel.org/r/20230623151036.3955013-3-kyletso@google.com
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 54c6d5fa59d2c800ca09472e4415b12c3ed64107
Author: Kyle Tso <kyletso@google.com>
Date:   Fri Jun 23 23:10:34 2023 +0800

    usb: typec: Set port->pd before adding device for typec_port
    
    commit b33ebb2415e7e0a55ee3d049c2890d3a3e3805b6 upstream.
    
    When calling device_add in the registration of typec_port, it will do
    the NULL check on usb_power_delivery handle in typec_port for the
    visibility of the device attributes. It is always NULL because port->pd
    is set in typec_port_set_usb_power_delivery which is later than the
    device_add call.
    
    Set port->pd before device_add and only link the device after that.
    
    Fixes: a7cff92f0635 ("usb: typec: USB Power Delivery helpers for ports and partners")
    Cc: stable@vger.kernel.org
    Signed-off-by: Kyle Tso <kyletso@google.com>
    Acked-by: Heikki Krogerus <heikki.krogerus@linux.intel.com>
    Link: https://lore.kernel.org/r/20230623151036.3955013-2-kyletso@google.com
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 41c60abd3eee9872d6bfbf6f2e2ab12117adef2e
Author: Samuel Thibault <samuel.thibault@ens-lyon.org>
Date:   Mon Jul 10 02:26:45 2023 +0200

    TIOCSTI: always enable for CAP_SYS_ADMIN
    
    commit 690c8b804ad2eafbd35da5d3c95ad325ca7d5061 upstream.
    
    83efeeeb3d04 ("tty: Allow TIOCSTI to be disabled") broke BRLTTY's
    ability to simulate keypresses on the console, thus effectively breaking
    braille keyboards of blind users.
    
    This restores the TIOCSTI feature for CAP_SYS_ADMIN processes, which
    BRLTTY is, thus fixing braille keyboards without re-opening the security
    issue.
    
    Signed-off-by: Samuel Thibault <samuel.thibault@ens-lyon.org>
    Acked-by: Kees Cook <keescook@chromium.org>
    Fixes: 83efeeeb3d04 ("tty: Allow TIOCSTI to be disabled")
    Cc: stable@vger.kernel.org
    Reported-by: Nicolas Pitre <nico@fluxnic.net>
    Link: https://lore.kernel.org/r/20230710002645.v565c7xq5iddruse@begin
    Acked-by: Jiri Slaby <jirislaby@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit f8416e85c8c4c993a362123e18b1bf5e911b1676
Author: Marc Kleine-Budde <mkl@pengutronix.de>
Date:   Tue Jul 18 11:43:54 2023 +0200

    can: gs_usb: gs_can_close(): add missing set of CAN state to CAN_STATE_STOPPED
    
    commit f8a2da6ec2417cca169fa85a8ab15817bccbb109 upstream.
    
    After an initial link up the CAN device is in ERROR-ACTIVE mode. Due
    to a missing CAN_STATE_STOPPED in gs_can_close() it doesn't change to
    STOPPED after a link down:
    
    | ip link set dev can0 up
    | ip link set dev can0 down
    | ip --details link show can0
    | 13: can0: <NOARP,ECHO> mtu 16 qdisc pfifo_fast state DOWN mode DEFAULT group default qlen 10
    |     link/can  promiscuity 0 allmulti 0 minmtu 0 maxmtu 0
    |     can state ERROR-ACTIVE restart-ms 1000
    
    Add missing assignment of CAN_STATE_STOPPED in gs_can_close().
    
    Cc: stable@vger.kernel.org
    Fixes: d08e973a77d1 ("can: gs_usb: Added support for the GS_USB CAN devices")
    Link: https://lore.kernel.org/all/20230718-gs_usb-fix-can-state-v1-1-f19738ae2c23@pengutronix.de
    Signed-off-by: Marc Kleine-Budde <mkl@pengutronix.de>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 5b656220e65e3dc0b5dd98cba6387a6cb3a0a2db
Author: Johan Hovold <johan@kernel.org>
Date:   Thu Jul 20 09:53:57 2023 +0200

    USB: serial: simple: sort driver entries
    
    commit d245aedc00775c4d7265a9f4522cc4e1fd34d102 upstream.
    
    Sort the driver symbols alphabetically in order to make it more obvious
    where new driver entries should be added.
    
    Cc: stable@vger.kernel.org
    Acked-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
    Signed-off-by: Johan Hovold <johan@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 0e44d051c8721db4f6b50acdbd1a58f33f8b73d1
Author: Oliver Neukum <oneukum@suse.com>
Date:   Wed Jul 12 16:16:41 2023 +0200

    USB: serial: simple: add Kaufmann RKS+CAN VCP
    
    commit dd92c8a1f99bcd166204ffc219ea5a23dd65d64f upstream.
    
    Add the device and product ID for this CAN bus interface / license
    dongle. The device is usable either directly from user space or can be
    attached to a kernel CAN interface with slcan_attach.
    
    Reported-by: Kaufmann Automotive GmbH <info@kaufmann-automotive.ch>
    Tested-by: Kaufmann Automotive GmbH <info@kaufmann-automotive.ch>
    Signed-off-by: Oliver Neukum <oneukum@suse.com>
    [ johan: amend commit message and move entries in sort order ]
    Cc: stable@vger.kernel.org
    Signed-off-by: Johan Hovold <johan@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit d62a293e0ad3e3dd0cdd301bf333863a33064812
Author: Mohsen Tahmasebi <moh53n@moh53n.ir>
Date:   Mon Jul 10 11:22:18 2023 +0330

    USB: serial: option: add Quectel EC200A module support
    
    commit 857ea9005806e2a458016880278f98715873e977 upstream.
    
    Add Quectel EC200A "DIAG, AT, MODEM":
    
    0x6005: ECM / RNDIS + DIAG + AT + MODEM
    
    T:  Bus=01 Lev=01 Prnt=02 Port=05 Cnt=01 Dev#=  8 Spd=480  MxCh= 0
    D:  Ver= 2.00 Cls=ef(misc ) Sub=02 Prot=01 MxPS=64 #Cfgs=  1
    P:  Vendor=2c7c ProdID=6005 Rev=03.18
    S:  Manufacturer=Android
    S:  Product=Android
    S:  SerialNumber=0000
    C:  #Ifs= 5 Cfg#= 1 Atr=e0 MxPwr=500mA
    I:  If#= 0 Alt= 0 #EPs= 1 Cls=02(commc) Sub=06 Prot=00 Driver=cdc_ether
    E:  Ad=87(I) Atr=03(Int.) MxPS=  64 Ivl=4096ms
    I:  If#= 1 Alt= 1 #EPs= 2 Cls=0a(data ) Sub=00 Prot=00 Driver=cdc_ether
    E:  Ad=0c(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
    E:  Ad=83(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
    I:  If#= 2 Alt= 0 #EPs= 2 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
    E:  Ad=0b(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
    E:  Ad=82(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
    I:  If#= 3 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
    E:  Ad=0f(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
    E:  Ad=86(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
    E:  Ad=89(I) Atr=03(Int.) MxPS=  64 Ivl=4096ms
    I:  If#= 4 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=00 Driver=option
    E:  Ad=0a(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
    E:  Ad=81(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
    E:  Ad=88(I) Atr=03(Int.) MxPS=  64 Ivl=4096ms
    
    Signed-off-by: Mohsen Tahmasebi <moh53n@moh53n.ir>
    Tested-by: Mostafa Ghofrani <mostafaghrr@gmail.com>
    Cc: stable@vger.kernel.org
    Signed-off-by: Johan Hovold <johan@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 56637bd2de53c14c79a09dd0b304991193828e3b
Author: Jerry Meng <jerry-meng@foxmail.com>
Date:   Thu Jun 29 17:35:22 2023 +0800

    USB: serial: option: support Quectel EM060K_128
    
    commit 4f7cab49cecee16120d27c1734cfdf3d6c0e5329 upstream.
    
    EM060K_128 is EM060K's sub-model, having the same name "Quectel EM060K-GL"
    
    MBIM + GNSS + DIAG + NMEA + AT + QDSS + DPL
    
    T:  Bus=03 Lev=01 Prnt=01 Port=01 Cnt=02 Dev#=  8 Spd=480  MxCh= 0
    D:  Ver= 2.00 Cls=00(>ifc ) Sub=00 Prot=00 MxPS=64 #Cfgs=  1
    P:  Vendor=2c7c ProdID=0128 Rev= 5.04
    S:  Manufacturer=Quectel
    S:  Product=Quectel EM060K-GL
    S:  SerialNumber=f6fa08b6
    C:* #Ifs= 8 Cfg#= 1 Atr=a0 MxPwr=500mA
    A:  FirstIf#= 0 IfCount= 2 Cls=02(comm.) Sub=0e Prot=00
    I:* If#= 0 Alt= 0 #EPs= 1 Cls=02(comm.) Sub=0e Prot=00 Driver=cdc_mbim
    E:  Ad=81(I) Atr=03(Int.) MxPS=  64 Ivl=32ms
    I:  If#= 1 Alt= 0 #EPs= 0 Cls=0a(data ) Sub=00 Prot=02 Driver=cdc_mbim
    I:* If#= 1 Alt= 1 #EPs= 2 Cls=0a(data ) Sub=00 Prot=02 Driver=cdc_mbim
    E:  Ad=8e(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
    E:  Ad=0f(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
    I:* If#= 2 Alt= 0 #EPs= 1 Cls=ff(vend.) Sub=ff Prot=ff Driver=(none)
    E:  Ad=82(I) Atr=03(Int.) MxPS=  64 Ivl=32ms
    I:* If#= 3 Alt= 0 #EPs= 2 Cls=ff(vend.) Sub=ff Prot=30 Driver=option
    E:  Ad=01(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
    E:  Ad=83(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
    I:* If#= 4 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=00 Prot=40 Driver=option
    E:  Ad=85(I) Atr=03(Int.) MxPS=  10 Ivl=32ms
    E:  Ad=84(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
    E:  Ad=02(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
    I:* If#= 5 Alt= 0 #EPs= 3 Cls=ff(vend.) Sub=ff Prot=40 Driver=option
    E:  Ad=87(I) Atr=03(Int.) MxPS=  10 Ivl=32ms
    E:  Ad=86(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
    E:  Ad=03(O) Atr=02(Bulk) MxPS= 512 Ivl=0ms
    I:* If#= 6 Alt= 0 #EPs= 1 Cls=ff(vend.) Sub=ff Prot=70 Driver=(none)
    E:  Ad=88(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
    I:* If#= 7 Alt= 0 #EPs= 1 Cls=ff(vend.) Sub=ff Prot=80 Driver=(none)
    E:  Ad=8f(I) Atr=02(Bulk) MxPS= 512 Ivl=0ms
    
    Signed-off-by: Jerry Meng <jerry-meng@foxmail.com>
    Cc: stable@vger.kernel.org
    Signed-off-by: Johan Hovold <johan@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit c83261b1a5c0f72ba7bde24578dc7b839f7e9a76
Author: Samuel Holland <samuel.holland@sifive.com>
Date:   Fri Jun 23 23:01:59 2023 -0700

    serial: sifive: Fix sifive_serial_console_setup() section
    
    commit 9b8fef6345d5487137d4193bb0a0eae2203c284e upstream.
    
    This function is called indirectly from the platform driver probe
    function. Even if the driver is built in, it may be probed after
    free_initmem() due to deferral or unbinding/binding via sysfs.
    Thus the function cannot be marked as __init.
    
    Fixes: 45c054d0815b ("tty: serial: add driver for the SiFive UART")
    Cc: stable <stable@kernel.org>
    Signed-off-by: Samuel Holland <samuel.holland@sifive.com>
    Link: https://lore.kernel.org/r/20230624060159.3401369-1-samuel.holland@sifive.com
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 12a529e625cbf4924c8234c909c23aa14ef63fa6
Author: Ruihong Luo <colorsu1922@gmail.com>
Date:   Thu Jul 13 08:42:36 2023 +0800

    serial: 8250_dw: Preserve original value of DLF register
    
    commit 748c5ea8b8796ae8ee80b8d3a3d940570b588d59 upstream.
    
    Preserve the original value of the Divisor Latch Fraction (DLF) register.
    When the DLF register is modified without preservation, it can disrupt
    the baudrate settings established by firmware or bootloader, leading to
    data corruption and the generation of unreadable or distorted characters.
    
    Fixes: 701c5e73b296 ("serial: 8250_dw: add fractional divisor support")
    Cc: stable <stable@kernel.org>
    Signed-off-by: Ruihong Luo <colorsu1922@gmail.com>
    Link: https://lore.kernel.org/stable/20230713004235.35904-1-colorsu1922%40gmail.com
    Reviewed-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com>
    Reviewed-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
    Link: https://lore.kernel.org/r/20230713004235.35904-1-colorsu1922@gmail.com
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 867bf51492d68629e64da7ee906eb81e41fc6cbe
Author: Biju Das <biju.das.jz@bp.renesas.com>
Date:   Tue Jul 4 16:48:18 2023 +0100

    tty: serial: sh-sci: Fix sleeping in atomic context
    
    commit 57c984f6fe20ebb9306d6e8c09b4f67fe63298c6 upstream.
    
    Fix sleeping in atomic context warning as reported by the Smatch static
    checker tool by replacing disable_irq->disable_irq_nosync.
    
    Reported by: Dan Carpenter <dan.carpenter@linaro.org>
    
    Fixes: 8749061be196 ("tty: serial: sh-sci: Add RZ/G2L SCIFA DMA tx support")
    Cc: stable@kernel.org
    Signed-off-by: Biju Das <biju.das.jz@bp.renesas.com>
    Reviewed-by: Geert Uytterhoeven <geert+renesas@glider.be>
    Link: https://lore.kernel.org/r/20230704154818.406913-1-biju.das.jz@bp.renesas.com
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 7ceb28ca8a6756824ff03871250746080add89cb
Author: Johan Hovold <johan+linaro@kernel.org>
Date:   Thu Jul 13 16:57:41 2023 +0200

    serial: qcom-geni: drop bogus runtime pm state update
    
    commit 4dd8752a14ca0303fbdf0a6c68ff65f0a50bd2fa upstream.
    
    The runtime PM state should not be changed by drivers that do not
    implement runtime PM even if it happens to work around a bug in PM core.
    
    With the wake irq arming now fixed, drop the bogus runtime PM state
    update which left the device in active state (and could potentially
    prevent a parent device from suspending).
    
    Fixes: f3974413cf02 ("tty: serial: qcom_geni_serial: Wakeup IRQ cleanup")
    Cc: 5.6+ <stable@vger.kernel.org> # 5.6+
    Signed-off-by: Johan Hovold <johan+linaro@kernel.org>
    Reviewed-by: Tony Lindgren <tony@atomide.com>
    Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 31d7fc013aa4b309c42ddf6a12b9b09067b24fe7
Author: Sean Christopherson <seanjc@google.com>
Date:   Tue Jun 13 13:30:35 2023 -0700

    KVM: x86: Disallow KVM_SET_SREGS{2} if incoming CR0 is invalid
    
    commit 26a0652cb453c72f6aab0974bc4939e9b14f886b upstream.
    
    Reject KVM_SET_SREGS{2} with -EINVAL if the incoming CR0 is invalid,
    e.g. due to setting bits 63:32, illegal combinations, or to a value that
    isn't allowed in VMX (non-)root mode.  The VMX checks in particular are
    "fun" as failure to disallow Real Mode for an L2 that is configured with
    unrestricted guest disabled, when KVM itself has unrestricted guest
    enabled, will result in KVM forcing VM86 mode to virtual Real Mode for
    L2, but then fail to unwind the related metadata when synthesizing a
    nested VM-Exit back to L1 (which has unrestricted guest enabled).
    
    Opportunistically fix a benign typo in the prototype for is_valid_cr4().
    
    Cc: stable@vger.kernel.org
    Reported-by: syzbot+5feef0b9ee9c8e9e5689@syzkaller.appspotmail.com
    Closes: https://lore.kernel.org/all/000000000000f316b705fdf6e2b4@google.com
    Signed-off-by: Sean Christopherson <seanjc@google.com>
    Message-Id: <20230613203037.1968489-2-seanjc@google.com>
    Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 00ab40209428c6ce66f5b7f75077d2d28906daef
Author: Sean Christopherson <seanjc@google.com>
Date:   Tue Jun 13 13:30:36 2023 -0700

    KVM: VMX: Don't fudge CR0 and CR4 for restricted L2 guest
    
    commit c4abd7352023aa96114915a0bb2b88016a425cda upstream.
    
    Stuff CR0 and/or CR4 to be compliant with a restricted guest if and only
    if KVM itself is not configured to utilize unrestricted guests, i.e. don't
    stuff CR0/CR4 for a restricted L2 that is running as the guest of an
    unrestricted L1.  Any attempt to VM-Enter a restricted guest with invalid
    CR0/CR4 values should fail, i.e. in a nested scenario, KVM (as L0) should
    never observe a restricted L2 with incompatible CR0/CR4, since nested
    VM-Enter from L1 should have failed.
    
    And if KVM does observe an active, restricted L2 with incompatible state,
    e.g. due to a KVM bug, fudging CR0/CR4 instead of letting VM-Enter fail
    does more harm than good, as KVM will often neglect to undo the side
    effects, e.g. won't clear rmode.vm86_active on nested VM-Exit, and thus
    the damage can easily spill over to L1.  On the other hand, letting
    VM-Enter fail due to bad guest state is more likely to contain the damage
    to L2 as KVM relies on hardware to perform most guest state consistency
    checks, i.e. KVM needs to be able to reflect a failed nested VM-Enter into
    L1 irrespective of (un)restricted guest behavior.
    
    Cc: Jim Mattson <jmattson@google.com>
    Cc: stable@vger.kernel.org
    Fixes: bddd82d19e2e ("KVM: nVMX: KVM needs to unset "unrestricted guest" VM-execution control in vmcs02 if vmcs12 doesn't set it")
    Signed-off-by: Sean Christopherson <seanjc@google.com>
    Message-Id: <20230613203037.1968489-3-seanjc@google.com>
    Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit fa69c355a429cd92a023fc629256094002aa38ac
Author: Sean Christopherson <seanjc@google.com>
Date:   Tue Jul 11 16:01:25 2023 -0700

    KVM: Grab a reference to KVM for VM and vCPU stats file descriptors
    
    commit eed3013faa401aae662398709410a59bb0646e32 upstream.
    
    Grab a reference to KVM prior to installing VM and vCPU stats file
    descriptors to ensure the underlying VM and vCPU objects are not freed
    until the last reference to any and all stats fds are dropped.
    
    Note, the stats paths manually invoke fd_install() and so don't need to
    grab a reference before creating the file.
    
    Fixes: ce55c049459c ("KVM: stats: Support binary stats retrieval for a VCPU")
    Fixes: fcfe1baeddbf ("KVM: stats: Support binary stats retrieval for a VM")
    Reported-by: Zheng Zhang <zheng.zhang@email.ucr.edu>
    Closes: https://lore.kernel.org/all/CAC_GQSr3xzZaeZt85k_RCBd5kfiOve8qXo7a81Cq53LuVQ5r=Q@mail.gmail.com
    Cc: stable@vger.kernel.org
    Cc: Kees Cook <keescook@chromium.org>
    Signed-off-by: Sean Christopherson <seanjc@google.com>
    Reviewed-by: Kees Cook <keescook@chromium.org>
    Message-Id: <20230711230131.648752-2-seanjc@google.com>
    Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 7175cc32ff513e488af252d819690930fb6413d3
Author: Michael Grzeschik <m.grzeschik@pengutronix.de>
Date:   Sat Jul 22 00:22:56 2023 +0200

    usb: gadget: core: remove unbalanced mutex_unlock in usb_gadget_activate
    
    commit 6237390644fb92b81f5262877fe545d0d2c7b5d7 upstream.
    
    Commit 286d9975a838 ("usb: gadget: udc: core: Prevent soft_connect_store() race")
    introduced one extra mutex_unlock of connect_lock in the usb_gadget_active function.
    
    Fixes: 286d9975a838 ("usb: gadget: udc: core: Prevent soft_connect_store() race")
    Cc: stable <stable@kernel.org>
    Signed-off-by: Michael Grzeschik <m.grzeschik@pengutronix.de>
    Reviewed-by: Alan Stern <stern@rowland.harvard.edu>
    Link: https://lore.kernel.org/r/20230721222256.1743645-1-m.grzeschik@pengutronix.de
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 9934e5d07c0dc294169a7d52f6309f35cd6d7755
Author: Zqiang <qiang.zhang1211@gmail.com>
Date:   Fri Jul 14 15:40:11 2023 +0800

    USB: gadget: Fix the memory leak in raw_gadget driver
    
    commit 83e30f2bf86ef7c38fbd476ed81a88522b620628 upstream.
    
    Currently, increasing raw_dev->count happens before invoke the
    raw_queue_event(), if the raw_queue_event() return error, invoke
    raw_release() will not trigger the dev_free() to be called.
    
    [  268.905865][ T5067] raw-gadget.0 gadget.0: failed to queue event
    [  268.912053][ T5067] udc dummy_udc.0: failed to start USB Raw Gadget: -12
    [  268.918885][ T5067] raw-gadget.0: probe of gadget.0 failed with error -12
    [  268.925956][ T5067] UDC core: USB Raw Gadget: couldn't find an available UDC or it's busy
    [  268.934657][ T5067] misc raw-gadget: fail, usb_gadget_register_driver returned -16
    
    BUG: memory leak
    
    [<ffffffff8154bf94>] kmalloc_trace+0x24/0x90 mm/slab_common.c:1076
    [<ffffffff8347eb55>] kmalloc include/linux/slab.h:582 [inline]
    [<ffffffff8347eb55>] kzalloc include/linux/slab.h:703 [inline]
    [<ffffffff8347eb55>] dev_new drivers/usb/gadget/legacy/raw_gadget.c:191 [inline]
    [<ffffffff8347eb55>] raw_open+0x45/0x110 drivers/usb/gadget/legacy/raw_gadget.c:385
    [<ffffffff827d1d09>] misc_open+0x1a9/0x1f0 drivers/char/misc.c:165
    
    [<ffffffff8154bf94>] kmalloc_trace+0x24/0x90 mm/slab_common.c:1076
    [<ffffffff8347cd2f>] kmalloc include/linux/slab.h:582 [inline]
    [<ffffffff8347cd2f>] raw_ioctl_init+0xdf/0x410 drivers/usb/gadget/legacy/raw_gadget.c:460
    [<ffffffff8347dfe9>] raw_ioctl+0x5f9/0x1120 drivers/usb/gadget/legacy/raw_gadget.c:1250
    [<ffffffff81685173>] vfs_ioctl fs/ioctl.c:51 [inline]
    
    [<ffffffff8154bf94>] kmalloc_trace+0x24/0x90 mm/slab_common.c:1076
    [<ffffffff833ecc6a>] kmalloc include/linux/slab.h:582 [inline]
    [<ffffffff833ecc6a>] kzalloc include/linux/slab.h:703 [inline]
    [<ffffffff833ecc6a>] dummy_alloc_request+0x5a/0xe0 drivers/usb/gadget/udc/dummy_hcd.c:665
    [<ffffffff833e9132>] usb_ep_alloc_request+0x22/0xd0 drivers/usb/gadget/udc/core.c:196
    [<ffffffff8347f13d>] gadget_bind+0x6d/0x370 drivers/usb/gadget/legacy/raw_gadget.c:292
    
    This commit therefore invoke kref_get() under the condition that
    raw_queue_event() return success.
    
    Reported-by: syzbot+feb045d335c1fdde5bf7@syzkaller.appspotmail.com
    Cc: stable <stable@kernel.org>
    Closes: https://syzkaller.appspot.com/bug?extid=feb045d335c1fdde5bf7
    Signed-off-by: Zqiang <qiang.zhang1211@gmail.com>
    Reviewed-by: Andrey Konovalov <andreyknvl@gmail.com>
    Tested-by: Andrey Konovalov <andreyknvl@gmail.com>
    Link: https://lore.kernel.org/r/20230714074011.20989-1-qiang.zhang1211@gmail.com
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 9820f6e036d00cddbc2971ca823425bcd0ee179d
Author: Frank Li <Frank.Li@nxp.com>
Date:   Fri Jul 7 19:00:14 2023 -0400

    usb: gadget: call usb_gadget_check_config() to verify UDC capability
    
    commit f4fc01af5b640bc39bd9403b5fd855345a2ad5f8 upstream.
    
    The legacy gadget driver omitted calling usb_gadget_check_config()
    to ensure that the USB device controller (UDC) has adequate resources,
    including sufficient endpoint numbers and types, to support the given
    configuration.
    
    Previously, usb_add_config() was solely invoked by the legacy gadget
    driver. Adds the necessary usb_gadget_check_config() after the bind()
    operation to fix the issue.
    
    Fixes: dce49449e04f ("usb: cdns3: allocate TX FIFO size according to composite EP number")
    Cc: stable <stable@kernel.org>
    Reported-by: Ravi Gunasekaran <r-gunasekaran@ti.com>
    Signed-off-by: Frank Li <Frank.Li@nxp.com>
    Link: https://lore.kernel.org/r/20230707230015.494999-1-Frank.Li@nxp.com
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 1099be4ad9d29d6881579882987dece70403bc74
Author: Dan Carpenter <dan.carpenter@linaro.org>
Date:   Tue Jul 4 17:09:09 2023 +0300

    Revert "usb: gadget: tegra-xudc: Fix error check in tegra_xudc_powerdomain_init()"
    
    commit a8291be6b5dd465c22af229483dbac543a91e24e upstream.
    
    This reverts commit f08aa7c80dac27ee00fa6827f447597d2fba5465.
    
    The reverted commit was based on static analysis and a misunderstanding
    of how PTR_ERR() and NULLs are supposed to work.  When a function
    returns both pointer errors and NULL then normally the NULL means
    "continue operating without a feature because it was deliberately
    turned off".  The NULL should not be treated as a failure.  If a driver
    cannot work when that feature is disabled then the KConfig should
    enforce that the function cannot return NULL.  We should not need to
    test for it.
    
    In this driver, the bug means that probe cannot succeed when CONFIG_PM
    is disabled.
    
    Signed-off-by: Dan Carpenter <dan.carpenter@linaro.org>
    Fixes: f08aa7c80dac ("usb: gadget: tegra-xudc: Fix error check in tegra_xudc_powerdomain_init()")
    Cc: stable <stable@kernel.org>
    Link: https://lore.kernel.org/r/ZKQoBa84U/ykEh3C@moroto
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 528c9d73153754defb748f0b96ad33308668d817
Author: Zheng Yejian <zhengyejian1@huawei.com>
Date:   Wed Jul 26 17:58:04 2023 +0800

    tracing: Fix warning in trace_buffered_event_disable()
    
    [ Upstream commit dea499781a1150d285c62b26659f62fb00824fce ]
    
    Warning happened in trace_buffered_event_disable() at
      WARN_ON_ONCE(!trace_buffered_event_ref)
    
      Call Trace:
       ? __warn+0xa5/0x1b0
       ? trace_buffered_event_disable+0x189/0x1b0
       __ftrace_event_enable_disable+0x19e/0x3e0
       free_probe_data+0x3b/0xa0
       unregister_ftrace_function_probe_func+0x6b8/0x800
       event_enable_func+0x2f0/0x3d0
       ftrace_process_regex.isra.0+0x12d/0x1b0
       ftrace_filter_write+0xe6/0x140
       vfs_write+0x1c9/0x6f0
       [...]
    
    The cause of the warning is in __ftrace_event_enable_disable(),
    trace_buffered_event_enable() was called once while
    trace_buffered_event_disable() was called twice.
    Reproduction script show as below, for analysis, see the comments:
     ```
     #!/bin/bash
    
     cd /sys/kernel/tracing/
    
     # 1. Register a 'disable_event' command, then:
     #    1) SOFT_DISABLED_BIT was set;
     #    2) trace_buffered_event_enable() was called first time;
     echo 'cmdline_proc_show:disable_event:initcall:initcall_finish' > \
         set_ftrace_filter
    
     # 2. Enable the event registered, then:
     #    1) SOFT_DISABLED_BIT was cleared;
     #    2) trace_buffered_event_disable() was called first time;
     echo 1 > events/initcall/initcall_finish/enable
    
     # 3. Try to call into cmdline_proc_show(), then SOFT_DISABLED_BIT was
     #    set again!!!
     cat /proc/cmdline
    
     # 4. Unregister the 'disable_event' command, then:
     #    1) SOFT_DISABLED_BIT was cleared again;
     #    2) trace_buffered_event_disable() was called second time!!!
     echo '!cmdline_proc_show:disable_event:initcall:initcall_finish' > \
         set_ftrace_filter
     ```
    
    To fix it, IIUC, we can change to call trace_buffered_event_enable() at
    fist time soft-mode enabled, and call trace_buffered_event_disable() at
    last time soft-mode disabled.
    
    Link: https://lore.kernel.org/linux-trace-kernel/20230726095804.920457-1-zhengyejian1@huawei.com
    
    Cc: <mhiramat@kernel.org>
    Fixes: 0fc1b09ff1ff ("tracing: Use temp buffer when filtering events")
    Signed-off-by: Zheng Yejian <zhengyejian1@huawei.com>
    Signed-off-by: Steven Rostedt (Google) <rostedt@goodmis.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 54820008db2ec71d0b277bf29383ae4c7e56b735
Author: Zheng Yejian <zhengyejian1@huawei.com>
Date:   Mon Jul 24 13:40:40 2023 +0800

    ring-buffer: Fix wrong stat of cpu_buffer->read
    
    [ Upstream commit 2d093282b0d4357373497f65db6a05eb0c28b7c8 ]
    
    When pages are removed in rb_remove_pages(), 'cpu_buffer->read' is set
    to 0 in order to make sure any read iterators reset themselves. However,
    this will mess 'entries' stating, see following steps:
    
      # cd /sys/kernel/tracing/
      # 1. Enlarge ring buffer prepare for later reducing:
      # echo 20 > per_cpu/cpu0/buffer_size_kb
      # 2. Write a log into ring buffer of cpu0:
      # taskset -c 0 echo "hello1" > trace_marker
      # 3. Read the log:
      # cat per_cpu/cpu0/trace_pipe
           <...>-332     [000] .....    62.406844: tracing_mark_write: hello1
      # 4. Stop reading and see the stats, now 0 entries, and 1 event readed:
      # cat per_cpu/cpu0/stats
       entries: 0
       [...]
       read events: 1
      # 5. Reduce the ring buffer
      # echo 7 > per_cpu/cpu0/buffer_size_kb
      # 6. Now entries became unexpected 1 because actually no entries!!!
      # cat per_cpu/cpu0/stats
       entries: 1
       [...]
       read events: 0
    
    To fix it, introduce 'page_removed' field to count total removed pages
    since last reset, then use it to let read iterators reset themselves
    instead of changing the 'read' pointer.
    
    Link: https://lore.kernel.org/linux-trace-kernel/20230724054040.3489499-1-zhengyejian1@huawei.com
    
    Cc: <mhiramat@kernel.org>
    Cc: <vnagarnaik@google.com>
    Fixes: 83f40318dab0 ("ring-buffer: Make removal of ring buffer pages atomic")
    Signed-off-by: Zheng Yejian <zhengyejian1@huawei.com>
    Signed-off-by: Steven Rostedt (Google) <rostedt@goodmis.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 8481fc3f53527918aeb27957200b0c5d52790bf3
Author: Arnd Bergmann <arnd@arndb.de>
Date:   Wed Jul 26 22:33:22 2023 +0200

    ata: pata_ns87415: mark ns87560_tf_read static
    
    [ Upstream commit 3fc2febb0f8ffae354820c1772ec008733237cfa ]
    
    The global function triggers a warning because of the missing prototype
    
    drivers/ata/pata_ns87415.c:263:6: warning: no previous prototype for 'ns87560_tf_read' [-Wmissing-prototypes]
      263 | void ns87560_tf_read(struct ata_port *ap, struct ata_taskfile *tf)
    
    There are no other references to this, so just make it static.
    
    Fixes: c4b5b7b6c4423 ("pata_ns87415: Initial cut at 87415/87560 IDE support")
    Reviewed-by: Sergey Shtylyov <s.shtylyov@omp.ru>
    Reviewed-by: Serge Semin <fancer.lancer@gmail.com>
    Signed-off-by: Arnd Bergmann <arnd@arndb.de>
    Signed-off-by: Damien Le Moal <dlemoal@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit d232314284c76f50b886237be978fd0528b2ff71
Author: Hugh Dickins <hughd@google.com>
Date:   Sun Jul 23 13:55:00 2023 -0700

    tmpfs: fix Documentation of noswap and huge mount options
    
    [ Upstream commit 253e5df8b8f0145adb090f57c6f4e6efa52d738e ]
    
    The noswap mount option is surely not one of the three options for sizing:
    move its description down.
    
    The huge= mount option does not accept numeric values: those are just in
    an internal enum.  Delete those numbers, and follow the manpage text more
    closely (but there's not yet any fadvise() or fcntl() which applies here).
    
    /sys/kernel/mm/transparent_hugepage/shmem_enabled is hard to describe, and
    barely relevant to mounting a tmpfs: just refer to transhuge.rst (while
    still using the words deny and force, to help as informal reminders).
    
    [rdunlap@infradead.org: fixup Docs table for huge mount options]
      Link: https://lkml.kernel.org/r/20230725052333.26857-1-rdunlap@infradead.org
    Link: https://lkml.kernel.org/r/986cb0bf-9780-354-9bb-4bf57aadbab@google.com
    Signed-off-by: Hugh Dickins <hughd@google.com>
    Signed-off-by: Randy Dunlap <rdunlap@infradead.org>
    Fixes: d0f5a85442d1 ("shmem: update documentation")
    Fixes: 2c6efe9cf2d7 ("shmem: add support to ignore swap")
    Reviewed-by: Luis Chamberlain <mcgrof@kernel.org>
    Cc: Christian Brauner <brauner@kernel.org>
    Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 495b327435b0298e9b3b434f5834d459a93673ce
Author: Jason Gunthorpe <jgg@ziepe.ca>
Date:   Tue Jul 25 16:05:49 2023 -0300

    iommufd: IOMMUFD_DESTROY should not increase the refcount
    
    [ Upstream commit 99f98a7c0d6985d5507c8130a981972e4b7b3bdc ]
    
    syzkaller found a race where IOMMUFD_DESTROY increments the refcount:
    
           obj = iommufd_get_object(ucmd->ictx, cmd->id, IOMMUFD_OBJ_ANY);
           if (IS_ERR(obj))
                   return PTR_ERR(obj);
           iommufd_ref_to_users(obj);
           /* See iommufd_ref_to_users() */
           if (!iommufd_object_destroy_user(ucmd->ictx, obj))
    
    As part of the sequence to join the two existing primitives together.
    
    Allowing the refcount the be elevated without holding the destroy_rwsem
    violates the assumption that all temporary refcount elevations are
    protected by destroy_rwsem. Racing IOMMUFD_DESTROY with
    iommufd_object_destroy_user() will cause spurious failures:
    
      WARNING: CPU: 0 PID: 3076 at drivers/iommu/iommufd/device.c:477 iommufd_access_destroy+0x18/0x20 drivers/iommu/iommufd/device.c:478
      Modules linked in:
      CPU: 0 PID: 3076 Comm: syz-executor.0 Not tainted 6.3.0-rc1-syzkaller #0
      Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 07/03/2023
      RIP: 0010:iommufd_access_destroy+0x18/0x20 drivers/iommu/iommufd/device.c:477
      Code: e8 3d 4e 00 00 84 c0 74 01 c3 0f 0b c3 0f 1f 44 00 00 f3 0f 1e fa 48 89 fe 48 8b bf a8 00 00 00 e8 1d 4e 00 00 84 c0 74 01 c3 <0f> 0b c3 0f 1f 44 00 00 41 57 41 56 41 55 4c 8d ae d0 00 00 00 41
      RSP: 0018:ffffc90003067e08 EFLAGS: 00010246
      RAX: 0000000000000000 RBX: ffff888109ea0300 RCX: 0000000000000000
      RDX: 0000000000000001 RSI: 0000000000000000 RDI: 00000000ffffffff
      RBP: 0000000000000004 R08: 0000000000000000 R09: ffff88810bbb3500
      R10: ffff88810bbb3e48 R11: 0000000000000000 R12: ffffc90003067e88
      R13: ffffc90003067ea8 R14: ffff888101249800 R15: 00000000fffffffe
      FS:  00007ff7254fe6c0(0000) GS:ffff888237c00000(0000) knlGS:0000000000000000
      CS:  0010 DS: 0000 ES: 0000 CR0: 0000000080050033
      CR2: 0000555557262da8 CR3: 000000010a6fd000 CR4: 0000000000350ef0
      Call Trace:
       <TASK>
       iommufd_test_create_access drivers/iommu/iommufd/selftest.c:596 [inline]
       iommufd_test+0x71c/0xcf0 drivers/iommu/iommufd/selftest.c:813
       iommufd_fops_ioctl+0x10f/0x1b0 drivers/iommu/iommufd/main.c:337
       vfs_ioctl fs/ioctl.c:51 [inline]
       __do_sys_ioctl fs/ioctl.c:870 [inline]
       __se_sys_ioctl fs/ioctl.c:856 [inline]
       __x64_sys_ioctl+0x84/0xc0 fs/ioctl.c:856
       do_syscall_x64 arch/x86/entry/common.c:50 [inline]
       do_syscall_64+0x38/0x80 arch/x86/entry/common.c:80
       entry_SYSCALL_64_after_hwframe+0x63/0xcd
    
    The solution is to not increment the refcount on the IOMMUFD_DESTROY path
    at all. Instead use the xa_lock to serialize everything. The refcount
    check == 1 and xa_erase can be done under a single critical region. This
    avoids the need for any refcount incrementing.
    
    It has the downside that if userspace races destroy with other operations
    it will get an EBUSY instead of waiting, but this is kind of racing is
    already dangerous.
    
    Fixes: 2ff4bed7fee7 ("iommufd: File descriptor, context, kconfig and makefiles")
    Link: https://lore.kernel.org/r/2-v1-85aacb2af554+bc-iommufd_syz3_jgg@nvidia.com
    Reviewed-by: Kevin Tian <kevin.tian@intel.com>
    Reported-by: syzbot+7574ebfe589049630608@syzkaller.appspotmail.com
    Signed-off-by: Jason Gunthorpe <jgg@nvidia.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 59679bd0049ed2c8e3c59f9e6093fa409e4a0e7c
Author: Ming Lei <ming.lei@redhat.com>
Date:   Wed Jul 26 22:45:02 2023 +0800

    ublk: return -EINTR if breaking from waiting for existed users in DEL_DEV
    
    [ Upstream commit 3e9dce80dbf91972aed972c743f539c396a34312 ]
    
    If user interrupts wait_event_interruptible() in ublk_ctrl_del_dev(),
    return -EINTR and let user know what happens.
    
    Fixes: 0abe39dec065 ("block: ublk: improve handling device deletion")
    Reported-by: Stefano Garzarella <sgarzare@redhat.com>
    Signed-off-by: Ming Lei <ming.lei@redhat.com>
    Reviewed-by: Stefano Garzarella <sgarzare@redhat.com>
    Link: https://lore.kernel.org/r/20230726144502.566785-4-ming.lei@redhat.com
    Signed-off-by: Jens Axboe <axboe@kernel.dk>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit b3a1e243a74632f88b22e713f1c7256754017d58
Author: Ming Lei <ming.lei@redhat.com>
Date:   Wed Jul 26 22:45:01 2023 +0800

    ublk: fail to recover device if queue setup is interrupted
    
    [ Upstream commit 0c0cbd4ebc375ceebc75c89df04b74f215fab23a ]
    
    In ublk_ctrl_end_recovery(), if wait_for_completion_interruptible() is
    interrupted by signal, queues aren't setup successfully yet, so we
    have to fail UBLK_CMD_END_USER_RECOVERY, otherwise kernel oops can be
    triggered.
    
    Fixes: c732a852b419 ("ublk_drv: add START_USER_RECOVERY and END_USER_RECOVERY support")
    Reported-by: Stefano Garzarella <sgarzare@redhat.com>
    Signed-off-by: Ming Lei <ming.lei@redhat.com>
    Reviewed-by: Stefano Garzarella <sgarzare@redhat.com>
    Link: https://lore.kernel.org/r/20230726144502.566785-3-ming.lei@redhat.com
    Signed-off-by: Jens Axboe <axboe@kernel.dk>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 6ab3e7d424cd413d7a5e976c8a30b4ffa84a65dd
Author: Ming Lei <ming.lei@redhat.com>
Date:   Wed Jul 26 22:45:00 2023 +0800

    ublk: fail to start device if queue setup is interrupted
    
    [ Upstream commit 53e7d08f6d6e214c40db1f51291bb2975c789dc2 ]
    
    In ublk_ctrl_start_dev(), if wait_for_completion_interruptible() is
    interrupted by signal, queues aren't setup successfully yet, so we
    have to fail UBLK_CMD_START_DEV, otherwise kernel oops can be triggered.
    
    Reported by German when working on qemu-storage-deamon which requires
    single thread ublk daemon.
    
    Fixes: 71f28f3136af ("ublk_drv: add io_uring based userspace block driver")
    Reported-by: German Maglione <gmaglione@redhat.com>
    Signed-off-by: Ming Lei <ming.lei@redhat.com>
    Link: https://lore.kernel.org/r/20230726144502.566785-2-ming.lei@redhat.com
    Signed-off-by: Jens Axboe <axboe@kernel.dk>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit e2e4bc585e8c251e69c9b969fa8b421e604e03f5
Author: Rob Clark <robdclark@chromium.org>
Date:   Mon Jul 24 13:30:21 2023 -0700

    drm/msm: Disallow submit with fence id 0
    
    [ Upstream commit 1b5d0ddcb34a605835051ae2950d5cfed0373dd8 ]
    
    A fence id of zero is expected to be invalid, and is not removed from
    the fence_idr table.  If userspace is requesting to specify the fence
    id with the FENCE_SN_IN flag, we need to reject a zero fence id value.
    
    Fixes: 17154addc5c1 ("drm/msm: Add MSM_SUBMIT_FENCE_SN_IN")
    Signed-off-by: Rob Clark <robdclark@chromium.org>
    Patchwork: https://patchwork.freedesktop.org/patch/549180/
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 15a2103d55fc9b395c868773b2c781c694591584
Author: Sindhu Devale <sindhu.devale@intel.com>
Date:   Tue Jul 25 10:54:38 2023 -0500

    RDMA/irdma: Report correct WC error
    
    [ Upstream commit ae463563b7a1b7d4a3d0b065b09d37a76b693937 ]
    
    Report the correct WC error if a MW bind is performed
    on an already valid/bound window.
    
    Fixes: 44d9e52977a1 ("RDMA/irdma: Implement device initialization definitions")
    Signed-off-by: Sindhu Devale <sindhu.devale@intel.com>
    Signed-off-by: Shiraz Saleem <shiraz.saleem@intel.com>
    Link: https://lore.kernel.org/r/20230725155439.1057-2-shiraz.saleem@intel.com
    Signed-off-by: Leon Romanovsky <leon@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit fd38ef70f9b88bbddafaddf19f0bdda2c64a234d
Author: Sindhu Devale <sindhu.devale@intel.com>
Date:   Tue Jul 25 10:54:37 2023 -0500

    RDMA/irdma: Fix op_type reporting in CQEs
    
    [ Upstream commit 3bfb25fa2b5bb9c29681e6ac861808f4be1331a9 ]
    
    The op_type field CQ poll info structure is incorrectly
    filled in with the queue type as opposed to the op_type
    received in the CQEs. The wrong opcode could be decoded
    and returned to the ULP.
    
    Copy the op_type field received in the CQE in the CQ poll
    info structure.
    
    Fixes: 24419777e943 ("RDMA/irdma: Fix RQ completion opcode")
    Signed-off-by: Sindhu Devale <sindhu.devale@intel.com>
    Signed-off-by: Shiraz Saleem <shiraz.saleem@intel.com>
    Link: https://lore.kernel.org/r/20230725155439.1057-1-shiraz.saleem@intel.com
    Signed-off-by: Leon Romanovsky <leon@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 637c2d569ca5b4fe3b91a3bd3082537401e715ce
Author: Dan Carpenter <dan.carpenter@linaro.org>
Date:   Fri Jul 21 17:55:49 2023 +0300

    drm/amd/display: Unlock on error path in dm_handle_mst_sideband_msg_ready_event()
    
    [ Upstream commit 38ac4e8385ffb275b1837986ca6c16f26ea028c5 ]
    
    This error path needs to unlock the "aconnector->handle_mst_msg_ready"
    mutex before returning.
    
    Fixes: 4f6d9e38c4d2 ("drm/amd/display: Add polling method to handle MST reply packet")
    Signed-off-by: Dan Carpenter <dan.carpenter@linaro.org>
    Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit d3e51257ec317a44b24964090ad245f19c828a43
Author: Mario Limonciello <mario.limonciello@amd.com>
Date:   Thu Jul 13 00:14:59 2023 -0500

    drm/amd: Fix an error handling mistake in psp_sw_init()
    
    [ Upstream commit c01aebeef3ce45f696ffa0a1303cea9b34babb45 ]
    
    If the second call to amdgpu_bo_create_kernel() fails, the memory
    allocated from the first call should be cleared.  If the third call
    fails, the memory from the second call should be cleared.
    
    Fixes: b95b5391684b ("drm/amdgpu/psp: move PSP memory alloc from hw_init to sw_init")
    Signed-off-by: Mario Limonciello <mario.limonciello@amd.com>
    Reviewed-by: Lijo Lazar <lijo.lazar@amd.com>
    Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 032bfd60999f7eed2cbe73fc00a52c0d5a6a63b2
Author: Yu Kuai <yukuai3@huawei.com>
Date:   Sat Jul 8 17:21:53 2023 +0800

    dm raid: protect md_stop() with 'reconfig_mutex'
    
    [ Upstream commit 7d5fff8982a2199d49ec067818af7d84d4f95ca0 ]
    
    __md_stop_writes() and __md_stop() will modify many fields that are
    protected by 'reconfig_mutex', and all the callers will grab
    'reconfig_mutex' except for md_stop().
    
    Also, update md_stop() to make certain 'reconfig_mutex' is held using
    lockdep_assert_held().
    
    Fixes: 9d09e663d550 ("dm: raid456 basic support")
    Signed-off-by: Yu Kuai <yukuai3@huawei.com>
    Signed-off-by: Mike Snitzer <snitzer@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit fa00410d2df142b58388fb0742716ab5c48dfb95
Author: Yu Kuai <yukuai3@huawei.com>
Date:   Sat Jul 8 17:21:52 2023 +0800

    dm raid: clean up four equivalent goto tags in raid_ctr()
    
    [ Upstream commit e74c874eabe2e9173a8fbdad616cd89c70eb8ffd ]
    
    There are four equivalent goto tags in raid_ctr(), clean them up to
    use just one.
    
    There is no functional change and this is preparation to fix
    raid_ctr()'s unprotected md_stop().
    
    Signed-off-by: Yu Kuai <yukuai3@huawei.com>
    Signed-off-by: Mike Snitzer <snitzer@kernel.org>
    Stable-dep-of: 7d5fff8982a2 ("dm raid: protect md_stop() with 'reconfig_mutex'")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 0dc2104c2221e6b7c8fb0ae65219df47e0a5e3af
Author: Yu Kuai <yukuai3@huawei.com>
Date:   Sat Jul 8 17:21:51 2023 +0800

    dm raid: fix missing reconfig_mutex unlock in raid_ctr() error paths
    
    [ Upstream commit bae3028799dc4f1109acc4df37c8ff06f2d8f1a0 ]
    
    In the error paths 'bad_stripe_cache' and 'bad_check_reshape',
    'reconfig_mutex' is still held after raid_ctr() returns.
    
    Fixes: 9dbd1aa3a81c ("dm raid: add reshaping support to the target")
    Signed-off-by: Yu Kuai <yukuai3@huawei.com>
    Signed-off-by: Mike Snitzer <snitzer@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 7a72e63d926b728d24f73d2d6052f5e14be0c502
Author: Stefano Stabellini <sstabellini@kernel.org>
Date:   Fri Jul 21 16:13:03 2023 -0700

    xenbus: check xen_domain in xenbus_probe_initcall
    
    [ Upstream commit 0d8f7cc8057890db08c54fe610d8a94af59da082 ]
    
    The same way we already do in xenbus_init.
    Fixes the following warning:
    
    [  352.175563] Trying to free already-free IRQ 0
    [  352.177355] WARNING: CPU: 1 PID: 88 at kernel/irq/manage.c:1893 free_irq+0xbf/0x350
    [...]
    [  352.213951] Call Trace:
    [  352.214390]  <TASK>
    [  352.214717]  ? __warn+0x81/0x170
    [  352.215436]  ? free_irq+0xbf/0x350
    [  352.215906]  ? report_bug+0x10b/0x200
    [  352.216408]  ? prb_read_valid+0x17/0x20
    [  352.216926]  ? handle_bug+0x44/0x80
    [  352.217409]  ? exc_invalid_op+0x13/0x60
    [  352.217932]  ? asm_exc_invalid_op+0x16/0x20
    [  352.218497]  ? free_irq+0xbf/0x350
    [  352.218979]  ? __pfx_xenbus_probe_thread+0x10/0x10
    [  352.219600]  xenbus_probe+0x7a/0x80
    [  352.221030]  xenbus_probe_thread+0x76/0xc0
    
    Fixes: 5b3353949e89 ("xen: add support for initializing xenstore later as HVM domain")
    Signed-off-by: Stefano Stabellini <stefano.stabellini@amd.com>
    Tested-by: Petr Mladek <pmladek@suse.com>
    Reviewed-by: Oleksandr Tyshchenko <oleksandr_tyshchenko@epam.com>
    
    Link: https://lore.kernel.org/r/alpine.DEB.2.22.394.2307211609140.3118466@ubuntu-linux-20-04-desktop
    Signed-off-by: Juergen Gross <jgross@suse.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 6a2b89b6b75636605e43a009f6e665f8959ca8f6
Author: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
Date:   Mon Jul 17 20:49:31 2023 +0200

    drm/i915: Fix an error handling path in igt_write_huge()
    
    [ Upstream commit e354f67733115b4453268f61e6e072e9b1ea7a2f ]
    
    All error handling paths go to 'out', except this one. Be consistent and
    also branch to 'out' here.
    
    Fixes: c10a652e239e ("drm/i915/selftests: Rework context handling in hugepages selftests")
    Signed-off-by: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
    Reviewed-by: Andrzej Hajda <andrzej.hajda@intel.com>
    Reviewed-by: Andi Shyti <andi.shyti@linux.intel.com>
    Signed-off-by: Andi Shyti <andi.shyti@linux.intel.com>
    Link: https://patchwork.freedesktop.org/patch/msgid/7a036b88671312ee9adc01c74ef5b3376f690b76.1689619758.git.christophe.jaillet@wanadoo.fr
    (cherry picked from commit 361ecaadb1ce3c5312c7c4c419271326d43899eb)
    Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 20b4735ebf34b1a05963aa9ff483e005dd7f5797
Author: Steve French <stfrench@microsoft.com>
Date:   Tue Jul 25 01:05:23 2023 -0500

    smb3: do not set NTLMSSP_VERSION flag for negotiate not auth request
    
    [ Upstream commit 19826558210b9102a7d4681c91784d137d60d71b ]
    
    The NTLMSSP_NEGOTIATE_VERSION flag only needs to be sent during
    the NTLMSSP NEGOTIATE (not the AUTH) request, so filter it out for
    NTLMSSP AUTH requests. See MS-NLMP 2.2.1.3
    
    This fixes a problem found by the gssntlmssp server.
    
    Link: https://github.com/gssapi/gss-ntlmssp/issues/95
    Fixes: 52d005337b2c ("smb3: send NTLMSSP version information")
    Acked-by: Roy Shterman <roy.shterman@gmail.com>
    Signed-off-by: Steve French <stfrench@microsoft.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 312c9b87bf1fc634571257830012c4f2212a42d0
Author: Bart Van Assche <bvanassche@acm.org>
Date:   Thu Jul 6 13:14:12 2023 -0700

    block: Fix a source code comment in include/uapi/linux/blkzoned.h
    
    [ Upstream commit e0933b526fbfd937c4a8f4e35fcdd49f0e22d411 ]
    
    Fix the symbolic names for zone conditions in the blkzoned.h header
    file.
    
    Cc: Hannes Reinecke <hare@suse.de>
    Cc: Damien Le Moal <dlemoal@kernel.org>
    Fixes: 6a0cb1bc106f ("block: Implement support for zoned block devices")
    Signed-off-by: Bart Van Assche <bvanassche@acm.org>
    Reviewed-by: Damien Le Moal <dlemoal@kernel.org>
    Link: https://lore.kernel.org/r/20230706201422.3987341-1-bvanassche@acm.org
    Signed-off-by: Jens Axboe <axboe@kernel.dk>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit e4631ad24a23349cd8e82fd5834946c52abf128c
Author: Matus Gajdos <matuszpd@gmail.com>
Date:   Wed Jul 19 18:47:29 2023 +0200

    ASoC: fsl_spdif: Silence output on stop
    
    [ Upstream commit 0e4c2b6b0c4a4b4014d9424c27e5e79d185229c5 ]
    
    Clear TX registers on stop to prevent the SPDIF interface from sending
    last written word over and over again.
    
    Fixes: a2388a498ad2 ("ASoC: fsl: Add S/PDIF CPU DAI driver")
    Signed-off-by: Matus Gajdos <matuszpd@gmail.com>
    Reviewed-by: Fabio Estevam <festevam@gmail.com>
    Link: https://lore.kernel.org/r/20230719164729.19969-1-matuszpd@gmail.com
    Signed-off-by: Mark Brown <broonie@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit b576cef3758cb651a92d88de190b1049aa2352ca
Author: Breno Leitao <leitao@debian.org>
Date:   Fri Jul 14 02:31:46 2023 -0700

    cxl/acpi: Return 'rc' instead of '0' in cxl_parse_cfmws()
    
    [ Upstream commit 91019b5bc7c2c5e6f676cce80ee6d12b2753d018 ]
    
    Driver initialization returned success (return 0) even if the
    initialization (cxl_decoder_add() or acpi_table_parse_cedt()) failed.
    
    Return the error instead of swallowing it.
    
    Fixes: f4ce1f766f1e ("cxl/acpi: Convert CFMWS parsing to ACPI sub-table helpers")
    Signed-off-by: Breno Leitao <leitao@debian.org>
    Link: https://lore.kernel.org/r/20230714093146.2253438-2-leitao@debian.org
    Reviewed-by: Alison Schofield <alison.schofield@intel.com>
    Signed-off-by: Vishal Verma <vishal.l.verma@intel.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 316db489647b8ddc381682597e89787eac61a278
Author: Breno Leitao <leitao@debian.org>
Date:   Fri Jul 14 02:31:45 2023 -0700

    cxl/acpi: Fix a use-after-free in cxl_parse_cfmws()
    
    [ Upstream commit 4cf67d3cc9994a59cf77bb9c0ccf9007fe916afe ]
    
    KASAN and KFENCE detected an user-after-free in the CXL driver. This
    happens in the cxl_decoder_add() fail path. KASAN prints the following
    error:
    
       BUG: KASAN: slab-use-after-free in cxl_parse_cfmws (drivers/cxl/acpi.c:299)
    
    This happens in cxl_parse_cfmws(), where put_device() is called,
    releasing cxld, which is accessed later.
    
    Use the local variables in the dev_err() instead of pointing to the
    released memory. Since the dev_err() is printing a resource, change the open
    coded print format to use the %pr format specifier.
    
    Fixes: e50fe01e1f2a ("cxl/core: Drop ->platform_res attribute for root decoders")
    Signed-off-by: Breno Leitao <leitao@debian.org>
    Link: https://lore.kernel.org/r/20230714093146.2253438-1-leitao@debian.org
    Reviewed-by: Alison Schofield <alison.schofield@intel.com>
    Reviewed-by: Dave Jiang <dave.jiang@intel.com>
    Reviewed-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
    Signed-off-by: Vishal Verma <vishal.l.verma@intel.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit e2808329b69aec619ba0960b9c4327fa50af1f42
Author: Rob Clark <robdclark@chromium.org>
Date:   Wed Jul 12 15:25:23 2023 -0700

    drm/msm: Fix hw_fence error path cleanup
    
    [ Upstream commit 1cd0787f082e1a179f2b6e749d08daff1a9f6b1b ]
    
    In an error path where the submit is free'd without the job being run,
    the hw_fence pointer is simply a kzalloc'd block of memory.  In this
    case we should just kfree() it, rather than trying to decrement it's
    reference count.  Fortunately we can tell that this is the case by
    checking for a zero refcount, since if the job was run, the submit would
    be holding a reference to the hw_fence.
    
    Fixes: f94e6a51e17c ("drm/msm: Pre-allocate hw_fence")
    Signed-off-by: Rob Clark <robdclark@chromium.org>
    Patchwork: https://patchwork.freedesktop.org/patch/547088/
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 8ac09b9939f10227bda7b3e5ac4ac3023b8e1611
Author: Gaosheng Cui <cuigaosheng1@huawei.com>
Date:   Mon Jul 17 09:47:38 2023 +0800

    drm/msm: Fix IS_ERR_OR_NULL() vs NULL check in a5xx_submit_in_rb()
    
    [ Upstream commit 6e8a996563ecbe68e49c49abd4aaeef69f11f2dc ]
    
    The msm_gem_get_vaddr() returns an ERR_PTR() on failure, and a null
    is catastrophic here, so we should use IS_ERR_OR_NULL() to check
    the return value.
    
    Fixes: 6a8bd08d0465 ("drm/msm: add sudo flag to submit ioctl")
    Signed-off-by: Gaosheng Cui <cuigaosheng1@huawei.com>
    Reviewed-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
    Reviewed-by: Abhinav Kumar <quic_abhinavk@quicinc.com>
    Reviewed-by: Akhil P Oommen <quic_akhilpo@quicinc.com>
    Patchwork: https://patchwork.freedesktop.org/patch/547712/
    Signed-off-by: Rob Clark <robdclark@chromium.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 56f76d1368f878bd876c8c410bf0eb79844c6aa6
Author: Selvin Xavier <selvin.xavier@broadcom.com>
Date:   Fri Jul 14 01:22:49 2023 -0700

    RDMA/bnxt_re: Fix hang during driver unload
    
    [ Upstream commit 29900bf351e1a7e4643da5c3c3cd9df75c577b88 ]
    
    Driver unload hits a hang during stress testing of load/unload.
    
    stack trace snippet -
    
    tasklet_kill at ffffffff9aabb8b2
    bnxt_qplib_nq_stop_irq at ffffffffc0a805fb [bnxt_re]
    bnxt_qplib_disable_nq at ffffffffc0a80c5b [bnxt_re]
    bnxt_re_dev_uninit at ffffffffc0a67d15 [bnxt_re]
    bnxt_re_remove_device at ffffffffc0a6af1d [bnxt_re]
    
    tasklet_kill can hang if the tasklet is scheduled after it is disabled.
    
    Modified the sequences to disable the interrupt first and synchronize
    irq before disabling the tasklet.
    
    Fixes: 1ac5a4047975 ("RDMA/bnxt_re: Add bnxt_re RoCE driver")
    Signed-off-by: Kashyap Desai <kashyap.desai@broadcom.com>
    Signed-off-by: Selvin Xavier <selvin.xavier@broadcom.com>
    Link: https://lore.kernel.org/r/1689322969-25402-3-git-send-email-selvin.xavier@broadcom.com
    Signed-off-by: Leon Romanovsky <leon@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 6de5b9944fed9b00b9ceaf7e8fe3210cd0ec44d5
Author: Kashyap Desai <kashyap.desai@broadcom.com>
Date:   Fri Jun 9 04:01:46 2023 -0700

    RDMA/bnxt_re: add helper function __poll_for_resp
    
    [ Upstream commit 354f5bd985af9515190828bc642ebdf59acea121 ]
    
    This interface will be used if the driver has not enabled interrupt
    and/or interrupt is disabled for a short period of time.
    Completion is not possible from interrupt so this interface does
    self-polling.
    
    Signed-off-by: Kashyap Desai <kashyap.desai@broadcom.com>
    Signed-off-by: Selvin Xavier <selvin.xavier@broadcom.com>
    Link: https://lore.kernel.org/r/1686308514-11996-10-git-send-email-selvin.xavier@broadcom.com
    Signed-off-by: Leon Romanovsky <leon@kernel.org>
    Stable-dep-of: 29900bf351e1 ("RDMA/bnxt_re: Fix hang during driver unload")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 22dfc9dffb769609c55d39e54fe0510274be6139
Author: Kashyap Desai <kashyap.desai@broadcom.com>
Date:   Fri Jun 9 04:01:45 2023 -0700

    RDMA/bnxt_re: Simplify the function that sends the FW commands
    
    [ Upstream commit 159cf95e42a7ca7375646fab82c0056cbb71f9e9 ]
    
     - Use __send_message_basic_sanity helper function.
     - Do not retry posting same command if there is a queue full detection.
     - ENXIO is used to indicate controller recovery.
     - In the case of ERR_DEVICE_DETACHED state, the driver should not post
       commands to the firmware, but also return fabricated written code.
    
    Signed-off-by: Kashyap Desai <kashyap.desai@broadcom.com>
    Signed-off-by: Selvin Xavier <selvin.xavier@broadcom.com>
    Link: https://lore.kernel.org/r/1686308514-11996-9-git-send-email-selvin.xavier@broadcom.com
    Signed-off-by: Leon Romanovsky <leon@kernel.org>
    Stable-dep-of: 29900bf351e1 ("RDMA/bnxt_re: Fix hang during driver unload")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit e0777f9c327f5fa09006ec9aa2504bb782ce0c9a
Author: Kashyap Desai <kashyap.desai@broadcom.com>
Date:   Fri Jun 9 04:01:44 2023 -0700

    RDMA/bnxt_re: use shadow qd while posting non blocking rcfw command
    
    [ Upstream commit 65288a22ddd81422a2a2a10c15df976a5332e41b ]
    
    Whenever there is a fast path IO and create/destroy resources from
    the slow path is happening in parallel, we may notice high latency
    of slow path command completion.
    
    Introduces a shadow queue depth to prevent the outstanding requests
    to the FW. Driver will not allow more than #RCFW_CMD_NON_BLOCKING_SHADOW_QD
    non-blocking commands to the Firmware.
    
    Shadow queue depth is a soft limit only for non-blocking
    commands. Blocking commands will be posted to the firmware
    as long as there is a free slot.
    
    Signed-off-by: Kashyap Desai <kashyap.desai@broadcom.com>
    Signed-off-by: Selvin Xavier <selvin.xavier@broadcom.com>
    Link: https://lore.kernel.org/r/1686308514-11996-8-git-send-email-selvin.xavier@broadcom.com
    Signed-off-by: Leon Romanovsky <leon@kernel.org>
    Stable-dep-of: 29900bf351e1 ("RDMA/bnxt_re: Fix hang during driver unload")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 4e5c10167e724aa46319b9c26eda7b66b810891d
Author: Kashyap Desai <kashyap.desai@broadcom.com>
Date:   Fri Jun 9 04:01:43 2023 -0700

    RDMA/bnxt_re: Avoid the command wait if firmware is inactive
    
    [ Upstream commit 3022cc15119733cebaef05feddb5d87b9e401c0e ]
    
    Add a check to avoid waiting if driver already detects a
    FW timeout. Return success for resource destroy in case
    the device is detached. Add helper function to map timeout
    error code to success.
    
    Signed-off-by: Kashyap Desai <kashyap.desai@broadcom.com>
    Signed-off-by: Selvin Xavier <selvin.xavier@broadcom.com>
    Link: https://lore.kernel.org/r/1686308514-11996-7-git-send-email-selvin.xavier@broadcom.com
    Signed-off-by: Leon Romanovsky <leon@kernel.org>
    Stable-dep-of: 29900bf351e1 ("RDMA/bnxt_re: Fix hang during driver unload")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 973d3fa70af7912064b8c41d017745cc26f53653
Author: Kashyap Desai <kashyap.desai@broadcom.com>
Date:   Fri Jun 9 04:01:42 2023 -0700

    RDMA/bnxt_re: Enhance the existing functions that wait for FW responses
    
    [ Upstream commit 8cf1d12ad56beb73d2439ccf334b7148e71de58e ]
    
    Use jiffies based timewait instead of counting iteration for
    commands that block for FW response.
    
    Also add a poll routine for control path commands. This is for
    polling completion if the waiting commands timeout. This avoids cases
    where the driver misses completion interrupts.
    
    Signed-off-by: Kashyap Desai <kashyap.desai@broadcom.com>
    Signed-off-by: Selvin Xavier <selvin.xavier@broadcom.com>
    Link: https://lore.kernel.org/r/1686308514-11996-6-git-send-email-selvin.xavier@broadcom.com
    Signed-off-by: Leon Romanovsky <leon@kernel.org>
    Stable-dep-of: 29900bf351e1 ("RDMA/bnxt_re: Fix hang during driver unload")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 7faa6097694164380ed19600c7a7993d071270b9
Author: Kashyap Desai <kashyap.desai@broadcom.com>
Date:   Fri Jul 14 01:22:48 2023 -0700

    RDMA/bnxt_re: Prevent handling any completions after qp destroy
    
    [ Upstream commit b5bbc6551297447d3cca55cf907079e206e9cd82 ]
    
    HW may generate completions that indicates QP is destroyed.
    Driver should not be scheduling any more completion handlers
    for this QP, after the QP is destroyed. Since CQs are active
    during the QP destroy, driver may still schedule completion
    handlers. This can cause a race where the destroy_cq and poll_cq
    running simultaneously.
    
    Snippet of kernel panic while doing bnxt_re driver load unload in loop.
    This indicates a poll after the CQ is freed. 
    
    [77786.481636] Call Trace:
    [77786.481640]  <TASK>
    [77786.481644]  bnxt_re_poll_cq+0x14a/0x620 [bnxt_re]
    [77786.481658]  ? kvm_clock_read+0x14/0x30
    [77786.481693]  __ib_process_cq+0x57/0x190 [ib_core]
    [77786.481728]  ib_cq_poll_work+0x26/0x80 [ib_core]
    [77786.481761]  process_one_work+0x1e5/0x3f0
    [77786.481768]  worker_thread+0x50/0x3a0
    [77786.481785]  ? __pfx_worker_thread+0x10/0x10
    [77786.481790]  kthread+0xe2/0x110
    [77786.481794]  ? __pfx_kthread+0x10/0x10
    [77786.481797]  ret_from_fork+0x2c/0x50
    
    To avoid this, complete all completion handlers before returning the
    destroy QP. If free_cq is called soon after destroy_qp,  IB stack
    will cancel the CQ work before invoking the destroy_cq verb and
    this will prevent any race mentioned.
    
    Fixes: 1ac5a4047975 ("RDMA/bnxt_re: Add bnxt_re RoCE driver")
    Signed-off-by: Kashyap Desai <kashyap.desai@broadcom.com>
    Signed-off-by: Selvin Xavier <selvin.xavier@broadcom.com>
    Link: https://lore.kernel.org/r/1689322969-25402-2-git-send-email-selvin.xavier@broadcom.com
    Signed-off-by: Leon Romanovsky <leon@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit d824dc70380c5e9e231942b9c9fe4bb7dca32081
Author: Thomas Bogendoerfer <tbogendoerfer@suse.de>
Date:   Thu Jul 13 16:16:58 2023 +0200

    RDMA/mthca: Fix crash when polling CQ for shared QPs
    
    [ Upstream commit dc52aadbc1849cbe3fcf6bc54d35f6baa396e0a1 ]
    
    Commit 21c2fe94abb2 ("RDMA/mthca: Combine special QP struct with mthca QP")
    introduced a new struct mthca_sqp which doesn't contain struct mthca_qp
    any longer. Placing a pointer of this new struct into qptable leads
    to crashes, because mthca_poll_one() expects a qp pointer. Fix this
    by putting the correct pointer into qptable.
    
    Fixes: 21c2fe94abb2 ("RDMA/mthca: Combine special QP struct with mthca QP")
    Signed-off-by: Thomas Bogendoerfer <tbogendoerfer@suse.de>
    Link: https://lore.kernel.org/r/20230713141658.9426-1-tbogendoerfer@suse.de
    Signed-off-by: Leon Romanovsky <leon@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 046e12b8fc66735ee784ab915909fb18e8623428
Author: Shiraz Saleem <shiraz.saleem@intel.com>
Date:   Wed Jul 12 18:41:33 2023 -0500

    RDMA/core: Update CMA destination address on rdma_resolve_addr
    
    [ Upstream commit 0e15863015d97c1ee2cc29d599abcc7fa2dc3e95 ]
    
    8d037973d48c ("RDMA/core: Refactor rdma_bind_addr") intoduces as regression
    on irdma devices on certain tests which uses rdma CM, such as cmtime.
    
    No connections can be established with the MAD QP experiences a fatal
    error on the active side.
    
    The cma destination address is not updated with the dst_addr when ULP
    on active side calls rdma_bind_addr followed by rdma_resolve_addr.
    The id_priv state is 'bound' in resolve_prepare_src and update is skipped.
    
    This leaves the dgid passed into irdma driver to create an Address Handle
    (AH) for the MAD QP at 0. The create AH descriptor as well as the ARP cache
    entry is invalid and HW throws an asynchronous events as result.
    
    [ 1207.656888] resolve_prepare_src caller: ucma_resolve_addr+0xff/0x170 [rdma_ucm] daddr=200.0.4.28 id_priv->state=7
    [....]
    [ 1207.680362] ice 0000:07:00.1 rocep7s0f1: caller: irdma_create_ah+0x3e/0x70 [irdma] ah_id=0 arp_idx=0 dest_ip=0.0.0.0
    destMAC=00:00:64:ca:b7:52 ipvalid=1 raw=0000:0000:0000:0000:0000:ffff:0000:0000
    [ 1207.682077] ice 0000:07:00.1 rocep7s0f1: abnormal ae_id = 0x401 bool qp=1 qp_id = 1, ae_src=5
    [ 1207.691657] infiniband rocep7s0f1: Fatal error (1) on MAD QP (1)
    
    Fix this by updating the CMA destination address when the ULP calls
    a resolve address with the CM state already bound.
    
    Fixes: 8d037973d48c ("RDMA/core: Refactor rdma_bind_addr")
    Signed-off-by: Shiraz Saleem <shiraz.saleem@intel.com>
    Link: https://lore.kernel.org/r/20230712234133.1343-1-shiraz.saleem@intel.com
    Signed-off-by: Leon Romanovsky <leon@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit b8b90ba636e3861665aef9a3eab5fcf92839a2c5
Author: Shiraz Saleem <shiraz.saleem@intel.com>
Date:   Tue Jul 11 12:52:53 2023 -0500

    RDMA/irdma: Fix data race on CQP request done
    
    [ Upstream commit f0842bb3d38863777e3454da5653d80b5fde6321 ]
    
    KCSAN detects a data race on cqp_request->request_done memory location
    which is accessed locklessly in irdma_handle_cqp_op while being
    updated in irdma_cqp_ce_handler.
    
    Annotate lockless intent with READ_ONCE/WRITE_ONCE to avoid any
    compiler optimizations like load fusing and/or KCSAN warning.
    
    [222808.417128] BUG: KCSAN: data-race in irdma_cqp_ce_handler [irdma] / irdma_wait_event [irdma]
    
    [222808.417532] write to 0xffff8e44107019dc of 1 bytes by task 29658 on cpu 5:
    [222808.417610]  irdma_cqp_ce_handler+0x21e/0x270 [irdma]
    [222808.417725]  cqp_compl_worker+0x1b/0x20 [irdma]
    [222808.417827]  process_one_work+0x4d1/0xa40
    [222808.417835]  worker_thread+0x319/0x700
    [222808.417842]  kthread+0x180/0x1b0
    [222808.417852]  ret_from_fork+0x22/0x30
    
    [222808.417918] read to 0xffff8e44107019dc of 1 bytes by task 29688 on cpu 1:
    [222808.417995]  irdma_wait_event+0x1e2/0x2c0 [irdma]
    [222808.418099]  irdma_handle_cqp_op+0xae/0x170 [irdma]
    [222808.418202]  irdma_cqp_cq_destroy_cmd+0x70/0x90 [irdma]
    [222808.418308]  irdma_puda_dele_rsrc+0x46d/0x4d0 [irdma]
    [222808.418411]  irdma_rt_deinit_hw+0x179/0x1d0 [irdma]
    [222808.418514]  irdma_ib_dealloc_device+0x11/0x40 [irdma]
    [222808.418618]  ib_dealloc_device+0x2a/0x120 [ib_core]
    [222808.418823]  __ib_unregister_device+0xde/0x100 [ib_core]
    [222808.418981]  ib_unregister_device+0x22/0x40 [ib_core]
    [222808.419142]  irdma_ib_unregister_device+0x70/0x90 [irdma]
    [222808.419248]  i40iw_close+0x6f/0xc0 [irdma]
    [222808.419352]  i40e_client_device_unregister+0x14a/0x180 [i40e]
    [222808.419450]  i40iw_remove+0x21/0x30 [irdma]
    [222808.419554]  auxiliary_bus_remove+0x31/0x50
    [222808.419563]  device_remove+0x69/0xb0
    [222808.419572]  device_release_driver_internal+0x293/0x360
    [222808.419582]  driver_detach+0x7c/0xf0
    [222808.419592]  bus_remove_driver+0x8c/0x150
    [222808.419600]  driver_unregister+0x45/0x70
    [222808.419610]  auxiliary_driver_unregister+0x16/0x30
    [222808.419618]  irdma_exit_module+0x18/0x1e [irdma]
    [222808.419733]  __do_sys_delete_module.constprop.0+0x1e2/0x310
    [222808.419745]  __x64_sys_delete_module+0x1b/0x30
    [222808.419755]  do_syscall_64+0x39/0x90
    [222808.419763]  entry_SYSCALL_64_after_hwframe+0x63/0xcd
    
    [222808.419829] value changed: 0x01 -> 0x03
    
    Fixes: 915cc7ac0f8e ("RDMA/irdma: Add miscellaneous utility definitions")
    Signed-off-by: Shiraz Saleem <shiraz.saleem@intel.com>
    Link: https://lore.kernel.org/r/20230711175253.1289-4-shiraz.saleem@intel.com
    Signed-off-by: Leon Romanovsky <leon@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 2623ca92cd8f9668edabe9e4f4a3cf77fd7115f2
Author: Shiraz Saleem <shiraz.saleem@intel.com>
Date:   Tue Jul 11 12:52:52 2023 -0500

    RDMA/irdma: Fix data race on CQP completion stats
    
    [ Upstream commit f2c3037811381f9149243828c7eb9a1631df9f9c ]
    
    CQP completion statistics is read lockesly in irdma_wait_event and
    irdma_check_cqp_progress while it can be updated in the completion
    thread irdma_sc_ccq_get_cqe_info on another CPU as KCSAN reports.
    
    Make completion statistics an atomic variable to reflect coherent updates
    to it. This will also avoid load/store tearing logic bug potentially
    possible by compiler optimizations.
    
    [77346.170861] BUG: KCSAN: data-race in irdma_handle_cqp_op [irdma] / irdma_sc_ccq_get_cqe_info [irdma]
    
    [77346.171383] write to 0xffff8a3250b108e0 of 8 bytes by task 9544 on cpu 4:
    [77346.171483]  irdma_sc_ccq_get_cqe_info+0x27a/0x370 [irdma]
    [77346.171658]  irdma_cqp_ce_handler+0x164/0x270 [irdma]
    [77346.171835]  cqp_compl_worker+0x1b/0x20 [irdma]
    [77346.172009]  process_one_work+0x4d1/0xa40
    [77346.172024]  worker_thread+0x319/0x700
    [77346.172037]  kthread+0x180/0x1b0
    [77346.172054]  ret_from_fork+0x22/0x30
    
    [77346.172136] read to 0xffff8a3250b108e0 of 8 bytes by task 9838 on cpu 2:
    [77346.172234]  irdma_handle_cqp_op+0xf4/0x4b0 [irdma]
    [77346.172413]  irdma_cqp_aeq_cmd+0x75/0xa0 [irdma]
    [77346.172592]  irdma_create_aeq+0x390/0x45a [irdma]
    [77346.172769]  irdma_rt_init_hw.cold+0x212/0x85d [irdma]
    [77346.172944]  irdma_probe+0x54f/0x620 [irdma]
    [77346.173122]  auxiliary_bus_probe+0x66/0xa0
    [77346.173137]  really_probe+0x140/0x540
    [77346.173154]  __driver_probe_device+0xc7/0x220
    [77346.173173]  driver_probe_device+0x5f/0x140
    [77346.173190]  __driver_attach+0xf0/0x2c0
    [77346.173208]  bus_for_each_dev+0xa8/0xf0
    [77346.173225]  driver_attach+0x29/0x30
    [77346.173240]  bus_add_driver+0x29c/0x2f0
    [77346.173255]  driver_register+0x10f/0x1a0
    [77346.173272]  __auxiliary_driver_register+0xbc/0x140
    [77346.173287]  irdma_init_module+0x55/0x1000 [irdma]
    [77346.173460]  do_one_initcall+0x7d/0x410
    [77346.173475]  do_init_module+0x81/0x2c0
    [77346.173491]  load_module+0x1232/0x12c0
    [77346.173506]  __do_sys_finit_module+0x101/0x180
    [77346.173522]  __x64_sys_finit_module+0x3c/0x50
    [77346.173538]  do_syscall_64+0x39/0x90
    [77346.173553]  entry_SYSCALL_64_after_hwframe+0x63/0xcd
    
    [77346.173634] value changed: 0x0000000000000094 -> 0x0000000000000095
    
    Fixes: 915cc7ac0f8e ("RDMA/irdma: Add miscellaneous utility definitions")
    Signed-off-by: Shiraz Saleem <shiraz.saleem@intel.com>
    Link: https://lore.kernel.org/r/20230711175253.1289-3-shiraz.saleem@intel.com
    Signed-off-by: Leon Romanovsky <leon@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit ee38994979df83f24a0d4185450624fd3926edcd
Author: Shiraz Saleem <shiraz.saleem@intel.com>
Date:   Tue Jul 11 12:52:51 2023 -0500

    RDMA/irdma: Add missing read barriers
    
    [ Upstream commit 4984eb51453ff7eddee9e5ce816145be39c0ec5c ]
    
    On code inspection, there are many instances in the driver where
    CEQE and AEQE fields written to by HW are read without guaranteeing
    that the polarity bit has been read and checked first.
    
    Add a read barrier to avoid reordering of loads on the CEQE/AEQE fields
    prior to checking the polarity bit.
    
    Fixes: 3f49d6842569 ("RDMA/irdma: Implement HW Admin Queue OPs")
    Signed-off-by: Shiraz Saleem <shiraz.saleem@intel.com>
    Link: https://lore.kernel.org/r/20230711175253.1289-2-shiraz.saleem@intel.com
    Signed-off-by: Leon Romanovsky <leon@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 0370fbed4d5566935a1cfc2ccc6ce8a26ab51eca
Author: Rob Clark <robdclark@chromium.org>
Date:   Tue Jul 11 10:54:07 2023 -0700

    drm/msm/adreno: Fix snapshot BINDLESS_DATA size
    
    [ Upstream commit bd846ceee9c478d0397428f02696602ba5eb264a ]
    
    The incorrect size was causing "CP | AHB bus error" when snapshotting
    the GPU state on a6xx gen4 (a660 family).
    
    Closes: https://gitlab.freedesktop.org/drm/msm/-/issues/26
    Signed-off-by: Rob Clark <robdclark@chromium.org>
    Reviewed-by: Akhil P Oommen <quic_akhilpo@quicinc.com>
    Fixes: 1707add81551 ("drm/msm/a6xx: Add a6xx gpu state")
    Patchwork: https://patchwork.freedesktop.org/patch/546763/
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 7ded87a612f89c78fa0c8622388e48753da0db42
Author: Marijn Suijten <marijn.suijten@somainline.org>
Date:   Tue Jun 27 22:14:16 2023 +0200

    drm/msm/dsi: Drop unused regulators from QCM2290 14nm DSI PHY config
    
    [ Upstream commit 97368254a08e2ca4766e7f84a45840230fe77fa3 ]
    
    The regulator setup was likely copied from other SoCs by mistake.  Just
    like SM6125 the DSI PHY on this platform is not getting power from a
    regulator but from the MX power domain.
    
    Fixes: 572e9fd6d14a ("drm/msm/dsi: Add phy configuration for QCM2290")
    Signed-off-by: Marijn Suijten <marijn.suijten@somainline.org>
    Reviewed-by: Konrad Dybcio <konrad.dybcio@linaro.org>
    Reviewed-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
    Reviewed-by: Abhinav Kumar <quic_abhinavk@quicinc.com>
    Patchwork: https://patchwork.freedesktop.org/patch/544536/
    Link: https://lore.kernel.org/r/20230627-sm6125-dpu-v2-1-03e430a2078c@somainline.org
    Signed-off-by: Abhinav Kumar <quic_abhinavk@quicinc.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit c4934d3966c766d93ea7bad16c38689b968cf4ee
Author: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
Date:   Fri Jul 7 22:39:32 2023 +0300

    drm/msm/dpu: drop enum dpu_core_perf_data_bus_id
    
    [ Upstream commit e8383f5cf1b3573ce140a80bfbfd809278ab16d6 ]
    
    Drop the leftover of bus-client -> interconnect conversion, the enum
    dpu_core_perf_data_bus_id.
    
    Fixes: cb88482e2570 ("drm/msm/dpu: clean up references of DPU custom bus scaling")
    Reviewed-by: Konrad Dybcio <konrad.dybcio@linaro.org>
    Reviewed-by: Abhinav Kumar <quic_abhinavk@quicinc.com>
    Signed-off-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
    Patchwork: https://patchwork.freedesktop.org/patch/546048/
    Link: https://lore.kernel.org/r/20230707193942.3806526-2-dmitry.baryshkov@linaro.org
    Signed-off-by: Abhinav Kumar <quic_abhinavk@quicinc.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit e7b18ba79cd3f282ebd9eb277904cdd1b8472a56
Author: Jonathan Marek <jonathan@marek.ca>
Date:   Tue Jul 4 12:01:04 2023 -0400

    drm/msm/dpu: add missing flush and fetch bits for DMA4/DMA5 planes
    
    [ Upstream commit ba7a94ea73120e3f72c4a9b7ed6fd5598d29c069 ]
    
    Note that with this, DMA4/DMA5 are still non-functional, but at least
    display *something* in modetest instead of nothing or underflow.
    
    Fixes: efcd0107727c ("drm/msm/dpu: add support for SM8550")
    Signed-off-by: Jonathan Marek <jonathan@marek.ca>
    Reviewed-by: Abhinav Kumar <quic_abhinavk@quicinc.com>
    Tested-by: Neil Armstrong <neil.armstrong@linaro.org> # on SM8550-QRD
    Patchwork: https://patchwork.freedesktop.org/patch/545548/
    Link: https://lore.kernel.org/r/20230704160106.26055-1-jonathan@marek.ca
    Signed-off-by: Abhinav Kumar <quic_abhinavk@quicinc.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit cdb23d0d7d0bcd3111974a24567d4e8ae8b6ce61
Author: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
Date:   Wed Jul 12 15:11:39 2023 +0300

    drm/msm/mdss: correct UBWC programming for SM8550
    
    [ Upstream commit a85c238c5ccd64f8d4c4560702c65cb25dee791c ]
    
    The SM8550 platform employs newer UBWC decoder, which requires slightly
    different programming.
    
    Fixes: a2f33995c19d ("drm/msm: mdss: add support for SM8550")
    Signed-off-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
    Reviewed-by: Abhinav Kumar <quic_abhinavk@quicinc.com>
    Patchwork: https://patchwork.freedesktop.org/patch/546934/
    Link: https://lore.kernel.org/r/20230712121145.1994830-3-dmitry.baryshkov@linaro.org
    Signed-off-by: Abhinav Kumar <quic_abhinavk@quicinc.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit acc0e7732247a8556426e4340e2985d235a01c9e
Author: Dan Carpenter <dan.carpenter@linaro.org>
Date:   Thu Jun 29 09:07:37 2023 +0300

    RDMA/mlx4: Make check for invalid flags stricter
    
    [ Upstream commit d64b1ee12a168030fbb3e0aebf7bce49e9a07589 ]
    
    This code is trying to ensure that only the flags specified in the list
    are allowed.  The problem is that ucmd->rx_hash_fields_mask is a u64 and
    the flags are an enum which is treated as a u32 in this context.  That
    means the test doesn't check whether the highest 32 bits are zero.
    
    Fixes: 4d02ebd9bbbd ("IB/mlx4: Fix RSS hash fields restrictions")
    Signed-off-by: Dan Carpenter <dan.carpenter@linaro.org>
    Link: https://lore.kernel.org/r/233ed975-982d-422a-b498-410f71d8a101@moroto.mountain
    Signed-off-by: Leon Romanovsky <leon@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 8b1fc5b540482c2ae31767ff46705cdfef7e77c2
Author: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
Date:   Tue Apr 25 08:47:27 2023 +0200

    fs/9p: Fix a datatype used with V9FS_DIRECT_IO
    
    [ Upstream commit 95f41d87810083d8b3dedcce46a4e356cf4a9673 ]
    
    The commit in Fixes has introduced some "enum p9_session_flags" values
    larger than a char.
    Such values are stored in "v9fs_session_info->flags" which is a char only.
    
    Turn it into an int so that the "enum p9_session_flags" values can fit in
    it.
    
    Fixes: 6deffc8924b5 ("fs/9p: Add new mount modes")
    Signed-off-by: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
    Reviewed-by: Dominique Martinet <asmadeus@codewreck.org>
    Reviewed-by: Christian Schoenebeck <linux_oss@crudebyte.com>
    Signed-off-by: Eric Van Hensbergen <ericvh@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit fcc62b0e34241e40ffd7b5f6c33ecf726fef5643
Author: Fedor Pchelkin <pchelkin@ispras.ru>
Date:   Wed Jul 26 00:46:25 2023 +0300

    tipc: stop tipc crypto on failure in tipc_node_create
    
    [ Upstream commit de52e17326c3e9a719c9ead4adb03467b8fae0ef ]
    
    If tipc_link_bc_create() fails inside tipc_node_create() for a newly
    allocated tipc node then we should stop its tipc crypto and free the
    resources allocated with a call to tipc_crypto_start().
    
    As the node ref is initialized to one to that point, just put the ref on
    tipc_link_bc_create() error case that would lead to tipc_node_free() be
    eventually executed and properly clean the node and its crypto resources.
    
    Found by Linux Verification Center (linuxtesting.org).
    
    Fixes: cb8092d70a6f ("tipc: move bc link creation back to tipc_node_create")
    Suggested-by: Xin Long <lucien.xin@gmail.com>
    Signed-off-by: Fedor Pchelkin <pchelkin@ispras.ru>
    Reviewed-by: Xin Long <lucien.xin@gmail.com>
    Link: https://lore.kernel.org/r/20230725214628.25246-1-pchelkin@ispras.ru
    Signed-off-by: Paolo Abeni <pabeni@redhat.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 3a85a6487b908374a8cfdb9b7ed0e850c7ca2476
Author: Yuanjun Gong <ruc_gongyuanjun@163.com>
Date:   Tue Jul 25 14:48:10 2023 +0800

    tipc: check return value of pskb_trim()
    
    [ Upstream commit e46e06ffc6d667a89b979701288e2264f45e6a7b ]
    
    goto free_skb if an unexpected result is returned by pskb_tirm()
    in tipc_crypto_rcv_complete().
    
    Fixes: fc1b6d6de220 ("tipc: introduce TIPC encryption & authentication")
    Signed-off-by: Yuanjun Gong <ruc_gongyuanjun@163.com>
    Reviewed-by: Tung Nguyen <tung.q.nguyen@dektech.com.au>
    Link: https://lore.kernel.org/r/20230725064810.5820-1-ruc_gongyuanjun@163.com
    Signed-off-by: Paolo Abeni <pabeni@redhat.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 122d387677aefc0aa6bdd2ccb4204cd4b6417552
Author: Yuanjun Gong <ruc_gongyuanjun@163.com>
Date:   Tue Jul 25 11:27:26 2023 +0800

    benet: fix return value check in be_lancer_xmit_workarounds()
    
    [ Upstream commit 5c85f7065718a949902b238a6abd8fc907c5d3e0 ]
    
    in be_lancer_xmit_workarounds(), it should go to label 'tx_drop'
    if an unexpected value is returned by pskb_trim().
    
    Fixes: 93040ae5cc8d ("be2net: Fix to trim skb for padded vlan packets to workaround an ASIC Bug")
    Signed-off-by: Yuanjun Gong <ruc_gongyuanjun@163.com>
    Link: https://lore.kernel.org/r/20230725032726.15002-1-ruc_gongyuanjun@163.com
    Signed-off-by: Paolo Abeni <pabeni@redhat.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit e57cfdb11295f1ade9eb20358b896474f0835886
Author: Lin Ma <linma@zju.edu.cn>
Date:   Tue Jul 25 10:42:27 2023 +0800

    net/sched: mqprio: Add length check for TCA_MQPRIO_{MAX/MIN}_RATE64
    
    [ Upstream commit 6c58c8816abb7b93b21fa3b1d0c1726402e5e568 ]
    
    The nla_for_each_nested parsing in function mqprio_parse_nlattr() does
    not check the length of the nested attribute. This can lead to an
    out-of-attribute read and allow a malformed nlattr (e.g., length 0) to
    be viewed as 8 byte integer and passed to priv->max_rate/min_rate.
    
    This patch adds the check based on nla_len() when check the nla_type(),
    which ensures that the length of these two attribute must equals
    sizeof(u64).
    
    Fixes: 4e8b86c06269 ("mqprio: Introduce new hardware offload mode and shaper in mqprio")
    Reviewed-by: Victor Nogueira <victor@mojatatu.com>
    Signed-off-by: Lin Ma <linma@zju.edu.cn>
    Link: https://lore.kernel.org/r/20230725024227.426561-1-linma@zju.edu.cn
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit ece320c78d629c83332b2ad85b8cd52fbc345a5c
Author: Wei Fang <wei.fang@nxp.com>
Date:   Tue Jul 25 15:41:48 2023 +0800

    net: fec: tx processing does not call XDP APIs if budget is 0
    
    [ Upstream commit 15cec633fc7bfe4cd69aa012c3b35b31acfc86f2 ]
    
    According to the clarification [1] in the latest napi.rst, the tx
    processing cannot call any XDP (or page pool) APIs if the "budget"
    is 0. Because NAPI is called with the budget of 0 (such as netpoll)
    indicates we may be in an IRQ context, however, we cannot use the
    page pool from IRQ context.
    
    [1] https://lore.kernel.org/all/20230720161323.2025379-1-kuba@kernel.org/
    
    Fixes: 20f797399035 ("net: fec: recycle pages for transmitted XDP frames")
    Signed-off-by: Wei Fang <wei.fang@nxp.com>
    Suggested-by: Jakub Kicinski <kuba@kernel.org>
    Link: https://lore.kernel.org/r/20230725074148.2936402-1-wei.fang@nxp.com
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit fcbfd96a1e6131fbf8290e6f9e8621b06e5d90ac
Author: Arkadiusz Kubalewski <arkadiusz.kubalewski@intel.com>
Date:   Tue Jul 25 12:16:41 2023 +0200

    tools: ynl-gen: fix enum index in _decode_enum(..)
    
    [ Upstream commit d7ddf5f4269fcaf19aafe971e635d91897423a3a ]
    
    Remove wrong index adjustment, which is leftover from adding
    support for sparse enums.
    enum.entries_by_val() function shall not subtract the start-value, as
    it is indexed with real enum value.
    
    Fixes: c311aaa74ca1 ("tools: ynl: fix enum-as-flags in the generic CLI")
    Signed-off-by: Arkadiusz Kubalewski <arkadiusz.kubalewski@intel.com>
    Reviewed-by: Donald Hunter <donald.hunter@gmail.com>
    Link: https://lore.kernel.org/r/20230725101642.267248-2-arkadiusz.kubalewski@intel.com
    Reviewed-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 33e9ae3dac1224cc1d43932aed13b08dc790fbb8
Author: Linus Torvalds <torvalds@linux-foundation.org>
Date:   Tue Jul 25 09:38:32 2023 -0700

    mm: suppress mm fault logging if fatal signal already pending
    
    [ Upstream commit 5f0bc0b042fc77ff70e14c790abdec960cde4ec1 ]
    
    Commit eda0047296a1 ("mm: make the page fault mmap locking killable")
    intentionally made it much easier to trigger the "page fault fails
    because a fatal signal is pending" situation, by having the mmap locking
    fail early in that case.
    
    We have long aborted page faults in other fatal cases when the actual IO
    for a page is interrupted by SIGKILL - which is particularly useful for
    the traditional case of NFS hanging due to network issues, but local
    filesystems could cause it too if you happened to get the SIGKILL while
    waiting for a page to be faulted in (eg lock_folio_maybe_drop_mmap()).
    
    So aborting the page fault wasn't a new condition - but it now triggers
    earlier, before we even get to 'handle_mm_fault()'.  And as a result the
    error doesn't go through our 'fault_signal_pending()' logic, and doesn't
    get filtered away there.
    
    Normally you'd never even notice, because if a fatal signal is pending,
    the new SIGSEGV we send ends up being ignored anyway.
    
    But it turns out that there is one very noticeable exception: if you
    enable 'show_unhandled_signals', the aborted page fault will be logged
    in the kernel messages, and you'll get a scary line looking something
    like this in your logs:
    
      pverados[2183248]: segfault at 55e5a00f9ae0 ip 000055e5a00f9ae0 sp 00007ffc0720bea8 error 14 in perl[55e5a00d4000+195000] likely on CPU 10 (core 4, socket 0)
    
    which is rather misleading.  It's not really a segfault at all, it's
    just "the thread was killed before the page fault completed, so we
    aborted the page fault".
    
    Fix this by just making it clear that a pending fatal signal means that
    any new signal coming in after that is implicitly handled.  This will
    avoid the misleading logging, since now the signal isn't 'unhandled' any
    more.
    
    Reported-and-tested-by: Fiona Ebner <f.ebner@proxmox.com>
    Tested-by: Thomas Lamprecht <t.lamprecht@proxmox.com>
    Link: https://lore.kernel.org/lkml/8d063a26-43f5-0bb7-3203-c6a04dc159f8@proxmox.com/
    Acked-by: Oleg Nesterov <oleg@redhat.com>
    Fixes: eda0047296a1 ("mm: make the page fault mmap locking killable")
    Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 14448359681062bf51d9c67e0264869548b79853
Author: Pablo Neira Ayuso <pablo@netfilter.org>
Date:   Sun Jul 23 16:41:48 2023 +0200

    netfilter: nf_tables: disallow rule addition to bound chain via NFTA_RULE_CHAIN_ID
    
    [ Upstream commit 0ebc1064e4874d5987722a2ddbc18f94aa53b211 ]
    
    Bail out with EOPNOTSUPP when adding rule to bound chain via
    NFTA_RULE_CHAIN_ID. The following warning splat is shown when
    adding a rule to a deleted bound chain:
    
     WARNING: CPU: 2 PID: 13692 at net/netfilter/nf_tables_api.c:2013 nf_tables_chain_destroy+0x1f7/0x210 [nf_tables]
     CPU: 2 PID: 13692 Comm: chain-bound-rul Not tainted 6.1.39 #1
     RIP: 0010:nf_tables_chain_destroy+0x1f7/0x210 [nf_tables]
    
    Fixes: d0e2c7de92c7 ("netfilter: nf_tables: add NFT_CHAIN_BINDING")
    Reported-by: Kevin Rich <kevinrich1337@gmail.com>
    Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
    Signed-off-by: Florian Westphal <fw@strlen.de>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 027d00132487bcf2a4ee7493bb8de9d6331d48e3
Author: Pablo Neira Ayuso <pablo@netfilter.org>
Date:   Sun Jul 23 16:24:46 2023 +0200

    netfilter: nf_tables: skip immediate deactivate in _PREPARE_ERROR
    
    [ Upstream commit 0a771f7b266b02d262900c75f1e175c7fe76fec2 ]
    
    On error when building the rule, the immediate expression unbinds the
    chain, hence objects can be deactivated by the transaction records.
    
    Otherwise, it is possible to trigger the following warning:
    
     WARNING: CPU: 3 PID: 915 at net/netfilter/nf_tables_api.c:2013 nf_tables_chain_destroy+0x1f7/0x210 [nf_tables]
     CPU: 3 PID: 915 Comm: chain-bind-err- Not tainted 6.1.39 #1
     RIP: 0010:nf_tables_chain_destroy+0x1f7/0x210 [nf_tables]
    
    Fixes: 4bedf9eee016 ("netfilter: nf_tables: fix chain binding transaction logic")
    Reported-by: Kevin Rich <kevinrich1337@gmail.com>
    Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
    Signed-off-by: Florian Westphal <fw@strlen.de>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit cd66733932399475fe933cb3ec03e687ed401462
Author: Florian Westphal <fw@strlen.de>
Date:   Thu Jul 20 21:30:05 2023 +0200

    netfilter: nft_set_rbtree: fix overlap expiration walk
    
    [ Upstream commit f718863aca469a109895cb855e6b81fff4827d71 ]
    
    The lazy gc on insert that should remove timed-out entries fails to release
    the other half of the interval, if any.
    
    Can be reproduced with tests/shell/testcases/sets/0044interval_overlap_0
    in nftables.git and kmemleak enabled kernel.
    
    Second bug is the use of rbe_prev vs. prev pointer.
    If rbe_prev() returns NULL after at least one iteration, rbe_prev points
    to element that is not an end interval, hence it should not be removed.
    
    Lastly, check the genmask of the end interval if this is active in the
    current generation.
    
    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>

commit c12554d97fcd954d5c66bcd016586732cf240d0b
Author: Muhammad Husaini Zulkifli <muhammad.husaini.zulkifli@intel.com>
Date:   Mon Jul 24 09:12:50 2023 -0700

    igc: Fix Kernel Panic during ndo_tx_timeout callback
    
    [ Upstream commit d4a7ce642100765119a872d4aba1bf63e3a22c8a ]
    
    The Xeon validation group has been carrying out some loaded tests
    with various HW configurations, and they have seen some transmit
    queue time out happening during the test. This will cause the
    reset adapter function to be called by igc_tx_timeout().
    Similar race conditions may arise when the interface is being brought
    down and up in igc_reinit_locked(), an interrupt being generated, and
    igc_clean_tx_irq() being called to complete the TX.
    
    When the igc_tx_timeout() function is invoked, this patch will turn
    off all TX ring HW queues during igc_down() process. TX ring HW queues
    will be activated again during the igc_configure_tx_ring() process
    when performing the igc_up() procedure later.
    
    This patch also moved existing igc_disable_tx_ring_hw() to avoid using
    forward declaration.
    
    Kernel trace:
    [ 7678.747813] ------------[ cut here ]------------
    [ 7678.757914] NETDEV WATCHDOG: enp1s0 (igc): transmit queue 2 timed out
    [ 7678.770117] WARNING: CPU: 0 PID: 13 at net/sched/sch_generic.c:525 dev_watchdog+0x1ae/0x1f0
    [ 7678.784459] Modules linked in: xt_conntrack nft_chain_nat xt_MASQUERADE xt_addrtype nft_compat
    nf_tables nfnetlink br_netfilter bridge stp llc overlay dm_mod emrcha(PO) emriio(PO) rktpm(PO)
    cegbuf_mod(PO) patch_update(PO) se(PO) sgx_tgts(PO) mktme(PO) keylocker(PO) svtdx(PO) svfs_pci_hotplug(PO)
    vtd_mod(PO) davemem(PO) svmabort(PO) svindexio(PO) usbx2(PO) ehci_sched(PO) svheartbeat(PO) ioapic(PO)
    sv8259(PO) svintr(PO) lt(PO) pcierootport(PO) enginefw_mod(PO) ata(PO) smbus(PO) spiflash_cdf(PO) arden(PO)
    dsa_iax(PO) oobmsm_punit(PO) cpm(PO) svkdb(PO) ebg_pch(PO) pch(PO) sviotargets(PO) svbdf(PO) svmem(PO)
    svbios(PO) dram(PO) svtsc(PO) targets(PO) superio(PO) svkernel(PO) cswitch(PO) mcf(PO) pentiumIII_mod(PO)
    fs_svfs(PO) mdevdefdb(PO) svfs_os_services(O) ixgbe mdio mdio_devres libphy emeraldrapids_svdefs(PO)
    regsupport(O) libnvdimm nls_cp437 snd_hda_codec_realtek snd_hda_codec_generic ledtrig_audio snd_hda_intel
    snd_intel_dspcfg snd_hda_codec snd_hwdep x86_pkg_temp_thermal snd_hda_core snd_pcm snd_timer isst_if_mbox_pci
    [ 7678.784496]  input_leds isst_if_mmio sg snd isst_if_common soundcore wmi button sad9(O) drm fuse backlight
    configfs efivarfs ip_tables x_tables vmd sdhci led_class rtl8150 r8152 hid_generic pegasus mmc_block usbhid
    mmc_core hid megaraid_sas ixgb igb i2c_algo_bit ice i40e hpsa scsi_transport_sas e1000e e1000 e100 ax88179_178a
    usbnet xhci_pci sd_mod xhci_hcd t10_pi crc32c_intel crc64_rocksoft igc crc64 crc_t10dif usbcore
    crct10dif_generic ptp crct10dif_common usb_common pps_core
    [ 7679.200403] RIP: 0010:dev_watchdog+0x1ae/0x1f0
    [ 7679.210201] Code: 28 e9 53 ff ff ff 4c 89 e7 c6 05 06 42 b9 00 01 e8 17 d1 fb ff 44 89 e9 4c
    89 e6 48 c7 c7 40 ad fb 81 48 89 c2 e8 52 62 82 ff <0f> 0b e9 72 ff ff ff 65 8b 05 80 7d 7c 7e
    89 c0 48 0f a3 05 0a c1
    [ 7679.245438] RSP: 0018:ffa00000001f7d90 EFLAGS: 00010282
    [ 7679.256021] RAX: 0000000000000000 RBX: ff11000109938440 RCX: 0000000000000000
    [ 7679.268710] RDX: ff11000361e26cd8 RSI: ff11000361e1b880 RDI: ff11000361e1b880
    [ 7679.281314] RBP: ffa00000001f7da8 R08: ff1100035f8fffe8 R09: 0000000000027ffb
    [ 7679.293840] R10: 0000000000001f0a R11: ff1100035f840000 R12: ff11000109938000
    [ 7679.306276] R13: 0000000000000002 R14: dead000000000122 R15: ffa00000001f7e18
    [ 7679.318648] FS:  0000000000000000(0000) GS:ff11000361e00000(0000) knlGS:0000000000000000
    [ 7679.332064] CS:  0010 DS: 0000 ES: 0000 CR0: 0000000080050033
    [ 7679.342757] CR2: 00007ffff7fca168 CR3: 000000013b08a006 CR4: 0000000000471ef8
    [ 7679.354984] DR0: 0000000000000000 DR1: 0000000000000000 DR2: 0000000000000000
    [ 7679.367207] DR3: 0000000000000000 DR6: 00000000fffe07f0 DR7: 0000000000000400
    [ 7679.379370] PKRU: 55555554
    [ 7679.386446] Call Trace:
    [ 7679.393152]  <TASK>
    [ 7679.399363]  ? __pfx_dev_watchdog+0x10/0x10
    [ 7679.407870]  call_timer_fn+0x31/0x110
    [ 7679.415698]  expire_timers+0xb2/0x120
    [ 7679.423403]  run_timer_softirq+0x179/0x1e0
    [ 7679.431532]  ? __schedule+0x2b1/0x820
    [ 7679.439078]  __do_softirq+0xd1/0x295
    [ 7679.446426]  ? __pfx_smpboot_thread_fn+0x10/0x10
    [ 7679.454867]  run_ksoftirqd+0x22/0x30
    [ 7679.462058]  smpboot_thread_fn+0xb7/0x160
    [ 7679.469670]  kthread+0xcd/0xf0
    [ 7679.476097]  ? __pfx_kthread+0x10/0x10
    [ 7679.483211]  ret_from_fork+0x29/0x50
    [ 7679.490047]  </TASK>
    [ 7679.495204] ---[ end trace 0000000000000000 ]---
    [ 7679.503179] igc 0000:01:00.0 enp1s0: Register Dump
    [ 7679.511230] igc 0000:01:00.0 enp1s0: Register Name   Value
    [ 7679.519892] igc 0000:01:00.0 enp1s0: CTRL            181c0641
    [ 7679.528782] igc 0000:01:00.0 enp1s0: STATUS          40280683
    [ 7679.537551] igc 0000:01:00.0 enp1s0: CTRL_EXT        10000040
    [ 7679.546284] igc 0000:01:00.0 enp1s0: MDIC            180a3800
    [ 7679.554942] igc 0000:01:00.0 enp1s0: ICR             00000081
    [ 7679.563503] igc 0000:01:00.0 enp1s0: RCTL            04408022
    [ 7679.571963] igc 0000:01:00.0 enp1s0: RDLEN[0-3]      00001000 00001000 00001000 00001000
    [ 7679.583075] igc 0000:01:00.0 enp1s0: RDH[0-3]        00000068 000000b6 0000000f 00000031
    [ 7679.594162] igc 0000:01:00.0 enp1s0: RDT[0-3]        00000066 000000b2 0000000e 00000030
    [ 7679.605174] igc 0000:01:00.0 enp1s0: RXDCTL[0-3]     02040808 02040808 02040808 02040808
    [ 7679.616196] igc 0000:01:00.0 enp1s0: RDBAL[0-3]      1bb7c000 1bb7f000 1bb82000 0ef33000
    [ 7679.627242] igc 0000:01:00.0 enp1s0: RDBAH[0-3]      00000001 00000001 00000001 00000001
    [ 7679.638256] igc 0000:01:00.0 enp1s0: TCTL            a503f0fa
    [ 7679.646607] igc 0000:01:00.0 enp1s0: TDBAL[0-3]      2ba4a000 1bb6f000 1bb74000 1bb79000
    [ 7679.657609] igc 0000:01:00.0 enp1s0: TDBAH[0-3]      00000001 00000001 00000001 00000001
    [ 7679.668551] igc 0000:01:00.0 enp1s0: TDLEN[0-3]      00001000 00001000 00001000 00001000
    [ 7679.679470] igc 0000:01:00.0 enp1s0: TDH[0-3]        000000a7 0000002d 000000bf 000000d9
    [ 7679.690406] igc 0000:01:00.0 enp1s0: TDT[0-3]        000000a7 0000002d 000000bf 000000d9
    [ 7679.701264] igc 0000:01:00.0 enp1s0: TXDCTL[0-3]     02100108 02100108 02100108 02100108
    [ 7679.712123] igc 0000:01:00.0 enp1s0: Reset adapter
    [ 7683.085967] igc 0000:01:00.0 enp1s0: NIC Link is Up 1000 Mbps Full Duplex, Flow Control: RX/TX
    [ 8086.945561] ------------[ cut here ]------------
    Entering kdb (current=0xffffffff8220b200, pid 0) on processor 0
    Oops: (null) due to oops @ 0xffffffff81573888
    RIP: 0010:dql_completed+0x148/0x160
    Code: c9 00 48 89 57 58 e9 46 ff ff ff 45 85 e4 41 0f 95 c4 41 39 db 0f 95
    c1 41 84 cc 74 05 45 85 ed 78 0a 44 89 c1 e9 27 ff ff ff <0f> 0b 01 f6 44 89
    c1 29 f1 0f 48 ca eb 8c cc cc cc cc cc cc cc cc
    RSP: 0018:ffa0000000003e00 EFLAGS: 00010287
    RAX: 000000000000006c RBX: ffa0000003eb0f78 RCX: ff11000109938000
    RDX: 0000000000000003 RSI: 0000000000000160 RDI: ff110001002e9480
    RBP: ffa0000000003ed8 R08: ff110001002e93c0 R09: ffa0000000003d28
    R10: 0000000000007cc0 R11: 0000000000007c54 R12: 00000000ffffffd9
    R13: ff1100037039cb00 R14: 00000000ffffffd9 R15: ff1100037039c048
    FS:  0000000000000000(0000) GS:ff11000361e00000(0000) knlGS:0000000000000000
    CS:  0010 DS: 0000 ES: 0000 CR0: 0000000080050033
    CR2: 00007ffff7fca168 CR3: 000000013b08a003 CR4: 0000000000471ef8
    DR0: 0000000000000000 DR1: 0000000000000000 DR2: 0000000000000000
    DR3: 0000000000000000 DR6: 00000000fffe07f0 DR7: 0000000000000400
    PKRU: 55555554
    Call Trace:
     <IRQ>
     ? igc_poll+0x1a9/0x14d0 [igc]
     __napi_poll+0x2e/0x1b0
     net_rx_action+0x126/0x250
     __do_softirq+0xd1/0x295
     irq_exit_rcu+0xc5/0xf0
     common_interrupt+0x86/0xa0
     </IRQ>
     <TASK>
     asm_common_interrupt+0x27/0x40
    RIP: 0010:cpuidle_enter_state+0xd3/0x3e0
    Code: 73 f1 ff ff 49 89 c6 8b 05 e2 ca a7 00 85 c0 0f 8f b3 02 00 00 31 ff e8 1b
    de 75 ff 80 7d d7 00 0f 85 cd 01 00 00 fb 45 85 ff <0f> 88 fd 00 00 00 49 63 cf
    4c 2b 75 c8 48 8d 04 49 48 89 ca 48 8d
    RSP: 0018:ffffffff82203df0 EFLAGS: 00000202
    RAX: ff11000361e2a200 RBX: 0000000000000002 RCX: 000000000000001f
    RDX: 0000000000000000 RSI: 000000003cf3cf3d RDI: 0000000000000000
    RBP: ffffffff82203e28 R08: 0000075ae38471c8 R09: 0000000000000018
    R10: 000000000000031a R11: ffffffff8238dca0 R12: ffd1ffffff200000
    R13: ffffffff8238dca0 R14: 0000075ae38471c8 R15: 0000000000000002
     cpuidle_enter+0x2e/0x50
     call_cpuidle+0x23/0x40
     do_idle+0x1be/0x220
     cpu_startup_entry+0x20/0x30
     rest_init+0xb5/0xc0
     arch_call_rest_init+0xe/0x30
     start_kernel+0x448/0x760
     x86_64_start_kernel+0x109/0x150
     secondary_startup_64_no_verify+0xe0/0xeb
     </TASK>
    more>
    [0]kdb>
    
    [0]kdb>
    [0]kdb> go
    Catastrophic error detected
    kdb_continue_catastrophic=0, type go a second time if you really want to
    continue
    [0]kdb> go
    Catastrophic error detected
    kdb_continue_catastrophic=0, attempting to continue
    [ 8086.955689] refcount_t: underflow; use-after-free.
    [ 8086.955697] WARNING: CPU: 0 PID: 0 at lib/refcount.c:28 refcount_warn_saturate+0xc2/0x110
    [ 8086.955706] Modules linked in: xt_conntrack nft_chain_nat xt_MASQUERADE xt_addrtype nft_compat
    nf_tables nfnetlink br_netfilter bridge stp llc overlay dm_mod emrcha(PO) emriio(PO) rktpm(PO)
    cegbuf_mod(PO) patch_update(PO) se(PO) sgx_tgts(PO) mktme(PO) keylocker(PO) svtdx(PO)
    svfs_pci_hotplug(PO) vtd_mod(PO) davemem(PO) svmabort(PO) svindexio(PO) usbx2(PO) ehci_sched(PO)
    svheartbeat(PO) ioapic(PO) sv8259(PO) svintr(PO) lt(PO) pcierootport(PO) enginefw_mod(PO) ata(PO)
    smbus(PO) spiflash_cdf(PO) arden(PO) dsa_iax(PO) oobmsm_punit(PO) cpm(PO) svkdb(PO) ebg_pch(PO)
    pch(PO) sviotargets(PO) svbdf(PO) svmem(PO) svbios(PO) dram(PO) svtsc(PO) targets(PO) superio(PO)
    svkernel(PO) cswitch(PO) mcf(PO) pentiumIII_mod(PO) fs_svfs(PO) mdevdefdb(PO) svfs_os_services(O)
    ixgbe mdio mdio_devres libphy emeraldrapids_svdefs(PO) regsupport(O) libnvdimm nls_cp437
    snd_hda_codec_realtek snd_hda_codec_generic ledtrig_audio snd_hda_intel snd_intel_dspcfg
    snd_hda_codec snd_hwdep x86_pkg_temp_thermal snd_hda_core snd_pcm snd_timer isst_if_mbox_pci
    [ 8086.955751]  input_leds isst_if_mmio sg snd isst_if_common soundcore wmi button sad9(O) drm
    fuse backlight configfs efivarfs ip_tables x_tables vmd sdhci led_class rtl8150 r8152 hid_generic
    pegasus mmc_block usbhid mmc_core hid megaraid_sas ixgb igb i2c_algo_bit ice i40e hpsa
    scsi_transport_sas e1000e e1000 e100 ax88179_178a usbnet xhci_pci sd_mod xhci_hcd t10_pi
    crc32c_intel crc64_rocksoft igc crc64 crc_t10dif usbcore crct10dif_generic ptp crct10dif_common
    usb_common pps_core
    [ 8086.955784] RIP: 0010:refcount_warn_saturate+0xc2/0x110
    [ 8086.955788] Code: 01 e8 82 e7 b4 ff 0f 0b 5d c3 cc cc cc cc 80 3d 68 c6 eb 00 00 75 81
    48 c7 c7 a0 87 f6 81 c6 05 58 c6 eb 00 01 e8 5e e7 b4 ff <0f> 0b 5d c3 cc cc cc cc 80 3d
    42 c6 eb 00 00 0f 85 59 ff ff ff 48
    [ 8086.955790] RSP: 0018:ffa0000000003da0 EFLAGS: 00010286
    [ 8086.955793] RAX: 0000000000000000 RBX: ff1100011da40ee0 RCX: ff11000361e1b888
    [ 8086.955794] RDX: 00000000ffffffd8 RSI: 0000000000000027 RDI: ff11000361e1b880
    [ 8086.955795] RBP: ffa0000000003da0 R08: 80000000ffff9f45 R09: ffa0000000003d28
    [ 8086.955796] R10: ff1100035f840000 R11: 0000000000000028 R12: ff11000319ff8000
    [ 8086.955797] R13: ff1100011bb79d60 R14: 00000000ffffffd6 R15: ff1100037039cb00
    [ 8086.955798] FS:  0000000000000000(0000) GS:ff11000361e00000(0000) knlGS:0000000000000000
    [ 8086.955800] CS:  0010 DS: 0000 ES: 0000 CR0: 0000000080050033
    [ 8086.955801] CR2: 00007ffff7fca168 CR3: 000000013b08a003 CR4: 0000000000471ef8
    [ 8086.955803] DR0: 0000000000000000 DR1: 0000000000000000 DR2: 0000000000000000
    [ 8086.955803] DR3: 0000000000000000 DR6: 00000000fffe07f0 DR7: 0000000000000400
    [ 8086.955804] PKRU: 55555554
    [ 8086.955805] Call Trace:
    [ 8086.955806]  <IRQ>
    [ 8086.955808]  tcp_wfree+0x112/0x130
    [ 8086.955814]  skb_release_head_state+0x24/0xa0
    [ 8086.955818]  napi_consume_skb+0x9c/0x160
    [ 8086.955821]  igc_poll+0x5d8/0x14d0 [igc]
    [ 8086.955835]  __napi_poll+0x2e/0x1b0
    [ 8086.955839]  net_rx_action+0x126/0x250
    [ 8086.955843]  __do_softirq+0xd1/0x295
    [ 8086.955846]  irq_exit_rcu+0xc5/0xf0
    [ 8086.955851]  common_interrupt+0x86/0xa0
    [ 8086.955857]  </IRQ>
    [ 8086.955857]  <TASK>
    [ 8086.955858]  asm_common_interrupt+0x27/0x40
    [ 8086.955862] RIP: 0010:cpuidle_enter_state+0xd3/0x3e0
    [ 8086.955866] Code: 73 f1 ff ff 49 89 c6 8b 05 e2 ca a7 00 85 c0 0f 8f b3 02 00 00 31 ff e8
    1b de 75 ff 80 7d d7 00 0f 85 cd 01 00 00 fb 45 85 ff <0f> 88 fd 00 00 00 49 63 cf 4c 2b 75
    c8 48 8d 04 49 48 89 ca 48 8d
    [ 8086.955867] RSP: 0018:ffffffff82203df0 EFLAGS: 00000202
    [ 8086.955869] RAX: ff11000361e2a200 RBX: 0000000000000002 RCX: 000000000000001f
    [ 8086.955870] RDX: 0000000000000000 RSI: 000000003cf3cf3d RDI: 0000000000000000
    [ 8086.955871] RBP: ffffffff82203e28 R08: 0000075ae38471c8 R09: 0000000000000018
    [ 8086.955872] R10: 000000000000031a R11: ffffffff8238dca0 R12: ffd1ffffff200000
    [ 8086.955873] R13: ffffffff8238dca0 R14: 0000075ae38471c8 R15: 0000000000000002
    [ 8086.955875]  cpuidle_enter+0x2e/0x50
    [ 8086.955880]  call_cpuidle+0x23/0x40
    [ 8086.955884]  do_idle+0x1be/0x220
    [ 8086.955887]  cpu_startup_entry+0x20/0x30
    [ 8086.955889]  rest_init+0xb5/0xc0
    [ 8086.955892]  arch_call_rest_init+0xe/0x30
    [ 8086.955895]  start_kernel+0x448/0x760
    [ 8086.955898]  x86_64_start_kernel+0x109/0x150
    [ 8086.955900]  secondary_startup_64_no_verify+0xe0/0xeb
    [ 8086.955904]  </TASK>
    [ 8086.955904] ---[ end trace 0000000000000000 ]---
    [ 8086.955912] ------------[ cut here ]------------
    [ 8086.955913] kernel BUG at lib/dynamic_queue_limits.c:27!
    [ 8086.955918] invalid opcode: 0000 [#1] SMP
    [ 8086.955922] RIP: 0010:dql_completed+0x148/0x160
    [ 8086.955925] Code: c9 00 48 89 57 58 e9 46 ff ff ff 45 85 e4 41 0f 95 c4 41 39 db
    0f 95 c1 41 84 cc 74 05 45 85 ed 78 0a 44 89 c1 e9 27 ff ff ff <0f> 0b 01 f6 44 89
    c1 29 f1 0f 48 ca eb 8c cc cc cc cc cc cc cc cc
    [ 8086.955927] RSP: 0018:ffa0000000003e00 EFLAGS: 00010287
    [ 8086.955928] RAX: 000000000000006c RBX: ffa0000003eb0f78 RCX: ff11000109938000
    [ 8086.955929] RDX: 0000000000000003 RSI: 0000000000000160 RDI: ff110001002e9480
    [ 8086.955930] RBP: ffa0000000003ed8 R08: ff110001002e93c0 R09: ffa0000000003d28
    [ 8086.955931] R10: 0000000000007cc0 R11: 0000000000007c54 R12: 00000000ffffffd9
    [ 8086.955932] R13: ff1100037039cb00 R14: 00000000ffffffd9 R15: ff1100037039c048
    [ 8086.955933] FS:  0000000000000000(0000) GS:ff11000361e00000(0000) knlGS:0000000000000000
    [ 8086.955934] CS:  0010 DS: 0000 ES: 0000 CR0: 0000000080050033
    [ 8086.955935] CR2: 00007ffff7fca168 CR3: 000000013b08a003 CR4: 0000000000471ef8
    [ 8086.955936] DR0: 0000000000000000 DR1: 0000000000000000 DR2: 0000000000000000
    [ 8086.955937] DR3: 0000000000000000 DR6: 00000000fffe07f0 DR7: 0000000000000400
    [ 8086.955938] PKRU: 55555554
    [ 8086.955939] Call Trace:
    [ 8086.955939]  <IRQ>
    [ 8086.955940]  ? igc_poll+0x1a9/0x14d0 [igc]
    [ 8086.955949]  __napi_poll+0x2e/0x1b0
    [ 8086.955952]  net_rx_action+0x126/0x250
    [ 8086.955956]  __do_softirq+0xd1/0x295
    [ 8086.955958]  irq_exit_rcu+0xc5/0xf0
    [ 8086.955961]  common_interrupt+0x86/0xa0
    [ 8086.955964]  </IRQ>
    [ 8086.955965]  <TASK>
    [ 8086.955965]  asm_common_interrupt+0x27/0x40
    [ 8086.955968] RIP: 0010:cpuidle_enter_state+0xd3/0x3e0
    [ 8086.955971] Code: 73 f1 ff ff 49 89 c6 8b 05 e2 ca a7 00 85 c0 0f 8f b3 02 00 00
    31 ff e8 1b de 75 ff 80 7d d7 00 0f 85 cd 01 00 00 fb 45 85 ff <0f> 88 fd 00 00 00
    49 63 cf 4c 2b 75 c8 48 8d 04 49 48 89 ca 48 8d
    [ 8086.955972] RSP: 0018:ffffffff82203df0 EFLAGS: 00000202
    [ 8086.955973] RAX: ff11000361e2a200 RBX: 0000000000000002 RCX: 000000000000001f
    [ 8086.955974] RDX: 0000000000000000 RSI: 000000003cf3cf3d RDI: 0000000000000000
    [ 8086.955974] RBP: ffffffff82203e28 R08: 0000075ae38471c8 R09: 0000000000000018
    [ 8086.955975] R10: 000000000000031a R11: ffffffff8238dca0 R12: ffd1ffffff200000
    [ 8086.955976] R13: ffffffff8238dca0 R14: 0000075ae38471c8 R15: 0000000000000002
    [ 8086.955978]  cpuidle_enter+0x2e/0x50
    [ 8086.955981]  call_cpuidle+0x23/0x40
    [ 8086.955984]  do_idle+0x1be/0x220
    [ 8086.955985]  cpu_startup_entry+0x20/0x30
    [ 8086.955987]  rest_init+0xb5/0xc0
    [ 8086.955990]  arch_call_rest_init+0xe/0x30
    [ 8086.955992]  start_kernel+0x448/0x760
    [ 8086.955994]  x86_64_start_kernel+0x109/0x150
    [ 8086.955996]  secondary_startup_64_no_verify+0xe0/0xeb
    [ 8086.955998]  </TASK>
    [ 8086.955999] Modules linked in: xt_conntrack nft_chain_nat xt_MASQUERADE xt_addrtype
    nft_compat nf_tables nfnetlink br_netfilter bridge stp llc overlay dm_mod emrcha(PO) emriio(PO)
    rktpm(PO) cegbuf_mod(PO) patch_update(PO) se(PO) sgx_tgts(PO) mktme(PO) keylocker(PO) svtdx(PO)
    svfs_pci_hotplug(PO) vtd_mod(PO) davemem(PO) svmabort(PO) svindexio(PO) usbx2(PO) ehci_sched(PO)
    svheartbeat(PO) ioapic(PO) sv8259(PO) svintr(PO) lt(PO) pcierootport(PO) enginefw_mod(PO) ata(PO)
    smbus(PO) spiflash_cdf(PO) arden(PO) dsa_iax(PO) oobmsm_punit(PO) cpm(PO) svkdb(PO) ebg_pch(PO)
    pch(PO) sviotargets(PO) svbdf(PO) svmem(PO) svbios(PO) dram(PO) svtsc(PO) targets(PO) superio(PO)
    svkernel(PO) cswitch(PO) mcf(PO) pentiumIII_mod(PO) fs_svfs(PO) mdevdefdb(PO) svfs_os_services(O)
    ixgbe mdio mdio_devres libphy emeraldrapids_svdefs(PO) regsupport(O) libnvdimm nls_cp437
    snd_hda_codec_realtek snd_hda_codec_generic ledtrig_audio snd_hda_intel snd_intel_dspcfg
    snd_hda_codec snd_hwdep x86_pkg_temp_thermal snd_hda_core snd_pcm snd_timer isst_if_mbox_pci
    [ 8086.956029]  input_leds isst_if_mmio sg snd isst_if_common soundcore wmi button sad9(O) drm
    fuse backlight configfs efivarfs ip_tables x_tables vmd sdhci led_class rtl8150 r8152 hid_generic
    pegasus mmc_block usbhid mmc_core hid megaraid_sas ixgb igb i2c_algo_bit ice i40e hpsa
    scsi_transport_sas e1000e e1000 e100 ax88179_178a usbnet xhci_pci sd_mod xhci_hcd t10_pi
    crc32c_intel crc64_rocksoft igc crc64 crc_t10dif usbcore crct10dif_generic ptp crct10dif_common
    usb_common pps_core
    [16762.543675] INFO: NMI handler (kgdb_nmi_handler) took too long to run: 8675587.593 msecs
    [16762.543678] INFO: NMI handler (kgdb_nmi_handler) took too long to run: 8675587.595 msecs
    [16762.543673] INFO: NMI handler (kgdb_nmi_handler) took too long to run: 8675587.495 msecs
    [16762.543679] INFO: NMI handler (kgdb_nmi_handler) took too long to run: 8675587.599 msecs
    [16762.543678] INFO: NMI handler (kgdb_nmi_handler) took too long to run: 8675587.598 msecs
    [16762.543690] INFO: NMI handler (kgdb_nmi_handler) took too long to run: 8675587.605 msecs
    [16762.543684] INFO: NMI handler (kgdb_nmi_handler) took too long to run: 8675587.599 msecs
    [16762.543693] INFO: NMI handler (kgdb_nmi_handler) took too long to run: 8675587.613 msecs
    [16762.543784] ---[ end trace 0000000000000000 ]---
    [16762.849099] RIP: 0010:dql_completed+0x148/0x160
    PANIC: Fatal exception in interrupt
    
    Fixes: 9b275176270e ("igc: Add ndo_tx_timeout support")
    Tested-by: Alejandra Victoria Alcaraz <alejandra.victoria.alcaraz@intel.com>
    Signed-off-by: Muhammad Husaini Zulkifli <muhammad.husaini.zulkifli@intel.com>
    Acked-by: Sasha Neftin <sasha.neftin@intel.com>
    Tested-by: Naama Meir <naamax.meir@linux.intel.com>
    Signed-off-by: Tony Nguyen <anthony.l.nguyen@intel.com>
    Reviewed-by: Simon Horman <simon.horman@corigine.com>
    Signed-off-by: David S. Miller <davem@davemloft.net>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 79f44709aa7a744fbfbadd4aef678443290c6991
Author: Lin Ma <linma@zju.edu.cn>
Date:   Sun Jul 23 16:02:05 2023 +0800

    macvlan: add forgotten nla_policy for IFLA_MACVLAN_BC_CUTOFF
    
    [ Upstream commit 55cef78c244d0d076f5a75a35530ca63c92f4426 ]
    
    The previous commit 954d1fa1ac93 ("macvlan: Add netlink attribute for
    broadcast cutoff") added one additional attribute named
    IFLA_MACVLAN_BC_CUTOFF to allow broadcast cutfoff.
    
    However, it forgot to describe the nla_policy at macvlan_policy
    (drivers/net/macvlan.c). Hence, this suppose NLA_S32 (4 bytes) integer
    can be faked as empty (0 bytes) by a malicious user, which could leads
    to OOB in heap just like CVE-2023-3773.
    
    To fix it, this commit just completes the nla_policy description for
    IFLA_MACVLAN_BC_CUTOFF. This enforces the length check and avoids the
    potential OOB read.
    
    Fixes: 954d1fa1ac93 ("macvlan: Add netlink attribute for broadcast cutoff")
    Signed-off-by: Lin Ma <linma@zju.edu.cn>
    Reviewed-by: Simon Horman <simon.horman@corigine.com>
    Link: https://lore.kernel.org/r/20230723080205.3715164-1-linma@zju.edu.cn
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 70539e9bc0e655fa71a69b0380b1476a4148fce4
Author: Kirill A. Shutemov <kirill.shutemov@linux.intel.com>
Date:   Tue Jul 25 02:03:29 2023 +0300

    x86/traps: Fix load_unaligned_zeropad() handling for shared TDX memory
    
    [ Upstream commit 9f9116406120638b4d8db3831ffbc430dd2e1e95 ]
    
    Commit c4e34dd99f2e ("x86: simplify load_unaligned_zeropad()
    implementation") changes how exceptions around load_unaligned_zeropad()
    handled.  The kernel now uses the fault_address in fixup_exception() to
    verify the address calculations for the load_unaligned_zeropad().
    
    It works fine for #PF, but breaks on #VE since no fault address is
    passed down to fixup_exception().
    
    Propagating ve_info.gla down to fixup_exception() resolves the issue.
    
    See commit 1e7769653b06 ("x86/tdx: Handle load_unaligned_zeropad()
    page-cross to a shared page") for more context.
    
    Signed-off-by: Kirill A. Shutemov <kirill.shutemov@linux.intel.com>
    Reported-by: Michael Kelley <mikelley@microsoft.com>
    Fixes: c4e34dd99f2e ("x86: simplify load_unaligned_zeropad() implementation")
    Acked-by: Dave Hansen <dave.hansen@linux.intel.com>
    Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 33f73e215d8f66120d20dea2ca0e9b135ec011f6
Author: Maxim Mikityanskiy <maxtram95@gmail.com>
Date:   Fri Jul 21 17:54:23 2023 +0300

    platform/x86: msi-laptop: Fix rfkill out-of-sync on MSI Wind U100
    
    [ Upstream commit ad084a6d99bc182bf109c190c808e2ea073ec57b ]
    
    Only the HW rfkill state is toggled on laptops with quirks->ec_read_only
    (so far only MSI Wind U90/U100). There are, however, a few issues with
    the implementation:
    
    1. The initial HW state is always unblocked, regardless of the actual
       state on boot, because msi_init_rfkill only sets the SW state,
       regardless of ec_read_only.
    
    2. The initial SW state corresponds to the actual state on boot, but it
       can't be changed afterwards, because set_device_state returns
       -EOPNOTSUPP. It confuses the userspace, making Wi-Fi and/or Bluetooth
       unusable if it was blocked on boot, and breaking the airplane mode if
       the rfkill was unblocked on boot.
    
    Address the above issues by properly initializing the HW state on
    ec_read_only laptops and by allowing the userspace to toggle the SW
    state. Don't set the SW state ourselves and let the userspace fully
    control it. Toggling the SW state is a no-op, however, it allows the
    userspace to properly toggle the airplane mode. The actual SW radio
    disablement is handled by the corresponding rtl818x_pci and btusb
    drivers that have their own rfkills.
    
    Tested on MSI Wind U100 Plus, BIOS ver 1.0G, EC ver 130.
    
    Fixes: 0816392b97d4 ("msi-laptop: merge quirk tables to one")
    Fixes: 0de6575ad0a8 ("msi-laptop: Add MSI Wind U90/U100 support")
    Signed-off-by: Maxim Mikityanskiy <maxtram95@gmail.com>
    Link: https://lore.kernel.org/r/20230721145423.161057-1-maxtram95@gmail.com
    Reviewed-by: Hans de Goede <hdegoede@redhat.com>
    Signed-off-by: Hans de Goede <hdegoede@redhat.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 7c83b2f01655dfd369cbf6fcb7d3edc25b529046
Author: Vincent Whitchurch <vincent.whitchurch@axis.com>
Date:   Fri Jul 21 15:39:20 2023 +0200

    net: stmmac: Apply redundant write work around on 4.xx too
    
    [ Upstream commit 284779dbf4e98753458708783af8c35630674a21 ]
    
    commit a3a57bf07de23fe1ff779e0fdf710aa581c3ff73 ("net: stmmac: work
    around sporadic tx issue on link-up") worked around a problem with TX
    sometimes not working after a link-up by avoiding a redundant write to
    MAC_CTRL_REG (aka GMAC_CONFIG), since the IP appeared to have problems
    with handling multiple writes to that register in some cases.
    
    That commit however only added the work around to dwmac_lib.c (apart
    from the common code in stmmac_main.c), but my systems with version
    4.21a of the IP exhibit the same problem, so add the work around to
    dwmac4_lib.c too.
    
    Fixes: a3a57bf07de2 ("net: stmmac: work around sporadic tx issue on link-up")
    Signed-off-by: Vincent Whitchurch <vincent.whitchurch@axis.com>
    Reviewed-by: Simon Horman <simon.horman@corigine.com>
    Link: https://lore.kernel.org/r/20230721-stmmac-tx-workaround-v1-1-9411cbd5ee07@axis.com
    Signed-off-by: Paolo Abeni <pabeni@redhat.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit f3ff2a5cca186d79c65e8219ee0e5020eb328041
Author: Suman Ghosh <sumang@marvell.com>
Date:   Fri Jul 21 11:42:22 2023 +0530

    octeontx2-af: Fix hash extraction enable configuration
    
    [ Upstream commit 4e62c99d71e56817c934caa2a709a775c8cee078 ]
    
    As of today, hash extraction support is enabled for all the silicons.
    Because of which we are facing initialization issues when the silicon
    does not support hash extraction. During creation of the hardware
    parsing table for IPv6 address, we need to consider if hash extraction
    is enabled then extract only 32 bit, otherwise 128 bit needs to be
    extracted. This patch fixes the issue and configures the hardware parser
    based on the availability of the feature.
    
    Fixes: a95ab93550d3 ("octeontx2-af: Use hashed field in MCAM key")
    Signed-off-by: Suman Ghosh <sumang@marvell.com>
    Reviewed-by: Simon Horman <simon.horman@corigine.com>
    Link: https://lore.kernel.org/r/20230721061222.2632521-1-sumang@marvell.com
    Signed-off-by: Paolo Abeni <pabeni@redhat.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 213055a66c2c498e8a716caac6473cfe27a495c4
Author: Hangbin Liu <liuhangbin@gmail.com>
Date:   Fri Jul 21 12:03:56 2023 +0800

    team: reset team's flags when down link is P2P device
    
    [ Upstream commit fa532bee17d15acf8bba4bc8e2062b7a093ba801 ]
    
    When adding a point to point downlink to team device, we neglected to reset
    the team's flags, which were still using flags like BROADCAST and
    MULTICAST. Consequently, this would initiate ARP/DAD for P2P downlink
    interfaces, such as when adding a GRE device to team device. Fix this by
    remove multicast/broadcast flags and add p2p and noarp flags.
    
    After removing the none ethernet interface and adding an ethernet interface
    to team, we need to reset team interface flags. Unlike bonding interface,
    team do not need restore IFF_MASTER, IFF_SLAVE flags.
    
    Reported-by: Liang Li <liali@redhat.com>
    Closes: https://bugzilla.redhat.com/show_bug.cgi?id=2221438
    Fixes: 1d76efe1577b ("team: add support for non-ethernet devices")
    Signed-off-by: Hangbin Liu <liuhangbin@gmail.com>
    Signed-off-by: Paolo Abeni <pabeni@redhat.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 84d0bb176d851c2bc127b95d6a5a211d6c9641f8
Author: Hangbin Liu <liuhangbin@gmail.com>
Date:   Fri Jul 21 12:03:55 2023 +0800

    bonding: reset bond's flags when down link is P2P device
    
    [ Upstream commit da19a2b967cf1e2c426f50d28550d1915214a81d ]
    
    When adding a point to point downlink to the bond, we neglected to reset
    the bond's flags, which were still using flags like BROADCAST and
    MULTICAST. Consequently, this would initiate ARP/DAD for P2P downlink
    interfaces, such as when adding a GRE device to the bonding.
    
    To address this issue, let's reset the bond's flags for P2P interfaces.
    
    Before fix:
    7: gre0@NONE: <POINTOPOINT,NOARP,SLAVE,UP,LOWER_UP> mtu 1500 qdisc noqueue master bond0 state UNKNOWN group default qlen 1000
        link/gre6 2006:70:10::1 peer 2006:70:10::2 permaddr 167f:18:f188::
    8: bond0: <BROADCAST,MULTICAST,MASTER,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group default qlen 1000
        link/gre6 2006:70:10::1 brd 2006:70:10::2
        inet6 fe80::200:ff:fe00:0/64 scope link
           valid_lft forever preferred_lft forever
    
    After fix:
    7: gre0@NONE: <POINTOPOINT,NOARP,SLAVE,UP,LOWER_UP> mtu 1500 qdisc noqueue master bond2 state UNKNOWN group default qlen 1000
        link/gre6 2006:70:10::1 peer 2006:70:10::2 permaddr c29e:557a:e9d9::
    8: bond0: <POINTOPOINT,NOARP,MASTER,UP,LOWER_UP> mtu 1500 qdisc noqueue state UP group default qlen 1000
        link/gre6 2006:70:10::1 peer 2006:70:10::2
        inet6 fe80::1/64 scope link
           valid_lft forever preferred_lft forever
    
    Reported-by: Liang Li <liali@redhat.com>
    Closes: https://bugzilla.redhat.com/show_bug.cgi?id=2221438
    Fixes: 872254dd6b1f ("net/bonding: Enable bonding to enslave non ARPHRD_ETHER")
    Signed-off-by: Hangbin Liu <liuhangbin@gmail.com>
    Signed-off-by: Paolo Abeni <pabeni@redhat.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 5a36ae715590cc0bf6b06b618ca7c0bfc6a53c31
Author: Jedrzej Jagielski <jedrzej.jagielski@intel.com>
Date:   Fri Jul 21 08:58:54 2023 -0700

    ice: Fix memory management in ice_ethtool_fdir.c
    
    [ Upstream commit a3336056504d780590ac6d6ac94fbba829994594 ]
    
    Fix ethtool FDIR logic to not use memory after its release.
    In the ice_ethtool_fdir.c file there are 2 spots where code can
    refer to pointers which may be missing.
    
    In the ice_cfg_fdir_xtrct_seq() function seg may be freed but
    even then may be still used by memcpy(&tun_seg[1], seg, sizeof(*seg)).
    
    In the ice_add_fdir_ethtool() function struct ice_fdir_fltr *input
    may first fail to be added via ice_fdir_update_list_entry() but then
    may be deleted by ice_fdir_update_list_entry.
    
    Terminate in both cases when the returned value of the previous
    operation is other than 0, free memory and don't use it anymore.
    
    Reported-by: Michal Schmidt <mschmidt@redhat.com>
    Link: https://bugzilla.redhat.com/show_bug.cgi?id=2208423
    Fixes: cac2a27cd9ab ("ice: Support IPv4 Flow Director filters")
    Reviewed-by: Przemek Kitszel <przemyslaw.kitszel@intel.com>
    Signed-off-by: Jedrzej Jagielski <jedrzej.jagielski@intel.com>
    Reviewed-by: Leon Romanovsky <leonro@nvidia.com>
    Tested-by: Pucha Himasekhar Reddy <himasekharx.reddy.pucha@intel.com> (A Contingent worker at Intel)
    Signed-off-by: Tony Nguyen <anthony.l.nguyen@intel.com>
    Link: https://lore.kernel.org/r/20230721155854.1292805-1-anthony.l.nguyen@intel.com
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 1e50c11ed44e28a57c6215a5e7643ae85c6297fa
Author: Stewart Smith <trawets@amazon.com>
Date:   Fri Jul 21 15:24:10 2023 -0700

    tcp: Reduce chance of collisions in inet6_hashfn().
    
    [ Upstream commit d11b0df7ddf1831f3e170972f43186dad520bfcc ]
    
    For both IPv4 and IPv6 incoming TCP connections are tracked in a hash
    table with a hash over the source & destination addresses and ports.
    However, the IPv6 hash is insufficient and can lead to a high rate of
    collisions.
    
    The IPv6 hash used an XOR to fit everything into the 96 bits for the
    fast jenkins hash, meaning it is possible for an external entity to
    ensure the hash collides, thus falling back to a linear search in the
    bucket, which is slow.
    
    We take the approach of hash the full length of IPv6 address in
    __ipv6_addr_jhash() so that all users can benefit from a more secure
    version.
    
    While this may look like it adds overhead, the reality of modern CPUs
    means that this is unmeasurable in real world scenarios.
    
    In simulating with llvm-mca, the increase in cycles for the hashing
    code was ~16 cycles on Skylake (from a base of ~155), and an extra ~9
    on Nehalem (base of ~173).
    
    In commit dd6d2910c5e0 ("netfilter: conntrack: switch to siphash")
    netfilter switched from a jenkins hash to a siphash, but even the faster
    hsiphash is a more significant overhead (~20-30%) in some preliminary
    testing.  So, in this patch, we keep to the more conservative approach to
    ensure we don't add much overhead per SYN.
    
    In testing, this results in a consistently even spread across the
    connection buckets.  In both testing and real-world scenarios, we have
    not found any measurable performance impact.
    
    Fixes: 08dcdbf6a7b9 ("ipv6: use a stronger hash for tcp")
    Signed-off-by: Stewart Smith <trawets@amazon.com>
    Signed-off-by: Samuel Mendoza-Jonas <samjonas@amazon.com>
    Suggested-by: Eric Dumazet <edumazet@google.com>
    Signed-off-by: Kuniyuki Iwashima <kuniyu@amazon.com>
    Reviewed-by: Eric Dumazet <edumazet@google.com>
    Link: https://lore.kernel.org/r/20230721222410.17914-1-kuniyu@amazon.com
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 6fe0d14c767527c4129c752628b43ba492530b69
Author: Wei Fang <wei.fang@nxp.com>
Date:   Fri Jul 21 16:35:59 2023 +0800

    net: fec: avoid tx queue timeout when XDP is enabled
    
    [ Upstream commit bb7a0156365dffe2fcd63e2051145fbe4f8908b4 ]
    
    According to the implementation of XDP of FEC driver, the XDP path
    shares the transmit queues with the kernel network stack, so it is
    possible to lead to a tx timeout event when XDP uses the tx queue
    pretty much exclusively. And this event will cause the reset of the
    FEC hardware.
    To avoid timeout in this case, we use the txq_trans_cond_update()
    interface to update txq->trans_start to jiffies so that watchdog
    won't generate a transmit timeout warning.
    
    Fixes: 6d6b39f180b8 ("net: fec: add initial XDP support")
    Signed-off-by: Wei Fang <wei.fang@nxp.com>
    Link: https://lore.kernel.org/r/20230721083559.2857312-1-wei.fang@nxp.com
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit e9f329d943f2fe0e72ffe0c90b40f56e7de6837c
Author: Maciej Żenczykowski <maze@google.com>
Date:   Thu Jul 20 09:00:22 2023 -0700

    ipv6 addrconf: fix bug where deleting a mngtmpaddr can create a new temporary address
    
    [ Upstream commit 69172f0bcb6a09110c5d2a6d792627f5095a9018 ]
    
    currently on 6.4 net/main:
    
      # ip link add dummy1 type dummy
      # echo 1 > /proc/sys/net/ipv6/conf/dummy1/use_tempaddr
      # ip link set dummy1 up
      # ip -6 addr add 2000::1/64 mngtmpaddr dev dummy1
      # ip -6 addr show dev dummy1
    
      11: dummy1: <BROADCAST,NOARP,UP,LOWER_UP> mtu 1500 qdisc noqueue state UNKNOWN group default qlen 1000
          inet6 2000::44f3:581c:8ca:3983/64 scope global temporary dynamic
             valid_lft 604800sec preferred_lft 86172sec
          inet6 2000::1/64 scope global mngtmpaddr
             valid_lft forever preferred_lft forever
          inet6 fe80::e8a8:a6ff:fed5:56d4/64 scope link
             valid_lft forever preferred_lft forever
    
      # ip -6 addr del 2000::44f3:581c:8ca:3983/64 dev dummy1
    
      (can wait a few seconds if you want to, the above delete isn't [directly] the problem)
    
      # ip -6 addr show dev dummy1
    
      11: dummy1: <BROADCAST,NOARP,UP,LOWER_UP> mtu 1500 qdisc noqueue state UNKNOWN group default qlen 1000
          inet6 2000::1/64 scope global mngtmpaddr
             valid_lft forever preferred_lft forever
          inet6 fe80::e8a8:a6ff:fed5:56d4/64 scope link
             valid_lft forever preferred_lft forever
    
      # ip -6 addr del 2000::1/64 mngtmpaddr dev dummy1
      # ip -6 addr show dev dummy1
    
      11: dummy1: <BROADCAST,NOARP,UP,LOWER_UP> mtu 1500 qdisc noqueue state UNKNOWN group default qlen 1000
          inet6 2000::81c9:56b7:f51a:b98f/64 scope global temporary dynamic
             valid_lft 604797sec preferred_lft 86169sec
          inet6 fe80::e8a8:a6ff:fed5:56d4/64 scope link
             valid_lft forever preferred_lft forever
    
    This patch prevents this new 'global temporary dynamic' address from being
    created by the deletion of the related (same subnet prefix) 'mngtmpaddr'
    (which is triggered by there already being no temporary addresses).
    
    Cc: Jiri Pirko <jiri@resnulli.us>
    Fixes: 53bd67491537 ("ipv6 addrconf: introduce IFA_F_MANAGETEMPADDR to tell kernel to manage temporary addresses")
    Reported-by: Xiao Ma <xiaom@google.com>
    Signed-off-by: Maciej Żenczykowski <maze@google.com>
    Reviewed-by: David Ahern <dsahern@kernel.org>
    Link: https://lore.kernel.org/r/20230720160022.1887942-1-maze@google.com
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit e92b177161f17375bc275d3b70382294a1390211
Author: Yuanjun Gong <ruc_gongyuanjun@163.com>
Date:   Thu Jul 20 22:42:19 2023 +0800

    ethernet: atheros: fix return value check in atl1e_tso_csum()
    
    [ Upstream commit 69a184f7a372aac588babfb0bd681aaed9779f5b ]
    
    in atl1e_tso_csum, it should check the return value of pskb_trim(),
    and return an error code if an unexpected value is returned
    by pskb_trim().
    
    Fixes: a6a5325239c2 ("atl1e: Atheros L1E Gigabit Ethernet driver")
    Signed-off-by: Yuanjun Gong <ruc_gongyuanjun@163.com>
    Reviewed-by: Simon Horman <simon.horman@corigine.com>
    Link: https://lore.kernel.org/r/20230720144219.39285-1-ruc_gongyuanjun@163.com
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 2111337afeb77730f5bc3bfb419171fe3c446ad7
Author: Yuanjun Gong <ruc_gongyuanjun@163.com>
Date:   Sat Jul 22 22:25:11 2023 +0800

    atheros: fix return value check in atl1_tso()
    
    [ Upstream commit ed96824b71ed67664390890441b229423a25317f ]
    
    in atl1_tso(), it should check the return value of pskb_trim(),
    and return an error code if an unexpected value is returned
    by pskb_trim().
    
    Fixes: 401c0aabec4b ("atl1: simplify tx packet descriptor")
    Signed-off-by: Yuanjun Gong <ruc_gongyuanjun@163.com>
    Link: https://lore.kernel.org/r/20230722142511.12448-1-ruc_gongyuanjun@163.com
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit ce69eac840db0b559994dc4290fce3d7c0d7bccd
Author: Harshit Mogalapalli <harshit.m.mogalapalli@oracle.com>
Date:   Fri Jul 21 02:05:55 2023 -0700

    phy: hisilicon: Fix an out of bounds check in hisi_inno_phy_probe()
    
    [ Upstream commit 13c088cf3657d70893d75cf116be937f1509cc0f ]
    
    The size of array 'priv->ports[]' is INNO_PHY_PORT_NUM.
    
    In the for loop, 'i' is used as the index for array 'priv->ports[]'
    with a check (i > INNO_PHY_PORT_NUM) which indicates that
    INNO_PHY_PORT_NUM is allowed value for 'i' in the same loop.
    
    This > comparison needs to be changed to >=, otherwise it potentially leads
    to an out of bounds write on the next iteration through the loop
    
    Fixes: ba8b0ee81fbb ("phy: add inno-usb2-phy driver for hi3798cv200 SoC")
    Reported-by: Dan Carpenter <dan.carpenter@linaro.org>
    Signed-off-by: Harshit Mogalapalli <harshit.m.mogalapalli@oracle.com>
    Link: https://lore.kernel.org/r/20230721090558.3588613-1-harshit.m.mogalapalli@oracle.com
    Signed-off-by: Vinod Koul <vkoul@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit bc1e4f99e2234de619ed780943ccafe6277d882d
Author: Jiri Benc <jbenc@redhat.com>
Date:   Fri Jul 21 16:30:47 2023 +0200

    vxlan: fix GRO with VXLAN-GPE
    
    [ Upstream commit b0b672c4d0957e5897685667fc848132b8bd2d71 ]
    
    In VXLAN-GPE, there may not be an Ethernet header following the VXLAN
    header. But in GRO, the vxlan driver calls eth_gro_receive
    unconditionally, which means the following header is incorrectly parsed
    as Ethernet.
    
    Introduce GPE specific GRO handling.
    
    For better performance, do not check for GPE during GRO but rather
    install a different set of functions at setup time.
    
    Fixes: e1e5314de08ba ("vxlan: implement GPE")
    Reported-by: Paolo Abeni <pabeni@redhat.com>
    Signed-off-by: Jiri Benc <jbenc@redhat.com>
    Signed-off-by: David S. Miller <davem@davemloft.net>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit c3a497decbeea7527f4bde23b20e447913101938
Author: Jiri Benc <jbenc@redhat.com>
Date:   Fri Jul 21 16:30:46 2023 +0200

    vxlan: generalize vxlan_parse_gpe_hdr and remove unused args
    
    [ Upstream commit 17a0a64448b568442a101de09575f81ffdc45d15 ]
    
    The vxlan_parse_gpe_hdr function extracts the next protocol value from
    the GPE header and marks GPE bits as parsed.
    
    In order to be used in the next patch, split the function into protocol
    extraction and bit marking. The bit marking is meaningful only in
    vxlan_rcv; move it directly there.
    
    Rename the function to vxlan_parse_gpe_proto to reflect what it now
    does. Remove unused arguments skb and vxflags. Move the function earlier
    in the file to allow it to be called from more places in the next patch.
    
    Signed-off-by: Jiri Benc <jbenc@redhat.com>
    Signed-off-by: David S. Miller <davem@davemloft.net>
    Stable-dep-of: b0b672c4d095 ("vxlan: fix GRO with VXLAN-GPE")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 3b0f05b8218a8a26fa037088a266bb7fe4c4b84a
Author: Jiri Benc <jbenc@redhat.com>
Date:   Thu Jul 20 11:05:56 2023 +0200

    vxlan: calculate correct header length for GPE
    
    [ Upstream commit 94d166c5318c6edd1e079df8552233443e909c33 ]
    
    VXLAN-GPE does not add an extra inner Ethernet header. Take that into
    account when calculating header length.
    
    This causes problems in skb_tunnel_check_pmtu, where incorrect PMTU is
    cached.
    
    In the collect_md mode (which is the only mode that VXLAN-GPE
    supports), there's no magic auto-setting of the tunnel interface MTU.
    It can't be, since the destination and thus the underlying interface
    may be different for each packet.
    
    So, the administrator is responsible for setting the correct tunnel
    interface MTU. Apparently, the administrators are capable enough to
    calculate that the maximum MTU for VXLAN-GPE is (their_lower_MTU - 36).
    They set the tunnel interface MTU to 1464. If you run a TCP stream over
    such interface, it's then segmented according to the MTU 1464, i.e.
    producing 1514 bytes frames. Which is okay, this still fits the lower
    MTU.
    
    However, skb_tunnel_check_pmtu (called from vxlan_xmit_one) uses 50 as
    the header size and thus incorrectly calculates the frame size to be
    1528. This leads to ICMP too big message being generated (locally),
    PMTU of 1450 to be cached and the TCP stream to be resegmented.
    
    The fix is to use the correct actual header size, especially for
    skb_tunnel_check_pmtu calculation.
    
    Fixes: e1e5314de08ba ("vxlan: implement GPE")
    Signed-off-by: Jiri Benc <jbenc@redhat.com>
    Reviewed-by: Simon Horman <simon.horman@corigine.com>
    Signed-off-by: David S. Miller <davem@davemloft.net>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 4bf9ced9c06b75edea2b22fd86cdfe4a478ee437
Author: Jijie Shao <shaojijie@huawei.com>
Date:   Thu Jul 20 10:05:10 2023 +0800

    net: hns3: fix wrong bw weight of disabled tc issue
    
    [ Upstream commit 882481b1c55fc44861d7e2d54b4e0936b1b39f2c ]
    
    In dwrr mode, the default bandwidth weight of disabled tc is set to 0.
    If the bandwidth weight is 0, the mode will change to sp.
    Therefore, disabled tc default bandwidth weight need changed to 1,
    and 0 is returned when query the bandwidth weight of disabled tc.
    In addition, driver need stop configure bandwidth weight if tc is disabled.
    
    Fixes: 848440544b41 ("net: hns3: Add support of TX Scheduler & Shaper to HNS3 driver")
    Signed-off-by: Jie Wang <wangjie125@huawei.com>
    Signed-off-by: Jijie Shao <shaojijie@huawei.com>
    Signed-off-by: David S. Miller <davem@davemloft.net>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 7a0eab957136201e34c462ce341171f5d7041a9e
Author: Jijie Shao <shaojijie@huawei.com>
Date:   Thu Jul 20 10:05:09 2023 +0800

    net: hns3: fix wrong tc bandwidth weight data issue
    
    [ Upstream commit 116d9f732eef634abbd871f2c6f613a5b4677742 ]
    
    Currently, the weight saved by the driver is used as the query result,
    which may be different from the actual weight in the register.
    Therefore, the register value read from the firmware is used
    as the query result
    
    Fixes: 0e32038dc856 ("net: hns3: refactor dump tc of debugfs")
    Signed-off-by: Jijie Shao <shaojijie@huawei.com>
    Signed-off-by: David S. Miller <davem@davemloft.net>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit f89520d2e1c22407a929895437e7a0c59697542a
Author: Hao Lan <lanhao@huawei.com>
Date:   Thu Jul 20 10:05:07 2023 +0800

    net: hns3: fix the imp capability bit cannot exceed 32 bits issue
    
    [ Upstream commit b27d0232e8897f7c896dc8ad80c9907dd57fd3f3 ]
    
    Current only the first 32 bits of the capability flag bit are considered.
    When the matching capability flag bit is greater than 31 bits,
    it will get an error bit.This patch use bitmap to solve this issue.
    It can handle each capability bit whitout bit width limit.
    
    Fixes: da77aef9cc58 ("net: hns3: create common cmdq resource allocate/free/query APIs")
    Signed-off-by: Hao Lan <lanhao@huawei.com>
    Signed-off-by: Jijie Shao <shaojijie@huawei.com>
    Signed-off-by: David S. Miller <davem@davemloft.net>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 076eb7bcf7586a9078f179e420ebbd7386ad5f7f
Author: Jiawen Wu <jiawenwu@trustnetic.com>
Date:   Wed Jul 19 17:22:33 2023 +0800

    net: phy: marvell10g: fix 88x3310 power up
    
    [ Upstream commit c7b75bea853daeb64fc831dbf39a6bbabcc402ac ]
    
    Clear MV_V2_PORT_CTRL_PWRDOWN bit to set power up for 88x3310 PHY,
    it sometimes does not take effect immediately. And a read of this
    register causes the bit not to clear. This will cause mv3310_reset()
    to time out, which will fail the config initialization. So add a delay
    before the next access.
    
    Fixes: c9cc1c815d36 ("net: phy: marvell10g: place in powersave mode at probe")
    Signed-off-by: Jiawen Wu <jiawenwu@trustnetic.com>
    Reviewed-by: Russell King (Oracle) <rmk+kernel@armlinux.org.uk>
    Signed-off-by: David S. Miller <davem@davemloft.net>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit e62e51ccc8cb738e786d3c4a4603d85d75f65c4b
Author: Jacob Keller <jacob.e.keller@intel.com>
Date:   Mon Jul 10 13:41:28 2023 -0700

    iavf: check for removal state before IAVF_FLAG_PF_COMMS_FAILED
    
    [ Upstream commit 91896c8acce23d33ed078cffd46a9534b1f82be5 ]
    
    In iavf_adminq_task(), if the function can't acquire the
    adapter->crit_lock, it checks if the driver is removing. If so, it simply
    exits without re-enabling the interrupt. This is done to ensure that the
    task stops processing as soon as possible once the driver is being removed.
    
    However, if the IAVF_FLAG_PF_COMMS_FAILED is set, the function checks this
    before attempting to acquire the lock. In this case, the function exits
    early and re-enables the interrupt. This will happen even if the driver is
    already removing.
    
    Avoid this, by moving the check to after the adapter->crit_lock is
    acquired. This way, if the driver is removing, we will not re-enable the
    interrupt.
    
    Fixes: fc2e6b3b132a ("iavf: Rework mutexes for better synchronisation")
    Signed-off-by: Jacob Keller <jacob.e.keller@intel.com>
    Tested-by: Rafal Romanowski <rafal.romanowski@intel.com>
    Signed-off-by: Tony Nguyen <anthony.l.nguyen@intel.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit f8d88654b5840fc5859aa16a1eefe46c38bdad92
Author: Jacob Keller <jacob.e.keller@intel.com>
Date:   Mon Jul 10 13:41:27 2023 -0700

    iavf: fix potential deadlock on allocation failure
    
    [ Upstream commit a2f054c10bef0b54600ec9cb776508443e941343 ]
    
    In iavf_adminq_task(), if kzalloc() fails to allocate the event.msg_buf,
    the function will exit without releasing the adapter->crit_lock.
    
    This is unlikely, but if it happens, the next access to that mutex will
    deadlock.
    
    Fix this by moving the unlock to the end of the function, and adding a new
    label to allow jumping to the unlock portion of the function exit flow.
    
    Fixes: fc2e6b3b132a ("iavf: Rework mutexes for better synchronisation")
    Signed-off-by: Jacob Keller <jacob.e.keller@intel.com>
    Tested-by: Rafal Romanowski <rafal.romanowski@intel.com>
    Signed-off-by: Tony Nguyen <anthony.l.nguyen@intel.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 0ef05b8f83edd105252fa0a3086ad99abcddf054
Author: Wang Ming <machel@vivo.com>
Date:   Thu Jul 13 09:42:39 2023 +0800

    i40e: Fix an NULL vs IS_ERR() bug for debugfs_create_dir()
    
    [ Upstream commit 043b1f185fb0f3939b7427f634787706f45411c4 ]
    
    The debugfs_create_dir() function returns error pointers.
    It never returns NULL. Most incorrect error checks were fixed,
    but the one in i40e_dbg_init() was forgotten.
    
    Fix the remaining error check.
    
    Fixes: 02e9c290814c ("i40e: debugfs interface")
    Signed-off-by: Wang Ming <machel@vivo.com>
    Tested-by: Pucha Himasekhar Reddy <himasekharx.reddy.pucha@intel.com> (A Contingent worker at Intel)
    Signed-off-by: Tony Nguyen <anthony.l.nguyen@intel.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit b96b9635df28a35008f5ef048d8cc249f2de0a01
Author: Arnd Bergmann <arnd@arndb.de>
Date:   Thu Jun 1 23:37:22 2023 +0200

    media: mtk_jpeg_core: avoid unused-variable warning
    
    [ Upstream commit 20de9fdaf4883deffb0138eef28e9cbbead32cfd ]
    
    The mtk8195_jpegenc_drvdata object was added outside of an #ifdef causing
    a harmless build warning.
    
    drivers/media/platform/mediatek/jpeg/mtk_jpeg_core.c:1879:32: error: 'mtk8195_jpegenc_drvdata' defined but not used [-Werror=unused-variable]
     1879 | static struct mtk_jpeg_variant mtk8195_jpegenc_drvdata = {
          |                                ^~~~~~~~~~~~~~~~~~~~~~~
    
    A follow-up patch moved it inside of an #ifdef, which caused more
    warnings, and a third patch ended up adding even more #ifdefs. These
    were all bogus, since the actual problem here is the incorrect use
    of of_ptr(). Since the driver (like any other modern platform driver)
    only works in combination with CONFIG_OF, there is no point in hiding
    the reference, so just remove that along with all the pointless #ifdef
    checks in the driver.
    
    This improves build coverage and avoids running into the same problem
    again when another part of the driver gets changed that relies on
    the #ifdef blocks to be completely matched.
    
    Fixes: 934e8bccac95 ("mtk-jpegenc: support jpegenc multi-hardware")
    Fixes: 4ae47770d57b ("media: mtk-jpegenc: Fix a compilation issue")
    Fixes: da4ede4b7fd6 ("media: mtk-jpeg: move data/code inside CONFIG_OF blocks")
    Signed-off-by: Arnd Bergmann <arnd@arndb.de>
    Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl>
    Signed-off-by: Mauro Carvalho Chehab <mchehab@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 46256d801a5ec223e337d07983aba9a7a3db98cd
Author: Randy Dunlap <rdunlap@infradead.org>
Date:   Sat May 20 16:41:42 2023 -0700

    media: mtk-jpeg: move data/code inside CONFIG_OF blocks
    
    [ Upstream commit da4ede4b7fd6aa341b69e3a9d2517b8df5e744fd ]
    
    Lots of data and functions here are not needed when CONFIG_OF is not
    set, so move them inside #ifdef CONFIG_OF blocks to prevent the warnings.
    
    ../drivers/media/platform/mediatek/jpeg/mtk_jpeg_core.c:1645:29: warning: ‘mtk_jpeg_clocks’ defined but not used [-Wunused-variable]
     1645 | static struct clk_bulk_data mtk_jpeg_clocks[] = {
    ../drivers/media/platform/mediatek/jpeg/mtk_jpeg_core.c:1640:29: warning: ‘mt8173_jpeg_dec_clocks’ defined but not used [-Wunused-variable]
     1640 | static struct clk_bulk_data mt8173_jpeg_dec_clocks[] = {
    ../drivers/media/platform/mediatek/jpeg/mtk_jpeg_core.c:1481:20: warning: ‘mtk_jpeg_dec_irq’ defined but not used [-Wunused-function]
     1481 | static irqreturn_t mtk_jpeg_dec_irq(int irq, void *priv)
    ../drivers/media/platform/mediatek/jpeg/mtk_jpeg_core.c:1461:20: warning: ‘mtk_jpeg_enc_irq’ defined but not used [-Wunused-function]
     1461 | static irqreturn_t mtk_jpeg_enc_irq(int irq, void *priv)
    ../drivers/media/platform/mediatek/jpeg/mtk_jpeg_core.c:1180:13: warning: ‘mtk_jpegdec_worker’ defined but not used [-Wunused-function]
     1180 | static void mtk_jpegdec_worker(struct work_struct *work)
    ../drivers/media/platform/mediatek/jpeg/mtk_jpeg_core.c:986:13: warning: ‘mtk_jpegenc_worker’ defined but not used [-Wunused-function]
      986 | static void mtk_jpegenc_worker(struct work_struct *work)
    ../drivers/media/platform/mediatek/jpeg/mtk_jpeg_core.c:79:28: warning: ‘mtk_jpeg_dec_formats’ defined but not used [-Wunused-variable]
       79 | static struct mtk_jpeg_fmt mtk_jpeg_dec_formats[] = {
    ../drivers/media/platform/mediatek/jpeg/mtk_jpeg_core.c:31:28: warning: ‘mtk_jpeg_enc_formats’ defined but not used [-Wunused-variable]
       31 | static struct mtk_jpeg_fmt mtk_jpeg_enc_formats[] = {
    ../drivers/media/platform/mediatek/jpeg/mtk_jpeg_core.c:1222:20: warning: ‘mtk_jpeg_enc_done’ defined but not used [-Wunused-function]
     1222 | static irqreturn_t mtk_jpeg_enc_done(struct mtk_jpeg_dev *jpeg)
    ../drivers/media/platform/mediatek/jpeg/mtk_jpeg_core.c:1072:12: warning: ‘mtk_jpegdec_set_hw_param’ defined but not used [-Wunused-function]
     1072 | static int mtk_jpegdec_set_hw_param(struct mtk_jpeg_ctx *ctx,
    ../drivers/media/platform/mediatek/jpeg/mtk_jpeg_core.c:1060:12: warning: ‘mtk_jpegdec_put_hw’ defined but not used [-Wunused-function]
     1060 | static int mtk_jpegdec_put_hw(struct mtk_jpeg_dev *jpeg, int hw_id)
    ../drivers/media/platform/mediatek/jpeg/mtk_jpeg_core.c:1038:12: warning: ‘mtk_jpegdec_get_hw’ defined but not used [-Wunused-function]
     1038 | static int mtk_jpegdec_get_hw(struct mtk_jpeg_ctx *ctx)
    ../drivers/media/platform/mediatek/jpeg/mtk_jpeg_core.c:977:12: warning: ‘mtk_jpegenc_put_hw’ defined but not used [-Wunused-function]
      977 | static int mtk_jpegenc_put_hw(struct mtk_jpeg_dev *jpeg, int hw_id)
    ../drivers/media/platform/mediatek/jpeg/mtk_jpeg_core.c:963:12: warning: ‘mtk_jpegenc_set_hw_param’ defined but not used [-Wunused-function]
      963 | static int mtk_jpegenc_set_hw_param(struct mtk_jpeg_ctx *ctx,
    ../drivers/media/platform/mediatek/jpeg/mtk_jpeg_core.c:941:12: warning: ‘mtk_jpegenc_get_hw’ defined but not used [-Wunused-function]
      941 | static int mtk_jpegenc_get_hw(struct mtk_jpeg_ctx *ctx)
    
    Signed-off-by: Randy Dunlap <rdunlap@infradead.org>
    Reported-by: kernel test robot <lkp@intel.com>
    Link: https://lore.kernel.org/linux-media/202305042146.j4ZxuvpM-lkp@intel.com/
    Cc: Bin Liu <bin.liu@mediatek.com>
    Cc: oushixiong <oushixiong@kylinos.cn>
    Cc: Mauro Carvalho Chehab <mchehab@kernel.org>
    Cc: Hans Verkuil <hverkuil-cisco@xs4all.nl>
    Cc: linux-media@vger.kernel.org
    Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl>
    Stable-dep-of: 20de9fdaf488 ("media: mtk_jpeg_core: avoid unused-variable warning")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 1c47de39107b36c7ca0e25f2996b1f0f5d49524e
Author: Nicolas Dufresne <nicolas.dufresne@collabora.com>
Date:   Thu May 25 22:10:15 2023 +0200

    media: amphion: Fix firmware path to match linux-firmware
    
    [ Upstream commit dcff0b56f661b6b42e828012b464d22cc2068c38 ]
    
    The path did not match the one it was submitted into linux-firmware
    which prevented generic distribution from having working CODEC.
    
    Fixes: 9f599f351e86 ("media: amphion: add vpu core driver")
    Signed-off-by: Nicolas Dufresne <nicolas.dufresne@collabora.com>
    Signed-off-by: Hans Verkuil <hverkuil-cisco@xs4all.nl>
    Signed-off-by: Mauro Carvalho Chehab <mchehab@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit f660df7a5d626a75e95fd6ea674bd1db506ba25a
Author: Sakari Ailus <sakari.ailus@linux.intel.com>
Date:   Tue Jun 13 18:47:53 2023 +0200

    media: staging: atomisp: select V4L2_FWNODE
    
    [ Upstream commit bf4c985707d3168ebb7d87d15830de66949d979c ]
    
    Select V4L2_FWNODE as the driver depends on it.
    
    Reported-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
    Fixes: aa31f6514047 ("media: atomisp: allow building the driver again")
    Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com>
    Tested-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
    Reviewed-by: Hans de Goede <hdegoede@redhat.com>
    Signed-off-by: Mauro Carvalho Chehab <mchehab@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 68799920f634344a3a5b41455468916a0c0b6b7d
Author: Sakari Ailus <sakari.ailus@linux.intel.com>
Date:   Tue May 30 12:16:39 2023 +0200

    media: tc358746: Address compiler warnings
    
    [ Upstream commit 9c2dcfc2cf0f2e4e0a0db33bc1a626e35928c475 ]
    
    Address these compiler warnings by initialising the m_best and p_best
    values to 0 and 1 respectively (as latter is used as a divisor):
    
       drivers/media/i2c/tc358746.c: In function 'tc358746_find_pll_settings':
    >> drivers/media/i2c/tc358746.c:817:13: warning: 'p_best' is used uninitialized
    [-Wuninitialized]
         817 |         u16 p_best, p;
             |             ^~~~~~
    >> drivers/media/i2c/tc358746.c:816:13: warning: 'm_best' is used uninitialized
    [-Wuninitialized]
         816 |         u16 m_best, mul;
             |             ^~~~~~
    
    The warnings may well be a false positive but it is difficult for a
    compiler to find out whether that truly is the case.
    
    Closes: https://lore.kernel.org/oe-kbuild-all/202305301627.fLT3Bkds-lkp@intel.com/
    
    Reported-by: kernel test robot <lkp@intel.com>
    Fixes: 80a21da3605 ("media: tc358746: add Toshiba TC358746 Parallel to CSI-2 bridge driver")
    Signed-off-by: Sakari Ailus <sakari.ailus@linux.intel.com>
    Reviewed-by: Marco Felsch <m.felsch@pengutronix.de>
    Signed-off-by: Mauro Carvalho Chehab <mchehab@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 73c9da33b9ec9a174a205fc07049740e71590380
Author: Dan Carpenter <dan.carpenter@linaro.org>
Date:   Tue Jun 27 08:42:10 2023 +0300

    soundwire: amd: Fix a check for errors in probe()
    
    [ Upstream commit 7891d0a5ce6f627132d3068ba925cf86f29008b1 ]
    
    This code has two problems:
    1) The devm_ioremap() function returns NULL, not error pointers.
    2) It's checking the wrong variable.  ->mmio instead of ->acp_mmio.
    
    Fixes: d8f48fbdfd9a ("soundwire: amd: Add support for AMD Manager driver")
    Suggested-by: "Mukunda,Vijendar" <vijendar.mukunda@amd.com>
    Signed-off-by: Dan Carpenter <dan.carpenter@linaro.org>
    Link: https://lore.kernel.org/r/9863b2bf-0de2-4bf8-8f09-fe24dc5c63ff@moroto.mountain
    Signed-off-by: Vinod Koul <vkoul@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit f716d59dcc675c0bc7bc58c4d617b2ce4b87cba1
Author: Srinivas Kandagatla <srinivas.kandagatla@linaro.org>
Date:   Thu May 25 14:38:09 2023 +0100

    soundwire: qcom: update status correctly with mask
    
    [ Upstream commit f84d41b2a083b990cbdf70f3b24b6b108b9678ad ]
    
    SoundWire device status can be incorrectly updated without
    proper mask, fix this by adding a mask before updating the status.
    
    Fixes: c7d49c76d1d5 ("soundwire: qcom: add support to new interrupts")
    Signed-off-by: Srinivas Kandagatla <srinivas.kandagatla@linaro.org>
    Link: https://lore.kernel.org/r/20230525133812.30841-2-srinivas.kandagatla@linaro.org
    Signed-off-by: Vinod Koul <vkoul@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 7b988cbc65c434789d77b7b6139db7d58a40dc18
Author: Adrien Thierry <athierry@redhat.com>
Date:   Thu Jun 29 10:45:39 2023 -0400

    phy: qcom-snps-femto-v2: properly enable ref clock
    
    [ Upstream commit 8a0eb8f9b9a002291a3934acfd913660b905249e ]
    
    The driver is not enabling the ref clock, which thus gets disabled by
    the clk_disable_unused() initcall. This leads to the dwc3 controller
    failing to initialize if probed after clk_disable_unused() is called,
    for instance when the driver is built as a module.
    
    To fix this, switch to the clk_bulk API to handle both cfg_ahb and ref
    clocks at the proper places.
    
    Note that the cfg_ahb clock is currently not used by any device tree
    instantiation of the PHY. Work needs to be done separately to fix this.
    
    Link: https://lore.kernel.org/linux-arm-msm/ZEqvy+khHeTkC2hf@fedora/
    Fixes: 51e8114f80d0 ("phy: qcom-snps: Add SNPS USB PHY driver for QCOM based SOCs")
    Signed-off-by: Adrien Thierry <athierry@redhat.com>
    Link: https://lore.kernel.org/r/20230629144542.14906-3-athierry@redhat.com
    Signed-off-by: Vinod Koul <vkoul@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit fdf6f1a46680aedfadd45af6956af6a2abcc1226
Author: Adrien Thierry <athierry@redhat.com>
Date:   Thu Jun 29 10:45:38 2023 -0400

    phy: qcom-snps-femto-v2: keep cfg_ahb_clk enabled during runtime suspend
    
    [ Upstream commit 45d89a344eb46db9dce851c28e14f5e3c635c251 ]
    
    In the dwc3 core, both system and runtime suspend end up calling
    dwc3_suspend_common(). From there, what happens for the PHYs depends on
    the USB mode and whether the controller is entering system or runtime
    suspend.
    
    HOST mode:
      (1) system suspend on a non-wakeup-capable controller
    
      The [1] if branch is taken. dwc3_core_exit() is called, which ends up
      calling phy_power_off() and phy_exit(). Those two functions decrease the
      PM runtime count at some point, so they will trigger the PHY runtime
      sleep (assuming the count is right).
    
      (2) runtime suspend / system suspend on a wakeup-capable controller
    
      The [1] branch is not taken. dwc3_suspend_common() calls
      phy_pm_runtime_put_sync(). Assuming the ref count is right, the PHY
      runtime suspend op is called.
    
    DEVICE mode:
      dwc3_core_exit() is called on both runtime and system sleep
      unless the controller is already runtime suspended.
    
    OTG mode:
      (1) system suspend : dwc3_core_exit() is called
    
      (2) runtime suspend : do nothing
    
    In host mode, the code seems to make a distinction between 1) runtime
    sleep / system sleep for wakeup-capable controller, and 2) system sleep
    for non-wakeup-capable controller, where phy_power_off() and phy_exit()
    are only called for the latter. This suggests the PHY is not supposed to
    be in a fully powered-off state for runtime sleep and system sleep for
    wakeup-capable controller.
    
    Moreover, downstream, cfg_ahb_clk only gets disabled for system suspend.
    The clocks are disabled by phy->set_suspend() [2] which is only called
    in the system sleep path through dwc3_core_exit() [3].
    
    With that in mind, don't disable the clocks during the femto PHY runtime
    suspend callback. The clocks will only be disabled during system suspend
    for non-wakeup-capable controllers, through dwc3_core_exit().
    
    [1] https://elixir.bootlin.com/linux/v6.4/source/drivers/usb/dwc3/core.c#L1988
    [2] https://git.codelinaro.org/clo/la/kernel/msm-5.4/-/blob/LV.AU.1.2.1.r2-05300-gen3meta.0/drivers/usb/phy/phy-msm-snps-hs.c#L524
    [3] https://git.codelinaro.org/clo/la/kernel/msm-5.4/-/blob/LV.AU.1.2.1.r2-05300-gen3meta.0/drivers/usb/dwc3/core.c#L1915
    
    Signed-off-by: Adrien Thierry <athierry@redhat.com>
    Link: https://lore.kernel.org/r/20230629144542.14906-2-athierry@redhat.com
    Signed-off-by: Vinod Koul <vkoul@kernel.org>
    Stable-dep-of: 8a0eb8f9b9a0 ("phy: qcom-snps-femto-v2: properly enable ref clock")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 8465ebae166d86a2678c51802cf81dcbc2046fcb
Author: Guillaume Ranquet <granquet@baylibre.com>
Date:   Tue May 30 10:43:07 2023 +0200

    phy: mediatek: hdmi: mt8195: fix prediv bad upper limit test
    
    [ Upstream commit 95bd315f0a5ed7d7afe771776272c5b3cdb29bc8 ]
    
    The pll prediv calculus searchs for the smallest prediv that gets
    the ns_hdmipll_ck in the range of 5 GHz to 12 GHz.
    
    A typo in the upper bound test was testing for 5Ghz to 1Ghz
    
    Fixes: 45810d486bb44 ("phy: mediatek: add support for phy-mtk-hdmi-mt8195")
    Signed-off-by: Guillaume Ranquet <granquet@baylibre.com>
    Reviewed-by: AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
    Link: https://lore.kernel.org/r/20230529-hdmi_phy_fix-v1-1-bf65f53af533@baylibre.com
    Signed-off-by: Vinod Koul <vkoul@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit e73498bbdd62b4b187f0d0c70084eed02caa31e0
Author: Dan Carpenter <dan.carpenter@linaro.org>
Date:   Tue Jul 11 09:13:25 2023 +0300

    phy: phy-mtk-dp: Fix an error code in probe()
    
    [ Upstream commit 5782017cc4d0c8f3425d55b893675bb8a20c33e9 ]
    
    Negative -EINVAL was intended instead of positive EINVAL.
    
    Fixes: 6a23afad443a ("phy: phy-mtk-dp: Add driver for DP phy")
    Signed-off-by: Dan Carpenter <dan.carpenter@linaro.org>
    Reviewed-by: Chen-Yu Tsai <wenst@chromium.org>
    Link: https://lore.kernel.org/r/3c699e00-2883-40d9-92c3-0da1dc38fdd4@moroto.mountain
    Signed-off-by: Vinod Koul <vkoul@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 339fee69a1daa71d6f97e47a867e2c32419a2406
Author: Ojaswin Mujoo <ojaswin@linux.ibm.com>
Date:   Sat Jul 22 22:45:24 2023 +0530

    ext4: fix rbtree traversal bug in ext4_mb_use_preallocated
    
    [ Upstream commit 9d3de7ee192a6a253f475197fe4d2e2af10a731f ]
    
    During allocations, while looking for preallocations(PA) in the per
    inode rbtree, we can't do a direct traversal of the tree because
    ext4_mb_discard_group_preallocation() can paralelly mark the pa deleted
    and that can cause direct traversal to skip some entries. This was
    leading to a BUG_ON() being hit [1] when we missed a PA that could satisfy
    our request and ultimately tried to create a new PA that would overlap
    with the missed one.
    
    To makes sure we handle that case while still keeping the performance of
    the rbtree, we make use of the fact that the only pa that could possibly
    overlap the original goal start is the one that satisfies the below
    conditions:
    
      1. It must have it's logical start immediately to the left of
      (ie less than) original logical start.
    
      2. It must not be deleted
    
    To find this pa we use the following traversal method:
    
    1. Descend into the rbtree normally to find the immediate neighboring
    PA. Here we keep descending irrespective of if the PA is deleted or if
    it overlaps with our request etc. The goal is to find an immediately
    adjacent PA.
    
    2. If the found PA is on right of original goal, use rb_prev() to find
    the left adjacent PA.
    
    3. Check if this PA is deleted and keep moving left with rb_prev() until
    a non deleted PA is found.
    
    4. This is the PA we are looking for. Now we can check if it can satisfy
    the original request and proceed accordingly.
    
    This approach also takes care of having deleted PAs in the tree.
    
    (While we are at it, also fix a possible overflow bug in calculating the
    end of a PA)
    
    [1] https://lore.kernel.org/linux-ext4/CA+G9fYv2FRpLqBZf34ZinR8bU2_ZRAUOjKAD3+tKRFaEQHtt8Q@mail.gmail.com/
    
    Cc: stable@kernel.org # 6.4
    Fixes: 3872778664e3 ("ext4: Use rbtrees to manage PAs instead of inode i_prealloc_list")
    Signed-off-by: Ojaswin Mujoo <ojaswin@linux.ibm.com>
    Reported-by: Naresh Kamboju <naresh.kamboju@linaro.org>
    Reviewed-by: Ritesh Harjani (IBM) ritesh.list@gmail.com
    Tested-by: Ritesh Harjani (IBM) ritesh.list@gmail.com
    Link: https://lore.kernel.org/r/edd2efda6a83e6343c5ace9deea44813e71dbe20.1690045963.git.ojaswin@linux.ibm.com
    Signed-off-by: Theodore Ts'o <tytso@mit.edu>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit a0f2ba186693ff7101ec933749058bc8aa33cc87
Author: Ritesh Harjani <ritesh.list@gmail.com>
Date:   Tue May 30 18:03:40 2023 +0530

    ext4: mballoc: Remove useless setting of ac_criteria
    
    [ Upstream commit 569f196f1e7a14472f21734170411f75a3179db0 ]
    
    There will be changes coming in future patches which will introduce a new
    criteria for block allocation. This removes the useless setting of ac_criteria.
    AFAIU, this might be only used to differentiate between whether a preallocated
    blocks was allocated or was regular allocator called for allocating blocks.
    Hence this also adds the debug prints to identify what type of block allocation
    was done in ext4_mb_show_ac().
    
    Signed-off-by: Ritesh Harjani (IBM) <ritesh.list@gmail.com>
    Signed-off-by: Ojaswin Mujoo <ojaswin@linux.ibm.com>
    Reviewed-by: Jan Kara <jack@suse.cz>
    Link: https://lore.kernel.org/r/1dbae05617519cb6202f1b299c9d1be3e7cda763.1685449706.git.ojaswin@linux.ibm.com
    Signed-off-by: Theodore Ts'o <tytso@mit.edu>
    Stable-dep-of: 9d3de7ee192a ("ext4: fix rbtree traversal bug in ext4_mb_use_preallocated")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit d254d8814025454bb2ff191080fc21e8681e81d3
Author: Kemeng Shi <shikemeng@huaweicloud.com>
Date:   Sat Jun 3 23:03:13 2023 +0800

    ext4: add EXT4_MB_HINT_GOAL_ONLY test in ext4_mb_use_preallocated
    
    [ Upstream commit 1eff590489a213a213c57d96b86f48b32cdf8c3a ]
    
    ext4_mb_use_preallocated will ignore the demand to alloc goal blocks,
    although the EXT4_MB_HINT_GOAL_ONLY is requested.
    For group pa, ext4_mb_group_or_file will not set EXT4_MB_HINT_GROUP_ALLOC
    if EXT4_MB_HINT_GOAL_ONLY is set. So we will not alloc goal blocks from
    group pa if EXT4_MB_HINT_GOAL_ONLY is set.
    For inode pa, ext4_mb_pa_goal_check is added to check if free extent in
    found inode pa meets goal blocks when EXT4_MB_HINT_GOAL_ONLY is set.
    
    Signed-off-by: Kemeng Shi <shikemeng@huaweicloud.com>
    Suggested-by: Ojaswin Mujoo <ojaswin@linux.ibm.com>
    Link: https://lore.kernel.org/r/20230603150327.3596033-6-shikemeng@huaweicloud.com
    Signed-off-by: Theodore Ts'o <tytso@mit.edu>
    Stable-dep-of: 9d3de7ee192a ("ext4: fix rbtree traversal bug in ext4_mb_use_preallocated")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit a0fea63317b755fb6c17d07123044cc6372bfc2e
Author: Daniel Miess <daniel.miess@amd.com>
Date:   Thu Jun 22 08:11:48 2023 -0400

    drm/amd/display: Prevent vtotal from being set to 0
    
    [ Upstream commit 2a9482e55968ed7368afaa9c2133404069117320 ]
    
    [Why]
    In dcn314 DML the destination pipe vtotal was being set
    to the crtc adjustment vtotal_min value even in cases
    where that value is 0.
    
    [How]
    Only set vtotal to the crtc adjustment vtotal_min value
    in cases where the value is non-zero.
    
    Cc: Mario Limonciello <mario.limonciello@amd.com>
    Cc: Alex Deucher <alexander.deucher@amd.com>
    Cc: stable@vger.kernel.org
    Reviewed-by: Nicholas Kazlauskas <nicholas.kazlauskas@amd.com>
    Acked-by: Alan Liu <haoping.liu@amd.com>
    Signed-off-by: Daniel Miess <daniel.miess@amd.com>
    Tested-by: Daniel Wheeler <daniel.wheeler@amd.com>
    Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 64bc8e10c87adf60b2d32aacf3afb288e51d5a62
Author: Daniel Miess <daniel.miess@amd.com>
Date:   Tue Apr 25 14:29:48 2023 -0400

    drm/amd/display: Fix possible underflow for displays with large vblank
    
    [ Upstream commit 1a4bcdbea4319efeb26cc4b05be859a7867e02dc ]
    
    [Why]
    Underflow observed when using a display with a large vblank region
    and low refresh rate
    
    [How]
    Simplify calculation of vblank_nom
    
    Increase value for VBlankNomDefaultUS to 800us
    
    Reviewed-by: Jun Lei <jun.lei@amd.com>
    Acked-by: Aurabindo Pillai <aurabindo.pillai@amd.com>
    Signed-off-by: Daniel Miess <daniel.miess@amd.com>
    Tested-by: Daniel Wheeler <daniel.wheeler@amd.com>
    Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
    Stable-dep-of: 2a9482e55968 ("drm/amd/display: Prevent vtotal from being set to 0")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 8e2fd3a1588ea0bbf16f706845071a1fadabcff9
Author: Gabe Teeger <gabe.teeger@amd.com>
Date:   Thu Apr 6 17:03:06 2023 -0400

    drm/amd/display: update extended blank for dcn314 onwards
    
    [ Upstream commit 469a62938a45ef382c9cb7b9fec6c6c1fcd781c0 ]
    
    [Why]
    Flickering and underflow was observed when testing extended
    blank on dcn314.
    
    [What]
    Vstartup is contrainted by vblank_nom, so adjusting it to include
    non-adjusted vtotal in its calculation during freesync video
    means that Vstartup is not changed when vtotal changes.
    This fixed the flickering + underflow.
    
    dc_extended_blank_supported function was removed
    because extended blank is only relevant to when
    zstate is supported. The increased vtotal during
    freesync can be passed to dml regardless of whether
    extended blank is supported or not, so this function is
    not needed.
    
    Updates were made recently in dml to the calculation of
    min_dst_y_next_start. Dml input for dcn314 will now
    always use the newer calculation for min_dst_y_next_start.
    Dml input for older dcn versions remains untouched.
    
    The variable optimized_min_dst_y_next_start
    is replaced everywhere with min_dst_y_next_start,
    and the updated dml allows min_dst_y_next_start to
    increase to an optimized value during freesync video,
    then return to default when freesync is disengaged.
    
    Also removed registry key for controlling
    extended blank feature.
    
    Tested-by: Daniel Wheeler <daniel.wheeler@amd.com>
    Reviewed-by: Nicholas Kazlauskas <Nicholas.Kazlauskas@amd.com>
    Acked-by: Rodrigo Siqueira <Rodrigo.Siqueira@amd.com>
    Signed-off-by: Gabe Teeger <gabe.teeger@amd.com>
    Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
    Stable-dep-of: 2a9482e55968 ("drm/amd/display: Prevent vtotal from being set to 0")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 74f46ce3474762ab30cfc03fe411a15355099d05
Author: Rodrigo Siqueira <Rodrigo.Siqueira@amd.com>
Date:   Fri Mar 24 14:29:52 2023 -0600

    drm/amd/display: Add FAMS validation before trying to use it
    
    [ Upstream commit e3416e872f84086667df21daf166506fab97358d ]
    
    To ensure that FAMS can be used, DC must check if there is VRR support.
    This commit adds the required configuration to ensure FAMS can be executed in the target system.
    
    Reviewed-by: Alvin Lee <Alvin.Lee2@amd.com>
    Acked-by: Qingqing Zhuo <qingqing.zhuo@amd.com>
    Signed-off-by: Rodrigo Siqueira <Rodrigo.Siqueira@amd.com>
    Tested-by: Daniel Wheeler <daniel.wheeler@amd.com>
    Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
    Stable-dep-of: 2a9482e55968 ("drm/amd/display: Prevent vtotal from being set to 0")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 2401285f91c0e23d76bd4a88ee27d5ed14d07d76
Author: Liam R. Howlett <Liam.Howlett@oracle.com>
Date:   Wed Jul 12 13:39:15 2023 -0400

    maple_tree: fix 32 bit mas_next testing
    
    [ Upstream commit 7a93c71a6714ca1a9c03d70432dac104b0cfb815 ]
    
    The test setup of mas_next is dependent on node entry size to create a 2
    level tree, but the tests did not account for this in the expected value
    when shifting beyond the scope of the tree.
    
    Fix this by setting up the test to succeed depending on the node entries
    which is dependent on the 32/64 bit setup.
    
    Link: https://lkml.kernel.org/r/20230712173916.168805-1-Liam.Howlett@oracle.com
    Fixes: 120b116208a0 ("maple_tree: reorganize testing to restore module testing")
    Signed-off-by: Liam R. Howlett <Liam.Howlett@oracle.com>
    Reported-by: Geert Uytterhoeven <geert@linux-m68k.org>
      Closes: https://lore.kernel.org/linux-mm/CAMuHMdV4T53fOw7VPoBgPR7fP6RYqf=CBhD_y_vOg53zZX_DnA@mail.gmail.com/
    Tested-by: Geert Uytterhoeven <geert@linux-m68k.org>
    Cc: <stable@vger.kernel.org>
    Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 79bad53f7e526ced7f7e67a3b4585a654579acfe
Author: Liam R. Howlett <Liam.Howlett@oracle.com>
Date:   Thu May 18 10:55:28 2023 -0400

    maple_tree: add __init and __exit to test module
    
    [ Upstream commit eaf9790d3bc6e157a2134c01c7d707a5a712fab1 ]
    
    The test functions are not needed after the module is removed, so mark
    them as such.  Add __exit to the module removal function.  Some other
    variables have been marked as const static as well.
    
    Link: https://lkml.kernel.org/r/20230518145544.1722059-20-Liam.Howlett@oracle.com
    Signed-off-by: Liam R. Howlett <Liam.Howlett@oracle.com>
    Suggested-by: Andrew Morton <akpm@linux-foundation.org>
    Cc: David Binderman <dcb314@hotmail.com>
    Cc: Peng Zhang <zhangpeng.00@bytedance.com>
    Cc: Sergey Senozhatsky <senozhatsky@chromium.org>
    Cc: Vernon Yang <vernon2gm@gmail.com>
    Cc: Wei Yang <richard.weiyang@gmail.com>
    Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
    Stable-dep-of: 7a93c71a6714 ("maple_tree: fix 32 bit mas_next testing")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit c24d051e6b48015e32f1361cdf67e1784dd14a9f
Author: Christian König <christian.koenig@amd.com>
Date:   Fri Jul 7 11:25:00 2023 +0200

    drm/ttm: never consider pinned BOs for eviction&swap
    
    [ Upstream commit a2848d08742c8e8494675892c02c0d22acbe3cf8 ]
    
    There is a small window where we have already incremented the pin count
    but not yet moved the bo from the lru to the pinned list.
    
    Signed-off-by: Christian König <christian.koenig@amd.com>
    Reported-by: Pelloux-Prayer, Pierre-Eric <Pierre-eric.Pelloux-prayer@amd.com>
    Tested-by: Pelloux-Prayer, Pierre-Eric <Pierre-eric.Pelloux-prayer@amd.com>
    Acked-by: Alex Deucher <alexander.deucher@amd.com>
    Cc: stable@vger.kernel.org
    Link: https://patchwork.freedesktop.org/patch/msgid/20230707120826.3701-1-christian.koenig@amd.com
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit adff2d7cc515ec9b73a711b51c76f8bd5c548ced
Author: Mario Limonciello <mario.limonciello@amd.com>
Date:   Fri Jun 23 10:05:21 2023 -0500

    drm/amd/display: Set minimum requirement for using PSR-SU on Phoenix
    
    [ Upstream commit cd2e31a9ab93d13c412a36c6e26811e0f830985b ]
    
    The same parade TCON issue can potentially happen on Phoenix, and the same
    PSR resilience changes have been ported into the DMUB firmware.
    
    Don't allow running PSR-SU unless on the newer firmware.
    
    Cc: stable@vger.kernel.org
    Cc: Sean Wang <sean.ns.wang@amd.com>
    Cc: Marc Rossi <Marc.Rossi@amd.com>
    Cc: Hamza Mahfooz <Hamza.Mahfooz@amd.com>
    Cc: Tsung-hua (Ryan) Lin <Tsung-hua.Lin@amd.com>
    Signed-off-by: Mario Limonciello <mario.limonciello@amd.com>
    Reviewed-by: Leo Li <sunpeng.li@amd.com>
    Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit f73fac742bb1ce97e9135f9729eb7bcc20293d81
Author: Mario Limonciello <mario.limonciello@amd.com>
Date:   Fri Jun 23 10:05:20 2023 -0500

    drm/amd/display: Set minimum requirement for using PSR-SU on Rembrandt
    
    [ Upstream commit c35b6ea8f2ecfa9d775530b70d4e727869099a9c ]
    
    A number of parade TCONs are causing system hangs when utilized with
    older DMUB firmware and PSR-SU. Some changes have been introduced into
    DMUB firmware to add resilience against these failures.
    
    Don't allow running PSR-SU unless on the newer firmware.
    
    Cc: stable@vger.kernel.org
    Cc: Sean Wang <sean.ns.wang@amd.com>
    Cc: Marc Rossi <Marc.Rossi@amd.com>
    Cc: Hamza Mahfooz <Hamza.Mahfooz@amd.com>
    Cc: Tsung-hua (Ryan) Lin <Tsung-hua.Lin@amd.com>
    Link: https://gitlab.freedesktop.org/drm/amd/-/issues/2443
    Signed-off-by: Mario Limonciello <mario.limonciello@amd.com>
    Reviewed-by: Leo Li <sunpeng.li@amd.com>
    Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
    Stable-dep-of: cd2e31a9ab93 ("drm/amd/display: Set minimum requirement for using PSR-SU on Phoenix")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 452bbeb39ea506f33ab550bda7ecd262db36f707
Author: Cruise Hung <cruise.hung@amd.com>
Date:   Fri May 12 23:33:46 2023 +0800

    drm/amd/display: Update correct DCN314 register header
    
    [ Upstream commit 268182606f26434c5d3ebd0e86efcb0418dec487 ]
    
    [Why]
    The register header for DCN314 is not correct.
    
    [How]
    Update correct DCN314 register header.
    
    Reviewed-by: Nicholas Kazlauskas <nicholas.kazlauskas@amd.com>
    Acked-by: Tom Chung <chiahsuan.chung@amd.com>
    Signed-off-by: Cruise Hung <cruise.hung@amd.com>
    Tested-by: Daniel Wheeler <daniel.wheeler@amd.com>
    Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
    Stable-dep-of: cd2e31a9ab93 ("drm/amd/display: Set minimum requirement for using PSR-SU on Phoenix")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit bd0e7b7c28d3e427a997f7188c902d92f3d202d9
Author: Dmytro Laktyushkin <dmytro.laktyushkin@amd.com>
Date:   Tue May 16 15:50:40 2023 -0400

    drm/amd/display: fix dcn315 single stream crb allocation
    
    [ Upstream commit 49f26218c344741cb3eaa740b1e44e960551a87f ]
    
    Change to improve avoiding asymetric crb calculations for single stream
    scenarios.
    
    Cc: Mario Limonciello <mario.limonciello@amd.com>
    Cc: Alex Deucher <alexander.deucher@amd.com>
    Cc: stable@vger.kernel.org
    Acked-by: Stylon Wang <stylon.wang@amd.com>
    Signed-off-by: Dmytro Laktyushkin <dmytro.laktyushkin@amd.com>
    Reviewed-by: Charlene Liu <Charlene.Liu@amd.com>
    Tested-by: Daniel Wheeler <daniel.wheeler@amd.com>
    Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit edac24ed87c8e697aa9239774733f13adb7198c1
Author: Dmytro Laktyushkin <Dmytro.Laktyushkin@amd.com>
Date:   Fri Dec 9 15:13:18 2022 -0500

    drm/amd/display: add pixel rate based CRB allocation support
    
    [ Upstream commit 9ba90d760e9354c124fa9bbea08017d96699a82c ]
    
    This feature is meant to unblock PSTATE for certain high end display
    configs on dcn315. This is achieved by allocating CRB to detile buffer
    based on display requirements to meet pstate latency hiding needs.
    
    Tested-by: Daniel Wheeler <daniel.wheeler@amd.com>
    Reviewed-by: Charlene Liu <Charlene.Liu@amd.com>
    Acked-by: Rodrigo Siqueira <Rodrigo.Siqueira@amd.com>
    Signed-off-by: Dmytro Laktyushkin <Dmytro.Laktyushkin@amd.com>
    Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
    Stable-dep-of: 49f26218c344 ("drm/amd/display: fix dcn315 single stream crb allocation")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 45510d28524656184a71d68a58e182557373c903
Author: Michael Strauss <michael.strauss@amd.com>
Date:   Tue Apr 11 12:44:54 2023 -0400

    drm/amd/display: Keep disable aux-i delay as 0
    
    [ Upstream commit 5a096b73c8fed3a9987ba15378285df360e2284b ]
    
    [WHY]
    Current Aux-I sequence checks for local_sink which isn't populated on
    MST links
    
    [HOW]
    Leave disable aux-i delay as 0 for MST cases
    
    Cc: stable@vger.kernel.org
    Tested-by: Daniel Wheeler <daniel.wheeler@amd.com>
    Reviewed-by: George Shen <George.Shen@amd.com>
    Reviewed-by: Aric Cyr <Aric.Cyr@amd.com>
    Acked-by: Rodrigo Siqueira <Rodrigo.Siqueira@amd.com>
    Signed-off-by: Michael Strauss <michael.strauss@amd.com>
    Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 5705367911810afd2ec1c64a01ace8bad9154d09
Author: Michael Strauss <michael.strauss@amd.com>
Date:   Mon Apr 3 11:43:50 2023 -0400

    drm/amd/display: Convert Delaying Aux-I Disable To Monitor Patch
    
    [ Upstream commit 9fa8cc0c444562fa19e20ca20f1c70e15b9d8c13 ]
    
    [WHY]
    32ms delay was added to resolve issue with a specific sink, however this same
    delay also introduces erroneous link training failures with certain sink
    devices.
    
    [HOW]
    Only apply the 32ms delay for offending devices instead of globally.
    
    Tested-by: Daniel Wheeler <daniel.wheeler@amd.com>
    Reviewed-by: Jun Lei <Jun.Lei@amd.com>
    Acked-by: Rodrigo Siqueira <Rodrigo.Siqueira@amd.com>
    Signed-off-by: Michael Strauss <michael.strauss@amd.com>
    Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
    Stable-dep-of: 5a096b73c8fe ("drm/amd/display: Keep disable aux-i delay as 0")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 776ae6b0616781d4aea48c71cf2d278b769a2512
Author: Rick Wertenbroek <rick.wertenbroek@gmail.com>
Date:   Tue Apr 18 09:46:57 2023 +0200

    PCI: rockchip: Don't advertise MSI-X in PCIe capabilities
    
    [ Upstream commit a52587e0bee14cbeeadf48a24013828cb04b8df8 ]
    
    The RK3399 PCIe endpoint controller cannot generate MSI-X IRQs.
    This is documented in the RK3399 technical reference manual (TRM)
    section 17.5.9 "Interrupt Support".
    
    MSI-X capability should therefore not be advertised. Remove the
    MSI-X capability by editing the capability linked-list. The
    previous entry is the MSI capability, therefore get the next
    entry from the MSI-X capability entry and set it as next entry
    for the MSI capability. This in effect removes MSI-X from the list.
    
    Linked list before : MSI cap -> MSI-X cap -> PCIe Device cap -> ...
    Linked list now : MSI cap -> PCIe Device cap -> ...
    
    Link: https://lore.kernel.org/r/20230418074700.1083505-11-rick.wertenbroek@gmail.com
    Fixes: cf590b078391 ("PCI: rockchip: Add EP driver for Rockchip PCIe controller")
    Tested-by: Damien Le Moal <dlemoal@kernel.org>
    Signed-off-by: Rick Wertenbroek <rick.wertenbroek@gmail.com>
    Signed-off-by: Lorenzo Pieralisi <lpieralisi@kernel.org>
    Reviewed-by: Damien Le Moal <dlemoal@kernel.org>
    Cc: stable@vger.kernel.org
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 544c121cae02e7511165a2f7580d1252ec3f10c7
Author: Rick Wertenbroek <rick.wertenbroek@gmail.com>
Date:   Tue Apr 18 09:46:55 2023 +0200

    PCI: rockchip: Fix window mapping and address translation for endpoint
    
    [ Upstream commit dc73ed0f1b8bddd7f2bf70d123e68ffc99ad71ce ]
    
    The RK3399 PCI endpoint core has 33 windows for PCIe space, now in the
    driver up to 32 fixed size (1M) windows are used and pages are allocated
    and mapped accordingly. The driver first used a single window and allocated
    space inside which caused translation issues (between CPU space and PCI
    space) because a window can only have a single translation at a given
    time, which if multiple pages are allocated inside will cause conflicts.
    Now each window is a single region of 1M which will always guarantee that
    the translation is not in conflict.
    
    Set the translation register addresses for physical function. As documented
    in the technical reference manual (TRM) section 17.5.5 "PCIe Address
    Translation" and section 17.6.8 "Address Translation Registers Description"
    
    Link: https://lore.kernel.org/r/20230418074700.1083505-9-rick.wertenbroek@gmail.com
    Fixes: cf590b078391 ("PCI: rockchip: Add EP driver for Rockchip PCIe controller")
    Tested-by: Damien Le Moal <dlemoal@kernel.org>
    Signed-off-by: Rick Wertenbroek <rick.wertenbroek@gmail.com>
    Signed-off-by: Lorenzo Pieralisi <lpieralisi@kernel.org>
    Reviewed-by: Damien Le Moal <dlemoal@kernel.org>
    Cc: stable@vger.kernel.org
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 317b9617417b7adea445d4caecb6baccbf81f50a
Author: Rick Wertenbroek <rick.wertenbroek@gmail.com>
Date:   Tue Apr 18 09:46:48 2023 +0200

    PCI: rockchip: Remove writes to unused registers
    
    [ Upstream commit 92a9c57c325dd51682d428ba960d961fec3c8a08 ]
    
    Remove write accesses to registers that are marked "unused" (and
    therefore read-only) in the technical reference manual (TRM)
    (see RK3399 TRM 17.6.8.1)
    
    Link: https://lore.kernel.org/r/20230418074700.1083505-2-rick.wertenbroek@gmail.com
    Tested-by: Damien Le Moal <dlemoal@kernel.org>
    Signed-off-by: Rick Wertenbroek <rick.wertenbroek@gmail.com>
    Signed-off-by: Lorenzo Pieralisi <lpieralisi@kernel.org>
    Reviewed-by: Damien Le Moal <dlemoal@kernel.org>
    Stable-dep-of: dc73ed0f1b8b ("PCI: rockchip: Fix window mapping and address translation for endpoint")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit b71a2852f8cf88e463645c53110e75891c26fc54
Author: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com>
Date:   Tue May 2 11:39:23 2023 +0300

    PCI/ASPM: Avoid link retraining race
    
    [ Upstream commit e7e39756363ad5bd83ddeae1063193d0f13870fd ]
    
    PCIe r6.0.1, sec 7.5.3.7, recommends setting the link control parameters,
    then waiting for the Link Training bit to be clear before setting the
    Retrain Link bit.
    
    This avoids a race where the LTSSM may not use the updated parameters if it
    is already in the midst of link training because of other normal link
    activity.
    
    Wait for the Link Training bit to be clear before toggling the Retrain Link
    bit to ensure that the LTSSM uses the updated link control parameters.
    
    [bhelgaas: commit log, return 0 (success)/-ETIMEDOUT instead of bool for
    both pcie_wait_for_retrain() and the existing pcie_retrain_link()]
    Suggested-by: Lukas Wunner <lukas@wunner.de>
    Fixes: 7d715a6c1ae5 ("PCI: add PCI Express ASPM support")
    Link: https://lore.kernel.org/r/20230502083923.34562-1-ilpo.jarvinen@linux.intel.com
    Signed-off-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com>
    Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
    Reviewed-by: Lukas Wunner <lukas@wunner.de>
    Cc: stable@vger.kernel.org
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 874b9d8a92d534fb6fef6853d1d1f6652adf4f39
Author: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com>
Date:   Tue Jun 20 14:49:33 2023 -0500

    PCI/ASPM: Factor out pcie_wait_for_retrain()
    
    [ Upstream commit 9c7f136433d26592cb4d9cd00b4e15c33d9797c6 ]
    
    Factor pcie_wait_for_retrain() out from pcie_retrain_link().  No functional
    change intended.
    
    [bhelgaas: split out from
    https: //lore.kernel.org/r/20230502083923.34562-1-ilpo.jarvinen@linux.intel.com]
    Signed-off-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com>
    Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
    Stable-dep-of: e7e39756363a ("PCI/ASPM: Avoid link retraining race")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 16caca59a23bfeed2591b7cee972b4632e2a0a2c
Author: Bjorn Helgaas <bhelgaas@google.com>
Date:   Tue Jun 20 14:44:55 2023 -0500

    PCI/ASPM: Return 0 or -ETIMEDOUT from pcie_retrain_link()
    
    [ Upstream commit f5297a01ee805d7fa569d288ed65fc0f9ac9b03d ]
    
    "pcie_retrain_link" is not a question with a true/false answer, so "bool"
    isn't quite the right return type.  Return 0 for success or -ETIMEDOUT if
    the retrain failed.  No functional change intended.
    
    [bhelgaas: based on Ilpo's patch below]
    Link: https://lore.kernel.org/r/20230502083923.34562-1-ilpo.jarvinen@linux.intel.com
    Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
    Stable-dep-of: e7e39756363a ("PCI/ASPM: Avoid link retraining race")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit fb0c501d7293fcc63b010dfadc5ea64f11a95975
Author: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
Date:   Tue Jul 4 21:50:28 2023 +0200

    i2c: nomadik: Remove a useless call in the remove function
    
    [ Upstream commit 05f933d5f7318b03ff2028c1704dc867ac16f2c7 ]
    
    Since commit 235602146ec9 ("i2c-nomadik: turn the platform driver to an amba
    driver"), there is no more request_mem_region() call in this driver.
    
    So remove the release_mem_region() call from the remove function which is
    likely a left over.
    
    Fixes: 235602146ec9 ("i2c-nomadik: turn the platform driver to an amba driver")
    Cc: <stable@vger.kernel.org> # v3.6+
    Acked-by: Linus Walleij <linus.walleij@linaro.org>
    Reviewed-by: Andi Shyti <andi.shyti@kernel.org>
    Signed-off-by: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
    Signed-off-by: Wolfram Sang <wsa@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit fc491dad925fca04f851f6ff8d1abd5bb023e207
Author: Andi Shyti <andi.shyti@kernel.org>
Date:   Sun Jun 11 03:37:00 2023 +0200

    i2c: nomadik: Use devm_clk_get_enabled()
    
    [ Upstream commit 9c7174db4cdd111e10d19eed5c36fd978a14c8a2 ]
    
    Replace the pair of functions, devm_clk_get() and
    clk_prepare_enable(), with a single function
    devm_clk_get_enabled().
    
    Signed-off-by: Andi Shyti <andi.shyti@kernel.org>
    Reviewed-by: Linus Walleij <linus.walleij@linaro.org>
    Signed-off-by: Wolfram Sang <wsa@kernel.org>
    Stable-dep-of: 05f933d5f731 ("i2c: nomadik: Remove a useless call in the remove function")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit b6014022b64a1987a5bf48f6e26443338769a395
Author: Andi Shyti <andi.shyti@kernel.org>
Date:   Sun Jun 11 03:36:59 2023 +0200

    i2c: nomadik: Remove unnecessary goto label
    
    [ Upstream commit 1c5d33fff0d375e4ab7c4261dc62a286babbb4c6 ]
    
    The err_no_mem goto label doesn't do anything. Remove it.
    
    Signed-off-by: Andi Shyti <andi.shyti@kernel.org>
    Reviewed-by: Linus Walleij <linus.walleij@linaro.org>
    Signed-off-by: Wolfram Sang <wsa@kernel.org>
    Stable-dep-of: 05f933d5f731 ("i2c: nomadik: Remove a useless call in the remove function")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 00f38672ef5a1dcc871992a6b13d5c4a095bc53a
Author: Markus Elfring <elfring@users.sourceforge.net>
Date:   Fri Feb 2 14:50:09 2018 +0100

    i2c: Improve size determinations
    
    [ Upstream commit 06e989578232da33a7fe96b04191b862af8b2cec ]
    
    Replace the specification of a data structure by a pointer dereference
    as the parameter for the operator "sizeof" to make the corresponding
    size determination a bit safer according to the Linux coding style
    convention.
    
    This issue was detected by using the Coccinelle software.
    
    Signed-off-by: Markus Elfring <elfring@users.sourceforge.net>
    Signed-off-by: Wolfram Sang <wsa@kernel.org>
    Stable-dep-of: 05f933d5f731 ("i2c: nomadik: Remove a useless call in the remove function")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 576c5fa88dd72352809ab70fef98e8d8140f93b7
Author: Markus Elfring <elfring@users.sourceforge.net>
Date:   Fri Feb 2 17:24:57 2018 +0100

    i2c: Delete error messages for failed memory allocations
    
    [ Upstream commit 6b3b21a8542fd2fb6ffc61bc13b9419f0c58ebad ]
    
    These issues were detected by using the Coccinelle software.
    
    Signed-off-by: Markus Elfring <elfring@users.sourceforge.net>
    Signed-off-by: Wolfram Sang <wsa@kernel.org>
    Stable-dep-of: 05f933d5f731 ("i2c: nomadik: Remove a useless call in the remove function")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 50cafe0581ef77175efe08a777382ebe3e1d0a29
Author: Filipe Manana <fdmanana@suse.com>
Date:   Mon Jun 19 17:21:50 2023 +0100

    btrfs: fix race between quota disable and relocation
    
    [ Upstream commit 8a4a0b2a3eaf75ca8854f856ef29690c12b2f531 ]
    
    If we disable quotas while we have a relocation of a metadata block group
    that has extents belonging to the quota root, we can cause the relocation
    to fail with -ENOENT. This is because relocation builds backref nodes for
    extents of the quota root and later needs to walk the backrefs and access
    the quota root - however if in between a task disables quotas, it results
    in deleting the quota root from the root tree (with btrfs_del_root(),
    called from btrfs_quota_disable().
    
    This can be sporadically triggered by test case btrfs/255 from fstests:
    
      $ ./check btrfs/255
      FSTYP         -- btrfs
      PLATFORM      -- Linux/x86_64 debian0 6.4.0-rc6-btrfs-next-134+ #1 SMP PREEMPT_DYNAMIC Thu Jun 15 11:59:28 WEST 2023
      MKFS_OPTIONS  -- /dev/sdc
      MOUNT_OPTIONS -- /dev/sdc /home/fdmanana/btrfs-tests/scratch_1
    
      btrfs/255 6s ... _check_dmesg: something found in dmesg (see /home/fdmanana/git/hub/xfstests/results//btrfs/255.dmesg)
      - output mismatch (see /home/fdmanana/git/hub/xfstests/results//btrfs/255.out.bad)
    #      --- tests/btrfs/255.out  2023-03-02 21:47:53.876609426 +0000
    #      +++ /home/fdmanana/git/hub/xfstests/results//btrfs/255.out.bad   2023-06-16 10:20:39.267563212 +0100
    #      @@ -1,2 +1,4 @@
    #       QA output created by 255
    #      +ERROR: error during balancing '/home/fdmanana/btrfs-tests/scratch_1': No such file or directory
    #      +There may be more info in syslog - try dmesg | tail
    #       Silence is golden
    #      ...
          (Run 'diff -u /home/fdmanana/git/hub/xfstests/tests/btrfs/255.out /home/fdmanana/git/hub/xfstests/results//btrfs/255.out.bad'  to see the entire diff)
      Ran: btrfs/255
      Failures: btrfs/255
      Failed 1 of 1 tests
    
    To fix this make the quota disable operation take the cleaner mutex, as
    relocation of a block group also takes this mutex. This is also what we
    do when deleting a subvolume/snapshot, we take the cleaner mutex in the
    cleaner kthread (at cleaner_kthread()) and then we call btrfs_del_root()
    at btrfs_drop_snapshot() while under the protection of the cleaner mutex.
    
    Fixes: bed92eae26cc ("Btrfs: qgroup implementation and prototypes")
    CC: stable@vger.kernel.org # 5.4+
    Signed-off-by: Filipe Manana <fdmanana@suse.com>
    Signed-off-by: David Sterba <dsterba@suse.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 693a76175826dbf5745fb292af44bd8c911ad3a9
Author: Christoph Hellwig <hch@lst.de>
Date:   Wed May 31 08:04:52 2023 +0200

    btrfs: fix fsverify read error handling in end_page_read
    
    [ Upstream commit 2c14f0ffdd30bd3d321ad5fe76fcf701746e1df6 ]
    
    Also clear the uptodate bit to make sure the page isn't seen as uptodate
    in the page cache if fsverity verification fails.
    
    Fixes: 146054090b08 ("btrfs: initial fsverity support")
    CC: stable@vger.kernel.org # 5.15+
    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>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit c42d836e2ef5e8f90bb8674b77e7aa3b8d66d040
Author: Christoph Hellwig <hch@lst.de>
Date:   Wed May 31 08:04:51 2023 +0200

    btrfs: factor out a btrfs_verify_page helper
    
    [ Upstream commit ed9ee98ecb4fdbdfe043ee3eec0a65c0745d8669 ]
    
    Split all the conditionals for the fsverity calls in end_page_read into
    a btrfs_verify_page helper to keep the code readable and make additional
    refactoring easier.
    
    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: 2c14f0ffdd30 ("btrfs: fix fsverify read error handling in end_page_read")
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 96229406255f0ce8f231cd1e7c5ea76be3870879
Author: Guenter Roeck <linux@roeck-us.net>
Date:   Wed Jul 19 20:28:47 2023 -0700

    regmap: Disable locking for RBTREE and MAPLE unit tests
    
    [ Upstream commit a9e26169cfda651802f88262a315146fbe4bc74c ]
    
    REGCACHE_RBTREE and REGCACHE_MAPLE dynamically allocate memory
    for regmap operations. This is incompatible with spinlock based locking
    which is used for fast_io operations. Disable locking for the associated
    unit tests to avoid lockdep splashes.
    
    Fixes: f033c26de5a5 ("regmap: Add maple tree based register cache")
    Fixes: 2238959b6ad2 ("regmap: Add some basic kunit tests")
    Signed-off-by: Guenter Roeck <linux@roeck-us.net>
    Link: https://lore.kernel.org/r/20230720032848.1306349-1-linux@roeck-us.net
    Signed-off-by: Mark Brown <broonie@kernel.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit d9b791d8362359d241b4e8f4b4767c681ffdb6ef
Author: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
Date:   Wed Jul 19 13:41:01 2023 +0200

    gpio: mvebu: fix irq domain leak
    
    [ Upstream commit 644ee70267a934be27370f9aa618b29af7290544 ]
    
    Uwe Kleine-König pointed out we still have one resource leak in the mvebu
    driver triggered on driver detach. Let's address it with a custom devm
    action.
    
    Fixes: 812d47889a8e ("gpio/mvebu: Use irq_domain_add_linear")
    Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
    Reviewed-by: Andy Shevchenko <andy.shevchenko@gmail.com>
    Reviewed-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 53638f73948deefb886b8287a8923571b2515480
Author: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
Date:   Mon Jul 17 16:27:43 2023 +0200

    gpio: mvebu: Make use of devm_pwmchip_add
    
    [ Upstream commit 1945063eb59e64d2919cb14d54d081476d9e53bb ]
    
    This allows to get rid of a call to pwmchip_remove() in the error path. There
    is no .remove function for this driver, so this change fixes a resource leak
    when a gpio-mvebu device is unbound.
    
    Fixes: 757642f9a584 ("gpio: mvebu: Add limited PWM support")
    Signed-off-by: Uwe Kleine-König <u.kleine-koenig@pengutronix.de>
    Reviewed-by: Andy Shevchenko <andy@kernel.org>
    Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 3f8f1601128b33e9af35a0b8df7b68a839b5c755
Author: Hans de Goede <hdegoede@redhat.com>
Date:   Mon Jul 10 14:34:25 2023 +0200

    gpio: tps68470: Make tps68470_gpio_output() always set the initial value
    
    [ Upstream commit 5a7adc6c1069ce31ef4f606ae9c05592c80a6ab5 ]
    
    Make tps68470_gpio_output() call tps68470_gpio_set() for output-only pins
    too, so that the initial value passed to gpiod_direction_output() is
    honored for these pins too.
    
    Fixes: 275b13a65547 ("gpio: Add support for TPS68470 GPIOs")
    Reviewed-by: Andy Shevchenko <andy.shevchenko@gmail.com>
    Reviewed-by: Daniel Scally <dan.scally@ideasonboard.com>
    Tested-by: Daniel Scally <dan.scally@ideasonboard.com>
    Reviewed-by: Sakari Ailus <sakari.ailus@linux.intel.com>
    Signed-off-by: Hans de Goede <hdegoede@redhat.com>
    Signed-off-by: Bartosz Golaszewski <bartosz.golaszewski@linaro.org>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 384d3da61118bee8336e4aa06f3880d54b786061
Author: Ondrej Mosnacek <omosnace@redhat.com>
Date:   Tue Jul 18 13:56:07 2023 +0200

    io_uring: don't audit the capability check in io_uring_create()
    
    [ Upstream commit 6adc2272aaaf84f34b652cf77f770c6fcc4b8336 ]
    
    The check being unconditional may lead to unwanted denials reported by
    LSMs when a process has the capability granted by DAC, but denied by an
    LSM. In the case of SELinux such denials are a problem, since they can't
    be effectively filtered out via the policy and when not silenced, they
    produce noise that may hide a true problem or an attack.
    
    Since not having the capability merely means that the created io_uring
    context will be accounted against the current user's RLIMIT_MEMLOCK
    limit, we can disable auditing of denials for this check by using
    ns_capable_noaudit() instead of capable().
    
    Fixes: 2b188cc1bb85 ("Add io_uring IO interface")
    Link: https://bugzilla.redhat.com/show_bug.cgi?id=2193317
    Signed-off-by: Ondrej Mosnacek <omosnace@redhat.com>
    Reviewed-by: Jeff Moyer <jmoyer@redhat.com>
    Link: https://lore.kernel.org/r/20230718115607.65652-1-omosnace@redhat.com
    Signed-off-by: Jens Axboe <axboe@kernel.dk>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit aa52a654da5fc973272db891bd0c8a8fdcc66bd6
Author: Sven Schnelle <svens@linux.ibm.com>
Date:   Thu Jul 13 15:54:23 2023 +0200

    s390/mm: fix per vma lock fault handling
    
    [ Upstream commit 7686762d1ed092db4d120e29b565712c969dc075 ]
    
    With per-vma locks, handle_mm_fault() may return non-fatal error
    flags. In this case the code should reset the fault flags before
    returning.
    
    Fixes: e06f47a16573 ("s390/mm: try VMA lock-based page fault handling first")
    Signed-off-by: Sven Schnelle <svens@linux.ibm.com>
    Reviewed-by: Heiko Carstens <hca@linux.ibm.com>
    Signed-off-by: Heiko Carstens <hca@linux.ibm.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit f1c7a776338f2ac5e34da40e58fe9f33ea390a5e
Author: Claudio Imbrenda <imbrenda@linux.ibm.com>
Date:   Wed Jul 5 13:19:37 2023 +0200

    KVM: s390: pv: fix index value of replaced ASCE
    
    [ Upstream commit c2fceb59bbda16468bda82b002383bff59de89ab ]
    
    The index field of the struct page corresponding to a guest ASCE should
    be 0. When replacing the ASCE in s390_replace_asce(), the index of the
    new ASCE should also be set to 0.
    
    Having the wrong index might lead to the wrong addresses being passed
    around when notifying pte invalidations, and eventually to validity
    intercepts (VM crash) if the prefix gets unmapped and the notifier gets
    called with the wrong address.
    
    Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org>
    Fixes: faa2f72cb356 ("KVM: s390: pv: leak the topmost page table when destroy fails")
    Reviewed-by: Janosch Frank <frankja@linux.ibm.com>
    Signed-off-by: Claudio Imbrenda <imbrenda@linux.ibm.com>
    Message-ID: <20230705111937.33472-3-imbrenda@linux.ibm.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit b5b88c86258a5e74837e20fa3f98971c85a5cc61
Author: Claudio Imbrenda <imbrenda@linux.ibm.com>
Date:   Wed Jul 5 13:19:36 2023 +0200

    KVM: s390: pv: simplify shutdown and fix race
    
    [ Upstream commit 5ff92181577a89ed12ad4e0e5813751faf16a139 ]
    
    Simplify the shutdown of non-protected VMs. There is no need to do
    complex manipulations of the counter if it was zero.
    
    This also fixes a very rare race which caused pages to be torn down
    from the address space with a non-zero counter even on older machines
    that don't support the UVC instruction, causing a crash.
    
    Reported-by: Marc Hartmayer <mhartmay@linux.ibm.com>
    Fixes: fb491d5500a7 ("KVM: s390: pv: asynchronous destroy for reboot")
    Reviewed-by: Nico Boehr <nrb@linux.ibm.com>
    Signed-off-by: Claudio Imbrenda <imbrenda@linux.ibm.com>
    Message-ID: <20230705111937.33472-2-imbrenda@linux.ibm.com>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 959dc1b16ea3f1db1d3be0e504e3a2ae126d3b87
Author: Haren Myneni <haren@linux.ibm.com>
Date:   Sun Jul 16 03:05:06 2023 -0700

    powerpc/pseries/vas: Hold mmap_mutex after mmap lock during window close
    
    [ Upstream commit b59c9dc4d9d47b3c4572d826603fde507055b656 ]
    
    Commit 8ef7b9e1765a ("powerpc/pseries/vas: Close windows with DLPAR
    core removal") unmaps the window paste address and issues HCALL to
    close window in the hypervisor for migration or DLPAR core removal
    events. So holds mmap_mutex and then mmap lock before unmap the
    paste address. But if the user space issue mmap paste address at
    the same time with the migration event, coproc_mmap() is called
    after holding the mmap lock which can trigger deadlock when trying
    to acquire mmap_mutex in coproc_mmap().
    
    t1: mmap() call to mmap              t2: Migration event
        window paste address
    
    do_mmap2()                           migration_store()
     ksys_mmap_pgoff()                    pseries_migrate_partition()
      vm_mmap_pgoff()                      vas_migration_handler()
        Acquire mmap lock                   reconfig_close_windows()
        do_mmap()                             lock mmap_mutex
         mmap_region()                        Acquire mmap lock
          call_mmap()                         //Wait for mmap lock
           coproc_mmap()                        unmap vma
             lock mmap_mutex                    update window status
             //wait for mmap_mutex            Release mmap lock
              mmap vma                        unlock mmap_mutex
              update window status
             unlock mmap_mutex
        ...
        Release mmap lock
    
    Fix this deadlock issue by holding mmap lock first before mmap_mutex
    in reconfig_close_windows().
    
    Fixes: 8ef7b9e1765a ("powerpc/pseries/vas: Close windows with DLPAR core removal")
    Signed-off-by: Haren Myneni <haren@linux.ibm.com>
    Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
    Link: https://msgid.link/20230716100506.7833-1-haren@linux.ibm.com
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 7bbda96776298ee321bc0f21428a1bc70ba61742
Author: Ross Lagerwall <ross.lagerwall@citrix.com>
Date:   Fri Jul 14 11:11:06 2023 +0100

    blk-mq: Fix stall due to recursive flush plug
    
    [ Upstream commit 70904263512a74a3b8941dd9e6e515ca6fc57821 ]
    
    We have seen rare IO stalls as follows:
    
    * blk_mq_plug_issue_direct() is entered with an mq_list containing two
    requests.
    * For the first request, it sets last == false and enters the driver's
    queue_rq callback.
    * The driver queue_rq callback indirectly calls schedule() which calls
    blk_flush_plug(). This may happen if the driver has the
    BLK_MQ_F_BLOCKING flag set and is allowed to sleep in ->queue_rq.
    * blk_flush_plug() handles the remaining request in the mq_list. mq_list
    is now empty.
    * The original call to queue_rq resumes (with last == false).
    * The loop in blk_mq_plug_issue_direct() terminates because there are no
    remaining requests in mq_list.
    
    The IO is now stalled because the last request submitted to the driver
    had last == false and there was no subsequent call to commit_rqs().
    
    Fix this by returning early in blk_mq_flush_plug_list() if rq_count is 0
    which it will be in the recursive case, rather than checking if the
    mq_list is empty. At the same time, adjust one of the callers to skip
    the mq_list empty check as it is not necessary.
    
    Fixes: dc5fc361d891 ("block: attempt direct issue of plug list")
    Signed-off-by: Ross Lagerwall <ross.lagerwall@citrix.com>
    Reviewed-by: Bart Van Assche <bvanassche@acm.org>
    Link: https://lore.kernel.org/r/20230714101106.3635611-1-ross.lagerwall@citrix.com
    Signed-off-by: Jens Axboe <axboe@kernel.dk>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 91450dec0445f4d12f960ba68d8d05c3cb2ab5b8
Author: Sudeep Holla <sudeep.holla@arm.com>
Date:   Tue Jul 4 20:32:43 2023 +0100

    KVM: arm64: Handle kvm_arm_init failure correctly in finalize_pkvm
    
    [ Upstream commit fa729bc7c9c8c17a2481358c841ef8ca920485d3 ]
    
    Currently there is no synchronisation between finalize_pkvm() and
    kvm_arm_init() initcalls. The finalize_pkvm() proceeds happily even if
    kvm_arm_init() fails resulting in the following warning on all the CPUs
    and eventually a HYP panic:
    
      | kvm [1]: IPA Size Limit: 48 bits
      | kvm [1]: Failed to init hyp memory protection
      | kvm [1]: error initializing Hyp mode: -22
      |
      | <snip>
      |
      | WARNING: CPU: 0 PID: 0 at arch/arm64/kvm/pkvm.c:226 _kvm_host_prot_finalize+0x30/0x50
      | Modules linked in:
      | CPU: 0 PID: 0 Comm: swapper/0 Not tainted 6.4.0 #237
      | Hardware name: FVP Base RevC (DT)
      | pstate: 634020c5 (nZCv daIF +PAN -UAO +TCO +DIT -SSBS BTYPE=--)
      | pc : _kvm_host_prot_finalize+0x30/0x50
      | lr : __flush_smp_call_function_queue+0xd8/0x230
      |
      | Call trace:
      |  _kvm_host_prot_finalize+0x3c/0x50
      |  on_each_cpu_cond_mask+0x3c/0x6c
      |  pkvm_drop_host_privileges+0x4c/0x78
      |  finalize_pkvm+0x3c/0x5c
      |  do_one_initcall+0xcc/0x240
      |  do_initcall_level+0x8c/0xac
      |  do_initcalls+0x54/0x94
      |  do_basic_setup+0x1c/0x28
      |  kernel_init_freeable+0x100/0x16c
      |  kernel_init+0x20/0x1a0
      |  ret_from_fork+0x10/0x20
      | Failed to finalize Hyp protection: -22
      |     dtb=fvp-base-revc.dtb
      | kvm [95]: nVHE hyp BUG at: arch/arm64/kvm/hyp/nvhe/mem_protect.c:540!
      | kvm [95]: nVHE call trace:
      | kvm [95]:  [<ffff800081052984>] __kvm_nvhe_hyp_panic+0xac/0xf8
      | kvm [95]:  [<ffff800081059644>] __kvm_nvhe_handle_host_mem_abort+0x1a0/0x2ac
      | kvm [95]:  [<ffff80008105511c>] __kvm_nvhe_handle_trap+0x4c/0x160
      | kvm [95]:  [<ffff8000810540fc>] __kvm_nvhe___skip_pauth_save+0x4/0x4
      | kvm [95]: ---[ end nVHE call trace ]---
      | kvm [95]: Hyp Offset: 0xfffe8db00ffa0000
      | Kernel panic - not syncing: HYP panic:
      | PS:a34023c9 PC:0000f250710b973c ESR:00000000f2000800
      | FAR:ffff000800cb00d0 HPFAR:000000000880cb00 PAR:0000000000000000
      | VCPU:0000000000000000
      | CPU: 3 PID: 95 Comm: kworker/u16:2 Tainted: G        W          6.4.0 #237
      | Hardware name: FVP Base RevC (DT)
      | Workqueue: rpciod rpc_async_schedule
      | Call trace:
      |  dump_backtrace+0xec/0x108
      |  show_stack+0x18/0x2c
      |  dump_stack_lvl+0x50/0x68
      |  dump_stack+0x18/0x24
      |  panic+0x138/0x33c
      |  nvhe_hyp_panic_handler+0x100/0x184
      |  new_slab+0x23c/0x54c
      |  ___slab_alloc+0x3e4/0x770
      |  kmem_cache_alloc_node+0x1f0/0x278
      |  __alloc_skb+0xdc/0x294
      |  tcp_stream_alloc_skb+0x2c/0xf0
      |  tcp_sendmsg_locked+0x3d0/0xda4
      |  tcp_sendmsg+0x38/0x5c
      |  inet_sendmsg+0x44/0x60
      |  sock_sendmsg+0x1c/0x34
      |  xprt_sock_sendmsg+0xdc/0x274
      |  xs_tcp_send_request+0x1ac/0x28c
      |  xprt_transmit+0xcc/0x300
      |  call_transmit+0x78/0x90
      |  __rpc_execute+0x114/0x3d8
      |  rpc_async_schedule+0x28/0x48
      |  process_one_work+0x1d8/0x314
      |  worker_thread+0x248/0x474
      |  kthread+0xfc/0x184
      |  ret_from_fork+0x10/0x20
      | SMP: stopping secondary CPUs
      | Kernel Offset: 0x57c5cb460000 from 0xffff800080000000
      | PHYS_OFFSET: 0x80000000
      | CPU features: 0x00000000,1035b7a3,ccfe773f
      | Memory Limit: none
      | ---[ end Kernel panic - not syncing: HYP panic:
      | PS:a34023c9 PC:0000f250710b973c ESR:00000000f2000800
      | FAR:ffff000800cb00d0 HPFAR:000000000880cb00 PAR:0000000000000000
      | VCPU:0000000000000000 ]---
    
    Fix it by checking for the successfull initialisation of kvm_arm_init()
    in finalize_pkvm() before proceeding any futher.
    
    Fixes: 87727ba2bb05 ("KVM: arm64: Ensure CPU PMU probes before pKVM host de-privilege")
    Cc: Will Deacon <will@kernel.org>
    Cc: Marc Zyngier <maz@kernel.org>
    Cc: Oliver Upton <oliver.upton@linux.dev>
    Cc: James Morse <james.morse@arm.com>
    Cc: Suzuki K Poulose <suzuki.poulose@arm.com>
    Cc: Zenghui Yu <yuzenghui@huawei.com>
    Signed-off-by: Sudeep Holla <sudeep.holla@arm.com>
    Acked-by: Marc Zyngier <maz@kernel.org>
    Link: https://lore.kernel.org/r/20230704193243.3300506-1-sudeep.holla@arm.com
    Signed-off-by: Oliver Upton <oliver.upton@linux.dev>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 3e5ea6b6a571c37ceee837ac25384c2f39e52a8b
Author: Zhihao Cheng <chengzhihao1@huawei.com>
Date:   Tue Jun 6 21:59:26 2023 +0800

    jbd2: Fix wrongly judgement for buffer head removing while doing checkpoint
    
    [ Upstream commit e34c8dd238d0c9368b746480f313055f5bab5040 ]
    
    Following process,
    
    jbd2_journal_commit_transaction
    // there are several dirty buffer heads in transaction->t_checkpoint_list
              P1                   wb_workfn
    jbd2_log_do_checkpoint
     if (buffer_locked(bh)) // false
                                __block_write_full_page
                                 trylock_buffer(bh)
                                 test_clear_buffer_dirty(bh)
     if (!buffer_dirty(bh))
      __jbd2_journal_remove_checkpoint(jh)
       if (buffer_write_io_error(bh)) // false
                                 >> bh IO error occurs <<
     jbd2_cleanup_journal_tail
      __jbd2_update_log_tail
       jbd2_write_superblock
       // The bh won't be replayed in next mount.
    , which could corrupt the ext4 image, fetch a reproducer in [Link].
    
    Since writeback process clears buffer dirty after locking buffer head,
    we can fix it by try locking buffer and check dirtiness while buffer is
    locked, the buffer head can be removed if it is neither dirty nor locked.
    
    Link: https://bugzilla.kernel.org/show_bug.cgi?id=217490
    Fixes: 470decc613ab ("[PATCH] jbd2: initial copy of files from jbd")
    Signed-off-by: Zhihao Cheng <chengzhihao1@huawei.com>
    Signed-off-by: Zhang Yi <yi.zhang@huawei.com>
    Reviewed-by: Jan Kara <jack@suse.cz>
    Link: https://lore.kernel.org/r/20230606135928.434610-5-yi.zhang@huaweicloud.com
    Signed-off-by: Theodore Ts'o <tytso@mit.edu>
    Signed-off-by: Sasha Levin <sashal@kernel.org>

commit 2ecab4882ca368d5e65627cce63b78731cfcab6a
Author: Heiner Kallweit <hkallweit1@gmail.com>
Date:   Tue Jul 18 13:11:31 2023 +0200

    r8169: revert 2ab19de62d67 ("r8169: remove ASPM restrictions now that ASPM is disabled during NAPI poll")
    
    commit cf2ffdea0839398cb0551762af7f5efb0a6e0fea upstream.
    
    There have been reports that on a number of systems this change breaks
    network connectivity. Therefore effectively revert it. Mainly affected
    seem to be systems where BIOS denies ASPM access to OS.
    Due to later changes we can't do a direct revert.
    
    Fixes: 2ab19de62d67 ("r8169: remove ASPM restrictions now that ASPM is disabled during NAPI poll")
    Cc: stable@vger.kernel.org
    Link: https://lore.kernel.org/netdev/e47bac0d-e802-65e1-b311-6acb26d5cf10@freenet.de/T/
    Closes: https://bugzilla.kernel.org/show_bug.cgi?id=217596
    Signed-off-by: Heiner Kallweit <hkallweit1@gmail.com>
    Link: https://lore.kernel.org/r/57f13ec0-b216-d5d8-363d-5b05528ec5fb@gmail.com
    Signed-off-by: Jakub Kicinski <kuba@kernel.org>
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 979f8de763edb0d6744f1e397a3c7e46d3eba400
Author: Mario Limonciello <mario.limonciello@amd.com>
Date:   Fri Jul 7 21:26:09 2023 -0500

    drm/amd: Align SMU11 SMU_MSG_OverridePcieParameters implementation with SMU13
    
    commit e701156ccc6c7a5f104a968dda74cd6434178712 upstream.
    
    SMU13 overrides dynamic PCIe lane width and dynamic speed by when on
    certain hosts. commit 38e4ced80479 ("drm/amd/pm: conditionally disable
    pcie lane switching for some sienna_cichlid SKUs") worked around this
    issue by setting up certain SKUs to set up certain limits, but the same
    fundamental problem with those hosts affects all SMU11 implmentations
    as well, so align the SMU11 and SMU13 driver handling.
    
    Signed-off-by: Mario Limonciello <mario.limonciello@amd.com>
    Reviewed-by: Evan Quan <evan.quan@amd.com>
    Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
    Cc: stable@vger.kernel.org # 6.1.x
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit 3d7a757d2c15ef26ebdac20bf6f10da8d94b7918
Author: Mario Limonciello <mario.limonciello@amd.com>
Date:   Fri Jul 7 21:26:08 2023 -0500

    drm/amd: Move helper for dynamic speed switch check out of smu13
    
    commit 188623076d0f1a500583d392b6187056bf7cc71a upstream.
    
    This helper is used for checking if the connected host supports
    the feature, it can be moved into generic code to be used by other
    smu implementations as well.
    
    Signed-off-by: Mario Limonciello <mario.limonciello@amd.com>
    Reviewed-by: Evan Quan <evan.quan@amd.com>
    Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
    Cc: stable@vger.kernel.org # 6.1.x
    Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>

commit b94db3f542f904bfaf584f6842a2c9654182999d
Author: Shyam Sundar S K <Shyam-sundar.S-k@amd.com>
Date:   Fri Jul 14 20:14:34 2023 +0530

    platform/x86/amd/pmf: reduce verbosity of apmf_get_system_params
    
    commit 839e90e75e695b3d9ee17f5a2811e7ee5aea8d4a upstream.
    
    apmf_get_system_params() failure is not a critical event, reduce its
    verbosity from dev_err to dev_dbg.
    
    Signed-off-by: Mario Limonciello <mario.limonciello@amd.com>
    Signed-off-by: Shyam Sundar S K <Shyam-sundar.S-k@amd.com>
    Link: https://lore.kernel.org/r/20230714144435.1239776-1-Shyam-sundar.S-k@amd.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>

commit 71bcf64f908328e19169a3c7bbfa9b4dccf86b77
Author: Shyam Sundar S K <Shyam-sundar.S-k@amd.com>
Date:   Fri Jul 14 20:14:35 2023 +0530

    platform/x86/amd/pmf: Notify OS power slider update
    
    commit 33c9ab5b493a0e922b06c12fed4fdcb862212cda upstream.
    
    APMF fn8 can notify EC about the OS slider position change. Add this
    capability to the PMF driver so that it can call the APMF fn8 based on
    the changes in the Platform profile events.
    
    Co-developed-by: Mario Limonciello <mario.limonciello@amd.com>
    Signed-off-by: Mario Limonciello <mario.limonciello@amd.com>
    Signed-off-by: Patil Rajesh Reddy <Patil.Reddy@amd.com>
    Signed-off-by: Shyam Sundar S K <Shyam-sundar.S-k@amd.com>
    Link: https://lore.kernel.org/r/20230714144435.1239776-2-Shyam-sundar.S-k@amd.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>