1. 07 Aug, 2023 2 commits
    • Bob Peterson's avatar
      gfs2: Don't use filemap_splice_read · 0be84321
      Bob Peterson authored
      Starting with patch 2cb1e089, gfs2 started using the new function
      filemap_splice_read rather than the old (and subsequently deleted)
      function generic_file_splice_read.
      
      filemap_splice_read works by taking references to a number of folios in
      the page cache and splicing those folios into a pipe.  The folios are
      then read from the pipe and the folio references are dropped.  This can
      take an arbitrary amount of time.  We cannot allow that in gfs2 because
      those folio references will pin the inode glock to the node and prevent
      it from being demoted, which can lead to cluster-wide deadlocks.
      
      Instead, use copy_splice_read.
      
      (In addition, the old generic_file_splice_read called into ->read_iter,
      which called gfs2_file_read_iter, which took the inode glock during the
      operation.  The new filemap_splice_read interface does not take the
      inode glock anymore.  This is fixable, but it still wouldn't prevent
      cluster-wide deadlocks.)
      
      Fixes: 2cb1e089 ("splice: Use filemap_splice_read() instead of generic_file_splice_read()")
      Signed-off-by: default avatarBob Peterson <rpeterso@redhat.com>
      Signed-off-by: default avatarAndreas Gruenbacher <agruenba@redhat.com>
      0be84321
    • Andreas Gruenbacher's avatar
      gfs2: Fix freeze consistency check in gfs2_trans_add_meta · 2cbd8064
      Andreas Gruenbacher authored
      Function gfs2_trans_add_meta() checks for the SDF_FROZEN flag to make
      sure that no buffers are added to a transaction while the filesystem is
      frozen.  With the recent freeze/thaw rework, the SDF_FROZEN flag is
      cleared after thaw_super() is called, which is sufficient for
      serializing freeze/thaw.
      
      However, other filesystem operations started after thaw_super() may now
      be calling gfs2_trans_add_meta() before the SDF_FROZEN flag is cleared,
      which will trigger the SDF_FROZEN check in gfs2_trans_add_meta().  Fix
      that by checking the s_writers.frozen state instead.
      
      In addition, make sure not to call gfs2_assert_withdraw() with the
      sd_log_lock spin lock held.  Check for a withdrawn filesystem before
      checking for a frozen filesystem, and don't pin/add buffers to the
      current transaction in case of a failure in either case.
      Signed-off-by: default avatarAndreas Gruenbacher <agruenba@redhat.com>
      Signed-off-by: default avatarBob Peterson <rpeterso@redhat.com>
      2cbd8064
  2. 04 Jul, 2023 14 commits
    • Linus Torvalds's avatar
      Merge tag 'gfs2-v6.4-rc5-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/gfs2/linux-gfs2 · 94c76955
      Linus Torvalds authored
      Pull gfs2 updates from Andreas Gruenbacher:
      
       - Move the freeze/thaw logic from glock callback context to process /
         worker thread context to prevent deadlocks
      
       - Fix a quota reference couting bug in do_qc()
      
       - Carry on deallocating inodes even when gfs2_rindex_update() fails
      
       - Retry filesystem-internal reads when they are interruped by a signal
      
       - Eliminate kmap_atomic() in favor of kmap_local_page() /
         memcpy_{from,to}_page()
      
       - Get rid of noop_direct_IO
      
       - And a few more minor fixes and cleanups
      
      * tag 'gfs2-v6.4-rc5-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/gfs2/linux-gfs2: (23 commits)
        gfs2: Add quota_change type
        gfs2: Use memcpy_{from,to}_page where appropriate
        gfs2: Convert remaining kmap_atomic calls to kmap_local_page
        gfs2: Replace deprecated kmap_atomic with kmap_local_page
        gfs: Get rid of unnucessary locking in inode_go_dump
        gfs2: gfs2_freeze_lock_shared cleanup
        gfs2: Replace sd_freeze_state with SDF_FROZEN flag
        gfs2: Rework freeze / thaw logic
        gfs2: Rename SDF_{FS_FROZEN => FREEZE_INITIATOR}
        gfs2: Reconfiguring frozen filesystem already rejected
        gfs2: Rename gfs2_freeze_lock{ => _shared }
        gfs2: Rename the {freeze,thaw}_super callbacks
        gfs2: Rename remaining "transaction" glock references
        gfs2: retry interrupted internal reads
        gfs2: Fix possible data races in gfs2_show_options()
        gfs2: Fix duplicate should_fault_in_pages() call
        gfs2: set FMODE_CAN_ODIRECT instead of a dummy direct_IO method
        gfs2: Don't remember delete unless it's successful
        gfs2: Update rl_unlinked before releasing rgrp lock
        gfs2: Fix gfs2_qa_get imbalance in gfs2_quota_hold
        ...
      94c76955
    • Linus Torvalds's avatar
      Merge tag 'pm-6.5-rc1-2' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm · ccf46d85
      Linus Torvalds authored
      Pull more power management updates from Rafael Wysocki:
       "These add support for new hardware (ap807 and AM62A7), fix several
        issues in cpufreq drivers and in the operating performance points
        (OPP) framework, fix up intel_idle after recent changes and add
        documentation.
      
        Specifics:
      
         - Add missing __init annotation to one function in the intel_idle
           drvier (Rafael Wysocki)
      
         - Make intel_pstate use a correct scaling factor when mapping HWP
           performance levels to frequency values on hybrid-capable systems
           with disabled E-cores (Srinivas Pandruvada)
      
         - Fix Kconfig dependencies of the cpufreq-dt-platform driver (Viresh
           Kumar)
      
         - Add support to build cpufreq-dt-platdev as a module (Zhipeng Wang)
      
         - Don't allocate Sparc's cpufreq_driver dynamically (Viresh Kumar)
      
         - Add support for TI's AM62A7 platform (Vibhore Vardhan)
      
         - Add support for Armada's ap807 platform (Russell King (Oracle))
      
         - Add support for StarFive JH7110 SoC (Mason Huo)
      
         - Fix voltage selection for Mediatek Socs (Daniel Golle)
      
         - Fix error handling in Tegra's cpufreq driver (Christophe JAILLET)
      
         - Document Qualcomm's IPQ8074 in DT bindings (Robert Marko)
      
         - Don't warn for disabling a non-existing frequency for imx6q cpufreq
           driver (Christoph Niedermaier)
      
         - Use dev_err_probe() in Qualcomm's cpufreq driver (Andrew Halaney)
      
         - Simplify performance state related logic in the OPP core (Viresh
           Kumar)
      
         - Fix use-after-free and improve locking around lazy_opp_tables
           (Viresh Kumar, Stephan Gerhold)
      
         - Minor cleanups - using dev_err_probe() and rate-limiting debug
           messages (Andrew Halaney, Adrián Larumbe)"
      
      * tag 'pm-6.5-rc1-2' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm: (23 commits)
        cpufreq: intel_pstate: Fix scaling for hybrid-capable systems with disabled E-cores
        cpufreq: Make CONFIG_CPUFREQ_DT_PLATDEV depend on OF
        intel_idle: Add __init annotation to matchup_vm_state_with_baremetal()
        OPP: Properly propagate error along when failing to get icc_path
        OPP: Use dev_err_probe() when failing to get icc_path
        cpufreq: qcom-cpufreq-hw: Use dev_err_probe() when failing to get icc paths
        cpufreq: mediatek: correct voltages for MT7622 and MT7623
        cpufreq: armada-8k: add ap807 support
        OPP: Simplify the over-designed pstate <-> level dance
        OPP: pstate is only valid for genpd OPP tables
        OPP: don't drop performance constraint on OPP table removal
        OPP: Protect `lazy_opp_tables` list with `opp_table_lock`
        OPP: Staticize `lazy_opp_tables` in of.c
        cpufreq: dt-platdev: Support building as module
        opp: Fix use-after-free in lazy_opp_tables after probe deferral
        dt-bindings: cpufreq: qcom-cpufreq-nvmem: document IPQ8074
        cpufreq: dt-platdev: Blacklist ti,am62a7 SoC
        cpufreq: ti-cpufreq: Add support for AM62A7
        OPP: rate-limit debug messages when no change in OPP is required
        cpufreq: imx6q: don't warn for disabling a non-existing frequency
        ...
      ccf46d85
    • Linus Torvalds's avatar
      Merge tag 'clk-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/clk/linux · b869e9f4
      Linus Torvalds authored
      Pull more clk updates from Stephen Boyd:
       "Another set of clk driver updates and fixes for the merge window. The
        driver updates needed more time to bake in linux-next.
      
        Updates:
         - Support for more clk controllers in Qualcomm SoCs such as SM8350,
           SM8450, SDX75, SC8280XP, and IPQ9574
         - Runtime PM enablement of some more Qualcomm clk controllers
         - Various fixes to Qualcomm clk driver data to use correct clk_ops
           and to check halt bits properly
         - AT91 updates to modernize with clk_parent_data structures
      
        Fixes:
         - Remove 'syscon' from dt binding fix for ti,j721e-system-controller
         - Fix determine rate in the Tegra driver that got wrecked by the
           refactorting of muxes this merge window"
      
      * tag 'clk-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/clk/linux: (69 commits)
        clk: tegra: Avoid calling an uninitialized function
        dt-bindings: mfd: ti,j721e-system-controller: Remove syscon from example
        clk: at91: sama7g5: s/ep_chg_chg_id/ep_chg_id
        clk: at91: sama7g5: switch to parent_hw and parent_data
        clk: at91: sckc: switch to parent_data/parent_hw
        clk: at91: clk-sam9x60-pll: add support for parent_hw
        clk: at91: clk-utmi: add support for parent_hw
        clk: at91: clk-system: add support for parent_hw
        clk: at91: clk-programmable: add support for parent_hw
        clk: at91: clk-peripheral: add support for parent_hw
        clk: at91: clk-master: add support for parent_hw
        clk: at91: clk-generated: add support for parent_hw
        clk: at91: clk-main: add support for parent_data/parent_hw
        clk: qcom: gcc-sc8280xp: Add runtime PM
        clk: qcom: gpucc-sc8280xp: Add runtime PM
        clk: qcom: mmcc-msm8974: fix MDSS_GDSC power flags
        clk: qcom: gpucc-sm6375: Enable runtime pm
        dt-bindings: clock: sm6375-gpucc: Add VDD_GX
        clk: qcom: gcc-sm6115: Add missing PLL config properties
        clk: qcom: clk-alpha-pll: Add a way to update some bits of test_ctl(_hi)
        ...
      b869e9f4
    • Linus Torvalds's avatar
      Merge tag 'firewire-6.5-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/ieee1394/linux1394 · 406fb9eb
      Linus Torvalds authored
      Pull firewire updates from Takashi Sakamoto:
       "This consist of three parts; UAPI update, OHCI driver update, and
        several bug fixes.
      
        Firstly, the 1394 OHCI specification defines method to retrieve
        hardware time stamps for asynchronous communication, which was
        previously unavailable in user space. This adds new events to the
        UAPI, allowing applications to retrieve the time when asynchronous
        packet are received and sent. The new events are tested in the
        bleeding edge of libhinawa and look to work well. The new version of
        libhinawa will be released after current merge window is closed:
      
          https://git.kernel.org/pub/scm/libs/ieee1394/libhinawa.git/
      
        Secondly, the FireWire stack includes a PCM device driver for 1394
        OHCI hardware, This change modernizes the driver by managed resource
        (devres) framework.
      
        Lastly, bug fixes for firewire-net and firewire-core"
      
      * tag 'firewire-6.5-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/ieee1394/linux1394: (25 commits)
        firewire: net: fix use after free in fwnet_finish_incoming_packet()
        firewire: core: obsolete usage of GFP_ATOMIC at building node tree
        firewire: ohci: release buffer for AR req/resp contexts when managed resource is released
        firewire: ohci: use devres for content of configuration ROM
        firewire: ohci: use devres for IT, IR, AT/receive, and AT/request contexts
        firewire: ohci: use devres for list of isochronous contexts
        firewire: ohci: use devres for requested IRQ
        firewire: ohci: use devres for misc DMA buffer
        firewire: ohci: use devres for MMIO region mapping
        firewire: ohci: use devres for PCI-related resources
        firewire: ohci: use devres for memory object of ohci structure
        firewire: fix warnings to generate UAPI documentation
        firewire: fix build failure due to missing module license
        firewire: cdev: implement new event relevant to phy packet with time stamp
        firewire: cdev: add new event to notify phy packet with time stamp
        firewire: cdev: code refactoring to dispatch event for phy packet
        firewire: cdev: implement new event to notify response subaction with time stamp
        firewire: cdev: add new event to notify response subaction with time stamp
        firewire: cdev: code refactoring to operate event of response
        firewire: core: implement variations to send request and wait for response with time stamp
        ...
      406fb9eb
    • Linus Torvalds's avatar
      module: fix init_module_from_file() error handling · f1962207
      Linus Torvalds authored
      Vegard Nossum pointed out two different problems with the error handling
      in init_module_from_file():
      
       (a) the idempotent loading code didn't clean up properly in some error
           cases, leaving the on-stack 'struct idempotent' element still in
           the hash table
      
       (b) failure to read the module file would nonsensically update the
           'invalid_kread_bytes' stat counter with the error value
      
      The first error is quite nasty, in that it can then cause subsequent
      idempotent loads of that same file to access stale stack contents of the
      previous failure.  The case may not happen in any normal situation
      (explaining all the "Tested-by's on the original change), and requires
      admin privileges, but syzkaller triggers random bad behavior as a
      result:
      
          BUG: soft lockup in sys_finit_module
          BUG: unable to handle kernel paging request in init_module_from_file
          general protection fault in init_module_from_file
          INFO: task hung in init_module_from_file
          KASAN: out-of-bounds Read in init_module_from_file
          KASAN: slab-out-of-bounds Read in init_module_from_file
          ...
      
      The second error is fairly benign and just leads to nonsensical stats
      (and has been around since the debug stats were added).
      
      Vegard also provided a patch for the idempotent loading issue, but I'd
      rather re-organize the code and make it more legible using another level
      of helper functions than add the usual "goto out" error handling.
      
      Link: https://lore.kernel.org/lkml/20230704100852.23452-1-vegard.nossum@oracle.com/
      Fixes: 9b9879fc ("modules: catch concurrent module loads, treat them as idempotent")
      Reported-by: default avatarVegard Nossum <vegard.nossum@oracle.com>
      Reported-by: default avatarHarshit Mogalapalli <harshit.m.mogalapalli@oracle.com>
      Reported-by: syzbot+9c2bdc9d24e4a7abe741@syzkaller.appspotmail.com
      Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
      f1962207
    • Rafael J. Wysocki's avatar
      Merge branches 'pm-cpufreq' and 'pm-cpuidle' · 40c565a4
      Rafael J. Wysocki authored
      Merge CPU power management updates for 6.5-rc1:
      
       - Add missing __init annotation to one function in the intel_idle
         drvier (Rafael Wysocki).
      
       - Make intel_pstate use a correct scaling factor when mapping HWP
         performance levels to frequency values on hybrid-capable systems
         with disabled E-cores (Srinivas Pandruvada).
      
       - Fix Kconfig dependencies of the cpufreq-dt-platform driver (Viresh
         Kumar).
      
       - Add support to build cpufreq-dt-platdev as a module (Zhipeng Wang).
      
       - Don't allocate Sparc's cpufreq_driver dynamically (Viresh Kumar).
      
       - Add support for TI's AM62A7 platform (Vibhore Vardhan).
      
       - Add support for Armada's ap807 platform (Russell King (Oracle)).
      
       - Add support for StarFive JH7110 SoC (Mason Huo).
      
       - Fix voltage selection for Mediatek Socs (Daniel Golle).
      
       - Fix error handling in Tegra's cpufreq driver (Christophe JAILLET).
      
       - Document Qualcomm's IPQ8074 in DT bindings (Robert Marko).
      
       - Don't warn for disabling a non-existing frequency for imx6q cpufreq
         driver (Christoph Niedermaier).
      
       - Use dev_err_probe() in Qualcomm's cpufreq driver (Andrew Halaney).
      
      * pm-cpufreq:
        cpufreq: intel_pstate: Fix scaling for hybrid-capable systems with disabled E-cores
        cpufreq: Make CONFIG_CPUFREQ_DT_PLATDEV depend on OF
        cpufreq: qcom-cpufreq-hw: Use dev_err_probe() when failing to get icc paths
        cpufreq: mediatek: correct voltages for MT7622 and MT7623
        cpufreq: armada-8k: add ap807 support
        cpufreq: dt-platdev: Support building as module
        dt-bindings: cpufreq: qcom-cpufreq-nvmem: document IPQ8074
        cpufreq: dt-platdev: Blacklist ti,am62a7 SoC
        cpufreq: ti-cpufreq: Add support for AM62A7
        cpufreq: imx6q: don't warn for disabling a non-existing frequency
        cpufreq: sparc: Don't allocate cpufreq_driver dynamically
        cpufreq: tegra194: Fix an error handling path in tegra194_cpufreq_probe()
        cpufreq: dt-platdev: Add JH7110 SOC to the allowlist
      
      * pm-cpuidle:
        intel_idle: Add __init annotation to matchup_vm_state_with_baremetal()
      40c565a4
    • Thierry Reding's avatar
      clk: tegra: Avoid calling an uninitialized function · f679e89a
      Thierry Reding authored
      Commit 493ffb04 ("clk: tegra: super: Switch to determine_rate")
      replaced clk_super_round_rate() by clk_super_determine_rate(), but
      didn't update one callsite that was explicitly calling the old
      tegra_clk_super_ops.round_rate() function, which was now NULL. This
      resulted in a crash on Tegra30 systems during early boot.
      
      Switch this callsite over to the clk_super_determine_rate() equivalent
      to avoid the crash.
      
      Fixes: 493ffb04 ("clk: tegra: super: Switch to determine_rate")
      Tested-by: default avatarDmitry Osipenko <digetx@gmail.com>
      Signed-off-by: default avatarThierry Reding <treding@nvidia.com>
      Link: https://lore.kernel.org/r/20230630130748.840729-1-thierry.reding@gmail.comSigned-off-by: default avatarStephen Boyd <sboyd@kernel.org>
      f679e89a
    • Linus Torvalds's avatar
      mm: don't do validate_mm() unnecessarily and without mmap locking · b5641a5d
      Linus Torvalds authored
      This is an addition to commit ae80b404 ("mm: validate the mm before
      dropping the mmap lock"), because it turns out there were two problems,
      but lockdep just stopped complaining after finding the first one.
      
      The do_vmi_align_munmap() function now drops the mmap lock after doing
      the validate_mm() call, but it turns out that one of the callers then
      immediately calls validate_mm() again.
      
      That's both a bit silly, and now (again) happens without the mmap lock
      held.
      
      So just remove that validate_mm() call from the caller, but make sure to
      not lose any coverage by doing that mm sanity checking in the error path
      of do_vmi_align_munmap() too.
      Reported-and-tested-by: default avatarkernel test robot <oliver.sang@intel.com>
      Link: https://lore.kernel.org/lkml/ZKN6CdkKyxBShPHi@xsang-OptiPlex-9020/
      Fixes: 408579cd ("mm: Update do_vmi_align_munmap() return semantics")
      Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
      b5641a5d
    • SeongJae Park's avatar
      arch/arm64/mm/fault: Fix undeclared variable error in do_page_fault() · 24be4d0b
      SeongJae Park authored
      Commit ae870a68 ("arm64/mm: Convert to using
      lock_mm_and_find_vma()") made do_page_fault() to use 'vma' even if
      CONFIG_PER_VMA_LOCK is not defined, but the declaration is still in the
      ifdef.
      
      As a result, building kernel without the config fails with undeclared
      variable error as below:
      
          arch/arm64/mm/fault.c: In function 'do_page_fault':
          arch/arm64/mm/fault.c:624:2: error: 'vma' undeclared (first use in this function); did you mean 'vmap'?
            624 |  vma = lock_mm_and_find_vma(mm, addr, regs);
                |  ^~~
                |  vmap
      
      Fix it by moving the declaration out of the ifdef.
      
      Fixes: ae870a68 ("arm64/mm: Convert to using lock_mm_and_find_vma()")
      Signed-off-by: default avatarSeongJae Park <sj@kernel.org>
      Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
      24be4d0b
    • Linus Torvalds's avatar
      Merge tag 'block-6.5-2023-07-03' of git://git.kernel.dk/linux · e50df249
      Linus Torvalds authored
      Pull more block updates from Jens Axboe:
       "Mostly items that came in a bit late for the initial pull request,
        wanted to make sure they had the appropriate amount of linux-next soak
        before going upstream.
      
        Outside of stragglers, just generic fixes for either merge window
        items, or longer standing bugs"
      
      * tag 'block-6.5-2023-07-03' of git://git.kernel.dk/linux: (25 commits)
        md/raid0: add discard support for the 'original' layout
        nvme: disable controller on reset state failure
        nvme: sync timeout work on failed reset
        nvme: ensure unquiesce on teardown
        cdrom/gdrom: Fix build error
        nvme: improved uring polling
        block: add request polling helper
        nvme-mpath: fix I/O failure with EAGAIN when failing over I/O
        nvme: host: fix command name spelling
        blk-sysfs: add a new attr_group for blk_mq
        blk-iocost: move wbt_enable/disable_default() out of spinlock
        blk-wbt: cleanup rwb_enabled() and wbt_disabled()
        blk-wbt: remove dead code to handle wbt enable/disable with io inflight
        blk-wbt: don't create wbt sysfs entry if CONFIG_BLK_WBT is disabled
        blk-mq: fix two misuses on RQF_USE_SCHED
        blk-throttle: Fix io statistics for cgroup v1
        bcache: Fix bcache device claiming
        bcache: Alloc holder object before async registration
        raid10: avoid spin_lock from fastpath from raid10_unplug()
        md: fix 'delete_mutex' deadlock
        ...
      e50df249
    • Linus Torvalds's avatar
      Merge tag 'io_uring-6.5-2023-07-03' of git://git.kernel.dk/linux · 4f528753
      Linus Torvalds authored
      Pull io_uring fixes from Jens Axboe:
       "The fix for the msghdr->msg_inq assigned value being wrong, using -1
        instead of -1U for the signed type.
      
        Also a fix for ensuring when we're trying to run task_work on an
        exiting task, that we wait for it. This is not really a correctness
        thing as the work is being canceled, but it does help with ensuring
        file descriptors are closed when the task has exited."
      
      * tag 'io_uring-6.5-2023-07-03' of git://git.kernel.dk/linux:
        io_uring: flush offloaded and delayed task_work on exit
        io_uring: remove io_fallback_tw() forward declaration
        io_uring/net: use proper value for msg_inq
      4f528753
    • Linus Torvalds's avatar
      Merge tag 'hsi-for-6.5' of git://git.kernel.org/pub/scm/linux/kernel/git/sre/linux-hsi · 69c9f230
      Linus Torvalds authored
      Pull HSI updates from Sebastian Reichel:
      
       - fix build warning with W=1
      
       - drop error handling for debugfs
      
      * tag 'hsi-for-6.5' of git://git.kernel.org/pub/scm/linux/kernel/git/sre/linux-hsi:
        HSI: omap_ssi_port: Drop error checking for debugfs_create_dir
        HSI: fix ssi_waketest() declaration
      69c9f230
    • Linus Torvalds's avatar
      Merge tag 'for-v6.5' of git://git.kernel.org/pub/scm/linux/kernel/git/sre/linux-power-supply · 0df24138
      Linus Torvalds authored
      Pull power supply and reset updates from Sebastian Reichel:
      
       - Add new Qualcomm PMI8998/PM660 SMB2 charger
      
       - bq256xx: support systems without thermistors
      
       - cros_pchg: fix peripheral device status after system resume
      
       - axp20x_usb_power: add support for AXP192
      
       - qcom-pon: add support for pm8941
      
       - at91-reset: prepare to expose reset reason to sysfs
      
       - switch all I2C drivers back to use .probe instead of .probe_new
      
       - convert some more DT bindings to YAML
      
       - misc cleanups
      
      * tag 'for-v6.5' of git://git.kernel.org/pub/scm/linux/kernel/git/sre/linux-power-supply: (28 commits)
        MAINTAINERS: add documentation file for Microchip SAMA5D2 shutdown controller
        dt-bindings: power: reset: atmel,sama5d2-shdwc: convert to yaml
        dt-bindings: power: reset: atmel,at91sam9260-shdwc: convert to yaml
        power: reset: at91-reset: change the power on reason prototype
        power: reset: qcom-pon: add support for pm8941-pon
        dt-bindings: power: reset: qcom-pon: define pm8941-pon
        power: supply: add Qualcomm PMI8998 SMB2 Charger driver
        dt-bindings: power: supply: qcom,pmi8998-charger: add bindings for smb2 driver
        power: supply: rt9467: Make charger-enable control as logic level
        power: supply: Switch i2c drivers back to use .probe()
        power: reset: add HAS_IOPORT dependencies
        dt-bindings: power: supply: axp20x: Add AXP192 compatible
        power: supply: axp20x_usb_power: Add support for AXP192
        power: supply: axp20x_usb_power: Remove variant IDs from VBUS polling check
        power: supply: axp20x_usb_power: Use regmap field for VBUS disabling
        power: supply: axp20x_usb_power: Use regmap fields for USB BC feature
        power: supply: axp20x_usb_power: Use regmap fields for VBUS monitor feature
        power: supply: axp20x_usb_power: Simplify USB current limit handling
        power: supply: hwmon: constify pointers to hwmon_channel_info
        power: supply: twl4030_madc_battery: Refactor twl4030_madc_bat_ext_changed()
        ...
      0df24138
    • Linus Torvalds's avatar
      Merge tag 'rproc-v6.5' of git://git.kernel.org/pub/scm/linux/kernel/git/remoteproc/linux · 02676ecc
      Linus Torvalds authored
      Pull remoteproc updates from Bjorn Andersson:
       "The bulk of these patches relates to the moving to a void-returning
        remove callback.
      
        The i.MX HiFi remoteproc driver gets its pm_ops helpers updated to
        resolve build warnings about 'defined but not used' variables in
        certain configurations.
      
        The ST STM32 remoteproc driver is extended to allow using a SCMI reset
        controller to hold boot, and has an error message corrected.
      
        The Qualcomm Q6V5 PAS driver gains a missing 'static' qualifier on
        adsp_segment_dump()"
      
      * tag 'rproc-v6.5' of git://git.kernel.org/pub/scm/linux/kernel/git/remoteproc/linux: (23 commits)
        remoteproc: qcom_q6v5_pas: staticize adsp_segment_dump()
        remoteproc: stm32: Fix error code in stm32_rproc_parse_dt()
        remoteproc: stm32: Allow hold boot management by the SCMI reset controller
        dt-bindings: remoteproc: st,stm32-rproc: Rework reset declarations
        remoteproc: imx_dsp_rproc: use modern pm_ops
        remoteproc: wkup_m3: Convert to platform remove callback returning void
        remoteproc: stm32: Convert to platform remove callback returning void
        remoteproc: st: Convert to platform remove callback returning void
        remoteproc: virtio: Convert to platform remove callback returning void
        remoteproc: rcar: Convert to platform remove callback returning void
        remoteproc: qcom_wcnss: Convert to platform remove callback returning void
        remoteproc: qcom_q6v5_wcss: Convert to platform remove callback returning void
        remoteproc: qcom_q6v5_pas: Convert to platform remove callback returning void
        remoteproc: qcom_q6v5_mss: Convert to platform remove callback returning void
        remoteproc: qcom_q6v5_adsp: Convert to platform remove callback returning void
        remoteproc: pru: Convert to platform remove callback returning void
        remoteproc: omap: Convert to platform remove callback returning void
        remoteproc: mtk_scp: Convert to platform remove callback returning void
        remoteproc: meson_mx_ao_arc: Convert to platform remove callback returning void
        remoteproc: keystone: Convert to platform remove callback returning void
        ...
      02676ecc
  3. 03 Jul, 2023 24 commits
    • Linus Torvalds's avatar
      Merge tag 'hwlock-v6.5' of git://git.kernel.org/pub/scm/linux/kernel/git/remoteproc/linux · 6afb24a0
      Linus Torvalds authored
      Pull hwspinlock update from Bjorn Andersson:
       "This drops the last of_match_ptr() from the hwspinlock drivers,
        solving the resulting 'defined but not used' warning/error"
      
      * tag 'hwlock-v6.5' of git://git.kernel.org/pub/scm/linux/kernel/git/remoteproc/linux:
        hwspinlock: omap: drop of_match_ptr for ID table
      6afb24a0
    • Arnd Bergmann's avatar
      rdma: fix INFINIBAND_USER_ACCESS dependency · b39aeb33
      Arnd Bergmann authored
      After a change to the bnxt_re driver, it fails to link when
      CONFIG_INFINIBAND_USER_ACCESS is disabled:
      
        aarch64-linux-ld: drivers/infiniband/hw/bnxt_re/ib_verbs.o: in function `bnxt_re_handler_BNXT_RE_METHOD_ALLOC_PAGE':
        ib_verbs.c:(.text+0xd64): undefined reference to `ib_uverbs_get_ucontext_file'
        aarch64-linux-ld: drivers/infiniband/hw/bnxt_re/ib_verbs.o:(.rodata+0x168): undefined reference to `uverbs_idr_class'
        aarch64-linux-ld: drivers/infiniband/hw/bnxt_re/ib_verbs.o:(.rodata+0x1a8): undefined reference to `uverbs_destroy_def_handler'
      
      The problem is that the 'bnxt_re_uapi_defs' structure is built
      unconditionally and references a couple of functions that are never
      really called in this configuration but instead require other functions
      that are left out.
      
      Adding an #ifdef around the new code, or a Kconfig dependency would
      address this problem, but adding the compile-time check inside of the
      UAPI_DEF_CHAIN_OBJ_TREE_NAMED() macro seems best because that also
      addresses the problem in other drivers that may run into the same
      dependency.
      
      Fixes: 360da60d ("RDMA/bnxt_re: Enable low latency push")
      Signed-off-by: default avatarArnd Bergmann <arnd@arndb.de>
      Acked-by: default avatarLeon Romanovsky <leon@kernel.org>
      Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
      b39aeb33
    • Linus Torvalds's avatar
      Merge tag 'for_linus' of git://git.kernel.org/pub/scm/linux/kernel/git/mst/vhost · a8d70602
      Linus Torvalds authored
      Pull virtio updates from Michael Tsirkin:
      
       - resume support in vdpa/solidrun
      
       - structure size optimizations in virtio_pci
      
       - new pds_vdpa driver
      
       - immediate initialization mechanism for vdpa/ifcvf
      
       - interrupt bypass for vdpa/mlx5
      
       - multiple worker support for vhost
      
       - viirtio net in Intel F2000X-PL support for vdpa/ifcvf
      
       - fixes, cleanups all over the place
      
      * tag 'for_linus' of git://git.kernel.org/pub/scm/linux/kernel/git/mst/vhost: (48 commits)
        vhost: Make parameter name match of vhost_get_vq_desc()
        vduse: fix NULL pointer dereference
        vhost: Allow worker switching while work is queueing
        vhost_scsi: add support for worker ioctls
        vhost: allow userspace to create workers
        vhost: replace single worker pointer with xarray
        vhost: add helper to parse userspace vring state/file
        vhost: remove vhost_work_queue
        vhost_scsi: flush IO vqs then send TMF rsp
        vhost_scsi: convert to vhost_vq_work_queue
        vhost_scsi: make SCSI cmd completion per vq
        vhost_sock: convert to vhost_vq_work_queue
        vhost: convert poll work to be vq based
        vhost: take worker or vq for flushing
        vhost: take worker or vq instead of dev for queueing
        vhost, vhost_net: add helper to check if vq has work
        vhost: add vhost_worker pointer to vhost_virtqueue
        vhost: dynamically allocate vhost_worker
        vhost: create worker at end of vhost_dev_set_owner
        virtio_bt: call scheduler when we free unused buffs
        ...
      a8d70602
    • Linus Torvalds's avatar
      Merge tag 'for-linus' of git://git.kernel.org/pub/scm/virt/kvm/kvm · e8069f5a
      Linus Torvalds authored
      Pull kvm updates from Paolo Bonzini:
       "ARM64:
      
         - Eager page splitting optimization for dirty logging, optionally
           allowing for a VM to avoid the cost of hugepage splitting in the
           stage-2 fault path.
      
         - Arm FF-A proxy for pKVM, allowing a pKVM host to safely interact
           with services that live in the Secure world. pKVM intervenes on
           FF-A calls to guarantee the host doesn't misuse memory donated to
           the hyp or a pKVM guest.
      
         - Support for running the split hypervisor with VHE enabled, known as
           'hVHE' mode. This is extremely useful for testing the split
           hypervisor on VHE-only systems, and paves the way for new use cases
           that depend on having two TTBRs available at EL2.
      
         - Generalized framework for configurable ID registers from userspace.
           KVM/arm64 currently prevents arbitrary CPU feature set
           configuration from userspace, but the intent is to relax this
           limitation and allow userspace to select a feature set consistent
           with the CPU.
      
         - Enable the use of Branch Target Identification (FEAT_BTI) in the
           hypervisor.
      
         - Use a separate set of pointer authentication keys for the
           hypervisor when running in protected mode, as the host is untrusted
           at runtime.
      
         - Ensure timer IRQs are consistently released in the init failure
           paths.
      
         - Avoid trapping CTR_EL0 on systems with Enhanced Virtualization
           Traps (FEAT_EVT), as it is a register commonly read from userspace.
      
         - Erratum workaround for the upcoming AmpereOne part, which has
           broken hardware A/D state management.
      
        RISC-V:
      
         - Redirect AMO load/store misaligned traps to KVM guest
      
         - Trap-n-emulate AIA in-kernel irqchip for KVM guest
      
         - Svnapot support for KVM Guest
      
        s390:
      
         - New uvdevice secret API
      
         - CMM selftest and fixes
      
         - fix racy access to target CPU for diag 9c
      
        x86:
      
         - Fix missing/incorrect #GP checks on ENCLS
      
         - Use standard mmu_notifier hooks for handling APIC access page
      
         - Drop now unnecessary TR/TSS load after VM-Exit on AMD
      
         - Print more descriptive information about the status of SEV and
           SEV-ES during module load
      
         - Add a test for splitting and reconstituting hugepages during and
           after dirty logging
      
         - Add support for CPU pinning in demand paging test
      
         - Add support for AMD PerfMonV2, with a variety of cleanups and minor
           fixes included along the way
      
         - Add a "nx_huge_pages=never" option to effectively avoid creating NX
           hugepage recovery threads (because nx_huge_pages=off can be toggled
           at runtime)
      
         - Move handling of PAT out of MTRR code and dedup SVM+VMX code
      
         - Fix output of PIC poll command emulation when there's an interrupt
      
         - Add a maintainer's handbook to document KVM x86 processes,
           preferred coding style, testing expectations, etc.
      
         - Misc cleanups, fixes and comments
      
        Generic:
      
         - Miscellaneous bugfixes and cleanups
      
        Selftests:
      
         - Generate dependency files so that partial rebuilds work as
           expected"
      
      * tag 'for-linus' of git://git.kernel.org/pub/scm/virt/kvm/kvm: (153 commits)
        Documentation/process: Add a maintainer handbook for KVM x86
        Documentation/process: Add a label for the tip tree handbook's coding style
        KVM: arm64: Fix misuse of KVM_ARM_VCPU_POWER_OFF bit index
        RISC-V: KVM: Remove unneeded semicolon
        RISC-V: KVM: Allow Svnapot extension for Guest/VM
        riscv: kvm: define vcpu_sbi_ext_pmu in header
        RISC-V: KVM: Expose IMSIC registers as attributes of AIA irqchip
        RISC-V: KVM: Add in-kernel virtualization of AIA IMSIC
        RISC-V: KVM: Expose APLIC registers as attributes of AIA irqchip
        RISC-V: KVM: Add in-kernel emulation of AIA APLIC
        RISC-V: KVM: Implement device interface for AIA irqchip
        RISC-V: KVM: Skeletal in-kernel AIA irqchip support
        RISC-V: KVM: Set kvm_riscv_aia_nr_hgei to zero
        RISC-V: KVM: Add APLIC related defines
        RISC-V: KVM: Add IMSIC related defines
        RISC-V: KVM: Implement guest external interrupt line management
        KVM: x86: Remove PRIx* definitions as they are solely for user space
        s390/uv: Update query for secret-UVCs
        s390/uv: replace scnprintf with sysfs_emit
        s390/uvdevice: Add 'Lock Secret Store' UVC
        ...
      e8069f5a
    • Linus Torvalds's avatar
      Merge tag 'kgdb-6.5-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/danielt/linux · eded3777
      Linus Torvalds authored
      Pull kgdb updates from Daniel Thompson:
       "Fairly small changes this cycle:
      
         - An additional static inline function when kgdb is not enabled to
           reduce boilerplate in arch files
      
         - kdb will now handle input with linefeeds more like carriage return.
           This will make little difference for interactive use but can make
           it script to use expect-like interaction with kdb
      
         - A couple of warning fixes"
      
      * tag 'kgdb-6.5-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/danielt/linux:
        kdb: move kdb_send_sig() declaration to a better header file
        kdb: Handle LF in the command parser
        kdb: include kdb_private.h for function prototypes
        kgdb: Provide a stub kgdb_nmicallback() if !CONFIG_KGDB
      eded3777
    • Bob Peterson's avatar
      gfs2: Add quota_change type · 432928c9
      Bob Peterson authored
      Function do_qc has two main uses: (1) to re-sync the local quota changes
      (qd) to the master quotas, and (2) normal quota changes. In the case of
      normal quota changes, the change can be positive or negative, as the
      quota usage goes up and down.
      
      Before this patch function do_qc was distinguishing one from another by
      whether the resulting value is or isn't zero: In the case of a re-sync
      (called do_sync) the quota value is moved from the temporary value to a
      master value, so the amount is added to one and subtracted from the
      other. The problem is that since the values can be positive or negative
      we can occasionally run into situations where we are not doing a re-sync
      but the quota change just happens to cancel out the previous value.
      
      In the case of a re-sync extra references and locks are taken, and so
      do_qc needs to release them. In the case of a normal quota change, no
      extra references and locks are taken, so it must not try to release
      them.
      
      The problem is: if the quota change is not a re-sync but the value just
      happens to cancel out the original quota change, the resulting zero
      value fools do_qc into thinking this is a re-sync and therefore it must
      release the extra references. This results in problems, mainly having to
      do with slot reference numbers going smaller than zero.
      
      This patch introduces new constants, QC_SYNC and QC_CHANGE so do_qc can
      really tell the difference. For QC_SYNC calls it must release the extra
      references acquired by gfs2_quota_unlock's call to qd_check_sync. For
      QC_CHANGE calls it does not have extra references to put.
      
      Note that this allows quota changes back to a value of zero, and so I
      removed an assert warning related to that.
      Signed-off-by: default avatarBob Peterson <rpeterso@redhat.com>
      Signed-off-by: default avatarAndreas Gruenbacher <agruenba@redhat.com>
      432928c9
    • Andreas Gruenbacher's avatar
      gfs2: Use memcpy_{from,to}_page where appropriate · d68d0c6c
      Andreas Gruenbacher authored
      Replace kmap_local_page() + memcpy() + kunmap_local() sequences with
      memcpy_{from,to}_page() where we are not doing anything else with the
      mapped page.
      Signed-off-by: default avatarAndreas Gruenbacher <agruenba@redhat.com>
      d68d0c6c
    • Andreas Gruenbacher's avatar
      gfs2: Convert remaining kmap_atomic calls to kmap_local_page · b0c21c6d
      Andreas Gruenbacher authored
      Replace the remaining instances of kmap_atomic() ... kunmap_atomic()
      with kmap_local_page() ... kunmap_local().
      
      In gfs2_write_buf_to_page(), we can call flush_dcache_page() after
      unmapping the page.
      Signed-off-by: default avatarAndreas Gruenbacher <agruenba@redhat.com>
      b0c21c6d
    • Deepak R Varma's avatar
      gfs2: Replace deprecated kmap_atomic with kmap_local_page · 58721bd4
      Deepak R Varma authored
      kmap_atomic() is deprecated in favor of kmap_local_{folio,page}().
      
      Therefore, replace kmap_atomic() with kmap_local_page() in
      gfs2_internal_read() and stuffed_readpage().
      
      kmap_atomic() disables page-faults and preemption (the latter only for
      !PREEMPT_RT kernels), However, the code within the mapping/un-mapping in
      gfs2_internal_read() and stuffed_readpage() does not depend on the
      above-mentioned side effects.
      
      Therefore, a mere replacement of the old API with the new one is all that
      is required (i.e., there is no need to explicitly add any calls to
      pagefault_disable() and/or preempt_disable()).
      Signed-off-by: default avatarDeepak R Varma <drv@mailo.com>
      Signed-off-by: default avatarAndreas Gruenbacher <agruenba@redhat.com>
      58721bd4
    • Andreas Gruenbacher's avatar
      gfs: Get rid of unnucessary locking in inode_go_dump · f246dd4b
      Andreas Gruenbacher authored
      Commit 27a2660f ("gfs2: Dump nrpages for inodes and their glocks")
      added some locking around reading inode->i_data.nrpages.  That locking
      doesn't do anything really, so get rid of it.
      
      With that, the glock argument to ->go_dump() can be made const again as
      well.
      Signed-off-by: default avatarAndreas Gruenbacher <agruenba@redhat.com>
      f246dd4b
    • Andreas Gruenbacher's avatar
      gfs2: gfs2_freeze_lock_shared cleanup · 6c7410f4
      Andreas Gruenbacher authored
      All the remaining users of gfs2_freeze_lock_shared() set freeze_gh to
      &sdp->sd_freeze_gh and flags to 0, so remove those two parameters.
      Signed-off-by: default avatarAndreas Gruenbacher <agruenba@redhat.com>
      6c7410f4
    • Andreas Gruenbacher's avatar
      gfs2: Replace sd_freeze_state with SDF_FROZEN flag · 5432af15
      Andreas Gruenbacher authored
      Replace sd_freeze_state with a new SDF_FROZEN flag.
      
      There no longer is a need for indicating that a freeze is in progress
      (SDF_STARTING_FREEZE); we are now protecting the critical sections with
      the sd_freeze_mutex.
      Signed-off-by: default avatarAndreas Gruenbacher <agruenba@redhat.com>
      5432af15
    • Andreas Gruenbacher's avatar
      gfs2: Rework freeze / thaw logic · b77b4a48
      Andreas Gruenbacher authored
      So far, at mount time, gfs2 would take the freeze glock in shared mode
      and then immediately drop it again, turning it into a cached glock that
      can be reclaimed at any time.  To freeze the filesystem cluster-wide,
      the node initiating the freeze would take the freeze glock in exclusive
      mode, which would cause the freeze glock's freeze_go_sync() callback to
      run on each node.  There, gfs2 would freeze the filesystem and schedule
      gfs2_freeze_func() to run.  gfs2_freeze_func() would re-acquire the
      freeze glock in shared mode, thaw the filesystem, and drop the freeze
      glock again.  The initiating node would keep the freeze glock held in
      exclusive mode.  To thaw the filesystem, the initiating node would drop
      the freeze glock again, which would allow gfs2_freeze_func() to resume
      on all nodes, leaving the filesystem in the thawed state.
      
      It turns out that in freeze_go_sync(), we cannot reliably and safely
      freeze the filesystem.  This is primarily because the final unmount of a
      filesystem takes a write lock on the s_umount rw semaphore before
      calling into gfs2_put_super(), and freeze_go_sync() needs to call
      freeze_super() which also takes a write lock on the same semaphore,
      causing a deadlock.  We could work around this by trying to take an
      active reference on the super block first, which would prevent unmount
      from running at the same time.  But that can fail, and freeze_go_sync()
      isn't actually allowed to fail.
      
      To get around this, this patch changes the freeze glock locking scheme
      as follows:
      
      At mount time, each node takes the freeze glock in shared mode.  To
      freeze a filesystem, the initiating node first freezes the filesystem
      locally and then drops and re-acquires the freeze glock in exclusive
      mode.  All other nodes notice that there is contention on the freeze
      glock in their go_callback callbacks, and they schedule
      gfs2_freeze_func() to run.  There, they freeze the filesystem locally
      and drop and re-acquire the freeze glock before re-thawing the
      filesystem.  This is happening outside of the glock state engine, so
      there, we are allowed to fail.
      
      From a cluster point of view, taking and immediately dropping a glock is
      indistinguishable from taking the glock and only dropping it upon
      contention, so this new scheme is compatible with the old one.
      
      Thanks to Li Dong <lidong@vivo.com> for reporting a locking bug in
      gfs2_freeze_func() in a previous version of this commit.
      Signed-off-by: default avatarAndreas Gruenbacher <agruenba@redhat.com>
      b77b4a48
    • Linus Torvalds's avatar
      Merge tag 'usb-6.5-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/usb · 56cbceab
      Linus Torvalds authored
      Pull USB / Thunderbolt driver updates from Greg KH:
       "Here is the big set of USB and Thunderbolt driver updates for 6.5-rc1.
      
        Included in here are:
      
         - Lots of USB4/Thunderbolt additions and updates for new hardware
           types and fixes as people are starting to get access to the
           hardware in the wild
      
         - new gadget controller driver, cdns2, added
      
         - new typec drivers added
      
         - xhci driver updates
      
         - typec driver updates
      
         - usbip driver fixes
      
         - usb-serial driver updates and fixes
      
         - lots of smaller USB driver updates
      
        All of these have been in linux-next for a while with no reported
        problems"
      
      * tag 'usb-6.5-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/usb: (265 commits)
        usb: host: xhci-plat: Set XHCI_STATE_REMOVING before resuming XHCI HC
        usb: host: xhci: Do not re-initialize the XHCI HC if being removed
        usb: typec: nb7vpq904m: fix CONFIG_DRM dependency
        usbip: usbip_host: Replace strlcpy with strscpy
        usb: dwc3: gadget: Propagate core init errors to UDC during pullup
        USB: serial: option: add LARA-R6 01B PIDs
        usb: ulpi: Make container_of() no-op in to_ulpi_dev()
        usb: gadget: legacy: fix error return code in gfs_bind
        usb: typec: fsa4480: add support for Audio Accessory Mode
        usb: typec: fsa4480: rework mux & switch setup to handle more states
        usb: typec: ucsi: call typec_set_mode on non-altmode partner change
        USB: gadget: f_hid: make hidg_class a static const structure
        USB: gadget: f_printer: make usb_gadget_class a static const structure
        USB: mon: make mon_bin_class a static const structure
        USB: gadget: udc: core: make udc_class a static const structure
        USB: roles: make role_class a static const structure
        dt-bindings: usb: dwc3: Add interrupt-names property support for wakeup interrupt
        dt-bindings: usb: Add StarFive JH7110 USB controller
        dt-bindings: usb: dwc3: Add IPQ9574 compatible
        usb: cdns2: Fix spelling mistake in a trace message "Wakupe" -> "Wakeup"
        ...
      56cbceab
    • Linus Torvalds's avatar
      Merge tag 'tty-6.5-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/tty · 868a9fd9
      Linus Torvalds authored
      Pull tty/serial driver updates from Greg KH:
       "Here is the big set of tty/serial driver updates for 6.5-rc1.
      
        Included in here are:
      
         - tty_audit code cleanups from Jiri
      
         - more 8250 cleanups from Ilpo
      
         - samsung_tty driver bugfixes
      
         - 8250 lock port updates
      
         - usual fsl_lpuart driver updates and fixes
      
         - other small serial driver fixes and updates, full details in the
           shortlog
      
        All of these have been in linux-next for a while with no reported
        issues"
      
      * tag 'tty-6.5-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/tty: (58 commits)
        tty_audit: make data of tty_audit_log() const
        tty_audit: make tty pointers in exposed functions const
        tty_audit: make icanon a bool
        tty_audit: invert the condition in tty_audit_log()
        tty_audit: use kzalloc() in tty_audit_buf_alloc()
        tty_audit: use TASK_COMM_LEN for task comm
        Revert "8250: add support for ASIX devices with a FIFO bug"
        serial: atmel: don't enable IRQs prematurely
        tty: serial: Add Nuvoton ma35d1 serial driver support
        tty: serial: fsl_lpuart: add earlycon for imx8ulp platform
        tty: serial: imx: fix rs485 rx after tx
        selftests: tty: add selftest for tty timestamp updates
        tty: tty_io: update timestamps on all device nodes
        tty: fix hang on tty device with no_room set
        serial: core: fix -EPROBE_DEFER handling in init
        serial: 8250_omap: Use force_suspend and resume for system suspend
        tty: serial: samsung_tty: Use abs() to simplify some code
        tty: serial: samsung_tty: Fix a memory leak in s3c24xx_serial_getclk() when iterating clk
        tty: serial: samsung_tty: Fix a memory leak in s3c24xx_serial_getclk() in case of error
        serial: 8250: Apply FSL workarounds also without SERIAL_8250_CONSOLE
        ...
      868a9fd9
    • Linus Torvalds's avatar
      Merge tag 'staging-6.5-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/staging · db9c6d1d
      Linus Torvalds authored
      Pull staging driver updates from Greg KH:
       "Here is a set of staging driver updates for 6.5-rc1. It's a small
        update this merge window, nothing major at all, overall just under
        1000 lines of code removed, not a huge churn.
      
        Nothing major to highlight here either, just lots of small coding
        style fixes.
      
        All of these have been in linux-next for a while with no reported
        problems"
      
      * tag 'staging-6.5-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/staging: (62 commits)
        staging: rtl8192e: Remove whitespace and blank lines
        staging: rtl8192e: remove 5G related code
        staging: rtl8192e: remove comparison to true
        staging: rtl8192e: remove return statement from void function
        staging: rtl8192e: convert else if sequence to switch
        staging: rtl8192e: clean up brace coding style issues
        staging: rtl8723bs: Fix blank line issues
        staging: rtl8723bs: Fix block comment issue
        staging: rtl8723bs: Fix indentation issues
        staging: vchiq_arm: Remove extra struct vchiq_instance declaration
        staging: rtl8192e: Rename variable InitialGainHandler
        staging: rtl8192e: Rename variable LeisurePSLeave
        staging: rtl8192e: Rename variable SetBWModeHandler
        staging: rtl8192e: Rename variable SetWirelessMode
        staging: rtl8192e: Rename RTLLIB_LINKED_SCANNING
        staging: rtl8192e: Rename RTLLIB_LINKED to MAC80211_LINKED
        staging: rtl8192e: Rename RTLLIB_NOLINK to MAC80211_NOLINK
        staging: rtl8192e: Rename state to link_state
        staging: rtl8192e: Rename rtllib_state to rtl_link_state
        staging: rtl8192e: Remove unused enum led_ctl_mode
        ...
      db9c6d1d
    • Linus Torvalds's avatar
      Merge tag 'driver-core-6.5-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/driver-core · fc75f216
      Linus Torvalds authored
      Pull driver core updates from Greg KH:
       "Here are a small set of changes for 6.5-rc1 for some driver core
        changes. Included in here are:
      
         - device property cleanups to make it easier to write "agnostic"
           drivers when regards to the firmware layer underneath them (DT vs.
           ACPI)
      
         - debugfs documentation updates
      
         - devres additions
      
         - sysfs documentation and changes to handle empty directory creation
           logic better
      
         - tiny kernfs optimizations
      
         - other tiny changes
      
        All of these have been in linux-next for a while with no reported
        problems"
      
      * tag 'driver-core-6.5-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/driver-core:
        sysfs: Skip empty folders creation
        sysfs: Improve readability by following the kernel coding style
        drivers: fwnode: fix fwnode_irq_get[_byname]()
        ata: ahci_platform: Make code agnostic to OF/ACPI
        device property: Implement device_is_compatible()
        ACPI: Move ACPI_DEVICE_CLASS() to mod_devicetable.h
        base/node: Use 'property' to identify an access parameter
        driver core: device.h: add some missing kerneldocs
        kernfs: fix missing kernfs_idr_lock to remove an ID from the IDR
        isa: Remove unnecessary checks
        MAINTAINERS: add entry for auxiliary bus
        debugfs: Correct the 'debugfs_create_str' docs
        serial: qcom_geni: Comment use of devm_krealloc rather than devm_krealloc_array
        iio: adc: Use devm_krealloc_array
        hwmon: pmbus: Use devm_krealloc_array
      fc75f216
    • Linus Torvalds's avatar
      Merge tag 'char-misc-6.5-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/char-misc · 44aeec83
      Linus Torvalds authored
      Pull Char/Misc updates from Greg KH:
       "Here is the big set of char/misc and other driver subsystem updates
        for 6.5-rc1.
      
        Lots of different, tiny, stuff in here, from a range of smaller driver
        subsystems, including pulls from some substems directly:
      
         - IIO driver updates and additions
      
         - W1 driver updates and fixes (and a new maintainer!)
      
         - FPGA driver updates and fixes
      
         - Counter driver updates
      
         - Extcon driver updates
      
         - Interconnect driver updates
      
         - Coresight driver updates
      
         - mfd tree tag merge needed for other updates on top of that, lots of
           small driver updates as patches, including:
      
         - static const updates for class structures
      
         - nvmem driver updates
      
         - pcmcia driver fix
      
         - lots of other small driver updates and fixes
      
        All of these have been in linux-next for a while with no reported
        problems"
      
      * tag 'char-misc-6.5-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/char-misc: (243 commits)
        bsr: fix build problem with bsr_class static cleanup
        comedi: make all 'class' structures const
        char: xillybus: make xillybus_class a static const structure
        xilinx_hwicap: make icap_class a static const structure
        virtio_console: make port class a static const structure
        ppdev: make ppdev_class a static const structure
        char: misc: make misc_class a static const structure
        /dev/mem: make mem_class a static const structure
        char: lp: make lp_class a static const structure
        dsp56k: make dsp56k_class a static const structure
        bsr: make bsr_class a static const structure
        oradax: make 'cl' a static const structure
        hwtracing: hisi_ptt: Fix potential sleep in atomic context
        hwtracing: hisi_ptt: Advertise PERF_PMU_CAP_NO_EXCLUDE for PTT PMU
        hwtracing: hisi_ptt: Export available filters through sysfs
        hwtracing: hisi_ptt: Add support for dynamically updating the filter list
        hwtracing: hisi_ptt: Factor out filter allocation and release operation
        samples: pfsm: add CC_CAN_LINK dependency
        misc: fastrpc: check return value of devm_kasprintf()
        coresight: dummy: Update type of mode parameter in dummy_{sink,source}_enable()
        ...
      44aeec83
    • Linus Torvalds's avatar
      Merge tag 'backlight-next-6.5' of git://git.kernel.org/pub/scm/linux/kernel/git/lee/backlight · 0a8d6c9c
      Linus Torvalds authored
      Pull backlight updates from Lee Jones:
       "New Functionality:
         - Add lots of Device Tree bindings / support
         - Turn off LED strings when display is blank
         - Switch I2C drivers from .probe_new() to .probe()
         - Remove superfluous NULL checks
         - Only obtain PWM information once and do it in .probe()
      
        Fix-ups:
         - Ensure locks are obtained and held when required"
      
      * tag 'backlight-next-6.5' of git://git.kernel.org/pub/scm/linux/kernel/git/lee/backlight:
        backlight: led_bl: Take led_access lock when required
        video: backlight: lp855x: Get PWM for PWM mode during probe
        dt-bindings: backlight: lp855x: Convert to YAML and modernize
        dt-bindings: backlight: pwm: Make power-supply not required
        backlight: pwm_bl: Remove unneeded checks for valid GPIOs
        backlight: Switch i2c drivers back to use .probe()
        backlight: lm3630a: Turn off both led strings when display is blank
        dt-bindings: leds: backlight: ktz8866: Add reg property and update example
      0a8d6c9c
    • Linus Torvalds's avatar
      Merge tag 'leds-next-6.5' of git://git.kernel.org/pub/scm/linux/kernel/git/lee/leds · c156d4af
      Linus Torvalds authored
      Pull LED updates from Lee Jones:
       "New Drivers:
         - Add support for Intel Cherry Trail Whiskey Cove PMIC LEDs
         - Add support for Awinic AW20036/AW20054/AW20072 LEDs
      
        New Device Support:
         - Add support for PMI632 LPG to QCom LPG
         - Add support for PMI8998 to QCom Flash
         - Add support for MT6331, WLEDs and MT6332 to Mediatek MT6323 PMIC
      
        New Functionality:
         - Implement the LP55xx Charge Pump
         - Add support for suspend / resume to Intel Cherry Trail Whiskey Cove PMIC
         - Add support for breathing mode to Intel Cherry Trail Whiskey Cove PMIC
         - Enable per-pin resolution Pinctrl in LEDs GPIO
      
        Fix-ups:
         - Allow thread to sleep by switching from spinlock to mutex
         - Add lots of Device Tree bindings / support
         - Adapt relationships / dependencies driven by Kconfig
         - Switch I2C drivers from .probe_new() to .probe()
         - Remove superfluous / duplicate code
         - Replace strlcpy() with strscpy() for efficiency and overflow prevention
         - Staticify various functions
         - Trivial: Fixing coding style
         - Simplify / reduce code
      
        Bug Fixes:
         - Prevent NETDEV_LED_MODE_LINKUP from being cleared on rename
         - Repair race between led_set_brightness(LED_{OFF,FULL})
         - Fix Oops relating to sleeping in critical sections
         - Clear LED_INIT_DEFAULT_TRIGGER flag when clearing the current trigger
         - Do not leak resources in error handling paths
         - Fix unsigned comparison which can never be negative
         - Provide missing NULL terminating entries in tables
         - Fix misnaming issues"
      
      * tag 'leds-next-6.5' of git://git.kernel.org/pub/scm/linux/kernel/git/lee/leds: (53 commits)
        leds: leds-mt6323: Adjust return/parameter types in wled get/set callbacks
        leds: sgm3140: Add richtek,rt5033-led compatible
        dt-bindings: leds: sgm3140: Document richtek,rt5033 compatible
        dt-bindings: backlight: kinetic,ktz8866: Add missing type for "current-num-sinks"
        dt-bindings: leds: Drop unneeded quotes
        leds: Fix config reference for AW200xx driver
        leds: leds-mt6323: Add support for WLEDs and MT6332
        leds: leds-mt6323: Add support for MT6331 leds
        leds: leds-mt6323: Open code and drop MT6323_CAL_HW_DUTY macro
        leds: leds-mt6323: Drop MT6323_ prefix from macros and defines
        leds: leds-mt6323: Specify registers and specs in platform data
        dt-bindings: leds: leds-mt6323: Document mt6332 compatible
        dt-bindings: leds: leds-mt6323: Document mt6331 compatible
        leds: simatic-ipc-leds-gpio: Introduce more Kconfig switches
        leds: simatic-ipc-leds-gpio: Split up into multiple drivers
        leds: simatic-ipc-leds-gpio: Move two extra gpio pins into another table
        leds: simatic-ipc-leds-gpio: Add terminating entries to gpio tables
        leds: flash: leds-qcom-flash: Fix an unsigned comparison which can never be negative
        leds: cht-wcove: Remove unneeded semicolon
        leds: cht-wcove: Fix an unsigned comparison which can never be negative
        ...
      c156d4af
    • Linus Torvalds's avatar
      Merge tag 'mfd-next-6.5' of git://git.kernel.org/pub/scm/linux/kernel/git/lee/mfd · b8ec70ab
      Linus Torvalds authored
      Pull MFD updates from Lee Jones:
       "New Drivers:
         - Add support for TI TPS6594/TPS6593/LP8764 PMICs
         - Add support for Samsung RT5033 Battery Charger
         - Add support for Analog Devices MAX77540 and MAX77541 PMICs
      
        New Device Support:
         - Add support for SPI to Rockchip RK808 (and friends)
         - Add support for AXP192 PMIC to X-Powers AXP20X
         - Add support for AXP313a PMIC to X-Powers AXP20X
         - Add support for RK806 to Rockchip RK8XX
      
        Removed Device Support:
         - Removed MFD support for Richtek RT5033 Battery
      
        Fix-ups:
         - Remove superfluous code
         - Switch I2C drivers from .probe_new() to .probe()
         - Convert over to managed resources (devm_*(), etc)
         - Use dev_err_probe() for returning errors from .probe()
         - Add lots of Device Tree bindings / support
         - Improve cache efficiency by switching to Maple
         - Use own exported namespaces (NS)
         - Include missing and remove superfluous headers
         - Start using / convert to the new shutdown sys-off API
         - Trivial: variable / define renaming
         - Make use of of_property_read_reg() when requesting DT 'reg's
      
        Bug Fixes:
         - Fix chip revision readout due to incorrect data masking
         - Amend incorrect register and mask values used for charger state
         - Hide unused functionality at compile time
         - Fix resource leaks following error handling routines
         - Return correct error values and fix error handling in general
         - Repair incorrect device names - used for device matching
         - Remedy broken module auto-loading"
      
      * tag 'mfd-next-6.5' of git://git.kernel.org/pub/scm/linux/kernel/git/lee/mfd: (51 commits)
        dt-bindings: mfd: max77541: Add ADI MAX77541/MAX77540
        iio: adc: max77541: Add ADI MAX77541 ADC Support
        regulator: max77541: Add ADI MAX77541/MAX77540 Regulator Support
        dt-bindings: regulator: max77541: Add ADI MAX77541/MAX77540 Regulator
        mfd: Switch two more drivers back to use struct i2c_driver::probe
        dt-bindings: mfd: samsung,s5m8767: Simplify excluding properties
        mfd: stmpe: Only disable the regulators if they are enabled
        mfd: max77541: Add ADI MAX77541/MAX77540 PMIC Support
        dt-bindings: mfd: gateworks-gsc: Remove unnecessary fan-controller nodes
        mfd: core: Use of_property_read_reg() to parse "reg"
        mfd: stmfx: Nullify stmfx->vdd in case of error
        mfd: stmfx: Fix error path in stmfx_chip_init
        mfd: intel-lpss: Add missing check for platform_get_resource
        mfd: stpmic1: Add PMIC poweroff via sys-off handler
        mfd: stpmic1: Fixup main control register and bits naming
        dt-bindings: mfd: qcom,tcsr: Add the compatible for IPQ8074
        mfd: tps65219: Add support for soft shutdown via sys-off API
        mfd: pm8008: Drop bogus i2c module alias
        mfd: pm8008: Fix module autoloading
        mfd: tps65219: Add GPIO cell instance
        ...
      b8ec70ab
    • Linus Torvalds's avatar
      Merge tag 'mailbox-v6.5' of git://git.linaro.org/landing-teams/working/fujitsu/integration · 99bdeae2
      Linus Torvalds authored
      Pull mailbox updates from Jassi Brar:
      
       - tegra: support for Tegra264
      
       - broadcom: convert bcm2835 bindings from txt to yaml bcm2835
      
       - qcom: support for IPQ5018
      
       - ti: always zero TX data fields
      
      * tag 'mailbox-v6.5' of git://git.linaro.org/landing-teams/working/fujitsu/integration:
        mailbox: ti-msgmgr: Fill non-message tx data fields with 0x0
        mailbox: tegra: add support for Tegra264
        dt-bindings: mailbox: tegra: Document Tegra264 HSP
        dt-bindings: mailbox: convert bcm2835-mbox bindings to YAML
        dt-bindings: mailbox: qcom: Add IPQ5018 APCS compatible
      99bdeae2
    • Linus Torvalds's avatar
      Merge tag 'rtc-6.5' of git://git.kernel.org/pub/scm/linux/kernel/git/abelloni/linux · b349de4c
      Linus Torvalds authored
      Pull RTC updates from Alexandre Belloni:
       "The isl1208 dirver was reworked tobe able to work as part of an MFD.
      
        All the Loongson chips are now supported through a new driver, the old
        one is removed.
      
        Summary:
      
        Subsystem:
         - Switch i2c drivers back to use .probe()
         - Constify pointers to hwmon_channel_info
      
        New driver:
         - Loongson on chip RTC, replacing the Loongson 1 only driver
      
        Drivers:
         - isl1208: cleanup and support for RAA215300
         - st-lpc: cleanups
         - stm32: fix wakeup"
      
      * tag 'rtc-6.5' of git://git.kernel.org/pub/scm/linux/kernel/git/abelloni/linux: (21 commits)
        rtc: Add rtc driver for the Loongson family chips
        rtc: Remove the Loongson-1 RTC driver
        dt-bindings: rtc: Split loongson,ls2x-rtc into SoC-based compatibles
        rtc: rv3028: make rv3028 probeable from userspace
        rtc: isl1208: Add support for the built-in RTC on the PMIC RAA215300
        rtc: isl1208: Add isl1208_set_xtoscb()
        rtc: isl1208: Drop enum isl1208_id and split isl1208_configs[]
        rtc: isl1208: Make similar I2C and DT-based matching table
        rtc: isl1208: Drop name variable
        dt-bindings: rtc: isil,isl1208: Document clock and clock-names properties
        dt-bindings: rtc: isl1208: Convert to json-schema
        rtc: st-lpc: Simplify clk handling in st_rtc_probe()
        rtc: st-lpc: Release some resources in st_rtc_probe() in case of error
        rtc: stm32: remove dedicated wakeup management
        dt-bindings: rtc: restrict node name suffixes
        rtc: add HAS_IOPORT dependencies
        rtc: Switch i2c drivers back to use .probe()
        rtc: rv3032: constify pointers to hwmon_channel_info
        rtc: isl12022: constify pointers to hwmon_channel_info
        rtc: ds3232: constify pointers to hwmon_channel_info
        ...
      b349de4c
    • Linus Torvalds's avatar
      Merge tag 'i3c/for-6.5' of git://git.kernel.org/pub/scm/linux/kernel/git/i3c/linux · a7419587
      Linus Torvalds authored
      Pull i3c updates from Alexandre Belloni:
      
       - svc: fix suspend/resume on some platforms, fix locking issues
      
      * tag 'i3c/for-6.5' of git://git.kernel.org/pub/scm/linux/kernel/git/i3c/linux:
        i3c: master: svc: add NACK check after start byte sent
        i3c: master: svc: fix cpu schedule in spin lock
        i3c: master: svc: fix i3c suspend/resume issue
      a7419587