balloc.c 22.2 KB
Newer Older
1
/*
2
 *  linux/fs/ext4/balloc.c
3 4 5 6 7 8 9 10 11 12 13 14 15 16
 *
 * Copyright (C) 1992, 1993, 1994, 1995
 * Remy Card (card@masi.ibp.fr)
 * Laboratoire MASI - Institut Blaise Pascal
 * Universite Pierre et Marie Curie (Paris VI)
 *
 *  Enhanced block allocation by Stephen Tweedie (sct@redhat.com), 1993
 *  Big-endian to little-endian byte-swapping/bitmaps by
 *        David S. Miller (davem@caip.rutgers.edu), 1995
 */

#include <linux/time.h>
#include <linux/capability.h>
#include <linux/fs.h>
17
#include <linux/jbd2.h>
18 19
#include <linux/quotaops.h>
#include <linux/buffer_head.h>
20 21
#include "ext4.h"
#include "ext4_jbd2.h"
A
Andreas Dilger 已提交
22
#include "group.h"
23
#include "mballoc.h"
24

25 26 27 28
/*
 * balloc.c contains the blocks allocation and deallocation routines
 */

29 30 31 32
/*
 * Calculate the block group number and offset, given a block number
 */
void ext4_get_group_no_and_offset(struct super_block *sb, ext4_fsblk_t blocknr,
33
		ext4_group_t *blockgrpp, ext4_grpblk_t *offsetp)
34
{
D
Dave Kleikamp 已提交
35
	struct ext4_super_block *es = EXT4_SB(sb)->s_es;
36 37
	ext4_grpblk_t offset;

D
Dave Kleikamp 已提交
38
	blocknr = blocknr - le32_to_cpu(es->s_first_data_block);
A
Andrew Morton 已提交
39
	offset = do_div(blocknr, EXT4_BLOCKS_PER_GROUP(sb));
40 41 42
	if (offsetp)
		*offsetp = offset;
	if (blockgrpp)
D
Dave Kleikamp 已提交
43
		*blockgrpp = blocknr;
44 45 46

}

47 48 49 50
static int ext4_block_in_group(struct super_block *sb, ext4_fsblk_t block,
			ext4_group_t block_group)
{
	ext4_group_t actual_group;
A
Aneesh Kumar K.V 已提交
51
	ext4_get_group_no_and_offset(sb, block, &actual_group, NULL);
52 53 54 55 56 57
	if (actual_group == block_group)
		return 1;
	return 0;
}

static int ext4_group_used_meta_blocks(struct super_block *sb,
58 59
				       ext4_group_t block_group,
				       struct ext4_group_desc *gdp)
60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83
{
	ext4_fsblk_t tmp;
	struct ext4_sb_info *sbi = EXT4_SB(sb);
	/* block bitmap, inode bitmap, and inode table blocks */
	int used_blocks = sbi->s_itb_per_group + 2;

	if (EXT4_HAS_INCOMPAT_FEATURE(sb, EXT4_FEATURE_INCOMPAT_FLEX_BG)) {
		if (!ext4_block_in_group(sb, ext4_block_bitmap(sb, gdp),
					block_group))
			used_blocks--;

		if (!ext4_block_in_group(sb, ext4_inode_bitmap(sb, gdp),
					block_group))
			used_blocks--;

		tmp = ext4_inode_table(sb, gdp);
		for (; tmp < ext4_inode_table(sb, gdp) +
				sbi->s_itb_per_group; tmp++) {
			if (!ext4_block_in_group(sb, tmp, block_group))
				used_blocks -= 1;
		}
	}
	return used_blocks;
}
84

A
Andreas Dilger 已提交
85 86 87
/* Initializes an uninitialized block bitmap if given, and returns the
 * number of blocks free in the group. */
unsigned ext4_init_block_bitmap(struct super_block *sb, struct buffer_head *bh,
88
		 ext4_group_t block_group, struct ext4_group_desc *gdp)
