1. 23 Nov, 2022 9 commits
    • Dave Marchevsky's avatar
      fuse: Rearrange fuse_allow_current_process checks · b1387777
      Dave Marchevsky authored
      This is a followup to a previous commit of mine [0], which added the
      allow_sys_admin_access && capable(CAP_SYS_ADMIN) check.  This patch
      rearranges the order of checks in fuse_allow_current_process without
      changing functionality.
      
      Commit 9ccf47b2 ("fuse: Add module param for CAP_SYS_ADMIN access
      bypassing allow_other") added allow_sys_admin_access &&
      capable(CAP_SYS_ADMIN) check to the beginning of the function, with the
      reasoning that allow_sys_admin_access should be an 'escape hatch' for users
      with CAP_SYS_ADMIN, allowing them to skip any subsequent checks.
      
      However, placing this new check first results in many capable() calls when
      allow_sys_admin_access is set, where another check would've also returned
      1.  This can be problematic when a BPF program is tracing capable() calls.
      
      At Meta we ran into such a scenario recently.  On a host where
      allow_sys_admin_access is set but most of the FUSE access is from processes
      which would pass other checks - i.e.  they don't need CAP_SYS_ADMIN 'escape
      hatch' - this results in an unnecessary capable() call for each fs op.  We
      also have a daemon tracing capable() with BPF and doing some data
      collection, so tracing these extraneous capable() calls has the potential
      to regress performance for an application doing many FUSE ops.
      
      So rearrange the order of these checks such that CAP_SYS_ADMIN 'escape
      hatch' is checked last.  Add a small helper, fuse_permissible_uidgid, to
      make the logic easier to understand.  Previously, if allow_other is set on
      the fuse_conn, uid/git checking doesn't happen as current_in_userns result
      is returned.  These semantics are maintained here: fuse_permissible_uidgid
      check only happens if allow_other is not set.
      Signed-off-by: default avatarDave Marchevsky <davemarchevsky@fb.com>
      Suggested-by: default avatarAndrii Nakryiko <andrii@kernel.org>
      Reviewed-by: default avatarChristian Brauner (Microsoft) <brauner@kernel.org>
      Signed-off-by: default avatarMiklos Szeredi <mszeredi@redhat.com>
      b1387777
    • Dharmendra Singh's avatar
      fuse: allow non-extending parallel direct writes on the same file · 15352405
      Dharmendra Singh authored
      In general, as of now, in FUSE, direct writes on the same file are
      serialized over inode lock i.e we hold inode lock for the full duration of
      the write request.  I could not find in fuse code and git history a comment
      which clearly explains why this exclusive lock is taken for direct writes.
      Following might be the reasons for acquiring an exclusive lock but not be
      limited to
      
       1) Our guess is some USER space fuse implementations might be relying on
          this lock for serialization.
      
       2) The lock protects against file read/write size races.
      
       3) Ruling out any issues arising from partial write failures.
      
      This patch relaxes the exclusive lock for direct non-extending writes only.
      File size extending writes might not need the lock either, but we are not
      entirely sure if there is a risk to introduce any kind of regression.
      Furthermore, benchmarking with fio does not show a difference between patch
      versions that take on file size extension a) an exclusive lock and b) a
      shared lock.
      
      A possible example of an issue with i_size extending writes are write error
      cases.  Some writes might succeed and others might fail for file system
      internal reasons - for example ENOSPACE.  With parallel file size extending
      writes it _might_ be difficult to revert the action of the failing write,
      especially to restore the right i_size.
      
      With these changes, we allow non-extending parallel direct writes on the
      same file with the help of a flag called FOPEN_PARALLEL_DIRECT_WRITES.  If
      this flag is set on the file (flag is passed from libfuse to fuse kernel as
      part of file open/create), we do not take exclusive lock anymore, but
      instead use a shared lock that allows non-extending writes to run in
      parallel.  FUSE implementations which rely on this inode lock for
      serialization can continue to do so and serialized direct writes are still
      the default.  Implementations that do not do write serialization need to be
      updated and need to set the FOPEN_PARALLEL_DIRECT_WRITES flag in their file
      open/create reply.
      
      On patch review there were concerns that network file systems (or vfs
      multiple mounts of the same file system) might have issues with parallel
      writes.  We believe this is not the case, as this is just a local lock,
      which network file systems could not rely on anyway.  I.e. this lock is
      just for local consistency.
      Signed-off-by: default avatarDharmendra Singh <dsingh@ddn.com>
      Signed-off-by: default avatarBernd Schubert <bschubert@ddn.com>
      Signed-off-by: default avatarMiklos Szeredi <mszeredi@redhat.com>
      15352405
    • ye xingchen's avatar
      fuse: remove the unneeded result variable · e2283a73
      ye xingchen authored
      Return the value fuse_dev_release() directly instead of storing it in
      another redundant variable.
      Reported-by: default avatarZeal Robot <zealci@zte.com.cn>
      Signed-off-by: default avatarye xingchen <ye.xingchen@zte.com.cn>
      Signed-off-by: default avatarMiklos Szeredi <mszeredi@redhat.com>
      e2283a73
    • Christian Brauner's avatar
      fuse: port to vfs{g,u}id_t and associated helpers · 00d369bc
      Christian Brauner authored
      A while ago we introduced a dedicated vfs{g,u}id_t type in commit
      1e5267cd ("mnt_idmapping: add vfs{g,u}id_t").  We already switched over
      a good part of the VFS.  Ultimately we will remove all legacy idmapped
      mount helpers that operate only on k{g,u}id_t in favor of the new type safe
      helpers that operate on vfs{g,u}id_t.
      
      Cc: Seth Forshee (Digital Ocean) <sforshee@kernel.org>
      Cc: Christoph Hellwig <hch@lst.de>
      Signed-off-by: default avatarChristian Brauner (Microsoft) <brauner@kernel.org>
      Signed-off-by: default avatarMiklos Szeredi <mszeredi@redhat.com>
      00d369bc
    • Jann Horn's avatar
      fuse: Remove user_ns check for FUSE_DEV_IOC_CLONE · 0618021e
      Jann Horn authored
      Commit 8ed1f0e2 ("fs/fuse: fix ioctl type confusion") fixed a type
      confusion bug by adding an ->f_op comparison.
      
      Based on some off-list discussion back then, another check was added to
      compare the f_cred->user_ns.  This is not for security reasons, but was
      based on the idea that a FUSE device FD should be using the UID/GID
      mappings of its f_cred->user_ns, and those translations are done using
      fc->user_ns, which matches the f_cred->user_ns of the initial FUSE device
      FD thanks to the check in fuse_fill_super().  See also commit 8cb08329
      ("fuse: Support fuse filesystems outside of init_user_ns").
      
      But FUSE_DEV_IOC_CLONE is, at a higher level, a *cloning* operation that
      copies an existing context (with a weird API that involves first opening
      /dev/fuse, then tying the resulting new FUSE device FD to an existing FUSE
      instance).  So if an application is already passing FUSE FDs across userns
      boundaries and dealing with the resulting ID mapping complications somehow,
      it doesn't make much sense to block this cloning operation.
      
      I've heard that this check is an obstacle for some folks, and I don't see a
      good reason to keep it, so remove it.
      Signed-off-by: default avatarJann Horn <jannh@google.com>
      Signed-off-by: default avatarMiklos Szeredi <mszeredi@redhat.com>
      0618021e
    • Jiachen Zhang's avatar
      fuse: always revalidate rename target dentry · ccc031e2
      Jiachen Zhang authored
      The previous commit df8629af ("fuse: always revalidate if exclusive
      create") ensures that the dentries are revalidated on O_EXCL creates.  This
      commit complements it by also performing revalidation for rename target
      dentries.  Otherwise, a rename target file that only exists in kernel
      dentry cache but not in the filesystem will result in EEXIST if
      RENAME_NOREPLACE flag is used.
      Signed-off-by: default avatarJiachen Zhang <zhangjiachen.jaycee@bytedance.com>
      Signed-off-by: default avatarZhang Tianci <zhangtianci.1997@bytedance.com>
      Signed-off-by: default avatarMiklos Szeredi <mszeredi@redhat.com>
      ccc031e2
    • Miklos Szeredi's avatar
      fuse: add "expire only" mode to FUSE_NOTIFY_INVAL_ENTRY · 4f8d3702
      Miklos Szeredi authored
      Add a flag to entry expiration that lets the filesystem expire a dentry
      without kicking it out from the cache immediately.
      
      This makes a difference for overmounted dentries, where plain invalidation
      would detach all submounts before dropping the dentry from the cache.  If
      only expiry is set on the dentry, then any overmounts are left alone and
      until ->d_revalidate() is called.
      
      Note: ->d_revalidate() is not called for the case of following a submount,
      so invalidation will only be triggered for the non-overmounted case.  The
      dentry could also be mounted in a different mount instance, in which case
      any submounts will still be detached.
      Suggested-by: default avatarJakob Blomer <jblomer@cern.ch>
      Signed-off-by: default avatarMiklos Szeredi <mszeredi@redhat.com>
      4f8d3702
    • Fabio M. De Francesco's avatar
      fs/fuse: Replace kmap() with kmap_local_page() · a1db2f7e
      Fabio M. De Francesco authored
      The use of kmap() is being deprecated in favor of kmap_local_page().
      
      There are two main problems with kmap(): (1) It comes with an overhead as
      the mapping space is restricted and protected by a global lock for
      synchronization and (2) it also requires global TLB invalidation when the
      kmap’s pool wraps and it might block when the mapping space is fully
      utilized until a slot becomes available.
      
      With kmap_local_page() the mappings are per thread, CPU local, can take
      page faults, and can be called from any context (including interrupts).
      It is faster than kmap() in kernels with HIGHMEM enabled. Furthermore,
      the tasks can be preempted and, when they are scheduled to run again, the
      kernel virtual addresses are restored and still valid.
      
      Therefore, replace kmap() with kmap_local_page() in fuse_readdir_cached(), 
      it being the only call site of kmap() currently left in fs/fuse.
      
      Cc: "Venkataramanan, Anirudh" <anirudh.venkataramanan@intel.com>
      Suggested-by: default avatarIra Weiny <ira.weiny@intel.com>
      Signed-off-by: default avatarFabio M. De Francesco <fmdefrancesco@gmail.com>
      Signed-off-by: default avatarMiklos Szeredi <mszeredi@redhat.com>
      a1db2f7e
    • Miklos Szeredi's avatar
      fuse: lock inode unconditionally in fuse_fallocate() · 44361e8c
      Miklos Szeredi authored
      file_modified() must be called with inode lock held.  fuse_fallocate()
      didn't lock the inode in case of just FALLOC_KEEP_SIZE flags value, which
      resulted in a kernel Warning in notify_change().
      
      Lock the inode unconditionally, like all other fallocate implementations
      do.
      Reported-by: default avatarPengfei Xu <pengfei.xu@intel.com>
      Reported-and-tested-by: syzbot+462da39f0667b357c4b6@syzkaller.appspotmail.com
      Fixes: 4a6f278d ("fuse: add file_modified() to fallocate")
      Signed-off-by: default avatarMiklos Szeredi <mszeredi@redhat.com>
      44361e8c
  2. 21 Nov, 2022 1 commit
  3. 20 Nov, 2022 8 commits
  4. 19 Nov, 2022 8 commits
  5. 18 Nov, 2022 14 commits
    • Chen Jun's avatar
      Input: i8042 - fix leaking of platform device on module removal · 81cd7e84
      Chen Jun authored
      Avoid resetting the module-wide i8042_platform_device pointer in
      i8042_probe() or i8042_remove(), so that the device can be properly
      destroyed by i8042_exit() on module unload.
      
      Fixes: 9222ba68 ("Input: i8042 - add deferred probe support")
      Signed-off-by: default avatarChen Jun <chenjun102@huawei.com>
      Link: https://lore.kernel.org/r/20221109034148.23821-1-chenjun102@huawei.comSigned-off-by: default avatarDmitry Torokhov <dmitry.torokhov@gmail.com>
      81cd7e84
    • Linus Torvalds's avatar
      Merge tag 'io_uring-6.1-2022-11-18' of git://git.kernel.dk/linux · a66e4cbf
      Linus Torvalds authored
      Pull io_uring fixes from Jens Axboe:
       "This is mostly fixing issues around the poll rework, but also two
        tweaks for the multishot handling for accept and receive.
      
        All stable material"
      
      * tag 'io_uring-6.1-2022-11-18' of git://git.kernel.dk/linux:
        io_uring: disallow self-propelled ring polling
        io_uring: fix multishot recv request leaks
        io_uring: fix multishot accept request leaks
        io_uring: fix tw losing poll events
        io_uring: update res mask in io_poll_check_events
      a66e4cbf
    • Linus Torvalds's avatar
      Merge tag 'arm64-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/arm64/linux · 23a60a03
      Linus Torvalds authored
      Pull arm64 fixes from Catalin Marinas:
      
       - Fix a build error with CONFIG_CFI_CLANG + CONFIG_FTRACE when
         CONFIG_FUNCTION_GRAPH_TRACER is not enabled.
      
       - Fix a BUG_ON triggered by the page table checker due to incorrect
         file_map_count for non-leaf pmd/pud (the arm64
         pmd_user_accessible_page() not checking whether it's a leaf entry).
      
      * tag 'arm64-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/arm64/linux:
        arm64/mm: fix incorrect file_map_count for non-leaf pmd/pud
        arm64: ftrace: Define ftrace_stub_graph only with FUNCTION_GRAPH_TRACER
      23a60a03
    • Linus Torvalds's avatar
      Merge tag 'block-6.1-2022-11-18' of git://git.kernel.dk/linux · f4408c3d
      Linus Torvalds authored
      Pull block fixes from Jens Axboe:
      
       - NVMe pull request via Christoph:
            - Two more bogus nid quirks (Bean Huo, Tiago Dias Ferreira)
            - Memory leak fix in nvmet (Sagi Grimberg)
      
       - Regression fix for block cgroups pinning the wrong blkcg, causing
         leaks of cgroups and blkcgs (Chris)
      
       - UAF fix for drbd setup error handling (Dan)
      
       - Fix DMA alignment propagation in DM (Keith)
      
      * tag 'block-6.1-2022-11-18' of git://git.kernel.dk/linux:
        dm-log-writes: set dma_alignment limit in io_hints
        dm-integrity: set dma_alignment limit in io_hints
        block: make blk_set_default_limits() private
        dm-crypt: provide dma_alignment limit in io_hints
        block: make dma_alignment a stacking queue_limit
        nvmet: fix a memory leak in nvmet_auth_set_key
        nvme-pci: add NVME_QUIRK_BOGUS_NID for Netac NV7000
        drbd: use after free in drbd_create_device()
        nvme-pci: add NVME_QUIRK_BOGUS_NID for Micron Nitro
        blk-cgroup: properly pin the parent in blkcg_css_online
      f4408c3d
    • Linus Torvalds's avatar
      Merge tag 'drm-fixes-2022-11-19' of git://anongit.freedesktop.org/drm/drm · b5bf1d8a
      Linus Torvalds authored
      Pull drm fixes from Dave Airlie:
       "I guess the main question is are things settling down, and I'd say
        kinda, these are all pretty small fixes, nothing big stands out
        really, just seems to be quite a few of them.
      
        Mostly amdgpu and core fixes, with some i915, tegra, vc4, panel bits.
      
        core:
         - Fix potential memory leak in drm_dev_init()
         - Fix potential null-ptr-deref in drm_vblank_destroy_worker()
         - Revert hiding unregistered connectors from userspace, as it breaks
           on DP-MST
         - Add workaround for DP++ dual mode adaptors that don't support i2c
           subaddressing
      
        i915:
         - Fix uaf with lmem_userfault_list handling
      
        amdgpu:
         - gang submit fixes
         - Fix a possible memory leak in ganng submit error path
         - DP tunneling fixes
         - DCN 3.1 page flip fix
         - DCN 3.2.x fixes
         - DCN 3.1.4 fixes
         - Don't expose degamma on hardware that doesn't support it
         - BACO fixes for SMU 11.x
         - BACO fixes for SMU 13.x
         - Virtual display fix for devices with no display hardware
      
        amdkfd:
         - Memory limit regression fix
      
        tegra:
         - tegra20 GART fix
      
        vc4:
         - Fix error handling in vc4_atomic_commit_tail()
      
        lima:
         - Set lima's clkname corrrectly when regulator is missing
      
        panel:
         - Set bpc for logictechno panels"
      
      * tag 'drm-fixes-2022-11-19' of git://anongit.freedesktop.org/drm/drm: (28 commits)
        gpu: host1x: Avoid trying to use GART on Tegra20
        drm/display: Don't assume dual mode adaptors support i2c sub-addressing
        drm/amd/pm: fix SMU13 runpm hang due to unintentional workaround
        drm/amd/pm: enable runpm support over BACO for SMU13.0.7
        drm/amd/pm: enable runpm support over BACO for SMU13.0.0
        drm/amdgpu: there is no vbios fb on devices with no display hw (v2)
        drm/amdkfd: Fix a memory limit issue
        drm/amdgpu: disable BACO support on more cards
        drm/amd/display: don't enable DRM CRTC degamma property for DCE
        drm/amd/display: Set max for prefetch lines on dcn32
        drm/amd/display: use uclk pstate latency for fw assisted mclk validation dcn32
        drm/amd/display: Fix prefetch calculations for dcn32
        drm/amd/display: Fix optc2_configure warning on dcn314
        drm/amd/display: Fix calculation for cursor CAB allocation
        Revert "drm: hide unregistered connectors from GETCONNECTOR IOCTL"
        drm/amd/display: Support parsing VRAM info v3.0 from VBIOS
        drm/amd/display: Fix invalid DPIA AUX reply causing system hang
        drm/amdgpu: Add psp_13_0_10_ta firmware to modinfo
        drm/amd/display: Add HUBP surface flip interrupt handler
        drm/amd/display: Fix access timeout to DPIA AUX at boot time
        ...
      b5bf1d8a
    • Linus Torvalds's avatar
      Merge tag 's390-6.1-5' of git://git.kernel.org/pub/scm/linux/kernel/git/s390/linux · ab290ead
      Linus Torvalds authored
      Pull s390 fixes from Alexander Gordeev:
      
       - Fix deadlock in discontiguous saved segments (DCSS) block device
         driver. When adding a disk and scanning partitions the scan would not
         break out early without a missed flag.
      
       - Avoid using global register variable for current_stack_pointer due to
         an old bug in gcc versions prior to gcc-8.4. Due to this bug a broken
         code is generated, which leads to stack corruptions.
      
      * tag 's390-6.1-5' of git://git.kernel.org/pub/scm/linux/kernel/git/s390/linux:
        s390: avoid using global register for current_stack_pointer
        s390/dcssblk: fix deadlock when adding a DCSS
      ab290ead
    • Linus Torvalds's avatar
      Merge tag 'for-6.1/dm-fixes-2' of... · 5556a78c
      Linus Torvalds authored
      Merge tag 'for-6.1/dm-fixes-2' of git://git.kernel.org/pub/scm/linux/kernel/git/device-mapper/linux-dm
      
      Pull device mapper fixes from Mike Snitzer:
      
       - Fix misbehavior if list_versions DM ioctl races with module loading
      
       - Fix missing decrement of no_sleep_enabled if dm_bufio_client_create
         failed
      
       - Allow DM integrity devices to be activated in read-only mode
      
      * tag 'for-6.1/dm-fixes-2' of git://git.kernel.org/pub/scm/linux/kernel/git/device-mapper/linux-dm:
        dm integrity: clear the journal on suspend
        dm integrity: flush the journal on suspend
        dm bufio: Fix missing decrement of no_sleep_enabled if dm_bufio_client_create failed
        dm ioctl: fix misbehavior if list_versions races with module loading
      5556a78c
    • Dave Airlie's avatar
      Merge tag 'drm/tegra/for-6.1-rc6' of https://gitlab.freedesktop.org/drm/tegra into drm-fixes · b1010b93
      Dave Airlie authored
      drm/tegra: Fixes for v6.1-rc6
      
      This contains a single fix that avoids using the GART on Tegra20 because
      it doesn't work well with the way the Tegra DRM driver tries to use it.
      Signed-off-by: default avatarDave Airlie <airlied@redhat.com>
      
      From: Thierry Reding <thierry.reding@gmail.com>
      Link: https://patchwork.freedesktop.org/patch/msgid/20221118121614.3511110-1-thierry.reding@gmail.com
      b1010b93
    • Linus Torvalds's avatar
      Merge tag 'usb-6.1-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/usb · 950a9f56
      Linus Torvalds authored
      Pull USB driver fixes from Greg KH:
       "Here are a number of USB driver fixes and new device ids for 6.1-rc6.
        Included in here are:
      
         - new usb-serial device ids
      
         - dwc3 driver fixes for reported problems
      
         - cdns3 driver fixes
      
         - new USB device quirks
      
         - typec driver fixes
      
         - extcon USB typec driver fix
      
        All of these have been in linux-next with no reported issues"
      
      * tag 'usb-6.1-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/usb:
        USB: serial: option: add u-blox LARA-L6 modem
        USB: serial: option: add u-blox LARA-R6 00B modem
        USB: serial: option: remove old LARA-R6 PID
        USB: serial: option: add Fibocom FM160 0x0111 composition
        usb: add NO_LPM quirk for Realforce 87U Keyboard
        usb: cdns3: host: fix endless superspeed hub port reset
        usb: chipidea: fix deadlock in ci_otg_del_timer
        usb: dwc3: Do not get extcon device when usb-role-switch is used
        usb: typec: tipd: Prevent uninitialized event{1,2} in IRQ handler
        usb: typec: mux: Enter safe mode only when pins need to be reconfigured
        extcon: usbc-tusb320: Call the Type-C IRQ handler only if a port is registered
        Revert "usb: dwc3: disable USB core PHY management"
        usb: dwc3: gadget: Return -ESHUTDOWN on ep disable
        USB: bcma: Make GPIO explicitly optional
        USB: serial: option: add Sierra Wireless EM9191
      950a9f56
    • Linus Torvalds's avatar
      Merge tag 'staging-6.1-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/staging · 12fe29ee
      Linus Torvalds authored
      Pull staging driver fix from Greg KH:
       "Here is a single staging driver fix for 6.1-rc6.
      
        It resolves a bogus signed character test as pointed out, and fixed
        by, Jason in the rtl8192e driver
      
        It has been in linux-next for a few weeks now with no reported
        problems"
      
      * tag 'staging-6.1-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/staging:
        staging: rtl8192e: remove bogus ssid character sign test
      12fe29ee
    • Liu Shixin's avatar
      arm64/mm: fix incorrect file_map_count for non-leaf pmd/pud · 5b47348f
      Liu Shixin authored
      The page table check trigger BUG_ON() unexpectedly when collapse hugepage:
      
       ------------[ cut here ]------------
       kernel BUG at mm/page_table_check.c:82!
       Internal error: Oops - BUG: 00000000f2000800 [#1] SMP
       Dumping ftrace buffer:
          (ftrace buffer empty)
       Modules linked in:
       CPU: 6 PID: 68 Comm: khugepaged Not tainted 6.1.0-rc3+ #750
       Hardware name: linux,dummy-virt (DT)
       pstate: 60000005 (nZCv daif -PAN -UAO -TCO -DIT -SSBS BTYPE=--)
       pc : page_table_check_clear.isra.0+0x258/0x3f0
       lr : page_table_check_clear.isra.0+0x240/0x3f0
      [...]
       Call trace:
        page_table_check_clear.isra.0+0x258/0x3f0
        __page_table_check_pmd_clear+0xbc/0x108
        pmdp_collapse_flush+0xb0/0x160
        collapse_huge_page+0xa08/0x1080
        hpage_collapse_scan_pmd+0xf30/0x1590
        khugepaged_scan_mm_slot.constprop.0+0x52c/0xac8
        khugepaged+0x338/0x518
        kthread+0x278/0x2f8
        ret_from_fork+0x10/0x20
      [...]
      
      Since pmd_user_accessible_page() doesn't check if a pmd is leaf, it
      decrease file_map_count for a non-leaf pmd comes from collapse_huge_page().
      and so trigger BUG_ON() unexpectedly.
      
      Fix this problem by using pmd_leaf() insteal of pmd_present() in
      pmd_user_accessible_page(). Moreover, use pud_leaf() for
      pud_user_accessible_page() too.
      
      Fixes: 42b25471 ("arm64/mm: enable ARCH_SUPPORTS_PAGE_TABLE_CHECK")
      Reported-by: default avatarDenys Vlasenko <dvlasenk@redhat.com>
      Signed-off-by: default avatarLiu Shixin <liushixin2@huawei.com>
      Reviewed-by: default avatarDavid Hildenbrand <david@redhat.com>
      Acked-by: default avatarPasha Tatashin <pasha.tatashin@soleen.com>
      Reviewed-by: default avatarKefeng Wang <wangkefeng.wang@huawei.com>
      Acked-by: default avatarWill Deacon <will@kernel.org>
      Link: https://lore.kernel.org/r/20221117075602.2904324-2-liushixin2@huawei.comSigned-off-by: default avatarCatalin Marinas <catalin.marinas@arm.com>
      5b47348f
    • Linus Torvalds's avatar
      Merge tag 'tty-6.1-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/tty · 09389357
      Linus Torvalds authored
      Pull tty/serial driver fixes from Greg KH:
       "Here are a number of small tty and serial driver fixes for 6.1-rc6.
        They all resolve reported problems:
      
         - kernel doc build problems with the -rc1 serial driver documentation
           update
      
         - n_gsm reported problems
      
         - imx serial driver missing callback
      
         - lots of tiny 8250 driver fixes for reported issues.
      
        All of these have been in linux-next for over a week with no reported
        problems"
      
      * tag 'tty-6.1-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/tty:
        docs/driver-api/miscellaneous: Remove kernel-doc of serial_core.c
        serial: 8250: Flush DMA Rx on RLSI
        serial: 8250_lpss: Use 16B DMA burst with Elkhart Lake
        serial: 8250_lpss: Configure DMA also w/o DMA filter
        serial: 8250: Fall back to non-DMA Rx if IIR_RDI occurs
        tty: n_gsm: fix sleep-in-atomic-context bug in gsm_control_send
        Revert "tty: n_gsm: replace kicktimer with delayed_work"
        Revert "tty: n_gsm: avoid call of sleeping functions from atomic context"
        serial: imx: Add missing .thaw_noirq hook
        tty: serial: fsl_lpuart: don't break the on-going transfer when global reset
        serial: 8250: omap: Flush PM QOS work on remove
        serial: 8250: omap: Fix unpaired pm_runtime_put_sync() in omap8250_remove()
        serial: 8250_omap: remove wait loop from Errata i202 workaround
        serial: 8250: omap: Fix missing PM runtime calls for omap8250_set_mctrl()
        serial: 8250: 8250_omap: Avoid RS485 RTS glitch on ->set_termios()
      09389357
    • Linus Torvalds's avatar
      Merge tag 'driver-core-6.1-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/driver-core · 63c8c0d7
      Linus Torvalds authored
      Pull driver core fixes from Greg KH:
       "Here are two small driver core fixes for 6.1-rc6:
      
         - utsname fix, this one should already be in your tree as it came
           from a different tree earlier.
      
         - kernfs bugfix for a much reported syzbot report that seems to keep
           getting triggered.
      
        Both of these have been in linux-next for a while with no reported
        issues"
      
      * tag 'driver-core-6.1-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/driver-core:
        kernfs: Fix spurious lockdep warning in kernfs_find_and_get_node_by_id()
        kernel/utsname_sysctl.c: Add missing enum uts_proc value
      63c8c0d7
    • Linus Torvalds's avatar
      Merge tag 'char-misc-6.1-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/char-misc · 1f63d1a1
      Linus Torvalds authored
      Pull char/misc driver fixes from Greg KH:
       "Here are some small char/misc and other driver fixes for 6.1-rc6 to
        resolve some reported problems. Included in here are:
      
         - iio driver fixes
      
         - binder driver fix
      
         - nvmem driver fix
      
         - vme_vmci information leak fix
      
         - parport fix
      
         - slimbus configuration fix
      
         - coreboot firmware bugfix
      
         - speakup build fix and crash fix
      
        All of these have been in linux-next for a while with no reported
        issues"
      
      * tag 'char-misc-6.1-rc6' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/char-misc: (22 commits)
        firmware: coreboot: Register bus in module init
        nvmem: u-boot-env: fix crc32_data_offset on redundant u-boot-env
        slimbus: qcom-ngd: Fix build error when CONFIG_SLIM_QCOM_NGD_CTRL=y && CONFIG_QCOM_RPROC_COMMON=m
        docs: update mediator contact information in CoC doc
        slimbus: stream: correct presence rate frequencies
        nvmem: lan9662-otp: Fix compatible string
        binder: validate alloc->mm in ->mmap() handler
        parport_pc: Avoid FIFO port location truncation
        siox: fix possible memory leak in siox_device_add()
        misc/vmw_vmci: fix an infoleak in vmci_host_do_receive_datagram()
        speakup: replace utils' u_char with unsigned char
        speakup: fix a segfault caused by switching consoles
        tools: iio: iio_generic_buffer: Fix read size
        iio: imu: bno055: uninitialized variable bug in bno055_trigger_handler()
        iio: adc: at91_adc: fix possible memory leak in at91_adc_allocate_trigger()
        iio: adc: mp2629: fix potential array out of bound access
        iio: adc: mp2629: fix wrong comparison of channel
        iio: pressure: ms5611: changed hardcoded SPI speed to value limited
        iio: pressure: ms5611: fixed value compensation bug
        iio: accel: bma400: Ensure VDDIO is enable defore reading the chip ID.
        ...
      1f63d1a1