inode.c 18.0 KB
Newer Older
J
Jaegeuk Kim 已提交
1
/*
J
Jaegeuk Kim 已提交
2 3 4 5 6 7 8 9 10 11 12 13
 * fs/f2fs/inode.c
 *
 * Copyright (c) 2012 Samsung Electronics Co., Ltd.
 *             http://www.samsung.com/
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License version 2 as
 * published by the Free Software Foundation.
 */
#include <linux/fs.h>
#include <linux/f2fs_fs.h>
#include <linux/buffer_head.h>
14
#include <linux/backing-dev.h>
J
Jaegeuk Kim 已提交
15 16 17 18
#include <linux/writeback.h>

#include "f2fs.h"
#include "node.h"
19
#include "segment.h"
J
Jaegeuk Kim 已提交
20

21 22
#include <trace/events/f2fs.h>

23
void f2fs_mark_inode_dirty_sync(struct inode *inode, bool sync)
J
Jaegeuk Kim 已提交
24
{
25 26 27
	if (is_inode_flag_set(inode, FI_NEW_INODE))
		return;

28
	if (f2fs_inode_dirtied(inode, sync))
J
Jaegeuk Kim 已提交
29
		return;
30

J
Jaegeuk Kim 已提交
31 32 33
	mark_inode_dirty_sync(inode);
}

J
Jaegeuk Kim 已提交
34 35 36
void f2fs_set_inode_flags(struct inode *inode)
{
	unsigned int flags = F2FS_I(inode)->i_flags;
37
	unsigned int new_fl = 0;
J
Jaegeuk Kim 已提交
38

39
	if (flags & F2FS_SYNC_FL)
40
		new_fl |= S_SYNC;
41
	if (flags & F2FS_APPEND_FL)
42
		new_fl |= S_APPEND;
43
	if (flags & F2FS_IMMUTABLE_FL)
44
		new_fl |= S_IMMUTABLE;
45
	if (flags & F2FS_NOATIME_FL)
46
		new_fl |= S_NOATIME;
47
	if (flags & F2FS_DIRSYNC_FL)
48
		new_fl |= S_DIRSYNC;
49 50
	if (f2fs_encrypted_inode(inode))
		new_fl |= S_ENCRYPTED;
Z
Zhang Zhen 已提交
51
	inode_set_flags(inode, new_fl,
52 53
			S_SYNC|S_APPEND|S_IMMUTABLE|S_NOATIME|S_DIRSYNC|
			S_ENCRYPTED);
J
Jaegeuk Kim 已提交
54 55
}

56 57
static void __get_inode_rdev(struct inode *inode, struct f2fs_inode *ri)
{
58 59
	int extra_size = get_extra_isize(inode);

60 61
	if (S_ISCHR(inode->i_mode) || S_ISBLK(inode->i_mode) ||
			S_ISFIFO(inode->i_mode) || S_ISSOCK(inode->i_mode)) {
62 63 64
		if (ri->i_addr[extra_size])
			inode->i_rdev = old_decode_dev(
				le32_to_cpu(ri->i_addr[extra_size]));
65
		else
66 67
			inode->i_rdev = new_decode_dev(
				le32_to_cpu(ri->i_addr[extra_size + 1]));
68 69 70
	}
}

71 72
static bool __written_first_block(struct f2fs_inode *ri)
{
73
	block_t addr = le32_to_cpu(ri->i_addr[offset_in_addr(ri)]);
J
Jaegeuk Kim 已提交
74

C
Chao Yu 已提交
75
	if (is_valid_blkaddr(addr))
76 77 78 79
		return true;
	return false;
}

80 81
static void __set_inode_rdev(struct inode *inode, struct f2fs_inode *ri)
{
82 83
	int extra_size = get_extra_isize(inode);

84 85
	if (S_ISCHR(inode->i_mode) || S_ISBLK(inode->i_mode)) {
		if (old_valid_dev(inode->i_rdev)) {
86
			ri->i_addr[extra_size] =
C
Chris Fries 已提交
87
				cpu_to_le32(old_encode_dev(inode->i_rdev));
88
			ri->i_addr[extra_size + 1] = 0;
89
		} else {
90 91
			ri->i_addr[extra_size] = 0;
			ri->i_addr[extra_size + 1] =
C
Chris Fries 已提交
92
				cpu_to_le32(new_encode_dev(inode->i_rdev));
93
			ri->i_addr[extra_size + 2] = 0;
94 95 96 97
		}
	}
}

