1. 11 Jun, 2024 6 commits
    • Jiri Olsa's avatar
      uprobe: Add uretprobe syscall to speed up return probe · ff474a78
      Jiri Olsa authored
      Adding uretprobe syscall instead of trap to speed up return probe.
      
      At the moment the uretprobe setup/path is:
      
        - install entry uprobe
      
        - when the uprobe is hit, it overwrites probed function's return address
          on stack with address of the trampoline that contains breakpoint
          instruction
      
        - the breakpoint trap code handles the uretprobe consumers execution and
          jumps back to original return address
      
      This patch replaces the above trampoline's breakpoint instruction with new
      ureprobe syscall call. This syscall does exactly the same job as the trap
      with some more extra work:
      
        - syscall trampoline must save original value for rax/r11/rcx registers
          on stack - rax is set to syscall number and r11/rcx are changed and
          used by syscall instruction
      
        - the syscall code reads the original values of those registers and
          restore those values in task's pt_regs area
      
        - only caller from trampoline exposed in '[uprobes]' is allowed,
          the process will receive SIGILL signal otherwise
      
      Even with some extra work, using the uretprobes syscall shows speed
      improvement (compared to using standard breakpoint):
      
        On Intel (11th Gen Intel(R) Core(TM) i7-1165G7 @ 2.80GHz)
      
        current:
          uretprobe-nop  :    1.498 ± 0.000M/s
          uretprobe-push :    1.448 ± 0.001M/s
          uretprobe-ret  :    0.816 ± 0.001M/s
      
        with the fix:
          uretprobe-nop  :    1.969 ± 0.002M/s  < 31% speed up
          uretprobe-push :    1.910 ± 0.000M/s  < 31% speed up
          uretprobe-ret  :    0.934 ± 0.000M/s  < 14% speed up
      
        On Amd (AMD Ryzen 7 5700U)
      
        current:
          uretprobe-nop  :    0.778 ± 0.001M/s
          uretprobe-push :    0.744 ± 0.001M/s
          uretprobe-ret  :    0.540 ± 0.001M/s
      
        with the fix:
          uretprobe-nop  :    0.860 ± 0.001M/s  < 10% speed up
          uretprobe-push :    0.818 ± 0.001M/s  < 10% speed up
          uretprobe-ret  :    0.578 ± 0.000M/s  <  7% speed up
      
      The performance test spawns a thread that runs loop which triggers
      uprobe with attached bpf program that increments the counter that
      gets printed in results above.
      
      The uprobe (and uretprobe) kind is determined by which instruction
      is being patched with breakpoint instruction. That's also important
      for uretprobes, because uprobe is installed for each uretprobe.
      
      The performance test is part of bpf selftests:
        tools/testing/selftests/bpf/run_bench_uprobes.sh
      
      Note at the moment uretprobe syscall is supported only for native
      64-bit process, compat process still uses standard breakpoint.
      
      Note that when shadow stack is enabled the uretprobe syscall returns
      via iret, which is slower than return via sysret, but won't cause the
      shadow stack violation.
      
      Link: https://lore.kernel.org/all/20240611112158.40795-4-jolsa@kernel.org/Suggested-by: default avatarAndrii Nakryiko <andrii@kernel.org>
      Reviewed-by: default avatarOleg Nesterov <oleg@redhat.com>
      Reviewed-by: default avatarMasami Hiramatsu (Google) <mhiramat@kernel.org>
      Acked-by: default avatarAndrii Nakryiko <andrii@kernel.org>
      Signed-off-by: default avatarOleg Nesterov <oleg@redhat.com>
      Signed-off-by: default avatarJiri Olsa <jolsa@kernel.org>
      Signed-off-by: default avatarMasami Hiramatsu (Google) <mhiramat@kernel.org>
      ff474a78
    • Jiri Olsa's avatar
      uprobe: Wire up uretprobe system call · 190fec72
      Jiri Olsa authored
      Wiring up uretprobe system call, which comes in following changes.
      We need to do the wiring before, because the uretprobe implementation
      needs the syscall number.
      
      Note at the moment uretprobe syscall is supported only for native
      64-bit process.
      
      Link: https://lore.kernel.org/all/20240611112158.40795-3-jolsa@kernel.org/Reviewed-by: default avatarOleg Nesterov <oleg@redhat.com>
      Reviewed-by: default avatarMasami Hiramatsu (Google) <mhiramat@kernel.org>
      Acked-by: default avatarAndrii Nakryiko <andrii@kernel.org>
      Signed-off-by: default avatarJiri Olsa <jolsa@kernel.org>
      Signed-off-by: default avatarMasami Hiramatsu (Google) <mhiramat@kernel.org>
      190fec72
    • Jiri Olsa's avatar
      x86/shstk: Make return uprobe work with shadow stack · 1713b63a
      Jiri Olsa authored
      Currently the application with enabled shadow stack will crash
      if it sets up return uprobe. The reason is the uretprobe kernel
      code changes the user space task's stack, but does not update
      shadow stack accordingly.
      
      Adding new functions to update values on shadow stack and using
      them in uprobe code to keep shadow stack in sync with uretprobe
      changes to user stack.
      
      Link: https://lore.kernel.org/all/20240611112158.40795-2-jolsa@kernel.org/Acked-by: default avatarAndrii Nakryiko <andrii@kernel.org>
      Acked-by: default avatarRick Edgecombe <rick.p.edgecombe@intel.com>
      Reviewed-by: default avatarOleg Nesterov <oleg@redhat.com>
      Fixes: 488af8ea ("x86/shstk: Wire in shadow stack interface")
      Signed-off-by: default avatarJiri Olsa <jolsa@kernel.org>
      Signed-off-by: default avatarMasami Hiramatsu (Google) <mhiramat@kernel.org>
      1713b63a
    • Jeff Johnson's avatar
      samples: kprobes: add missing MODULE_DESCRIPTION() macros · 1b3c86ee
      Jeff Johnson authored
      make allmodconfig && make W=1 C=1 reports:
      WARNING: modpost: missing MODULE_DESCRIPTION() in samples/kprobes/kprobe_example.o
      WARNING: modpost: missing MODULE_DESCRIPTION() in samples/kprobes/kretprobe_example.o
      
      Add the missing invocations of the MODULE_DESCRIPTION() macro.
      
      Link: https://lore.kernel.org/all/20240601-md-samples-kprobes-v1-1-b6a772353893@quicinc.com/Signed-off-by: default avatarJeff Johnson <quic_jjohnson@quicinc.com>
      Signed-off-by: default avatarMasami Hiramatsu (Google) <mhiramat@kernel.org>
      1b3c86ee
    • Jeff Johnson's avatar
      fprobe: add missing MODULE_DESCRIPTION() macro · df216f57
      Jeff Johnson authored
      make allmodconfig && make W=1 C=1 reports:
      WARNING: modpost: missing MODULE_DESCRIPTION() in samples/fprobe/fprobe_example.o
      
      Add the missing invocation of the MODULE_DESCRIPTION() macro.
      
      Link: https://lore.kernel.org/all/20240601-md-samples-fprobe-v1-1-5d256a956612@quicinc.com/Signed-off-by: default avatarJeff Johnson <quic_jjohnson@quicinc.com>
      Signed-off-by: default avatarMasami Hiramatsu (Google) <mhiramat@kernel.org>
      df216f57
    • Masami Hiramatsu (Google)'s avatar
      tracing: Build event generation tests only as modules · 3572bd56
      Masami Hiramatsu (Google) authored
      The kprobes and synth event generation test modules add events and lock
      (get a reference) those event file reference in module init function,
      and unlock and delete it in module exit function. This is because those
      are designed for playing as modules.
      
      If we make those modules as built-in, those events are left locked in the
      kernel, and never be removed. This causes kprobe event self-test failure
      as below.
      
      [   97.349708] ------------[ cut here ]------------
      [   97.353453] WARNING: CPU: 3 PID: 1 at kernel/trace/trace_kprobe.c:2133 kprobe_trace_self_tests_init+0x3f1/0x480
      [   97.357106] Modules linked in:
      [   97.358488] CPU: 3 PID: 1 Comm: swapper/0 Not tainted 6.9.0-g69964673-dirty #14
      [   97.361556] Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS 1.15.0-1 04/01/2014
      [   97.363880] RIP: 0010:kprobe_trace_self_tests_init+0x3f1/0x480
      [   97.365538] Code: a8 24 08 82 e9 ae fd ff ff 90 0f 0b 90 48 c7 c7 e5 aa 0b 82 e9 ee fc ff ff 90 0f 0b 90 48 c7 c7 2d 61 06 82 e9 8e fd ff ff 90 <0f> 0b 90 48 c7 c7 33 0b 0c 82 89 c6 e8 6e 03 1f ff 41 ff c7 e9 90
      [   97.370429] RSP: 0000:ffffc90000013b50 EFLAGS: 00010286
      [   97.371852] RAX: 00000000fffffff0 RBX: ffff888005919c00 RCX: 0000000000000000
      [   97.373829] RDX: ffff888003f40000 RSI: ffffffff8236a598 RDI: ffff888003f40a68
      [   97.375715] RBP: 0000000000000000 R08: 0000000000000001 R09: 0000000000000000
      [   97.377675] R10: ffffffff811c9ae5 R11: ffffffff8120c4e0 R12: 0000000000000000
      [   97.379591] R13: 0000000000000001 R14: 0000000000000015 R15: 0000000000000000
      [   97.381536] FS:  0000000000000000(0000) GS:ffff88807dcc0000(0000) knlGS:0000000000000000
      [   97.383813] CS:  0010 DS: 0000 ES: 0000 CR0: 0000000080050033
      [   97.385449] CR2: 0000000000000000 CR3: 0000000002244000 CR4: 00000000000006b0
      [   97.387347] DR0: 0000000000000000 DR1: 0000000000000000 DR2: 0000000000000000
      [   97.389277] DR3: 0000000000000000 DR6: 00000000fffe0ff0 DR7: 0000000000000400
      [   97.391196] Call Trace:
      [   97.391967]  <TASK>
      [   97.392647]  ? __warn+0xcc/0x180
      [   97.393640]  ? kprobe_trace_self_tests_init+0x3f1/0x480
      [   97.395181]  ? report_bug+0xbd/0x150
      [   97.396234]  ? handle_bug+0x3e/0x60
      [   97.397311]  ? exc_invalid_op+0x1a/0x50
      [   97.398434]  ? asm_exc_invalid_op+0x1a/0x20
      [   97.399652]  ? trace_kprobe_is_busy+0x20/0x20
      [   97.400904]  ? tracing_reset_all_online_cpus+0x15/0x90
      [   97.402304]  ? kprobe_trace_self_tests_init+0x3f1/0x480
      [   97.403773]  ? init_kprobe_trace+0x50/0x50
      [   97.404972]  do_one_initcall+0x112/0x240
      [   97.406113]  do_initcall_level+0x95/0xb0
      [   97.407286]  ? kernel_init+0x1a/0x1a0
      [   97.408401]  do_initcalls+0x3f/0x70
      [   97.409452]  kernel_init_freeable+0x16f/0x1e0
      [   97.410662]  ? rest_init+0x1f0/0x1f0
      [   97.411738]  kernel_init+0x1a/0x1a0
      [   97.412788]  ret_from_fork+0x39/0x50
      [   97.413817]  ? rest_init+0x1f0/0x1f0
      [   97.414844]  ret_from_fork_asm+0x11/0x20
      [   97.416285]  </TASK>
      [   97.417134] irq event stamp: 13437323
      [   97.418376] hardirqs last  enabled at (13437337): [<ffffffff8110bc0c>] console_unlock+0x11c/0x150
      [   97.421285] hardirqs last disabled at (13437370): [<ffffffff8110bbf1>] console_unlock+0x101/0x150
      [   97.423838] softirqs last  enabled at (13437366): [<ffffffff8108e17f>] handle_softirqs+0x23f/0x2a0
      [   97.426450] softirqs last disabled at (13437393): [<ffffffff8108e346>] __irq_exit_rcu+0x66/0xd0
      [   97.428850] ---[ end trace 0000000000000000 ]---
      
      And also, since we can not cleanup dynamic_event file, ftracetest are
      failed too.
      
      To avoid these issues, build these tests only as modules.
      
      Link: https://lore.kernel.org/all/171811263754.85078.5877446624311852525.stgit@devnote2/
      
      Fixes: 9fe41efa ("tracing: Add synth event generation test module")
      Fixes: 64836248 ("tracing: Add kprobe event command generation test module")
      Signed-off-by: default avatarMasami Hiramatsu (Google) <mhiramat@kernel.org>
      Reviewed-by: default avatarSteven Rostedt (Google) <rostedt@goodmis.org>
      3572bd56
  2. 09 Jun, 2024 5 commits
    • Linus Torvalds's avatar
      Linux 6.10-rc3 · 83a7eefe
      Linus Torvalds authored
      83a7eefe
    • Linus Torvalds's avatar
      Merge tag 'perf-tools-fixes-for-v6.10-2-2024-06-09' of... · b8481381
      Linus Torvalds authored
      Merge tag 'perf-tools-fixes-for-v6.10-2-2024-06-09' of git://git.kernel.org/pub/scm/linux/kernel/git/perf/perf-tools
      
      Pull perf tools fixes from Arnaldo Carvalho de Melo:
      
       - Update copies of kernel headers, which resulted in support for the
         new 'mseal' syscall, SUBVOL statx return mask bit, RISC-V and PPC
         prctls, fcntl's DUPFD_QUERY, POSTED_MSI_NOTIFICATION IRQ vector,
         'map_shadow_stack' syscall for x86-32.
      
       - Revert perf.data record memory allocation optimization that ended up
         causing a regression, work is being done to re-introduce it in the
         next merge window.
      
       - Fix handling of minimal vmlinux.h file used with BPF's CO-RE when
         interrupting the build.
      
      * tag 'perf-tools-fixes-for-v6.10-2-2024-06-09' of git://git.kernel.org/pub/scm/linux/kernel/git/perf/perf-tools:
        perf bpf: Fix handling of minimal vmlinux.h file when interrupting the build
        Revert "perf record: Reduce memory for recording PERF_RECORD_LOST_SAMPLES event"
        tools headers arm64: Sync arm64's cputype.h with the kernel sources
        tools headers uapi: Sync linux/stat.h with the kernel sources to pick STATX_SUBVOL
        tools headers UAPI: Update i915_drm.h with the kernel sources
        tools headers UAPI: Sync kvm headers with the kernel sources
        tools arch x86: Sync the msr-index.h copy with the kernel sources
        tools headers: Update the syscall tables and unistd.h, mostly to support the new 'mseal' syscall
        perf trace beauty: Update the arch/x86/include/asm/irq_vectors.h copy with the kernel sources to pick POSTED_MSI_NOTIFICATION
        perf beauty: Update copy of linux/socket.h with the kernel sources
        tools headers UAPI: Sync fcntl.h with the kernel sources to pick F_DUPFD_QUERY
        tools headers UAPI: Sync linux/prctl.h with the kernel sources
        tools include UAPI: Sync linux/stat.h with the kernel sources
      b8481381
    • Linus Torvalds's avatar
      Merge tag 'edac_urgent_for_v6.10_rc3' of git://git.kernel.org/pub/scm/linux/kernel/git/ras/ras · 637c2dfc
      Linus Torvalds authored
      Pull EDAC fixes from Borislav Petkov:
      
       - Convert PCI core error codes to proper error numbers since latter get
         propagated all the way up to the module loading functions
      
      * tag 'edac_urgent_for_v6.10_rc3' of git://git.kernel.org/pub/scm/linux/kernel/git/ras/ras:
        EDAC/igen6: Convert PCIBIOS_* return codes to errnos
        EDAC/amd64: Convert PCIBIOS_* return codes to errnos
      637c2dfc
    • Linus Torvalds's avatar
      Merge tag 'clk-fixes-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/clk/linux · 771ed661
      Linus Torvalds authored
      Pull clk fix from Stephen Boyd:
       "One fix for the SiFive PRCI clocks so that the device boots again.
      
        This driver was registering clkdev lookups that were always going to
        be useless. This wasn't a problem until clkdev started returning an
        error in these cases, causing this driver to fail probe, and thus boot
        to fail because clks are essential for most drivers. The fix is
        simple, don't use clkdev because this is a DT based system where
        clkdev isn't used"
      
      * tag 'clk-fixes-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/clk/linux:
        clk: sifive: Do not register clkdevs for PRCI clocks
      771ed661
    • Linus Torvalds's avatar
      Merge tag '6.10-rc2-smb3-client-fixes' of git://git.samba.org/sfrench/cifs-2.6 · c5dbc2ed
      Linus Torvalds authored
      Pull smb client fixes from Steve French:
       "Two small smb3 client fixes:
      
         - fix deadlock in umount
      
         - minor cleanup due to netfs change"
      
      * tag '6.10-rc2-smb3-client-fixes' of git://git.samba.org/sfrench/cifs-2.6:
        cifs: Don't advance the I/O iterator before terminating subrequest
        smb: client: fix deadlock in smb2_find_smb_tcon()
      c5dbc2ed
  3. 08 Jun, 2024 8 commits
    • Linus Torvalds's avatar
      Merge tag 'for-linus-2024060801' of git://git.kernel.org/pub/scm/linux/kernel/git/hid/hid · 061d1af7
      Linus Torvalds authored
      Pull HID fixes from Benjamin Tissoires:
      
       - fix potential read out of bounds in hid-asus (Andrew Ballance)
      
       - fix endian-conversion on little endian systems in intel-ish-hid (Arnd
         Bergmann)
      
       - A couple of new input event codes (Aseda Aboagye)
      
       - errors handling fixes in hid-nvidia-shield (Chen Ni), hid-nintendo
         (Christophe JAILLET), hid-logitech-dj (José Expósito)
      
       - current leakage fix while the device is in suspend on a i2c-hid
         laptop (Johan Hovold)
      
       - other assorted smaller fixes and device ID / quirk entry additions
      
      * tag 'for-linus-2024060801' of git://git.kernel.org/pub/scm/linux/kernel/git/hid/hid:
        HID: Ignore battery for ELAN touchscreens 2F2C and 4116
        HID: i2c-hid: elan: fix reset suspend current leakage
        dt-bindings: HID: i2c-hid: elan: add 'no-reset-on-power-off' property
        dt-bindings: HID: i2c-hid: elan: add Elan eKTH5015M
        dt-bindings: HID: i2c-hid: add dedicated Ilitek ILI2901 schema
        input: Add support for "Do Not Disturb"
        input: Add event code for accessibility key
        hid: asus: asus_report_fixup: fix potential read out of bounds
        HID: logitech-hidpp: add missing MODULE_DESCRIPTION() macro
        HID: intel-ish-hid: fix endian-conversion
        HID: nintendo: Fix an error handling path in nintendo_hid_probe()
        HID: logitech-dj: Fix memory leak in logi_dj_recv_switch_to_dj_mode()
        HID: core: remove unnecessary WARN_ON() in implement()
        HID: nvidia-shield: Add missing check for input_ff_create_memless
        HID: intel-ish-hid: Fix build error for COMPILE_TEST
      061d1af7
    • Linus Torvalds's avatar
      Merge tag 'kbuild-fixes-v6.10-2' of... · 329f70c5
      Linus Torvalds authored
      Merge tag 'kbuild-fixes-v6.10-2' of git://git.kernel.org/pub/scm/linux/kernel/git/masahiroy/linux-kbuild
      
      Pull Kbuild fixes from Masahiro Yamada:
      
       - Fix the initial state of the save button in 'make gconfig'
      
       - Improve the Kconfig documentation
      
       - Fix a Kconfig bug regarding property visibility
      
       - Fix build breakage for systems where 'sed' is not installed in /bin
      
       - Fix a false warning about missing MODULE_DESCRIPTION()
      
      * tag 'kbuild-fixes-v6.10-2' of git://git.kernel.org/pub/scm/linux/kernel/git/masahiroy/linux-kbuild:
        modpost: do not warn about missing MODULE_DESCRIPTION() for vmlinux.o
        kbuild: explicitly run mksysmap as sed script from link-vmlinux.sh
        kconfig: remove wrong expr_trans_bool()
        kconfig: doc: document behavior of 'select' and 'imply' followed by 'if'
        kconfig: doc: fix a typo in the note about 'imply'
        kconfig: gconf: give a proper initial state to the Save button
        kconfig: remove unneeded code for user-supplied values being out of range
      329f70c5
    • Linus Torvalds's avatar
      Merge tag 'media/v6.10-2' of git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-media · 1e7ccdd3
      Linus Torvalds authored
      Pull media fixes from Mauro Carvalho Chehab:
      
       - fixes for the new ipu6 driver (and related fixes to mei csi driver)
      
       - fix a double debugfs remove logic at mgb4 driver
      
       - a documentation fix
      
      * tag 'media/v6.10-2' of git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/linux-media:
        media: intel/ipu6: add csi2 port sanity check in notifier bound
        media: intel/ipu6: update the maximum supported csi2 port number to 6
        media: mei: csi: Warn less verbosely of a missing device fwnode
        media: mei: csi: Put the IPU device reference
        media: intel/ipu6: fix the buffer flags caused by wrong parentheses
        media: intel/ipu6: Fix an error handling path in isys_probe()
        media: intel/ipu6: Move isys_remove() close to isys_probe()
        media: intel/ipu6: Fix some redundant resources freeing in ipu6_pci_remove()
        media: Documentation: v4l: Fix ACTIVE route flag
        media: mgb4: Fix double debugfs remove
      1e7ccdd3
    • Linus Torvalds's avatar
      Merge tag 'irq-urgent-2024-06-08' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · 36714d69
      Linus Torvalds authored
      Pull irq fixes from Ingo Molnar:
      
       - Fix possible memory leak the riscv-intc irqchip driver load failures
      
       - Fix boot crash in the sifive-plic irqchip driver caused by recently
         changed boot initialization order
      
       - Fix race condition in the gic-v3-its irqchip driver
      
      * tag 'irq-urgent-2024-06-08' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        irqchip/gic-v3-its: Fix potential race condition in its_vlpi_prop_update()
        irqchip/sifive-plic: Chain to parent IRQ after handlers are ready
        irqchip/riscv-intc: Prevent memory leak when riscv_intc_init_common() fails
      36714d69
    • Linus Torvalds's avatar
      Merge tag 'x86-urgent-2024-06-08' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · 7cedb020
      Linus Torvalds authored
      Pull x86 fixes from Ingo Molnar:
       "Miscellaneous fixes:
      
         - Fix kexec() crash if call depth tracking is enabled
      
         - Fix SMN reads on inaccessible registers on certain AMD systems"
      
      * tag 'x86-urgent-2024-06-08' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        x86/amd_nb: Check for invalid SMN reads
        x86/kexec: Fix bug with call depth tracking
      7cedb020
    • Linus Torvalds's avatar
      Merge tag 'perf-urgent-2024-06-08' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · 7cec2e16
      Linus Torvalds authored
      Pull perf event fix from Ingo Molnar:
       "Fix race between perf_event_free_task() and perf_event_release_kernel()
        that can result in missed wakeups and hung tasks"
      
      * tag 'perf-urgent-2024-06-08' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        perf/core: Fix missing wakeup when waiting for context reference
      7cec2e16
    • Linus Torvalds's avatar
      Merge tag 'locking-urgent-2024-06-08' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip · bbc5332b
      Linus Torvalds authored
      Pull locking doc fix from Ingo Molnar:
       "Fix typos in the kerneldoc of some of the atomic APIs"
      
      * tag 'locking-urgent-2024-06-08' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
        locking/atomic: scripts: fix ${atomic}_sub_and_test() kerneldoc
      bbc5332b
    • Linus Torvalds's avatar
      Merge tag 'mm-hotfixes-stable-2024-06-07-15-24' of... · dc772f82
      Linus Torvalds authored
      Merge tag 'mm-hotfixes-stable-2024-06-07-15-24' of git://git.kernel.org/pub/scm/linux/kernel/git/akpm/mm
      
      Pull misc fixes from Andrew Morton:
       "14 hotfixes, 6 of which are cc:stable.
      
        All except the nilfs2 fix affect MM and all are singletons - see the
        chagelogs for details"
      
      * tag 'mm-hotfixes-stable-2024-06-07-15-24' of git://git.kernel.org/pub/scm/linux/kernel/git/akpm/mm:
        nilfs2: fix nilfs_empty_dir() misjudgment and long loop on I/O errors
        mm: fix xyz_noprof functions calling profiled functions
        codetag: avoid race at alloc_slab_obj_exts
        mm/hugetlb: do not call vma_add_reservation upon ENOMEM
        mm/ksm: fix ksm_zero_pages accounting
        mm/ksm: fix ksm_pages_scanned accounting
        kmsan: do not wipe out origin when doing partial unpoisoning
        vmalloc: check CONFIG_EXECMEM in is_vmalloc_or_module_addr()
        mm: page_alloc: fix highatomic typing in multi-block buddies
        nilfs2: fix potential kernel bug due to lack of writeback flag waiting
        memcg: remove the lockdep assert from __mod_objcg_mlstate()
        mm: arm64: fix the out-of-bounds issue in contpte_clear_young_dirty_ptes
        mm: huge_mm: fix undefined reference to `mthp_stats' for CONFIG_SYSFS=n
        mm: drop the 'anon_' prefix for swap-out mTHP counters
      dc772f82
  4. 07 Jun, 2024 21 commits