• Josef Bacik's avatar
    Btrfs: fix btrfs_remove_from_free_space corner case · 6606bb97
    Josef Bacik authored
    Yan Zheng hit a problem where we tried to remove some free space but failed
    because we couldn't find the free space entry.  This is because the free space
    was held within a bitmap that had a starting offset well before the actual
    offset of the free space, and there were free space extents that were in the
    same range as that offset, so tree_search_offset returned with NULL because we
    couldn't find a free space extent that had that offset.  This is fixed by
    making sure that if we fail to find the entry, we re-search again with
    bitmap_only set to 1 and do an offset_to_bitmap so we can get the appropriate
    bitmap.  A similar problem happens in btrfs_alloc_from_bitmap for the
    clustering code, but that is not as bad since we will just go and redo our
    cluster allocation.
    
    Also this adds some debugging checks to make sure that the free space we are
    trying to remove from the bitmap is in fact there.  This can probably go away
    after a while, but since this code is only used by the tree-logging stuff it
    would be nice to run with it for a while to make sure there are no problems.
    Signed-off-by: default avatarJosef Bacik <jbacik@redhat.com>
    Signed-off-by: default avatarChris Mason <chris.mason@oracle.com>
    6606bb97
free-space-cache.c 34 KB