98
static void __recover_inline_status(struct inode *inode, struct page *ipage)
99
{
C
Chao Yu 已提交
100
	void *inline_data = inline_data_addr(inode, ipage);
101
	__le32 *start = inline_data;
C
Chao Yu 已提交
102
	__le32 *end = start + MAX_INLINE_DATA(inode) / sizeof(__le32);
103

104 105
	while (start < end) {
		if (*start++) {
106
			f2fs_wait_on_page_writeback(ipage, NODE, true);
107

108 109
			set_inode_flag(inode, FI_DATA_EXIST);
			set_raw_inline(inode, F2FS_INODE(ipage));
110 111 112
			set_page_dirty(ipage);
			return;
		}
113
	}
114
	return;
115 116
}

C
Chao Yu 已提交
117 118 119 120 121 122 123 124 125 126
static bool f2fs_enable_inode_chksum(struct f2fs_sb_info *sbi, struct page *page)
{
	struct f2fs_inode *ri = &F2FS_NODE(page)->i;

	if (!f2fs_sb_has_inode_chksum(sbi->sb))
		return false;

	if (!RAW_IS_INODE(F2FS_NODE(page)) || !(ri->i_inline & F2FS_EXTRA_ATTR))
		return false;

127 128
	if (!F2FS_FITS_IN_INODE(ri, le16_to_cpu(ri->i_extra_isize),
				i_inode_checksum))
C
Chao Yu 已提交
129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161
		return false;

	return true;
}

static __u32 f2fs_inode_chksum(struct f2fs_sb_info *sbi, struct page *page)
{
	struct f2fs_node *node = F2FS_NODE(page);
	struct f2fs_inode *ri = &node->i;
	__le32 ino = node->footer.ino;
	__le32 gen = ri->i_generation;
	__u32 chksum, chksum_seed;
	__u32 dummy_cs = 0;
	unsigned int offset = offsetof(struct f2fs_inode, i_inode_checksum);
	unsigned int cs_size = sizeof(dummy_cs);

	chksum = f2fs_chksum(sbi, sbi->s_chksum_seed, (__u8 *)&ino,
							sizeof(ino));
	chksum_seed = f2fs_chksum(sbi, chksum, (__u8 *)&gen, sizeof(gen));

	chksum = f2fs_chksum(sbi, chksum_seed, (__u8 *)ri, offset);
	chksum = f2fs_chksum(sbi, chksum, (__u8 *)&dummy_cs, cs_size);
	offset += cs_size;
	chksum = f2fs_chksum(sbi, chksum, (__u8 *)ri + offset,
						F2FS_BLKSIZE - offset);
	return chksum;
}

bool f2fs_inode_chksum_verify(struct f2fs_sb_info *sbi, struct page *page)
{
	struct f2fs_inode *ri;
	__u32 provided, calculated;

162 163
	if (!f2fs_enable_inode_chksum(sbi, page) ||
			PageDirty(page) || PageWriteback(page))
C
Chao Yu 已提交
164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187
		return true;

	ri = &F2FS_NODE(page)->i;
	provided = le32_to_cpu(ri->i_inode_checksum);
	calculated = f2fs_inode_chksum(sbi, page);

	if (provided != calculated)
		f2fs_msg(sbi->sb, KERN_WARNING,
			"checksum invalid, ino = %x, %x vs. %x",
			ino_of_node(page), provided, calculated);

	return provided == calculated;
}

void f2fs_inode_chksum_set(struct f2fs_sb_info *sbi, struct page *page)
{
	struct f2fs_inode *ri = &F2FS_NODE(page)->i;

	if (!f2fs_enable_inode_chksum(sbi, page))
		return;

	ri->i_inode_checksum = cpu_to_le32(f2fs_inode_chksum(sbi, page));
}

