inode.c 29.3 KB
Newer Older
R
Ryusuke Konishi 已提交
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
/*
 * inode.c - NILFS inode operations.
 *
 * Copyright (C) 2005-2008 Nippon Telegraph and Telephone Corporation.
 *
 * This program is free software; you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation; either version 2 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
16
 * Written by Ryusuke Konishi.
R
Ryusuke Konishi 已提交
17 18 19 20
 *
 */

#include <linux/buffer_head.h>
21
#include <linux/gfp.h>
R
Ryusuke Konishi 已提交
22
#include <linux/mpage.h>
23
#include <linux/pagemap.h>
R
Ryusuke Konishi 已提交
24
#include <linux/writeback.h>
25
#include <linux/uio.h>
R
Ryusuke Konishi 已提交
26
#include "nilfs.h"
A
Al Viro 已提交
27
#include "btnode.h"
R
Ryusuke Konishi 已提交
28 29 30 31 32 33
#include "segment.h"
#include "page.h"
#include "mdt.h"
#include "cpfile.h"
#include "ifile.h"

34 35 36 37 38 39 40
/**
 * struct nilfs_iget_args - arguments used during comparison between inodes
 * @ino: inode number
 * @cno: checkpoint number
 * @root: pointer on NILFS root object (mounted checkpoint)
 * @for_gc: inode for GC flag
 */
41 42 43
struct nilfs_iget_args {
	u64 ino;
	__u64 cno;
44
	struct nilfs_root *root;
45 46
	int for_gc;
};
R
Ryusuke Konishi 已提交
47

48 49
static int nilfs_iget_test(struct inode *inode, void *opaque);

50 51 52 53 54 55
void nilfs_inode_add_blocks(struct inode *inode, int n)
{
	struct nilfs_root *root = NILFS_I(inode)->i_root;

	inode_add_bytes(inode, (1 << inode->i_blkbits) * n);
	if (root)
56
		atomic64_add(n, &root->blocks_count);
57 58 59 60 61 62 63 64
}

void nilfs_inode_sub_blocks(struct inode *inode, int n)
{
	struct nilfs_root *root = NILFS_I(inode)->i_root;

	inode_sub_bytes(inode, (1 << inode->i_blkbits) * n);
	if (root)
65
		atomic64_sub(n, &root->blocks_count);
66 67
}

R
Ryusuke Konishi 已提交
68 69 70 71 72 73 74 75 76 77 78 79 80 81 82
/**
 * nilfs_get_block() - get a file block on the filesystem (callback function)
 * @inode - inode struct of the target file
 * @blkoff - file block number
 * @bh_result - buffer head to be mapped on
 * @create - indicate whether allocating the block or not when it has not
 *      been allocated yet.
 *
 * This function does not issue actual read request of the specified data
 * block. It is done by VFS.
 */
int nilfs_get_block(struct inode *inode, sector_t blkoff,
		    struct buffer_head *bh_result, int create)
{
	struct nilfs_inode_info *ii = NILFS_I(inode);
83
	struct the_nilfs *nilfs = inode->i_sb->s_fs_info;
84
	__u64 blknum = 0;
R
Ryusuke Konishi 已提交
85
	int err = 0, ret;
86
	unsigned maxblocks = bh_result->b_size >> inode->i_blkbits;
R
Ryusuke Konishi 已提交
87

88
	down_read(&NILFS_MDT(nilfs->ns_dat)->mi_sem);
89
	ret = nilfs_bmap_lookup_contig(ii->i_bmap, blkoff, &blknum, maxblocks);
90
	up_read(&NILFS_MDT(nilfs->ns_dat)->mi_sem);
91
	if (ret >= 0) {	/* found */
R
Ryusuke Konishi 已提交
92
		map_bh(bh_result, inode->i_sb, blknum);
93 94
		if (ret > 0)
			bh_result->b_size = (ret << inode->i_blkbits);
R
Ryusuke Konishi 已提交
95 96 97 98 99 100 101 102 103 104
		goto out;
	}
	/* data block was not found */
	if (ret == -ENOENT && create) {
		struct nilfs_transaction_info ti;

		bh_result->b_blocknr = 0;
		err = nilfs_transaction_begin(inode->i_sb, &ti, 1);
		if (unlikely(err))
			goto out;
105
		err = nilfs_bmap_insert(ii->i_bmap, blkoff,
R
Ryusuke Konishi 已提交
106 107 108 109 110 111 112 113 114
					(unsigned long)bh_result);
		if (unlikely(err != 0)) {
			if (err == -EEXIST) {
				/*
				 * The get_block() function could be called
				 * from multiple callers for an inode.
				 * However, the page having this block must
				 * be locked in this case.
				 */
115
				printk(KERN_WARNING
R
Ryusuke Konishi 已提交
116 117 118 119 120 121
				       "nilfs_get_block: a race condition "
				       "while inserting a data block. "
				       "(inode number=%lu, file block "
				       "offset=%llu)\n",
				       inode->i_ino,
				       (unsigned long long)blkoff);
122
				err = 0;
R
Ryusuke Konishi 已提交
123
			}
124
			nilfs_transaction_abort(inode->i_sb);
R
Ryusuke Konishi 已提交
125 126
			goto out;
		}
127
		nilfs_mark_inode_dirty_sync(inode);
128
		nilfs_transaction_commit(inode->i_sb); /* never fails */
R
Ryusuke Konishi 已提交
129 130
		/* Error handling should be detailed */
		set_buffer_new(bh_result);
131
		set_buffer_delay(bh_result);
R
Ryusuke Konishi 已提交
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 162 163 164 165 166 167 168 169 170 171 172 173
		map_bh(bh_result, inode->i_sb, 0); /* dbn must be changed
						      to proper value */
	} else if (ret == -ENOENT) {
		/* not found is not error (e.g. hole); must return without
		   the mapped state flag. */
		;
	} else {
		err = ret;
	}

 out:
	return err;
}

/**
 * nilfs_readpage() - implement readpage() method of nilfs_aops {}
 * address_space_operations.
 * @file - file struct of the file to be read
 * @page - the page to be read
 */
static int nilfs_readpage(struct file *file, struct page *page)
{
	return mpage_readpage(page, nilfs_get_block);
}