A
Andreas Dilger 已提交
89 90 91 92 93 94 95 96 97 98 99
{
	int bit, bit_max;
	unsigned free_blocks, group_blocks;
	struct ext4_sb_info *sbi = EXT4_SB(sb);

	if (bh) {
		J_ASSERT_BH(bh, buffer_locked(bh));

		/* If checksum is bad mark all blocks used to prevent allocation
		 * essentially implementing a per-group read-only flag. */
		if (!ext4_group_desc_csum_verify(sbi, block_group, gdp)) {
100
			ext4_error(sb, __func__,
101
				  "Checksum bad for group %u", block_group);
102 103 104
			ext4_free_blks_set(sb, gdp, 0);
			ext4_free_inodes_set(sb, gdp, 0);
			ext4_itable_unused_set(sb, gdp, 0);
A
Andreas Dilger 已提交
105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122
			memset(bh->b_data, 0xff, sb->s_blocksize);
			return 0;
		}
		memset(bh->b_data, 0, sb->s_blocksize);
	}

	/* Check for superblock and gdt backups in this group */
	bit_max = ext4_bg_has_super(sb, block_group);

	if (!EXT4_HAS_INCOMPAT_FEATURE(sb, EXT4_FEATURE_INCOMPAT_META_BG) ||
	    block_group < le32_to_cpu(sbi->s_es->s_first_meta_bg) *
			  sbi->s_desc_per_block) {
		if (bit_max) {
			bit_max += ext4_bg_num_gdb(sb, block_group);
			bit_max +=
				le16_to_cpu(sbi->s_es->s_reserved_gdt_blocks);
		}
	} else { /* For META_BG_BLOCK_GROUPS */
123
		bit_max += ext4_bg_num_gdb(sb, block_group);
A
Andreas Dilger 已提交
124 125 126 127 128 129 130 131 132 133
	}

	if (block_group == sbi->s_groups_count - 1) {
		/*
		 * Even though mke2fs always initialize first and last group
		 * if some other tool enabled the EXT4_BG_BLOCK_UNINIT we need
		 * to make sure we calculate the right free blocks
		 */
		group_blocks = ext4_blocks_count(sbi->s_es) -
			le32_to_cpu(sbi->s_es->s_first_data_block) -
134
			(EXT4_BLOCKS_PER_GROUP(sb) * (sbi->s_groups_count - 1));
A
Andreas Dilger 已提交
135 136 137 138 139 140 141
	} else {
		group_blocks = EXT4_BLOCKS_PER_GROUP(sb);
	}

	free_blocks = group_blocks - bit_max;

	if (bh) {
142 143
		ext4_fsblk_t start, tmp;
		int flex_bg = 0;
144

A
Andreas Dilger 已提交
145 146 147
		for (bit = 0; bit < bit_max; bit++)
			ext4_set_bit(bit, bh->b_data);

148
		start = ext4_group_first_block_no(sb, block_group);
A
Andreas Dilger 已提交
149

150 151 152
		if (EXT4_HAS_INCOMPAT_FEATURE(sb,
					      EXT4_FEATURE_INCOMPAT_FLEX_BG))
			flex_bg = 1;
A
Andreas Dilger 已提交
153

154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169
		/* Set bits for block and inode bitmaps, and inode table */
		tmp = ext4_block_bitmap(sb, gdp);
		if (!flex_bg || ext4_block_in_group(sb, tmp, block_group))
			ext4_set_bit(tmp - start, bh->b_data);

		tmp = ext4_inode_bitmap(sb, gdp);
		if (!flex_bg || ext4_block_in_group(sb, tmp, block_group))
			ext4_set_bit(tmp - start, bh->b_data);

		tmp = ext4_inode_table(sb, gdp);
		for (; tmp < ext4_inode_table(sb, gdp) +
				sbi->s_itb_per_group; tmp++) {
			if (!flex_bg ||
				ext4_block_in_group(sb, tmp, block_group))
				ext4_set_bit(tmp - start, bh->b_data);
		}
A
Andreas Dilger 已提交
170 171 172 173 174 175 176
		/*
		 * Also if the number of blocks within the group is
		 * less than the blocksize * 8 ( which is the size
		 * of bitmap ), set rest of the block bitmap to 1
		 */
		mark_bitmap_end(group_blocks, sb->s_blocksize * 8, bh->b_data);
	}
177
	return free_blocks - ext4_group_used_meta_blocks(sb, block_group, gdp);
A
Andreas Dilger 已提交
178 179 180
}