188 189 190 191 192 193 194 195 196 197 198 199 200 201 202
static bool sanity_check_inode(struct inode *inode)
{
	struct f2fs_sb_info *sbi = F2FS_I_SB(inode);

	if (f2fs_sb_has_flexible_inline_xattr(sbi->sb)
			&& !f2fs_has_extra_attr(inode)) {
		set_sbi_flag(sbi, SBI_NEED_FSCK);
		f2fs_msg(sbi->sb, KERN_WARNING,
			"%s: corrupted inode ino=%lx, run fsck to fix.",
			__func__, inode->i_ino);
		return false;
	}
	return true;
}

J
Jaegeuk Kim 已提交
203 204
static int do_read_inode(struct inode *inode)
{
205
	struct f2fs_sb_info *sbi = F2FS_I_SB(inode);
J
Jaegeuk Kim 已提交
206 207 208
	struct f2fs_inode_info *fi = F2FS_I(inode);
	struct page *node_page;
	struct f2fs_inode *ri;
C
Chao Yu 已提交
209
	projid_t i_projid;
J
Jaegeuk Kim 已提交
210 211

	/* Check if ino is within scope */
212
	if (check_nid_range(sbi, inode->i_ino))
213
		return -EINVAL;
J
Jaegeuk Kim 已提交
214 215 216 217 218

	node_page = get_node_page(sbi, inode->i_ino);
	if (IS_ERR(node_page))
		return PTR_ERR(node_page);

219
	ri = F2FS_INODE(node_page);
J
Jaegeuk Kim 已提交
220 221 222 223 224 225

	inode->i_mode = le16_to_cpu(ri->i_mode);
	i_uid_write(inode, le32_to_cpu(ri->i_uid));
	i_gid_write(inode, le32_to_cpu(ri->i_gid));
	set_nlink(inode, le32_to_cpu(ri->i_links));
	inode->i_size = le64_to_cpu(ri->i_size);
226
	inode->i_blocks = SECTOR_FROM_BLOCK(le64_to_cpu(ri->i_blocks) - 1);
J
Jaegeuk Kim 已提交
227 228 229 230 231 232 233 234

	inode->i_atime.tv_sec = le64_to_cpu(ri->i_atime);
	inode->i_ctime.tv_sec = le64_to_cpu(ri->i_ctime);
	inode->i_mtime.tv_sec = le64_to_cpu(ri->i_mtime);
	inode->i_atime.tv_nsec = le32_to_cpu(ri->i_atime_nsec);
	inode->i_ctime.tv_nsec = le32_to_cpu(ri->i_ctime_nsec);
	inode->i_mtime.tv_nsec = le32_to_cpu(ri->i_mtime_nsec);
	inode->i_generation = le32_to_cpu(ri->i_generation);
235 236 237
	if (S_ISDIR(inode->i_mode))
		fi->i_current_depth = le32_to_cpu(ri->i_current_depth);
	else if (S_ISREG(inode->i_mode))
238 239
		fi->i_gc_failures[GC_FAILURE_PIN] =
					le16_to_cpu(ri->i_gc_failures);
J
Jaegeuk Kim 已提交
240 241 242 243
	fi->i_xattr_nid = le32_to_cpu(ri->i_xattr_nid);
	fi->i_flags = le32_to_cpu(ri->i_flags);
	fi->flags = 0;
	fi->i_advise = ri->i_advise;
244
	fi->i_pino = le32_to_cpu(ri->i_pino);
245
	fi->i_dir_level = ri->i_dir_level;
246

247 248
	if (f2fs_init_extent_tree(inode, &ri->i_ext))
		set_page_dirty(node_page);
249

250
	get_inline_info(inode, ri);
251

252 253 254
	fi->i_extra_isize = f2fs_has_extra_attr(inode) ?
					le16_to_cpu(ri->i_extra_isize) : 0;

C
Chao Yu 已提交
255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270
	if (f2fs_sb_has_flexible_inline_xattr(sbi->sb)) {
		fi->i_inline_xattr_size = le16_to_cpu(ri->i_inline_xattr_size);
	} else if (f2fs_has_inline_xattr(inode) ||
				f2fs_has_inline_dentry(inode)) {
		fi->i_inline_xattr_size = DEFAULT_INLINE_XATTR_ADDRS;
	} else {

		/*
		 * Previous inline data or directory always reserved 200 bytes
		 * in inode layout, even if inline_xattr is disabled. In order
		 * to keep inline_dentry's structure for backward compatibility,
		 * we get the space back only from inline_data.
		 */
		fi->i_inline_xattr_size = 0;
	}

271 272
	/* check data exist */
	if (f2fs_has_inline_data(inode) && !f2fs_exist_data(inode))
273
		__recover_inline_status(inode, node_page);
274

275 276 277
	/* get rdev by using inline_info */
	__get_inode_rdev(inode, ri);

278
	if (__written_first_block(ri))
279
		set_inode_flag(inode, FI_FIRST_BLOCK_WRITTEN);
280

281 282 283
	if (!need_inode_block_update(sbi, inode->i_ino))
		fi->last_disk_size = inode->i_size;

284
	if (fi->i_flags & F2FS_PROJINHERIT_FL)
C
Chao Yu 已提交
285 286 287 288 289 290 291 292 293
		set_inode_flag(inode, FI_PROJ_INHERIT);

	if (f2fs_has_extra_attr(inode) && f2fs_sb_has_project_quota(sbi->sb) &&
			F2FS_FITS_IN_INODE(ri, fi->i_extra_isize, i_projid))
		i_projid = (projid_t)le32_to_cpu(ri->i_projid);
	else
		i_projid = F2FS_DEF_PROJID;
	fi->i_projid = make_kprojid(&init_user_ns, i_projid);

C
Chao Yu 已提交
294 295 296 297 298 299
	if (f2fs_has_extra_attr(inode) && f2fs_sb_has_inode_crtime(sbi->sb) &&
			F2FS_FITS_IN_INODE(ri, fi->i_extra_isize, i_crtime)) {
		fi->i_crtime.tv_sec = le64_to_cpu(ri->i_crtime);
		fi->i_crtime.tv_nsec = le32_to_cpu(ri->i_crtime_nsec);
	}

300 301 302 303
	F2FS_I(inode)->i_disk_time[0] = inode->i_atime;
	F2FS_I(inode)->i_disk_time[1] = inode->i_ctime;
	F2FS_I(inode)->i_disk_time[2] = inode->i_mtime;
	F2FS_I(inode)->i_disk_time[3] = F2FS_I(inode)->i_crtime;
J
Jaegeuk Kim 已提交
304
	f2fs_put_page(node_page, 1);
305

C
Chao Yu 已提交
306
	stat_inc_inline_xattr(inode);
307 308 309
	stat_inc_inline_inode(inode);
	stat_inc_inline_dir(inode);

310
	return 0;
J
Jaegeuk Kim 已提交
311 312 313 314 315 316
}

struct inode *f2fs_iget(struct super_block *sb, unsigned long ino)
{
	struct f2fs_sb_info *sbi = F2FS_SB(sb);
	struct inode *inode;
317
	int ret = 0;
J
Jaegeuk Kim 已提交
318 319 320 321

	inode = iget_locked(sb, ino);
	if (!inode)
		return ERR_PTR(-ENOMEM);
322 323 324

	if (!(inode->i_state & I_NEW)) {
		trace_f2fs_iget(inode);
J
Jaegeuk Kim 已提交
325
		return inode;
326
	}
J
Jaegeuk Kim 已提交
327 328 329 330 331 332
	if (ino == F2FS_NODE_INO(sbi) || ino == F2FS_META_INO(sbi))
		goto make_now;

	ret = do_read_inode(inode);
	if (ret)
		goto bad_inode;
333 334 335 336
	if (!sanity_check_inode(inode)) {
		ret = -EINVAL;
		goto bad_inode;
	}
J
Jaegeuk Kim 已提交
337 338 339
make_now:
	if (ino == F2FS_NODE_INO(sbi)) {
		inode->i_mapping->a_ops = &f2fs_node_aops;
340
		mapping_set_gfp_mask(inode->i_mapping, GFP_NOFS);
J
Jaegeuk Kim 已提交
341 342
	} else if (ino == F2FS_META_INO(sbi)) {
		inode->i_mapping->a_ops = &f2fs_meta_aops;
343
		mapping_set_gfp_mask(inode->i_mapping, GFP_NOFS);
J
Jaegeuk Kim 已提交
344 345 346 347 348 349 350 351
	} else if (S_ISREG(inode->i_mode)) {
		inode->i_op = &f2fs_file_inode_operations;
		inode->i_fop = &f2fs_file_operations;
		inode->i_mapping->a_ops = &f2fs_dblock_aops;
	} else if (S_ISDIR(inode->i_mode)) {
		inode->i_op = &f2fs_dir_inode_operations;
		inode->i_fop = &f2fs_dir_operations;
		inode->i_mapping->a_ops = &f2fs_dblock_aops;
352
		inode_nohighmem(inode);
J
Jaegeuk Kim 已提交
353
	} else if (S_ISLNK(inode->i_mode)) {
354 355 356 357
		if (f2fs_encrypted_inode(inode))
			inode->i_op = &f2fs_encrypted_symlink_inode_operations;
		else
			inode->i_op = &f2fs_symlink_inode_operations;
358
		inode_nohighmem(inode);
J
Jaegeuk Kim 已提交
359 360 361 362 363 364 365 366 367
		inode->i_mapping->a_ops = &f2fs_dblock_aops;
	} else if (S_ISCHR(inode->i_mode) || S_ISBLK(inode->i_mode) ||
			S_ISFIFO(inode->i_mode) || S_ISSOCK(inode->i_mode)) {
		inode->i_op = &f2fs_special_inode_operations;
		init_special_inode(inode, inode->i_mode, inode->i_rdev);
	} else {
		ret = -EIO;
		goto bad_inode;
	}
J
Jaegeuk Kim 已提交
368
	f2fs_set_inode_flags(inode);
J
Jaegeuk Kim 已提交
369
	unlock_new_inode(inode);
370
	trace_f2fs_iget(inode);
J
Jaegeuk Kim 已提交
371 372 373 374
	return inode;

bad_inode:
	iget_failed(inode);
375
	trace_f2fs_iget_exit(inode, ret);
J
Jaegeuk Kim 已提交
376 377 378
	return ERR_PTR(ret);
}