/**
 * nilfs_readpages() - implement readpages() method of nilfs_aops {}
 * address_space_operations.
 * @file - file struct of the file to be read
 * @mapping - address_space struct used for reading multiple pages
 * @pages - the pages to be read
 * @nr_pages - number of pages to be read
 */
static int nilfs_readpages(struct file *file, struct address_space *mapping,
			   struct list_head *pages, unsigned nr_pages)
{
	return mpage_readpages(mapping, pages, nr_pages, nilfs_get_block);
}

static int nilfs_writepages(struct address_space *mapping,
			    struct writeback_control *wbc)
{
174 175 176
	struct inode *inode = mapping->host;
	int err = 0;

177 178 179 180 181
	if (inode->i_sb->s_flags & MS_RDONLY) {
		nilfs_clear_dirty_pages(mapping, false);
		return -EROFS;
	}

182 183 184 185 186
	if (wbc->sync_mode == WB_SYNC_ALL)
		err = nilfs_construct_dsync_segment(inode->i_sb, inode,
						    wbc->range_start,
						    wbc->range_end);
	return err;
R
Ryusuke Konishi 已提交
187 188 189 190 191 192 193
}

static int nilfs_writepage(struct page *page, struct writeback_control *wbc)
{
	struct inode *inode = page->mapping->host;
	int err;

194
	if (inode->i_sb->s_flags & MS_RDONLY) {
195 196 197 198 199 200 201 202 203 204 205
		/*
		 * It means that filesystem was remounted in read-only
		 * mode because of error or metadata corruption. But we
		 * have dirty pages that try to be flushed in background.
		 * So, here we simply discard this dirty page.
		 */
		nilfs_clear_dirty_page(page, false);
		unlock_page(page);
		return -EROFS;
	}

R
Ryusuke Konishi 已提交
206 207 208 209 210 211 212 213 214 215 216 217 218 219 220
	redirty_page_for_writepage(wbc, page);
	unlock_page(page);

	if (wbc->sync_mode == WB_SYNC_ALL) {
		err = nilfs_construct_segment(inode->i_sb);
		if (unlikely(err))
			return err;
	} else if (wbc->for_reclaim)
		nilfs_flush_segment(inode->i_sb, inode->i_ino);

	return 0;
}

static int nilfs_set_page_dirty(struct page *page)
{
221
	struct inode *inode = page->mapping->host;
222
	int ret = __set_page_dirty_nobuffers(page);
R
Ryusuke Konishi 已提交
223

224 225 226
	if (page_has_buffers(page)) {
		unsigned nr_dirty = 0;
		struct buffer_head *bh, *head;
R
Ryusuke Konishi 已提交
227

228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246
		/*
		 * This page is locked by callers, and no other thread
		 * concurrently marks its buffers dirty since they are
		 * only dirtied through routines in fs/buffer.c in
		 * which call sites of mark_buffer_dirty are protected
		 * by page lock.
		 */
		bh = head = page_buffers(page);
		do {
			/* Do not mark hole blocks dirty */
			if (buffer_dirty(bh) || !buffer_mapped(bh))
				continue;

			set_buffer_dirty(bh);
			nr_dirty++;
		} while (bh = bh->b_this_page, bh != head);

		if (nr_dirty)
			nilfs_set_file_dirty(inode, nr_dirty);
247
	} else if (ret) {
248
		unsigned nr_dirty = 1 << (PAGE_SHIFT - inode->i_blkbits);
249 250

		nilfs_set_file_dirty(inode, nr_dirty);
R
Ryusuke Konishi 已提交
251 252 253 254
	}
	return ret;
}

M
Marco Stornelli 已提交
255 256 257 258 259
void nilfs_write_failed(struct address_space *mapping, loff_t to)
{
	struct inode *inode = mapping->host;

	if (to > inode->i_size) {
260
		truncate_pagecache(inode, inode->i_size);
M
Marco Stornelli 已提交
261 262 263 264
		nilfs_truncate(inode);
	}
}

R
Ryusuke Konishi 已提交
265 266 267 268 269 270 271 272 273 274 275
static int nilfs_write_begin(struct file *file, struct address_space *mapping,
			     loff_t pos, unsigned len, unsigned flags,
			     struct page **pagep, void **fsdata)

{
	struct inode *inode = mapping->host;
	int err = nilfs_transaction_begin(inode->i_sb, NULL, 1);

	if (unlikely(err))
		return err;

276 277 278
	err = block_write_begin(mapping, pos, len, flags, pagep,
				nilfs_get_block);
	if (unlikely(err)) {
M
Marco Stornelli 已提交
279
		nilfs_write_failed(mapping, pos + len);
280
		nilfs_transaction_abort(inode->i_sb);
281
	}
R
Ryusuke Konishi 已提交
282 283 284 285 286 287 288 289
	return err;
}

static int nilfs_write_end(struct file *file, struct address_space *mapping,
			   loff_t pos, unsigned len, unsigned copied,
			   struct page *page, void *fsdata)
{
	struct inode *inode = mapping->host;
290
	unsigned start = pos & (PAGE_SIZE - 1);
R
Ryusuke Konishi 已提交
291 292 293 294 295 296 297
	unsigned nr_dirty;
	int err;

	nr_dirty = nilfs_page_count_clean_buffers(page, start,
						  start + copied);
	copied = generic_write_end(file, mapping, pos, len, copied, page,
				   fsdata);
298
	nilfs_set_file_dirty(inode, nr_dirty);
299
	err = nilfs_transaction_commit(inode->i_sb);
R
Ryusuke Konishi 已提交
300 301 302 303
	return err ? : copied;
}

static ssize_t
304
nilfs_direct_IO(struct kiocb *iocb, struct iov_iter *iter)
R
Ryusuke Konishi 已提交
305
{
A
Al Viro 已提交
306
	struct inode *inode = file_inode(iocb->ki_filp);
R
Ryusuke Konishi 已提交
307

308
	if (iov_iter_rw(iter) == WRITE)
R
Ryusuke Konishi 已提交
309 310 311
		return 0;

	/* Needs synchronization with the cleaner */
312
	return blockdev_direct_IO(iocb, inode, iter, nilfs_get_block);
R
Ryusuke Konishi 已提交
313 314
}

