[Bug 283391] [fusefs] fuse_internal_cache_attrs: 0xfffff801e6e51898 is not exclusive locked but should be

From: <bugzilla-noreply_at_freebsd.org>
Date: Tue, 17 Dec 2024 20:26:44 UTC
https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=283391

            Bug ID: 283391
           Summary: [fusefs] fuse_internal_cache_attrs: 0xfffff801e6e51898
                    is not exclusive locked but should be
           Product: Base System
           Version: 15.0-CURRENT
          Hardware: Any
                OS: Any
            Status: New
          Severity: Affects Only Me
          Priority: ---
         Component: kern
          Assignee: bugs@FreeBSD.org
          Reporter: asomers@FreeBSD.org

Incorrect locking in fusefs can lead to a panic, but only when DEBUG_VFS_LOCKS
is set in the kernel configuration.  So far the only path I know that can
trigger this panic is to come through CTL.

Steps to Reproduce
==================
$ pkg install -y fusefs-ext2
$ truncate -s 1g /tmp/ext2.img
$ mkfs.ext2 /tmp/ext2.img
$ sudo fuse-ext2 -o default_permissions,allow_other,rw+ /tmp/ext2.img /tmp/mnt
$ sudo truncate -s 1m /tmp/mnt/file
$ sudo ctladm create -b block -o file=/tmp/mnt/file
LUN created successfully
backend:       block
device type:   0
LUN size:      1048576 bytes
blocksize      512 bytes
LUN ID:        0
Serial Number: MYSERIAL0000
Device ID:     MYDEVID0000
$ sudo ctladm port -o on -p 0

That's usually enough to trigger the bug, but it may be necessary to read the
resulting device file, too.

Stack Trace
===========
KDB: stack backtrace:
db_trace_self_wrapper() at db_trace_self_wrapper+0x2b/frame 0xfffffe00da0c4a40
assert_vop_elocked() at assert_vop_elocked+0x56/frame 0xfffffe00da0c4a70
fuse_internal_cache_attrs() at fuse_internal_cache_attrs+0x47/frame
0xfffffe00da0c4ad0
fuse_internal_do_getattr() at fuse_internal_do_getattr+0x156/frame
0xfffffe00da0c4b80
fuse_vnode_size() at fuse_vnode_size+0x70/frame 0xfffffe00da0c4bd0
fuse_read_biobackend() at fuse_read_biobackend+0x56/frame 0xfffffe00da0c4c60
fuse_vnop_read() at fuse_vnop_read+0x12d/frame 0xfffffe00da0c4cc0
VOP_READ_APV() at VOP_READ_APV+0x96/frame 0xfffffe00da0c4cf0
ctl_be_block_dispatch_file() at ctl_be_block_dispatch_file+0x271/frame
0xfffffe00da0c4d90
ctl_be_block_worker() at ctl_be_block_worker+0xdab/frame 0xfffffe00da0c4e40
taskqueue_run_locked() at taskqueue_run_locked+0x1c2/frame 0xfffffe00da0c4ec0
taskqueue_thread_loop() at taskqueue_thread_loop+0xd3/frame 0xfffffe00da0c4ef0
fork_exit() at fork_exit+0xc7/frame 0xfffffe00da0c4f30
fork_trampoline() at fork_trampoline+0xe/frame 0xfffffe00da0c4f30
--- trap 0x2d0a6873, rip = 0x2038373030363372, rsp = 0x7720200a222f6461, rbp =
0x617020200a303632 ---
vnode 0xfffff80003af5528: type VREG state VSTATE_CONSTRUCTED op
0xffffffff82a23848
    usecount 1, writecount 1, refcount 1 seqc users 0
    hold count flags ()
    flags (VMP_LAZYLIST)
    v_object 0xfffff80005d70e70 ref 0 pages 0 cleanbuf 0 dirtybuf 0
    lock type fuse: SHARED (count 1)
nodeid: 3, parent nodeid: 0, nlookup: 2, flag: 0x2000
fuse_internal_cache_attrs: 0xfffff80003af5528 is not exclusive locked but
should be
KDB: enter: lock violation

-- 
You are receiving this mail because:
You are the assignee for the bug.