379 380 381 382 383 384 385 386 387 388 389 390 391 392
struct inode *f2fs_iget_retry(struct super_block *sb, unsigned long ino)
{
	struct inode *inode;
retry:
	inode = f2fs_iget(sb, ino);
	if (IS_ERR(inode)) {
		if (PTR_ERR(inode) == -ENOMEM) {
			congestion_wait(BLK_RW_ASYNC, HZ/50);
			goto retry;
		}
	}
	return inode;
}

393
void update_inode(struct inode *inode, struct page *node_page)
J
Jaegeuk Kim 已提交
394 395
{
	struct f2fs_inode *ri;
396
	struct extent_tree *et = F2FS_I(inode)->extent_tree;
J
Jaegeuk Kim 已提交
397

398
	f2fs_wait_on_page_writeback(node_page, NODE, true);
399 400 401
	set_page_dirty(node_page);

	f2fs_inode_synced(inode);
J
Jaegeuk Kim 已提交
402

403
	ri = F2FS_INODE(node_page);
J
Jaegeuk Kim 已提交
404 405 406 407 408 409 410

	ri->i_mode = cpu_to_le16(inode->i_mode);
	ri->i_advise = F2FS_I(inode)->i_advise;
	ri->i_uid = cpu_to_le32(i_uid_read(inode));
	ri->i_gid = cpu_to_le32(i_gid_read(inode));
	ri->i_links = cpu_to_le32(inode->i_nlink);
	ri->i_size = cpu_to_le64(i_size_read(inode));
411
	ri->i_blocks = cpu_to_le64(SECTOR_TO_BLOCK(inode->i_blocks) + 1);
412

413 414 415 416 417
	if (et) {
		read_lock(&et->lock);
		set_raw_extent(&et->largest, &ri->i_ext);
		read_unlock(&et->lock);
	} else {
J
Jaegeuk Kim 已提交
418
		memset(&ri->i_ext, 0, sizeof(ri->i_ext));
419
	}
420
	set_raw_inline(inode, ri);
J
Jaegeuk Kim 已提交
421 422 423 424 425 426 427

	ri->i_atime = cpu_to_le64(inode->i_atime.tv_sec);
	ri->i_ctime = cpu_to_le64(inode->i_ctime.tv_sec);
	ri->i_mtime = cpu_to_le64(inode->i_mtime.tv_sec);
	ri->i_atime_nsec = cpu_to_le32(inode->i_atime.tv_nsec);
	ri->i_ctime_nsec = cpu_to_le32(inode->i_ctime.tv_nsec);
	ri->i_mtime_nsec = cpu_to_le32(inode->i_mtime.tv_nsec);
428 429 430 431
	if (S_ISDIR(inode->i_mode))
		ri->i_current_depth =
			cpu_to_le32(F2FS_I(inode)->i_current_depth);
	else if (S_ISREG(inode->i_mode))
432 433
		ri->i_gc_failures =
			cpu_to_le16(F2FS_I(inode)->i_gc_failures[GC_FAILURE_PIN]);
J
Jaegeuk Kim 已提交
434 435
	ri->i_xattr_nid = cpu_to_le32(F2FS_I(inode)->i_xattr_nid);
	ri->i_flags = cpu_to_le32(F2FS_I(inode)->i_flags);
436
	ri->i_pino = cpu_to_le32(F2FS_I(inode)->i_pino);
J
Jaegeuk Kim 已提交
437
	ri->i_generation = cpu_to_le32(inode->i_generation);
438
	ri->i_dir_level = F2FS_I(inode)->i_dir_level;
439

C
Chao Yu 已提交
440
	if (f2fs_has_extra_attr(inode)) {
441 442
		ri->i_extra_isize = cpu_to_le16(F2FS_I(inode)->i_extra_isize);

C
Chao Yu 已提交
443 444 445 446
		if (f2fs_sb_has_flexible_inline_xattr(F2FS_I_SB(inode)->sb))
			ri->i_inline_xattr_size =
				cpu_to_le16(F2FS_I(inode)->i_inline_xattr_size);

C
Chao Yu 已提交
447 448 449 450 451 452 453 454 455
		if (f2fs_sb_has_project_quota(F2FS_I_SB(inode)->sb) &&
			F2FS_FITS_IN_INODE(ri, F2FS_I(inode)->i_extra_isize,
								i_projid)) {
			projid_t i_projid;

			i_projid = from_kprojid(&init_user_ns,
						F2FS_I(inode)->i_projid);
			ri->i_projid = cpu_to_le32(i_projid);
		}
C
Chao Yu 已提交
456 457 458 459 460 461 462 463 464

		if (f2fs_sb_has_inode_crtime(F2FS_I_SB(inode)->sb) &&
			F2FS_FITS_IN_INODE(ri, F2FS_I(inode)->i_extra_isize,
								i_crtime)) {
			ri->i_crtime =
				cpu_to_le64(F2FS_I(inode)->i_crtime.tv_sec);
			ri->i_crtime_nsec =
				cpu_to_le32(F2FS_I(inode)->i_crtime.tv_nsec);
		}
C
Chao Yu 已提交
465 466
	}

467
	__set_inode_rdev(inode, ri);
468

469 470 471 472
	/* deleted inode */
	if (inode->i_nlink == 0)
		clear_inline_node(node_page);

473 474 475 476
	F2FS_I(inode)->i_disk_time[0] = inode->i_atime;
	F2FS_I(inode)->i_disk_time[1] = inode->i_ctime;
	F2FS_I(inode)->i_disk_time[2] = inode->i_mtime;
	F2FS_I(inode)->i_disk_time[3] = F2FS_I(inode)->i_crtime;
J
Jaegeuk Kim 已提交
477 478
}