181 182 183 184 185 186 187 188
/*
 * The free blocks are managed by bitmaps.  A file system contains several
 * blocks groups.  Each group contains 1 bitmap block for blocks, 1 bitmap
 * block for inodes, N blocks for the inode table and data blocks.
 *
 * The file system contains group descriptors which are located after the
 * super block.  Each descriptor contains the number of the bitmap block and
 * the free blocks count in the block.  The descriptors are loaded in memory
189
 * when a file system is mounted (see ext4_fill_super).
190 191 192 193 194 195
 */


#define in_range(b, first, len)	((b) >= (first) && (b) <= (first) + (len) - 1)

/**
196
 * ext4_get_group_desc() -- load group descriptor from disk
197 198 199 200 201
 * @sb:			super block
 * @block_group:	given block group
 * @bh:			pointer to the buffer head to store the block
 *			group descriptor
 */
202
struct ext4_group_desc * ext4_get_group_desc(struct super_block *sb,
203
					     ext4_group_t block_group,
204
					     struct buffer_head **bh)
205
{
206 207
	unsigned int group_desc;
	unsigned int offset;
208
	struct ext4_group_desc *desc;
209
	struct ext4_sb_info *sbi = EXT4_SB(sb);
210 211

	if (block_group >= sbi->s_groups_count) {
212 213
		ext4_error(sb, "ext4_get_group_desc",
			   "block_group >= groups_count - "
214
			   "block_group = %u, groups_count = %u",
215
			   block_group, sbi->s_groups_count);
216 217 218 219 220

		return NULL;
	}
	smp_rmb();

221 222
	group_desc = block_group >> EXT4_DESC_PER_BLOCK_BITS(sb);
	offset = block_group & (EXT4_DESC_PER_BLOCK(sb) - 1);
223
	if (!sbi->s_group_desc[group_desc]) {
224 225
		ext4_error(sb, "ext4_get_group_desc",
			   "Group descriptor not loaded - "
226
			   "block_group = %u, group_desc = %u, desc = %u",
227
			   block_group, group_desc, offset);
228 229 230
		return NULL;
	}

231 232 233
	desc = (struct ext4_group_desc *)(
		(__u8 *)sbi->s_group_desc[group_desc]->b_data +
		offset * EXT4_DESC_SIZE(sb));
234 235
	if (bh)
		*bh = sbi->s_group_desc[group_desc];
236
	return desc;
237 238
}

239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284
static int ext4_valid_block_bitmap(struct super_block *sb,
					struct ext4_group_desc *desc,
					unsigned int block_group,
					struct buffer_head *bh)
{
	ext4_grpblk_t offset;
	ext4_grpblk_t next_zero_bit;
	ext4_fsblk_t bitmap_blk;
	ext4_fsblk_t group_first_block;

	if (EXT4_HAS_INCOMPAT_FEATURE(sb, EXT4_FEATURE_INCOMPAT_FLEX_BG)) {
		/* with FLEX_BG, the inode/block bitmaps and itable
		 * blocks may not be in the group at all
		 * so the bitmap validation will be skipped for those groups
		 * or it has to also read the block group where the bitmaps
		 * are located to verify they are set.
		 */
		return 1;
	}
	group_first_block = ext4_group_first_block_no(sb, block_group);

	/* check whether block bitmap block number is set */
	bitmap_blk = ext4_block_bitmap(sb, desc);
	offset = bitmap_blk - group_first_block;
	if (!ext4_test_bit(offset, bh->b_data))
		/* bad block bitmap */
		goto err_out;

	/* check whether the inode bitmap block number is set */
	bitmap_blk = ext4_inode_bitmap(sb, desc);
	offset = bitmap_blk - group_first_block;
	if (!ext4_test_bit(offset, bh->b_data))
		/* bad block bitmap */
		goto err_out;

	/* check whether the inode table block number is set */
	bitmap_blk = ext4_inode_table(sb, desc);
	offset = bitmap_blk - group_first_block;
	next_zero_bit = ext4_find_next_zero_bit(bh->b_data,
				offset + EXT4_SB(sb)->s_itb_per_group,
				offset);
	if (next_zero_bit >= offset + EXT4_SB(sb)->s_itb_per_group)
		/* good bitmap for inode tables */
		return 1;

err_out:
285
	ext4_error(sb, __func__,
286 287 288 289 290
			"Invalid block bitmap - "
			"block_group = %d, block = %llu",
			block_group, bitmap_blk);
	return 0;
}
291
/**
292
 * ext4_read_block_bitmap()
293 294 295
 * @sb:			super block
 * @block_group:	given block group
 *
296 297
 * Read the bitmap for a given block_group,and validate the
 * bits for block/inode/inode tables are set in the bitmaps
298 299 300
 *
 * Return buffer_head on success or NULL in case of failure.
 */
A
Andreas Dilger 已提交
301
struct buffer_head *
302
ext4_read_block_bitmap(struct super_block *sb, ext4_group_t block_group)
303
{
304 305
	struct ext4_group_desc *desc;
	struct buffer_head *bh = NULL;
306
	ext4_fsblk_t bitmap_blk;
307

A
Andreas Dilger 已提交
308
	desc = ext4_get_group_desc(sb, block_group, NULL);
309
	if (!desc)
310 311
		return NULL;
	bitmap_blk = ext4_block_bitmap(sb, desc);
312 313
	bh = sb_getblk(sb, bitmap_blk);
	if (unlikely(!bh)) {
314
		ext4_error(sb, __func__,
315
			    "Cannot read block bitmap - "
316
			    "block_group = %u, block_bitmap = %llu",
317
			    block_group, bitmap_blk);
318 319
		return NULL;
	}
320 321

	if (bitmap_uptodate(bh))
322 323
		return bh;

324
	lock_buffer(bh);
325 326 327 328
	if (bitmap_uptodate(bh)) {
		unlock_buffer(bh);
		return bh;
	}
329
	spin_lock(sb_bgl_lock(EXT4_SB(sb), block_group));
A
Andreas Dilger 已提交
330
	if (desc->bg_flags & cpu_to_le16(EXT4_BG_BLOCK_UNINIT)) {
331
		ext4_init_block_bitmap(sb, bh, block_group, desc);
332
		set_bitmap_uptodate(bh);
333
		set_buffer_uptodate(bh);
334
		spin_unlock(sb_bgl_lock(EXT4_SB(sb), block_group));
A
Aneesh Kumar K.V 已提交
335
		unlock_buffer(bh);
336
		return bh;
A
Andreas Dilger 已提交
337
	}
338
	spin_unlock(sb_bgl_lock(EXT4_SB(sb), block_group));
339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354
	if (buffer_uptodate(bh)) {
		/*
		 * if not uninit if bh is uptodate,
		 * bitmap is also uptodate
		 */
		set_bitmap_uptodate(bh);
		unlock_buffer(bh);
		return bh;
	}
	/*
	 * submit the buffer_head for read. We can
	 * safely mark the bitmap as uptodate now.
	 * We do it here so the bitmap uptodate bit
	 * get set with buffer lock held.
	 */
	set_bitmap_uptodate(bh);
355 356
	if (bh_submit_read(bh) < 0) {
		put_bh(bh);
357
		ext4_error(sb, __func__,
358
			    "Cannot read block bitmap - "
359
			    "block_group = %u, block_bitmap = %llu",
360
			    block_group, bitmap_blk);
361 362
		return NULL;
	}
363 364 365 366 367
	ext4_valid_block_bitmap(sb, desc, block_group, bh);
	/*
	 * file system mounted not to panic on error,
	 * continue with corrupt bitmap
	 */
368 369 370 371
	return bh;
}

/**
372
 * ext4_add_groupblocks() -- Add given blocks to an existing group
373 374
 * @handle:			handle to this transaction
 * @sb:				super block
375
 * @block:			start physcial block to add to the block group
376
 * @count:			number of blocks to free
377
 *
378 379 380
 * This marks the blocks as free in the bitmap. We ask the
 * mballoc to reload the buddy after this by setting group
 * EXT4_GROUP_INFO_NEED_INIT_BIT flag
381
 */
382 383
void ext4_add_groupblocks(handle_t *handle, struct super_block *sb,
			 ext4_fsblk_t block, unsigned long count)
384 385 386
{
	struct buffer_head *bitmap_bh = NULL;
	struct buffer_head *gd_bh;
387
	ext4_group_t block_group;
388
	ext4_grpblk_t bit;
389
	unsigned int i;
390 391
	struct ext4_group_desc *desc;
	struct ext4_super_block *es;
392
	struct ext4_sb_info *sbi;
393
	int err = 0, ret, blk_free_count;
394 395
	ext4_grpblk_t blocks_freed;
	struct ext4_group_info *grp;
396

397
	sbi = EXT4_SB(sb);
398
	es = sbi->s_es;
399
	ext4_debug("Adding block(s) %llu-%llu\n", block, block + count - 1);
400

401
	ext4_get_group_no_and_offset(sb, block, &block_group, &bit);
402
	grp = ext4_get_group_info(sb, block_group);
403 404 405 406
	/*
	 * Check to see if we are freeing blocks across a group
	 * boundary.
	 */
407
	if (bit + count > EXT4_BLOCKS_PER_GROUP(sb)) {
408
		goto error_return;
409
	}
410
	bitmap_bh = ext4_read_block_bitmap(sb, block_group);
411 412
	if (!bitmap_bh)
		goto error_return;
413
	desc = ext4_get_group_desc(sb, block_group, &gd_bh);
414 415 416
	if (!desc)
		goto error_return;

417 418 419 420
	if (in_range(ext4_block_bitmap(sb, desc), block, count) ||
	    in_range(ext4_inode_bitmap(sb, desc), block, count) ||
	    in_range(block, ext4_inode_table(sb, desc), sbi->s_itb_per_group) ||
	    in_range(block + count - 1, ext4_inode_table(sb, desc),
421
		     sbi->s_itb_per_group)) {
422 423
		ext4_error(sb, __func__,
			   "Adding blocks in system zones - "
424 425
			   "Block = %llu, count = %lu",
			   block, count);
426 427
		goto error_return;
	}
428 429

	/*
430
	 * We are about to add blocks to the bitmap,
431 432 433
	 * so we need undo access.
	 */
	BUFFER_TRACE(bitmap_bh, "getting undo access");
434
	err = ext4_journal_get_undo_access(handle, bitmap_bh);
435 436 437 438 439 440 441 442 443
	if (err)
		goto error_return;

	/*
	 * We are about to modify some metadata.  Call the journal APIs
	 * to unshare ->b_data if a currently-committing transaction is
	 * using it
	 */
	BUFFER_TRACE(gd_bh, "get_write_access");
444
	err = ext4_journal_get_write_access(handle, gd_bh);
445 446
	if (err)
		goto error_return;
447 448 449 450 451
	/*
	 * make sure we don't allow a parallel init on other groups in the
	 * same buddy cache
	 */
	down_write(&grp->alloc_sem);
452
	for (i = 0, blocks_freed = 0; i < count; i++) {
453
		BUFFER_TRACE(bitmap_bh, "clear bit");
454
		if (!ext4_clear_bit_atomic(sb_bgl_lock(sbi, block_group),
455
						bit + i, bitmap_bh->b_data)) {
456
			ext4_error(sb, __func__,
457
				   "bit already cleared for block %llu",
L
Laurent Vivier 已提交
458
				   (ext4_fsblk_t)(block + i));
459 460
			BUFFER_TRACE(bitmap_bh, "bit already cleared");
		} else {
461
			blocks_freed++;
462 463 464
		}
	}
	spin_lock(sb_bgl_lock(sbi, block_group));
465 466
	blk_free_count = blocks_freed + ext4_free_blks_count(sb, desc);
	ext4_free_blks_set(sb, desc, blk_free_count);
A
Andreas Dilger 已提交
467
	desc->bg_checksum = ext4_group_desc_csum(sbi, block_group, desc);
468
	spin_unlock(sb_bgl_lock(sbi, block_group));
469
	percpu_counter_add(&sbi->s_freeblocks_counter, blocks_freed);
470

471 472
	if (sbi->s_log_groups_per_flex) {
		ext4_group_t flex_group = ext4_flex_group(sbi, block_group);
473 474
		atomic_add(blocks_freed,
			   &sbi->s_flex_groups[flex_group].free_blocks);
475
	}
476 477 478 479 480 481 482
	/*
	 * request to reload the buddy with the
	 * new bitmap information
	 */
	set_bit(EXT4_GROUP_INFO_NEED_INIT_BIT, &(grp->bb_state));
	ext4_mb_update_group_info(grp, blocks_freed);
	up_write(&grp->alloc_sem);
483

484 485
	/* We dirtied the bitmap block */
	BUFFER_TRACE(bitmap_bh, "dirtied bitmap block");
486
	err = ext4_handle_dirty_metadata(handle, NULL, bitmap_bh);
487 488 489

	/* And the group descriptor block */
	BUFFER_TRACE(gd_bh, "dirtied group descriptor block");
490
	ret = ext4_handle_dirty_metadata(handle, NULL, gd_bh);
491 492
	if (!err)
		err = ret;
493
	sb->s_dirt = 1;
494

495 496
error_return:
	brelse(bitmap_bh);
497
	ext4_std_error(sb, err);
498 499 500 501
	return;
}

