On Mon, 23 Jul 2018, Matthew Wilcox wrote: > On Mon, Jul 23, 2018 at 03:42:22PM -0700, Hugh Dickins wrote: > > On Mon, 23 Jul 2018, Matthew Wilcox wrote: > > > I figured out a fix and pushed it to the 'ida' branch in > > > git://git.infradead.org/users/willy/linux-dax.git > > > > Great, thanks a lot for sorting that out so quickly. But I've cloned > > the tree and don't see today's patch, so assume you've folded the fix > > into an existing commit? If possible, please append the diff of today's > > fix to this thread so that we can try it out. Or if that's difficult, > > please at least tell which files were modified, then I can probably > > work it out from the diff of those files against mmotm. > > Sure! It's just this: > > diff --git a/lib/xarray.c b/lib/xarray.c > index 32a9c2a6a9e9..383c410997eb 100644 > --- a/lib/xarray.c > +++ b/lib/xarray.c > @@ -660,6 +660,8 @@ void xas_create_range(struct xa_state *xas) > unsigned char sibs = xas->xa_sibs; > > xas->xa_index |= ((sibs + 1) << shift) - 1; > + if (!xas_top(xas->xa_node) && xas->xa_node->shift == xas->xa_shift) > + xas->xa_offset |= sibs; > xas->xa_shift = 0; > xas->xa_sibs = 0; Yes, that's a big improvement, the huge "cp" is now fine, thank you. I've updated my xfstests tree, and tried that on mmotm with this patch. The few failures are exactly the same as on 4.18-rc6, whether mounting tmpfs as huge or not. But four of the tests, generic/{340,345,346,354} crash (oops) on 4.18-rc5-mm1 + your patch above, but pass on 4.18-rc6. That was simply with non-huge tmpfs: I just patched them out and didn't try for whether they crash with huge tmpfs too: probably they do, but that won't be very interesting until the non-huge crashes are fixed. I paid no attention to where the crashes were, I was just pressing on to skip the problem tests to get as full a run as possible, with that list of what's problematic and needs further investigation. To test non-huge tmpfs (as root), I wrap xfstests' check script as follows (you'll want to mkdir or substitute somewhere else for /xft): export FSTYP=tmpfs export DISABLE_UDF_TEST=1 export TEST_DEV=tmpfs1: export TEST_DIR=/xft export SCRATCH_DEV=tmpfs2: export SCRATCH_MNT=/mnt mount -t $FSTYP -o size=1088M $TEST_DEV $TEST_DIR || exit $? ./check "$@" # typically "-g auto" umount /xft /mnt 2>/dev/null But don't bother with "-g auto" for the moment: I have workarounds in for a few of them, generic/{027,213,449}, which we need not get into right now (without them, two of those tests can take close to forever). To test huge tmpfs (as root), I wrap xfstests' check script as: export FSTYP=tmpfs export DISABLE_UDF_TEST=1 export TEST_DEV=tmpfs1: export TEST_DIR=/xft export SCRATCH_DEV=tmpfs2: export SCRATCH_MNT=/mnt export TMPFS_MOUNT_OPTIONS="-o size=1088M,huge=always" mount -t $FSTYP $TMPFS_MOUNT_OPTIONS $TEST_DEV $TEST_DIR || exit $? ./check "$@" # typically "-g auto" umount /xft /mnt 2>/dev/null Hugh