479
void update_inode_page(struct inode *inode)
J
Jaegeuk Kim 已提交
480
{
481
	struct f2fs_sb_info *sbi = F2FS_I_SB(inode);
J
Jaegeuk Kim 已提交
482
	struct page *node_page;
483
retry:
J
Jaegeuk Kim 已提交
484
	node_page = get_node_page(sbi, inode->i_ino);
485 486 487 488 489 490
	if (IS_ERR(node_page)) {
		int err = PTR_ERR(node_page);
		if (err == -ENOMEM) {
			cond_resched();
			goto retry;
		} else if (err != -ENOENT) {
491
			f2fs_stop_checkpoint(sbi, false);
492
		}
493
		return;
494
	}
495
	update_inode(inode, node_page);
J
Jaegeuk Kim 已提交
496 497 498
	f2fs_put_page(node_page, 1);
}

499 500
int f2fs_write_inode(struct inode *inode, struct writeback_control *wbc)
{
501
	struct f2fs_sb_info *sbi = F2FS_I_SB(inode);
502 503 504 505 506

	if (inode->i_ino == F2FS_NODE_INO(sbi) ||
			inode->i_ino == F2FS_META_INO(sbi))
		return 0;

507
	if (!is_inode_flag_set(inode, FI_DIRTY_INODE))
508 509
		return 0;

510
	/*
511
	 * We need to balance fs here to prevent from producing dirty node pages
512 513
	 * during the urgent cleaning time when runing out of free sections.
	 */
J
Jaegeuk Kim 已提交
514 515
	update_inode_page(inode);
	if (wbc && wbc->nr_to_write)
J
Jaegeuk Kim 已提交
516
		f2fs_balance_fs(sbi, true);
517
	return 0;
518 519
}

