Commit 9e5de354 authored by Artem Bityutskiy's avatar Artem Bityutskiy

UBIFS: push empty flash hack down

We have a hack which forces the amount of flash space to be
equivalent to 'c->blocks_cnt' in case of empty FS. This is
to make users happy and see '%0' used in 'df' when they
mount an empty FS. This hack is not needed in
'ubifs_calc_available()', but it is only needed the caller,
in 'ubifs_budg_get_free_space()'. So push it down there.
Signed-off-by: default avatarArtem Bityutskiy <Artem.Bityutskiy@nokia.com>
parent 8191e1fa
...@@ -302,18 +302,6 @@ long long ubifs_calc_available(const struct ubifs_info *c, int min_idx_lebs) ...@@ -302,18 +302,6 @@ long long ubifs_calc_available(const struct ubifs_info *c, int min_idx_lebs)
int subtract_lebs; int subtract_lebs;
long long available; long long available;
/*
* Force the amount available to the total size reported if the used
* space is zero.
*/
if (c->lst.total_used <= UBIFS_INO_NODE_SZ &&
c->budg_data_growth + c->budg_dd_growth == 0) {
/* Do the same calculation as for c->block_cnt */
available = c->main_lebs - 2;
available *= c->leb_size - c->dark_wm;
return available;
}
available = c->main_bytes - c->lst.total_used; available = c->main_bytes - c->lst.total_used;
/* /*
...@@ -739,8 +727,18 @@ long long ubifs_budg_get_free_space(struct ubifs_info *c) ...@@ -739,8 +727,18 @@ long long ubifs_budg_get_free_space(struct ubifs_info *c)
return 0; return 0;
} }
available = ubifs_calc_available(c, min_idx_lebs);
outstanding = c->budg_data_growth + c->budg_dd_growth; outstanding = c->budg_data_growth + c->budg_dd_growth;
/*
* Force the amount available to the total size reported if the used
* space is zero.
*/
if (c->lst.total_used <= UBIFS_INO_NODE_SZ && !outstanding) {
spin_unlock(&c->space_lock);
return (long long)c->block_cnt << UBIFS_BLOCK_SHIFT;
}
available = ubifs_calc_available(c, min_idx_lebs);
spin_unlock(&c->space_lock); spin_unlock(&c->space_lock);
if (available > outstanding) if (available > outstanding)
......
...@@ -649,8 +649,6 @@ static int init_constants_late(struct ubifs_info *c) ...@@ -649,8 +649,6 @@ static int init_constants_late(struct ubifs_info *c)
* *
* Subtract the LEB reserved for GC and the LEB which is reserved for * Subtract the LEB reserved for GC and the LEB which is reserved for
* deletions. * deletions.
*
* Review 'ubifs_calc_available()' if changing this calculation.
*/ */
tmp64 = c->main_lebs - 2; tmp64 = c->main_lebs - 2;
tmp64 *= (uint64_t)c->leb_size - c->dark_wm; tmp64 *= (uint64_t)c->leb_size - c->dark_wm;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment