inode.c 42.3 KB
Newer Older
L
Linus Torvalds 已提交
1 2
/*
 * (C) 1997 Linus Torvalds
3
 * (C) 1999 Andrea Arcangeli <andrea@suse.de> (dynamic inode allocation)
L
Linus Torvalds 已提交
4 5 6 7 8 9 10 11 12 13
 */
#include <linux/fs.h>
#include <linux/mm.h>
#include <linux/dcache.h>
#include <linux/init.h>
#include <linux/slab.h>
#include <linux/writeback.h>
#include <linux/module.h>
#include <linux/backing-dev.h>
#include <linux/wait.h>
N
Nick Piggin 已提交
14
#include <linux/rwsem.h>
L
Linus Torvalds 已提交
15 16 17 18 19 20
#include <linux/hash.h>
#include <linux/swap.h>
#include <linux/security.h>
#include <linux/pagemap.h>
#include <linux/cdev.h>
#include <linux/bootmem.h>
21
#include <linux/fsnotify.h>
22
#include <linux/mount.h>
23
#include <linux/async.h>
A
Al Viro 已提交
24
#include <linux/posix_acl.h>
25
#include <linux/prefetch.h>
26
#include <linux/ima.h>
27
#include <linux/cred.h>
28
#include <linux/buffer_head.h> /* for inode_has_buffers */
29
#include "internal.h"
L
Linus Torvalds 已提交
30

31
/*
32
 * Inode locking rules:
33 34 35
 *
 * inode->i_lock protects:
 *   inode->i_state, inode->i_hash, __iget()
D
Dave Chinner 已提交
36
 * inode->i_sb->s_inode_lru_lock protects:
37
 *   inode->i_sb->s_inode_lru, inode->i_lru
38 39
 * inode_sb_list_lock protects:
 *   sb->s_inodes, inode->i_sb_list
40 41
 * inode_wb_list_lock protects:
 *   bdi->wb.b_{dirty,io,more_io}, inode->i_wb_list
42 43
 * inode_hash_lock protects:
 *   inode_hashtable, inode->i_hash
44 45
 *
 * Lock ordering:
46 47 48
 *
 * inode_sb_list_lock
 *   inode->i_lock
D
Dave Chinner 已提交
49
 *     inode->i_sb->s_inode_lru_lock
50 51 52
 *
 * inode_wb_list_lock
 *   inode->i_lock
53 54 55 56 57 58 59
 *
 * inode_hash_lock
 *   inode_sb_list_lock
 *   inode->i_lock
 *
 * iunique_lock
 *   inode_hash_lock
60 61
 */

62 63
static unsigned int i_hash_mask __read_mostly;
static unsigned int i_hash_shift __read_mostly;
64 65
static struct hlist_head *inode_hashtable __read_mostly;
static __cacheline_aligned_in_smp DEFINE_SPINLOCK(inode_hash_lock);
L
Linus Torvalds 已提交
66

67
__cacheline_aligned_in_smp DEFINE_SPINLOCK(inode_sb_list_lock);
68
__cacheline_aligned_in_smp DEFINE_SPINLOCK(inode_wb_list_lock);
69

J
Jens Axboe 已提交
70 71 72 73 74 75 76 77
/*
 * Empty aops. Can be used for the cases where the user does not
 * define any of the address_space operations.
 */
const struct address_space_operations empty_aops = {
};
EXPORT_SYMBOL(empty_aops);

L
Linus Torvalds 已提交
78 79 80 81 82
/*
 * Statistics gathering..
 */
struct inodes_stat_t inodes_stat;

83
static DEFINE_PER_CPU(unsigned int, nr_inodes);
84
static DEFINE_PER_CPU(unsigned int, nr_unused);
85

86
static struct kmem_cache *inode_cachep __read_mostly;
L
Linus Torvalds 已提交
87

88
static int get_nr_inodes(void)
89
{
90 91 92 93 94
	int i;
	int sum = 0;
	for_each_possible_cpu(i)
		sum += per_cpu(nr_inodes, i);
	return sum < 0 ? 0 : sum;
95 96 97 98
}

static inline int get_nr_inodes_unused(void)
{
99 100 101 102 103
	int i;
	int sum = 0;
	for_each_possible_cpu(i)
		sum += per_cpu(nr_unused, i);
	return sum < 0 ? 0 : sum;
104 105 106 107
}

int get_nr_dirty_inodes(void)
{
108
	/* not actually dirty inodes, but a wild approximation */
109 110 111 112 113 114 115 116 117 118 119 120
	int nr_dirty = get_nr_inodes() - get_nr_inodes_unused();
	return nr_dirty > 0 ? nr_dirty : 0;
}

/*
 * Handle nr_inode sysctl
 */
#ifdef CONFIG_SYSCTL
int proc_nr_inodes(ctl_table *table, int write,
		   void __user *buffer, size_t *lenp, loff_t *ppos)
{
	inodes_stat.nr_inodes = get_nr_inodes();
121
	inodes_stat.nr_unused = get_nr_inodes_unused();
122 123 124 125
	return proc_dointvec(table, write, buffer, lenp, ppos);
}
#endif

D
David Chinner 已提交
126 127
/**
 * inode_init_always - perform inode structure intialisation
R
Randy Dunlap 已提交
128 129
 * @sb: superblock inode belongs to
 * @inode: inode to initialise
D
David Chinner 已提交
130 131 132 133
 *
 * These are initializations that need to be done on every inode
 * allocation as the fields are not initialised by slab allocation.
 */
134
int inode_init_always(struct super_block *sb, struct inode *inode)
L
Linus Torvalds 已提交
135
{
136
	static const struct inode_operations empty_iops;
137
	static const struct file_operations empty_fops;
138
	struct address_space *const mapping = &inode->i_data;
D
David Chinner 已提交
139 140 141 142 143 144 145 146

	inode->i_sb = sb;
	inode->i_blkbits = sb->s_blocksize_bits;
	inode->i_flags = 0;
	atomic_set(&inode->i_count, 1);
	inode->i_op = &empty_iops;
	inode->i_fop = &empty_fops;
	inode->i_nlink = 1;
A
Al Viro 已提交
147 148
	inode->i_uid = 0;
	inode->i_gid = 0;
D
David Chinner 已提交
149 150 151 152 153
	atomic_set(&inode->i_writecount, 0);
	inode->i_size = 0;
	inode->i_blocks = 0;
	inode->i_bytes = 0;
	inode->i_generation = 0;
L
Linus Torvalds 已提交
154
#ifdef CONFIG_QUOTA
D
David Chinner 已提交
155
	memset(&inode->i_dquot, 0, sizeof(inode->i_dquot));
L
Linus Torvalds 已提交
156
#endif
D
David Chinner 已提交
157 158 159 160 161
	inode->i_pipe = NULL;
	inode->i_bdev = NULL;
	inode->i_cdev = NULL;
	inode->i_rdev = 0;
	inode->dirtied_when = 0;
M
Mimi Zohar 已提交
162 163

	if (security_inode_alloc(inode))
164
		goto out;
D
David Chinner 已提交
165 166 167 168 169 170 171 172 173 174 175 176
	spin_lock_init(&inode->i_lock);
	lockdep_set_class(&inode->i_lock, &sb->s_type->i_lock_key);

	mutex_init(&inode->i_mutex);
	lockdep_set_class(&inode->i_mutex, &sb->s_type->i_mutex_key);

	init_rwsem(&inode->i_alloc_sem);
	lockdep_set_class(&inode->i_alloc_sem, &sb->s_type->i_alloc_sem_key);

	mapping->a_ops = &empty_aops;
	mapping->host = inode;
	mapping->flags = 0;
H
Hugh Dickins 已提交
177
	mapping_set_gfp_mask(mapping, GFP_HIGHUSER_MOVABLE);
D
David Chinner 已提交
178 179 180 181 182 183 184 185 186 187 188 189
	mapping->assoc_mapping = NULL;
	mapping->backing_dev_info = &default_backing_dev_info;
	mapping->writeback_index = 0;

	/*
	 * If the block_device provides a backing_dev_info for client
	 * inodes then use that.  Otherwise the inode share the bdev's
	 * backing_dev_info.
	 */
	if (sb->s_bdev) {
		struct backing_dev_info *bdi;

190
		bdi = sb->s_bdev->bd_inode->i_mapping->backing_dev_info;
D
David Chinner 已提交
191 192 193 194
		mapping->backing_dev_info = bdi;
	}
	inode->i_private = NULL;
	inode->i_mapping = mapping;
A
Al Viro 已提交
195 196 197
#ifdef CONFIG_FS_POSIX_ACL
	inode->i_acl = inode->i_default_acl = ACL_NOT_CACHED;
#endif
D
David Chinner 已提交
198

199 200 201 202
#ifdef CONFIG_FSNOTIFY
	inode->i_fsnotify_mask = 0;
#endif

203
	this_cpu_inc(nr_inodes);
204

205 206 207
	return 0;
out:
	return -ENOMEM;
L
Linus Torvalds 已提交
208
}
D
David Chinner 已提交
209 210 211 212 213 214 215 216 217 218 219
EXPORT_SYMBOL(inode_init_always);

static struct inode *alloc_inode(struct super_block *sb)
{
	struct inode *inode;

	if (sb->s_op->alloc_inode)
		inode = sb->s_op->alloc_inode(sb);
	else
		inode = kmem_cache_alloc(inode_cachep, GFP_KERNEL);

220 221 222 223 224 225 226 227 228 229 230 231
	if (!inode)
		return NULL;

	if (unlikely(inode_init_always(sb, inode))) {
		if (inode->i_sb->s_op->destroy_inode)
			inode->i_sb->s_op->destroy_inode(inode);
		else
			kmem_cache_free(inode_cachep, inode);
		return NULL;
	}

	return inode;
D
David Chinner 已提交
232
}
L
Linus Torvalds 已提交
233

234 235 236 237 238 239
void free_inode_nonrcu(struct inode *inode)
{
	kmem_cache_free(inode_cachep, inode);
}
EXPORT_SYMBOL(free_inode_nonrcu);

C
Christoph Hellwig 已提交
240
void __destroy_inode(struct inode *inode)
L
Linus Torvalds 已提交
241
{
242
	BUG_ON(inode_has_buffers(inode));
L
Linus Torvalds 已提交
243
	security_inode_free(inode);
244
	fsnotify_inode_delete(inode);
A
Al Viro 已提交
245 246 247 248 249 250
#ifdef CONFIG_FS_POSIX_ACL
	if (inode->i_acl && inode->i_acl != ACL_NOT_CACHED)
		posix_acl_release(inode->i_acl);
	if (inode->i_default_acl && inode->i_default_acl != ACL_NOT_CACHED)
		posix_acl_release(inode->i_default_acl);
#endif
251
	this_cpu_dec(nr_inodes);
C
Christoph Hellwig 已提交
252 253 254
}
EXPORT_SYMBOL(__destroy_inode);

N
Nick Piggin 已提交
255 256 257 258 259 260 261
static void i_callback(struct rcu_head *head)
{
	struct inode *inode = container_of(head, struct inode, i_rcu);
	INIT_LIST_HEAD(&inode->i_dentry);
	kmem_cache_free(inode_cachep, inode);
}

C
Christoph Hellwig 已提交
262
static void destroy_inode(struct inode *inode)
C
Christoph Hellwig 已提交
263
{
N
Nick Piggin 已提交
264
	BUG_ON(!list_empty(&inode->i_lru));
C
Christoph Hellwig 已提交
265
	__destroy_inode(inode);
L
Linus Torvalds 已提交
266 267 268
	if (inode->i_sb->s_op->destroy_inode)
		inode->i_sb->s_op->destroy_inode(inode);
	else
N
Nick Piggin 已提交
269
		call_rcu(&inode->i_rcu, i_callback);
L
Linus Torvalds 已提交
270 271
}

272 273 274 275 276
void address_space_init_once(struct address_space *mapping)
{
	memset(mapping, 0, sizeof(*mapping));
	INIT_RADIX_TREE(&mapping->page_tree, GFP_ATOMIC);
	spin_lock_init(&mapping->tree_lock);
277
	mutex_init(&mapping->i_mmap_mutex);
278 279 280 281 282 283 284
	INIT_LIST_HEAD(&mapping->private_list);
	spin_lock_init(&mapping->private_lock);
	INIT_RAW_PRIO_TREE_ROOT(&mapping->i_mmap);
	INIT_LIST_HEAD(&mapping->i_mmap_nonlinear);
}
EXPORT_SYMBOL(address_space_init_once);

L
Linus Torvalds 已提交
285 286 287 288 289 290 291 292 293 294 295
/*
 * These are initializations that only need to be done
 * once, because the fields are idempotent across use
 * of the inode, so let the slab aware of that.
 */
void inode_init_once(struct inode *inode)
{
	memset(inode, 0, sizeof(*inode));
	INIT_HLIST_NODE(&inode->i_hash);
	INIT_LIST_HEAD(&inode->i_dentry);
	INIT_LIST_HEAD(&inode->i_devices);
N
Nick Piggin 已提交
296 297
	INIT_LIST_HEAD(&inode->i_wb_list);
	INIT_LIST_HEAD(&inode->i_lru);
298
	address_space_init_once(&inode->i_data);
L
Linus Torvalds 已提交
299
	i_size_ordered_init(inode);
300
#ifdef CONFIG_FSNOTIFY
301
	INIT_HLIST_HEAD(&inode->i_fsnotify_marks);
302
#endif
L
Linus Torvalds 已提交
303 304 305
}
EXPORT_SYMBOL(inode_init_once);

306
static void init_once(void *foo)
L
Linus Torvalds 已提交
307
{
308
	struct inode *inode = (struct inode *) foo;
L
Linus Torvalds 已提交
309

C
Christoph Lameter 已提交
310
	inode_init_once(inode);
L
Linus Torvalds 已提交
311 312 313
}

/*
314
 * inode->i_lock must be held
L
Linus Torvalds 已提交
315
 */
316
void __iget(struct inode *inode)
L
Linus Torvalds 已提交
317
{
318 319
	atomic_inc(&inode->i_count);
}
320

A
Al Viro 已提交
321 322 323 324 325 326 327 328 329
/*
 * get additional reference to inode; caller must already hold one.
 */
void ihold(struct inode *inode)
{
	WARN_ON(atomic_inc_return(&inode->i_count) < 2);
}
EXPORT_SYMBOL(ihold);

330 331
static void inode_lru_list_add(struct inode *inode)
{
D
Dave Chinner 已提交
332
	spin_lock(&inode->i_sb->s_inode_lru_lock);
N
Nick Piggin 已提交
333
	if (list_empty(&inode->i_lru)) {
334 335
		list_add(&inode->i_lru, &inode->i_sb->s_inode_lru);
		inode->i_sb->s_nr_inodes_unused++;
336
		this_cpu_inc(nr_unused);
337
	}
D
Dave Chinner 已提交
338
	spin_unlock(&inode->i_sb->s_inode_lru_lock);
339
}
340

341 342
static void inode_lru_list_del(struct inode *inode)
{
D
Dave Chinner 已提交
343
	spin_lock(&inode->i_sb->s_inode_lru_lock);
N
Nick Piggin 已提交
344 345
	if (!list_empty(&inode->i_lru)) {
		list_del_init(&inode->i_lru);
346
		inode->i_sb->s_nr_inodes_unused--;
347
		this_cpu_dec(nr_unused);
348
	}
D
Dave Chinner 已提交
349
	spin_unlock(&inode->i_sb->s_inode_lru_lock);
L
Linus Torvalds 已提交
350 351
}

352 353 354 355 356 357
/**
 * inode_sb_list_add - add inode to the superblock list of inodes
 * @inode: inode to add
 */
void inode_sb_list_add(struct inode *inode)
{
358 359 360
	spin_lock(&inode_sb_list_lock);
	list_add(&inode->i_sb_list, &inode->i_sb->s_inodes);
	spin_unlock(&inode_sb_list_lock);
361 362 363
}
EXPORT_SYMBOL_GPL(inode_sb_list_add);

364
static inline void inode_sb_list_del(struct inode *inode)
365
{
366
	spin_lock(&inode_sb_list_lock);
367
	list_del_init(&inode->i_sb_list);
368
	spin_unlock(&inode_sb_list_lock);
369 370
}

371 372 373 374 375 376
static unsigned long hash(struct super_block *sb, unsigned long hashval)
{
	unsigned long tmp;

	tmp = (hashval * (unsigned long)sb) ^ (GOLDEN_RATIO_PRIME + hashval) /
			L1_CACHE_BYTES;
377 378
	tmp = tmp ^ ((tmp ^ GOLDEN_RATIO_PRIME) >> i_hash_shift);
	return tmp & i_hash_mask;
379 380 381 382 383 384 385 386 387 388 389 390
}

/**
 *	__insert_inode_hash - hash an inode
 *	@inode: unhashed inode
 *	@hashval: unsigned long value used to locate this object in the
 *		inode_hashtable.
 *
 *	Add an inode to the inode hash for this superblock.
 */
void __insert_inode_hash(struct inode *inode, unsigned long hashval)
{
391 392
	struct hlist_head *b = inode_hashtable + hash(inode->i_sb, hashval);

393
	spin_lock(&inode_hash_lock);
394
	spin_lock(&inode->i_lock);
395
	hlist_add_head(&inode->i_hash, b);
396
	spin_unlock(&inode->i_lock);
397
	spin_unlock(&inode_hash_lock);
398 399 400 401 402 403 404 405 406 407 408
}
EXPORT_SYMBOL(__insert_inode_hash);

/**
 *	remove_inode_hash - remove an inode from the hash
 *	@inode: inode to unhash
 *
 *	Remove an inode from the superblock.
 */
void remove_inode_hash(struct inode *inode)
{
409
	spin_lock(&inode_hash_lock);
410
	spin_lock(&inode->i_lock);
411
	hlist_del_init(&inode->i_hash);
412
	spin_unlock(&inode->i_lock);
413
	spin_unlock(&inode_hash_lock);
414 415 416
}
EXPORT_SYMBOL(remove_inode_hash);

A
Al Viro 已提交
417 418 419
void end_writeback(struct inode *inode)
{
	might_sleep();
420 421 422 423 424 425
	/*
	 * We have to cycle tree_lock here because reclaim can be still in the
	 * process of removing the last page (in __delete_from_page_cache())
	 * and we must not free mapping under it.
	 */
	spin_lock_irq(&inode->i_data.tree_lock);
A
Al Viro 已提交
426
	BUG_ON(inode->i_data.nrpages);
427
	spin_unlock_irq(&inode->i_data.tree_lock);
A
Al Viro 已提交
428 429 430 431
	BUG_ON(!list_empty(&inode->i_data.private_list));
	BUG_ON(!(inode->i_state & I_FREEING));
	BUG_ON(inode->i_state & I_CLEAR);
	inode_sync_wait(inode);
N
Nick Piggin 已提交
432
	/* don't need i_lock here, no concurrent mods to i_state */
A
Al Viro 已提交
433 434 435 436
	inode->i_state = I_FREEING | I_CLEAR;
}
EXPORT_SYMBOL(end_writeback);

D
Dave Chinner 已提交
437 438 439 440 441 442 443 444 445 446 447 448 449
/*
 * Free the inode passed in, removing it from the lists it is still connected
 * to. We remove any pages still attached to the inode and wait for any IO that
 * is still in progress before finally destroying the inode.
 *
 * An inode must already be marked I_FREEING so that we avoid the inode being
 * moved back onto lists if we race with other code that manipulates the lists
 * (e.g. writeback_single_inode). The caller is responsible for setting this.
 *
 * An inode must already be removed from the LRU list before being evicted from
 * the cache. This should occur atomically with setting the I_FREEING state
 * flag, so no inodes here should ever be on the LRU when being evicted.
 */
450
static void evict(struct inode *inode)
451 452 453
{
	const struct super_operations *op = inode->i_sb->s_op;

D
Dave Chinner 已提交
454 455 456
	BUG_ON(!(inode->i_state & I_FREEING));
	BUG_ON(!list_empty(&inode->i_lru));

457
	inode_wb_list_del(inode);
458 459
	inode_sb_list_del(inode);

A
Al Viro 已提交
460 461
	if (op->evict_inode) {
		op->evict_inode(inode);
462 463 464
	} else {
		if (inode->i_data.nrpages)
			truncate_inode_pages(&inode->i_data, 0);
A
Al Viro 已提交
465
		end_writeback(inode);
466
	}
467 468 469 470
	if (S_ISBLK(inode->i_mode) && inode->i_bdev)
		bd_forget(inode);
	if (S_ISCHR(inode->i_mode) && inode->i_cdev)
		cd_forget(inode);
D
Dave Chinner 已提交
471 472 473 474 475 476 477 478 479

	remove_inode_hash(inode);

	spin_lock(&inode->i_lock);
	wake_up_bit(&inode->i_state, __I_NEW);
	BUG_ON(inode->i_state != (I_FREEING | I_CLEAR));
	spin_unlock(&inode->i_lock);

	destroy_inode(inode);
480 481
}

L
Linus Torvalds 已提交
482 483 484 485 486 487 488 489 490 491 492 493
/*
 * dispose_list - dispose of the contents of a local list
 * @head: the head of the list to free
 *
 * Dispose-list gets a local list with local inodes in it, so it doesn't
 * need to worry about list corruption and SMP locks.
 */
static void dispose_list(struct list_head *head)
{
	while (!list_empty(head)) {
		struct inode *inode;

N
Nick Piggin 已提交
494 495
		inode = list_first_entry(head, struct inode, i_lru);
		list_del_init(&inode->i_lru);
L
Linus Torvalds 已提交
496

497
		evict(inode);
L
Linus Torvalds 已提交
498 499 500
	}
}

A
Al Viro 已提交
501 502 503 504 505 506 507 508
/**
 * evict_inodes	- evict all evictable inodes for a superblock
 * @sb:		superblock to operate on
 *
 * Make sure that no inodes with zero refcount are retained.  This is
 * called by superblock shutdown after having MS_ACTIVE flag removed,
 * so any inode reaching zero refcount during or after that call will
 * be immediately evicted.
L
Linus Torvalds 已提交
509
 */
A
Al Viro 已提交
510
void evict_inodes(struct super_block *sb)
L
Linus Torvalds 已提交
511
{
A
Al Viro 已提交
512 513
	struct inode *inode, *next;
	LIST_HEAD(dispose);
L
Linus Torvalds 已提交
514

515
	spin_lock(&inode_sb_list_lock);
A
Al Viro 已提交
516 517
	list_for_each_entry_safe(inode, next, &sb->s_inodes, i_sb_list) {
		if (atomic_read(&inode->i_count))
N
Nick Piggin 已提交
518
			continue;
519 520 521 522

		spin_lock(&inode->i_lock);
		if (inode->i_state & (I_NEW | I_FREEING | I_WILL_FREE)) {
			spin_unlock(&inode->i_lock);
L
Linus Torvalds 已提交
523
			continue;
524
		}
A
Al Viro 已提交
525 526

		inode->i_state |= I_FREEING;
527
		inode_lru_list_del(inode);
528
		spin_unlock(&inode->i_lock);
529
		list_add(&inode->i_lru, &dispose);
L
Linus Torvalds 已提交
530
	}
531
	spin_unlock(&inode_sb_list_lock);
A
Al Viro 已提交
532 533

	dispose_list(&dispose);
L
Linus Torvalds 已提交
534 535 536
}

/**
537 538
 * invalidate_inodes	- attempt to free all inodes on a superblock
 * @sb:		superblock to operate on
539
 * @kill_dirty: flag to guide handling of dirty inodes
L
Linus Torvalds 已提交
540
 *
541 542
 * Attempts to free all inodes for a given superblock.  If there were any
 * busy inodes return a non-zero value, else zero.
543 544
 * If @kill_dirty is set, discard dirty inodes too, otherwise treat
 * them as busy.
L
Linus Torvalds 已提交
545
 */
546
int invalidate_inodes(struct super_block *sb, bool kill_dirty)
L
Linus Torvalds 已提交
547
{
548
	int busy = 0;
549 550
	struct inode *inode, *next;
	LIST_HEAD(dispose);
L
Linus Torvalds 已提交
551

552
	spin_lock(&inode_sb_list_lock);
553
	list_for_each_entry_safe(inode, next, &sb->s_inodes, i_sb_list) {
554 555 556
		spin_lock(&inode->i_lock);
		if (inode->i_state & (I_NEW | I_FREEING | I_WILL_FREE)) {
			spin_unlock(&inode->i_lock);
N
Nick Piggin 已提交
557
			continue;
558
		}
559
		if (inode->i_state & I_DIRTY && !kill_dirty) {
560
			spin_unlock(&inode->i_lock);
561 562 563
			busy = 1;
			continue;
		}
564
		if (atomic_read(&inode->i_count)) {
565
			spin_unlock(&inode->i_lock);
566
			busy = 1;
L
Linus Torvalds 已提交
567 568
			continue;
		}
569 570

		inode->i_state |= I_FREEING;
571
		inode_lru_list_del(inode);
572
		spin_unlock(&inode->i_lock);
573
		list_add(&inode->i_lru, &dispose);
L
Linus Torvalds 已提交
574
	}
575
	spin_unlock(&inode_sb_list_lock);
L
Linus Torvalds 已提交
576

577
	dispose_list(&dispose);
L
Linus Torvalds 已提交
578 579 580 581 582 583

	return busy;
}

static int can_unuse(struct inode *inode)
{
584
	if (inode->i_state & ~I_REFERENCED)
L
Linus Torvalds 已提交
585 586 587 588 589 590 591 592 593 594 595
		return 0;
	if (inode_has_buffers(inode))
		return 0;
	if (atomic_read(&inode->i_count))
		return 0;
	if (inode->i_data.nrpages)
		return 0;
	return 1;
}

/*
596 597 598 599
 * Walk the superblock inode LRU for freeable inodes and attempt to free them.
 * This is called from the superblock shrinker function with a number of inodes
 * to trim from the LRU. Inodes to be freed are moved to a temporary list and
 * then are freed outside inode_lock by dispose_list().
L
Linus Torvalds 已提交
600 601
 *
 * Any inodes which are pinned purely because of attached pagecache have their
602 603
 * pagecache removed.  If the inode has metadata buffers attached to
 * mapping->private_list then try to remove them.
L
Linus Torvalds 已提交
604
 *
605 606 607 608 609 610 611
 * If the inode has the I_REFERENCED flag set, then it means that it has been
 * used recently - the flag is set in iput_final(). When we encounter such an
 * inode, clear the flag and move it to the back of the LRU so it gets another
 * pass through the LRU before it gets reclaimed. This is necessary because of
 * the fact we are doing lazy LRU updates to minimise lock contention so the
 * LRU does not have strict ordering. Hence we don't want to reclaim inodes
 * with this flag set because they are the inodes that are out of order.
L
Linus Torvalds 已提交
612
 */
613
void prune_icache_sb(struct super_block *sb, int nr_to_scan)
L
Linus Torvalds 已提交
614 615 616 617 618
{
	LIST_HEAD(freeable);
	int nr_scanned;
	unsigned long reap = 0;

D
Dave Chinner 已提交
619
	spin_lock(&sb->s_inode_lru_lock);
620
	for (nr_scanned = nr_to_scan; nr_scanned >= 0; nr_scanned--) {
L
Linus Torvalds 已提交
621 622
		struct inode *inode;

623
		if (list_empty(&sb->s_inode_lru))
L
Linus Torvalds 已提交
624 625
			break;

626
		inode = list_entry(sb->s_inode_lru.prev, struct inode, i_lru);
L
Linus Torvalds 已提交
627

628
		/*
D
Dave Chinner 已提交
629
		 * we are inverting the sb->s_inode_lru_lock/inode->i_lock here,
630 631 632 633
		 * so use a trylock. If we fail to get the lock, just move the
		 * inode to the back of the list so we don't spin on it.
		 */
		if (!spin_trylock(&inode->i_lock)) {
634
			list_move(&inode->i_lru, &sb->s_inode_lru);
635 636 637
			continue;
		}

638 639 640 641 642 643
		/*
		 * Referenced or dirty inodes are still in use. Give them
		 * another pass through the LRU as we canot reclaim them now.
		 */
		if (atomic_read(&inode->i_count) ||
		    (inode->i_state & ~I_REFERENCED)) {
N
Nick Piggin 已提交
644
			list_del_init(&inode->i_lru);
645
			spin_unlock(&inode->i_lock);
646
			sb->s_nr_inodes_unused--;
647
			this_cpu_dec(nr_unused);
648 649 650 651 652 653
			continue;
		}

		/* recently referenced inodes get one more pass */
		if (inode->i_state & I_REFERENCED) {
			inode->i_state &= ~I_REFERENCED;
654
			list_move(&inode->i_lru, &sb->s_inode_lru);
655
			spin_unlock(&inode->i_lock);
L
Linus Torvalds 已提交
656 657 658 659
			continue;
		}
		if (inode_has_buffers(inode) || inode->i_data.nrpages) {
			__iget(inode);
660
			spin_unlock(&inode->i_lock);
D
Dave Chinner 已提交
661
			spin_unlock(&sb->s_inode_lru_lock);
L
Linus Torvalds 已提交
662
			if (remove_inode_buffers(inode))
663 664
				reap += invalidate_mapping_pages(&inode->i_data,
								0, -1);
L
Linus Torvalds 已提交
665
			iput(inode);
D
Dave Chinner 已提交
666
			spin_lock(&sb->s_inode_lru_lock);
L
Linus Torvalds 已提交
667

668
			if (inode != list_entry(sb->s_inode_lru.next,
N
Nick Piggin 已提交
669
						struct inode, i_lru))
L
Linus Torvalds 已提交
670
				continue;	/* wrong inode or list_empty */
671 672 673
			/* avoid lock inversions with trylock */
			if (!spin_trylock(&inode->i_lock))
				continue;
674 675
			if (!can_unuse(inode)) {
				spin_unlock(&inode->i_lock);
L
Linus Torvalds 已提交
676
				continue;
677
			}
L
Linus Torvalds 已提交
678
		}
679
		WARN_ON(inode->i_state & I_NEW);
L
Linus Torvalds 已提交
680
		inode->i_state |= I_FREEING;
681
		spin_unlock(&inode->i_lock);
N
Nick Piggin 已提交
682 683

		list_move(&inode->i_lru, &freeable);
684
		sb->s_nr_inodes_unused--;
685
		this_cpu_dec(nr_unused);
L
Linus Torvalds 已提交
686
	}
687 688 689 690
	if (current_is_kswapd())
		__count_vm_events(KSWAPD_INODESTEAL, reap);
	else
		__count_vm_events(PGINODESTEAL, reap);
D
Dave Chinner 已提交
691
	spin_unlock(&sb->s_inode_lru_lock);
L
Linus Torvalds 已提交
692 693 694 695 696 697 698 699

	dispose_list(&freeable);
}

static void __wait_on_freeing_inode(struct inode *inode);
/*
 * Called with the inode lock held.
 */
700 701 702 703
static struct inode *find_inode(struct super_block *sb,
				struct hlist_head *head,
				int (*test)(struct inode *, void *),
				void *data)
L
Linus Torvalds 已提交
704 705
{
	struct hlist_node *node;
706
	struct inode *inode = NULL;
L
Linus Torvalds 已提交
707 708

repeat:
709
	hlist_for_each_entry(inode, node, head, i_hash) {
710 711 712
		spin_lock(&inode->i_lock);
		if (inode->i_sb != sb) {
			spin_unlock(&inode->i_lock);
L
Linus Torvalds 已提交
713
			continue;
714 715 716
		}
		if (!test(inode, data)) {
			spin_unlock(&inode->i_lock);
L
Linus Torvalds 已提交
717
			continue;
718
		}
A
Al Viro 已提交
719
		if (inode->i_state & (I_FREEING|I_WILL_FREE)) {
L
Linus Torvalds 已提交
720 721 722
			__wait_on_freeing_inode(inode);
			goto repeat;
		}
723
		__iget(inode);
724
		spin_unlock(&inode->i_lock);
725
		return inode;
L
Linus Torvalds 已提交
726
	}
727
	return NULL;
L
Linus Torvalds 已提交
728 729 730 731 732 733
}

/*
 * find_inode_fast is the fast path version of find_inode, see the comment at
 * iget_locked for details.
 */
734 735
static struct inode *find_inode_fast(struct super_block *sb,
				struct hlist_head *head, unsigned long ino)
L
Linus Torvalds 已提交
736 737
{
	struct hlist_node *node;
738
	struct inode *inode = NULL;
L
Linus Torvalds 已提交
739 740

repeat:
741
	hlist_for_each_entry(inode, node, head, i_hash) {
742 743 744
		spin_lock(&inode->i_lock);
		if (inode->i_ino != ino) {
			spin_unlock(&inode->i_lock);
L
Linus Torvalds 已提交
745
			continue;
746 747 748
		}
		if (inode->i_sb != sb) {
			spin_unlock(&inode->i_lock);
L
Linus Torvalds 已提交
749
			continue;
750
		}
A
Al Viro 已提交
751
		if (inode->i_state & (I_FREEING|I_WILL_FREE)) {
L
Linus Torvalds 已提交
752 753 754
			__wait_on_freeing_inode(inode);
			goto repeat;
		}
755
		__iget(inode);
756
		spin_unlock(&inode->i_lock);
757
		return inode;
L
Linus Torvalds 已提交
758
	}
759
	return NULL;
760 761
}

762 763 764 765
/*
 * Each cpu owns a range of LAST_INO_BATCH numbers.
 * 'shared_last_ino' is dirtied only once out of LAST_INO_BATCH allocations,
 * to renew the exhausted range.
766
 *
767 768 769 770 771 772 773 774 775
 * This does not significantly increase overflow rate because every CPU can
 * consume at most LAST_INO_BATCH-1 unused inode numbers. So there is
 * NR_CPUS*(LAST_INO_BATCH-1) wastage. At 4096 and 1024, this is ~0.1% of the
 * 2^32 range, and is a worst-case. Even a 50% wastage would only increase
 * overflow rate by 2x, which does not seem too significant.
 *
 * On a 32bit, non LFS stat() call, glibc will generate an EOVERFLOW
 * error if st_ino won't fit in target struct field. Use 32bit counter
 * here to attempt to avoid that.
776
 */
777 778 779
#define LAST_INO_BATCH 1024
static DEFINE_PER_CPU(unsigned int, last_ino);

780
unsigned int get_next_ino(void)
781
{
782 783
	unsigned int *p = &get_cpu_var(last_ino);
	unsigned int res = *p;
784

785 786 787 788 789 790 791 792 793 794 795 796
#ifdef CONFIG_SMP
	if (unlikely((res & (LAST_INO_BATCH-1)) == 0)) {
		static atomic_t shared_last_ino;
		int next = atomic_add_return(LAST_INO_BATCH, &shared_last_ino);

		res = next - LAST_INO_BATCH;
	}
#endif

	*p = ++res;
	put_cpu_var(last_ino);
	return res;
797
}
798
EXPORT_SYMBOL(get_next_ino);
799

L
Linus Torvalds 已提交
800 801 802 803
/**
 *	new_inode 	- obtain an inode
 *	@sb: superblock
 *
804
 *	Allocates a new inode for given superblock. The default gfp_mask
H
Hugh Dickins 已提交
805
 *	for allocations related to inode->i_mapping is GFP_HIGHUSER_MOVABLE.
806 807 808 809 810
 *	If HIGHMEM pages are unsuitable or it is known that pages allocated
 *	for the page cache are not reclaimable or migratable,
 *	mapping_set_gfp_mask() must be called with suitable flags on the
 *	newly created inode's mapping
 *
L
Linus Torvalds 已提交
811 812 813
 */
struct inode *new_inode(struct super_block *sb)
{
814
	struct inode *inode;
L
Linus Torvalds 已提交
815

816
	spin_lock_prefetch(&inode_sb_list_lock);
817

L
Linus Torvalds 已提交
818 819
	inode = alloc_inode(sb);
	if (inode) {
820
		spin_lock(&inode->i_lock);
L
Linus Torvalds 已提交
821
		inode->i_state = 0;
822
		spin_unlock(&inode->i_lock);
823
		inode_sb_list_add(inode);
L
Linus Torvalds 已提交
824 825 826 827 828
	}
	return inode;
}
EXPORT_SYMBOL(new_inode);

829 830 831 832 833 834 835
/**
 * unlock_new_inode - clear the I_NEW state and wake up any waiters
 * @inode:	new inode to unlock
 *
 * Called when the inode is fully initialised to clear the new state of the
 * inode and wake up anyone waiting for the inode to finish initialisation.
 */
L
Linus Torvalds 已提交
836 837
void unlock_new_inode(struct inode *inode)
{
838
#ifdef CONFIG_DEBUG_LOCK_ALLOC
839
	if (S_ISDIR(inode->i_mode)) {
840 841
		struct file_system_type *type = inode->i_sb->s_type;

842 843 844 845 846 847 848 849 850 851 852
		/* Set new key only if filesystem hasn't already changed it */
		if (!lockdep_match_class(&inode->i_mutex,
		    &type->i_mutex_key)) {
			/*
			 * ensure nobody is actually holding i_mutex
			 */
			mutex_destroy(&inode->i_mutex);
			mutex_init(&inode->i_mutex);
			lockdep_set_class(&inode->i_mutex,
					  &type->i_mutex_dir_key);
		}
853
	}
854
#endif
855
	spin_lock(&inode->i_lock);
C
Christoph Hellwig 已提交
856 857
	WARN_ON(!(inode->i_state & I_NEW));
	inode->i_state &= ~I_NEW;
858 859
	wake_up_bit(&inode->i_state, __I_NEW);
	spin_unlock(&inode->i_lock);
L
Linus Torvalds 已提交
860 861 862
}
EXPORT_SYMBOL(unlock_new_inode);

C
Christoph Hellwig 已提交
863 864 865 866 867 868 869 870 871 872 873 874 875 876 877 878
/**
 * iget5_locked - obtain an inode from a mounted file system
 * @sb:		super block of file system
 * @hashval:	hash value (usually inode number) to get
 * @test:	callback used for comparisons between inodes
 * @set:	callback used to initialize a new struct inode
 * @data:	opaque data pointer to pass to @test and @set
 *
 * Search for the inode specified by @hashval and @data in the inode cache,
 * and if present it is return it with an increased reference count. This is
 * a generalized version of iget_locked() for file systems where the inode
 * number is not sufficient for unique identification of an inode.
 *
 * If the inode is not in cache, allocate a new inode and return it locked,
 * hashed, and with the I_NEW flag set. The file system gets to fill it in
 * before unlocking it via unlock_new_inode().
L
Linus Torvalds 已提交
879
 *
C
Christoph Hellwig 已提交
880 881
 * Note both @test and @set are called with the inode_hash_lock held, so can't
 * sleep.
L
Linus Torvalds 已提交
882
 */
C
Christoph Hellwig 已提交
883 884 885
struct inode *iget5_locked(struct super_block *sb, unsigned long hashval,
		int (*test)(struct inode *, void *),
		int (*set)(struct inode *, void *), void *data)
L
Linus Torvalds 已提交
886
{
C
Christoph Hellwig 已提交
887
	struct hlist_head *head = inode_hashtable + hash(sb, hashval);
888
	struct inode *inode;
L
Linus Torvalds 已提交
889

C
Christoph Hellwig 已提交
890 891 892 893 894 895 896 897 898
	spin_lock(&inode_hash_lock);
	inode = find_inode(sb, head, test, data);
	spin_unlock(&inode_hash_lock);

	if (inode) {
		wait_on_inode(inode);
		return inode;
	}

L
Linus Torvalds 已提交
899 900
	inode = alloc_inode(sb);
	if (inode) {
901
		struct inode *old;
L
Linus Torvalds 已提交
902

903
		spin_lock(&inode_hash_lock);
L
Linus Torvalds 已提交
904 905 906 907 908 909
		/* We released the lock, so.. */
		old = find_inode(sb, head, test, data);
		if (!old) {
			if (set(inode, data))
				goto set_failed;

910 911
			spin_lock(&inode->i_lock);
			inode->i_state = I_NEW;
912
			hlist_add_head(&inode->i_hash, head);
913
			spin_unlock(&inode->i_lock);
914
			inode_sb_list_add(inode);
915
			spin_unlock(&inode_hash_lock);
L
Linus Torvalds 已提交
916 917 918 919 920 921 922 923 924 925 926 927

			/* Return the locked inode with I_NEW set, the
			 * caller is responsible for filling in the contents
			 */
			return inode;
		}

		/*
		 * Uhhuh, somebody else created the same inode under
		 * us. Use the old inode instead of the one we just
		 * allocated.
		 */
928
		spin_unlock(&inode_hash_lock);
L
Linus Torvalds 已提交
929 930 931 932 933 934 935
		destroy_inode(inode);
		inode = old;
		wait_on_inode(inode);
	}
	return inode;

set_failed:
936
	spin_unlock(&inode_hash_lock);
L
Linus Torvalds 已提交
937 938 939
	destroy_inode(inode);
	return NULL;
}
C
Christoph Hellwig 已提交
940
EXPORT_SYMBOL(iget5_locked);
L
Linus Torvalds 已提交
941

C
Christoph Hellwig 已提交
942 943 944 945 946 947 948 949 950 951 952 953
/**
 * iget_locked - obtain an inode from a mounted file system
 * @sb:		super block of file system
 * @ino:	inode number to get
 *
 * Search for the inode specified by @ino in the inode cache and if present
 * return it with an increased reference count. This is for file systems
 * where the inode number is sufficient for unique identification of an inode.
 *
 * If the inode is not in cache, allocate a new inode and return it locked,
 * hashed, and with the I_NEW flag set.  The file system gets to fill it in
 * before unlocking it via unlock_new_inode().
L
Linus Torvalds 已提交
954
 */
C
Christoph Hellwig 已提交
955
struct inode *iget_locked(struct super_block *sb, unsigned long ino)
L
Linus Torvalds 已提交
956
{
C
Christoph Hellwig 已提交
957
	struct hlist_head *head = inode_hashtable + hash(sb, ino);
958
	struct inode *inode;
L
Linus Torvalds 已提交
959

C
Christoph Hellwig 已提交
960 961 962 963 964 965 966 967
	spin_lock(&inode_hash_lock);
	inode = find_inode_fast(sb, head, ino);
	spin_unlock(&inode_hash_lock);
	if (inode) {
		wait_on_inode(inode);
		return inode;
	}

L
Linus Torvalds 已提交
968 969
	inode = alloc_inode(sb);
	if (inode) {
970
		struct inode *old;
L
Linus Torvalds 已提交
971

972
		spin_lock(&inode_hash_lock);
L
Linus Torvalds 已提交
973 974 975 976
		/* We released the lock, so.. */
		old = find_inode_fast(sb, head, ino);
		if (!old) {
			inode->i_ino = ino;
977 978
			spin_lock(&inode->i_lock);
			inode->i_state = I_NEW;
979
			hlist_add_head(&inode->i_hash, head);
980
			spin_unlock(&inode->i_lock);
981
			inode_sb_list_add(inode);
982
			spin_unlock(&inode_hash_lock);
L
Linus Torvalds 已提交
983 984 985 986 987 988 989 990 991 992 993 994

			/* Return the locked inode with I_NEW set, the
			 * caller is responsible for filling in the contents
			 */
			return inode;
		}

		/*
		 * Uhhuh, somebody else created the same inode under
		 * us. Use the old inode instead of the one we just
		 * allocated.
		 */
995
		spin_unlock(&inode_hash_lock);
L
Linus Torvalds 已提交
996 997 998 999 1000 1001
		destroy_inode(inode);
		inode = old;
		wait_on_inode(inode);
	}
	return inode;
}
C
Christoph Hellwig 已提交
1002
EXPORT_SYMBOL(iget_locked);
L
Linus Torvalds 已提交
1003

1004 1005 1006 1007 1008 1009 1010 1011 1012 1013 1014 1015 1016
/*
 * search the inode cache for a matching inode number.
 * If we find one, then the inode number we are trying to
 * allocate is not unique and so we should not use it.
 *
 * Returns 1 if the inode number is unique, 0 if it is not.
 */
static int test_inode_iunique(struct super_block *sb, unsigned long ino)
{
	struct hlist_head *b = inode_hashtable + hash(sb, ino);
	struct hlist_node *node;
	struct inode *inode;

1017
	spin_lock(&inode_hash_lock);
1018
	hlist_for_each_entry(inode, node, b, i_hash) {
1019 1020
		if (inode->i_ino == ino && inode->i_sb == sb) {
			spin_unlock(&inode_hash_lock);
1021
			return 0;
1022
		}
1023
	}
1024
	spin_unlock(&inode_hash_lock);
1025 1026 1027 1028

	return 1;
}

L
Linus Torvalds 已提交
1029 1030 1031 1032 1033 1034 1035 1036 1037 1038 1039 1040 1041 1042 1043 1044
/**
 *	iunique - get a unique inode number
 *	@sb: superblock
 *	@max_reserved: highest reserved inode number
 *
 *	Obtain an inode number that is unique on the system for a given
 *	superblock. This is used by file systems that have no natural
 *	permanent inode numbering system. An inode number is returned that
 *	is higher than the reserved limit but unique.
 *
 *	BUGS:
 *	With a large number of inodes live on the file system this function
 *	currently becomes quite slow.
 */
ino_t iunique(struct super_block *sb, ino_t max_reserved)
{
1045 1046 1047 1048 1049
	/*
	 * On a 32bit, non LFS stat() call, glibc will generate an EOVERFLOW
	 * error if st_ino won't fit in target struct field. Use 32bit counter
	 * here to attempt to avoid that.
	 */
1050
	static DEFINE_SPINLOCK(iunique_lock);
1051
	static unsigned int counter;
L
Linus Torvalds 已提交
1052
	ino_t res;
1053

1054
	spin_lock(&iunique_lock);
1055 1056 1057
	do {
		if (counter <= max_reserved)
			counter = max_reserved + 1;
L
Linus Torvalds 已提交
1058
		res = counter++;
1059 1060
	} while (!test_inode_iunique(sb, res));
	spin_unlock(&iunique_lock);
L
Linus Torvalds 已提交
1061

1062 1063
	return res;
}
L
Linus Torvalds 已提交
1064 1065 1066 1067
EXPORT_SYMBOL(iunique);

struct inode *igrab(struct inode *inode)
{
1068 1069
	spin_lock(&inode->i_lock);
	if (!(inode->i_state & (I_FREEING|I_WILL_FREE))) {
L
Linus Torvalds 已提交
1070
		__iget(inode);
1071 1072 1073
		spin_unlock(&inode->i_lock);
	} else {
		spin_unlock(&inode->i_lock);
L
Linus Torvalds 已提交
1074 1075 1076 1077 1078 1079
		/*
		 * Handle the case where s_op->clear_inode is not been
		 * called yet, and somebody is calling igrab
		 * while the inode is getting freed.
		 */
		inode = NULL;
1080
	}
L
Linus Torvalds 已提交
1081 1082 1083 1084 1085
	return inode;
}
EXPORT_SYMBOL(igrab);

/**
C
Christoph Hellwig 已提交
1086
 * ilookup5_nowait - search for an inode in the inode cache
L
Linus Torvalds 已提交
1087
 * @sb:		super block of file system to search
C
Christoph Hellwig 已提交
1088
 * @hashval:	hash value (usually inode number) to search for
L
Linus Torvalds 已提交
1089 1090 1091
 * @test:	callback used for comparisons between inodes
 * @data:	opaque data pointer to pass to @test
 *
C
Christoph Hellwig 已提交
1092
 * Search for the inode specified by @hashval and @data in the inode cache.
L
Linus Torvalds 已提交
1093 1094 1095
 * If the inode is in the cache, the inode is returned with an incremented
 * reference count.
 *
C
Christoph Hellwig 已提交
1096 1097
 * Note: I_NEW is not waited upon so you have to be very careful what you do
 * with the returned inode.  You probably should be using ilookup5() instead.
L
Linus Torvalds 已提交
1098
 *
1099
 * Note2: @test is called with the inode_hash_lock held, so can't sleep.
L
Linus Torvalds 已提交
1100
 */
C
Christoph Hellwig 已提交
1101 1102
struct inode *ilookup5_nowait(struct super_block *sb, unsigned long hashval,
		int (*test)(struct inode *, void *), void *data)
L
Linus Torvalds 已提交
1103
{
C
Christoph Hellwig 已提交
1104
	struct hlist_head *head = inode_hashtable + hash(sb, hashval);
L
Linus Torvalds 已提交
1105 1106
	struct inode *inode;

1107
	spin_lock(&inode_hash_lock);
L
Linus Torvalds 已提交
1108
	inode = find_inode(sb, head, test, data);
1109
	spin_unlock(&inode_hash_lock);
1110

C
Christoph Hellwig 已提交
1111
	return inode;
1112 1113 1114 1115 1116 1117 1118 1119 1120 1121
}
EXPORT_SYMBOL(ilookup5_nowait);

/**
 * ilookup5 - search for an inode in the inode cache
 * @sb:		super block of file system to search
 * @hashval:	hash value (usually inode number) to search for
 * @test:	callback used for comparisons between inodes
 * @data:	opaque data pointer to pass to @test
 *
C
Christoph Hellwig 已提交
1122 1123 1124
 * Search for the inode specified by @hashval and @data in the inode cache,
 * and if the inode is in the cache, return the inode with an incremented
 * reference count.  Waits on I_NEW before returning the inode.
1125
 * returned with an incremented reference count.
L
Linus Torvalds 已提交
1126
 *
C
Christoph Hellwig 已提交
1127 1128
 * This is a generalized version of ilookup() for file systems where the
 * inode number is not sufficient for unique identification of an inode.
L
Linus Torvalds 已提交
1129
 *
C
Christoph Hellwig 已提交
1130
 * Note: @test is called with the inode_hash_lock held, so can't sleep.
L
Linus Torvalds 已提交
1131 1132 1133 1134
 */
struct inode *ilookup5(struct super_block *sb, unsigned long hashval,
		int (*test)(struct inode *, void *), void *data)
{
C
Christoph Hellwig 已提交
1135
	struct inode *inode = ilookup5_nowait(sb, hashval, test, data);
L
Linus Torvalds 已提交
1136

C
Christoph Hellwig 已提交
1137 1138 1139
	if (inode)
		wait_on_inode(inode);
	return inode;
L
Linus Torvalds 已提交
1140 1141 1142 1143 1144 1145 1146 1147
}
EXPORT_SYMBOL(ilookup5);

/**
 * ilookup - search for an inode in the inode cache
 * @sb:		super block of file system to search
 * @ino:	inode number to search for
 *
C
Christoph Hellwig 已提交
1148 1149
 * Search for the inode @ino in the inode cache, and if the inode is in the
 * cache, the inode is returned with an incremented reference count.
L
Linus Torvalds 已提交
1150 1151 1152 1153 1154 1155
 */
struct inode *ilookup(struct super_block *sb, unsigned long ino)
{
	struct hlist_head *head = inode_hashtable + hash(sb, ino);
	struct inode *inode;

C
Christoph Hellwig 已提交
1156 1157 1158
	spin_lock(&inode_hash_lock);
	inode = find_inode_fast(sb, head, ino);
	spin_unlock(&inode_hash_lock);
L
Linus Torvalds 已提交
1159 1160

	if (inode)
C
Christoph Hellwig 已提交
1161 1162
		wait_on_inode(inode);
	return inode;
L
Linus Torvalds 已提交
1163
}
C
Christoph Hellwig 已提交
1164
EXPORT_SYMBOL(ilookup);
L
Linus Torvalds 已提交
1165

A
Al Viro 已提交
1166 1167 1168 1169 1170 1171 1172
int insert_inode_locked(struct inode *inode)
{
	struct super_block *sb = inode->i_sb;
	ino_t ino = inode->i_ino;
	struct hlist_head *head = inode_hashtable + hash(sb, ino);

	while (1) {
1173 1174
		struct hlist_node *node;
		struct inode *old = NULL;
1175
		spin_lock(&inode_hash_lock);
1176 1177 1178 1179 1180
		hlist_for_each_entry(old, node, head, i_hash) {
			if (old->i_ino != ino)
				continue;
			if (old->i_sb != sb)
				continue;
1181 1182 1183
			spin_lock(&old->i_lock);
			if (old->i_state & (I_FREEING|I_WILL_FREE)) {
				spin_unlock(&old->i_lock);
1184
				continue;
1185
			}
1186 1187 1188
			break;
		}
		if (likely(!node)) {
1189 1190
			spin_lock(&inode->i_lock);
			inode->i_state |= I_NEW;
A
Al Viro 已提交
1191
			hlist_add_head(&inode->i_hash, head);
1192
			spin_unlock(&inode->i_lock);
1193
			spin_unlock(&inode_hash_lock);
A
Al Viro 已提交
1194 1195 1196
			return 0;
		}
		__iget(old);
1197
		spin_unlock(&old->i_lock);
1198
		spin_unlock(&inode_hash_lock);
A
Al Viro 已提交
1199
		wait_on_inode(old);
A
Al Viro 已提交
1200
		if (unlikely(!inode_unhashed(old))) {
A
Al Viro 已提交
1201 1202 1203 1204 1205 1206 1207 1208 1209 1210 1211 1212 1213 1214 1215
			iput(old);
			return -EBUSY;
		}
		iput(old);
	}
}
EXPORT_SYMBOL(insert_inode_locked);

int insert_inode_locked4(struct inode *inode, unsigned long hashval,
		int (*test)(struct inode *, void *), void *data)
{
	struct super_block *sb = inode->i_sb;
	struct hlist_head *head = inode_hashtable + hash(sb, hashval);

	while (1) {
1216 1217 1218
		struct hlist_node *node;
		struct inode *old = NULL;

1219
		spin_lock(&inode_hash_lock);
1220 1221 1222 1223 1224
		hlist_for_each_entry(old, node, head, i_hash) {
			if (old->i_sb != sb)
				continue;
			if (!test(old, data))
				continue;
1225 1226 1227
			spin_lock(&old->i_lock);
			if (old->i_state & (I_FREEING|I_WILL_FREE)) {
				spin_unlock(&old->i_lock);
1228
				continue;
1229
			}
1230 1231 1232
			break;
		}
		if (likely(!node)) {
1233 1234
			spin_lock(&inode->i_lock);
			inode->i_state |= I_NEW;
A
Al Viro 已提交
1235
			hlist_add_head(&inode->i_hash, head);
1236
			spin_unlock(&inode->i_lock);
1237
			spin_unlock(&inode_hash_lock);
A
Al Viro 已提交
1238 1239 1240
			return 0;
		}
		__iget(old);
1241
		spin_unlock(&old->i_lock);
1242
		spin_unlock(&inode_hash_lock);
A
Al Viro 已提交
1243
		wait_on_inode(old);
A
Al Viro 已提交
1244
		if (unlikely(!inode_unhashed(old))) {
A
Al Viro 已提交
1245 1246 1247 1248 1249 1250 1251 1252
			iput(old);
			return -EBUSY;
		}
		iput(old);
	}
}
EXPORT_SYMBOL(insert_inode_locked4);

L
Linus Torvalds 已提交
1253

1254 1255 1256 1257 1258 1259
int generic_delete_inode(struct inode *inode)
{
	return 1;
}
EXPORT_SYMBOL(generic_delete_inode);

L
Linus Torvalds 已提交
1260
/*
1261 1262 1263
 * Normal UNIX filesystem behaviour: delete the
 * inode when the usage count drops to zero, and
 * i_nlink is zero.
L
Linus Torvalds 已提交
1264
 */
1265
int generic_drop_inode(struct inode *inode)
L
Linus Torvalds 已提交
1266
{
A
Al Viro 已提交
1267
	return !inode->i_nlink || inode_unhashed(inode);
L
Linus Torvalds 已提交
1268
}
1269
EXPORT_SYMBOL_GPL(generic_drop_inode);
L
Linus Torvalds 已提交
1270

1271 1272 1273
/*
 * Called when we're dropping the last reference
 * to an inode.
1274
 *
1275 1276 1277 1278 1279
 * Call the FS "drop_inode()" function, defaulting to
 * the legacy UNIX filesystem behaviour.  If it tells
 * us to evict inode, do so.  Otherwise, retain inode
 * in cache if fs is alive, sync and evict if fs is
 * shutting down.
1280
 */
1281
static void iput_final(struct inode *inode)
L
Linus Torvalds 已提交
1282 1283
{
	struct super_block *sb = inode->i_sb;
1284 1285 1286
	const struct super_operations *op = inode->i_sb->s_op;
	int drop;

1287 1288
	WARN_ON(inode->i_state & I_NEW);

1289
	if (op->drop_inode)
1290 1291 1292
		drop = op->drop_inode(inode);
	else
		drop = generic_drop_inode(inode);
L
Linus Torvalds 已提交
1293

D
Dave Chinner 已提交
1294 1295 1296 1297 1298 1299 1300 1301
	if (!drop && (sb->s_flags & MS_ACTIVE)) {
		inode->i_state |= I_REFERENCED;
		if (!(inode->i_state & (I_DIRTY|I_SYNC)))
			inode_lru_list_add(inode);
		spin_unlock(&inode->i_lock);
		return;
	}

1302
	if (!drop) {
1303
		inode->i_state |= I_WILL_FREE;
1304
		spin_unlock(&inode->i_lock);
L
Linus Torvalds 已提交
1305
		write_inode_now(inode, 1);
1306
		spin_lock(&inode->i_lock);
1307
		WARN_ON(inode->i_state & I_NEW);
1308
		inode->i_state &= ~I_WILL_FREE;
L
Linus Torvalds 已提交
1309
	}
N
Nick Piggin 已提交
1310

1311
	inode->i_state |= I_FREEING;
1312
	inode_lru_list_del(inode);
D
Dave Chinner 已提交
1313 1314
	spin_unlock(&inode->i_lock);

1315
	evict(inode);
L
Linus Torvalds 已提交
1316 1317 1318
}

/**
1319
 *	iput	- put an inode
L
Linus Torvalds 已提交
1320 1321 1322 1323 1324 1325 1326 1327 1328 1329
 *	@inode: inode to put
 *
 *	Puts an inode, dropping its usage count. If the inode use count hits
 *	zero, the inode is then freed and may also be destroyed.
 *
 *	Consequently, iput() can sleep.
 */
void iput(struct inode *inode)
{
	if (inode) {
A
Al Viro 已提交
1330
		BUG_ON(inode->i_state & I_CLEAR);
L
Linus Torvalds 已提交
1331

1332
		if (atomic_dec_and_lock(&inode->i_count, &inode->i_lock))
L
Linus Torvalds 已提交
1333 1334 1335 1336 1337 1338 1339 1340 1341 1342 1343 1344 1345
			iput_final(inode);
	}
}
EXPORT_SYMBOL(iput);

/**
 *	bmap	- find a block number in a file
 *	@inode: inode of file
 *	@block: block to find
 *
 *	Returns the block number on the device holding the inode that
 *	is the disk block number for the block of the file requested.
 *	That is, asked for block 4 of inode 1 the function will return the
1346
 *	disk block relative to the disk start that holds that block of the
L
Linus Torvalds 已提交
1347 1348
 *	file.
 */
1349
sector_t bmap(struct inode *inode, sector_t block)
L
Linus Torvalds 已提交
1350 1351 1352 1353 1354 1355 1356 1357
{
	sector_t res = 0;
	if (inode->i_mapping->a_ops->bmap)
		res = inode->i_mapping->a_ops->bmap(inode->i_mapping, block);
	return res;
}
EXPORT_SYMBOL(bmap);

1358 1359 1360 1361 1362 1363 1364 1365 1366 1367 1368 1369 1370 1371 1372 1373 1374 1375 1376 1377 1378 1379 1380 1381 1382 1383 1384 1385 1386 1387 1388 1389 1390 1391
/*
 * With relative atime, only update atime if the previous atime is
 * earlier than either the ctime or mtime or if at least a day has
 * passed since the last atime update.
 */
static int relatime_need_update(struct vfsmount *mnt, struct inode *inode,
			     struct timespec now)
{

	if (!(mnt->mnt_flags & MNT_RELATIME))
		return 1;
	/*
	 * Is mtime younger than atime? If yes, update atime:
	 */
	if (timespec_compare(&inode->i_mtime, &inode->i_atime) >= 0)
		return 1;
	/*
	 * Is ctime younger than atime? If yes, update atime:
	 */
	if (timespec_compare(&inode->i_ctime, &inode->i_atime) >= 0)
		return 1;

	/*
	 * Is the previous atime value older than a day? If yes,
	 * update atime:
	 */
	if ((long)(now.tv_sec - inode->i_atime.tv_sec) >= 24*60*60)
		return 1;
	/*
	 * Good, we can skip the atime update:
	 */
	return 0;
}

L
Linus Torvalds 已提交
1392
/**
C
Christoph Hellwig 已提交
1393 1394
 *	touch_atime	-	update the access time
 *	@mnt: mount the inode is accessed on
1395
 *	@dentry: dentry accessed
L
Linus Torvalds 已提交
1396 1397 1398 1399 1400
 *
 *	Update the accessed time on an inode and mark it for writeback.
 *	This function automatically handles read only file systems and media,
 *	as well as the "noatime" flag and inode specific "noatime" markers.
 */
C
Christoph Hellwig 已提交
1401
void touch_atime(struct vfsmount *mnt, struct dentry *dentry)
L
Linus Torvalds 已提交
1402
{
C
Christoph Hellwig 已提交
1403
	struct inode *inode = dentry->d_inode;
L
Linus Torvalds 已提交
1404 1405
	struct timespec now;

1406
	if (inode->i_flags & S_NOATIME)
A
Andi Kleen 已提交
1407
		return;
1408
	if (IS_NOATIME(inode))
A
Andi Kleen 已提交
1409
		return;
A
Andrew Morton 已提交
1410
	if ((inode->i_sb->s_flags & MS_NODIRATIME) && S_ISDIR(inode->i_mode))
A
Andi Kleen 已提交
1411
		return;
V
Valerie Henson 已提交
1412

1413
	if (mnt->mnt_flags & MNT_NOATIME)
A
Andi Kleen 已提交
1414
		return;
1415
	if ((mnt->mnt_flags & MNT_NODIRATIME) && S_ISDIR(inode->i_mode))
A
Andi Kleen 已提交
1416
		return;
L
Linus Torvalds 已提交
1417 1418

	now = current_fs_time(inode->i_sb);
1419 1420

	if (!relatime_need_update(mnt, inode, now))
A
Andi Kleen 已提交
1421
		return;
1422

V
Valerie Henson 已提交
1423
	if (timespec_equal(&inode->i_atime, &now))
A
Andi Kleen 已提交
1424 1425 1426 1427
		return;

	if (mnt_want_write(mnt))
		return;
V
Valerie Henson 已提交
1428 1429 1430

	inode->i_atime = now;
	mark_inode_dirty_sync(inode);
1431
	mnt_drop_write(mnt);
L
Linus Torvalds 已提交
1432
}
C
Christoph Hellwig 已提交
1433
EXPORT_SYMBOL(touch_atime);
L
Linus Torvalds 已提交
1434 1435

/**
1436 1437
 *	file_update_time	-	update mtime and ctime time
 *	@file: file accessed
L
Linus Torvalds 已提交
1438
 *
1439 1440 1441 1442
 *	Update the mtime and ctime members of an inode and mark the inode
 *	for writeback.  Note that this function is meant exclusively for
 *	usage in the file write path of filesystems, and filesystems may
 *	choose to explicitly ignore update via this function with the
1443
 *	S_NOCMTIME inode flag, e.g. for network filesystem where these
1444
 *	timestamps are handled by the server.
L
Linus Torvalds 已提交
1445 1446
 */

1447
void file_update_time(struct file *file)
L
Linus Torvalds 已提交
1448
{
1449
	struct inode *inode = file->f_path.dentry->d_inode;
L
Linus Torvalds 已提交
1450
	struct timespec now;
A
Andi Kleen 已提交
1451
	enum { S_MTIME = 1, S_CTIME = 2, S_VERSION = 4 } sync_it = 0;
L
Linus Torvalds 已提交
1452

A
Andi Kleen 已提交
1453
	/* First try to exhaust all avenues to not sync */
L
Linus Torvalds 已提交
1454 1455
	if (IS_NOCMTIME(inode))
		return;
1456

L
Linus Torvalds 已提交
1457
	now = current_fs_time(inode->i_sb);
A
Andi Kleen 已提交
1458 1459
	if (!timespec_equal(&inode->i_mtime, &now))
		sync_it = S_MTIME;
L
Linus Torvalds 已提交
1460

A
Andi Kleen 已提交
1461 1462
	if (!timespec_equal(&inode->i_ctime, &now))
		sync_it |= S_CTIME;
1463

A
Andi Kleen 已提交
1464 1465
	if (IS_I_VERSION(inode))
		sync_it |= S_VERSION;
1466

A
Andi Kleen 已提交
1467 1468 1469 1470 1471 1472 1473 1474 1475 1476 1477 1478 1479 1480 1481
	if (!sync_it)
		return;

	/* Finally allowed to write? Takes lock. */
	if (mnt_want_write_file(file))
		return;

	/* Only change inode inside the lock region */
	if (sync_it & S_VERSION)
		inode_inc_iversion(inode);
	if (sync_it & S_CTIME)
		inode->i_ctime = now;
	if (sync_it & S_MTIME)
		inode->i_mtime = now;
	mark_inode_dirty_sync(inode);
1482
	mnt_drop_write(file->f_path.mnt);
L
Linus Torvalds 已提交
1483
}
1484
EXPORT_SYMBOL(file_update_time);
L
Linus Torvalds 已提交
1485 1486 1487 1488 1489 1490 1491 1492 1493 1494 1495 1496 1497 1498 1499 1500

int inode_needs_sync(struct inode *inode)
{
	if (IS_SYNC(inode))
		return 1;
	if (S_ISDIR(inode->i_mode) && IS_DIRSYNC(inode))
		return 1;
	return 0;
}
EXPORT_SYMBOL(inode_needs_sync);

int inode_wait(void *word)
{
	schedule();
	return 0;
}
1501
EXPORT_SYMBOL(inode_wait);
L
Linus Torvalds 已提交
1502 1503

/*
1504 1505 1506 1507 1508 1509
 * If we try to find an inode in the inode hash while it is being
 * deleted, we have to wait until the filesystem completes its
 * deletion before reporting that it isn't found.  This function waits
 * until the deletion _might_ have completed.  Callers are responsible
 * to recheck inode state.
 *
C
Christoph Hellwig 已提交
1510
 * It doesn't matter if I_NEW is not set initially, a call to
1511 1512
 * wake_up_bit(&inode->i_state, __I_NEW) after removing from the hash list
 * will DTRT.
L
Linus Torvalds 已提交
1513 1514 1515 1516
 */
static void __wait_on_freeing_inode(struct inode *inode)
{
	wait_queue_head_t *wq;
C
Christoph Hellwig 已提交
1517 1518
	DEFINE_WAIT_BIT(wait, &inode->i_state, __I_NEW);
	wq = bit_waitqueue(&inode->i_state, __I_NEW);
L
Linus Torvalds 已提交
1519
	prepare_to_wait(wq, &wait.wait, TASK_UNINTERRUPTIBLE);
1520
	spin_unlock(&inode->i_lock);
1521
	spin_unlock(&inode_hash_lock);
L
Linus Torvalds 已提交
1522 1523
	schedule();
	finish_wait(wq, &wait.wait);
1524
	spin_lock(&inode_hash_lock);
L
Linus Torvalds 已提交
1525 1526 1527 1528 1529 1530 1531 1532 1533 1534 1535 1536 1537 1538 1539 1540 1541 1542 1543 1544 1545 1546 1547 1548 1549 1550 1551 1552 1553 1554 1555 1556 1557 1558 1559 1560 1561 1562 1563
}

static __initdata unsigned long ihash_entries;
static int __init set_ihash_entries(char *str)
{
	if (!str)
		return 0;
	ihash_entries = simple_strtoul(str, &str, 0);
	return 1;
}
__setup("ihash_entries=", set_ihash_entries);

/*
 * Initialize the waitqueues and inode hash table.
 */
void __init inode_init_early(void)
{
	int loop;

	/* If hashes are distributed across NUMA nodes, defer
	 * hash allocation until vmalloc space is available.
	 */
	if (hashdist)
		return;

	inode_hashtable =
		alloc_large_system_hash("Inode-cache",
					sizeof(struct hlist_head),
					ihash_entries,
					14,
					HASH_EARLY,
					&i_hash_shift,
					&i_hash_mask,
					0);

	for (loop = 0; loop < (1 << i_hash_shift); loop++)
		INIT_HLIST_HEAD(&inode_hashtable[loop]);
}

1564
void __init inode_init(void)
L
Linus Torvalds 已提交
1565 1566 1567 1568
{
	int loop;

	/* inode slab cache */
1569 1570 1571 1572 1573
	inode_cachep = kmem_cache_create("inode_cache",
					 sizeof(struct inode),
					 0,
					 (SLAB_RECLAIM_ACCOUNT|SLAB_PANIC|
					 SLAB_MEM_SPREAD),
1574
					 init_once);
L
Linus Torvalds 已提交
1575 1576 1577 1578 1579 1580 1581 1582 1583 1584 1585 1586 1587 1588 1589 1590 1591 1592 1593 1594 1595 1596 1597 1598 1599 1600 1601 1602 1603 1604 1605 1606 1607

	/* Hash may have been set up in inode_init_early */
	if (!hashdist)
		return;

	inode_hashtable =
		alloc_large_system_hash("Inode-cache",
					sizeof(struct hlist_head),
					ihash_entries,
					14,
					0,
					&i_hash_shift,
					&i_hash_mask,
					0);

	for (loop = 0; loop < (1 << i_hash_shift); loop++)
		INIT_HLIST_HEAD(&inode_hashtable[loop]);
}

void init_special_inode(struct inode *inode, umode_t mode, dev_t rdev)
{
	inode->i_mode = mode;
	if (S_ISCHR(mode)) {
		inode->i_fop = &def_chr_fops;
		inode->i_rdev = rdev;
	} else if (S_ISBLK(mode)) {
		inode->i_fop = &def_blk_fops;
		inode->i_rdev = rdev;
	} else if (S_ISFIFO(mode))
		inode->i_fop = &def_fifo_fops;
	else if (S_ISSOCK(mode))
		inode->i_fop = &bad_sock_fops;
	else
1608 1609 1610
		printk(KERN_DEBUG "init_special_inode: bogus i_mode (%o) for"
				  " inode %s:%lu\n", mode, inode->i_sb->s_id,
				  inode->i_ino);
L
Linus Torvalds 已提交
1611 1612
}
EXPORT_SYMBOL(init_special_inode);
1613 1614

/**
1615
 * inode_init_owner - Init uid,gid,mode for new inode according to posix standards
1616 1617 1618 1619 1620 1621 1622 1623 1624 1625 1626 1627 1628 1629 1630 1631 1632
 * @inode: New inode
 * @dir: Directory inode
 * @mode: mode of the new inode
 */
void inode_init_owner(struct inode *inode, const struct inode *dir,
			mode_t mode)
{
	inode->i_uid = current_fsuid();
	if (dir && dir->i_mode & S_ISGID) {
		inode->i_gid = dir->i_gid;
		if (S_ISDIR(mode))
			mode |= S_ISGID;
	} else
		inode->i_gid = current_fsgid();
	inode->i_mode = mode;
}
EXPORT_SYMBOL(inode_init_owner);
1633

1634 1635 1636 1637 1638 1639
/**
 * inode_owner_or_capable - check current task permissions to inode
 * @inode: inode being checked
 *
 * Return true if current either has CAP_FOWNER to the inode, or
 * owns the file.
1640
 */
1641
bool inode_owner_or_capable(const struct inode *inode)
1642 1643 1644 1645 1646 1647 1648 1649 1650
{
	struct user_namespace *ns = inode_userns(inode);

	if (current_user_ns() == ns && current_fsuid() == inode->i_uid)
		return true;
	if (ns_capable(ns, CAP_FOWNER))
		return true;
	return false;
}
1651
EXPORT_SYMBOL(inode_owner_or_capable);