diff options
author | Josef Bacik <josef@redhat.com> | 2011-09-22 14:30:02 -0400 |
---|---|---|
committer | Josef Bacik <josef@redhat.com> | 2011-10-19 15:12:47 -0400 |
commit | ef3be45722317f8c2fb0e861065df0c3830ff9ac (patch) | |
tree | 961c8bd9a36943c08d0302dd77b8bb512387956a /fs | |
parent | a8c9e5769718d47e87cce40c9b84cab421804797 (diff) | |
download | blackbird-op-linux-ef3be45722317f8c2fb0e861065df0c3830ff9ac.tar.gz blackbird-op-linux-ef3be45722317f8c2fb0e861065df0c3830ff9ac.zip |
Btrfs: check unused against how much space we actually want
There is a bug that may lead to early ENOSPC in our reservation code. We've
been checking against num_bytes which may be above and beyond what we want to
actually reserve, which could give us a false ENOSPC. Fix this by making sure
the unused space is above how much we want to reserve and not how much we're
trying to flush. Thanks,
Signed-off-by: Josef Bacik <josef@redhat.com>
Diffstat (limited to 'fs')
-rw-r--r-- | fs/btrfs/extent-tree.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/fs/btrfs/extent-tree.c b/fs/btrfs/extent-tree.c index 5498bdacd4c3..fd65f6bc676c 100644 --- a/fs/btrfs/extent-tree.c +++ b/fs/btrfs/extent-tree.c @@ -3472,7 +3472,7 @@ again: */ if (unused <= space_info->total_bytes) { unused = space_info->total_bytes - unused; - if (unused >= num_bytes) { + if (unused >= orig_bytes) { space_info->bytes_may_use += orig_bytes; ret = 0; } else { |