J
Jaegeuk Kim 已提交
520
/*
J
Jaegeuk Kim 已提交
521 522 523 524
 * Called at the last iput() if i_nlink is zero
 */
void f2fs_evict_inode(struct inode *inode)
{
525
	struct f2fs_sb_info *sbi = F2FS_I_SB(inode);
526
	nid_t xnid = F2FS_I(inode)->i_xattr_nid;
C
Chao Yu 已提交
527
	int err = 0;
J
Jaegeuk Kim 已提交
528

J
Jaegeuk Kim 已提交
529
	/* some remained atomic pages should discarded */
530
	if (f2fs_is_atomic_file(inode))
531
		drop_inmem_pages(inode);
J
Jaegeuk Kim 已提交
532

533
	trace_f2fs_evict_inode(inode);
534
	truncate_inode_pages_final(&inode->i_data);
J
Jaegeuk Kim 已提交
535 536 537

	if (inode->i_ino == F2FS_NODE_INO(sbi) ||
			inode->i_ino == F2FS_META_INO(sbi))
538
		goto out_clear;
J
Jaegeuk Kim 已提交
539

540
	f2fs_bug_on(sbi, get_dirty_pages(inode));
541
	remove_dirty_inode(inode);
J
Jaegeuk Kim 已提交
542

J
Jaegeuk Kim 已提交
543 544
	f2fs_destroy_extent_tree(inode);

J
Jaegeuk Kim 已提交
545 546 547
	if (inode->i_nlink || is_bad_inode(inode))
		goto no_delete;

C
Chao Yu 已提交
548 549
	dquot_initialize(inode);

550 551
	remove_ino_entry(sbi, inode->i_ino, APPEND_INO);
	remove_ino_entry(sbi, inode->i_ino, UPDATE_INO);
C
Chao Yu 已提交
552
	remove_ino_entry(sbi, inode->i_ino, FLUSH_INO);
553

554
	sb_start_intwrite(inode->i_sb);
555
	set_inode_flag(inode, FI_NO_ALLOC);
J
Jaegeuk Kim 已提交
556
	i_size_write(inode, 0);
557
retry:
J
Jaegeuk Kim 已提交
558
	if (F2FS_HAS_BLOCKS(inode))
559
		err = f2fs_truncate(inode);
J
Jaegeuk Kim 已提交
560

561 562 563 564 565 566
#ifdef CONFIG_F2FS_FAULT_INJECTION
	if (time_to_inject(sbi, FAULT_EVICT_INODE)) {
		f2fs_show_injection_info(FAULT_EVICT_INODE);
		err = -EIO;
	}
#endif
C
Chao Yu 已提交
567 568 569 570
	if (!err) {
		f2fs_lock_op(sbi);
		err = remove_inode_page(inode);
		f2fs_unlock_op(sbi);
C
Chao Yu 已提交
571 572
		if (err == -ENOENT)
			err = 0;
C
Chao Yu 已提交
573
	}
574

575 576 577 578 579 580
	/* give more chances, if ENOMEM case */
	if (err == -ENOMEM) {
		err = 0;
		goto retry;
	}

581 582
	if (err)
		update_inode_page(inode);
C
Chao Yu 已提交
583
	dquot_free_inode(inode);
584
	sb_end_intwrite(inode->i_sb);
J
Jaegeuk Kim 已提交
585
no_delete:
C
Chao Yu 已提交
586 587
	dquot_drop(inode);

C
Chao Yu 已提交
588
	stat_dec_inline_xattr(inode);
589
	stat_dec_inline_dir(inode);
590
	stat_dec_inline_inode(inode);
591

592
	if (likely(!is_set_ckpt_flags(sbi, CP_ERROR_FLAG)))
593
		f2fs_bug_on(sbi, is_inode_flag_set(inode, FI_DIRTY_INODE));
594 595
	else
		f2fs_inode_synced(inode);
596

597 598 599 600
	/* ino == 0, if f2fs_new_inode() was failed t*/
	if (inode->i_ino)
		invalidate_mapping_pages(NODE_MAPPING(sbi), inode->i_ino,
							inode->i_ino);
601 602
	if (xnid)
		invalidate_mapping_pages(NODE_MAPPING(sbi), xnid, xnid);
603 604 605 606 607 608
	if (inode->i_nlink) {
		if (is_inode_flag_set(inode, FI_APPEND_WRITE))
			add_ino_entry(sbi, inode->i_ino, APPEND_INO);
		if (is_inode_flag_set(inode, FI_UPDATE_WRITE))
			add_ino_entry(sbi, inode->i_ino, UPDATE_INO);
	}
609
	if (is_inode_flag_set(inode, FI_FREE_NID)) {
J
Jaegeuk Kim 已提交
610
		alloc_nid_failed(sbi, inode->i_ino);
611
		clear_inode_flag(inode, FI_FREE_NID);
J
Jaegeuk Kim 已提交
612
	} else {
613 614 615 616 617
		/*
		 * If xattr nid is corrupted, we can reach out error condition,
		 * err & !exist_written_data(sbi, inode->i_ino, ORPHAN_INO)).
		 * In that case, check_nid_range() is enough to give a clue.
		 */
618
	}
619
out_clear:
620
	fscrypt_put_encryption_info(inode);
621
	clear_inode(inode);
J
Jaegeuk Kim 已提交
622
}
623 624 625 626 627