315
const struct address_space_operations nilfs_aops = {
R
Ryusuke Konishi 已提交
316 317 318 319 320 321 322 323 324 325
	.writepage		= nilfs_writepage,
	.readpage		= nilfs_readpage,
	.writepages		= nilfs_writepages,
	.set_page_dirty		= nilfs_set_page_dirty,
	.readpages		= nilfs_readpages,
	.write_begin		= nilfs_write_begin,
	.write_end		= nilfs_write_end,
	/* .releasepage		= nilfs_releasepage, */
	.invalidatepage		= block_invalidatepage,
	.direct_IO		= nilfs_direct_IO,
326
	.is_partially_uptodate  = block_is_partially_uptodate,
R
Ryusuke Konishi 已提交
327 328
};

329 330 331 332 333 334 335 336 337 338 339
static int nilfs_insert_inode_locked(struct inode *inode,
				     struct nilfs_root *root,
				     unsigned long ino)
{
	struct nilfs_iget_args args = {
		.ino = ino, .root = root, .cno = 0, .for_gc = 0
	};

	return insert_inode_locked4(inode, ino, nilfs_iget_test, &args);
}

A
Al Viro 已提交
340
struct inode *nilfs_new_inode(struct inode *dir, umode_t mode)
R
Ryusuke Konishi 已提交
341 342
{
	struct super_block *sb = dir->i_sb;
343
	struct the_nilfs *nilfs = sb->s_fs_info;
R
Ryusuke Konishi 已提交
344 345
	struct inode *inode;
	struct nilfs_inode_info *ii;
346
	struct nilfs_root *root;
R
Ryusuke Konishi 已提交
347 348 349 350 351 352 353 354
	int err = -ENOMEM;
	ino_t ino;

	inode = new_inode(sb);
	if (unlikely(!inode))
		goto failed;

	mapping_set_gfp_mask(inode->i_mapping,
355
			   mapping_gfp_constraint(inode->i_mapping, ~__GFP_FS));
R
Ryusuke Konishi 已提交
356

357
	root = NILFS_I(dir)->i_root;
R
Ryusuke Konishi 已提交
358 359
	ii = NILFS_I(inode);
	ii->i_state = 1 << NILFS_I_NEW;
360
	ii->i_root = root;
R
Ryusuke Konishi 已提交
361

362
	err = nilfs_ifile_create_inode(root->ifile, &ino, &ii->i_bh);
R
Ryusuke Konishi 已提交
363 364 365 366
	if (unlikely(err))
		goto failed_ifile_create_inode;
	/* reference count of i_bh inherits from nilfs_mdt_read_block() */

367
	atomic64_inc(&root->inodes_count);
368
	inode_init_owner(inode, dir, mode);
R
Ryusuke Konishi 已提交
369 370 371 372 373 374
	inode->i_ino = ino;
	inode->i_mtime = inode->i_atime = inode->i_ctime = CURRENT_TIME;

	if (S_ISREG(mode) || S_ISDIR(mode) || S_ISLNK(mode)) {
		err = nilfs_bmap_read(ii->i_bmap, NULL);
		if (err < 0)
375
			goto failed_after_creation;
R
Ryusuke Konishi 已提交
376 377 378 379 380

		set_bit(NILFS_I_BMAP, &ii->i_state);
		/* No lock is needed; iget() ensures it. */
	}

381 382
	ii->i_flags = nilfs_mask_flags(
		mode, NILFS_I(dir)->i_flags & NILFS_FL_INHERITED);
R
Ryusuke Konishi 已提交
383 384 385 386 387

	/* ii->i_file_acl = 0; */
	/* ii->i_dir_acl = 0; */
	ii->i_dir_start_lookup = 0;
	nilfs_set_inode_flags(inode);
388 389 390
	spin_lock(&nilfs->ns_next_gen_lock);
	inode->i_generation = nilfs->ns_next_generation++;
	spin_unlock(&nilfs->ns_next_gen_lock);
391 392 393 394
	if (nilfs_insert_inode_locked(inode, root, ino) < 0) {
		err = -EIO;
		goto failed_after_creation;
	}
R
Ryusuke Konishi 已提交
395 396 397

	err = nilfs_init_acl(inode, dir);
	if (unlikely(err))
398
		goto failed_after_creation; /* never occur. When supporting
R
Ryusuke Konishi 已提交
399 400 401 402 403
				    nilfs_init_acl(), proper cancellation of
				    above jobs should be considered */

	return inode;

404
 failed_after_creation:
405
	clear_nlink(inode);
406
	unlock_new_inode(inode);
R
Ryusuke Konishi 已提交
407
	iput(inode);  /* raw_inode will be deleted through
408
			 nilfs_evict_inode() */
R
Ryusuke Konishi 已提交
409 410 411 412 413 414 415 416 417 418 419 420 421
	goto failed;

 failed_ifile_create_inode:
	make_bad_inode(inode);
	iput(inode);  /* if i_nlink == 1, generic_forget_inode() will be
			 called */
 failed:
	return ERR_PTR(err);
}

void nilfs_set_inode_flags(struct inode *inode)
{
	unsigned int flags = NILFS_I(inode)->i_flags;
422
	unsigned int new_fl = 0;
R
Ryusuke Konishi 已提交
423

424
	if (flags & FS_SYNC_FL)
425
		new_fl |= S_SYNC;
426
	if (flags & FS_APPEND_FL)
427
		new_fl |= S_APPEND;
428
	if (flags & FS_IMMUTABLE_FL)
429
		new_fl |= S_IMMUTABLE;
430
	if (flags & FS_NOATIME_FL)
431
		new_fl |= S_NOATIME;
432
	if (flags & FS_DIRSYNC_FL)
433 434 435
		new_fl |= S_DIRSYNC;
	inode_set_flags(inode, new_fl, S_SYNC | S_APPEND | S_IMMUTABLE |
			S_NOATIME | S_DIRSYNC);
R
Ryusuke Konishi 已提交
436 437 438 439 440 441 442 443 444
}

int nilfs_read_inode_common(struct inode *inode,
			    struct nilfs_inode *raw_inode)
{
	struct nilfs_inode_info *ii = NILFS_I(inode);
	int err;

	inode->i_mode = le16_to_cpu(raw_inode->i_mode);
445 446
	i_uid_write(inode, le32_to_cpu(raw_inode->i_uid));
	i_gid_write(inode, le32_to_cpu(raw_inode->i_gid));
M
Miklos Szeredi 已提交
447
	set_nlink(inode, le16_to_cpu(raw_inode->i_links_count));
R
Ryusuke Konishi 已提交
448 449 450 451
	inode->i_size = le64_to_cpu(raw_inode->i_size);
	inode->i_atime.tv_sec = le64_to_cpu(raw_inode->i_mtime);
	inode->i_ctime.tv_sec = le64_to_cpu(raw_inode->i_ctime);
	inode->i_mtime.tv_sec = le64_to_cpu(raw_inode->i_mtime);
452 453 454
	inode->i_atime.tv_nsec = le32_to_cpu(raw_inode->i_mtime_nsec);
	inode->i_ctime.tv_nsec = le32_to_cpu(raw_inode->i_ctime_nsec);
	inode->i_mtime.tv_nsec = le32_to_cpu(raw_inode->i_mtime_nsec);
455 456
	if (inode->i_nlink == 0)
		return -ESTALE; /* this inode is deleted */
R
Ryusuke Konishi 已提交
457 458 459 460 461 462 463 464

	inode->i_blocks = le64_to_cpu(raw_inode->i_blocks);
	ii->i_flags = le32_to_cpu(raw_inode->i_flags);
#if 0
	ii->i_file_acl = le32_to_cpu(raw_inode->i_file_acl);
	ii->i_dir_acl = S_ISREG(inode->i_mode) ?
		0 : le32_to_cpu(raw_inode->i_dir_acl);
#endif
465
	ii->i_dir_start_lookup = 0;
R
Ryusuke Konishi 已提交
466 467 468 469 470 471 472 473 474 475 476 477 478
	inode->i_generation = le32_to_cpu(raw_inode->i_generation);

	if (S_ISREG(inode->i_mode) || S_ISDIR(inode->i_mode) ||
	    S_ISLNK(inode->i_mode)) {
		err = nilfs_bmap_read(ii->i_bmap, raw_inode);
		if (err < 0)
			return err;
		set_bit(NILFS_I_BMAP, &ii->i_state);
		/* No lock is needed; iget() ensures it. */
	}
	return 0;
}

479 480
static int __nilfs_read_inode(struct super_block *sb,
			      struct nilfs_root *root, unsigned long ino,
R
Ryusuke Konishi 已提交
481 482
			      struct inode *inode)
{
483
	struct the_nilfs *nilfs = sb->s_fs_info;
R
Ryusuke Konishi 已提交
484 485 486 487
	struct buffer_head *bh;
	struct nilfs_inode *raw_inode;
	int err;

488
	down_read(&NILFS_MDT(nilfs->ns_dat)->mi_sem);
489
	err = nilfs_ifile_get_inode_block(root->ifile, ino, &bh);
R
Ryusuke Konishi 已提交
490 491 492
	if (unlikely(err))
		goto bad_inode;

493
	raw_inode = nilfs_ifile_map_inode(root->ifile, ino, bh);
R
Ryusuke Konishi 已提交
494

495 496
	err = nilfs_read_inode_common(inode, raw_inode);
	if (err)
R
Ryusuke Konishi 已提交
497 498 499 500 501 502 503 504 505 506 507 508
		goto failed_unmap;

	if (S_ISREG(inode->i_mode)) {
		inode->i_op = &nilfs_file_inode_operations;
		inode->i_fop = &nilfs_file_operations;
		inode->i_mapping->a_ops = &nilfs_aops;
	} else if (S_ISDIR(inode->i_mode)) {
		inode->i_op = &nilfs_dir_inode_operations;
		inode->i_fop = &nilfs_dir_operations;
		inode->i_mapping->a_ops = &nilfs_aops;
	} else if (S_ISLNK(inode->i_mode)) {
		inode->i_op = &nilfs_symlink_inode_operations;
509
		inode_nohighmem(inode);
R
Ryusuke Konishi 已提交
510 511 512 513 514
		inode->i_mapping->a_ops = &nilfs_aops;
	} else {
		inode->i_op = &nilfs_special_inode_operations;
		init_special_inode(
			inode, inode->i_mode,
515
			huge_decode_dev(le64_to_cpu(raw_inode->i_device_code)));
R
Ryusuke Konishi 已提交
516
	}
517
	nilfs_ifile_unmap_inode(root->ifile, ino, bh);
R
Ryusuke Konishi 已提交
518
	brelse(bh);
519
	up_read(&NILFS_MDT(nilfs->ns_dat)->mi_sem);
R
Ryusuke Konishi 已提交
520
	nilfs_set_inode_flags(inode);
521
	mapping_set_gfp_mask(inode->i_mapping,
522
			   mapping_gfp_constraint(inode->i_mapping, ~__GFP_FS));
R
Ryusuke Konishi 已提交
523 524 525
	return 0;

 failed_unmap:
526
	nilfs_ifile_unmap_inode(root->ifile, ino, bh);
R
Ryusuke Konishi 已提交
527 528 529
	brelse(bh);

 bad_inode:
530
	up_read(&NILFS_MDT(nilfs->ns_dat)->mi_sem);
R
Ryusuke Konishi 已提交
531 532 533
	return err;
}

534 535 536 537 538
static int nilfs_iget_test(struct inode *inode, void *opaque)
{
	struct nilfs_iget_args *args = opaque;
	struct nilfs_inode_info *ii;

539
	if (args->ino != inode->i_ino || args->root != NILFS_I(inode)->i_root)
540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556
		return 0;

	ii = NILFS_I(inode);
	if (!test_bit(NILFS_I_GCINODE, &ii->i_state))
		return !args->for_gc;

	return args->for_gc && args->cno == ii->i_cno;
}

static int nilfs_iget_set(struct inode *inode, void *opaque)
{
	struct nilfs_iget_args *args = opaque;

	inode->i_ino = args->ino;
	if (args->for_gc) {
		NILFS_I(inode)->i_state = 1 << NILFS_I_GCINODE;
		NILFS_I(inode)->i_cno = args->cno;
557 558 559 560 561
		NILFS_I(inode)->i_root = NULL;
	} else {
		if (args->root && args->ino == NILFS_ROOT_INO)
			nilfs_get_root(args->root);
		NILFS_I(inode)->i_root = args->root;
562 563 564 565
	}
	return 0;
}

566 567 568 569 570 571 572 573 574 575
struct inode *nilfs_ilookup(struct super_block *sb, struct nilfs_root *root,
			    unsigned long ino)
{
	struct nilfs_iget_args args = {
		.ino = ino, .root = root, .cno = 0, .for_gc = 0
	};

	return ilookup5(sb, ino, nilfs_iget_test, &args);
}

576 577
struct inode *nilfs_iget_locked(struct super_block *sb, struct nilfs_root *root,
				unsigned long ino)
R
Ryusuke Konishi 已提交
578
{
579 580 581
	struct nilfs_iget_args args = {
		.ino = ino, .root = root, .cno = 0, .for_gc = 0
	};
582 583 584 585 586 587 588

	return iget5_locked(sb, ino, nilfs_iget_test, nilfs_iget_set, &args);
}

struct inode *nilfs_iget(struct super_block *sb, struct nilfs_root *root,
			 unsigned long ino)
{
R
Ryusuke Konishi 已提交
589 590 591
	struct inode *inode;
	int err;

592
	inode = nilfs_iget_locked(sb, root, ino);
R
Ryusuke Konishi 已提交
593 594 595 596 597
	if (unlikely(!inode))
		return ERR_PTR(-ENOMEM);
	if (!(inode->i_state & I_NEW))
		return inode;

598
	err = __nilfs_read_inode(sb, root, ino, inode);
R
Ryusuke Konishi 已提交
599 600 601 602 603 604 605 606
	if (unlikely(err)) {
		iget_failed(inode);
		return ERR_PTR(err);
	}
	unlock_new_inode(inode);
	return inode;
}

607 608 609
struct inode *nilfs_iget_for_gc(struct super_block *sb, unsigned long ino,
				__u64 cno)
{
610 611 612
	struct nilfs_iget_args args = {
		.ino = ino, .root = NULL, .cno = cno, .for_gc = 1
	};
613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630
	struct inode *inode;
	int err;

	inode = iget5_locked(sb, ino, nilfs_iget_test, nilfs_iget_set, &args);
	if (unlikely(!inode))
		return ERR_PTR(-ENOMEM);
	if (!(inode->i_state & I_NEW))
		return inode;

	err = nilfs_init_gcinode(inode);
	if (unlikely(err)) {
		iget_failed(inode);
		return ERR_PTR(err);
	}
	unlock_new_inode(inode);
	return inode;
}

R
Ryusuke Konishi 已提交
631 632 633 634 635 636
void nilfs_write_inode_common(struct inode *inode,
			      struct nilfs_inode *raw_inode, int has_bmap)
{
	struct nilfs_inode_info *ii = NILFS_I(inode);

	raw_inode->i_mode = cpu_to_le16(inode->i_mode);
637 638
	raw_inode->i_uid = cpu_to_le32(i_uid_read(inode));
	raw_inode->i_gid = cpu_to_le32(i_gid_read(inode));
R
Ryusuke Konishi 已提交
639 640 641 642
	raw_inode->i_links_count = cpu_to_le16(inode->i_nlink);
	raw_inode->i_size = cpu_to_le64(inode->i_size);
	raw_inode->i_ctime = cpu_to_le64(inode->i_ctime.tv_sec);
	raw_inode->i_mtime = cpu_to_le64(inode->i_mtime.tv_sec);
643 644
	raw_inode->i_ctime_nsec = cpu_to_le32(inode->i_ctime.tv_nsec);
	raw_inode->i_mtime_nsec = cpu_to_le32(inode->i_mtime.tv_nsec);
R
Ryusuke Konishi 已提交
645 646 647 648 649
	raw_inode->i_blocks = cpu_to_le64(inode->i_blocks);

	raw_inode->i_flags = cpu_to_le32(ii->i_flags);
	raw_inode->i_generation = cpu_to_le32(inode->i_generation);

650 651 652 653 654 655 656 657 658 659
	if (NILFS_ROOT_METADATA_FILE(inode->i_ino)) {
		struct the_nilfs *nilfs = inode->i_sb->s_fs_info;

		/* zero-fill unused portion in the case of super root block */
		raw_inode->i_xattr = 0;
		raw_inode->i_pad = 0;
		memset((void *)raw_inode + sizeof(*raw_inode), 0,
		       nilfs->ns_inode_size - sizeof(*raw_inode));
	}

R
Ryusuke Konishi 已提交
660 661 662 663
	if (has_bmap)
		nilfs_bmap_write(ii->i_bmap, raw_inode);
	else if (S_ISCHR(inode->i_mode) || S_ISBLK(inode->i_mode))
		raw_inode->i_device_code =
664
			cpu_to_le64(huge_encode_dev(inode->i_rdev));
R
Ryusuke Konishi 已提交
665 666 667 668
	/* When extending inode, nilfs->ns_inode_size should be checked
	   for substitutions of appended fields */
}

669
void nilfs_update_inode(struct inode *inode, struct buffer_head *ibh, int flags)
R
Ryusuke Konishi 已提交
670 671 672
{
	ino_t ino = inode->i_ino;
	struct nilfs_inode_info *ii = NILFS_I(inode);
673
	struct inode *ifile = ii->i_root->ifile;
R
Ryusuke Konishi 已提交
674 675
	struct nilfs_inode *raw_inode;

676
	raw_inode = nilfs_ifile_map_inode(ifile, ino, ibh);
R
Ryusuke Konishi 已提交
677 678

	if (test_and_clear_bit(NILFS_I_NEW, &ii->i_state))
679
		memset(raw_inode, 0, NILFS_MDT(ifile)->mi_entry_size);
680 681
	if (flags & I_DIRTY_DATASYNC)
		set_bit(NILFS_I_INODE_SYNC, &ii->i_state);
R
Ryusuke Konishi 已提交
682 683 684 685 686

	nilfs_write_inode_common(inode, raw_inode, 0);
		/* XXX: call with has_bmap = 0 is a workaround to avoid
		   deadlock of bmap. This delays update of i_bmap to just
		   before writing */
687
	nilfs_ifile_unmap_inode(ifile, ino, ibh);
R
Ryusuke Konishi 已提交
688 689 690 691 692 693 694
}

#define NILFS_MAX_TRUNCATE_BLOCKS	16384  /* 64MB for 4KB block */

