Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 24086
b: refs/heads/master
c: b54e41e
h: refs/heads/master
v: v3
  • Loading branch information
Mingming Cao authored and Linus Torvalds committed Mar 26, 2006
1 parent fe2e412 commit f5f5e56
Show file tree
Hide file tree
Showing 3 changed files with 41 additions and 12 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: b47b24781c59565f45acd765dc995a752d561e96
refs/heads/master: b54e41ec17ae91dce174eb5a3515e7af4a440d42
46 changes: 36 additions & 10 deletions trunk/fs/ext3/balloc.c
Original file line number Diff line number Diff line change
Expand Up @@ -653,9 +653,11 @@ claim_block(spinlock_t *lock, int block, struct buffer_head *bh)
*/
static int
ext3_try_to_allocate(struct super_block *sb, handle_t *handle, int group,
struct buffer_head *bitmap_bh, int goal, struct ext3_reserve_window *my_rsv)
struct buffer_head *bitmap_bh, int goal,
unsigned long *count, struct ext3_reserve_window *my_rsv)
{
int group_first_block, start, end;
unsigned long num = 0;

/* we do allocation within the reservation window if we have a window */
if (my_rsv) {
Expand Down Expand Up @@ -713,8 +715,18 @@ ext3_try_to_allocate(struct super_block *sb, handle_t *handle, int group,
goto fail_access;
goto repeat;
}
return goal;
num++;
goal++;
while (num < *count && goal < end
&& ext3_test_allocatable(goal, bitmap_bh)
&& claim_block(sb_bgl_lock(EXT3_SB(sb), group), goal, bitmap_bh)) {
num++;
goal++;
}
*count = num;
return goal - num;
fail_access:
*count = num;
return -1;
}

Expand Down Expand Up @@ -1024,11 +1036,12 @@ static int
ext3_try_to_allocate_with_rsv(struct super_block *sb, handle_t *handle,
unsigned int group, struct buffer_head *bitmap_bh,
int goal, struct ext3_reserve_window_node * my_rsv,
int *errp)
unsigned long *count, int *errp)
{
unsigned long group_first_block;
int ret = 0;
int fatal;
unsigned long num = *count;

*errp = 0;

Expand All @@ -1051,7 +1064,8 @@ ext3_try_to_allocate_with_rsv(struct super_block *sb, handle_t *handle,
* or last attempt to allocate a block with reservation turned on failed
*/
if (my_rsv == NULL ) {
ret = ext3_try_to_allocate(sb, handle, group, bitmap_bh, goal, NULL);
ret = ext3_try_to_allocate(sb, handle, group, bitmap_bh,
goal, count, NULL);
goto out;
}
/*
Expand Down Expand Up @@ -1093,11 +1107,13 @@ ext3_try_to_allocate_with_rsv(struct super_block *sb, handle_t *handle,
|| (my_rsv->rsv_end < group_first_block))
BUG();
ret = ext3_try_to_allocate(sb, handle, group, bitmap_bh, goal,
&my_rsv->rsv_window);
&num, &my_rsv->rsv_window);
if (ret >= 0) {
my_rsv->rsv_alloc_hit++;
my_rsv->rsv_alloc_hit += num;
*count = num;
break; /* succeed */
}
num = *count;
}
out:
if (ret >= 0) {
Expand Down Expand Up @@ -1154,8 +1170,8 @@ int ext3_should_retry_alloc(struct super_block *sb, int *retries)
* bitmap, and then for any free bit if that fails.
* This function also updates quota and i_blocks field.
*/
int ext3_new_block(handle_t *handle, struct inode *inode,
unsigned long goal, int *errp)
int ext3_new_blocks(handle_t *handle, struct inode *inode,
unsigned long goal, unsigned long *count, int *errp)
{
struct buffer_head *bitmap_bh = NULL;
struct buffer_head *gdp_bh;
Expand All @@ -1178,6 +1194,7 @@ int ext3_new_block(handle_t *handle, struct inode *inode,
static int goal_hits, goal_attempts;
#endif
unsigned long ngroups;
unsigned long num = *count;

*errp = -ENOSPC;
sb = inode->i_sb;
Expand Down Expand Up @@ -1244,7 +1261,7 @@ int ext3_new_block(handle_t *handle, struct inode *inode,
if (!bitmap_bh)
goto io_error;
ret_block = ext3_try_to_allocate_with_rsv(sb, handle, group_no,
bitmap_bh, ret_block, my_rsv, &fatal);
bitmap_bh, ret_block, my_rsv, &num, &fatal);
if (fatal)
goto out;
if (ret_block >= 0)
Expand Down Expand Up @@ -1281,7 +1298,7 @@ int ext3_new_block(handle_t *handle, struct inode *inode,
if (!bitmap_bh)
goto io_error;
ret_block = ext3_try_to_allocate_with_rsv(sb, handle, group_no,
bitmap_bh, -1, my_rsv, &fatal);
bitmap_bh, -1, my_rsv, &num, &fatal);
if (fatal)
goto out;
if (ret_block >= 0)
Expand Down Expand Up @@ -1388,6 +1405,7 @@ int ext3_new_block(handle_t *handle, struct inode *inode,

*errp = 0;
brelse(bitmap_bh);
*count = num;
return ret_block;

io_error:
Expand All @@ -1406,6 +1424,14 @@ int ext3_new_block(handle_t *handle, struct inode *inode,
return 0;
}

int ext3_new_block(handle_t *handle, struct inode *inode,
unsigned long goal, int *errp)
{
unsigned long count = 1;

return ext3_new_blocks(handle, inode, goal, &count, errp);
}

unsigned long ext3_count_free_blocks(struct super_block *sb)
{
unsigned long desc_count;
Expand Down
5 changes: 4 additions & 1 deletion trunk/include/linux/ext3_fs.h
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,8 @@ struct statfs;
* Define EXT3_RESERVATION to reserve data blocks for expanding files
*/
#define EXT3_DEFAULT_RESERVE_BLOCKS 8
#define EXT3_MAX_RESERVE_BLOCKS 1024
/*max window size: 1024(direct blocks) + 3([t,d]indirect blocks) */
#define EXT3_MAX_RESERVE_BLOCKS 1027
#define EXT3_RESERVE_WINDOW_NOT_ALLOCATED 0
/*
* Always enable hashed directories
Expand Down Expand Up @@ -732,6 +733,8 @@ struct dir_private_info {
extern int ext3_bg_has_super(struct super_block *sb, int group);
extern unsigned long ext3_bg_num_gdb(struct super_block *sb, int group);
extern int ext3_new_block (handle_t *, struct inode *, unsigned long, int *);
extern int ext3_new_blocks (handle_t *, struct inode *, unsigned long,
unsigned long *, int *);
extern void ext3_free_blocks (handle_t *, struct inode *, unsigned long,
unsigned long);
extern void ext3_free_blocks_sb (handle_t *, struct super_block *,
Expand Down

0 comments on commit f5f5e56

Please sign in to comment.