/**
502
 * ext4_free_blocks() -- Free given blocks and update quota
503 504 505 506
 * @handle:		handle for this transaction
 * @inode:		inode
 * @block:		start physical block to free
 * @count:		number of blocks to count
507
 * @metadata: 		Are these metadata blocks
508
 */
509
void ext4_free_blocks(handle_t *handle, struct inode *inode,
510 511
			ext4_fsblk_t block, unsigned long count,
			int metadata)
512
{
513
	struct super_block *sb;
514 515
	unsigned long dquot_freed_blocks;

516 517
	/* this isn't the right place to decide whether block is metadata
	 * inode.c/extents.c knows better, but for safety ... */
518 519 520 521 522 523 524 525 526 527
	if (S_ISDIR(inode->i_mode) || S_ISLNK(inode->i_mode))
		metadata = 1;

	/* We need to make sure we don't reuse
	 * block released untill the transaction commit.
	 * writeback mode have weak data consistency so
	 * don't force data as metadata when freeing block
	 * for writeback mode.
	 */
	if (metadata == 0 && !ext4_should_writeback_data(inode))
528 529
		metadata = 1;

530
	sb = inode->i_sb;
531

532 533
	ext4_mb_free_blocks(handle, inode, block, count,
			    metadata, &dquot_freed_blocks);
534
	if (dquot_freed_blocks)
535
		vfs_dq_free_block(inode, dquot_freed_blocks);
536 537 538
	return;
}

539 540 541 542 543 544 545 546 547
/**
 * ext4_has_free_blocks()
 * @sbi:	in-core super block structure.
 * @nblocks:	number of needed blocks
 *
 * Check if filesystem has nblocks free & available for allocation.
 * On success return 1, return 0 on failure.
 */
int ext4_has_free_blocks(struct ext4_sb_info *sbi, s64 nblocks)
548
{
549
	s64 free_blocks, dirty_blocks, root_blocks;
550
	struct percpu_counter *fbc = &sbi->s_freeblocks_counter;
551
	struct percpu_counter *dbc = &sbi->s_dirtyblocks_counter;
552

553 554
	free_blocks  = percpu_counter_read_positive(fbc);
	dirty_blocks = percpu_counter_read_positive(dbc);
555
	root_blocks = ext4_r_blocks_count(sbi->s_es);
556

557 558
	if (free_blocks - (nblocks + root_blocks + dirty_blocks) <
						EXT4_FREEBLOCKS_WATERMARK) {
559 560
		free_blocks  = percpu_counter_sum_positive(fbc);
		dirty_blocks = percpu_counter_sum_positive(dbc);
561 562 563
		if (dirty_blocks < 0) {
			printk(KERN_CRIT "Dirty block accounting "
					"went wrong %lld\n",
564
					(long long)dirty_blocks);
565 566 567
		}
	}
	/* Check whether we have space after
568
	 * accounting for current dirty blocks & root reserved blocks.
569
	 */
570 571
	if (free_blocks >= ((root_blocks + nblocks) + dirty_blocks))
		return 1;
572

573
	/* Hm, nope.  Are (enough) root reserved blocks available? */
574
	if (sbi->s_resuid == current_fsuid() ||
575 576 577 578 579 580 581
	    ((sbi->s_resgid != 0) && in_group_p(sbi->s_resgid)) ||
	    capable(CAP_SYS_RESOURCE)) {
		if (free_blocks >= (nblocks + dirty_blocks))
			return 1;
	}

	return 0;
582 583
}

584
int ext4_claim_free_blocks(struct ext4_sb_info *sbi,
A
Aneesh Kumar K.V 已提交
585
						s64 nblocks)
586
{
587 588
	if (ext4_has_free_blocks(sbi, nblocks)) {
		percpu_counter_add(&sbi->s_dirtyblocks_counter, nblocks);
589
		return 0;
590 591
	} else
		return -ENOSPC;
592
}
593

594
/**
595
 * ext4_should_retry_alloc()
596 597 598
 * @sb:			super block
 * @retries		number of attemps has been made
 *
599
 * ext4_should_retry_alloc() is called when ENOSPC is returned, and if
600 601 602 603 604 605
 * it is profitable to retry the operation, this function will wait
 * for the current or commiting transaction to complete, and then
 * return TRUE.
 *
 * if the total number of retries exceed three times, return FALSE.
 */
606
int ext4_should_retry_alloc(struct super_block *sb, int *retries)
607
{
608 609 610
	if (!ext4_has_free_blocks(EXT4_SB(sb), 1) ||
	    (*retries)++ > 3 ||
	    !EXT4_SB(sb)->s_journal)
611 612 613 614
		return 0;

	jbd_debug(1, "%s: retrying operation after ENOSPC\n", sb->s_id);

615
	return jbd2_journal_force_commit_nested(EXT4_SB(sb)->s_journal);
616 617
}

A
Aneesh Kumar K.V 已提交
618
/*
619
 * ext4_new_meta_blocks() -- allocate block for meta data (indexing) blocks
A
Aneesh Kumar K.V 已提交
620 621 622 623
 *
 * @handle:             handle to this transaction
 * @inode:              file inode
 * @goal:               given target block(filesystem wide)
T
Theodore Ts'o 已提交
624
 * @count:		pointer to total number of blocks needed
A
Aneesh Kumar K.V 已提交
625 626
 * @errp:               error code
 *
T
Theodore Ts'o 已提交
627
 * Return 1st allocated block number on success, *count stores total account
628
 * error stores in errp pointer
A
Aneesh Kumar K.V 已提交
629
 */
630 631
ext4_fsblk_t ext4_new_meta_blocks(handle_t *handle, struct inode *inode,
		ext4_fsblk_t goal, unsigned long *count, int *errp)
A
Aneesh Kumar K.V 已提交
632
{
T
Theodore Ts'o 已提交
633
	struct ext4_allocation_request ar;
634
	ext4_fsblk_t ret;
T
Theodore Ts'o 已提交
635 636 637 638 639 640 641 642 643 644 645

	memset(&ar, 0, sizeof(ar));
	/* Fill with neighbour allocated blocks */
	ar.inode = inode;
	ar.goal = goal;
	ar.len = count ? *count : 1;

	ret = ext4_mb_new_blocks(handle, &ar, errp);
	if (count)
		*count = ar.len;

646 647 648
	/*
	 * Account for the allocated meta blocks
	 */
649
	if (!(*errp) && EXT4_I(inode)->i_delalloc_reserved_flag) {
650
		spin_lock(&EXT4_I(inode)->i_block_reservation_lock);
T
Theodore Ts'o 已提交
651
		EXT4_I(inode)->i_allocated_meta_blocks += ar.len;
652 653 654
		spin_unlock(&EXT4_I(inode)->i_block_reservation_lock);
	}
	return ret;
A
Aneesh Kumar K.V 已提交
655 656
}

657
/**
658
 * ext4_count_free_blocks() -- count filesystem free blocks
659 660 661 662
 * @sb:		superblock
 *
 * Adds up the number of free blocks from each block group.
 */
