Blame view

fs/ext2/ialloc.c 18.3 KB
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1
2
3
4
5
6
7
8
9
10
11
12
13
  /*
   *  linux/fs/ext2/ialloc.c
   *
   * Copyright (C) 1992, 1993, 1994, 1995
   * Remy Card (card@masi.ibp.fr)
   * Laboratoire MASI - Institut Blaise Pascal
   * Universite Pierre et Marie Curie (Paris VI)
   *
   *  BSD ufs-inspired inode and directory allocation by 
   *  Stephen Tweedie (sct@dcs.ed.ac.uk), 1993
   *  Big-endian to little-endian byte-swapping/bitmaps by
   *        David S. Miller (davem@caip.rutgers.edu), 1995
   */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
  #include <linux/quotaops.h>
  #include <linux/sched.h>
  #include <linux/backing-dev.h>
  #include <linux/buffer_head.h>
  #include <linux/random.h>
  #include "ext2.h"
  #include "xattr.h"
  #include "acl.h"
  
  /*
   * ialloc.c contains the inodes allocation and deallocation routines
   */
  
  /*
   * The free inodes 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.
   */
  
  
  /*
   * Read the inode allocation bitmap for a given block_group, reading
   * into the specified slot in the superblock's bitmap cache.
   *
   * Return buffer_head of bitmap on success or NULL.
   */
  static struct buffer_head *
  read_inode_bitmap(struct super_block * sb, unsigned long block_group)
  {
  	struct ext2_group_desc *desc;
  	struct buffer_head *bh = NULL;
  
  	desc = ext2_get_group_desc(sb, block_group, NULL);
  	if (!desc)
  		goto error_out;
  
  	bh = sb_bread(sb, le32_to_cpu(desc->bg_inode_bitmap));
  	if (!bh)
  		ext2_error(sb, "read_inode_bitmap",
  			    "Cannot read inode bitmap - "
  			    "block_group = %lu, inode_bitmap = %u",
  			    block_group, le32_to_cpu(desc->bg_inode_bitmap));
  error_out:
  	return bh;
  }
  
  static void ext2_release_inode(struct super_block *sb, int group, int dir)
  {
  	struct ext2_group_desc * desc;
  	struct buffer_head *bh;
  
  	desc = ext2_get_group_desc(sb, group, &bh);
  	if (!desc) {
  		ext2_error(sb, "ext2_release_inode",
  			"can't get descriptor for group %d", group);
  		return;
  	}
  
  	spin_lock(sb_bgl_lock(EXT2_SB(sb), group));
fba4d3997   Marcin Slusarz   ext2: le*_add_cpu...
77
  	le16_add_cpu(&desc->bg_free_inodes_count, 1);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
78
  	if (dir)
fba4d3997   Marcin Slusarz   ext2: le*_add_cpu...
79
  		le16_add_cpu(&desc->bg_used_dirs_count, -1);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
  	spin_unlock(sb_bgl_lock(EXT2_SB(sb), group));
  	if (dir)
  		percpu_counter_dec(&EXT2_SB(sb)->s_dirs_counter);
  	sb->s_dirt = 1;
  	mark_buffer_dirty(bh);
  }
  
  /*
   * NOTE! When we get the inode, we're the only people
   * that have access to it, and as such there are no
   * race conditions we have to worry about. The inode
   * is not on the hash-lists, and it cannot be reached
   * through the filesystem because the directory entry
   * has been deleted earlier.
   *
   * HOWEVER: we must make sure that we get no aliases,
   * which means that we have to call "clear_inode()"
   * _before_ we mark the inode not in use in the inode
   * bitmaps. Otherwise a newly created file might use
   * the same inode number (not actually the same pointer
   * though), and then we'd have two inodes sharing the
   * same inode number and space on the harddisk.
   */
  void ext2_free_inode (struct inode * inode)
  {
  	struct super_block * sb = inode->i_sb;
  	int is_directory;
  	unsigned long ino;
524e4a1d1   Francis Moreau   ext2: remove usel...
108
  	struct buffer_head *bitmap_bh;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
109
110
111
112
113
114
115
116
117
118
119
120
  	unsigned long block_group;
  	unsigned long bit;
  	struct ext2_super_block * es;
  
  	ino = inode->i_ino;
  	ext2_debug ("freeing inode %lu
  ", ino);
  
  	/*
  	 * Note: we must free any quota before locking the superblock,
  	 * as writing the quota to disk may need the lock as well.
  	 */
72edc4d08   Al Viro   merge ext2 delete...
121
122
123
124
  	/* Quota is already initialized in iput() */
  	ext2_xattr_delete_inode(inode);
  	dquot_free_inode(inode);
  	dquot_drop(inode);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
125
126
127
  
  	es = EXT2_SB(sb)->s_es;
  	is_directory = S_ISDIR(inode->i_mode);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
128
129
130
131
  	if (ino < EXT2_FIRST_INO(sb) ||
  	    ino > le32_to_cpu(es->s_inodes_count)) {
  		ext2_error (sb, "ext2_free_inode",
  			    "reserved or nonexistent inode %lu", ino);
524e4a1d1   Francis Moreau   ext2: remove usel...
132
  		return;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
133
134
135
  	}
  	block_group = (ino - 1) / EXT2_INODES_PER_GROUP(sb);
  	bit = (ino - 1) % EXT2_INODES_PER_GROUP(sb);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
136
137
  	bitmap_bh = read_inode_bitmap(sb, block_group);
  	if (!bitmap_bh)
524e4a1d1   Francis Moreau   ext2: remove usel...
138
  		return;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
139
140
141
142
143
144
145
146
147
148
149
  
  	/* Ok, now we can actually update the inode bitmaps.. */
  	if (!ext2_clear_bit_atomic(sb_bgl_lock(EXT2_SB(sb), block_group),
  				bit, (void *) bitmap_bh->b_data))
  		ext2_error (sb, "ext2_free_inode",
  			      "bit already cleared for inode %lu", ino);
  	else
  		ext2_release_inode(sb, block_group, is_directory);
  	mark_buffer_dirty(bitmap_bh);
  	if (sb->s_flags & MS_SYNCHRONOUS)
  		sync_dirty_buffer(bitmap_bh);
524e4a1d1   Francis Moreau   ext2: remove usel...
150

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
  	brelse(bitmap_bh);
  }
  
  /*
   * We perform asynchronous prereading of the new inode's inode block when
   * we create the inode, in the expectation that the inode will be written
   * back soon.  There are two reasons:
   *
   * - When creating a large number of files, the async prereads will be
   *   nicely merged into large reads
   * - When writing out a large number of inodes, we don't need to keep on
   *   stalling the writes while we read the inode block.
   *
   * FIXME: ext2_get_group_desc() needs to be simplified.
   */
  static void ext2_preread_inode(struct inode *inode)
  {
  	unsigned long block_group;
  	unsigned long offset;
  	unsigned long block;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
171
172
173
174
175
176
177
178
179
180
  	struct ext2_group_desc * gdp;
  	struct backing_dev_info *bdi;
  
  	bdi = inode->i_mapping->backing_dev_info;
  	if (bdi_read_congested(bdi))
  		return;
  	if (bdi_write_congested(bdi))
  		return;
  
  	block_group = (inode->i_ino - 1) / EXT2_INODES_PER_GROUP(inode->i_sb);
ef2fb6798   Eric Sandeen   remove unused bh ...
181
  	gdp = ext2_get_group_desc(inode->i_sb, block_group, NULL);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
  	if (gdp == NULL)
  		return;
  
  	/*
  	 * Figure out the offset within the block group inode table
  	 */
  	offset = ((inode->i_ino - 1) % EXT2_INODES_PER_GROUP(inode->i_sb)) *
  				EXT2_INODE_SIZE(inode->i_sb);
  	block = le32_to_cpu(gdp->bg_inode_table) +
  				(offset >> EXT2_BLOCK_SIZE_BITS(inode->i_sb));
  	sb_breadahead(inode->i_sb, block);
  }
  
  /*
   * There are two policies for allocating an inode.  If the new inode is
   * a directory, then a forward search is made for a block group with both
   * free space and a low directory-to-inode ratio; if that fails, then of
   * the groups with above-average free space, that group with the fewest
   * directories already is chosen.
   *
   * For other inodes, search forward from the parent directory\'s block
   * group to find a free inode.
   */
  static int find_group_dir(struct super_block *sb, struct inode *parent)
  {
  	int ngroups = EXT2_SB(sb)->s_groups_count;
  	int avefreei = ext2_count_free_inodes(sb) / ngroups;
  	struct ext2_group_desc *desc, *best_desc = NULL;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
210
211
212
  	int group, best_group = -1;
  
  	for (group = 0; group < ngroups; group++) {
ef2fb6798   Eric Sandeen   remove unused bh ...
213
  		desc = ext2_get_group_desc (sb, group, NULL);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
214
215
216
217
218
219
220
221
222
  		if (!desc || !desc->bg_free_inodes_count)
  			continue;
  		if (le16_to_cpu(desc->bg_free_inodes_count) < avefreei)
  			continue;
  		if (!best_desc || 
  		    (le16_to_cpu(desc->bg_free_blocks_count) >
  		     le16_to_cpu(best_desc->bg_free_blocks_count))) {
  			best_group = group;
  			best_desc = desc;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
  		}
  	}
  	if (!best_desc)
  		return -1;
  
  	return best_group;
  }
  
  /* 
   * Orlov's allocator for directories. 
   * 
   * We always try to spread first-level directories.
   *
   * If there are blockgroups with both free inodes and free blocks counts 
   * not worse than average we return one with smallest directory count. 
   * Otherwise we simply return a random group. 
   * 
   * For the rest rules look so: 
   * 
   * It's OK to put directory into a group unless 
   * it has too many directories already (max_dirs) or 
   * it has too few free inodes left (min_inodes) or 
   * it has too few free blocks left (min_blocks) or 
   * it's already running too large debt (max_debt). 
1cc8dcf56   Benoit Boissinot   ext*: spelling fi...
247
   * Parent's group is preferred, if it doesn't satisfy these 
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
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
   * conditions we search cyclically through the rest. If none 
   * of the groups look good we just look for a group with more 
   * free inodes than average (starting at parent's group). 
   * 
   * Debt is incremented each time we allocate a directory and decremented 
   * when we allocate an inode, within 0--255. 
   */ 
  
  #define INODE_COST 64
  #define BLOCK_COST 256
  
  static int find_group_orlov(struct super_block *sb, struct inode *parent)
  {
  	int parent_group = EXT2_I(parent)->i_block_group;
  	struct ext2_sb_info *sbi = EXT2_SB(sb);
  	struct ext2_super_block *es = sbi->s_es;
  	int ngroups = sbi->s_groups_count;
  	int inodes_per_group = EXT2_INODES_PER_GROUP(sb);
  	int freei;
  	int avefreei;
  	int free_blocks;
  	int avefreeb;
  	int blocks_per_dir;
  	int ndirs;
  	int max_debt, max_dirs, min_blocks, min_inodes;
  	int group = -1, i;
  	struct ext2_group_desc *desc;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
275
276
277
278
279
280
281
282
283
284
  
  	freei = percpu_counter_read_positive(&sbi->s_freeinodes_counter);
  	avefreei = freei / ngroups;
  	free_blocks = percpu_counter_read_positive(&sbi->s_freeblocks_counter);
  	avefreeb = free_blocks / ngroups;
  	ndirs = percpu_counter_read_positive(&sbi->s_dirs_counter);
  
  	if ((parent == sb->s_root->d_inode) ||
  	    (EXT2_I(parent)->i_flags & EXT2_TOPDIR_FL)) {
  		struct ext2_group_desc *best_desc = NULL;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
285
286
287
288
289
290
291
  		int best_ndir = inodes_per_group;
  		int best_group = -1;
  
  		get_random_bytes(&group, sizeof(group));
  		parent_group = (unsigned)group % ngroups;
  		for (i = 0; i < ngroups; i++) {
  			group = (parent_group + i) % ngroups;
ef2fb6798   Eric Sandeen   remove unused bh ...
292
  			desc = ext2_get_group_desc (sb, group, NULL);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
293
294
295
296
297
298
299
300
301
302
303
  			if (!desc || !desc->bg_free_inodes_count)
  				continue;
  			if (le16_to_cpu(desc->bg_used_dirs_count) >= best_ndir)
  				continue;
  			if (le16_to_cpu(desc->bg_free_inodes_count) < avefreei)
  				continue;
  			if (le16_to_cpu(desc->bg_free_blocks_count) < avefreeb)
  				continue;
  			best_group = group;
  			best_ndir = le16_to_cpu(desc->bg_used_dirs_count);
  			best_desc = desc;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
304
305
306
  		}
  		if (best_group >= 0) {
  			desc = best_desc;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
  			group = best_group;
  			goto found;
  		}
  		goto fallback;
  	}
  
  	if (ndirs == 0)
  		ndirs = 1;	/* percpu_counters are approximate... */
  
  	blocks_per_dir = (le32_to_cpu(es->s_blocks_count)-free_blocks) / ndirs;
  
  	max_dirs = ndirs / ngroups + inodes_per_group / 16;
  	min_inodes = avefreei - inodes_per_group / 4;
  	min_blocks = avefreeb - EXT2_BLOCKS_PER_GROUP(sb) / 4;
  
  	max_debt = EXT2_BLOCKS_PER_GROUP(sb) / max(blocks_per_dir, BLOCK_COST);
  	if (max_debt * INODE_COST > inodes_per_group)
  		max_debt = inodes_per_group / INODE_COST;
  	if (max_debt > 255)
  		max_debt = 255;
  	if (max_debt == 0)
  		max_debt = 1;
  
  	for (i = 0; i < ngroups; i++) {
  		group = (parent_group + i) % ngroups;
ef2fb6798   Eric Sandeen   remove unused bh ...
332
  		desc = ext2_get_group_desc (sb, group, NULL);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
  		if (!desc || !desc->bg_free_inodes_count)
  			continue;
  		if (sbi->s_debts[group] >= max_debt)
  			continue;
  		if (le16_to_cpu(desc->bg_used_dirs_count) >= max_dirs)
  			continue;
  		if (le16_to_cpu(desc->bg_free_inodes_count) < min_inodes)
  			continue;
  		if (le16_to_cpu(desc->bg_free_blocks_count) < min_blocks)
  			continue;
  		goto found;
  	}
  
  fallback:
  	for (i = 0; i < ngroups; i++) {
  		group = (parent_group + i) % ngroups;
ef2fb6798   Eric Sandeen   remove unused bh ...
349
  		desc = ext2_get_group_desc (sb, group, NULL);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
  		if (!desc || !desc->bg_free_inodes_count)
  			continue;
  		if (le16_to_cpu(desc->bg_free_inodes_count) >= avefreei)
  			goto found;
  	}
  
  	if (avefreei) {
  		/*
  		 * The free-inodes counter is approximate, and for really small
  		 * filesystems the above test can fail to find any blockgroups
  		 */
  		avefreei = 0;
  		goto fallback;
  	}
  
  	return -1;
  
  found:
  	return group;
  }
  
  static int find_group_other(struct super_block *sb, struct inode *parent)
  {
  	int parent_group = EXT2_I(parent)->i_block_group;
  	int ngroups = EXT2_SB(sb)->s_groups_count;
  	struct ext2_group_desc *desc;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
376
377
378
379
380
381
  	int group, i;
  
  	/*
  	 * Try to place the inode in its parent directory
  	 */
  	group = parent_group;
ef2fb6798   Eric Sandeen   remove unused bh ...
382
  	desc = ext2_get_group_desc (sb, group, NULL);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
  	if (desc && le16_to_cpu(desc->bg_free_inodes_count) &&
  			le16_to_cpu(desc->bg_free_blocks_count))
  		goto found;
  
  	/*
  	 * We're going to place this inode in a different blockgroup from its
  	 * parent.  We want to cause files in a common directory to all land in
  	 * the same blockgroup.  But we want files which are in a different
  	 * directory which shares a blockgroup with our parent to land in a
  	 * different blockgroup.
  	 *
  	 * So add our directory's i_ino into the starting point for the hash.
  	 */
  	group = (group + parent->i_ino) % ngroups;
  
  	/*
  	 * Use a quadratic hash to find a group with a free inode and some
  	 * free blocks.
  	 */
  	for (i = 1; i < ngroups; i <<= 1) {
  		group += i;
  		if (group >= ngroups)
  			group -= ngroups;
ef2fb6798   Eric Sandeen   remove unused bh ...
406
  		desc = ext2_get_group_desc (sb, group, NULL);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
407
408
409
410
411
412
413
414
415
416
417
418
419
  		if (desc && le16_to_cpu(desc->bg_free_inodes_count) &&
  				le16_to_cpu(desc->bg_free_blocks_count))
  			goto found;
  	}
  
  	/*
  	 * That failed: try linear search for a free inode, even if that group
  	 * has no free blocks.
  	 */
  	group = parent_group;
  	for (i = 0; i < ngroups; i++) {
  		if (++group >= ngroups)
  			group = 0;
ef2fb6798   Eric Sandeen   remove unused bh ...
420
  		desc = ext2_get_group_desc (sb, group, NULL);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
421
422
423
424
425
426
427
428
429
  		if (desc && le16_to_cpu(desc->bg_free_inodes_count))
  			goto found;
  	}
  
  	return -1;
  
  found:
  	return group;
  }
3ea40bc94   Al Viro   ext2: propagate u...
430
  struct inode *ext2_new_inode(struct inode *dir, umode_t mode,
2a7dba391   Eric Paris   fs/vfs/security: ...
431
  			     const struct qstr *qstr)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
  {
  	struct super_block *sb;
  	struct buffer_head *bitmap_bh = NULL;
  	struct buffer_head *bh2;
  	int group, i;
  	ino_t ino = 0;
  	struct inode * inode;
  	struct ext2_group_desc *gdp;
  	struct ext2_super_block *es;
  	struct ext2_inode_info *ei;
  	struct ext2_sb_info *sbi;
  	int err;
  
  	sb = dir->i_sb;
  	inode = new_inode(sb);
  	if (!inode)
  		return ERR_PTR(-ENOMEM);
  
  	ei = EXT2_I(inode);
  	sbi = EXT2_SB(sb);
  	es = sbi->s_es;
  	if (S_ISDIR(mode)) {
  		if (test_opt(sb, OLDALLOC))
  			group = find_group_dir(sb, dir);
  		else
  			group = find_group_orlov(sb, dir);
  	} else 
  		group = find_group_other(sb, dir);
  
  	if (group == -1) {
  		err = -ENOSPC;
  		goto fail;
  	}
  
  	for (i = 0; i < sbi->s_groups_count; i++) {
  		gdp = ext2_get_group_desc(sb, group, &bh2);
  		brelse(bitmap_bh);
  		bitmap_bh = read_inode_bitmap(sb, group);
  		if (!bitmap_bh) {
  			err = -EIO;
  			goto fail;
  		}
  		ino = 0;
  
  repeat_in_this_group:
  		ino = ext2_find_next_zero_bit((unsigned long *)bitmap_bh->b_data,
  					      EXT2_INODES_PER_GROUP(sb), ino);
  		if (ino >= EXT2_INODES_PER_GROUP(sb)) {
  			/*
  			 * Rare race: find_group_xx() decided that there were
  			 * free inodes in this group, but by the time we tried
  			 * to allocate one, they're all gone.  This can also
  			 * occur because the counters which find_group_orlov()
  			 * uses are approximate.  So just go and search the
  			 * next block group.
  			 */
  			if (++group == sbi->s_groups_count)
  				group = 0;
  			continue;
  		}
  		if (ext2_set_bit_atomic(sb_bgl_lock(sbi, group),
  						ino, bitmap_bh->b_data)) {
  			/* we lost this inode */
  			if (++ino >= EXT2_INODES_PER_GROUP(sb)) {
  				/* this group is exhausted, try next group */
  				if (++group == sbi->s_groups_count)
  					group = 0;
  				continue;
  			}
  			/* try to find free inode in the same group */
  			goto repeat_in_this_group;
  		}
  		goto got;
  	}
  
  	/*
  	 * Scanned all blockgroups.
  	 */
  	err = -ENOSPC;
  	goto fail;
  got:
  	mark_buffer_dirty(bitmap_bh);
  	if (sb->s_flags & MS_SYNCHRONOUS)
  		sync_dirty_buffer(bitmap_bh);
  	brelse(bitmap_bh);
  
  	ino += group * EXT2_INODES_PER_GROUP(sb) + 1;
  	if (ino < EXT2_FIRST_INO(sb) || ino > le32_to_cpu(es->s_inodes_count)) {
  		ext2_error (sb, "ext2_new_inode",
  			    "reserved inode or inode > inodes count - "
  			    "block_group = %d,inode=%lu", group,
  			    (unsigned long) ino);
  		err = -EIO;
  		goto fail;
  	}
aa0dff2d0   Peter Zijlstra   lib: percpu_count...
527
  	percpu_counter_add(&sbi->s_freeinodes_counter, -1);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
528
529
530
531
  	if (S_ISDIR(mode))
  		percpu_counter_inc(&sbi->s_dirs_counter);
  
  	spin_lock(sb_bgl_lock(sbi, group));
fba4d3997   Marcin Slusarz   ext2: le*_add_cpu...
532
  	le16_add_cpu(&gdp->bg_free_inodes_count, -1);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
533
534
535
  	if (S_ISDIR(mode)) {
  		if (sbi->s_debts[group] < 255)
  			sbi->s_debts[group]++;
fba4d3997   Marcin Slusarz   ext2: le*_add_cpu...
536
  		le16_add_cpu(&gdp->bg_used_dirs_count, 1);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
537
538
539
540
541
542
543
544
  	} else {
  		if (sbi->s_debts[group])
  			sbi->s_debts[group]--;
  	}
  	spin_unlock(sb_bgl_lock(sbi, group));
  
  	sb->s_dirt = 1;
  	mark_buffer_dirty(bh2);
ffba102d7   Dmitry Monakhov   ext2: replace ino...
545
546
547
  	if (test_opt(sb, GRPID)) {
  		inode->i_mode = mode;
  		inode->i_uid = current_fsuid();
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
548
  		inode->i_gid = dir->i_gid;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
549
  	} else
ffba102d7   Dmitry Monakhov   ext2: replace ino...
550
  		inode_init_owner(inode, dir, mode);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
551
552
  
  	inode->i_ino = ino;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
553
554
555
  	inode->i_blocks = 0;
  	inode->i_mtime = inode->i_atime = inode->i_ctime = CURRENT_TIME_SEC;
  	memset(ei->i_data, 0, sizeof(ei->i_data));
ef8b64618   Duane Griffin   ext2: tighten res...
556
557
  	ei->i_flags =
  		ext2_mask_flags(mode, EXT2_I(dir)->i_flags & EXT2_FL_INHERITED);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
558
559
560
561
562
563
  	ei->i_faddr = 0;
  	ei->i_frag_no = 0;
  	ei->i_frag_size = 0;
  	ei->i_file_acl = 0;
  	ei->i_dir_acl = 0;
  	ei->i_dtime = 0;
a686cd898   Martin J. Bligh   ext2 reservations
564
  	ei->i_block_alloc_info = NULL;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
565
  	ei->i_block_group = group;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
566
567
568
569
570
571
  	ei->i_dir_start_lookup = 0;
  	ei->i_state = EXT2_STATE_NEW;
  	ext2_set_inode_flags(inode);
  	spin_lock(&sbi->s_next_gen_lock);
  	inode->i_generation = sbi->s_next_generation++;
  	spin_unlock(&sbi->s_next_gen_lock);
41080b5a2   Al Viro   nfsd race fixes: ...
572
  	if (insert_inode_locked(inode) < 0) {
ef6919c28   Jan Kara   ext2: Fix error h...
573
574
575
576
577
  		ext2_error(sb, "ext2_new_inode",
  			   "inode number already in use - inode=%lu",
  			   (unsigned long) ino);
  		err = -EIO;
  		goto fail;
41080b5a2   Al Viro   nfsd race fixes: ...
578
  	}
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
579

871a29315   Christoph Hellwig   dquot: cleanup dq...
580
  	dquot_initialize(inode);
63936ddaa   Christoph Hellwig   dquot: cleanup in...
581
582
  	err = dquot_alloc_inode(inode);
  	if (err)
9ed6c2fb3   Chris Sykes   [PATCH] Fix ext2_...
583
  		goto fail_drop;
9ed6c2fb3   Chris Sykes   [PATCH] Fix ext2_...
584

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
585
  	err = ext2_init_acl(inode, dir);
9ed6c2fb3   Chris Sykes   [PATCH] Fix ext2_...
586
587
  	if (err)
  		goto fail_free_drop;
2a7dba391   Eric Paris   fs/vfs/security: ...
588
  	err = ext2_init_security(inode, dir, qstr);
9ed6c2fb3   Chris Sykes   [PATCH] Fix ext2_...
589
590
  	if (err)
  		goto fail_free_drop;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
591
592
593
594
595
  	mark_inode_dirty(inode);
  	ext2_debug("allocating inode %lu
  ", inode->i_ino);
  	ext2_preread_inode(inode);
  	return inode;
9ed6c2fb3   Chris Sykes   [PATCH] Fix ext2_...
596
  fail_free_drop:
63936ddaa   Christoph Hellwig   dquot: cleanup in...
597
  	dquot_free_inode(inode);
9ed6c2fb3   Chris Sykes   [PATCH] Fix ext2_...
598
599
  
  fail_drop:
9f7547580   Christoph Hellwig   dquot: cleanup dq...
600
  	dquot_drop(inode);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
601
  	inode->i_flags |= S_NOQUOTA;
6d6b77f16   Miklos Szeredi   filesystems: add ...
602
  	clear_nlink(inode);
41080b5a2   Al Viro   nfsd race fixes: ...
603
  	unlock_new_inode(inode);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
  	iput(inode);
  	return ERR_PTR(err);
  
  fail:
  	make_bad_inode(inode);
  	iput(inode);
  	return ERR_PTR(err);
  }
  
  unsigned long ext2_count_free_inodes (struct super_block * sb)
  {
  	struct ext2_group_desc *desc;
  	unsigned long desc_count = 0;
  	int i;	
  
  #ifdef EXT2FS_DEBUG
  	struct ext2_super_block *es;
  	unsigned long bitmap_count = 0;
  	struct buffer_head *bitmap_bh = NULL;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
  	es = EXT2_SB(sb)->s_es;
  	for (i = 0; i < EXT2_SB(sb)->s_groups_count; i++) {
  		unsigned x;
  
  		desc = ext2_get_group_desc (sb, i, NULL);
  		if (!desc)
  			continue;
  		desc_count += le16_to_cpu(desc->bg_free_inodes_count);
  		brelse(bitmap_bh);
  		bitmap_bh = read_inode_bitmap(sb, i);
  		if (!bitmap_bh)
  			continue;
  
  		x = ext2_count_free(bitmap_bh, EXT2_INODES_PER_GROUP(sb) / 8);
  		printk("group %d: stored = %d, counted = %u
  ",
  			i, le16_to_cpu(desc->bg_free_inodes_count), x);
  		bitmap_count += x;
  	}
  	brelse(bitmap_bh);
  	printk("ext2_count_free_inodes: stored = %lu, computed = %lu, %lu
  ",
  		percpu_counter_read(&EXT2_SB(sb)->s_freeinodes_counter),
  		desc_count, bitmap_count);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
  	return desc_count;
  #else
  	for (i = 0; i < EXT2_SB(sb)->s_groups_count; i++) {
  		desc = ext2_get_group_desc (sb, i, NULL);
  		if (!desc)
  			continue;
  		desc_count += le16_to_cpu(desc->bg_free_inodes_count);
  	}
  	return desc_count;
  #endif
  }
  
  /* Called at mount-time, super-block is locked */
  unsigned long ext2_count_dirs (struct super_block * sb)
  {
  	unsigned long count = 0;
  	int i;
  
  	for (i = 0; i < EXT2_SB(sb)->s_groups_count; i++) {
  		struct ext2_group_desc *gdp = ext2_get_group_desc (sb, i, NULL);
  		if (!gdp)
  			continue;
  		count += le16_to_cpu(gdp->bg_used_dirs_count);
  	}
  	return count;
  }