1. 28 Apr, 2023 20 commits
    • Linus Torvalds's avatar
      Merge tag 'trace-tools-v6.4' of git://git.kernel.org/pub/scm/linux/kernel/git/trace/linux-trace · 5ea8abf5
      Linus Torvalds authored
      Pull tracing tools updates from Steven Rostedt:
      
       - Add auto-analysis only option to rtla/timerlat
      
         Add an --aa-only option to the tooling to perform only the auto
         analysis and not to parse and format the data.
      
       - Other minor fixes and clean ups
      
      * tag 'trace-tools-v6.4' of git://git.kernel.org/pub/scm/linux/kernel/git/trace/linux-trace:
        rtla/timerlat: Fix "Previous IRQ" auto analysis' line
        rtla/timerlat: Add auto-analysis only option
        rv: Remove redundant assignment to variable retval
        rv: Fix addition on an uninitialized variable 'run'
        rtla: Add .gitignore file
      5ea8abf5
    • Linus Torvalds's avatar
      Merge tag 'trace-v6.4' of git://git.kernel.org/pub/scm/linux/kernel/git/trace/linux-trace · d579c468
      Linus Torvalds authored
      Pull tracing updates from Steven Rostedt:
      
       - User events are finally ready!
      
         After lots of collaboration between various parties, we finally
         locked down on a stable interface for user events that can also work
         with user space only tracing.
      
         This is implemented by telling the kernel (or user space library, but
         that part is user space only and not part of this patch set), where
         the variable is that the application uses to know if something is
         listening to the trace.
      
         There's also an interface to tell the kernel about these events,
         which will show up in the /sys/kernel/tracing/events/user_events/
         directory, where it can be enabled.
      
         When it's enabled, the kernel will update the variable, to tell the
         application to start writing to the kernel.
      
         See https://lwn.net/Articles/927595/
      
       - Cleaned up the direct trampolines code to simplify arm64 addition of
         direct trampolines.
      
         Direct trampolines use the ftrace interface but instead of jumping to
         the ftrace trampoline, applications (mostly BPF) can register their
         own trampoline for performance reasons.
      
       - Some updates to the fprobe infrastructure. fprobes are more efficient
         than kprobes, as it does not need to save all the registers that
         kprobes on ftrace do. More work needs to be done before the fprobes
         will be exposed as dynamic events.
      
       - More updates to references to the obsolete path of
         /sys/kernel/debug/tracing for the new /sys/kernel/tracing path.
      
       - Add a seq_buf_do_printk() helper to seq_bufs, to print a large buffer
         line by line instead of all at once.
      
         There are users in production kernels that have a large data dump
         that originally used printk() directly, but the data dump was larger
         than what printk() allowed as a single print.
      
         Using seq_buf() to do the printing fixes that.
      
       - Add /sys/kernel/tracing/touched_functions that shows all functions
         that was every traced by ftrace or a direct trampoline. This is used
         for debugging issues where a traced function could have caused a
         crash by a bpf program or live patching.
      
       - Add a "fields" option that is similar to "raw" but outputs the fields
         of the events. It's easier to read by humans.
      
       - Some minor fixes and clean ups.
      
      * tag 'trace-v6.4' of git://git.kernel.org/pub/scm/linux/kernel/git/trace/linux-trace: (41 commits)
        ring-buffer: Sync IRQ works before buffer destruction
        tracing: Add missing spaces in trace_print_hex_seq()
        ring-buffer: Ensure proper resetting of atomic variables in ring_buffer_reset_online_cpus
        recordmcount: Fix memory leaks in the uwrite function
        tracing/user_events: Limit max fault-in attempts
        tracing/user_events: Prevent same address and bit per process
        tracing/user_events: Ensure bit is cleared on unregister
        tracing/user_events: Ensure write index cannot be negative
        seq_buf: Add seq_buf_do_printk() helper
        tracing: Fix print_fields() for __dyn_loc/__rel_loc
        tracing/user_events: Set event filter_type from type
        ring-buffer: Clearly check null ptr returned by rb_set_head_page()
        tracing: Unbreak user events
        tracing/user_events: Use print_format_fields() for trace output
        tracing/user_events: Align structs with tabs for readability
        tracing/user_events: Limit global user_event count
        tracing/user_events: Charge event allocs to cgroups
        tracing/user_events: Update documentation for ABI
        tracing/user_events: Use write ABI in example
        tracing/user_events: Add ABI self-test
        ...
      d579c468
    • Linus Torvalds's avatar
      Merge tag 'smp-core-2023-04-27' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · f20730ef
      Linus Torvalds authored
      Pull SMP cross-CPU function-call updates from Ingo Molnar:
      
       - Remove diagnostics and adjust config for CSD lock diagnostics
      
       - Add a generic IPI-sending tracepoint, as currently there's no easy
         way to instrument IPI origins: it's arch dependent and for some major
         architectures it's not even consistently available.
      
      * tag 'smp-core-2023-04-27' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        trace,smp: Trace all smp_function_call*() invocations
        trace: Add trace_ipi_send_cpu()
        sched, smp: Trace smp callback causing an IPI
        smp: reword smp call IPI comment
        treewide: Trace IPIs sent via smp_send_reschedule()
        irq_work: Trace self-IPIs sent via arch_irq_work_raise()
        smp: Trace IPIs sent via arch_send_call_function_ipi_mask()
        sched, smp: Trace IPIs sent via send_call_function_single_ipi()
        trace: Add trace_ipi_send_cpumask()
        kernel/smp: Make csdlock_debug= resettable
        locking/csd_lock: Remove per-CPU data indirection from CSD lock debugging
        locking/csd_lock: Remove added data from CSD lock debugging
        locking/csd_lock: Add Kconfig option for csd_debug default
      f20730ef
    • Linus Torvalds's avatar
      Merge tag 'sched-core-2023-04-27' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · 586b222d
      Linus Torvalds authored
      Pull scheduler updates from Ingo Molnar:
      
       - Allow unprivileged PSI poll()ing
      
       - Fix performance regression introduced by mm_cid
      
       - Improve livepatch stalls by adding livepatch task switching to
         cond_resched(). This resolves livepatching busy-loop stalls with
         certain CPU-bound kthreads
      
       - Improve sched_move_task() performance on autogroup configs
      
       - On core-scheduling CPUs, avoid selecting throttled tasks to run
      
       - Misc cleanups, fixes and improvements
      
      * tag 'sched-core-2023-04-27' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        sched/clock: Fix local_clock() before sched_clock_init()
        sched/rt: Fix bad task migration for rt tasks
        sched: Fix performance regression introduced by mm_cid
        sched/core: Make sched_dynamic_mutex static
        sched/psi: Allow unprivileged polling of N*2s period
        sched/psi: Extract update_triggers side effect
        sched/psi: Rename existing poll members in preparation
        sched/psi: Rearrange polling code in preparation
        sched/fair: Fix inaccurate tally of ttwu_move_affine
        vhost: Fix livepatch timeouts in vhost_worker()
        livepatch,sched: Add livepatch task switching to cond_resched()
        livepatch: Skip task_call_func() for current task
        livepatch: Convert stack entries array to percpu
        sched: Interleave cfs bandwidth timers for improved single thread performance at low utilization
        sched/core: Reduce cost of sched_move_task when config autogroup
        sched/core: Avoid selecting the task that is throttled to run when core-sched enable
        sched/topology: Make sched_energy_mutex,update static
      586b222d
    • Linus Torvalds's avatar
      Merge tag 'perf-core-2023-04-27' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · 7c339778
      Linus Torvalds authored
      Pull perf updates from Ingo Molnar:
      
       - Add Intel Granite Rapids support
      
       - Add uncore events for Intel SPR IMC PMU
      
       - Fix perf IRQ throttling bug
      
      * tag 'perf-core-2023-04-27' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        perf/x86/intel/uncore: Add events for Intel SPR IMC PMU
        perf/core: Fix hardlockup failure caused by perf throttle
        perf/x86/cstate: Add Granite Rapids support
        perf/x86/msr: Add Granite Rapids
        perf/x86/intel: Add Granite Rapids
      7c339778
    • Linus Torvalds's avatar
      Merge tag 'objtool-core-2023-04-27' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · 2aff7c70
      Linus Torvalds authored
      Pull objtool updates from Ingo Molnar:
      
       - Mark arch_cpu_idle_dead() __noreturn, make all architectures &
         drivers that did this inconsistently follow this new, common
         convention, and fix all the fallout that objtool can now detect
         statically
      
       - Fix/improve the ORC unwinder becoming unreliable due to
         UNWIND_HINT_EMPTY ambiguity, split it into UNWIND_HINT_END_OF_STACK
         and UNWIND_HINT_UNDEFINED to resolve it
      
       - Fix noinstr violations in the KCSAN code and the lkdtm/stackleak code
      
       - Generate ORC data for __pfx code
      
       - Add more __noreturn annotations to various kernel startup/shutdown
         and panic functions
      
       - Misc improvements & fixes
      
      * tag 'objtool-core-2023-04-27' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip: (52 commits)
        x86/hyperv: Mark hv_ghcb_terminate() as noreturn
        scsi: message: fusion: Mark mpt_halt_firmware() __noreturn
        x86/cpu: Mark {hlt,resume}_play_dead() __noreturn
        btrfs: Mark btrfs_assertfail() __noreturn
        objtool: Include weak functions in global_noreturns check
        cpu: Mark nmi_panic_self_stop() __noreturn
        cpu: Mark panic_smp_self_stop() __noreturn
        arm64/cpu: Mark cpu_park_loop() and friends __noreturn
        x86/head: Mark *_start_kernel() __noreturn
        init: Mark start_kernel() __noreturn
        init: Mark [arch_call_]rest_init() __noreturn
        objtool: Generate ORC data for __pfx code
        x86/linkage: Fix padding for typed functions
        objtool: Separate prefix code from stack validation code
        objtool: Remove superfluous dead_end_function() check
        objtool: Add symbol iteration helpers
        objtool: Add WARN_INSN()
        scripts/objdump-func: Support multiple functions
        context_tracking: Fix KCSAN noinstr violation
        objtool: Add stackleak instrumentation to uaccess safe list
        ...
      2aff7c70
    • Linus Torvalds's avatar
      Merge tag 'x86_mm_for_6.4' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · 22b8cc3e
      Linus Torvalds authored
      Pull x86 LAM (Linear Address Masking) support from Dave Hansen:
       "Add support for the new Linear Address Masking CPU feature.
      
        This is similar to ARM's Top Byte Ignore and allows userspace to store
        metadata in some bits of pointers without masking it out before use"
      
      * tag 'x86_mm_for_6.4' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        x86/mm/iommu/sva: Do not allow to set FORCE_TAGGED_SVA bit from outside
        x86/mm/iommu/sva: Fix error code for LAM enabling failure due to SVA
        selftests/x86/lam: Add test cases for LAM vs thread creation
        selftests/x86/lam: Add ARCH_FORCE_TAGGED_SVA test cases for linear-address masking
        selftests/x86/lam: Add inherit test cases for linear-address masking
        selftests/x86/lam: Add io_uring test cases for linear-address masking
        selftests/x86/lam: Add mmap and SYSCALL test cases for linear-address masking
        selftests/x86/lam: Add malloc and tag-bits test cases for linear-address masking
        x86/mm/iommu/sva: Make LAM and SVA mutually exclusive
        iommu/sva: Replace pasid_valid() helper with mm_valid_pasid()
        mm: Expose untagging mask in /proc/$PID/status
        x86/mm: Provide arch_prctl() interface for LAM
        x86/mm: Reduce untagged_addr() overhead for systems without LAM
        x86/uaccess: Provide untagged_addr() and remove tags before address check
        mm: Introduce untagged_addr_remote()
        x86/mm: Handle LAM on context switch
        x86: CPUID and CR3/CR4 flags for Linear Address Masking
        x86: Allow atomic MM_CONTEXT flags setting
        x86/mm: Rework address range check in get_user() and put_user()
      22b8cc3e
    • Linus Torvalds's avatar
      Merge tag 'x86_tdx_for_6.4' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · 7b664cc3
      Linus Torvalds authored
      Pull x86 tdx update from Dave Hansen:
       "The original tdx hypercall assembly code took two flags in %RSI to
        tweak its behavior at runtime. PeterZ recently axed one flag in commit
        e80a48ba ("x86/tdx: Remove TDX_HCALL_ISSUE_STI").
      
        Kill the other flag too and tweak the 'output' mode with an assembly
        macro instead. This results in elimination of one push/pop pair and
        overall easier to read assembly.
      
         - Do conditional __tdx_hypercall() 'output' processing via an
           assembly macro argument rather than a runtime register"
      
      * tag 'x86_tdx_for_6.4' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        x86/tdx: Drop flags from __tdx_hypercall()
      7b664cc3
    • Linus Torvalds's avatar
      Merge tag 'x86_fpu_for_6.4' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · e54debe6
      Linus Torvalds authored
      Pull x86 fpu updates from Dave Hansen:
       "There's no _actual_ kernel functionality here.
      
        This expands the documentation around AMX support including some code
        examples. The example code also exposed the fact that hardware
        architecture constants as part of the ABI, but there's no easy place
        that they get defined for apps. Adding them to a uabi header will
        eventually make life easier for consumers of the ABI.
      
        Summary:
      
         - Improve AMX documentation along with example code
      
         - Explicitly make some hardware constants part of the uabi"
      
      * tag 'x86_fpu_for_6.4' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        Documentation/x86: Explain the state component permission for guests
        Documentation/x86: Add the AMX enabling example
        x86/arch_prctl: Add AMX feature numbers as ABI constants
        Documentation/x86: Explain the purpose for dynamic features
      e54debe6
    • Linus Torvalds's avatar
      Merge tag 'x86_cache_for_6.4' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · 4980c176
      Linus Torvalds authored
      Pull x86 resctrl update from Dave Hansen:
       "Reduce redundant counter reads with resctrl refactoring"
      
      * tag 'x86_cache_for_6.4' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        x86/resctrl: Avoid redundant counter read in __mon_event_count()
      4980c176
    • Linus Torvalds's avatar
      Merge tag 'x86_cleanups_for_v6.4_rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · 682f7bba
      Linus Torvalds authored
      Pull x86 cleanups from Borislav Petkov:
      
       - Unify duplicated __pa() and __va() definitions
      
       - Simplify sysctl tables registration
      
       - Remove unused symbols
      
       - Correct function name in comment
      
      * tag 'x86_cleanups_for_v6.4_rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        x86/boot: Centralize __pa()/__va() definitions
        x86: Simplify one-level sysctl registration for itmt_kern_table
        x86: Simplify one-level sysctl registration for abi_table2
        x86/platform/intel-mid: Remove unused definitions from intel-mid.h
        x86/uaccess: Remove memcpy_page_flushcache()
        x86/entry: Change stale function name in comment to error_return()
      682f7bba
    • Linus Torvalds's avatar
      Merge tag 'mm-nonmm-stable-2023-04-27-16-01' of... · 33afd4b7
      Linus Torvalds authored
      Merge tag 'mm-nonmm-stable-2023-04-27-16-01' of git://git.kernel.org/pub/scm/linux/kernel/git/akpm/mm
      
      Pull non-MM updates from Andrew Morton:
       "Mainly singleton patches all over the place.
      
        Series of note are:
      
         - updates to scripts/gdb from Glenn Washburn
      
         - kexec cleanups from Bjorn Helgaas"
      
      * tag 'mm-nonmm-stable-2023-04-27-16-01' of git://git.kernel.org/pub/scm/linux/kernel/git/akpm/mm: (50 commits)
        mailmap: add entries for Paul Mackerras
        libgcc: add forward declarations for generic library routines
        mailmap: add entry for Oleksandr
        ocfs2: reduce ioctl stack usage
        fs/proc: add Kthread flag to /proc/$pid/status
        ia64: fix an addr to taddr in huge_pte_offset()
        checkpatch: introduce proper bindings license check
        epoll: rename global epmutex
        scripts/gdb: add GDB convenience functions $lx_dentry_name() and $lx_i_dentry()
        scripts/gdb: create linux/vfs.py for VFS related GDB helpers
        uapi/linux/const.h: prefer ISO-friendly __typeof__
        delayacct: track delays from IRQ/SOFTIRQ
        scripts/gdb: timerlist: convert int chunks to str
        scripts/gdb: print interrupts
        scripts/gdb: raise error with reduced debugging information
        scripts/gdb: add a Radix Tree Parser
        lib/rbtree: use '+' instead of '|' for setting color.
        proc/stat: remove arch_idle_time()
        checkpatch: check for misuse of the link tags
        checkpatch: allow Closes tags with links
        ...
      33afd4b7
    • Linus Torvalds's avatar
      Merge tag 'mm-stable-2023-04-27-15-30' of git://git.kernel.org/pub/scm/linux/kernel/git/akpm/mm · 7fa8a8ee
      Linus Torvalds authored
      Pull MM updates from Andrew Morton:
      
       - Nick Piggin's "shoot lazy tlbs" series, to improve the peformance of
         switching from a user process to a kernel thread.
      
       - More folio conversions from Kefeng Wang, Zhang Peng and Pankaj
         Raghav.
      
       - zsmalloc performance improvements from Sergey Senozhatsky.
      
       - Yue Zhao has found and fixed some data race issues around the
         alteration of memcg userspace tunables.
      
       - VFS rationalizations from Christoph Hellwig:
           - removal of most of the callers of write_one_page()
           - make __filemap_get_folio()'s return value more useful
      
       - Luis Chamberlain has changed tmpfs so it no longer requires swap
         backing. Use `mount -o noswap'.
      
       - Qi Zheng has made the slab shrinkers operate locklessly, providing
         some scalability benefits.
      
       - Keith Busch has improved dmapool's performance, making part of its
         operations O(1) rather than O(n).
      
       - Peter Xu adds the UFFD_FEATURE_WP_UNPOPULATED feature to userfaultd,
         permitting userspace to wr-protect anon memory unpopulated ptes.
      
       - Kirill Shutemov has changed MAX_ORDER's meaning to be inclusive
         rather than exclusive, and has fixed a bunch of errors which were
         caused by its unintuitive meaning.
      
       - Axel Rasmussen give userfaultfd the UFFDIO_CONTINUE_MODE_WP feature,
         which causes minor faults to install a write-protected pte.
      
       - Vlastimil Babka has done some maintenance work on vma_merge():
         cleanups to the kernel code and improvements to our userspace test
         harness.
      
       - Cleanups to do_fault_around() by Lorenzo Stoakes.
      
       - Mike Rapoport has moved a lot of initialization code out of various
         mm/ files and into mm/mm_init.c.
      
       - Lorenzo Stoakes removd vmf_insert_mixed_prot(), which was added for
         DRM, but DRM doesn't use it any more.
      
       - Lorenzo has also coverted read_kcore() and vread() to use iterators
         and has thereby removed the use of bounce buffers in some cases.
      
       - Lorenzo has also contributed further cleanups of vma_merge().
      
       - Chaitanya Prakash provides some fixes to the mmap selftesting code.
      
       - Matthew Wilcox changes xfs and afs so they no longer take sleeping
         locks in ->map_page(), a step towards RCUification of pagefaults.
      
       - Suren Baghdasaryan has improved mmap_lock scalability by switching to
         per-VMA locking.
      
       - Frederic Weisbecker has reworked the percpu cache draining so that it
         no longer causes latency glitches on cpu isolated workloads.
      
       - Mike Rapoport cleans up and corrects the ARCH_FORCE_MAX_ORDER Kconfig
         logic.
      
       - Liu Shixin has changed zswap's initialization so we no longer waste a
         chunk of memory if zswap is not being used.
      
       - Yosry Ahmed has improved the performance of memcg statistics
         flushing.
      
       - David Stevens has fixed several issues involving khugepaged,
         userfaultfd and shmem.
      
       - Christoph Hellwig has provided some cleanup work to zram's IO-related
         code paths.
      
       - David Hildenbrand has fixed up some issues in the selftest code's
         testing of our pte state changing.
      
       - Pankaj Raghav has made page_endio() unneeded and has removed it.
      
       - Peter Xu contributed some rationalizations of the userfaultfd
         selftests.
      
       - Yosry Ahmed has fixed an issue around memcg's page recalim
         accounting.
      
       - Chaitanya Prakash has fixed some arm-related issues in the
         selftests/mm code.
      
       - Longlong Xia has improved the way in which KSM handles hwpoisoned
         pages.
      
       - Peter Xu fixes a few issues with uffd-wp at fork() time.
      
       - Stefan Roesch has changed KSM so that it may now be used on a
         per-process and per-cgroup basis.
      
      * tag 'mm-stable-2023-04-27-15-30' of git://git.kernel.org/pub/scm/linux/kernel/git/akpm/mm: (369 commits)
        mm,unmap: avoid flushing TLB in batch if PTE is inaccessible
        shmem: restrict noswap option to initial user namespace
        mm/khugepaged: fix conflicting mods to collapse_file()
        sparse: remove unnecessary 0 values from rc
        mm: move 'mmap_min_addr' logic from callers into vm_unmapped_area()
        hugetlb: pte_alloc_huge() to replace huge pte_alloc_map()
        maple_tree: fix allocation in mas_sparse_area()
        mm: do not increment pgfault stats when page fault handler retries
        zsmalloc: allow only one active pool compaction context
        selftests/mm: add new selftests for KSM
        mm: add new KSM process and sysfs knobs
        mm: add new api to enable ksm per process
        mm: shrinkers: fix debugfs file permissions
        mm: don't check VMA write permissions if the PTE/PMD indicates write permissions
        migrate_pages_batch: fix statistics for longterm pin retry
        userfaultfd: use helper function range_in_vma()
        lib/show_mem.c: use for_each_populated_zone() simplify code
        mm: correct arg in reclaim_pages()/reclaim_clean_pages_from_list()
        fs/buffer: convert create_page_buffers to folio_create_buffers
        fs/buffer: add folio_create_empty_buffers helper
        ...
      7fa8a8ee
    • Linus Torvalds's avatar
      Merge tag 'mips_6.4' of git://git.kernel.org/pub/scm/linux/kernel/git/mips/linux · 91ec4b0d
      Linus Torvalds authored
      Pull MIPS updates from Thomas Bogendoerfer:
      
       - added support for Huawei B593u-12
      
       - added support for virt board aligned to QEMU MIPS virt board
      
       - added support for doing DMA coherence on a per device base
      
       - reworked handling of RALINK SoCs
      
       - cleanup for Loongon64 barriers
      
       - removed deprecated support for MIPS_CMP SMP handling method
      
       - removed support Sibyte CARMEL and CHRINE boards
      
       - cleanups and fixes
      
      * tag 'mips_6.4' of git://git.kernel.org/pub/scm/linux/kernel/git/mips/linux: (59 commits)
        MIPS: uprobes: Restore thread.trap_nr
        MIPS: Don't clear _PAGE_SPECIAL in _PAGE_CHG_MASK
        MIPS: Sink body of check_bugs_early() into its only call site
        MIPS: Mark check_bugs() as __init
        Revert "MIPS: generic: Enable all CPUs supported by virt board in Kconfig"
        MIPS: octeon_switch: Remove duplicated labels
        MIPS: loongson2ef: Add missing break in cs5536_isa
        MIPS: Remove set_swbp() in uprobes.c
        MIPS: Use def_bool y for ARCH_SUPPORTS_UPROBES
        MIPS: fw: Allow firmware to pass a empty env
        MIPS: Remove deprecated CONFIG_MIPS_CMP
        MIPS: lantiq: remove unused function declaration
        MIPS: Drop unused positional parameter in local_irq_{dis,en}able
        MIPS: mm: Remove local_cache_flush_page
        MIPS: Remove no longer used ide.h
        MIPS: mm: Remove unused *cache_page_indexed flush functions
        MIPS: generic: Enable all CPUs supported by virt board in Kconfig
        MIPS: Add board config for virt board
        MIPS: Octeon: Disable CVMSEG by default on other platforms
        MIPS: Loongson: Don't select platform features with CPU
        ...
      91ec4b0d
    • Linus Torvalds's avatar
      Merge tag 'sh-for-v6.4-tag1' of git://git.kernel.org/pub/scm/linux/kernel/git/glaubitz/sh-linux · 513f17f8
      Linus Torvalds authored
      Pull sh updates from John Paul Adrian Glaubitz:
       "This is a bit larger than my previous one and mainly consists of
        clean-up work in the arch/sh directory by Geert Uytterhoeven and Randy
        Dunlap.
      
        Additionally, this fixes a bug in the Storage Queue code that was
        discovered while I was reviewing a patch to switch the code to the
        bitmap API by Christophe Jaillet.
      
        So this contains both a fix for the original bug in the Storage Queue
        code that can be backported later as well as the Christophe's patch to
        swich the code to the bitmap API.
      
        Summary:
      
         - Use generic GCC library routines
      
         - sq: Use the bitmap API when applicable
      
         - sq: Fix incorrect element size for allocating bitmap buffer
      
         - pci: Remove unused variable in SH-7786 PCI Express code
      
         - mcount.S: fix build error when PRINTK is not enabled
      
         - remove sh5/sh64 last fragments
      
         - math-emu: fix macro redefined warning
      
         - init: use OF_EARLY_FLATTREE for early init
      
         - nmi_debug: fix return value of __setup handler
      
         - SH2007: drop the bad URL info"
      
      * tag 'sh-for-v6.4-tag1' of git://git.kernel.org/pub/scm/linux/kernel/git/glaubitz/sh-linux:
        sh: Replace <uapi/asm/types.h> by <asm-generic/int-ll64.h>
        sh: Use generic GCC library routines
        sh: sq: Use the bitmap API when applicable
        sh: sq: Fix incorrect element size for allocating bitmap buffer
        sh: pci: Remove unused variable in SH-7786 PCI Express code
        sh: mcount.S: fix build error when PRINTK is not enabled
        sh: remove sh5/sh64 last fragments
        sh: math-emu: fix macro redefined warning
        sh: init: use OF_EARLY_FLATTREE for early init
        sh: nmi_debug: fix return value of __setup handler
        sh: SH2007: drop the bad URL info
      513f17f8
    • Linus Torvalds's avatar
      Merge tag 'for-linus-6.4-rc1-tag' of git://git.kernel.org/pub/scm/linux/kernel/git/xen/tip · 35fab927
      Linus Torvalds authored
      Pull xen updates from Juergen Gross:
      
       - some cleanups in the Xen blkback driver
      
       - fix potential sleeps under lock in various Xen drivers
      
      * tag 'for-linus-6.4-rc1-tag' of git://git.kernel.org/pub/scm/linux/kernel/git/xen/tip:
        xen/blkback: move blkif_get_x86_*_req() into blkback.c
        xen/blkback: simplify free_persistent_gnts() interface
        xen/blkback: remove stale prototype
        xen/blkback: fix white space code style issues
        xen/pvcalls: don't call bind_evtchn_to_irqhandler() under lock
        xen/scsiback: don't call scsiback_free_translation_entry() under lock
        xen/pciback: don't call pcistub_device_put() under lock
      35fab927
    • Linus Torvalds's avatar
      Merge tag 'hyperv-next-signed-20230424' of... · da46b58f
      Linus Torvalds authored
      Merge tag 'hyperv-next-signed-20230424' of git://git.kernel.org/pub/scm/linux/kernel/git/hyperv/linux
      
      Pull hyperv updates from Wei Liu:
      
       - PCI passthrough for Hyper-V confidential VMs (Michael Kelley)
      
       - Hyper-V VTL mode support (Saurabh Sengar)
      
       - Move panic report initialization code earlier (Long Li)
      
       - Various improvements and bug fixes (Dexuan Cui and Michael Kelley)
      
      * tag 'hyperv-next-signed-20230424' of git://git.kernel.org/pub/scm/linux/kernel/git/hyperv/linux: (22 commits)
        PCI: hv: Replace retarget_msi_interrupt_params with hyperv_pcpu_input_arg
        Drivers: hv: move panic report code from vmbus to hv early init code
        x86/hyperv: VTL support for Hyper-V
        Drivers: hv: Kconfig: Add HYPERV_VTL_MODE
        x86/hyperv: Make hv_get_nmi_reason public
        x86/hyperv: Add VTL specific structs and hypercalls
        x86/init: Make get/set_rtc_noop() public
        x86/hyperv: Exclude lazy TLB mode CPUs from enlightened TLB flushes
        x86/hyperv: Add callback filter to cpumask_to_vpset()
        Drivers: hv: vmbus: Remove the per-CPU post_msg_page
        clocksource: hyper-v: make sure Invariant-TSC is used if it is available
        PCI: hv: Enable PCI pass-thru devices in Confidential VMs
        Drivers: hv: Don't remap addresses that are above shared_gpa_boundary
        hv_netvsc: Remove second mapping of send and recv buffers
        Drivers: hv: vmbus: Remove second way of mapping ring buffers
        Drivers: hv: vmbus: Remove second mapping of VMBus monitor pages
        swiotlb: Remove bounce buffer remapping for Hyper-V
        Driver: VMBus: Add Devicetree support
        dt-bindings: bus: Add Hyper-V VMBus
        Drivers: hv: vmbus: Convert acpi_device to more generic platform_device
        ...
      da46b58f
    • Linus Torvalds's avatar
      Merge tag 'for_linus' of git://git.kernel.org/pub/scm/linux/kernel/git/mst/vhost · 8ccd54fe
      Linus Torvalds authored
      Pull virtio updates from Michael Tsirkin:
       "virtio,vhost,vdpa: features, fixes, and cleanups:
      
         - reduction in interrupt rate in virtio
      
         - perf improvement for VDUSE
      
         - scalability for vhost-scsi
      
         - non power of 2 ring support for packed rings
      
         - better management for mlx5 vdpa
      
         - suspend for snet
      
         - VIRTIO_F_NOTIFICATION_DATA
      
         - shared backend with vdpa-sim-blk
      
         - user VA support in vdpa-sim
      
         - better struct packing for virtio
      
        and fixes, cleanups all over the place"
      
      * tag 'for_linus' of git://git.kernel.org/pub/scm/linux/kernel/git/mst/vhost: (52 commits)
        vhost_vdpa: fix unmap process in no-batch mode
        MAINTAINERS: make me a reviewer of VIRTIO CORE AND NET DRIVERS
        tools/virtio: fix build caused by virtio_ring changes
        virtio_ring: add a struct device forward declaration
        vdpa_sim_blk: support shared backend
        vdpa_sim: move buffer allocation in the devices
        vdpa/snet: use likely/unlikely macros in hot functions
        vdpa/snet: implement kick_vq_with_data callback
        virtio-vdpa: add VIRTIO_F_NOTIFICATION_DATA feature support
        virtio: add VIRTIO_F_NOTIFICATION_DATA feature support
        vdpa/snet: support the suspend vDPA callback
        vdpa/snet: support getting and setting VQ state
        MAINTAINERS: add vringh.h to Virtio Core and Net Drivers
        vringh: address kdoc warnings
        vdpa: address kdoc warnings
        virtio_ring: don't update event idx on get_buf
        vdpa_sim: add support for user VA
        vdpa_sim: replace the spinlock with a mutex to protect the state
        vdpa_sim: use kthread worker
        vdpa_sim: make devices agnostic for work management
        ...
      8ccd54fe
    • Linus Torvalds's avatar
      Merge tag 'pstore-v6.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/kees/linux · 0835b5ee
      Linus Torvalds authored
      Pull pstore update from Kees Cook:
      
       - Revert pmsg_lock back to a normal mutex (John Stultz)
      
      * tag 'pstore-v6.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/kees/linux:
        pstore: Revert pmsg_lock back to a normal mutex
      0835b5ee
    • Linus Torvalds's avatar
      Merge tag 'hardening-v6.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/kees/linux · 900941be
      Linus Torvalds authored
      Pull hardening update from Kees Cook:
      
       - Fix kheaders array declaration to avoid tripping FORTIFY_SOURCE
      
      * tag 'hardening-v6.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/kees/linux:
        kheaders: Use array declaration instead of char
      900941be
  2. 27 Apr, 2023 20 commits
    • Linus Torvalds's avatar
      Merge tag 'sysctl-6.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/mcgrof/linux · 888d3c9f
      Linus Torvalds authored
      Pull sysctl updates from Luis Chamberlain:
       "This only does a few sysctl moves from the kernel/sysctl.c file, the
        rest of the work has been put towards deprecating two API calls which
        incur recursion and prevent us from simplifying the registration
        process / saving memory per move. Most of the changes have been
        soaking on linux-next since v6.3-rc3.
      
        I've slowed down the kernel/sysctl.c moves due to Matthew Wilcox's
        feedback that we should see if we could *save* memory with these moves
        instead of incurring more memory. We currently incur more memory since
        when we move a syctl from kernel/sysclt.c out to its own file we end
        up having to add a new empty sysctl used to register it. To achieve
        saving memory we want to allow syctls to be passed without requiring
        the end element being empty, and just have our registration process
        rely on ARRAY_SIZE(). Without this, supporting both styles of sysctls
        would make the sysctl registration pretty brittle, hard to read and
        maintain as can be seen from Meng Tang's efforts to do just this [0].
        Fortunately, in order to use ARRAY_SIZE() for all sysctl registrations
        also implies doing the work to deprecate two API calls which use
        recursion in order to support sysctl declarations with subdirectories.
      
        And so during this development cycle quite a bit of effort went into
        this deprecation effort. I've annotated the following two APIs are
        deprecated and in few kernel releases we should be good to remove
        them:
      
         - register_sysctl_table()
         - register_sysctl_paths()
      
        During this merge window we should be able to deprecate and unexport
        register_sysctl_paths(), we can probably do that towards the end of
        this merge window.
      
        Deprecating register_sysctl_table() will take a bit more time but this
        pull request goes with a few example of how to do this.
      
        As it turns out each of the conversions to move away from either of
        these two API calls *also* saves memory. And so long term, all these
        changes *will* prove to have saved a bit of memory on boot.
      
        The way I see it then is if remove a user of one deprecated call, it
        gives us enough savings to move one kernel/sysctl.c out from the
        generic arrays as we end up with about the same amount of bytes.
      
        Since deprecating register_sysctl_table() and register_sysctl_paths()
        does not require maintainer coordination except the final unexport
        you'll see quite a bit of these changes from other pull requests, I've
        just kept the stragglers after rc3"
      
      Link: https://lkml.kernel.org/r/ZAD+cpbrqlc5vmry@bombadil.infradead.org [0]
      
      * tag 'sysctl-6.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/mcgrof/linux: (29 commits)
        fs: fix sysctls.c built
        mm: compaction: remove incorrect #ifdef checks
        mm: compaction: move compaction sysctl to its own file
        mm: memory-failure: Move memory failure sysctls to its own file
        arm: simplify two-level sysctl registration for ctl_isa_vars
        ia64: simplify one-level sysctl registration for kdump_ctl_table
        utsname: simplify one-level sysctl registration for uts_kern_table
        ntfs: simplfy one-level sysctl registration for ntfs_sysctls
        coda: simplify one-level sysctl registration for coda_table
        fs/cachefiles: simplify one-level sysctl registration for cachefiles_sysctls
        xfs: simplify two-level sysctl registration for xfs_table
        nfs: simplify two-level sysctl registration for nfs_cb_sysctls
        nfs: simplify two-level sysctl registration for nfs4_cb_sysctls
        lockd: simplify two-level sysctl registration for nlm_sysctls
        proc_sysctl: enhance documentation
        xen: simplify sysctl registration for balloon
        md: simplify sysctl registration
        hv: simplify sysctl registration
        scsi: simplify sysctl registration with register_sysctl()
        csky: simplify alignment sysctl registration
        ...
      888d3c9f
    • Linus Torvalds's avatar
      Merge tag 'modules-6.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/mcgrof/linux · b6a78285
      Linus Torvalds authored
      Pull module updates from Luis Chamberlain:
       "The summary of the changes for this pull requests is:
      
         - Song Liu's new struct module_memory replacement
      
         - Nick Alcock's MODULE_LICENSE() removal for non-modules
      
         - My cleanups and enhancements to reduce the areas where we vmalloc
           module memory for duplicates, and the respective debug code which
           proves the remaining vmalloc pressure comes from userspace.
      
        Most of the changes have been in linux-next for quite some time except
        the minor fixes I made to check if a module was already loaded prior
        to allocating the final module memory with vmalloc and the respective
        debug code it introduces to help clarify the issue. Although the
        functional change is small it is rather safe as it can only *help*
        reduce vmalloc space for duplicates and is confirmed to fix a bootup
        issue with over 400 CPUs with KASAN enabled. I don't expect stable
        kernels to pick up that fix as the cleanups would have also had to
        have been picked up. Folks on larger CPU systems with modules will
        want to just upgrade if vmalloc space has been an issue on bootup.
      
        Given the size of this request, here's some more elaborate details:
      
        The functional change change in this pull request is the very first
        patch from Song Liu which replaces the 'struct module_layout' with a
        new 'struct module_memory'. The old data structure tried to put
        together all types of supported module memory types in one data
        structure, the new one abstracts the differences in memory types in a
        module to allow each one to provide their own set of details. This
        paves the way in the future so we can deal with them in a cleaner way.
        If you look at changes they also provide a nice cleanup of how we
        handle these different memory areas in a module. This change has been
        in linux-next since before the merge window opened for v6.3 so to
        provide more than a full kernel cycle of testing. It's a good thing as
        quite a bit of fixes have been found for it.
      
        Jason Baron then made dynamic debug a first class citizen module user
        by using module notifier callbacks to allocate / remove module
        specific dynamic debug information.
      
        Nick Alcock has done quite a bit of work cross-tree to remove module
        license tags from things which cannot possibly be module at my request
        so to:
      
         a) help him with his longer term tooling goals which require a
            deterministic evaluation if a piece a symbol code could ever be
            part of a module or not. But quite recently it is has been made
            clear that tooling is not the only one that would benefit.
            Disambiguating symbols also helps efforts such as live patching,
            kprobes and BPF, but for other reasons and R&D on this area is
            active with no clear solution in sight.
      
         b) help us inch closer to the now generally accepted long term goal
            of automating all the MODULE_LICENSE() tags from SPDX license tags
      
        In so far as a) is concerned, although module license tags are a no-op
        for non-modules, tools which would want create a mapping of possible
        modules can only rely on the module license tag after the commit
        8b41fc44 ("kbuild: create modules.builtin without
        Makefile.modbuiltin or tristate.conf").
      
        Nick has been working on this *for years* and AFAICT I was the only
        one to suggest two alternatives to this approach for tooling. The
        complexity in one of my suggested approaches lies in that we'd need a
        possible-obj-m and a could-be-module which would check if the object
        being built is part of any kconfig build which could ever lead to it
        being part of a module, and if so define a new define
        -DPOSSIBLE_MODULE [0].
      
        A more obvious yet theoretical approach I've suggested would be to
        have a tristate in kconfig imply the same new -DPOSSIBLE_MODULE as
        well but that means getting kconfig symbol names mapping to modules
        always, and I don't think that's the case today. I am not aware of
        Nick or anyone exploring either of these options. Quite recently Josh
        Poimboeuf has pointed out that live patching, kprobes and BPF would
        benefit from resolving some part of the disambiguation as well but for
        other reasons. The function granularity KASLR (fgkaslr) patches were
        mentioned but Joe Lawrence has clarified this effort has been dropped
        with no clear solution in sight [1].
      
        In the meantime removing module license tags from code which could
        never be modules is welcomed for both objectives mentioned above. Some
        developers have also welcomed these changes as it has helped clarify
        when a module was never possible and they forgot to clean this up, and
        so you'll see quite a bit of Nick's patches in other pull requests for
        this merge window. I just picked up the stragglers after rc3. LWN has
        good coverage on the motivation behind this work [2] and the typical
        cross-tree issues he ran into along the way. The only concrete blocker
        issue he ran into was that we should not remove the MODULE_LICENSE()
        tags from files which have no SPDX tags yet, even if they can never be
        modules. Nick ended up giving up on his efforts due to having to do
        this vetting and backlash he ran into from folks who really did *not
        understand* the core of the issue nor were providing any alternative /
        guidance. I've gone through his changes and dropped the patches which
        dropped the module license tags where an SPDX license tag was missing,
        it only consisted of 11 drivers. To see if a pull request deals with a
        file which lacks SPDX tags you can just use:
      
          ./scripts/spdxcheck.py -f \
      	$(git diff --name-only commid-id | xargs echo)
      
        You'll see a core module file in this pull request for the above, but
        that's not related to his changes. WE just need to add the SPDX
        license tag for the kernel/module/kmod.c file in the future but it
        demonstrates the effectiveness of the script.
      
        Most of Nick's changes were spread out through different trees, and I
        just picked up the slack after rc3 for the last kernel was out. Those
        changes have been in linux-next for over two weeks.
      
        The cleanups, debug code I added and final fix I added for modules
        were motivated by David Hildenbrand's report of boot failing on a
        systems with over 400 CPUs when KASAN was enabled due to running out
        of virtual memory space. Although the functional change only consists
        of 3 lines in the patch "module: avoid allocation if module is already
        present and ready", proving that this was the best we can do on the
        modules side took quite a bit of effort and new debug code.
      
        The initial cleanups I did on the modules side of things has been in
        linux-next since around rc3 of the last kernel, the actual final fix
        for and debug code however have only been in linux-next for about a
        week or so but I think it is worth getting that code in for this merge
        window as it does help fix / prove / evaluate the issues reported with
        larger number of CPUs. Userspace is not yet fixed as it is taking a
        bit of time for folks to understand the crux of the issue and find a
        proper resolution. Worst come to worst, I have a kludge-of-concept [3]
        of how to make kernel_read*() calls for modules unique / converge
        them, but I'm currently inclined to just see if userspace can fix this
        instead"
      
      Link: https://lore.kernel.org/all/Y/kXDqW+7d71C4wz@bombadil.infradead.org/ [0]
      Link: https://lkml.kernel.org/r/025f2151-ce7c-5630-9b90-98742c97ac65@redhat.com [1]
      Link: https://lwn.net/Articles/927569/ [2]
      Link: https://lkml.kernel.org/r/20230414052840.1994456-3-mcgrof@kernel.org [3]
      
      * tag 'modules-6.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/mcgrof/linux: (121 commits)
        module: add debugging auto-load duplicate module support
        module: stats: fix invalid_mod_bytes typo
        module: remove use of uninitialized variable len
        module: fix building stats for 32-bit targets
        module: stats: include uapi/linux/module.h
        module: avoid allocation if module is already present and ready
        module: add debug stats to help identify memory pressure
        module: extract patient module check into helper
        modules/kmod: replace implementation with a semaphore
        Change DEFINE_SEMAPHORE() to take a number argument
        module: fix kmemleak annotations for non init ELF sections
        module: Ignore L0 and rename is_arm_mapping_symbol()
        module: Move is_arm_mapping_symbol() to module_symbol.h
        module: Sync code of is_arm_mapping_symbol()
        scripts/gdb: use mem instead of core_layout to get the module address
        interconnect: remove module-related code
        interconnect: remove MODULE_LICENSE in non-modules
        zswap: remove MODULE_LICENSE in non-modules
        zpool: remove MODULE_LICENSE in non-modules
        x86/mm/dump_pagetables: remove MODULE_LICENSE in non-modules
        ...
      b6a78285
    • Linus Torvalds's avatar
      cdx: fix build failure due to sysfs 'bus_type' argument needing to be const · d06f5a3f
      Linus Torvalds authored
      Commit 75cff725 ("driver core: bus: mark the struct bus_type for
      sysfs callbacks as constant") missed at least one case - the CDX bus
      driver.  Probably because Greg didn't notice the build failure, because
      it only ends up being enabled on arm64.
      
      And I missed it during the merge, because while I do arm64 builds these
      days, I don't do them in between each pull.  So it took a while for me
      to notice the breakage, rather than me just fixing it in the driver core
      merge that brought this failure case in.
      
      Maybe we should remove the CDX_BUS dependency on arm64 when COMPILE_TEST
      is on?
      
      Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
      Cc: Nipun Gupta <nipun.gupta@amd.com>
      Cc: Nikhil Agarwal <nikhil.agarwal@amd.com>
      Signed-off-by: default avatarLinus Torvalds <torvalds@linux-foundation.org>
      d06f5a3f
    • Johannes Berg's avatar
      ring-buffer: Sync IRQ works before buffer destruction · 675751bb
      Johannes Berg authored
      If something was written to the buffer just before destruction,
      it may be possible (maybe not in a real system, but it did
      happen in ARCH=um with time-travel) to destroy the ringbuffer
      before the IRQ work ran, leading this KASAN report (or a crash
      without KASAN):
      
          BUG: KASAN: slab-use-after-free in irq_work_run_list+0x11a/0x13a
          Read of size 8 at addr 000000006d640a48 by task swapper/0
      
          CPU: 0 PID: 0 Comm: swapper Tainted: G        W  O       6.3.0-rc1 #7
          Stack:
           60c4f20f 0c203d48 41b58ab3 60f224fc
           600477fa 60f35687 60c4f20f 601273dd
           00000008 6101eb00 6101eab0 615be548
          Call Trace:
           [<60047a58>] show_stack+0x25e/0x282
           [<60c609e0>] dump_stack_lvl+0x96/0xfd
           [<60c50d4c>] print_report+0x1a7/0x5a8
           [<603078d3>] kasan_report+0xc1/0xe9
           [<60308950>] __asan_report_load8_noabort+0x1b/0x1d
           [<60232844>] irq_work_run_list+0x11a/0x13a
           [<602328b4>] irq_work_tick+0x24/0x34
           [<6017f9dc>] update_process_times+0x162/0x196
           [<6019f335>] tick_sched_handle+0x1a4/0x1c3
           [<6019fd9e>] tick_sched_timer+0x79/0x10c
           [<601812b9>] __hrtimer_run_queues.constprop.0+0x425/0x695
           [<60182913>] hrtimer_interrupt+0x16c/0x2c4
           [<600486a3>] um_timer+0x164/0x183
           [...]
      
          Allocated by task 411:
           save_stack_trace+0x99/0xb5
           stack_trace_save+0x81/0x9b
           kasan_save_stack+0x2d/0x54
           kasan_set_track+0x34/0x3e
           kasan_save_alloc_info+0x25/0x28
           ____kasan_kmalloc+0x8b/0x97
           __kasan_kmalloc+0x10/0x12
           __kmalloc+0xb2/0xe8
           load_elf_phdrs+0xee/0x182
           [...]
      
          The buggy address belongs to the object at 000000006d640800
           which belongs to the cache kmalloc-1k of size 1024
          The buggy address is located 584 bytes inside of
           freed 1024-byte region [000000006d640800, 000000006d640c00)
      
      Add the appropriate irq_work_sync() so the work finishes before
      the buffers are destroyed.
      
      Prior to the commit in the Fixes tag below, there was only a
      single global IRQ work, so this issue didn't exist.
      
      Link: https://lore.kernel.org/linux-trace-kernel/20230427175920.a76159263122.I8295e405c44362a86c995e9c2c37e3e03810aa56@changeid
      
      Cc: stable@vger.kernel.org
      Cc: Masami Hiramatsu <mhiramat@kernel.org>
      Fixes: 15693458 ("tracing/ring-buffer: Move poll wake ups into ring buffer code")
      Signed-off-by: default avatarJohannes Berg <johannes.berg@intel.com>
      Signed-off-by: default avatarSteven Rostedt (Google) <rostedt@goodmis.org>
      675751bb
    • Paul Mackerras's avatar
    • Geert Uytterhoeven's avatar
      libgcc: add forward declarations for generic library routines · 4f20b747
      Geert Uytterhoeven authored
      With W=1 on platforms that use the generic gcc library routines
      (csky/loongarch/mips/riscv/sh/xtensa):
      
          lib/ashldi3.c:9:19: warning: no previous prototype for '__ashldi3' [-Wmissing-prototypes]
      	9 | long long notrace __ashldi3(long long u, word_type b)
      	  |                   ^~~~~~~~~
            CC      lib/ashrdi3.o
          lib/ashrdi3.c:9:19: warning: no previous prototype for '__ashrdi3' [-Wmissing-prototypes]
      	9 | long long notrace __ashrdi3(long long u, word_type b)
      	  |                   ^~~~~~~~~
            CC      lib/cmpdi2.o
          lib/cmpdi2.c:9:19: warning: no previous prototype for '__cmpdi2' [-Wmissing-prototypes]
      	9 | word_type notrace __cmpdi2(long long a, long long b)
      	  |                   ^~~~~~~~
            CC      lib/lshrdi3.o
          lib/lshrdi3.c:9:19: warning: no previous prototype for '__lshrdi3' [-Wmissing-prototypes]
      	9 | long long notrace __lshrdi3(long long u, word_type b)
      	  |                   ^~~~~~~~~
            CC      lib/muldi3.o
          lib/muldi3.c:49:19: warning: no previous prototype for '__muldi3' [-Wmissing-prototypes]
             49 | long long notrace __muldi3(long long u, long long v)
      	  |                   ^~~~~~~~
            CC      lib/ucmpdi2.o
          lib/ucmpdi2.c:8:19: warning: no previous prototype for '__ucmpdi2' [-Wmissing-prototypes]
      	8 | word_type notrace __ucmpdi2(unsigned long long a, unsigned long long b)
      	  |                   ^~~~~~~~~
      
      Fix this by adding forward declarations to the common libgcc header
      file.
      
      Link: https://lkml.kernel.org/r/5cdbe08296693dd53849f199c3933e16e97b33c1.1682088593.git.geert+renesas@glider.beSigned-off-by: default avatarGeert Uytterhoeven <geert+renesas@glider.be>
      Reported-by: default avatarkernel test robot <lkp@intel.com>
        Link: https://lore.kernel.org/oe-kbuild-all/202303272214.RxzpA6bP-lkp@intel.com/Acked-by: default avatarArnd Bergmann <arnd@arndb.de>
      Cc: Chris Zankel <chris@zankel.net>
      Cc: Max Filippov <jcmvbkbc@gmail.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      4f20b747
    • Huang Ying's avatar
      mm,unmap: avoid flushing TLB in batch if PTE is inaccessible · 4d4b6d66
      Huang Ying authored
      0Day/LKP reported a performance regression for commit 7e12beb8
      ("migrate_pages: batch flushing TLB").  In the commit, the TLB flushing
      during page migration is batched.  So, in try_to_migrate_one(),
      ptep_clear_flush() is replaced with set_tlb_ubc_flush_pending().  In
      further investigation, it is found that the TLB flushing can be avoided in
      ptep_clear_flush() if the PTE is inaccessible.  In fact, we can optimize
      in similar way for the batched TLB flushing too to improve the
      performance.
      
      So in this patch, we check pte_accessible() before
      set_tlb_ubc_flush_pending() in try_to_unmap/migrate_one().  Tests show
      that the benchmark score of the anon-cow-rand-mt test case of
      vm-scalability test suite can improve up to 2.1% with the patch on a Intel
      server machine.  The TLB flushing IPI can reduce up to 44.3%.
      
      Link: https://lore.kernel.org/oe-lkp/202303192325.ecbaf968-yujie.liu@intel.com
      Link: https://lore.kernel.org/oe-lkp/ab92aaddf1b52ede15e2c608696c36765a2602c1.camel@intel.com/
      Link: https://lkml.kernel.org/r/20230424065408.188498-1-ying.huang@intel.com
      Fixes: 7e12beb8 ("migrate_pages: batch flushing TLB")
      Signed-off-by: default avatar"Huang, Ying" <ying.huang@intel.com>
      Reported-by: default avatarkernel test robot <yujie.liu@intel.com>
      Reviewed-by: default avatarNadav Amit <namit@vmware.com>
      Reviewed-by: default avatarXin Hao <xhao@linux.alibaba.com>
      Cc: Mel Gorman <mgorman@techsingularity.net>
      Cc: Hugh Dickins <hughd@google.com>
      Cc: Matthew Wilcox (Oracle) <willy@infradead.org>
      Cc: David Hildenbrand <david@redhat.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      4d4b6d66
    • Christian Brauner's avatar
      shmem: restrict noswap option to initial user namespace · 01106e14
      Christian Brauner authored
      Prevent tmpfs instances mounted in an unprivileged namespaces from evading
      accounting of locked memory by using the "noswap" mount option.
      
      Link: https://lkml.kernel.org/r/20230420-faxen-advokat-40abb4c1a152@braunerSigned-off-by: default avatarChristian Brauner <brauner@kernel.org>
      Reported-by: default avatarHugh Dickins <hughd@google.com>
        Link: https://lore.kernel.org/lkml/79eae9fe-7818-a65c-89c6-138b55d609a@google.comReviewed-by: default avatarLuis Chamberlain <mcgrof@kernel.org>
      Cc: Adam Manzanares <a.manzanares@samsung.com>
      Cc: Davidlohr Bueso <dave@stgolabs.net>
      Cc: Kees Cook <keescook@chromium.org>
      Cc: Matthew Wilcox (Oracle) <willy@infradead.org>
      Cc: Pankaj Raghav <p.raghav@samsung.com>
      Cc: Yosry Ahmed <yosryahmed@google.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      01106e14
    • Hugh Dickins's avatar
      mm/khugepaged: fix conflicting mods to collapse_file() · 0175ab61
      Hugh Dickins authored
      Inserting Ivan Orlov's syzbot fix commit 2ce0bdfe
      ("mm: khugepaged: fix kernel BUG in hpage_collapse_scan_file()")
      ahead of Jiaqi Yan's and David Stevens's commits
      12904d95 ("mm/khugepaged: recover from poisoned file-backed memory")
      cae106dd ("mm/khugepaged: refactor collapse_file control flow")
      ac492b9c ("mm/khugepaged: skip shmem with userfaultfd")
      (all of which restructure collapse_file()) did not work out well.
      
      xfstests generic/086 on huge tmpfs (with accelerated khugepaged) freezes
      (if not on the first attempt, then the 2nd or 3rd) in find_lock_entries()
      while doing drop_caches: the file's xarray seems to have been corrupted,
      with find_get_entry() returning nonsense which makes no progress.
      
      Bisection led to ac492b9c; and diff against earlier working linux-next
      suggested that it's probably down to an errant xas_store(), which does not
      belong with the later changes (and nor does the positioning of warnings). 
      The later changes look as if they fix the syzbot issue independently.
      
      Remove most of what's left of 2ce0bdfe: just leave one WARN_ON_ONCE
      (xas_error) after the final xas_store() of the multi-index entry.
      
      Link: https://lkml.kernel.org/r/b6c881-c352-bb91-85a8-febeb09dfd71@google.comSigned-off-by: default avatarHugh Dickins <hughd@google.com>
      Cc: David Stevens <stevensd@chromium.org>
      Cc: Ivan Orlov <ivan.orlov0322@gmail.com>
      Cc: Jiaqi Yan <jiaqiyan@google.com>
      Signed-off-by: default avatarAndrew Morton <akpm@linux-foundation.org>
      0175ab61
    • Linus Torvalds's avatar
      Merge tag 'char-misc-6.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/char-misc · cec24b8b
      Linus Torvalds authored
      Pull char/misc drivers updates from Greg KH:
       "Here is the "big" set of char/misc and other driver subsystems for
        6.4-rc1.
      
        It's pretty big, but due to the removal of pcmcia drivers, almost
        breaks even for number of lines added vs. removed, a nice change.
      
        Included in here are:
      
         - removal of unused PCMCIA drivers (finally!)
      
         - Interconnect driver updates and additions
      
         - Lots of IIO driver updates and additions
      
         - MHI driver updates
      
         - Coresight driver updates
      
         - NVMEM driver updates, which required some OF updates
      
         - W1 driver updates and a new maintainer to manage the subsystem
      
         - FPGA driver updates
      
         - New driver subsystem, CDX, for AMD systems
      
         - lots of other small driver updates and additions
      
        All of these have been in linux-next for a while with no reported
        issues"
      
      * tag 'char-misc-6.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/char-misc: (196 commits)
        mcb-lpc: Reallocate memory region to avoid memory overlapping
        mcb-pci: Reallocate memory region to avoid memory overlapping
        mcb: Return actual parsed size when reading chameleon table
        kernel/configs: Drop Android config fragments
        virt: acrn: Replace obsolete memalign() with posix_memalign()
        spmi: Add a check for remove callback when removing a SPMI driver
        spmi: fix W=1 kernel-doc warnings
        spmi: mtk-pmif: Drop of_match_ptr for ID table
        spmi: pmic-arb: Convert to platform remove callback returning void
        spmi: mtk-pmif: Convert to platform remove callback returning void
        spmi: hisi-spmi-controller: Convert to platform remove callback returning void
        w1: gpio: remove unnecessary ENOMEM messages
        w1: omap-hdq: remove unnecessary ENOMEM messages
        w1: omap-hdq: add SPDX tag
        w1: omap-hdq: allow compile testing
        w1: matrox: remove unnecessary ENOMEM messages
        w1: matrox: use inline over __inline__
        w1: matrox: switch from asm to linux header
        w1: ds2482: do not use assignment in if condition
        w1: ds2482: drop unnecessary header
        ...
      cec24b8b
    • Linus Torvalds's avatar
      Merge tag 'driver-core-6.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/driver-core · 556eb8b7
      Linus Torvalds authored
      Pull driver core updates from Greg KH:
       "Here is the large set of driver core changes for 6.4-rc1.
      
        Once again, a busy development cycle, with lots of changes happening
        in the driver core in the quest to be able to move "struct bus" and
        "struct class" into read-only memory, a task now complete with these
        changes.
      
        This will make the future rust interactions with the driver core more
        "provably correct" as well as providing more obvious lifetime rules
        for all busses and classes in the kernel.
      
        The changes required for this did touch many individual classes and
        busses as many callbacks were changed to take const * parameters
        instead. All of these changes have been submitted to the various
        subsystem maintainers, giving them plenty of time to review, and most
        of them actually did so.
      
        Other than those changes, included in here are a small set of other
        things:
      
         - kobject logging improvements
      
         - cacheinfo improvements and updates
      
         - obligatory fw_devlink updates and fixes
      
         - documentation updates
      
         - device property cleanups and const * changes
      
         - firwmare loader dependency fixes.
      
        All of these have been in linux-next for a while with no reported
        problems"
      
      * tag 'driver-core-6.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/driver-core: (120 commits)
        device property: make device_property functions take const device *
        driver core: update comments in device_rename()
        driver core: Don't require dynamic_debug for initcall_debug probe timing
        firmware_loader: rework crypto dependencies
        firmware_loader: Strip off \n from customized path
        zram: fix up permission for the hot_add sysfs file
        cacheinfo: Add use_arch[|_cache]_info field/function
        arch_topology: Remove early cacheinfo error message if -ENOENT
        cacheinfo: Check cache properties are present in DT
        cacheinfo: Check sib_leaf in cache_leaves_are_shared()
        cacheinfo: Allow early level detection when DT/ACPI info is missing/broken
        cacheinfo: Add arm64 early level initializer implementation
        cacheinfo: Add arch specific early level initializer
        tty: make tty_class a static const structure
        driver core: class: remove struct class_interface * from callbacks
        driver core: class: mark the struct class in struct class_interface constant
        driver core: class: make class_register() take a const *
        driver core: class: mark class_release() as taking a const *
        driver core: remove incorrect comment for device_create*
        MIPS: vpe-cmp: remove module owner pointer from struct class usage.
        ...
      556eb8b7
    • Linus Torvalds's avatar
      Merge tag 'staging-6.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/staging · 97b2ff29
      Linus Torvalds authored
      Pull staging driver updates from Greg KH:
       "Here is the large set of staging driver updates for 6.4-rc1. Once
        again, we removed more code than was added, a nice trend.
      
        It was a calm cycle, mostly all just small coding style cleanups,
        included in here are:
      
         - removal of the greybus loopback testing tools, userspace code that
           didn't belong in a driver subdirectory and was causing problems for
           some build systems
      
         - platform remove callback cleanups
      
         - rtl8192e huge cleanups
      
         - other small staging driver cleanups.
      
        All of these have been in linux-next for a while with no reported
        problems"
      
      * tag 'staging-6.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/staging: (185 commits)
        staging: rtl8192e: Fix W_DISABLE# does not work after stop/start
        staging: rtl8192e: Remove unchanged variables bfsync_processing and more
        staging: rtl8192e: Remove unchanged variable frame_sync_monitor
        staging: rtl8192e: Remove unchanged variable chan_forced
        staging: rtl8192e: Remove set to true while true of bfirst_after_down
        staging: rtl8192e: Remove second initialization of bActuallySet
        staging: rtl8192e: Remove unused macro RT_SET_PS_LEVEL
        staging: rtl8192e: Remove unused function rtl92e_disable_nic
        staging: rtl8192e: Remove unchanged variable RegRfPsLevel
        staging: rtl8172: Add blank lines after declarations
        staging: rtl8192e: Remove unused variable RF_Type
        staging: rtl8192e: Remove one of two checks for hardware RTL8192SE
        staging: rtl8192e: Remove unused function _rtl92e_dm_init_wa_broadcom_iot
        staging: rtl8192e: Remove macro IS_HARDWARE_TYPE_8192SE
        staging: greybus: drop loopback test files
        staging: rtl8192e: Add blank lines after declarations
        staging: rtl8192e: avoid CamelCase <dot11RSNAStatsCCMPDecryptErrors>
        staging: rtl8192e: avoid CamelCase <dot11RSNAStatsCCMPReplays>
        staging: rtl8192e: avoid CamelCase <dot11RSNAStatsCCMPFormatErrors>
        staging: rtl8192e: fix alignment to match open parenthesis
        ...
      97b2ff29
    • Linus Torvalds's avatar
      Merge tag 'tty-6.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/tty · b39667ab
      Linus Torvalds authored
      Pull tty / serial updates from Greg KH:
       "Here is the big set of tty/serial driver updates for 6.4-rc1.
      
        Nothing major, just lots of tiny, constant, forward development. This
        includes:
      
         - obligatory n_gsm updates and feature additions
      
         - 8250_em driver updates
      
         - sh-sci driver updates
      
         - dts cleanups and updates
      
         - general cleanups and improvements by Ilpo and Jiri
      
         - other small serial driver core fixes and driver updates
      
        All of these have been in linux-next for a while with no reported
        problems"
      
      * tag 'tty-6.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/tty: (87 commits)
        n_gsm: Use array_index_nospec() with index that comes from userspace
        tty: vt: drop checks for undefined VT_SINGLE_DRIVER
        tty: vt: distribute EXPORT_SYMBOL()
        tty: vt: simplify some cases in tioclinux()
        tty: vt: reformat tioclinux()
        tty: serial: sh-sci: Fix end of transmission on SCI
        tty: serial: sh-sci: Add support for tx end interrupt handling
        tty: serial: sh-sci: Fix TE setting on SCI IP
        tty: serial: sh-sci: Add RZ/G2L SCIFA DMA rx support
        tty: serial: sh-sci: Add RZ/G2L SCIFA DMA tx support
        serial: max310x: fix IO data corruption in batched operations
        serial: core: Disable uart_start() on uart_remove_one_port()
        serial: 8250: Reinit port->pm on port specific driver unbind
        serial: 8250: Add missing wakeup event reporting
        tty: serial: fsl_lpuart: use UARTMODIR register bits for lpuart32 platform
        tty: serial: fsl_lpuart: adjust buffer length to the intended size
        serial: fix TIOCSRS485 locking
        serial: make SiFive serial drivers depend on ARCH_ symbols
        tty: synclink_gt: don't allocate and pass dummy flags
        tty: serial: simplify qcom_geni_serial_send_chunk_fifo()
        ...
      b39667ab
    • Linus Torvalds's avatar
      Merge tag 'usb-6.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/usb · 4010e62b
      Linus Torvalds authored
      Pull USB / Thunderbolt updates from Greg KH:
       "Here is the large set of USB and Thunderbolt changes for 6.4-rc1.
      
        The "biggest" thing in here is the removal of two obsolete drivers,
        u132-hcd and ftdi-elan, making this a net-removal of code overall.
      
        Other than the driver removals, included in here are:
      
         - Thunderbolt updates for new hardware and features
      
         - xhci driver updates and fixes
      
         - dwc3 driver updates and fixes
      
         - gadget core and driver updates and features added
      
         - mtu3 driver updates
      
         - dwc2 driver fixes and updates
      
         - usb-serial driver updates
      
         - typec driver updates and fixes
      
         - platform remove callback changes
      
         - dts updates and conversions
      
         - other small changes
      
        All have been in linux-next for a while with no reported problems"
      
      * tag 'usb-6.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/gregkh/usb: (177 commits)
        usb: dwc3: gadget: Refactor EP0 forced stall/restart into a separate API
        usb: dwc3: gadget: Execute gadget stop after halting the controller
        media: radio-shark: Add endpoint checks
        USB: sisusbvga: Add endpoint checks
        USB: core: Add routines for endpoint checks in old drivers
        usb: dwc3: gadget: Stall and restart EP0 if host is unresponsive
        dt-bindings: usb: snps,dwc3: Add 'snps,parkmode-disable-hs-quirk' quirk
        usb: dwc3: core: add support for disabling High-speed park mode
        dt-bindings: usb: ci-hdrc-usb2: allow multiple PHYs
        usb: mtu3: add optional clock xhci_ck and frmcnt_ck
        dt-bindings: usb: mtu3: add two optional clocks
        usb: mtu3: expose role-switch control to userspace
        usb: mtu3: unlock @mtu->lock just before giving back request
        usb: mtu3: fix kernel panic at qmu transfer done irq handler
        usb: mtu3: use boolean return value
        usb: mtu3: give back request when rx error happens
        usb: chipidea: fix missing goto in `ci_hdrc_probe`
        usb: gadget: udc: core: Prevent redundant calls to pullup
        usb: gadget: udc: core: Invoke usb_gadget_connect only when started
        usb: typec: ucsi: don't print PPM init deferred errors
        ...
      4010e62b
    • Linus Torvalds's avatar
      Merge tag 'firewire-6.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/ieee1394/linux1394 · b02847fc
      Linus Torvalds authored
      Pull firewire updates from Takashi Sakamoto:
       "The pull request includes a few changes, Its main purpose is to
        prepare for my future work by taking over maintainership from Stefan
        Richter. I have plans to work on several items; e.g. packet processing
        in workqueue context instead of tasklet.
      
        As you may be aware, the IEEE 1394 technology is outdated. However, we
        still have users. It is better to ensure a smooth transition for the
        users to shift to other categories of devices"
      
      * tag 'firewire-6.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/ieee1394/linux1394:
        firewire: init_ohci1394_dma: use correct function names in comments
        MAINTAINERS: replace maintainer of FireWire subsystem
      b02847fc
    • Linus Torvalds's avatar
      Merge tag 'for-linus-2023042601' of git://git.kernel.org/pub/scm/linux/kernel/git/hid/hid · 34da76dc
      Linus Torvalds authored
      Pull HID updates from Jiri Kosina:
      
       - import a bunch of HID selftests from out-of-tree hid-tools project
         (Benjamin Tissoires)
      
       - drastically reducing Bluetooth disconnects on hid-nintendo driven
         devices (Daniel J. Ogorchock)
      
       - lazy initialization of battery interfaces in wacom driver (Jason
         Gerecke)
      
       - generic support for all Kye tablets (David Yang)
      
       - proper rumble queue overrun handling in hid-nintendo (Daniel J.
         Ogorchock)
      
       - support for ADC measurement in logitech-hidpp driver (Bastien Nocera)
      
       - reset GPIO support in i2c-hid (Hans de Goede)
      
       - improved handling of generic "Digitizer" usage (Jason Gerecke)
      
       - support for KEY_CAMERA_FOCUS (Feng Qi)
      
       - quirks for Apple Geyser 3 and Apple Geyser 4 (Alex Henrie)
      
       - assorted functional fixes and device ID additions
      
      * tag 'for-linus-2023042601' of git://git.kernel.org/pub/scm/linux/kernel/git/hid/hid: (54 commits)
        HID: amd_sfh: Fix max supported HID devices
        HID: wacom: generic: Set battery quirk only when we see battery data
        HID: wacom: Lazy-init batteries
        HID: Ignore battery for ELAN touchscreen on ROG Flow X13 GV301RA
        HID: asus: explicitly include linux/leds.h
        HID: lg-g15: explicitly include linux/leds.h
        HID: steelseries: explicitly include linux/leds.h
        HID: apple: Set the tilde quirk flag on the Geyser 3
        HID: apple: explicitly include linux/leds.h
        HID: mcp2221: fix get and get_direction for gpio
        HID: mcp2221: fix report layout for gpio get
        HID: wacom: Set a default resolution for older tablets
        HID: i2c-hid-of: Add reset GPIO support to i2c-hid-of
        HID: i2c-hid-of: Allow using i2c-hid-of on non OF platforms
        HID: i2c-hid-of: Consistenly use dev local variable in probe()
        HID: kye: Fix rdesc for kye tablets
        HID: amd_sfh: Support for additional light sensor
        HID: amd_sfh: Handle "no sensors" enabled for SFH1.1
        HID: amd_sfh: Increase sensor command timeout for SFH1.1
        HID: amd_sfh: Correct the stop all command
        ...
      34da76dc
    • Linus Torvalds's avatar
      Merge tag 'fbdev-for-6.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/deller/linux-fbdev · 725a345b
      Linus Torvalds authored
      Pull fbdev updates from Helge Deller:
       "Nothing really exiting in here.
      
        The majority of lines changed is due to Uwe's preparation patches to
        change the return value of the .remove() callback to void.
      
        Summary:
      
         - vt_buffer.h: Fix build on alpha (Randy Dunlap)
      
         - mmp: Clock handling fix (Christophe JAILLET)
      
         - 68328fb, ps3fb, vfb: Init .owner field of struct fb_ops (Thomas
           Zimmermann)
      
         - fbdev: cg14: Convert to platform remove callback returning void
      
         - Preparation patches to convert drivers to return void in .remove()
           callback (Uwe Kleine-König)
      
         - Drop Paul Mackerras as rage128 maintainer"
      
      * tag 'fbdev-for-6.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/deller/linux-fbdev: (51 commits)
        MAINTAINERS: Remove rage128 framebuffer driver maintainer
        fbdev: vfb: Init owner field of struct fb_ops
        fbdev: ps3fb: Init owner field of struct fb_ops
        fbdev: 68328fb: Init owner field of struct fb_ops
        fbdev: mmp: Fix deferred clk handling in mmphw_probe()
        linux/vt_buffer.h: allow either builtin or modular for macros
        fbdev: xilinxfb: Convert to platform remove callback returning void
        fbdev: wmt_ge_rops: Convert to platform remove callback returning void
        fbdev: wm8505fb: Convert to platform remove callback returning void
        fbdev: vt8500lcdfb: Convert to platform remove callback returning void
        fbdev: via: Convert to platform remove callback returning void
        fbdev: vga16fb: Convert to platform remove callback returning void
        fbdev: vfb: Convert to platform remove callback returning void
        fbdev: vesafb: Convert to platform remove callback returning void
        fbdev: uvesafb: Convert to platform remove callback returning void
        fbdev: tcx: Convert to platform remove callback returning void
        fbdev: sm501fb: Convert to platform remove callback returning void
        fbdev: simplefb: Convert to platform remove callback returning void
        fbdev: sh_mobile_lcdcfb: Convert to platform remove callback returning void
        fbdev: sh7760fb: Convert to platform remove callback returning void
        ...
      725a345b
    • Linus Torvalds's avatar
      Merge tag 'i2c-for-6.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/wsa/linux · 89555eeb
      Linus Torvalds authored
      Pull i2c updates from Wolfram Sang:
       "Mostly fixes for DTs or DT handling this time. And a few driver
        bugfixes"
      
      * tag 'i2c-for-6.4-rc1' of git://git.kernel.org/pub/scm/linux/kernel/git/wsa/linux: (28 commits)
        i2c: xiic: xiic_xfer(): Fix runtime PM leak on error path
        i2c: cadence: cdns_i2c_master_xfer(): Fix runtime PM leak on error path
        i2c: omap: Improve error reporting for problems during .remove()
        i2c: cadence: Add reset controller support
        dt-bindings: i2c: cadence: Document `resets` property
        i2c: mediatek: add support for MT7981 SoC
        dt-bindings: i2c: i2c-mt65xx: add MediaTek MT7981 SoC
        dt-bindings: i2c: Drop unneeded quotes
        i2c: brcmstb: use devm_platform_ioremap_resource_byname()
        i2c: cadence: Detect maximum transfer size
        i2c: cadence: Allow to specify the FIFO depth
        dt-bindings: i2c: cadence: Document `fifo-depth` property
        i2c: xiic: Use devm_platform_get_and_ioremap_resource()
        i2c: mpc: Use i2c-scl-clk-low-timeout-us i2c property
        i2c: mpc: Use of_property_read_u32 instead of of_get_property
        dt-bindings: i2c: mpc: Mark "fsl,timeout" as deprecated
        i2c: xiic: hide OF related data for COMPILE_TEST
        i2c: synquacer: mark OF related data as maybe unused
        dt-bindings: i2c: i2c-mt65xx: Add compatible for MT6795 Helio X10
        i2c: imx: Simplify using devm_clk_get_enabled()
        ...
      89555eeb
    • Linus Torvalds's avatar
      Merge tag 'for-linus-6.4-1' of https://github.com/cminyard/linux-ipmi · d91f6a73
      Linus Torvalds authored
      Pull IPMI updates from Corey Minyard:
       "Minor bug fixes for the IPMI driver
      
        There was a bug in the SSIF driver where in certain conditions it
        could stop working.
      
        Outside of that: spelling fixes, removing some dead code, re-adding a
        missing statistic increment, and removal of register_sysctl_table()"
      
      * tag 'for-linus-6.4-1' of https://github.com/cminyard/linux-ipmi:
        ipmi:ssif: Drop if blocks with always false condition
        ipmi: fix SSIF not responding under certain cond.
        ipmi:ssif: Add send_retries increment
        char:ipmi:Fix spelling mistake "asychronously" -> "asynchronously"
        ipmi: simplify sysctl registration
        ipmi: ASPEED_BT_IPMI_BMC: select REGMAP_MMIO instead of depending on it
      d91f6a73
    • Linus Torvalds's avatar
      Merge tag 'spi-v6.4' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie/spi · fc2e58b8
      Linus Torvalds authored
      Pull spi updates from Mark Brown:
       "A fairly standard release for SPI with the exception of a change to
        the API for specifying chip selects done in preparation for supporting
        devices with more than one chip select, this required some mechanical
        changes throughout the tree which have been cooking in -next happily
        for a while.
      
        There's also a new API to allow us to support TPM chips on half duplex
        controllers.
      
        Summary:
      
         - Refactoring in preparation for supporting multiple chip selects for
           a single device, needed by some flash devices, which required a
           change in the SPI device API visible throughout the tree
      
         - Support for hardware assisted interaction with SPI TPMs on half
           duplex controllers, implemented on nVidia Tedra210 QuadSPI
      
         - Optimisation for large transfers on fsl-cpm devices
      
         - Cleanups around device property use which fix some sisues with
           fwnode
      
         - Use of both void remove() and devm_platform_.*ioremap_resource()
      
         - Support for AMD Pensando Elba, Amlogic A1, Cadence device mode,
           Intel MetorLake-S and StarFive J7110 QuadSPI"
      
      * tag 'spi-v6.4' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie/spi: (185 commits)
        spi: bcm63xx: use macro DEFINE_SIMPLE_DEV_PM_OPS
        spi: tegra210-quad: Enable TPM wait polling
        spi: Add TPM HW flow flag
        spi: bcm63xx: remove PM_SLEEP based conditional compilation
        spi: cadence-quadspi: use macro DEFINE_SIMPLE_DEV_PM_OPS
        spi: spi-cadence: Add support for Slave mode
        spi: spi-cadence: Switch to spi_controller structure
        spi: cadence-quadspi: fix suspend-resume implementations
        spi: dw: Add support for AMD Pensando Elba SoC
        spi: dw: Add AMD Pensando Elba SoC SPI Controller
        spi: cadence-quadspi: Disable the SPI before reconfiguring
        spi: cadence-quadspi: Update the read timeout based on the length
        spi: spi-loopback-test: Add module param for iteration length
        spi: add support for Amlogic A1 SPI Flash Controller
        dt-bindings: spi: add Amlogic A1 SPI controller
        spi: fsl-spi: No need to check transfer length versus word size
        spi: fsl-spi: Change mspi_apply_cpu_mode_quirks() to void
        spi: fsl-cpm: Use 16 bit mode for large transfers with even size
        spi: fsl-spi: Re-organise transfer bits_per_word adaptation
        spi: fsl-spi: Fix CPM/QE mode Litte Endian
        ...
      fc2e58b8