On Tue, May 17, 2016 at 03:20:16PM +0200, David Sterba wrote:
> On Fri, Apr 01, 2016 at 02:35:01PM +0800, Qu Wenruo wrote:
> > @@ -5815,6 +5817,23 @@ out_fail:
> >     }
> >     if (delalloc_lock)
> >             mutex_unlock(&BTRFS_I(inode)->delalloc_mutex);
> > +   /*
> > +    * The number of metadata bytes is calculated by the difference
> > +    * between outstanding_extents and reserved_extents. Sometimes though
> > +    * reserve_metadata_bytes() fails to reserve the wanted metadata bytes,
> > +    * indeed it has already done some work to reclaim metadata space, hence
> > +    * both outstanding_extents and reserved_extents would have changed and
> > +    * the bytes we try to reserve would also has changed(may be smaller).
> > +    * So here we try to reserve again. This is much useful for online
> > +    * dedupe, which will easily eat almost all meta space.
> > +    *
> > +    * XXX: Indeed here 3 is arbitrarily choosed, it's a good workaround for
> > +    * online dedupe, later we should find a better method to avoid dedupe
> > +    * enospc issue.
> > +    */
> > +   if (unlikely(ret == -ENOSPC && loops++ < 3))
> > +           goto again;
> > +
> 
> This does not seem right and needs to be addressed properly before I
> consider adding the patchset to for-next. I don't have idea how to fix
> it.

Agreed, and this sort of issue is a reason why I strongly feel we don't want
to merge this series piecemeal until we know that after everything is
complete, we can end up with a fully baked in-band dedupe implementation.

Luckily Qu says he's on it so if he posts a workable fix here my whole point
can become moot. Until then though this is exactly the type of 'fix later'
coding we need to be avoiding.
        --Mark

--
Mark Fasheh
--
To unsubscribe from this list: send the line "unsubscribe linux-btrfs" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to