From: kernel test robot <oliver.sang@intel.com>
To: Leo Martins <loemra.dev@gmail.com>
Cc: <oe-lkp@lists.linux.dev>, <lkp@intel.com>,
<linux-btrfs@vger.kernel.org>, <kernel-team@fb.com>,
<oliver.sang@intel.com>
Subject: Re: [PATCH] btrfs: prevent COW amplification during btrfs_search_slot
Date: Tue, 10 Feb 2026 15:45:49 +0800 [thread overview]
Message-ID: <202602101504.f113db13-lkp@intel.com> (raw)
In-Reply-To: <ba53d279b8bb3456f61cb8a4f15d9a4b1e618d0e.1769546089.git.loemra.dev@gmail.com>
Hello,
kernel test robot noticed "INFO:trying_to_register_non-static_key" on:
commit: ba9c6f19149df060c2b7c71eaac21c394c161190 ("[PATCH] btrfs: prevent COW amplification during btrfs_search_slot")
url: https://github.com/intel-lab-lkp/linux/commits/Leo-Martins/btrfs-prevent-COW-amplification-during-btrfs_search_slot/20260128-044526
base: https://git.kernel.org/cgit/linux/kernel/git/kdave/linux.git for-next
patch link: https://lore.kernel.org/all/ba53d279b8bb3456f61cb8a4f15d9a4b1e618d0e.1769546089.git.loemra.dev@gmail.com/
patch subject: [PATCH] btrfs: prevent COW amplification during btrfs_search_slot
in testcase: perf-sanity-tests
version:
with following parameters:
perf_compiler: gcc
group: group-01
config: x86_64-rhel-9.4-bpf
compiler: gcc-14
test machine: 8 threads 1 sockets Intel(R) Core(TM) i7-7700 CPU @ 3.60GHz (Kaby Lake) with 32G memory
(please refer to attached dmesg/kmsg for entire log/backtrace)
If you fix the issue in a separate patch/commit (i.e. not just a new version of
the same patch/commit), kindly add following tags
| Reported-by: kernel test robot <oliver.sang@intel.com>
| Closes: https://lore.kernel.org/oe-lkp/202602101504.f113db13-lkp@intel.com
[ 125.965833][ T4372] INFO: trying to register non-static key.
[ 125.971503][ T4372] The code is fine but needs lockdep annotation, or maybe
[ 125.978465][ T4372] you didn't initialize this object before use?
[ 125.984560][ T4372] turning off the locking correctness validator.
[ 125.990745][ T4372] CPU: 3 UID: 0 PID: 4372 Comm: mount Tainted: G S I 6.19.0-rc7-00122-gba9c6f19149d #1 PREEMPT(full)
[ 125.990755][ T4372] Tainted: [S]=CPU_OUT_OF_SPEC, [I]=FIRMWARE_WORKAROUND
[ 125.990758][ T4372] Hardware name: Dell Inc. OptiPlex 7050/062KRH, BIOS 1.2.0 12/22/2016
[ 125.990761][ T4372] Call Trace:
[ 125.990764][ T4372] <TASK>
[ 125.990767][ T4372] dump_stack_lvl (lib/dump_stack.c:122)
[ 125.990777][ T4372] register_lock_class (kernel/locking/lockdep.c:985 kernel/locking/lockdep.c:1299)
[ 125.990784][ T4372] ? lock_release (kernel/locking/lockdep.c:470 (discriminator 4) kernel/locking/lockdep.c:5891 (discriminator 4) kernel/locking/lockdep.c:5875 (discriminator 4))
[ 125.990790][ T4372] ? __rcu_read_unlock (kernel/rcu/tree_plugin.h:441 (discriminator 1))
[ 125.990799][ T4372] __lock_acquire (kernel/locking/lockdep.c:5113)
[ 125.990809][ T4372] lock_acquire (include/linux/preempt.h:469 (discriminator 2) include/trace/events/lock.h:24 (discriminator 2) include/trace/events/lock.h:24 (discriminator 2) kernel/locking/lockdep.c:5831 (discriminator 2))
[ 125.990815][ T4372] ? xa_destroy (lib/xarray.c:2390 (discriminator 1))
[ 125.990823][ T4372] ? xa_find (include/linux/rcupdate.h:341 include/linux/rcupdate.h:897 lib/xarray.c:2202)
[ 125.990830][ T4372] ? rcu_is_watching (arch/x86/include/asm/atomic.h:23 include/linux/atomic/atomic-arch-fallback.h:457 include/linux/context_tracking.h:128 kernel/rcu/tree.c:751)
[ 125.990836][ T4372] ? lock_acquire (include/trace/events/lock.h:24 (discriminator 2) kernel/locking/lockdep.c:5831 (discriminator 2))
[ 125.990844][ T4372] _raw_spin_lock_irqsave (include/linux/spinlock_api_smp.h:111 kernel/locking/spinlock.c:162)
[ 125.990851][ T4372] ? xa_destroy (lib/xarray.c:2390 (discriminator 1))
[ 125.990858][ T4372] xa_destroy (lib/xarray.c:2390 (discriminator 1))
[ 125.990865][ T4372] ? xa_find (lib/xarray.c:2204)
[ 125.990872][ T4372] ? __pfx_xa_destroy (lib/xarray.c:2384)
[ 125.990884][ T4372] ? unlock_up (fs/btrfs/ctree.c:1427) btrfs
[ 125.991323][ T4372] btrfs_search_slot (fs/btrfs/ctree.c:2043) btrfs
[ 125.991720][ T4372] ? rcu_is_watching (arch/x86/include/asm/atomic.h:23 include/linux/atomic/atomic-arch-fallback.h:457 include/linux/context_tracking.h:128 kernel/rcu/tree.c:751)
[ 125.991732][ T4372] ? __pfx_btrfs_search_slot (fs/btrfs/ctree.c:2043) btrfs
[ 125.992150][ T4372] ? lockdep_hardirqs_on_prepare (kernel/locking/lockdep.c:4629 (discriminator 4))
[ 125.992158][ T4372] ? ___slab_alloc (arch/x86/include/asm/irqflags.h:42 arch/x86/include/asm/irqflags.h:119 arch/x86/include/asm/irqflags.h:159 mm/slub.c:4555)
[ 125.992166][ T4372] ? __pfx___mutex_lock (kernel/locking/mutex.c:775)
[ 125.992173][ T4372] ? trace_preempt_on (include/trace/events/preemptirq.h:53 (discriminator 2) kernel/trace/trace_preemptirq.c:120 (discriminator 2))
[ 125.992184][ T4372] ? kmem_cache_alloc_noprof (include/trace/events/kmem.h:12 (discriminator 2) mm/slub.c:5273 (discriminator 2))
[ 125.992191][ T4372] ? btrfs_read_chunk_tree (fs/btrfs/volumes.c:7639) btrfs
[ 125.992599][ T4372] btrfs_read_chunk_tree (fs/btrfs/volumes.c:7680) btrfs
[ 125.993066][ T4372] ? __pfx_btrfs_read_chunk_tree (fs/btrfs/volumes.c:7627) btrfs
[ 125.993473][ T4372] ? __pfx_load_super_root (fs/btrfs/disk-io.c:2617) btrfs
[ 125.993868][ T4372] ? __pfx_btrfs_read_sys_array (fs/btrfs/volumes.c:7494) btrfs
[ 125.994309][ T4372] ? __asan_memcpy (mm/kasan/shadow.c:105 (discriminator 1))
[ 125.994317][ T4372] ? read_extent_buffer (fs/btrfs/extent_io.c:3981) btrfs
[ 125.994743][ T4372] open_ctree (fs/btrfs/disk-io.c:3481) btrfs
[ 125.995173][ T4372] btrfs_fill_super.cold (fs/btrfs/super.c:981) btrfs
[ 125.995570][ T4372] btrfs_get_tree_super (fs/btrfs/super.c:1945) btrfs
[ 125.995959][ T4372] btrfs_get_tree_subvol (fs/btrfs/super.c:2087) btrfs
[ 125.996378][ T4372] vfs_get_tree (fs/super.c:1751)
[ 125.996387][ T4372] vfs_cmd_create (fs/fsopen.c:231)
[ 125.996394][ T4372] __do_sys_fsconfig (fs/fsopen.c:474)
[ 125.996401][ T4372] ? __pfx___do_sys_fsconfig (fs/fsopen.c:356)
[ 125.996411][ T4372] ? vfs_read (include/linux/sched/xacct.h:24 fs/read_write.c:579)
[ 125.996417][ T4372] ? do_syscall_64 (arch/x86/include/asm/irqflags.h:42 arch/x86/include/asm/irqflags.h:119 include/linux/entry-common.h:108 arch/x86/entry/syscall_64.c:90)
[ 125.996425][ T4372] do_syscall_64 (arch/x86/entry/syscall_64.c:63 (discriminator 1) arch/x86/entry/syscall_64.c:94 (discriminator 1))
[ 125.996431][ T4372] ? kasan_quarantine_put (arch/x86/include/asm/irqflags.h:42 arch/x86/include/asm/irqflags.h:119 arch/x86/include/asm/irqflags.h:159 mm/kasan/quarantine.c:234)
[ 125.996438][ T4372] ? lockdep_hardirqs_on_prepare (kernel/locking/lockdep.c:4629 (discriminator 4))
[ 125.996446][ T4372] ? kasan_quarantine_put (arch/x86/include/asm/irqflags.h:42 arch/x86/include/asm/irqflags.h:119 arch/x86/include/asm/irqflags.h:159 mm/kasan/quarantine.c:234)
[ 125.996453][ T4372] ? kfree (mm/slub.c:6674 (discriminator 3) mm/slub.c:6882 (discriminator 3))
[ 125.996459][ T4372] ? __do_sys_fsconfig (fs/fsopen.c:499)
[ 125.996467][ T4372] ? ksys_read (fs/read_write.c:715)
[ 125.996473][ T4372] ? __pfx_ksys_read (fs/read_write.c:705)
[ 125.996479][ T4372] ? __do_sys_fsconfig (fs/fsopen.c:499)
[ 125.996486][ T4372] ? __pfx___do_sys_fsconfig (fs/fsopen.c:356)
[ 125.996492][ T4372] ? do_syscall_64 (include/linux/irq-entry-common.h:298 include/linux/entry-common.h:196 arch/x86/entry/syscall_64.c:100)
[ 125.996499][ T4372] ? do_syscall_64 (arch/x86/entry/syscall_64.c:113)
[ 125.996505][ T4372] ? __pfx_css_rstat_updated (kernel/cgroup/rstat.c:71)
[ 125.996512][ T4372] ? do_syscall_64 (include/linux/irq-entry-common.h:298 include/linux/entry-common.h:196 arch/x86/entry/syscall_64.c:100)
[ 125.996520][ T4372] ? do_syscall_64 (arch/x86/entry/syscall_64.c:113)
[ 125.996525][ T4372] ? find_held_lock (kernel/locking/lockdep.c:5350 (discriminator 1))
[ 125.996531][ T4372] ? count_memcg_events_mm+0x91/0x170
[ 125.996539][ T4372] ? count_memcg_events_mm+0x91/0x170
[ 125.996545][ T4372] ? __lock_release+0x5d/0x1b0
[ 125.996553][ T4372] ? find_held_lock (kernel/locking/lockdep.c:5350 (discriminator 1))
[ 125.996559][ T4372] ? exc_page_fault (arch/x86/include/asm/irqflags.h:26 arch/x86/include/asm/irqflags.h:109 arch/x86/include/asm/irqflags.h:151 arch/x86/mm/fault.c:1480 arch/x86/mm/fault.c:1527)
[ 125.996567][ T4372] ? exc_page_fault (arch/x86/include/asm/irqflags.h:26 arch/x86/include/asm/irqflags.h:109 arch/x86/include/asm/irqflags.h:151 arch/x86/mm/fault.c:1480 arch/x86/mm/fault.c:1527)
[ 125.996573][ T4372] ? __lock_release+0x5d/0x1b0
[ 125.996578][ T4372] ? handle_mm_fault (mm/memory.c:6469 (discriminator 1) mm/memory.c:6609 (discriminator 1))
[ 125.996587][ T4372] ? lock_release (kernel/locking/lockdep.c:470 (discriminator 4) kernel/locking/lockdep.c:5891 (discriminator 4) kernel/locking/lockdep.c:5875 (discriminator 4))
[ 125.996594][ T4372] ? irqentry_exit (include/linux/irq-entry-common.h:298 include/linux/irq-entry-common.h:341 kernel/entry/common.c:196)
[ 125.996600][ T4372] ? trace_hardirqs_on_prepare (kernel/trace/trace_preemptirq.c:64 (discriminator 4) kernel/trace/trace_preemptirq.c:59 (discriminator 4))
[ 125.996605][ T4372] ? lockdep_hardirqs_on_prepare (kernel/locking/lockdep.c:4629 (discriminator 4))
[ 125.996612][ T4372] ? irqentry_exit (arch/x86/include/asm/jump_label.h:37 include/linux/context_tracking_state.h:138 include/linux/context_tracking.h:41 include/linux/irq-entry-common.h:301 include/linux/irq-entry-common.h:341 kernel/entry/common.c:196)
[ 125.996619][ T4372] entry_SYSCALL_64_after_hwframe (arch/x86/entry/entry_64.S:131)
[ 125.996625][ T4372] RIP: 0033:0x7f169cce04aa
[ 125.996652][ T4372] Code: 73 01 c3 48 8b 0d 4e 59 0d 00 f7 d8 64 89 01 48 83 c8 ff c3 66 2e 0f 1f 84 00 00 00 00 00 66 90 49 89 ca b8 af 01 00 00 0f 05 <48> 3d 01 f0 ff ff 73 01 c3 48 8b 0d 1e 59 0d 00 f7 d8 64 89 01 48
All code
========
0: 73 01 jae 0x3
2: c3 ret
3: 48 8b 0d 4e 59 0d 00 mov 0xd594e(%rip),%rcx # 0xd5958
a: f7 d8 neg %eax
c: 64 89 01 mov %eax,%fs:(%rcx)
f: 48 83 c8 ff or $0xffffffffffffffff,%rax
13: c3 ret
14: 66 2e 0f 1f 84 00 00 cs nopw 0x0(%rax,%rax,1)
1b: 00 00 00
1e: 66 90 xchg %ax,%ax
20: 49 89 ca mov %rcx,%r10
23: b8 af 01 00 00 mov $0x1af,%eax
28: 0f 05 syscall
2a:* 48 3d 01 f0 ff ff cmp $0xfffffffffffff001,%rax <-- trapping instruction
30: 73 01 jae 0x33
32: c3 ret
33: 48 8b 0d 1e 59 0d 00 mov 0xd591e(%rip),%rcx # 0xd5958
3a: f7 d8 neg %eax
3c: 64 89 01 mov %eax,%fs:(%rcx)
3f: 48 rex.W
Code starting with the faulting instruction
===========================================
0: 48 3d 01 f0 ff ff cmp $0xfffffffffffff001,%rax
6: 73 01 jae 0x9
8: c3 ret
9: 48 8b 0d 1e 59 0d 00 mov 0xd591e(%rip),%rcx # 0xd592e
10: f7 d8 neg %eax
12: 64 89 01 mov %eax,%fs:(%rcx)
15: 48 rex.W
The kernel config and materials to reproduce are available at:
https://download.01.org/0day-ci/archive/20260210/202602101504.f113db13-lkp@intel.com
--
0-DAY CI Kernel Test Service
https://github.com/intel/lkp-tests/wiki
prev parent reply other threads:[~2026-02-10 7:46 UTC|newest]
Thread overview: 21+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-01-27 20:42 [PATCH] btrfs: prevent COW amplification during btrfs_search_slot Leo Martins
2026-01-28 21:48 ` Qu Wenruo
2026-01-29 19:30 ` Leo Martins
2026-01-29 11:52 ` Filipe Manana
2026-01-30 0:12 ` Leo Martins
2026-01-30 4:14 ` Sun YangKai
2026-01-30 9:37 ` Sun YangKai
2026-01-30 15:50 ` Sun YangKai
2026-01-30 16:11 ` Filipe Manana
2026-01-31 9:16 ` Sun YangKai
2026-01-30 12:49 ` Filipe Manana
2026-01-30 15:43 ` Boris Burkov
2026-01-30 15:57 ` Filipe Manana
2026-02-03 1:09 ` Leo Martins
2026-01-30 21:43 ` Leo Martins
2026-01-30 22:34 ` Qu Wenruo
2026-01-31 0:11 ` Boris Burkov
2026-01-31 1:06 ` Qu Wenruo
2026-01-31 17:16 ` Boris Burkov
2026-01-31 21:59 ` Qu Wenruo
2026-02-10 7:45 ` kernel test robot [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=202602101504.f113db13-lkp@intel.com \
--to=oliver.sang@intel.com \
--cc=kernel-team@fb.com \
--cc=linux-btrfs@vger.kernel.org \
--cc=lkp@intel.com \
--cc=loemra.dev@gmail.com \
--cc=oe-lkp@lists.linux.dev \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.