static void nilfs_truncate_bmap(struct nilfs_inode_info *ii,
				unsigned long from)
{
695
	__u64 b;
R
Ryusuke Konishi 已提交
696 697 698 699
	int ret;

	if (!test_bit(NILFS_I_BMAP, &ii->i_state))
		return;
700
repeat:
R
Ryusuke Konishi 已提交
701 702 703 704 705 706 707 708 709
	ret = nilfs_bmap_last_key(ii->i_bmap, &b);
	if (ret == -ENOENT)
		return;
	else if (ret < 0)
		goto failed;

	if (b < from)
		return;

710
	b -= min_t(__u64, NILFS_MAX_TRUNCATE_BLOCKS, b - from);
R
Ryusuke Konishi 已提交
711 712 713 714 715 716
	ret = nilfs_bmap_truncate(ii->i_bmap, b);
	nilfs_relax_pressure_in_lock(ii->vfs_inode.i_sb);
	if (!ret || (ret == -ENOMEM &&
		     nilfs_bmap_truncate(ii->i_bmap, b) == 0))
		goto repeat;

717 718 719 720
failed:
	nilfs_warning(ii->vfs_inode.i_sb, __func__,
		      "failed to truncate bmap (ino=%lu, err=%d)",
		      ii->vfs_inode.i_ino, ret);
R
Ryusuke Konishi 已提交
721 722 723 724 725 726 727 728 729 730 731 732 733 734 735 736 737
}

void nilfs_truncate(struct inode *inode)
{
	unsigned long blkoff;
	unsigned int blocksize;
	struct nilfs_transaction_info ti;
	struct super_block *sb = inode->i_sb;
	struct nilfs_inode_info *ii = NILFS_I(inode);

	if (!test_bit(NILFS_I_BMAP, &ii->i_state))
		return;
	if (IS_APPEND(inode) || IS_IMMUTABLE(inode))
		return;

	blocksize = sb->s_blocksize;
	blkoff = (inode->i_size + blocksize - 1) >> sb->s_blocksize_bits;
738
	nilfs_transaction_begin(sb, &ti, 0); /* never fails */
R
Ryusuke Konishi 已提交
739 740 741 742 743 744 745 746 747

	block_truncate_page(inode->i_mapping, inode->i_size, nilfs_get_block);

	nilfs_truncate_bmap(ii, blkoff);

	inode->i_mtime = inode->i_ctime = CURRENT_TIME;
	if (IS_SYNC(inode))
		nilfs_set_transaction_flag(NILFS_TI_SYNC);

748
	nilfs_mark_inode_dirty(inode);
749
	nilfs_set_file_dirty(inode, 0);
750
	nilfs_transaction_commit(sb);
R
Ryusuke Konishi 已提交
751 752 753 754
	/* May construct a logical segment and may fail in sync mode.
	   But truncate has no return value. */
}

A
Al Viro 已提交
755 756 757 758 759 760 761 762 763 764 765
static void nilfs_clear_inode(struct inode *inode)
{
	struct nilfs_inode_info *ii = NILFS_I(inode);

	/*
	 * Free resources allocated in nilfs_read_inode(), here.
	 */
	BUG_ON(!list_empty(&ii->i_dirty));
	brelse(ii->i_bh);
	ii->i_bh = NULL;

766 767
	if (nilfs_is_metadata_file_inode(inode))
		nilfs_mdt_clear(inode);
768

A
Al Viro 已提交
769 770 771 772
	if (test_bit(NILFS_I_BMAP, &ii->i_state))
		nilfs_bmap_clear(ii->i_bmap);

	nilfs_btnode_cache_clear(&ii->i_btnode_cache);
773 774 775

	if (ii->i_root && inode->i_ino == NILFS_ROOT_INO)
		nilfs_put_root(ii->i_root);
A
Al Viro 已提交
776 777 778
}

void nilfs_evict_inode(struct inode *inode)
R
Ryusuke Konishi 已提交
779 780 781 782
{
	struct nilfs_transaction_info ti;
	struct super_block *sb = inode->i_sb;
	struct nilfs_inode_info *ii = NILFS_I(inode);
783
	int ret;
R
Ryusuke Konishi 已提交
784

785
	if (inode->i_nlink || !ii->i_root || unlikely(is_bad_inode(inode))) {
786
		truncate_inode_pages_final(&inode->i_data);
787
		clear_inode(inode);
A
Al Viro 已提交
788
		nilfs_clear_inode(inode);
R
Ryusuke Konishi 已提交
789 790
		return;
	}
791 792
	nilfs_transaction_begin(sb, &ti, 0); /* never fails */

793
	truncate_inode_pages_final(&inode->i_data);
R
Ryusuke Konishi 已提交
794

795
	/* TODO: some of the following operations may fail.  */
R
Ryusuke Konishi 已提交
796
	nilfs_truncate_bmap(ii, 0);
797
	nilfs_mark_inode_dirty(inode);
798
	clear_inode(inode);
799

800 801
	ret = nilfs_ifile_delete_inode(ii->i_root->ifile, inode->i_ino);
	if (!ret)
802
		atomic64_dec(&ii->i_root->inodes_count);
803

A
Al Viro 已提交
804
	nilfs_clear_inode(inode);
805

R
Ryusuke Konishi 已提交
806 807
	if (IS_SYNC(inode))
		nilfs_set_transaction_flag(NILFS_TI_SYNC);
808
	nilfs_transaction_commit(sb);
R
Ryusuke Konishi 已提交
809 810 811 812 813 814 815
	/* May construct a logical segment and may fail in sync mode.
	   But delete_inode has no return value. */
}

