1. 16 May, 2024 14 commits
    • Rafael J. Wysocki's avatar
      platform/x86: wmi: Remove custom EC address space handler · 98a83da3
      Rafael J. Wysocki authored
      The custom EC address space handler in the WMI driver was only needed
      because the EC driver did not install its address space handler for
      EC operation regions beyond the EC device scope in the ACPI namespace.
      
      That has just changed, so the custom EC address handler is not needed
      any more and it can be removed.
      Signed-off-by: default avatarRafael J. Wysocki <rafael.j.wysocki@intel.com>
      Reviewed-by: default avatarArmin Wolf <W_Armin@gmx.de>
      Reviewed-by: default avatarHeikki Krogerus <heikki.krogerus@linux.intel.com>
      Reviewed-by: default avatarHans de Goede <hdegoede@redhat.com>
      Reviewed-by: default avatarMario Limonciello <mario.limonciello@amd.com>
      Reviewed-by: default avatarAndy Shevchenko <andriy.shevchenko@linux.intel.com>
      98a83da3
    • Rafael J. Wysocki's avatar
      ACPI: EC: Install address space handler at the namespace root · 60fa6ae6
      Rafael J. Wysocki authored
      It is reported that _DSM evaluation fails in ucsi_acpi_dsm() on Lenovo
      IdeaPad Pro 5 due to a missing address space handler for the EC address
      space:
      
       ACPI Error: No handler for Region [ECSI] (000000007b8176ee) [EmbeddedControl] (20230628/evregion-130)
      
      This happens because if there is no ECDT, the EC driver only registers
      the EC address space handler for operation regions defined in the EC
      device scope of the ACPI namespace while the operation region being
      accessed by the _DSM in question is located beyond that scope.
      
      To address this, modify the ACPI EC driver to install the EC address
      space handler at the root of the ACPI namespace for the first EC that
      can be found regardless of whether or not an ECDT is present.
      
      Note that this change is consistent with some examples in the ACPI
      specification in which EC operation regions located outside the EC
      device scope are used (for example, see Section 9.17.15 in ACPI 6.5),
      so the current behavior of the EC driver is arguably questionable.
      Reported-by: default avatarwebcaptcha <webcapcha@gmail.com>
      Link: https://bugzilla.kernel.org/show_bug.cgi?id=218789
      Link: https://uefi.org/specs/ACPI/6.5/09_ACPI_Defined_Devices_and_Device_Specific_Objects.html#example-asl-code
      Link: https://lore.kernel.org/linux-acpi/Zi+0whTvDbAdveHq@kuha.fi.intel.comSuggested-by: default avatarHeikki Krogerus <heikki.krogerus@linux.intel.com>
      Signed-off-by: default avatarRafael J. Wysocki <rafael.j.wysocki@intel.com>
      Reviewed-by: default avatarHans de Goede <hdegoede@redhat.com>
      Reviewed-by: default avatarMario Limonciello <mario.limonciello@amd.com>
      Reviewed-by: default avatarAndy Shevchenko <andriy.shevchenko@linux.intel.com>
      60fa6ae6
    • Linus Torvalds's avatar
      Merge tag 'platform-drivers-x86-v6.10-1' of... · ea5f6ad9
      Linus Torvalds authored
      Merge tag 'platform-drivers-x86-v6.10-1' of git://git.kernel.org/pub/scm/linux/kernel/git/pdx86/platform-drivers-x86
      
      Pull x86 platform driver updates from Hans de Goede:
      
       - New drivers/platform/arm64 directory for arm64 embedded-controller
         drivers
      
       - New drivers:
          - Acer Aspire 1 embedded controllers (for arm64 models)
          - ACPI quickstart PNP0C32 buttons
          - Dell All-In-One backlight support (dell-uart-backlight)
          - Lenovo WMI camera buttons
          - Lenovo Yoga Tablet 2 Pro 1380F/L fast charging
          - MeeGoPad ANX7428 Type-C Cross Switch (power sequencing only)
          - MSI WMI sensors (fan speed sensors only for now)
      
       - Asus WMI:
          - 2024 ROG Mini-LED support
          - MCU powersave support
          - Vivobook GPU MUX support
          - Misc. other improvements
      
       - Ideapad laptop:
          - Export FnLock LED as LED class device
          - Switch platform profiles using thermal management key
      
       - Intel drivers:
          - IFS: various improvements
          - PMC: Lunar Lake support
          - SDSI: various improvements
          - TPMI/ISST: various improvements
          - tools: intel-speed-select: various improvements
      
       - MS Surface drivers:
          - Fan profile switching support
          - Surface Pro thermal sensors support
      
       - ThinkPad ACPI:
          - Reworked hotkey support to use sparse keymaps
          - Add support for new trackpoint-doubletap, Fn+N and Fn+G hotkeys
      
       - WMI core:
          - New WMI driver development guide
      
       - x86 Android tablets:
          - Lenovo Yoga Tablet 2 Pro 1380F/L support
          - Xiaomi MiPad 2 status LED and bezel touch buttons backlight
            support
      
       - Miscellaneous cleanups / fixes / improvements
      
      * tag 'platform-drivers-x86-v6.10-1' of git://git.kernel.org/pub/scm/linux/kernel/git/pdx86/platform-drivers-x86: (128 commits)
        platform/x86: Add new MeeGoPad ANX7428 Type-C Cross Switch driver
        devm-helpers: Fix a misspelled cancellation in the comments
        tools arch x86: Add dell-uart-backlight-emulator
        platform/x86: Add new Dell UART backlight driver
        platform/x86: x86-android-tablets: Create LED device for Xiaomi Pad 2 bottom bezel touch buttons
        platform/x86: x86-android-tablets: Xiaomi pad2 RGB LED fwnode updates
        platform/x86: x86-android-tablets: Pass struct device to init()
        platform/x86/amd: pmc: Add new ACPI ID AMDI000B
        platform/x86/amd: pmf: Add new ACPI ID AMDI0105
        platform/x86: p2sb: Don't init until unassigned resources have been assigned
        platform/surface: aggregator: Log critical errors during SAM probing
        platform/x86: ISST: Support SST-BF and SST-TF per level
        platform/x86/fujitsu-laptop: Replace sprintf() with sysfs_emit()
        tools/power/x86/intel-speed-select: v1.19 release
        tools/power/x86/intel-speed-select: Display CPU as None for -1
        tools/power/x86/intel-speed-select: SST BF/TF support per level
        tools/power/x86/intel-speed-select: Increase number of CPUs displayed
        tools/power/x86/intel-speed-select: Present all TRL levels for turbo-freq
        tools/power/x86/intel-speed-select: Fix display for unsupported levels
        tools/power/x86/intel-speed-select: Support multiple dies
        ...
      ea5f6ad9
    • Linus Torvalds's avatar
      Merge tag 'mtd/for-6.10' of git://git.kernel.org/pub/scm/linux/kernel/git/mtd/linux · b426433c
      Linus Torvalds authored
      Pull MTD updates from Miquel Raynal:
       "MTD:
      
         - Simon Glass wanted to support binman's output properties in order
           to check their validity using the binding checks and proposed
           changes with the missing properties as well as a binman compatible.
      
         - Krzysztof Kozlowski on his side shared a new yaml for describing
           Samsung's OneNAND interface.
      
         - The interface with NVMEM has also been slightly improved/fixed,
           especially now that OTP are also supported in the NAND subsystem.
      
         - Along with these changes, small cleanups have also been contributed
           around ID tables, structure sizes, arithmetic checks and comments.
      
        Raw NAND subsystem:
      
         - Two small fixes, one in the Hynix vendor code for properly
           returning an error which might have been ignored and another in the
           Davinci driver to properly synchronize the controller with the gpio
           domain.
      
        SPI NOR subsystem:
      
         - SPI NOR now uses div_u64() instead of div64_u64() in places where
           the divisor is 32 bits. Many 32 bit architectures can optimize this
           variant better than a full 64 bit divide"
      
      * tag 'mtd/for-6.10' of git://git.kernel.org/pub/scm/linux/kernel/git/mtd/linux:
        mtd: spi-nor: replace unnecessary div64_u64() with div_u64()
        mtd: mchp23k256: drop unneeded MODULE_ALIAS
        dt-bindings: mtd: fixed-partition: Add binman compatibles
        dt-bindings: mtd: fixed-partitions: Add alignment properties
        mtd: maps: sa1100-flash: Prefer struct_size over open coded arithmetic
        mtd: core: Align comment with an action in mtd_otp_nvmem_add()
        mtd: rawnand: hynix: fixed typo
        mtd: rawnand: davinci: Add dummy read after sending command
        mtd: partitions: redboot: Added conversion of operands to a larger type
        dt-bindings: mtd: Add Samsung S5Pv210 OneNAND
        mtd: core: Don't fail mtd_otp_nvmem_add() if OTP is unsupported
        mtd: core: Report error if first mtd_otp_size() call fails in mtd_otp_nvmem_add()
      b426433c
    • Linus Torvalds's avatar
      Merge tag 'mmc-v6.10' of git://git.kernel.org/pub/scm/linux/kernel/git/ulfh/mmc · 8b06f753
      Linus Torvalds authored
      Pull MMC updates from Ulf Hansson:
       "MMC core:
         - Increase the timeout period of the ACMD41 command
         - Add card entry for quirks to debugfs
         - Add mmc_gpiod_set_cd_config() function
         - Store owner from SDIO modules with sdio_register_driver()
      
        MMC host:
         - atmel-mci: Some cleanups and a switch to use dev_err_probe()
         - renesas_sdhi:
            - Add support for RZ/G2L, RZ/G3S and RZ/V2M variants
            - Set the SDBUF after reset
         - sdhci: Add support for "Tuning Error" interrupts
         - sdhci-acpi:
            - Add quirk to enable pull-up on the card-detect GPIO on Asus
              T100TA
            - Disable write protect detection on Toshiba WT10-A
            - Fix Lenovo Yoga Tablet 2 Pro 1380 sdcard slot not working
         - sdhci_am654:
            - Re-work and fix the tuning support for multiple speed-modes
            - Add tuning algorithm for delay chain
         - sdhci-esdhc-imx: Add NXP S32G3 support
         - sdhci-of-dwcmshc:
            - Add tuning support for Sophgo CV1800B and SG200X
            - Implement SDHCI CQE support
         - sdhci-pci-gli: Use the proper pci_set_power_state() instead of
           PMCSR writes"
      
        MEMSTICK:
         - Convert a couple of drivers to use the ->remove_new() callback"
      
      * tag 'mmc-v6.10' of git://git.kernel.org/pub/scm/linux/kernel/git/ulfh/mmc: (59 commits)
        mmc: renesas_sdhi: Add compatible string for RZ/G2L family, RZ/G3S, and RZ/V2M SoCs
        dt-bindings: mmc: renesas,sdhi: Document RZ/G2L family compatibility
        dt-bindings: mmc: renesas,sdhi: Group single const value items into an enum list
        mmc: renesas_sdhi: Set the SDBUF after reset
        mmc: core: Increase the timeout period of the ACMD41 command
        mmc: core: Convert to use __mmc_poll_for_busy() SD_APP_OP_COND too
        mmc: atmel-mci: Switch to use dev_err_probe()
        mmc: atmel-mci: Incapsulate used to be a platform data into host structure
        mmc: atmel-mci: Replace platform device pointer by generic one
        mmc: atmel-mci: Use temporary variable for struct device
        mmc: atmel-mci: Get rid of platform data leftovers
        mmc: sdhci-of-dwcmshc: Add tuning support for Sophgo CV1800B and SG200X
        mmc: sdhci-of-dwcmshc: Remove useless "&" of th1520_execute_tuning
        mmc: sdhci-s3c: Choose sdhci_ops based on variant
        mmc: sdhci_am654: Constify struct sdhci_ops
        mmc: sdhci-sprd: Constify struct sdhci_ops
        mmc: sdhci-omap: Constify struct sdhci_ops
        mmc: sdhci-esdhc-mcf: Constify struct sdhci_ops
        mmc: slot-gpio: Use irq_handler_t type
        mmc: sdhci-acpi: Add quirk to enable pull-up on the card-detect GPIO on Asus T100TA
        ...
      8b06f753
    • Linus Torvalds's avatar
      Merge tag 'pmdomain-v6.10' of git://git.kernel.org/pub/scm/linux/kernel/git/ulfh/linux-pm · 8b35a3bb
      Linus Torvalds authored
      Pull pmdomain updates from Ulf Hansson:
       "pmdomain core:
         - Don't clear suspended_count at genpd_prepare()
         - Update the rejected/usage counters at system suspend too
      
        pmdomain providers:
         - ti-sci: Fix duplicate PD referrals
         - mediatek: Add MT8188 buck isolation setting
         - renesas: Add R-Car M3-W power-off delay quirk
         - renesas: Split R-Car M3-W and M3-W+ sub-drivers
      
        cpuidle-psci:
         - Update MAINTAINERS to set a git for DT IDLE PM DOMAIN/ARM PSCI PM
           DOMAIN
         - Update init level to core_initcall()
         - Drop superfluous wrappers psci_dt_attach|detach_cpu()"
      
      * tag 'pmdomain-v6.10' of git://git.kernel.org/pub/scm/linux/kernel/git/ulfh/linux-pm:
        pmdomain: ti-sci: Fix duplicate PD referrals
        pmdomain: core: Don't clear suspended_count at genpd_prepare()
        pmdomain: core: Update the rejected/usage counters at system suspend too
        pmdomain: renesas: rcar-sysc: Add R-Car M3-W power-off delay quirk
        pmdomain: renesas: rcar-sysc: Remove rcar_sysc_nullify() helper
        pmdomain: renesas: rcar-sysc: Split R-Car M3-W and M3-W+ sub-drivers
        pmdomain: renesas: rcar-sysc: Absorb rcar_sysc_ch into rcar_sysc_pd
        MAINTAINERS: Add a git for the DT IDLE PM DOMAIN
        MAINTAINERS: Add a git for the ARM PSCI PM DOMAIN
        cpuidle: psci: Update init level to core_initcall()
        cpuidle: psci: Drop superfluous wrappers psci_dt_attach|detach_cpu()
        pmdomain: mediatek: Add MT8188 buck isolation setting
        pmdomain: mediatek: scpsys: drop driver owner assignment
      8b35a3bb
    • Linus Torvalds's avatar
      Merge tag 'media/v6.10-1' of git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-media · 6fd600d7
      Linus Torvalds authored
      Pull media updates from Mauro Carvalho Chehab:
      
       - New V4L2 ioctl VIDIOC_REMOVE_BUFS
      
       - experimental support for using generic metaformats on V4L2 core
      
       - New drivers: Intel IPU6 controller driver, Broadcom BCM283x/BCM271x
      
       - More cleanups at atomisp driver
      
       - Usual bunch of driver cleanups, improvements and fixes
      
      * tag 'media/v6.10-1' of git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-media: (328 commits)
        media: bcm2835-unicam: Depend on COMMON_CLK
        Revert "media: v4l2-ctrls: show all owned controls in log_status"
        media: ov2740: Ensure proper reset sequence on probe()
        media: intel/ipu6: Don't print user-triggerable errors to kernel log
        media: bcm2835-unicam: Fix driver path in MAINTAINERS
        media: bcm2835-unicam: Fix a NULL vs IS_ERR() check
        media: bcm2835-unicam: Do not print error when irq not found
        media: bcm2835-unicam: Do not replace IRQ retcode during probe
        media: bcm2835-unicam: Convert to platform remove callback returning void
        media: media: intel/ipu6: Fix spelling mistake "remappinp" -> "remapping"
        media: intel/ipu6: explicitly include vmalloc.h
        media: cec.h: Fix kerneldoc
        media: uvcvideo: Refactor iterators
        media: v4l: async: refactor v4l2_async_create_ancillary_links
        media: intel/ipu6: Don't re-allocate memory for firmware
        media: dvb-frontends: tda10048: Fix integer overflow
        media: tc358746: Use the correct div_ function
        media: i2c: st-mipid02: Use the correct div function
        media: tegra-vde: Refactor timeout handling
        media: stk1160: Use min macro
        ...
      6fd600d7
    • Linus Torvalds's avatar
      Merge tag 'drm-next-2024-05-16' of https://gitlab.freedesktop.org/drm/kernel · 972a2543
      Linus Torvalds authored
      Pull drm fix from Dave Airlie:
      
       - fix breakage in buddy allocator
      
      * tag 'drm-next-2024-05-16' of https://gitlab.freedesktop.org/drm/kernel:
        drm/tests: Add a unit test for range bias allocation
        drm/buddy: Fix the range bias clear memory allocation issue
      972a2543
    • Miquel Raynal's avatar
      Merge tag 'nand/for-6.10' into mtd/next · 552c9380
      Miquel Raynal authored
      Raw NAND:
      
      Two small fixes, one in the Hynix vendor code for properly returning an
      error which might have been ignored and another in the Davinci driver to
      properly synchronize the controller with the gpio domain.
      Signed-off-by: default avatarMiquel Raynal <miquel.raynal@bootlin.com>
      552c9380
    • Miquel Raynal's avatar
      Merge tag 'spi-nor/for-6.10' into mtd/next · 964b8998
      Miquel Raynal authored
      SPI NOR now uses div_u64() instead of div64_u64() in places where the
      divisor is 32 bits. Many 32 bit architectures can optimize this variant
      better than a full 64 bit divide.
      Signed-off-by: default avatarMiquel Raynal <miquel.raynal@bootlin.com>
      964b8998
    • Arunpravin Paneer Selvam's avatar
      drm/tests: Add a unit test for range bias allocation · 431c590c
      Arunpravin Paneer Selvam authored
      Allocate cleared blocks in the bias range when the DRM
      buddy's clear avail is zero. This will validate the bias
      range allocation in scenarios like system boot when no
      cleared blocks are available and exercise the fallback
      path too. The resulting blocks should always be dirty.
      
      v1:(Matthew)
        - move the size to the variable declaration section.
        - move the mm.clear_avail init to allocator init.
      Signed-off-by: default avatarArunpravin Paneer Selvam <Arunpravin.PaneerSelvam@amd.com>
      Reviewed-by: default avatarMatthew Auld <matthew.auld@intel.com>
      Signed-off-by: default avatarDave Airlie <airlied@redhat.com>
      Link: https://patchwork.freedesktop.org/patch/msgid/20240514145636.16253-2-Arunpravin.PaneerSelvam@amd.com
      431c590c
    • Arunpravin Paneer Selvam's avatar
      drm/buddy: Fix the range bias clear memory allocation issue · bb21700b
      Arunpravin Paneer Selvam authored
      Problem statement: During the system boot time, an application request
      for the bulk volume of cleared range bias memory when the clear_avail
      is zero, we dont fallback into normal allocation method as we had an
      unnecessary clear_avail check which prevents the fallback method leads
      to fb allocation failure following system goes into unresponsive state.
      
      Solution: Remove the unnecessary clear_avail check in the range bias
      allocation function.
      
      v2: add a kunit for this corner case (Daniel Vetter)
      Signed-off-by: default avatarArunpravin Paneer Selvam <Arunpravin.PaneerSelvam@amd.com>
      Fixes: 96950929 ("drm/buddy: Implement tracking clear page feature")
      Reviewed-by: default avatarMatthew Auld <matthew.auld@intel.com>
      Signed-off-by: default avatarDave Airlie <airlied@redhat.com>
      Link: https://patchwork.freedesktop.org/patch/msgid/20240514145636.16253-1-Arunpravin.PaneerSelvam@amd.com
      bb21700b
    • Linus Torvalds's avatar
      Merge tag 'wq-for-6.10' of git://git.kernel.org/pub/scm/linux/kernel/git/tj/wq · 3c999d1a
      Linus Torvalds authored
      Pull workqueue updates from Tejun Heo:
      
       - Work items can now be disabled and enabled, and cancel_work_sync()
         and disable_work() can be called form atomic contexts for BH work
         items.
      
         This closes feature gap with tasklet and should allow converting all
         existing tasklet users to BH workqueues.
      
       - Improve pool sharing for unbound workqueues with strict affinity.
      
       - Misc changes including doc updates, improved debug annotations and
         cleanups.
      
      * tag 'wq-for-6.10' of git://git.kernel.org/pub/scm/linux/kernel/git/tj/wq:
        workqueue: Use "@..." in function comment to describe variable length argument
        workqueue: Add destroy_work_on_stack() in workqueue_softirq_dead()
        workqueue: remove unnecessary import and function in wq_monitor.py
        workqueue: Introduce enable_and_queue_work() convenience function
        workqueue: add function in event of workqueue_activate_work
        workqueue: Cleanup subsys attribute registration
        workqueue: Use list_last_entry() to get the last idle worker
        workqueue: Move attrs->cpumask out of worker_pool's properties when attrs->affn_strict
        workqueue: Use INIT_WORK_ONSTACK in workqueue_softirq_dead()
        workqueue: Allow cancel_work_sync() and disable_work() from atomic contexts on BH work items
        workqueue: Remember whether a work item was on a BH workqueue
        workqueue: Remove WORK_OFFQ_CANCELING
        workqueue: Implement disable/enable for (delayed) work items
        workqueue: Preserve OFFQ bits in cancel[_sync] paths
      3c999d1a
    • Linus Torvalds's avatar
      Merge tag 'cgroup-for-6.10' of git://git.kernel.org/pub/scm/linux/kernel/git/tj/cgroup · de6fef50
      Linus Torvalds authored
      Pull cgroup updates from Tejun Heo:
      
       - The locking around cpuset hotplug processing has always been a bit of
         mess which was worked around by making hotplug processing
         asynchronous. The asynchronity isn't great and led to other issues.
      
         We tried to make the behavior synchronous a while ago but that led to
         lockdep splats. Waiman took another stab at cleaning up and making it
         synchronous. The patch has been in -next for well over a month and
         there haven't been any complaints, so fingers crossed.
      
       - Tracepoints added to help understanding rstat lock contentions.
      
       - A bunch of minor changes - doc updates, code cleanups and selftests.
      
      * tag 'cgroup-for-6.10' of git://git.kernel.org/pub/scm/linux/kernel/git/tj/cgroup: (24 commits)
        cgroup/rstat: add cgroup_rstat_cpu_lock helpers and tracepoints
        selftests/cgroup: Drop define _GNU_SOURCE
        docs: cgroup-v1: Update page cache removal functions
        selftests/cgroup: fix uninitialized variables in test_zswap.c
        selftests/cgroup: cpu_hogger init: use {} instead of {NULL}
        selftests/cgroup: fix clang warnings: uninitialized fd variable
        selftests/cgroup: fix clang build failures for abs() calls
        cgroup/cpuset: Remove outdated comment in sched_partition_write()
        cgroup/cpuset: Fix incorrect top_cpuset flags
        cgroup/cpuset: Avoid clearing CS_SCHED_LOAD_BALANCE twice
        cgroup/cpuset: Statically initialize more members of top_cpuset
        cgroup: Avoid unnecessary looping in cgroup_no_v1()
        cgroup, legacy_freezer: update comment for freezer_css_offline()
        docs, cgroup: add entries for pids to cgroup-v2.rst
        cgroup: don't call cgroup1_pidlist_destroy_all() for v2
        cgroup_freezer: update comment for freezer_css_online()
        cgroup/rstat: desc member cgrp in cgroup_rstat_flush_release
        cgroup/rstat: add cgroup_rstat_lock helpers and tracepoints
        cgroup/pids: Remove superfluous zeroing
        docs: cgroup-v1: Fix description for css_online
        ...
      de6fef50
  2. 15 May, 2024 26 commits
    • Linus Torvalds's avatar
      Merge tag 'for-linus' of git://git.kernel.org/pub/scm/virt/kvm/kvm · f4b0c4b5
      Linus Torvalds authored
      Pull KVM updates from Paolo Bonzini:
       "ARM:
      
         - Move a lot of state that was previously stored on a per vcpu basis
           into a per-CPU area, because it is only pertinent to the host while
           the vcpu is loaded. This results in better state tracking, and a
           smaller vcpu structure.
      
         - Add full handling of the ERET/ERETAA/ERETAB instructions in nested
           virtualisation. The last two instructions also require emulating
           part of the pointer authentication extension. As a result, the trap
           handling of pointer authentication has been greatly simplified.
      
         - Turn the global (and not very scalable) LPI translation cache into
           a per-ITS, scalable cache, making non directly injected LPIs much
           cheaper to make visible to the vcpu.
      
         - A batch of pKVM patches, mostly fixes and cleanups, as the
           upstreaming process seems to be resuming. Fingers crossed!
      
         - Allocate PPIs and SGIs outside of the vcpu structure, allowing for
           smaller EL2 mapping and some flexibility in implementing more or
           less than 32 private IRQs.
      
         - Purge stale mpidr_data if a vcpu is created after the MPIDR map has
           been created.
      
         - Preserve vcpu-specific ID registers across a vcpu reset.
      
         - Various minor cleanups and improvements.
      
        LoongArch:
      
         - Add ParaVirt IPI support
      
         - Add software breakpoint support
      
         - Add mmio trace events support
      
        RISC-V:
      
         - Support guest breakpoints using ebreak
      
         - Introduce per-VCPU mp_state_lock and reset_cntx_lock
      
         - Virtualize SBI PMU snapshot and counter overflow interrupts
      
         - New selftests for SBI PMU and Guest ebreak
      
         - Some preparatory work for both TDX and SNP page fault handling.
      
           This also cleans up the page fault path, so that the priorities of
           various kinds of fauls (private page, no memory, write to read-only
           slot, etc.) are easier to follow.
      
        x86:
      
         - Minimize amount of time that shadow PTEs remain in the special
           REMOVED_SPTE state.
      
           This is a state where the mmu_lock is held for reading but
           concurrent accesses to the PTE have to spin; shortening its use
           allows other vCPUs to repopulate the zapped region while the zapper
           finishes tearing down the old, defunct page tables.
      
         - Advertise the max mappable GPA in the "guest MAXPHYADDR" CPUID
           field, which is defined by hardware but left for software use.
      
           This lets KVM communicate its inability to map GPAs that set bits
           51:48 on hosts without 5-level nested page tables. Guest firmware
           is expected to use the information when mapping BARs; this avoids
           that they end up at a legal, but unmappable, GPA.
      
         - Fixed a bug where KVM would not reject accesses to MSR that aren't
           supposed to exist given the vCPU model and/or KVM configuration.
      
         - As usual, a bunch of code cleanups.
      
        x86 (AMD):
      
         - Implement a new and improved API to initialize SEV and SEV-ES VMs,
           which will also be extendable to SEV-SNP.
      
           The new API specifies the desired encryption in KVM_CREATE_VM and
           then separately initializes the VM. The new API also allows
           customizing the desired set of VMSA features; the features affect
           the measurement of the VM's initial state, and therefore enabling
           them cannot be done tout court by the hypervisor.
      
           While at it, the new API includes two bugfixes that couldn't be
           applied to the old one without a flag day in userspace or without
           affecting the initial measurement. When a SEV-ES VM is created with
           the new VM type, KVM_GET_REGS/KVM_SET_REGS and friends are rejected
           once the VMSA has been encrypted. Also, the FPU and AVX state will
           be synchronized and encrypted too.
      
         - Support for GHCB version 2 as applicable to SEV-ES guests.
      
           This, once more, is only accessible when using the new
           KVM_SEV_INIT2 flow for initialization of SEV-ES VMs.
      
        x86 (Intel):
      
         - An initial bunch of prerequisite patches for Intel TDX were merged.
      
           They generally don't do anything interesting. The only somewhat
           user visible change is a new debugging mode that checks that KVM's
           MMU never triggers a #VE virtualization exception in the guest.
      
         - Clear vmcs.EXIT_QUALIFICATION when synthesizing an EPT Misconfig
           VM-Exit to L1, as per the SDM.
      
        Generic:
      
         - Use vfree() instead of kvfree() for allocations that always use
           vcalloc() or __vcalloc().
      
         - Remove .change_pte() MMU notifier - the changes to non-KVM code are
           small and Andrew Morton asked that I also take those through the
           KVM tree.
      
           The callback was only ever implemented by KVM (which was also the
           original user of MMU notifiers) but it had been nonfunctional ever
           since calls to set_pte_at_notify were wrapped with
           invalidate_range_start and invalidate_range_end... in 2012.
      
        Selftests:
      
         - Enhance the demand paging test to allow for better reporting and
           stressing of UFFD performance.
      
         - Convert the steal time test to generate TAP-friendly output.
      
         - Fix a flaky false positive in the xen_shinfo_test due to comparing
           elapsed time across two different clock domains.
      
         - Skip the MONITOR/MWAIT test if the host doesn't actually support
           MWAIT.
      
         - Avoid unnecessary use of "sudo" in the NX hugepage test wrapper
           shell script, to play nice with running in a minimal userspace
           environment.
      
         - Allow skipping the RSEQ test's sanity check that the vCPU was able
           to complete a reasonable number of KVM_RUNs, as the assert can fail
           on a completely valid setup.
      
           If the test is run on a large-ish system that is otherwise idle,
           and the test isn't affined to a low-ish number of CPUs, the vCPU
           task can be repeatedly migrated to CPUs that are in deep sleep
           states, which results in the vCPU having very little net runtime
           before the next migration due to high wakeup latencies.
      
         - Define _GNU_SOURCE for all selftests to fix a warning that was
           introduced by a change to kselftest_harness.h late in the 6.9
           cycle, and because forcing every test to #define _GNU_SOURCE is
           painful.
      
         - Provide a global pseudo-RNG instance for all tests, so that library
           code can generate random, but determinstic numbers.
      
         - Use the global pRNG to randomly force emulation of select writes
           from guest code on x86, e.g. to help validate KVM's emulation of
           locked accesses.
      
         - Allocate and initialize x86's GDT, IDT, TSS, segments, and default
           exception handlers at VM creation, instead of forcing tests to
           manually trigger the related setup.
      
        Documentation:
      
         - Fix a goof in the KVM_CREATE_GUEST_MEMFD documentation"
      
      * tag 'for-linus' of git://git.kernel.org/pub/scm/virt/kvm/kvm: (225 commits)
        selftests/kvm: remove dead file
        KVM: selftests: arm64: Test vCPU-scoped feature ID registers
        KVM: selftests: arm64: Test that feature ID regs survive a reset
        KVM: selftests: arm64: Store expected register value in set_id_regs
        KVM: selftests: arm64: Rename helper in set_id_regs to imply VM scope
        KVM: arm64: Only reset vCPU-scoped feature ID regs once
        KVM: arm64: Reset VM feature ID regs from kvm_reset_sys_regs()
        KVM: arm64: Rename is_id_reg() to imply VM scope
        KVM: arm64: Destroy mpidr_data for 'late' vCPU creation
        KVM: arm64: Use hVHE in pKVM by default on CPUs with VHE support
        KVM: arm64: Fix hvhe/nvhe early alias parsing
        KVM: SEV: Allow per-guest configuration of GHCB protocol version
        KVM: SEV: Add GHCB handling for termination requests
        KVM: SEV: Add GHCB handling for Hypervisor Feature Support requests
        KVM: SEV: Add support to handle AP reset MSR protocol
        KVM: x86: Explicitly zero kvm_caps during vendor module load
        KVM: x86: Fully re-initialize supported_mce_cap on vendor module load
        KVM: x86: Fully re-initialize supported_vm_types on vendor module load
        KVM: x86/mmu: Sanity check that __kvm_faultin_pfn() doesn't create noslot pfns
        KVM: x86/mmu: Initialize kvm_page_fault's pfn and hva to error values
        ...
      f4b0c4b5
    • Tejun Heo's avatar
      a2a58909
    • Linus Torvalds's avatar
      Merge tag 'cxl-for-6.10' of git://git.kernel.org/pub/scm/linux/kernel/git/cxl/cxl · 2e925002
      Linus Torvalds authored
      Pull CXL updates from Dave Jiang:
      
       - Three CXL mailbox passthrough commands are added to support the
         populating and clearing of vendor debug logs:
           - Get Log Capabilities
           - Get Supported Log Sub-List Commands
           - Clear Log
      
       - Add support of Device Phyiscal Address (DPA) to Host Physical Address
         (HPA) translation for CXL events of cxl_dram and cxl_general media.
      
         This allows user space to figure out which CXL region the event
         occured via trace event.
      
       - Connect CXL to CPER reporting.
      
         If a device is configured for firmware first, CXL event records are
         not sent directly to the host. Those records are reported through EFI
         Common Platform Error Records (CPER). Add support to route the CPER
         records through the CXL sub-system in order to provide DPA to HPA
         translation and also event decoding and tracing. This is useful for
         users to determine which system issues may correspond to specific
         hardware events.
      
       - A number of misc cleanups and fixes:
           - Fix for compile warning of cxl_security_ops
           - Add debug message for invalid interleave granularity
           - Enhancement to cxl-test event testing
           - Add dev_warn() on unsupported mixed mode decoder
           - Fix use of phys_to_target_node() for x86
           - Use helper function for decoder enum instead of open coding
           - Include missing headers for cxl-event
           - Fix MAINTAINERS file entry
           - Fix cxlr_pmem memory leak
           - Cleanup __cxl_parse_cfmws via scope-based resource menagement
           - Convert cxl_pmem_region_alloc() to scope-based resource management
      
      * tag 'cxl-for-6.10' of git://git.kernel.org/pub/scm/linux/kernel/git/cxl/cxl: (21 commits)
        cxl/cper: Remove duplicated GUID defines
        cxl/cper: Fix non-ACPI-APEI-GHES build
        cxl/pci: Process CPER events
        acpi/ghes: Process CXL Component Events
        cxl/region: Convert cxl_pmem_region_alloc to scope-based resource management
        cxl/acpi: Cleanup __cxl_parse_cfmws()
        cxl/region: Fix cxlr_pmem leaks
        cxl/core: Add region info to cxl_general_media and cxl_dram events
        cxl/region: Move cxl_trace_hpa() work to the region driver
        cxl/region: Move cxl_dpa_to_region() work to the region driver
        cxl/trace: Correct DPA field masks for general_media & dram events
        MAINTAINERS: repair file entry in COMPUTE EXPRESS LINK
        cxl/cxl-event: include missing <linux/types.h> and <linux/uuid.h>
        cxl/hdm: Debug, use decoder name function
        cxl: Fix use of phys_to_target_node() for x86
        cxl/hdm: dev_warn() on unsupported mixed mode decoder
        cxl/test: Enhance event testing
        cxl/hdm: Add debug message for invalid interleave granularity
        cxl: Fix compile warning for cxl_security_ops extern
        cxl/mbox: Add Clear Log mailbox command
        ...
      2e925002
    • Linus Torvalds's avatar
      Merge tag 'libnvdimm-for-6.10' of git://git.kernel.org/pub/scm/linux/kernel/git/nvdimm/nvdimm · c405aa3e
      Linus Torvalds authored
      Pull nvdimm updates from Ira Weiny:
       "The changes include removing duplicate code and updating the nvdimm
        tree to the current kernel interfaces such as using const for struct
        device_type and changing the platform remove callback signature"
      
      * tag 'libnvdimm-for-6.10' of git://git.kernel.org/pub/scm/linux/kernel/git/nvdimm/nvdimm:
        dax: remove redundant assignment to variable rc
        ndtest: Convert to platform remove callback returning void
        nvdimm/btt: always set max_integrity_segments
        nvdimm: remove nd_integrity_init
        dax: constify the struct device_type usage
        powerpc/papr_scm: Move duplicate definitions to common header files
      c405aa3e
    • Linus Torvalds's avatar
      Merge tag 'modules-6.10-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/mcgrof/linux · a4946824
      Linus Torvalds authored
      Pull modules updates from Luis Chamberlain:
       "Finally something fun. Mike Rapoport does some cleanup to allow us to
        take out module_alloc() out of modules into a new paint shedded
        execmem_alloc() and execmem_free() so to make emphasis these helpers
        are actually used outside of modules.
      
        It starts with a non-functional changes API rename / placeholders to
        then allow architectures to define their requirements into a new shiny
        struct execmem_info with ranges, and requirements for those ranges.
      
        Archs now can intitialize this execmem_info as the last part of
        mm_core_init() if they have to diverge from the norm. Each range is a
        known type clearly articulated and spelled out in enum execmem_type.
      
        Although a lot of this is major cleanup and prep work for future
        enhancements an immediate clear gain is we get to enable KPROBES
        without MODULES now. That is ultimately what motiviated to pick this
        work up again, now with smaller goal as concrete stepping stone"
      
      * tag 'modules-6.10-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/mcgrof/linux:
        bpf: remove CONFIG_BPF_JIT dependency on CONFIG_MODULES of
        kprobes: remove dependency on CONFIG_MODULES
        powerpc: use CONFIG_EXECMEM instead of CONFIG_MODULES where appropriate
        x86/ftrace: enable dynamic ftrace without CONFIG_MODULES
        arch: make execmem setup available regardless of CONFIG_MODULES
        powerpc: extend execmem_params for kprobes allocations
        arm64: extend execmem_info for generated code allocations
        riscv: extend execmem_params for generated code allocations
        mm/execmem, arch: convert remaining overrides of module_alloc to execmem
        mm/execmem, arch: convert simple overrides of module_alloc to execmem
        mm: introduce execmem_alloc() and execmem_free()
        module: make module_memory_{alloc,free} more self-contained
        sparc: simplify module_alloc()
        nios2: define virtual address space for modules
        mips: module: rename MODULE_START to MODULES_VADDR
        arm64: module: remove unneeded call to kasan_alloc_module_shadow()
        kallsyms: replace deprecated strncpy with strscpy
        module: allow UNUSED_KSYMS_WHITELIST to be relative against objtree.
      a4946824
    • Linus Torvalds's avatar
      Merge tag 'livepatching-for-6.10' of... · 8c06da67
      Linus Torvalds authored
      Merge tag 'livepatching-for-6.10' of git://git.kernel.org/pub/scm/linux/kernel/git/livepatching/livepatching
      
      Pull livepatching update from Petr Mladek:
      
       - Use more informative names for the livepatch transition states
      
      * tag 'livepatching-for-6.10' of git://git.kernel.org/pub/scm/linux/kernel/git/livepatching/livepatching:
        livepatch: Rename KLP_* to KLP_TRANSITION_*
      8c06da67
    • Linus Torvalds's avatar
      Merge tag 'printk-for-6.10' of git://git.kernel.org/pub/scm/linux/kernel/git/printk/linux · a19264d0
      Linus Torvalds authored
      Pull printk updates from Petr Mladek:
      
       - Use no_printk() instead of "if (0) printk()" constructs to avoid
         generating printk index for messages disabled at compile time
      
       - Remove deprecated strncpy/strcpy from printk.c
      
       - Remove redundant CONFIG_BASE_FULL in favor of CONFIG_BASE_SMALL
      
      * tag 'printk-for-6.10' of git://git.kernel.org/pub/scm/linux/kernel/git/printk/linux:
        printk: cleanup deprecated uses of strncpy/strcpy
        printk: Remove redundant CONFIG_BASE_FULL
        printk: Change type of CONFIG_BASE_SMALL to bool
        printk: Fix LOG_CPU_MAX_BUF_SHIFT when BASE_SMALL is enabled
        ceph: Use no_printk() helper
        dyndbg: Use *no_printk() helpers
        dev_printk: Add and use dev_no_printk()
        printk: Let no_printk() use _printk()
      a19264d0
    • Linus Torvalds's avatar
      Merge tag '6.10-rc-smb3-fixes' of git://git.samba.org/sfrench/cifs-2.6 · 1ab1bd2f
      Linus Torvalds authored
      Pull smb client updates from Steve French:
      
       - three important fixes to recent netfs conversion to fix various
         xfstest failures, and rmmod oops
      
       - cleanup patch to fix various GCC-14 warnings
      
      * tag '6.10-rc-smb3-fixes' of git://git.samba.org/sfrench/cifs-2.6:
        smb3: fix perf regression with cached writes with netfs conversion
        cifs: Fix locking in cifs_strict_readv()
        cifs: Change from mempool_destroy to mempool_exit for request pools
        smb: smb2pdu.h: Avoid -Wflex-array-member-not-at-end warnings
      1ab1bd2f
    • Paolo Bonzini's avatar
      selftests/kvm: remove dead file · cba23f33
      Paolo Bonzini authored
      This file was supposed to be removed in commit 2b7deea3 ("Revert
      "kvm: selftests: move base kvm_util.h declarations to kvm_util_base.h""),
      but it survived.  Remove it now.
      Signed-off-by: default avatarPaolo Bonzini <pbonzini@redhat.com>
      cba23f33
    • Linus Torvalds's avatar
      Merge tag 'sound-6.10-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound · 33e02dc6
      Linus Torvalds authored
      Pull sound updates from Takashi Iwai:
       "This one became bigger than usual, not in the total size but rather
        containing lots of small changes all over the places.
      
        The majority of changes are about ASoC, especially SOF / Intel stuff,
        and we see an interesting work for ASoC DAPM graph visualization,
        while there are many other code cleanup and refactoring, too.
      
        Core:
         - A deadlock fix at device disconnection
         - A new tool dapm-graph for visualising the DAPM state
      
        ASoC:
         - Large updates throughout the Intel audio drivers
         - Fixes and clarifications for the DAPM documentation
         - Cleanups of accessors for driver data, module labelling, and for
           constification
         - Modernsation and cleanup work in the Mediatek drivers
         - Several fixes and features for the DaVinci I2S driver
         - New drivers for several AMD and Intel platforms, Nuvoton NAU8325,
           Rockchip RK3308 and Texas Instruments PCM6240
      
        HD-audio:
         - Cleanup for CONFIG_PM dependencies
         - Cirrus HD-audio codec fixes and quirks
      
        Others:
         - Series of tree-wide fixes in Makefiles to use *-y
         - Additions of missing module descriptions
         - Scarlett2 USB mixer enhancements
         - A series of legacy emu10k1 fixes and improvements"
      
      * tag 'sound-6.10-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/tiwai/sound: (603 commits)
        ALSA: hda/realtek: Drop doubly quirk entry for 103c:8a2e
        ALSA: hda/realtek - fixed headset Mic not show
        ASoC: SOF: amd: Fix build error with built-in config
        ALSA: scarlett2: Increase mixer range to +12dB
        ALSA: scarlett2: Add S/PDIF source selection controls
        ALSA: core: Remove superfluous CONFIG_PM
        ALSA: Fix deadlocks with kctl removals at disconnection
        ASoC: audio-graph-card2: call of_node_get() before of_get_next_child()
        ASoC: SOF: amd: Correct spaces in Makefile
        ASoC: rt715-sdca-sdw: Fix wrong complete waiting in rt715_dev_resume()
        ASoC: Intel: sof_sdw_rt_amp: use dai parameter
        ASoC: Intel: sof_sdw: add dai parameter to rtd_init callback
        ASoC: Intel: sof_sdw: use .controls/.widgets to add controls/widgets
        ASoC: Intel: sof_sdw: add controls and dapm widgets in codec_info
        ASoC: Intel: sof_sdw: use generic name for controls/widgets
        ASoC: Intel: sof_sdw_cs_amp: rename Speakers to Speaker
        ASoC: Intel: maxim-common: change max98373 data to static
        ASoC: Intel: sof_sdw: add max98373 dapm routes
        ASoC: Intel: sof_rt5682: use max_98373_dai_link function
        ASoC: Intel: sof_nau8825: use max_98373_dai_link function
        ...
      33e02dc6
    • Linus Torvalds's avatar
      Merge tag 'fbdev-for-6.10-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/deller/linux-fbdev · d3467277
      Linus Torvalds authored
      Pull fbdev updates from Helge Deller:
       "Code cleanups for offb, shmobile, sisfb, savage, au1200fb, uvesafb,
        omap2 and sh7760fb, as well as the addition of some HAS_IOPORT
        dependencies and adjustment of generated logo file to make build
        reproducible"
      
      * tag 'fbdev-for-6.10-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/deller/linux-fbdev:
        fbdev: offb: replace of_node_put with __free(device_node)
        fbdev: savage: Handle err return when savagefb_check_var failed
        video: hdmi: prefer length specifier in format over string copying
        fbdev: uvesafb: replace deprecated strncpy with strscpy_pad
        fbdev: au1200fb: replace deprecated strncpy with strscpy
        fbdev: fsl-diu-fb: replace deprecated strncpy with strscpy_pad
        video: logo: Drop full path of the input filename in generated file
        fbdev: add HAS_IOPORT dependencies
        fbdev: sh7760fb: allow modular build
        fbdev: sisfb: hide unused variables
        fbdev: shmobile: fix snprintf truncation
        fbdev: omap2: replace of_graph_get_next_endpoint()
      d3467277
    • Linus Torvalds's avatar
      Merge tag 'drm-next-2024-05-15' of https://gitlab.freedesktop.org/drm/kernel · db5d28c0
      Linus Torvalds authored
      Pull drm updates from Dave Airlie:
       "This is the main pull request for the drm subsystems for 6.10.
      
        In drivers the main thing is a new driver for ARM Mali firmware based
        GPUs, otherwise there are a lot of changes to amdgpu/xe/i915/msm and
        scattered changes to everything else.
      
        In the core a bunch of headers and Kconfig was refactored, along with
        the addition of a new panic handler which is meant to provide a user
        friendly message when a panic happens and graphical display is
        enabled.
      
        New drivers:
         - panthor: ARM Mali/Immortalis CSF-based GPU driver
      
        Core:
         - add a CONFIG_DRM_WERROR option
         - make more headers self-contained
         - grab resv lock in pin/unpin
         - fix vmap resv locking
         - EDID/eDP panel matching
         - Kconfig cleanups
         - DT sound bindings
         - Add SIZE_HINTS property for cursor planes
         - Add struct drm_edid_product_id and helpers.
         - Use drm device based logging in more drm functions.
         - drop seq_file.h from a bunch of places
         - use drm_edid driver conversions
      
        dp:
         - DP Tunnel documentation
         - MST read sideband cap
         - Adaptive sync SDP prep work
      
        ttm:
         - improve placement for TTM BOs in idle/busy handling
      
        panic:
         - Fixes for drm-panic, and option to test it.
         - Add drm panic to simpledrm, mgag200, imx, ast
      
        bridge:
         - improve init ordering
         - adv7511: allow GPIO pin sharing
         - tc358775: add tc358675 support
      
        panel:
         - AUO B120XAN01.0
         - Samsung s6e3fa7
         - BOE NT116WHM-N44
         - CMN N116BCA-EA1,
         - CrystalClear CMT430B19N00
         - Startek KD050HDFIA020-C020A
         - powertip PH128800T006-ZHC01
         - Innolux G121X1-L03
         - LG sw43408
         - Khadas TS050 V2
         - EDO RM69380 OLED
         - CSOT MNB601LS1-1
      
        amdgpu:
         - HDCP/ODM/RAS fixes
         - Devcoredump improvements
         - Expose VCN activity via sysfs
         - SMY 13.0.x updates
         - Enable fast updates on DCN 3.1.4
         - Add dclk and vclk reporting on additional devices
         - Add ACA RAS infrastructure
         - Implement TLB flush fence
         - EEPROM handling fixes
         - SMUIO 14.0.2 support
         - SMU 14.0.1 Updates
         - SMU 14.0.2 support
         - Sync page table freeing with TLB flushes
         - DML2 refactor
         - DC debug improvements
         - DCN 3.5.x Updates
         - GPU reset fixes
         - HDP fix for second GFX pipe on GC 10.x
         - Enable secondary GFX pipe on GC 10.3
         - Refactor and clean up BACO/BOCO/BAMACO handling
         - Remove invalid TTM resource start check
         - UAF fix in VA IOCTL
         - GPUVM page fault redirection to secondary IH rings for IH 6.x
         - Initial support for mapping kernel queues via MES
         - Fix VRAM memory accounting
      
        amdkfd:
         - MQD handling cleanup
         - Preemption handling fixes for XCDs
         - TLB flush fix for GC 9.4.2
         - Properly clean up workqueue during module unload
         - Fix memory leak process create failure
         - Range check CP bad op exception targets to avoid reporting invalid exceptions to userspace
         - Fix eviction fence handling
         - Fix leak in GPU memory allocation failure case
         - DMABuf import handling fix
         - Enable SQ watchpoint for gfx10
      
        i915:
         - Adding new DG2 PCI ID
         - add context hints for GT frequency
         - enable only one CCS for compute workloads
         - new workarounds
         - Fix UAF on destroy against retire race and remove two earlier partial fixes
         - Limit the reserved VM space to only the platforms that need it
         - Fix gt reset with GuC submission is disable
         - Add and use gt_to_guc() wrapper
      
        i915/xe display:
         - Lunar Lake display enabling, including cdclk and other refactors
         - BIOS/VBT/opregion related refactor
         - Digital port related refactor/clean-up
         - Fix 2s boot time regression on DP panel replay init
         - Remove duplication on audio enable/disable on SDVO and g4x+ DP
         - Disable AuxCCS framebuffers if built for Xe
         - Make crtc disable more atomic
         - Increase DP idle pattern wait timeout to 2ms
         - Start using container_of_const() for some extra const safety
         - Fix Jasper Lake boot freeze
         - Enable MST mode for 128b/132b single-stream sideband
         - Enable Adaptive Sync SDP Support for DP
         - Fix MTL supported DP rates - removal of UHBR13.5
         - PLL refactoring
         - Limit eDP MSO pipe only for display version 20
         - More display refactor towards independence from i915 dev_priv
         - Convert i915/xe fbdev to DRM client
         - More initial work to make display code more independent from i915
      
        xe:
         - improved error capture
         - clean up some uAPI leftovers
         - devcoredump update
         - Add BMG mocs table
         - Handle GSCCS ER interrupt
         - Implement xe2- and GuC workarounds
         - struct xe_device cleanup
         - Hwmon updates
         - Add LRC parsing for more GPU instruction
         - Increase VM_BIND number of per-ioctl Ops
         - drm/xe: Add XE_BO_GGTT_INVALIDATE flag
         - Initial development for SR-IOV support
         - Add new PCI IDs to DG2 platform
         - Move userptr over to start using hmm_range_fault
      
        msm:
         - Switched to generating register header files during build process
           instead of shipping pre-generated headers
         - Merged DPU and MDP4 format databases.
         - DP:
           - Stop using compat string to distinguish DP and eDP cases
           - Added support for X Elite platform (X1E80100)
           - Reworked DP aux/audio support
           - Added SM6350 DP to the bindings
         - GPU:
           - a7xx perfcntr reg fixes
           - MAINTAINERS updates
           - a750 devcoredump support
      
        radeon:
         - Silence UBSAN warnings related to flexible arrays
      
        nouveau:
         - move some uAPI objects to uapi headers
      
        omapdrm:
         - console fix
      
        ast:
         - add i2c polling
      
        qaic:
         - add debugfs entries
      
        exynos:
         - fix platform_driver .owner
         - drop cleanup code
      
        mediatek:
         - Use devm_platform_get_and_ioremap_resource() in mtk_hdmi_ddc_probe()
         - Add GAMMA 12-bit LUT support for MT8188
         - Rename mtk_drm_* to mtk_*
         - Drop driver owner initialization
         - Correct calculation formula of PHY Timing"
      
      * tag 'drm-next-2024-05-15' of https://gitlab.freedesktop.org/drm/kernel: (1477 commits)
        drm/xe/ads: Use flexible-array
        drm/xe: Use ordered WQ for G2H handler
        drm/msm/gen_header: allow skipping the validation
        drm/msm/a6xx: Cleanup indexed regs const'ness
        drm/msm: Add devcoredump support for a750
        drm/msm: Adjust a7xx GBIF debugbus dumping
        drm/msm: Update a6xx registers XML
        drm/msm: Fix imported a750 snapshot header for upstream
        drm/msm: Import a750 snapshot registers from kgsl
        MAINTAINERS: Add Konrad Dybcio as a reviewer for the Adreno driver
        MAINTAINERS: Add a separate entry for Qualcomm Adreno GPU drivers
        drm/msm/a6xx: Avoid a nullptr dereference when speedbin setting fails
        drm/msm/adreno: fix CP cycles stat retrieval on a7xx
        drm/msm/a7xx: allow writing to CP_BV counter selection registers
        drm: zynqmp_dpsub: Always register bridge
        Revert "drm/bridge: ti-sn65dsi83: Fix enable error path"
        drm/fb_dma: Add checks in drm_fb_dma_get_scanout_buffer()
        drm/fbdev-generic: Do not set physical framebuffer address
        drm/panthor: Fix the FW reset logic
        drm/panthor: Make sure we handle 'unknown group state' case properly
        ...
      db5d28c0
    • Linus Torvalds's avatar
      Merge tag 'asymmetric-keys-next-6.10-rc1' of... · 46c6d2b1
      Linus Torvalds authored
      Merge tag 'asymmetric-keys-next-6.10-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/jarkko/linux-tpmdd
      
      Pull asymmetric keys update from Jarkko Sakkinen:
       "Add a self-test testing PCKS#7 signed data against ECDSA key and
        couple of bug fixes for missing deps"
      
      * tag 'asymmetric-keys-next-6.10-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/jarkko/linux-tpmdd:
        certs: Add ECDSA signature verification self-test
        certs: Move RSA self-test data to separate file
        KEYS: asymmetric: Add missing dependencies of FIPS_SIGNATURE_SELFTEST
        KEYS: asymmetric: Add missing dependency on CRYPTO_SIG
      46c6d2b1
    • Linus Torvalds's avatar
      Merge tag 'integrity-v6.10' of ssh://ra.kernel.org/pub/scm/linux/kernel/git/zohar/linux-integrity · 353ad6c0
      Linus Torvalds authored
      Pull integrity updates from Mimi Zohar:
       "Two IMA changes, one EVM change, a use after free bug fix, and a code
        cleanup to address "-Wflex-array-member-not-at-end" warnings:
      
         - The existing IMA {ascii, binary}_runtime_measurements lists include
           a hard coded SHA1 hash. To address this limitation, define per TPM
           enabled hash algorithm {ascii, binary}_runtime_measurements lists
      
         - Close an IMA integrity init_module syscall measurement gap by
           defining a new critical-data record
      
         - Enable (partial) EVM support on stacked filesystems (overlayfs).
           Only EVM portable & immutable file signatures are copied up, since
           they do not contain filesystem specific metadata"
      
      * tag 'integrity-v6.10' of ssh://ra.kernel.org/pub/scm/linux/kernel/git/zohar/linux-integrity:
        ima: add crypto agility support for template-hash algorithm
        evm: Rename is_unsupported_fs to is_unsupported_hmac_fs
        fs: Rename SB_I_EVM_UNSUPPORTED to SB_I_EVM_HMAC_UNSUPPORTED
        evm: Enforce signatures on unsupported filesystem for EVM_INIT_X509
        ima: re-evaluate file integrity on file metadata change
        evm: Store and detect metadata inode attributes changes
        ima: Move file-change detection variables into new structure
        evm: Use the metadata inode to calculate metadata hash
        evm: Implement per signature type decision in security_inode_copy_up_xattr
        security: allow finer granularity in permitting copy-up of security xattrs
        ima: Rename backing_inode to real_inode
        integrity: Avoid -Wflex-array-member-not-at-end warnings
        ima: define an init_module critical data record
        ima: Fix use-after-free on a dentry's dname.name
      353ad6c0
    • Linus Torvalds's avatar
      Merge tag 'selinux-pr-20240513' of git://git.kernel.org/pub/scm/linux/kernel/git/pcmoore/selinux · ccae19c6
      Linus Torvalds authored
      Pull selinux updates from Paul Moore:
      
       - Attempt to pre-allocate the SELinux status page so it doesn't appear
         to userspace that we are skipping SELinux policy sequence numbers
      
       - Reject invalid SELinux policy bitmaps with an error at policy load
         time
      
       - Consistently use the same type, u32, for ebitmap offsets
      
       - Improve the "symhash" hash function for better distribution on common
         policies
      
       - Correct a number of printk format specifiers in the ebitmap code
      
       - Improved error checking in sel_write_load()
      
       - Ensure we have a proper return code in the
         filename_trans_read_helper_compat() function
      
       - Make better use of the current_sid() helper function
      
       - Allow for more hash table statistics when debugging is enabled
      
       - Migrate from printk_ratelimit() to pr_warn_ratelimited()
      
       - Miscellaneous cleanups and tweaks to selinux_lsm_getattr()
      
       - More consitification work in the conditional policy space
      
      * tag 'selinux-pr-20240513' of git://git.kernel.org/pub/scm/linux/kernel/git/pcmoore/selinux:
        selinux: constify source policy in cond_policydb_dup()
        selinux: avoid printk_ratelimit()
        selinux: pre-allocate the status page
        selinux: clarify return code in filename_trans_read_helper_compat()
        selinux: use u32 as bit position type in ebitmap code
        selinux: improve symtab string hashing
        selinux: dump statistics for more hash tables
        selinux: make more use of current_sid()
        selinux: update numeric format specifiers for ebitmaps
        selinux: improve error checking in sel_write_load()
        selinux: cleanup selinux_lsm_getattr()
        selinux: reject invalid ebitmaps
      ccae19c6
    • Linus Torvalds's avatar
      Merge tag 'lsm-pr-20240513' of git://git.kernel.org/pub/scm/linux/kernel/git/pcmoore/lsm · 4cd4e4b8
      Linus Torvalds authored
      Pull lsm updates from Paul Moore:
      
       - The security/* portion of the effort to remove the empty sentinel
         elements at the end of the ctl_table arrays
      
       - Update the file list associated with the LSM / "SECURITY SUBSYSTEM"
         entry in the MAINTAINERS file (and then fix a typo in then update)
      
      * tag 'lsm-pr-20240513' of git://git.kernel.org/pub/scm/linux/kernel/git/pcmoore/lsm:
        MAINTAINERS: repair file entry in SECURITY SUBSYSTEM
        MAINTAINERS: update the LSM file list
        lsm: remove the now superfluous sentinel element from ctl_table array
      4cd4e4b8
    • Petr Mladek's avatar
      dafc2d0f
    • Hans de Goede's avatar
      platform/x86: Add new MeeGoPad ANX7428 Type-C Cross Switch driver · 2513563e
      Hans de Goede authored
      Some MeeGoPad top-set boxes have an ANX7428 Type-C Switch for USB3.1 Gen 1
      and DisplayPort over Type-C alternate mode support.
      
      The ANX7428 has a microcontroller which takes care of the PD negotiation
      and automatically sets the builtin Crosspoint Switch to send the right
      signal to the 4 highspeed pairs of the Type-C connector. It also takes
      care of HPD and AUX channel routing for DP alternate mode.
      
      IOW the ANX7428 operates fully autonomous and to the x5-Z8350 SoC
      things look like there simple is a USB-3 Type-A connector and a
      separate DisplayPort connector. Except that the BIOS does not
      power on the ANX7428 at boot (meh).
      
      Add a driver to power on the ANX7428. This driver is added under
      drivers/platform/x86 rather than under drivers/usb/typec for 2 reasons:
      
      1. This driver is specifically written to work with how the ANX7428 is
      described in the ACPI tables of the MeeGoPad x86 (Cherry Trail) devices.
      
      2. This driver only powers on the ANX7428 and does not do anything wrt
      its Type-C functionality. It should be possible to tell the controller
      which data- and/or power-role to negotiate and to swap the role(s) after
      negotiation but the MeeGoPad top-set boxes always draw their power from
      a separate power-connector and they only support USB host-mode. So this
      functionality is unnecessary and due to lack of documentation this is
      tricky to support.
      Signed-off-by: default avatarHans de Goede <hdegoede@redhat.com>
      Link: https://lore.kernel.org/r/20240514180343.70795-1-hdegoede@redhat.com
      2513563e
    • Linus Torvalds's avatar
      Merge tag 'net-next-6.10' of git://git.kernel.org/pub/scm/linux/kernel/git/netdev/net-next · 1b294a1f
      Linus Torvalds authored
      Pull networking updates from Jakub Kicinski:
       "Core & protocols:
      
         - Complete rework of garbage collection of AF_UNIX sockets.
      
           AF_UNIX is prone to forming reference count cycles due to fd
           passing functionality. New method based on Tarjan's Strongly
           Connected Components algorithm should be both faster and remove a
           lot of workarounds we accumulated over the years.
      
         - Add TCP fraglist GRO support, allowing chaining multiple TCP
           packets and forwarding them together. Useful for small switches /
           routers which lack basic checksum offload in some scenarios (e.g.
           PPPoE).
      
         - Support using SMP threads for handling packet backlog i.e. packet
           processing from software interfaces and old drivers which don't use
           NAPI. This helps move the processing out of the softirq jumble.
      
         - Continue work of converting from rtnl lock to RCU protection.
      
           Don't require rtnl lock when reading: IPv6 routing FIB, IPv6
           address labels, netdev threaded NAPI sysfs files, bonding driver's
           sysfs files, MPLS devconf, IPv4 FIB rules, netns IDs, tcp metrics,
           TC Qdiscs, neighbor entries, ARP entries via ioctl(SIOCGARP), a lot
           of the link information available via rtnetlink.
      
         - Small optimizations from Eric to UDP wake up handling, memory
           accounting, RPS/RFS implementation, TCP packet sizing etc.
      
         - Allow direct page recycling in the bulk API used by XDP, for +2%
           PPS.
      
         - Support peek with an offset on TCP sockets.
      
         - Add MPTCP APIs for querying last time packets were received/sent/acked
           and whether MPTCP "upgrade" succeeded on a TCP socket.
      
         - Add intra-node communication shortcut to improve SMC performance.
      
         - Add IPv6 (and IPv{4,6}-over-IPv{4,6}) support to the GTP protocol
           driver.
      
         - Add HSR-SAN (RedBOX) mode of operation to the HSR protocol driver.
      
         - Add reset reasons for tracing what caused a TCP reset to be sent.
      
         - Introduce direction attribute for xfrm (IPSec) states. State can be
           used either for input or output packet processing.
      
        Things we sprinkled into general kernel code:
      
         - Add bitmap_{read,write}(), bitmap_size(), expose BYTES_TO_BITS().
      
           This required touch-ups and renaming of a few existing users.
      
         - Add Endian-dependent __counted_by_{le,be} annotations.
      
         - Make building selftests "quieter" by printing summaries like
           "CC object.o" rather than full commands with all the arguments.
      
        Netfilter:
      
         - Use GFP_KERNEL to clone elements, to deal better with OOM
           situations and avoid failures in the .commit step.
      
        BPF:
      
         - Add eBPF JIT for ARCv2 CPUs.
      
         - Support attaching kprobe BPF programs through kprobe_multi link in
           a session mode, meaning, a BPF program is attached to both function
           entry and return, the entry program can decide if the return
           program gets executed and the entry program can share u64 cookie
           value with return program. "Session mode" is a common use-case for
           tetragon and bpftrace.
      
         - Add the ability to specify and retrieve BPF cookie for raw
           tracepoint programs in order to ease migration from classic to raw
           tracepoints.
      
         - Add an internal-only BPF per-CPU instruction for resolving per-CPU
           memory addresses and implement support in x86, ARM64 and RISC-V
           JITs. This allows inlining functions which need to access per-CPU
           state.
      
         - Optimize x86 BPF JIT's emit_mov_imm64, and add support for various
           atomics in bpf_arena which can be JITed as a single x86
           instruction. Support BPF arena on ARM64.
      
         - Add a new bpf_wq API for deferring events and refactor
           process-context bpf_timer code to keep common code where possible.
      
         - Harden the BPF verifier's and/or/xor value tracking.
      
         - Introduce crypto kfuncs to let BPF programs call kernel crypto
           APIs.
      
         - Support bpf_tail_call_static() helper for BPF programs with GCC 13.
      
         - Add bpf_preempt_{disable,enable}() kfuncs in order to allow a BPF
           program to have code sections where preemption is disabled.
      
        Driver API:
      
         - Skip software TC processing completely if all installed rules are
           marked as HW-only, instead of checking the HW-only flag rule by
           rule.
      
         - Add support for configuring PoE (Power over Ethernet), similar to
           the already existing support for PoDL (Power over Data Line)
           config.
      
         - Initial bits of a queue control API, for now allowing a single
           queue to be reset without disturbing packet flow to other queues.
      
         - Common (ethtool) statistics for hardware timestamping.
      
        Tests and tooling:
      
         - Remove the need to create a config file to run the net forwarding
           tests so that a naive "make run_tests" can exercise them.
      
         - Define a method of writing tests which require an external endpoint
           to communicate with (to send/receive data towards the test
           machine). Add a few such tests.
      
         - Create a shared code library for writing Python tests. Expose the
           YAML Netlink library from tools/ to the tests for easy Netlink
           access.
      
         - Move netfilter tests under net/, extend them, separate performance
           tests from correctness tests, and iron out issues found by running
           them "on every commit".
      
         - Refactor BPF selftests to use common network helpers.
      
         - Further work filling in YAML definitions of Netlink messages for:
           nftables, team driver, bonding interfaces, vlan interfaces, VF
           info, TC u32 mark, TC police action.
      
         - Teach Python YAML Netlink to decode attribute policies.
      
         - Extend the definition of the "indexed array" construct in the specs
           to cover arrays of scalars rather than just nests.
      
         - Add hyperlinks between definitions in generated Netlink docs.
      
        Drivers:
      
         - Make sure unsupported flower control flags are rejected by drivers,
           and make more drivers report errors directly to the application
           rather than dmesg (large number of driver changes from Asbjørn
           Sloth Tønnesen).
      
         - Ethernet high-speed NICs:
            - Broadcom (bnxt):
               - support multiple RSS contexts and steering traffic to them
               - support XDP metadata
               - make page pool allocations more NUMA aware
            - Intel (100G, ice, idpf):
               - extract datapath code common among Intel drivers into a library
               - use fewer resources in switchdev by sharing queues with the PF
               - add PFCP filter support
               - add Ethernet filter support
               - use a spinlock instead of HW lock in PTP clock ops
               - support 5 layer Tx scheduler topology
            - nVidia/Mellanox:
               - 800G link modes and 100G SerDes speeds
               - per-queue IRQ coalescing configuration
            - Marvell Octeon:
               - support offloading TC packet mark action
      
         - Ethernet NICs consumer, embedded and virtual:
            - stop lying about skb->truesize in USB Ethernet drivers, it
              messes up TCP memory calculations
            - Google cloud vNIC:
               - support changing ring size via ethtool
               - support ring reset using the queue control API
            - VirtIO net:
               - expose flow hash from RSS to XDP
               - per-queue statistics
               - add selftests
            - Synopsys (stmmac):
               - support controllers which require an RX clock signal from the
                 MII bus to perform their hardware initialization
            - TI:
               - icssg_prueth: support ICSSG-based Ethernet on AM65x SR1.0 devices
               - icssg_prueth: add SW TX / RX Coalescing based on hrtimers
               - cpsw: minimal XDP support
            - Renesas (ravb):
               - support describing the MDIO bus
            - Realtek (r8169):
               - add support for RTL8168M
            - Microchip Sparx5:
               - matchall and flower actions mirred and redirect
      
         - Ethernet switches:
            - nVidia/Mellanox:
               - improve events processing performance
            - Marvell:
               - add support for MV88E6250 family internal PHYs
            - Microchip:
               - add DCB and DSCP mapping support for KSZ switches
               - vsc73xx: convert to PHYLINK
            - Realtek:
               - rtl8226b/rtl8221b: add C45 instances and SerDes switching
      
         - Many driver changes related to PHYLIB and PHYLINK deprecated API
           cleanup
      
         - Ethernet PHYs:
            - Add a new driver for Airoha EN8811H 2.5 Gigabit PHY.
            - micrel: lan8814: add support for PPS out and external timestamp trigger
      
         - WiFi:
            - Disable Wireless Extensions (WEXT) in all Wi-Fi 7 devices
              drivers. Modern devices can only be configured using nl80211.
            - mac80211/cfg80211
               - handle color change per link for WiFi 7 Multi-Link Operation
            - Intel (iwlwifi):
               - don't support puncturing in 5 GHz
               - support monitor mode on passive channels
               - BZ-W device support
               - P2P with HE/EHT support
               - re-add support for firmware API 90
               - provide channel survey information for Automatic Channel Selection
            - MediaTek (mt76):
               - mt7921 LED control
               - mt7925 EHT radiotap support
               - mt7920e PCI support
            - Qualcomm (ath11k):
               - P2P support for QCA6390, WCN6855 and QCA2066
               - support hibernation
               - ieee80211-freq-limit Device Tree property support
            - Qualcomm (ath12k):
               - refactoring in preparation of multi-link support
               - suspend and hibernation support
               - ACPI support
               - debugfs support, including dfs_simulate_radar support
            - RealTek:
               - rtw88: RTL8723CS SDIO device support
               - rtw89: RTL8922AE Wi-Fi 7 PCI device support
               - rtw89: complete features of new WiFi 7 chip 8922AE including
                 BT-coexistence and Wake-on-WLAN
               - rtw89: use BIOS ACPI settings to set TX power and channels
               - rtl8xxxu: enable Management Frame Protection (MFP) support
      
         - Bluetooth:
            - support for Intel BlazarI and Filmore Peak2 (BE201)
            - support for MediaTek MT7921S SDIO
            - initial support for Intel PCIe BT driver
            - remove HCI_AMP support"
      
      * tag 'net-next-6.10' of git://git.kernel.org/pub/scm/linux/kernel/git/netdev/net-next: (1827 commits)
        selftests: netfilter: fix packetdrill conntrack testcase
        net: gro: fix napi_gro_cb zeroed alignment
        Bluetooth: btintel_pcie: Refactor and code cleanup
        Bluetooth: btintel_pcie: Fix warning reported by sparse
        Bluetooth: hci_core: Fix not handling hdev->le_num_of_adv_sets=1
        Bluetooth: btintel: Fix compiler warning for multi_v7_defconfig config
        Bluetooth: btintel_pcie: Fix compiler warnings
        Bluetooth: btintel_pcie: Add *setup* function to download firmware
        Bluetooth: btintel_pcie: Add support for PCIe transport
        Bluetooth: btintel: Export few static functions
        Bluetooth: HCI: Remove HCI_AMP support
        Bluetooth: L2CAP: Fix div-by-zero in l2cap_le_flowctl_init()
        Bluetooth: qca: Fix error code in qca_read_fw_build_info()
        Bluetooth: hci_conn: Use __counted_by() and avoid -Wfamnae warning
        Bluetooth: btintel: Add support for Filmore Peak2 (BE201)
        Bluetooth: btintel: Add support for BlazarI
        LE Create Connection command timeout increased to 20 secs
        dt-bindings: net: bluetooth: Add MediaTek MT7921S SDIO Bluetooth
        Bluetooth: compute LE flow credits based on recvbuf space
        Bluetooth: hci_sync: Use cmd->num_cis instead of magic number
        ...
      1b294a1f
    • Linus Torvalds's avatar
      Merge tag 'firewire-updates-6.10' of... · b850dc20
      Linus Torvalds authored
      Merge tag 'firewire-updates-6.10' of git://git.kernel.org/pub/scm/linux/kernel/git/ieee1394/linux1394
      
      Pull firewire updates from Takashi Sakamoto:
       "During the development period of v6.8 kernel, it became evident that
        there was a lack of helper utilities to trace the initial state of
        bus, while investigating certain PHYs compliant with different
        versions of IEEE 1394 specification.
      
        This series of changes includes the addition of tracepoints events,
        provided by 'firewire' subsystem. These events enable tracing of how
        firewire core functions during bus reset and asynchronous
        communication over IEEE 1394 bus.
      
        When implementing the tracepoints events, it was found that the
        existing serialization and deserialization helpers for several types
        of asynchronous packets are scattered across both firewire-core and
        firewire-ohci kernel modules. A set of inline functions is newly added
        to address it, along with some KUnit tests, serving as the foundation
        for the tracepoints events. This renders the dispersed code obsolete.
      
        The remaining changes constitute the final steps in phasing out the
        usage of deprecated PCI MSI APIs, in continuation from the previous
        version"
      
      * tag 'firewire-updates-6.10' of git://git.kernel.org/pub/scm/linux/kernel/git/ieee1394/linux1394: (29 commits)
        firewire: obsolete usage of *-objs in Makefile for KUnit test
        firewire: core: remove flag and width from u64 formats of tracepoints events
        firewire: core: fix type of timestamp for async_inbound_template tracepoints events
        firewire: core: add tracepoint event for handling bus reset
        Revert "firewire: core: option to log bus reset initiation"
        firewire: core: add tracepoints events for initiating bus reset
        firewire: ohci: obsolete OHCI_PARAM_DEBUG_BUSRESETS from debug module parameter
        firewire: ohci: add bus-reset event for initial set of handled irq
        firewire: core: add tracepoints event for asynchronous inbound phy packet
        firewire: core/cdev: add tracepoints events for asynchronous phy packet
        firewire: core: add tracepoints events for asynchronous outbound response
        firewire: core: add tracepoint event for asynchronous inbound request
        firewire: core: add tracepoints event for asynchronous inbound response
        firewire: core: add tracepoints events for asynchronous outbound request
        firewire: core: add support for Linux kernel tracepoints
        firewire: core: replace local macros with common inline functions for isochronous packet header
        firewire: core: add common macro to serialize/deserialize isochronous packet header
        firewire: core: obsolete tcode check macros with inline functions
        firewire: ohci: replace hard-coded values with common macros
        firewire: ohci: replace hard-coded values with inline functions for asynchronous packet header
        ...
      b850dc20
    • Linus Torvalds's avatar
      Merge tag 'for-6.10/dm-changes' of... · 4f8b6f25
      Linus Torvalds authored
      Merge tag 'for-6.10/dm-changes' of git://git.kernel.org/pub/scm/linux/kernel/git/device-mapper/linux-dm
      
      Pull device mapper updates from Mike Snitzer:
      
       - Add a dm-crypt optional "high_priority" flag that enables the crypt
         workqueues to use WQ_HIGHPRI.
      
       - Export dm-crypt workqueues via sysfs (by enabling WQ_SYSFS) to allow
         for improved visibility and controls over IO and crypt workqueues.
      
       - Fix dm-crypt to no longer constrain max_segment_size to PAGE_SIZE.
         This limit isn't needed given that the block core provides late bio
         splitting if bio exceeds underlying limits (e.g. max_segment_size).
      
       - Fix dm-crypt crypt_queue's use of WQ_UNBOUND to not use
         WQ_CPU_INTENSIVE because it is meaningless with WQ_UNBOUND.
      
       - Fix various issues with dm-delay target (ranging from a resource
         teardown fix, a fix for hung task when using kthread mode, and other
         improvements that followed from code inspection).
      
      * tag 'for-6.10/dm-changes' of git://git.kernel.org/pub/scm/linux/kernel/git/device-mapper/linux-dm:
        dm-delay: remove timer_lock
        dm-delay: change locking to avoid contention
        dm-delay: fix max_delay calculations
        dm-delay: fix hung task introduced by kthread mode
        dm-delay: fix workqueue delay_timer race
        dm-crypt: don't set WQ_CPU_INTENSIVE for WQ_UNBOUND crypt_queue
        dm: use queue_limits_set
        dm-crypt: stop constraining max_segment_size to PAGE_SIZE
        dm-crypt: export sysfs of all workqueues
        dm-crypt: add the optional "high_priority" flag
      4f8b6f25
    • Linus Torvalds's avatar
      Merge tag 'scsi-misc' of git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi · 113d1dd9
      Linus Torvalds authored
      Pull SCSI updates from James Bottomley:
       "Updates to the usual drivers (ufs, lpfc, qla2xxx, mpi3mr, libsas).
      
        The major update (which causes a conflict with block, see below) is
        Christoph removing the queue limits and their associated block
        helpers.
      
        The remaining patches are assorted minor fixes and deprecated function
        updates plus a bit of constification"
      
      * tag 'scsi-misc' of git://git.kernel.org/pub/scm/linux/kernel/git/jejb/scsi: (141 commits)
        scsi: mpi3mr: Sanitise num_phys
        scsi: lpfc: Copyright updates for 14.4.0.2 patches
        scsi: lpfc: Update lpfc version to 14.4.0.2
        scsi: lpfc: Add support for 32 byte CDBs
        scsi: lpfc: Change lpfc_hba hba_flag member into a bitmask
        scsi: lpfc: Introduce rrq_list_lock to protect active_rrq_list
        scsi: lpfc: Clear deferred RSCN processing flag when driver is unloading
        scsi: lpfc: Update logging of protection type for T10 DIF I/O
        scsi: lpfc: Change default logging level for unsolicited CT MIB commands
        scsi: target: Remove unused list 'device_list'
        scsi: iscsi: Remove unused list 'connlist_err'
        scsi: ufs: exynos: Add support for Tensor gs101 SoC
        scsi: ufs: exynos: Add some pa_dbg_ register offsets into drvdata
        scsi: ufs: exynos: Allow max frequencies up to 267Mhz
        scsi: ufs: exynos: Add EXYNOS_UFS_OPT_TIMER_TICK_SELECT option
        scsi: ufs: exynos: Add EXYNOS_UFS_OPT_UFSPR_SECURE option
        scsi: ufs: dt-bindings: exynos: Add gs101 compatible
        scsi: qla2xxx: Fix debugfs output for fw_resource_count
        scsi: qedf: Ensure the copied buf is NUL terminated
        scsi: bfa: Ensure the copied buf is NUL terminated
        ...
      113d1dd9
    • Linus Torvalds's avatar
      Merge tag 'ata-6.10-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/libata/linux · b2665fe6
      Linus Torvalds authored
      Pull ata updates from Damien Le Moal:
      
       - Convert the bindings for the imx-pata and ahci-da850 drivers to DT
         schemas (from Animesh)
      
       - Correct the code to handle HAS_IOPORT dependencies and conditionally
         compile drivers as needed (from Niklas)
      
       - Correct the legacy_exit() function in the pata_legacy driver to
         properly handle cleanups on driver exit (from Sergey)
      
       - Small code simplification removing the ata_exec_internal_sg()
         function and folding it into its only caller (from me)
      
      * tag 'ata-6.10-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/libata/linux:
        ata: pata_legacy: make legacy_exit() work again
        ata: libata-core: Remove ata_exec_internal_sg()
        ata: add HAS_IOPORT dependencies
        dt-bindings: ata: ahci-da850: Convert to dtschema
        dt-bindings: ata: imx-pata: Convert to dtschema
      b2665fe6
    • Linus Torvalds's avatar
      Merge tag 'fsverity-for-linus' of git://git.kernel.org/pub/scm/fs/fsverity/linux · b47c1823
      Linus Torvalds authored
      Pull fsverity update from Eric Biggers:
       "Fix a false positive kmemleak warning"
      
      * tag 'fsverity-for-linus' of git://git.kernel.org/pub/scm/fs/fsverity/linux:
        fsverity: use register_sysctl_init() to avoid kmemleak warning
      b47c1823
    • Linus Torvalds's avatar
      Merge tag 'fscrypt-for-linus' of git://git.kernel.org/pub/scm/fs/fscrypt/linux · fc883e7a
      Linus Torvalds authored
      Pull fscrypt update from Eric Biggers:
       "Improve the performance of opening unencrypted files on filesystems
        that support fscrypt"
      
      * tag 'fscrypt-for-linus' of git://git.kernel.org/pub/scm/fs/fscrypt/linux:
        fscrypt: try to avoid refing parent dentry in fscrypt_file_open
      fc883e7a
    • Linus Torvalds's avatar
      Merge tag 'for-linus-6.10-ofs1' of git://git.kernel.org/pub/scm/linux/kernel/git/hubcap/linux · eafb55a3
      Linus Torvalds authored
      Pull orangefs update from Mike Marshall:
       "Fix out-of-bounds fsid access.
      
        Small fix to quiet warnings from string fortification helpers,
        suggested by Arnd Bergmann"
      
      * tag 'for-linus-6.10-ofs1' of git://git.kernel.org/pub/scm/linux/kernel/git/hubcap/linux:
        orangefs: fix out-of-bounds fsid access
      eafb55a3