663
ext4_fsblk_t ext4_count_free_blocks(struct super_block *sb)
664
{
665 666
	ext4_fsblk_t desc_count;
	struct ext4_group_desc *gdp;
667 668
	ext4_group_t i;
	ext4_group_t ngroups = EXT4_SB(sb)->s_groups_count;
669 670 671
#ifdef EXT4FS_DEBUG
	struct ext4_super_block *es;
	ext4_fsblk_t bitmap_count;
672
	unsigned int x;
673 674
	struct buffer_head *bitmap_bh = NULL;

675
	es = EXT4_SB(sb)->s_es;
676 677 678 679 680 681
	desc_count = 0;
	bitmap_count = 0;
	gdp = NULL;

	smp_rmb();
	for (i = 0; i < ngroups; i++) {
682
		gdp = ext4_get_group_desc(sb, i, NULL);
683 684
		if (!gdp)
			continue;
685
		desc_count += ext4_free_blks_count(sb, gdp);
686
		brelse(bitmap_bh);
687
		bitmap_bh = ext4_read_block_bitmap(sb, i);
688 689 690
		if (bitmap_bh == NULL)
			continue;

691
		x = ext4_count_free(bitmap_bh, sb->s_blocksize);
692 693
		printk(KERN_DEBUG "group %u: stored = %d, counted = %u\n",
			i, ext4_free_blks_count(sb, gdp), x);
694 695 696
		bitmap_count += x;
	}
	brelse(bitmap_bh);
697 698 699
	printk(KERN_DEBUG "ext4_count_free_blocks: stored = %llu"
		", computed = %llu, %llu\n", ext4_free_blocks_count(es),
	       desc_count, bitmap_count);
700 701 702 703 704
	return bitmap_count;
#else
	desc_count = 0;
	smp_rmb();
	for (i = 0; i < ngroups; i++) {
705
		gdp = ext4_get_group_desc(sb, i, NULL);
706 707
		if (!gdp)
			continue;
708
		desc_count += ext4_free_blks_count(sb, gdp);
709 710 711 712 713 714
	}

	return desc_count;
#endif
}

715
static inline int test_root(ext4_group_t a, int b)
716 717 718 719 720 721 722 723
{
	int num = b;

	while (a > num)
		num *= b;
	return num == a;
}

724
static int ext4_group_sparse(ext4_group_t group)
725 726 727 728 729 730 731 732 733 734
{
	if (group <= 1)
		return 1;
	if (!(group & 1))
		return 0;
	return (test_root(group, 7) || test_root(group, 5) ||
		test_root(group, 3));
}

/**
735
 *	ext4_bg_has_super - number of blocks used by the superblock in group
736 737 738 739 740 741
 *	@sb: superblock for filesystem
 *	@group: group number to check
 *
 *	Return the number of blocks used by the superblock (primary or backup)
 *	in this group.  Currently this will be only 0 or 1.
 */
742
int ext4_bg_has_super(struct super_block *sb, ext4_group_t group)
743
{
744 745 746
	if (EXT4_HAS_RO_COMPAT_FEATURE(sb,
				EXT4_FEATURE_RO_COMPAT_SPARSE_SUPER) &&
			!ext4_group_sparse(group))
747 748 749 750
		return 0;
	return 1;
}

751 752
static unsigned long ext4_bg_num_gdb_meta(struct super_block *sb,
					ext4_group_t group)
753
{
754
	unsigned long metagroup = group / EXT4_DESC_PER_BLOCK(sb);
755 756
	ext4_group_t first = metagroup * EXT4_DESC_PER_BLOCK(sb);
	ext4_group_t last = first + EXT4_DESC_PER_BLOCK(sb) - 1;
757 758 759 760 761 762

	if (group == first || group == first + 1 || group == last)
		return 1;
	return 0;
}

763 764
static unsigned long ext4_bg_num_gdb_nometa(struct super_block *sb,
					ext4_group_t group)
765
{
766
	return ext4_bg_has_super(sb, group) ? EXT4_SB(sb)->s_gdb_count : 0;
767 768 769
}

/**
770
 *	ext4_bg_num_gdb - number of blocks used by the group table in group
771 772 773 774 775 776 777
 *	@sb: superblock for filesystem
 *	@group: group number to check
 *
 *	Return the number of blocks used by the group descriptor table
 *	(primary or backup) in this group.  In the future there may be a
 *	different number of descriptor blocks in each group.
 */
778
unsigned long ext4_bg_num_gdb(struct super_block *sb, ext4_group_t group)
779 780
{
	unsigned long first_meta_bg =
781 782
			le32_to_cpu(EXT4_SB(sb)->s_es->s_first_meta_bg);
	unsigned long metagroup = group / EXT4_DESC_PER_BLOCK(sb);
783

784
	if (!EXT4_HAS_INCOMPAT_FEATURE(sb,EXT4_FEATURE_INCOMPAT_META_BG) ||
785
			metagroup < first_meta_bg)
786
		return ext4_bg_num_gdb_nometa(sb, group);
787

788
	return ext4_bg_num_gdb_meta(sb,group);
789 790

}
791