int nilfs_setattr(struct dentry *dentry, struct iattr *iattr)
{
	struct nilfs_transaction_info ti;
816
	struct inode *inode = d_inode(dentry);
R
Ryusuke Konishi 已提交
817
	struct super_block *sb = inode->i_sb;
818
	int err;
R
Ryusuke Konishi 已提交
819 820 821 822 823 824 825 826

	err = inode_change_ok(inode, iattr);
	if (err)
		return err;

	err = nilfs_transaction_begin(sb, &ti, 0);
	if (unlikely(err))
		return err;
C
Christoph Hellwig 已提交
827 828 829

	if ((iattr->ia_valid & ATTR_SIZE) &&
	    iattr->ia_size != i_size_read(inode)) {
830
		inode_dio_wait(inode);
M
Marco Stornelli 已提交
831 832
		truncate_setsize(inode, iattr->ia_size);
		nilfs_truncate(inode);
C
Christoph Hellwig 已提交
833 834 835 836 837 838
	}

	setattr_copy(inode, iattr);
	mark_inode_dirty(inode);

	if (iattr->ia_valid & ATTR_MODE) {
R
Ryusuke Konishi 已提交
839
		err = nilfs_acl_chmod(inode);
C
Christoph Hellwig 已提交
840 841 842 843 844
		if (unlikely(err))
			goto out_err;
	}

	return nilfs_transaction_commit(sb);
845

C
Christoph Hellwig 已提交
846 847
out_err:
	nilfs_transaction_abort(sb);
848
	return err;
R
Ryusuke Konishi 已提交
849 850
}

851
int nilfs_permission(struct inode *inode, int mask)
852
{
853
	struct nilfs_root *root = NILFS_I(inode)->i_root;
854

855 856 857 858
	if ((mask & MAY_WRITE) && root &&
	    root->cno != NILFS_CPTREE_CURRENT_CNO)
		return -EROFS; /* snapshot is not writable */

859
	return generic_permission(inode, mask);
860 861
}

862
int nilfs_load_inode_block(struct inode *inode, struct buffer_head **pbh)
R
Ryusuke Konishi 已提交
863
{
864
	struct the_nilfs *nilfs = inode->i_sb->s_fs_info;
R
Ryusuke Konishi 已提交
865 866 867
	struct nilfs_inode_info *ii = NILFS_I(inode);
	int err;

868
	spin_lock(&nilfs->ns_inode_lock);
R
Ryusuke Konishi 已提交
869
	if (ii->i_bh == NULL) {
870
		spin_unlock(&nilfs->ns_inode_lock);
871 872
		err = nilfs_ifile_get_inode_block(ii->i_root->ifile,
						  inode->i_ino, pbh);
R
Ryusuke Konishi 已提交
873 874
		if (unlikely(err))
			return err;
875
		spin_lock(&nilfs->ns_inode_lock);
R
Ryusuke Konishi 已提交
876 877 878 879 880 881 882 883 884 885
		if (ii->i_bh == NULL)
			ii->i_bh = *pbh;
		else {
			brelse(*pbh);
			*pbh = ii->i_bh;
		}
	} else
		*pbh = ii->i_bh;

	get_bh(*pbh);
886
	spin_unlock(&nilfs->ns_inode_lock);
R
Ryusuke Konishi 已提交
887 888 889 890 891 892
	return 0;
}

int nilfs_inode_dirty(struct inode *inode)
{
	struct nilfs_inode_info *ii = NILFS_I(inode);
893
	struct the_nilfs *nilfs = inode->i_sb->s_fs_info;
R
Ryusuke Konishi 已提交
894 895 896
	int ret = 0;

	if (!list_empty(&ii->i_dirty)) {
897
		spin_lock(&nilfs->ns_inode_lock);
R
Ryusuke Konishi 已提交
898 899
		ret = test_bit(NILFS_I_DIRTY, &ii->i_state) ||
			test_bit(NILFS_I_BUSY, &ii->i_state);
900
		spin_unlock(&nilfs->ns_inode_lock);
R
Ryusuke Konishi 已提交
901 902 903 904
	}
	return ret;
}

905
int nilfs_set_file_dirty(struct inode *inode, unsigned nr_dirty)
R
Ryusuke Konishi 已提交
906 907
{
	struct nilfs_inode_info *ii = NILFS_I(inode);
908
	struct the_nilfs *nilfs = inode->i_sb->s_fs_info;
R
Ryusuke Konishi 已提交
909

910
	atomic_add(nr_dirty, &nilfs->ns_ndirtyblks);
R
Ryusuke Konishi 已提交
911

R
Ryusuke Konishi 已提交
912
	if (test_and_set_bit(NILFS_I_DIRTY, &ii->i_state))
R
Ryusuke Konishi 已提交
913 914
		return 0;

915
	spin_lock(&nilfs->ns_inode_lock);
R
Ryusuke Konishi 已提交
916 917 918 919 920 921 922
	if (!test_bit(NILFS_I_QUEUED, &ii->i_state) &&
	    !test_bit(NILFS_I_BUSY, &ii->i_state)) {
		/* Because this routine may race with nilfs_dispose_list(),
		   we have to check NILFS_I_QUEUED here, too. */
		if (list_empty(&ii->i_dirty) && igrab(inode) == NULL) {
			/* This will happen when somebody is freeing
			   this inode. */
923
			nilfs_warning(inode->i_sb, __func__,
R
Ryusuke Konishi 已提交
924 925
				      "cannot get inode (ino=%lu)\n",
				      inode->i_ino);
926
			spin_unlock(&nilfs->ns_inode_lock);
R
Ryusuke Konishi 已提交
927 928 929
			return -EINVAL; /* NILFS_I_DIRTY may remain for
					   freeing inode */
		}
930
		list_move_tail(&ii->i_dirty, &nilfs->ns_dirty_files);
R
Ryusuke Konishi 已提交
931 932
		set_bit(NILFS_I_QUEUED, &ii->i_state);
	}
933
	spin_unlock(&nilfs->ns_inode_lock);
R
Ryusuke Konishi 已提交
934 935 936
	return 0;
}

937
int __nilfs_mark_inode_dirty(struct inode *inode, int flags)
R
Ryusuke Konishi 已提交
938 939 940 941
{
	struct buffer_head *ibh;
	int err;

942
	err = nilfs_load_inode_block(inode, &ibh);
R
Ryusuke Konishi 已提交
943 944 945 946 947
	if (unlikely(err)) {
		nilfs_warning(inode->i_sb, __func__,
			      "failed to reget inode block.\n");
		return err;
	}
948
	nilfs_update_inode(inode, ibh, flags);
949
	mark_buffer_dirty(ibh);
950
	nilfs_mdt_mark_dirty(NILFS_I(inode)->i_root->ifile);
R
Ryusuke Konishi 已提交
951 952 953 954 955 956 957 958 959 960 961 962 963 964
	brelse(ibh);
	return 0;
}

