On Wed, Feb 08, 2017 at 11:23:12AM -0800, Darrick J. Wong wrote: > > To: "Darrick J. Wong" <darrick.wong@xxxxxxxxxx>, xfs@xxxxxxxxxxx > > [list moved; cc'ing linux-xfs@xxxxxxxxxxxxxxx] > > On Wed, Feb 08, 2017 at 12:11:56PM -0700, Ross Zwisler wrote: > > I hit the following WARN_ON_ONCE() during generic/270 with xfs (passed through > > kasan_symbolize.py): > > > > run fstests generic/270 at 2017-02-08 10:56:07 > > XFS (pmem0p2): Unmounting Filesystem > > XFS (pmem0p2): DAX enabled. Warning: EXPERIMENTAL, use at your own risk > > XFS (pmem0p2): Mounting V5 Filesystem > > XFS (pmem0p2): Ending clean mount > > XFS (pmem0p2): Quotacheck needed: Please wait. > > XFS (pmem0p2): Quotacheck: Done. > > XFS (pmem0p2): xlog_verify_grant_tail: space > BBTOB(tail_blocks) > > What does xfs_info say about this fs? I guess we're not trying to use > rmap here, so there's less metadata to shove through the log. > > I'm also wondering which file are we trying to insert-range on, and > what its bmap looks like? > I reproduced this with a generic ramdisk (no DAX) and managed to get an ino via a tracepoint and a resulting bmap: # xfs_io -c "fiemap -v" /mnt/fsstress.19801/p6f/d3/d3be/d4f9/f684 /mnt/fsstress.19801/p6f/d3/d3be/d4f9/f684: EXT: FILE-OFFSET BLOCK-RANGE TOTAL FLAGS 0: [0..239]: hole 240 1: [240..391]: 794920..795071 152 0x0 2: [392..871]: hole 480 3: [872..903]: 795072..795103 32 0x0 4: [904..975]: 795104..795175 72 0x1 5: [976..1780]: hole 805 Note that this the post-shift bmap. The warning is complaining that extents 3 and 4 are contiguous and thus can be merged. This is unexpected on "insert space" (right shift) because, IIRC, we aren't creating any new extent boundaries that didn't previously exist (as opposed to collapse, which starts by punching a hole and connecting bordering extents). This isn't really a functional problem, more flagging an unexpected/non-optimal but presumably still correct state. It may be the case that the assumption of never having separate but contiguous extents is not valid and the fix is to simply kill off the warning (perhaps being at or near ENOSPC is a factor here). It's probably worth some investigation to determine why this occurs for sure, however, just in case we have a problem somewhere else... Brian > --D > > > ------------[ cut here ]------------ > > WARNING: CPU: 7 PID: 23652 at fs/xfs/libxfs/xfs_bmap.c:5981[< none >] xfs_bmse_shift_one+0x3da/0x4c0 fs/xfs/libxfs/xfs_bmap.c:5981 > > Modules linked in: dax_pmem nd_pmem dax nd_btt nd_e820 libnvdimm > > CPU: 4 PID: 23652 Comm: 23288.fsstress. Not tainted 4.10.0-rc7-00065-g926af627 #1 > > Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS 1.9.1-1.fc24 04/01/2014 > > Call Trace: > > [< inline >] __dump_stack lib/dump_stack.c:15 > > [< none >] dump_stack+0x86/0xc3 lib/dump_stack.c:51 > > [< none >] __warn+0xcb/0xf0 kernel/panic.c:547 > > [< none >] warn_slowpath_null+0x1d/0x20 kernel/panic.c:582 > > [< none >] xfs_bmse_shift_one+0x3da/0x4c0 fs/xfs/libxfs/xfs_bmap.c:5981 > > [< none >] xfs_bmap_shift_extents+0x305/0x490 fs/xfs/libxfs/xfs_bmap.c:6144 > > [< none >] xfs_shift_file_space+0x25f/0x320 fs/xfs/xfs_bmap_util.c:1475 > > [< none >] xfs_insert_file_space+0x5a/0x180 fs/xfs/xfs_bmap_util.c:1548 > > [< none >] xfs_file_fallocate+0x34c/0x3b0 fs/xfs/xfs_file.c:844 > > ?[< none >] rcu_sync_lockdep_assert+0x2f/0x60 kernel/rcu/sync.c:68 > > [< none >] vfs_fallocate+0x15a/0x230 fs/open.c:320 > > [< inline >] SYSC_fallocate fs/open.c:343 > > [< none >] SyS_fallocate+0x48/0x80 fs/open.c:337 > > [< none >] entry_SYSCALL_64_fastpath+0x1f/0xc2 /home/rzwisler/project/linux/arch/x86/entry/entry_64.S:204 > > RIP: 0033:0x7f34dc4ff0ca > > RSP: 002b:00007ffcffa58058 EFLAGS: 00000246 ORIG_RAX: 000000000000011d > > RAX: ffffffffffffffda RBX: 0000000000000166 RCX: 00007f34dc4ff0ca > > RDX: 00000000000ba000 RSI: 0000000000000020 RDI: 0000000000000003 > > RBP: 0000000000000003 R08: 000000000000007b R09: 00007ffcffa5807c > > R10: 00000000000bc000 R11: 0000000000000246 R12: 00007f34d8000de0 > > R13: 00000000ffffffff R14: 000000000000af4a R15: 0000000000000000 > > ---[ end trace e24f5d4cbfc216f6 ]--- > > > > This trace is with the current linux/master: > > > > commit 926af6273fc6 ("Merge git://git.kernel.org/pub/scm/linux/kernel/git/davem/net") > > > > though I initially his this issue with a v4.9 kernel. My test setup is a pair > > of PMEM ramdisks made with the memmap command line parameter, and my > > test filesystem is mounted with DAX. > > > > This can be reproduced pretty easily by just running generic/270 in a > > loop. > > > > Thanks, > > - Ross > -- > To unsubscribe from this list: send the line "unsubscribe linux-xfs" in > the body of a message to majordomo@xxxxxxxxxxxxxxx > More majordomo info at http://vger.kernel.org/majordomo-info.html -- To unsubscribe from this list: send the line "unsubscribe linux-xfs" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html