/* caller should call f2fs_lock_op() */
void handle_failed_inode(struct inode *inode)
{
	struct f2fs_sb_info *sbi = F2FS_I_SB(inode);
J
Jaegeuk Kim 已提交
628
	struct node_info ni;
629

C
Chao Yu 已提交
630 631 632 633 634 635 636 637 638 639 640
	/*
	 * clear nlink of inode in order to release resource of inode
	 * immediately.
	 */
	clear_nlink(inode);

	/*
	 * we must call this to avoid inode being remained as dirty, resulting
	 * in a panic when flushing dirty inodes in gdirty_list.
	 */
	update_inode_page(inode);
641
	f2fs_inode_synced(inode);
C
Chao Yu 已提交
642

J
Jaegeuk Kim 已提交
643
	/* don't make bad inode, since it becomes a regular file. */
644 645
	unlock_new_inode(inode);

C
Chao Yu 已提交
646 647 648 649 650
	/*
	 * Note: we should add inode to orphan list before f2fs_unlock_op()
	 * so we can prevent losing this orphan when encoutering checkpoint
	 * and following suddenly power-off.
	 */
J
Jaegeuk Kim 已提交
651 652 653 654 655 656 657 658 659
	get_node_info(sbi, inode->i_ino, &ni);

	if (ni.blk_addr != NULL_ADDR) {
		int err = acquire_orphan_inode(sbi);
		if (err) {
			set_sbi_flag(sbi, SBI_NEED_FSCK);
			f2fs_msg(sbi->sb, KERN_WARNING,
				"Too many orphan inodes, run fsck to fix.");
		} else {
660
			add_orphan_inode(inode);
J
Jaegeuk Kim 已提交
661 662 663
		}
		alloc_nid_done(sbi, inode->i_ino);
	} else {
664
		set_inode_flag(inode, FI_FREE_NID);
C
Chao Yu 已提交
665
	}
666 667 668 669 670 671

	f2fs_unlock_op(sbi);

	/* iput will drop the inode object */
	iput(inode);
}