/**
 * nilfs_dirty_inode - reflect changes on given inode to an inode block.
 * @inode: inode of the file to be registered.
 *
 * nilfs_dirty_inode() loads a inode block containing the specified
 * @inode and copies data from a nilfs_inode to a corresponding inode
 * entry in the inode block. This operation is excluded from the segment
 * construction. This function can be called both as a single operation
 * and as a part of indivisible file operations.
 */
965
void nilfs_dirty_inode(struct inode *inode, int flags)
R
Ryusuke Konishi 已提交
966 967
{
	struct nilfs_transaction_info ti;
968
	struct nilfs_mdt_info *mdi = NILFS_MDT(inode);
R
Ryusuke Konishi 已提交
969 970 971 972 973 974 975

	if (is_bad_inode(inode)) {
		nilfs_warning(inode->i_sb, __func__,
			      "tried to mark bad_inode dirty. ignored.\n");
		dump_stack();
		return;
	}
976 977 978 979
	if (mdi) {
		nilfs_mdt_mark_dirty(inode);
		return;
	}
R
Ryusuke Konishi 已提交
980
	nilfs_transaction_begin(inode->i_sb, &ti, 0);
981
	__nilfs_mark_inode_dirty(inode, flags);
982
	nilfs_transaction_commit(inode->i_sb); /* never fails */
R
Ryusuke Konishi 已提交
983
}
R
Ryusuke Konishi 已提交
984 985 986 987

int nilfs_fiemap(struct inode *inode, struct fiemap_extent_info *fieinfo,
		 __u64 start, __u64 len)
{
988
	struct the_nilfs *nilfs = inode->i_sb->s_fs_info;
R
Ryusuke Konishi 已提交
989 990 991 992 993 994 995 996 997 998 999 1000 1001
	__u64 logical = 0, phys = 0, size = 0;
	__u32 flags = 0;
	loff_t isize;
	sector_t blkoff, end_blkoff;
	sector_t delalloc_blkoff;
	unsigned long delalloc_blklen;
	unsigned int blkbits = inode->i_blkbits;
	int ret, n;

	ret = fiemap_check_flags(fieinfo, FIEMAP_FLAG_SYNC);
	if (ret)
		return ret;

A
Al Viro 已提交
1002
	inode_lock(inode);
R
Ryusuke Konishi 已提交
1003 1004 1005 1006 1007 1008 1009 1010 1011 1012 1013 1014 1015 1016 1017 1018 1019 1020 1021 1022 1023 1024 1025 1026 1027 1028 1029 1030 1031 1032 1033 1034 1035 1036 1037 1038 1039 1040 1041 1042 1043 1044 1045 1046 1047 1048 1049 1050 1051 1052 1053 1054 1055 1056 1057 1058 1059 1060 1061 1062 1063 1064 1065 1066 1067 1068 1069 1070 1071 1072 1073 1074 1075 1076 1077 1078 1079 1080 1081 1082 1083 1084 1085 1086 1087 1088 1089 1090 1091 1092 1093 1094 1095 1096 1097 1098 1099 1100 1101 1102 1103 1104 1105 1106 1107 1108 1109 1110 1111

	isize = i_size_read(inode);

	blkoff = start >> blkbits;
	end_blkoff = (start + len - 1) >> blkbits;

	delalloc_blklen = nilfs_find_uncommitted_extent(inode, blkoff,
							&delalloc_blkoff);

	do {
		__u64 blkphy;
		unsigned int maxblocks;

		if (delalloc_blklen && blkoff == delalloc_blkoff) {
			if (size) {
				/* End of the current extent */
				ret = fiemap_fill_next_extent(
					fieinfo, logical, phys, size, flags);
				if (ret)
					break;
			}
			if (blkoff > end_blkoff)
				break;

			flags = FIEMAP_EXTENT_MERGED | FIEMAP_EXTENT_DELALLOC;
			logical = blkoff << blkbits;
			phys = 0;
			size = delalloc_blklen << blkbits;

			blkoff = delalloc_blkoff + delalloc_blklen;
			delalloc_blklen = nilfs_find_uncommitted_extent(
				inode, blkoff, &delalloc_blkoff);
			continue;
		}

		/*
		 * Limit the number of blocks that we look up so as
		 * not to get into the next delayed allocation extent.
		 */
		maxblocks = INT_MAX;
		if (delalloc_blklen)
			maxblocks = min_t(sector_t, delalloc_blkoff - blkoff,
					  maxblocks);
		blkphy = 0;

		down_read(&NILFS_MDT(nilfs->ns_dat)->mi_sem);
		n = nilfs_bmap_lookup_contig(
			NILFS_I(inode)->i_bmap, blkoff, &blkphy, maxblocks);
		up_read(&NILFS_MDT(nilfs->ns_dat)->mi_sem);

		if (n < 0) {
			int past_eof;

			if (unlikely(n != -ENOENT))
				break; /* error */

			/* HOLE */
			blkoff++;
			past_eof = ((blkoff << blkbits) >= isize);

			if (size) {
				/* End of the current extent */

				if (past_eof)
					flags |= FIEMAP_EXTENT_LAST;

				ret = fiemap_fill_next_extent(
					fieinfo, logical, phys, size, flags);
				if (ret)
					break;
				size = 0;
			}
			if (blkoff > end_blkoff || past_eof)
				break;
		} else {
			if (size) {
				if (phys && blkphy << blkbits == phys + size) {
					/* The current extent goes on */
					size += n << blkbits;
				} else {
					/* Terminate the current extent */
					ret = fiemap_fill_next_extent(
						fieinfo, logical, phys, size,
						flags);
					if (ret || blkoff > end_blkoff)
						break;

					/* Start another extent */
					flags = FIEMAP_EXTENT_MERGED;
					logical = blkoff << blkbits;
					phys = blkphy << blkbits;
					size = n << blkbits;
				}
			} else {
				/* Start a new extent */
				flags = FIEMAP_EXTENT_MERGED;
				logical = blkoff << blkbits;
				phys = blkphy << blkbits;
				size = n << blkbits;
			}
			blkoff += n;
		}
		cond_resched();
	} while (true);

	/* If ret is 1 then we just hit the end of the extent array */
	if (ret == 1)
		ret = 0;

A
Al Viro 已提交
1112
	inode_unlock(inode);
R
Ryusuke Konishi 已提交
1113 1114
	return ret;
}