2012-11-29 12:28:09 +08:00
|
|
|
/*
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
* fs/f2fs/f2fs.h
|
|
|
|
*
|
|
|
|
* 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.
|
|
|
|
*/
|
|
|
|
#ifndef _LINUX_F2FS_H
|
|
|
|
#define _LINUX_F2FS_H
|
|
|
|
|
|
|
|
#include <linux/types.h>
|
|
|
|
#include <linux/page-flags.h>
|
|
|
|
#include <linux/buffer_head.h>
|
|
|
|
#include <linux/slab.h>
|
|
|
|
#include <linux/crc32.h>
|
|
|
|
#include <linux/magic.h>
|
2013-08-08 14:56:49 +08:00
|
|
|
#include <linux/kobject.h>
|
2013-10-22 14:52:26 +08:00
|
|
|
#include <linux/sched.h>
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
|
2013-10-29 14:14:54 +08:00
|
|
|
#ifdef CONFIG_F2FS_CHECK_FS
|
2014-09-03 06:52:58 +08:00
|
|
|
#define f2fs_bug_on(sbi, condition) BUG_ON(condition)
|
2013-11-24 12:50:35 +08:00
|
|
|
#define f2fs_down_write(x, y) down_write_nest_lock(x, y)
|
2013-10-29 14:14:54 +08:00
|
|
|
#else
|
2014-09-03 06:52:58 +08:00
|
|
|
#define f2fs_bug_on(sbi, condition) \
|
|
|
|
do { \
|
|
|
|
if (unlikely(condition)) { \
|
|
|
|
WARN_ON(1); \
|
|
|
|
sbi->need_fsck = true; \
|
|
|
|
} \
|
|
|
|
} while (0)
|
2013-11-24 12:50:35 +08:00
|
|
|
#define f2fs_down_write(x, y) down_write(x)
|
2013-10-29 14:14:54 +08:00
|
|
|
#endif
|
|
|
|
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
/*
|
|
|
|
* For mount options
|
|
|
|
*/
|
|
|
|
#define F2FS_MOUNT_BG_GC 0x00000001
|
|
|
|
#define F2FS_MOUNT_DISABLE_ROLL_FORWARD 0x00000002
|
|
|
|
#define F2FS_MOUNT_DISCARD 0x00000004
|
|
|
|
#define F2FS_MOUNT_NOHEAP 0x00000008
|
|
|
|
#define F2FS_MOUNT_XATTR_USER 0x00000010
|
|
|
|
#define F2FS_MOUNT_POSIX_ACL 0x00000020
|
|
|
|
#define F2FS_MOUNT_DISABLE_EXT_IDENTIFY 0x00000040
|
2013-08-08 14:16:22 +08:00
|
|
|
#define F2FS_MOUNT_INLINE_XATTR 0x00000080
|
2013-11-10 23:13:16 +08:00
|
|
|
#define F2FS_MOUNT_INLINE_DATA 0x00000100
|
2014-09-24 18:15:19 +08:00
|
|
|
#define F2FS_MOUNT_INLINE_DENTRY 0x00000200
|
|
|
|
#define F2FS_MOUNT_FLUSH_MERGE 0x00000400
|
|
|
|
#define F2FS_MOUNT_NOBARRIER 0x00000800
|
2014-10-31 13:47:03 +08:00
|
|
|
#define F2FS_MOUNT_FASTBOOT 0x00001000
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
|
|
|
|
#define clear_opt(sbi, option) (sbi->mount_opt.opt &= ~F2FS_MOUNT_##option)
|
|
|
|
#define set_opt(sbi, option) (sbi->mount_opt.opt |= F2FS_MOUNT_##option)
|
|
|
|
#define test_opt(sbi, option) (sbi->mount_opt.opt & F2FS_MOUNT_##option)
|
|
|
|
|
|
|
|
#define ver_after(a, b) (typecheck(unsigned long long, a) && \
|
|
|
|
typecheck(unsigned long long, b) && \
|
|
|
|
((long long)((a) - (b)) > 0))
|
|
|
|
|
2013-05-24 11:41:04 +08:00
|
|
|
typedef u32 block_t; /*
|
|
|
|
* should not change u32, since it is the on-disk block
|
|
|
|
* address format, __le32.
|
|
|
|
*/
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
typedef u32 nid_t;
|
|
|
|
|
|
|
|
struct f2fs_mount_info {
|
|
|
|
unsigned int opt;
|
|
|
|
};
|
|
|
|
|
2013-06-19 19:47:19 +08:00
|
|
|
#define CRCPOLY_LE 0xedb88320
|
|
|
|
|
|
|
|
static inline __u32 f2fs_crc32(void *buf, size_t len)
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
{
|
2013-06-19 19:47:19 +08:00
|
|
|
unsigned char *p = (unsigned char *)buf;
|
|
|
|
__u32 crc = F2FS_SUPER_MAGIC;
|
|
|
|
int i;
|
|
|
|
|
|
|
|
while (len--) {
|
|
|
|
crc ^= *p++;
|
|
|
|
for (i = 0; i < 8; i++)
|
|
|
|
crc = (crc >> 1) ^ ((crc & 1) ? CRCPOLY_LE : 0);
|
|
|
|
}
|
|
|
|
return crc;
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
}
|
|
|
|
|
2013-06-19 19:47:19 +08:00
|
|
|
static inline bool f2fs_crc_valid(__u32 blk_crc, void *buf, size_t buf_size)
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
{
|
2013-06-19 19:47:19 +08:00
|
|
|
return f2fs_crc32(buf, buf_size) == blk_crc;
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* For checkpoint manager
|
|
|
|
*/
|
|
|
|
enum {
|
|
|
|
NAT_BITMAP,
|
|
|
|
SIT_BITMAP
|
|
|
|
};
|
|
|
|
|
2014-09-21 12:57:51 +08:00
|
|
|
enum {
|
|
|
|
CP_UMOUNT,
|
|
|
|
CP_SYNC,
|
2014-09-21 13:06:39 +08:00
|
|
|
CP_DISCARD,
|
2014-09-21 12:57:51 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
struct cp_control {
|
|
|
|
int reason;
|
2014-09-21 13:06:39 +08:00
|
|
|
__u64 trim_start;
|
|
|
|
__u64 trim_end;
|
|
|
|
__u64 trim_minlen;
|
|
|
|
__u64 trimmed;
|
2014-09-21 12:57:51 +08:00
|
|
|
};
|
|
|
|
|
2014-02-07 16:11:53 +08:00
|
|
|
/*
|
2014-02-27 19:12:24 +08:00
|
|
|
* For CP/NAT/SIT/SSA readahead
|
2014-02-07 16:11:53 +08:00
|
|
|
*/
|
|
|
|
enum {
|
|
|
|
META_CP,
|
|
|
|
META_NAT,
|
2014-02-27 19:12:24 +08:00
|
|
|
META_SIT,
|
2014-09-12 04:49:55 +08:00
|
|
|
META_SSA,
|
|
|
|
META_POR,
|
2014-02-07 16:11:53 +08:00
|
|
|
};
|
|
|
|
|
2014-07-26 06:47:17 +08:00
|
|
|
/* for the list of ino */
|
|
|
|
enum {
|
|
|
|
ORPHAN_INO, /* for orphan ino list */
|
2014-07-25 22:40:59 +08:00
|
|
|
APPEND_INO, /* for append ino list */
|
|
|
|
UPDATE_INO, /* for update ino list */
|
2014-07-26 06:47:17 +08:00
|
|
|
MAX_INO_ENTRY, /* max. list */
|
|
|
|
};
|
|
|
|
|
|
|
|
struct ino_entry {
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
struct list_head list; /* list head */
|
|
|
|
nid_t ino; /* inode number */
|
|
|
|
};
|
|
|
|
|
|
|
|
/* for the list of directory inodes */
|
|
|
|
struct dir_inode_entry {
|
|
|
|
struct list_head list; /* list head */
|
|
|
|
struct inode *inode; /* vfs inode pointer */
|
|
|
|
};
|
|
|
|
|
2013-11-15 12:55:58 +08:00
|
|
|
/* for the list of blockaddresses to be discarded */
|
|
|
|
struct discard_entry {
|
|
|
|
struct list_head list; /* list head */
|
|
|
|
block_t blkaddr; /* block address to be discarded */
|
|
|
|
int len; /* # of consecutive blocks of the discard */
|
|
|
|
};
|
|
|
|
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
/* for the list of fsync inodes, used only during recovery */
|
|
|
|
struct fsync_inode_entry {
|
|
|
|
struct list_head list; /* list head */
|
|
|
|
struct inode *inode; /* vfs inode pointer */
|
2014-09-12 05:29:06 +08:00
|
|
|
block_t blkaddr; /* block address locating the last fsync */
|
|
|
|
block_t last_dentry; /* block address locating the last dentry */
|
|
|
|
block_t last_inode; /* block address locating the last inode */
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
#define nats_in_cursum(sum) (le16_to_cpu(sum->n_nats))
|
|
|
|
#define sits_in_cursum(sum) (le16_to_cpu(sum->n_sits))
|
|
|
|
|
|
|
|
#define nat_in_journal(sum, i) (sum->nat_j.entries[i].ne)
|
|
|
|
#define nid_in_journal(sum, i) (sum->nat_j.entries[i].nid)
|
|
|
|
#define sit_in_journal(sum, i) (sum->sit_j.entries[i].se)
|
|
|
|
#define segno_in_journal(sum, i) (sum->sit_j.entries[i].segno)
|
|
|
|
|
2014-09-23 02:40:48 +08:00
|
|
|
#define MAX_NAT_JENTRIES(sum) (NAT_JOURNAL_ENTRIES - nats_in_cursum(sum))
|
|
|
|
#define MAX_SIT_JENTRIES(sum) (SIT_JOURNAL_ENTRIES - sits_in_cursum(sum))
|
|
|
|
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
static inline int update_nats_in_cursum(struct f2fs_summary_block *rs, int i)
|
|
|
|
{
|
|
|
|
int before = nats_in_cursum(rs);
|
|
|
|
rs->n_nats = cpu_to_le16(before + i);
|
|
|
|
return before;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int update_sits_in_cursum(struct f2fs_summary_block *rs, int i)
|
|
|
|
{
|
|
|
|
int before = sits_in_cursum(rs);
|
|
|
|
rs->n_sits = cpu_to_le16(before + i);
|
|
|
|
return before;
|
|
|
|
}
|
|
|
|
|
f2fs: refactor flush_sit_entries codes for reducing SIT writes
In commit aec71382c681 ("f2fs: refactor flush_nat_entries codes for reducing NAT
writes"), we descripte the issue as below:
"Although building NAT journal in cursum reduce the read/write work for NAT
block, but previous design leave us lower performance when write checkpoint
frequently for these cases:
1. if journal in cursum has already full, it's a bit of waste that we flush all
nat entries to page for persistence, but not to cache any entries.
2. if journal in cursum is not full, we fill nat entries to journal util
journal is full, then flush the left dirty entries to disk without merge
journaled entries, so these journaled entries may be flushed to disk at next
checkpoint but lost chance to flushed last time."
Actually, we have the same problem in using SIT journal area.
In this patch, firstly we will update sit journal with dirty entries as many as
possible. Secondly if there is no space in sit journal, we will remove all
entries in journal and walk through the whole dirty entry bitmap of sit,
accounting dirty sit entries located in same SIT block to sit entry set. All
entry sets are linked to list sit_entry_set in sm_info, sorted ascending order
by count of entries in set. Later we flush entries in set which have fewest
entries into journal as many as we can, and then flush dense set with merged
entries to disk.
In this way we can use sit journal area more effectively, also we will reduce
SIT update, result in gaining in performance and saving lifetime of flash
device.
In my testing environment, it shows this patch can help to reduce SIT block
update obviously.
virtual machine + hard disk:
fsstress -p 20 -n 400 -l 5
sit page num cp count sit pages/cp
based 2006.50 1349.75 1.486
patched 1566.25 1463.25 1.070
Our latency of merging op is small when handling a great number of dirty SIT
entries in flush_sit_entries:
latency(ns) dirty sit count
36038 2151
49168 2123
37174 2232
Signed-off-by: Chao Yu <chao2.yu@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
2014-09-04 18:13:01 +08:00
|
|
|
static inline bool __has_cursum_space(struct f2fs_summary_block *sum, int size,
|
|
|
|
int type)
|
|
|
|
{
|
|
|
|
if (type == NAT_JOURNAL)
|
2014-09-23 02:40:48 +08:00
|
|
|
return size <= MAX_NAT_JENTRIES(sum);
|
|
|
|
return size <= MAX_SIT_JENTRIES(sum);
|
f2fs: refactor flush_sit_entries codes for reducing SIT writes
In commit aec71382c681 ("f2fs: refactor flush_nat_entries codes for reducing NAT
writes"), we descripte the issue as below:
"Although building NAT journal in cursum reduce the read/write work for NAT
block, but previous design leave us lower performance when write checkpoint
frequently for these cases:
1. if journal in cursum has already full, it's a bit of waste that we flush all
nat entries to page for persistence, but not to cache any entries.
2. if journal in cursum is not full, we fill nat entries to journal util
journal is full, then flush the left dirty entries to disk without merge
journaled entries, so these journaled entries may be flushed to disk at next
checkpoint but lost chance to flushed last time."
Actually, we have the same problem in using SIT journal area.
In this patch, firstly we will update sit journal with dirty entries as many as
possible. Secondly if there is no space in sit journal, we will remove all
entries in journal and walk through the whole dirty entry bitmap of sit,
accounting dirty sit entries located in same SIT block to sit entry set. All
entry sets are linked to list sit_entry_set in sm_info, sorted ascending order
by count of entries in set. Later we flush entries in set which have fewest
entries into journal as many as we can, and then flush dense set with merged
entries to disk.
In this way we can use sit journal area more effectively, also we will reduce
SIT update, result in gaining in performance and saving lifetime of flash
device.
In my testing environment, it shows this patch can help to reduce SIT block
update obviously.
virtual machine + hard disk:
fsstress -p 20 -n 400 -l 5
sit page num cp count sit pages/cp
based 2006.50 1349.75 1.486
patched 1566.25 1463.25 1.070
Our latency of merging op is small when handling a great number of dirty SIT
entries in flush_sit_entries:
latency(ns) dirty sit count
36038 2151
49168 2123
37174 2232
Signed-off-by: Chao Yu <chao2.yu@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
2014-09-04 18:13:01 +08:00
|
|
|
}
|
|
|
|
|
2013-02-04 22:41:41 +08:00
|
|
|
/*
|
|
|
|
* ioctl commands
|
|
|
|
*/
|
2014-10-07 08:39:50 +08:00
|
|
|
#define F2FS_IOC_GETFLAGS FS_IOC_GETFLAGS
|
|
|
|
#define F2FS_IOC_SETFLAGS FS_IOC_SETFLAGS
|
|
|
|
|
|
|
|
#define F2FS_IOCTL_MAGIC 0xf5
|
|
|
|
#define F2FS_IOC_START_ATOMIC_WRITE _IO(F2FS_IOCTL_MAGIC, 1)
|
|
|
|
#define F2FS_IOC_COMMIT_ATOMIC_WRITE _IO(F2FS_IOCTL_MAGIC, 2)
|
2014-10-07 07:11:16 +08:00
|
|
|
#define F2FS_IOC_START_VOLATILE_WRITE _IO(F2FS_IOCTL_MAGIC, 3)
|
2013-02-04 22:41:41 +08:00
|
|
|
|
|
|
|
#if defined(__KERNEL__) && defined(CONFIG_COMPAT)
|
|
|
|
/*
|
|
|
|
* ioctl commands in 32 bit emulation
|
|
|
|
*/
|
|
|
|
#define F2FS_IOC32_GETFLAGS FS_IOC32_GETFLAGS
|
|
|
|
#define F2FS_IOC32_SETFLAGS FS_IOC32_SETFLAGS
|
|
|
|
#endif
|
|
|
|
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
/*
|
|
|
|
* For INODE and NODE manager
|
|
|
|
*/
|
2014-10-19 13:52:52 +08:00
|
|
|
/* for directory operations */
|
|
|
|
struct f2fs_dentry_ptr {
|
|
|
|
const void *bitmap;
|
|
|
|
struct f2fs_dir_entry *dentry;
|
|
|
|
__u8 (*filename)[F2FS_SLOT_LEN];
|
|
|
|
int max;
|
|
|
|
};
|
|
|
|
|
|
|
|
static inline void make_dentry_ptr(struct f2fs_dentry_ptr *d,
|
|
|
|
void *src, int type)
|
|
|
|
{
|
|
|
|
if (type == 1) {
|
|
|
|
struct f2fs_dentry_block *t = (struct f2fs_dentry_block *)src;
|
|
|
|
d->max = NR_DENTRY_IN_BLOCK;
|
|
|
|
d->bitmap = &t->dentry_bitmap;
|
|
|
|
d->dentry = t->dentry;
|
|
|
|
d->filename = t->filename;
|
|
|
|
} else {
|
|
|
|
struct f2fs_inline_dentry *t = (struct f2fs_inline_dentry *)src;
|
|
|
|
d->max = NR_INLINE_DENTRY;
|
|
|
|
d->bitmap = &t->dentry_bitmap;
|
|
|
|
d->dentry = t->dentry;
|
|
|
|
d->filename = t->filename;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-08-09 07:14:06 +08:00
|
|
|
/*
|
|
|
|
* XATTR_NODE_OFFSET stores xattrs to one node block per file keeping -1
|
|
|
|
* as its node offset to distinguish from index node blocks.
|
|
|
|
* But some bits are used to mark the node block.
|
|
|
|
*/
|
|
|
|
#define XATTR_NODE_OFFSET ((((unsigned int)-1) << OFFSET_BIT_SHIFT) \
|
|
|
|
>> OFFSET_BIT_SHIFT)
|
2013-02-26 12:10:46 +08:00
|
|
|
enum {
|
|
|
|
ALLOC_NODE, /* allocate a new node page if needed */
|
|
|
|
LOOKUP_NODE, /* look up a node without readahead */
|
|
|
|
LOOKUP_NODE_RA, /*
|
|
|
|
* look up a node with readahead called
|
2013-12-21 18:02:14 +08:00
|
|
|
* by get_data_block.
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
*/
|
2013-02-26 12:10:46 +08:00
|
|
|
};
|
|
|
|
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
#define F2FS_LINK_MAX 32000 /* maximum link count per file */
|
|
|
|
|
2014-04-28 17:59:43 +08:00
|
|
|
#define MAX_DIR_RA_PAGES 4 /* maximum ra pages of dir */
|
|
|
|
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
/* for in-memory extent cache entry */
|
2013-11-19 09:41:54 +08:00
|
|
|
#define F2FS_MIN_EXTENT_LEN 16 /* minimum extent length */
|
|
|
|
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
struct extent_info {
|
|
|
|
rwlock_t ext_lock; /* rwlock for consistency */
|
|
|
|
unsigned int fofs; /* start offset in a file */
|
|
|
|
u32 blk_addr; /* start block address of the extent */
|
2013-03-19 07:03:35 +08:00
|
|
|
unsigned int len; /* length of the extent */
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* i_advise uses FADVISE_XXX_BIT. We can add additional hints later.
|
|
|
|
*/
|
|
|
|
#define FADVISE_COLD_BIT 0x01
|
2013-06-14 07:52:35 +08:00
|
|
|
#define FADVISE_LOST_PINO_BIT 0x02
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
|
2014-02-27 19:09:05 +08:00
|
|
|
#define DEF_DIR_LEVEL 0
|
|
|
|
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
struct f2fs_inode_info {
|
|
|
|
struct inode vfs_inode; /* serve a vfs inode */
|
|
|
|
unsigned long i_flags; /* keep an inode flags for ioctl */
|
|
|
|
unsigned char i_advise; /* use to give file attribute hints */
|
2014-02-27 17:20:00 +08:00
|
|
|
unsigned char i_dir_level; /* use for dentry level for large dir */
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
unsigned int i_current_depth; /* use only in directory structure */
|
f2fs: fix tracking parent inode number
Previously, f2fs didn't track the parent inode number correctly which is stored
in each f2fs_inode. In the case of the following scenario, a bug can be occured.
Let's suppose there are one directory, "/b", and two files, "/a" and "/b/a".
- pino of "/a" is ROOT_INO.
- pino of "/b/a" is DIR_B_INO.
Then,
# sync
: The inode pages of "/a" and "/b/a" contain the parent inode numbers as
ROOT_INO and DIR_B_INO respectively.
# mv /a /b/a
: The parent inode number of "/a" should be changed to DIR_B_INO, but f2fs
didn't do that. Ref. f2fs_set_link().
In order to fix this clearly, I added i_pino in f2fs_inode_info, and whenever
it needs to be changed like in f2fs_add_link() and f2fs_set_link(), it is
updated temporarily in f2fs_inode_info.
And later, f2fs_write_inode() stores the latest information to the inode pages.
For power-off-recovery, f2fs_sync_file() triggers simply f2fs_write_inode().
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-12-10 16:52:48 +08:00
|
|
|
unsigned int i_pino; /* parent inode number */
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
umode_t i_acl_mode; /* keep file acl mode temporarily */
|
|
|
|
|
|
|
|
/* Use below internally in f2fs*/
|
|
|
|
unsigned long flags; /* use to pass per-file flags */
|
2014-03-20 18:10:08 +08:00
|
|
|
struct rw_semaphore i_sem; /* protect fi info */
|
2014-09-13 06:53:45 +08:00
|
|
|
atomic_t dirty_pages; /* # of dirty pages */
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
f2fs_hash_t chash; /* hash value of given file name */
|
|
|
|
unsigned int clevel; /* maximum level of given file name */
|
|
|
|
nid_t i_xattr_nid; /* node id that contains xattrs */
|
2013-08-09 13:46:15 +08:00
|
|
|
unsigned long long xattr_ver; /* cp version of xattr modification */
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
struct extent_info ext; /* in-memory extent cache entry */
|
2014-04-15 10:19:28 +08:00
|
|
|
struct dir_inode_entry *dirty_dir; /* the pointer of dirty dir */
|
2014-10-07 08:39:50 +08:00
|
|
|
|
2014-10-10 04:19:53 +08:00
|
|
|
struct radix_tree_root inmem_root; /* radix tree for inmem pages */
|
2014-10-07 08:39:50 +08:00
|
|
|
struct list_head inmem_pages; /* inmemory pages managed by f2fs */
|
|
|
|
struct mutex inmem_lock; /* lock for inmemory pages */
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
static inline void get_extent_info(struct extent_info *ext,
|
|
|
|
struct f2fs_extent i_ext)
|
|
|
|
{
|
|
|
|
write_lock(&ext->ext_lock);
|
|
|
|
ext->fofs = le32_to_cpu(i_ext.fofs);
|
|
|
|
ext->blk_addr = le32_to_cpu(i_ext.blk_addr);
|
|
|
|
ext->len = le32_to_cpu(i_ext.len);
|
|
|
|
write_unlock(&ext->ext_lock);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void set_raw_extent(struct extent_info *ext,
|
|
|
|
struct f2fs_extent *i_ext)
|
|
|
|
{
|
|
|
|
read_lock(&ext->ext_lock);
|
|
|
|
i_ext->fofs = cpu_to_le32(ext->fofs);
|
|
|
|
i_ext->blk_addr = cpu_to_le32(ext->blk_addr);
|
|
|
|
i_ext->len = cpu_to_le32(ext->len);
|
|
|
|
read_unlock(&ext->ext_lock);
|
|
|
|
}
|
|
|
|
|
|
|
|
struct f2fs_nm_info {
|
|
|
|
block_t nat_blkaddr; /* base disk address of NAT */
|
|
|
|
nid_t max_nid; /* maximum possible node ids */
|
2014-04-18 10:14:37 +08:00
|
|
|
nid_t available_nids; /* maximum available node ids */
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
nid_t next_scan_nid; /* the next nid to be scanned */
|
2014-03-19 12:31:37 +08:00
|
|
|
unsigned int ram_thresh; /* control the memory footprint */
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
|
|
|
|
/* NAT cache management */
|
|
|
|
struct radix_tree_root nat_root;/* root of the nat entry cache */
|
2014-09-23 02:40:48 +08:00
|
|
|
struct radix_tree_root nat_set_root;/* root of the nat set cache */
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
rwlock_t nat_tree_lock; /* protect nat_tree_lock */
|
|
|
|
struct list_head nat_entries; /* cached nat entry list (clean) */
|
2014-09-23 02:40:48 +08:00
|
|
|
unsigned int nat_cnt; /* the # of cached nat entries */
|
f2fs: refactor flush_nat_entries codes for reducing NAT writes
Although building NAT journal in cursum reduce the read/write work for NAT
block, but previous design leave us lower performance when write checkpoint
frequently for these cases:
1. if journal in cursum has already full, it's a bit of waste that we flush all
nat entries to page for persistence, but not to cache any entries.
2. if journal in cursum is not full, we fill nat entries to journal util
journal is full, then flush the left dirty entries to disk without merge
journaled entries, so these journaled entries may be flushed to disk at next
checkpoint but lost chance to flushed last time.
In this patch we merge dirty entries located in same NAT block to nat entry set,
and linked all set to list, sorted ascending order by entries' count of set.
Later we flush entries in sparse set into journal as many as we can, and then
flush merged entries to disk. In this way we can not only gain in performance,
but also save lifetime of flash device.
In my testing environment, it shows this patch can help to reduce NAT block
writes obviously. In hard disk test case: cost time of fsstress is stablely
reduced by about 5%.
1. virtual machine + hard disk:
fsstress -p 20 -n 200 -l 5
node num cp count nodes/cp
based 4599.6 1803.0 2.551
patched 2714.6 1829.6 1.483
2. virtual machine + 32g micro SD card:
fsstress -p 20 -n 200 -l 1 -w -f chown=0 -f creat=4 -f dwrite=0
-f fdatasync=4 -f fsync=4 -f link=0 -f mkdir=4 -f mknod=4 -f rename=5
-f rmdir=5 -f symlink=0 -f truncate=4 -f unlink=5 -f write=0 -S
node num cp count nodes/cp
based 84.5 43.7 1.933
patched 49.2 40.0 1.23
Our latency of merging op shows not bad when handling extreme case like:
merging a great number of dirty nats:
latency(ns) dirty nat count
3089219 24922
5129423 27422
4000250 24523
change log from v1:
o fix wrong logic in add_nat_entry when grab a new nat entry set.
o swith to create slab cache in create_node_manager_caches.
o use GFP_ATOMIC instead of GFP_NOFS to avoid potential long latency.
change log from v2:
o make comment position more appropriate suggested by Jaegeuk Kim.
Signed-off-by: Chao Yu <chao2.yu@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
2014-06-24 09:18:20 +08:00
|
|
|
unsigned int dirty_nat_cnt; /* total num of nat entries in set */
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
|
|
|
|
/* free node ids management */
|
2014-02-21 13:29:35 +08:00
|
|
|
struct radix_tree_root free_nid_root;/* root of the free_nid cache */
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
struct list_head free_nid_list; /* a list for free nids */
|
|
|
|
spinlock_t free_nid_list_lock; /* protect free nid list */
|
|
|
|
unsigned int fcnt; /* the number of free node id */
|
|
|
|
struct mutex build_lock; /* lock for build free nids */
|
|
|
|
|
|
|
|
/* for checkpoint */
|
|
|
|
char *nat_bitmap; /* NAT bitmap pointer */
|
|
|
|
int bitmap_size; /* bitmap size */
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* this structure is used as one of function parameters.
|
|
|
|
* all the information are dedicated to a given direct node block determined
|
|
|
|
* by the data offset in a file.
|
|
|
|
*/
|
|
|
|
struct dnode_of_data {
|
|
|
|
struct inode *inode; /* vfs inode pointer */
|
|
|
|
struct page *inode_page; /* its inode page, NULL is possible */
|
|
|
|
struct page *node_page; /* cached direct node page */
|
|
|
|
nid_t nid; /* node id of the direct node block */
|
|
|
|
unsigned int ofs_in_node; /* data offset in the node page */
|
|
|
|
bool inode_page_locked; /* inode page is locked or not */
|
|
|
|
block_t data_blkaddr; /* block address of the node block */
|
|
|
|
};
|
|
|
|
|
|
|
|
static inline void set_new_dnode(struct dnode_of_data *dn, struct inode *inode,
|
|
|
|
struct page *ipage, struct page *npage, nid_t nid)
|
|
|
|
{
|
2013-01-03 07:57:21 +08:00
|
|
|
memset(dn, 0, sizeof(*dn));
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
dn->inode = inode;
|
|
|
|
dn->inode_page = ipage;
|
|
|
|
dn->node_page = npage;
|
|
|
|
dn->nid = nid;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* For SIT manager
|
|
|
|
*
|
|
|
|
* By default, there are 6 active log areas across the whole main area.
|
|
|
|
* When considering hot and cold data separation to reduce cleaning overhead,
|
|
|
|
* we split 3 for data logs and 3 for node logs as hot, warm, and cold types,
|
|
|
|
* respectively.
|
|
|
|
* In the current design, you should not change the numbers intentionally.
|
|
|
|
* Instead, as a mount option such as active_logs=x, you can use 2, 4, and 6
|
|
|
|
* logs individually according to the underlying devices. (default: 6)
|
|
|
|
* Just in case, on-disk layout covers maximum 16 logs that consist of 8 for
|
|
|
|
* data and 8 for node logs.
|
|
|
|
*/
|
|
|
|
#define NR_CURSEG_DATA_TYPE (3)
|
|
|
|
#define NR_CURSEG_NODE_TYPE (3)
|
|
|
|
#define NR_CURSEG_TYPE (NR_CURSEG_DATA_TYPE + NR_CURSEG_NODE_TYPE)
|
|
|
|
|
|
|
|
enum {
|
|
|
|
CURSEG_HOT_DATA = 0, /* directory entry blocks */
|
|
|
|
CURSEG_WARM_DATA, /* data blocks */
|
|
|
|
CURSEG_COLD_DATA, /* multimedia or GCed data blocks */
|
|
|
|
CURSEG_HOT_NODE, /* direct node blocks of directory files */
|
|
|
|
CURSEG_WARM_NODE, /* direct node blocks of normal files */
|
|
|
|
CURSEG_COLD_NODE, /* indirect node blocks */
|
|
|
|
NO_CHECK_TYPE
|
|
|
|
};
|
|
|
|
|
2014-04-02 14:34:36 +08:00
|
|
|
struct flush_cmd {
|
|
|
|
struct completion wait;
|
2014-09-05 18:31:00 +08:00
|
|
|
struct llist_node llnode;
|
2014-04-02 14:34:36 +08:00
|
|
|
int ret;
|
|
|
|
};
|
|
|
|
|
2014-04-27 14:21:21 +08:00
|
|
|
struct flush_cmd_control {
|
|
|
|
struct task_struct *f2fs_issue_flush; /* flush thread */
|
|
|
|
wait_queue_head_t flush_wait_queue; /* waiting queue for wake-up */
|
2014-09-05 18:31:00 +08:00
|
|
|
struct llist_head issue_list; /* list for command issue */
|
|
|
|
struct llist_node *dispatch_list; /* list for command dispatch */
|
2014-04-27 14:21:21 +08:00
|
|
|
};
|
|
|
|
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
struct f2fs_sm_info {
|
|
|
|
struct sit_info *sit_info; /* whole segment information */
|
|
|
|
struct free_segmap_info *free_info; /* free segment information */
|
|
|
|
struct dirty_seglist_info *dirty_info; /* dirty segment information */
|
|
|
|
struct curseg_info *curseg_array; /* active segment information */
|
|
|
|
|
|
|
|
block_t seg0_blkaddr; /* block address of 0'th segment */
|
|
|
|
block_t main_blkaddr; /* start block address of main area */
|
|
|
|
block_t ssa_blkaddr; /* start block address of SSA area */
|
|
|
|
|
|
|
|
unsigned int segment_count; /* total # of segments */
|
|
|
|
unsigned int main_segments; /* # of segments in main area */
|
|
|
|
unsigned int reserved_segments; /* # of reserved segments */
|
|
|
|
unsigned int ovp_segments; /* # of overprovision segments */
|
2013-10-24 12:31:34 +08:00
|
|
|
|
|
|
|
/* a threshold to reclaim prefree segments */
|
|
|
|
unsigned int rec_prefree_segments;
|
2013-11-15 12:55:58 +08:00
|
|
|
|
|
|
|
/* for small discard management */
|
|
|
|
struct list_head discard_list; /* 4KB discard list */
|
|
|
|
int nr_discards; /* # of discards in the list */
|
|
|
|
int max_discards; /* max. discards to be issued */
|
2013-11-07 12:13:42 +08:00
|
|
|
|
f2fs: refactor flush_sit_entries codes for reducing SIT writes
In commit aec71382c681 ("f2fs: refactor flush_nat_entries codes for reducing NAT
writes"), we descripte the issue as below:
"Although building NAT journal in cursum reduce the read/write work for NAT
block, but previous design leave us lower performance when write checkpoint
frequently for these cases:
1. if journal in cursum has already full, it's a bit of waste that we flush all
nat entries to page for persistence, but not to cache any entries.
2. if journal in cursum is not full, we fill nat entries to journal util
journal is full, then flush the left dirty entries to disk without merge
journaled entries, so these journaled entries may be flushed to disk at next
checkpoint but lost chance to flushed last time."
Actually, we have the same problem in using SIT journal area.
In this patch, firstly we will update sit journal with dirty entries as many as
possible. Secondly if there is no space in sit journal, we will remove all
entries in journal and walk through the whole dirty entry bitmap of sit,
accounting dirty sit entries located in same SIT block to sit entry set. All
entry sets are linked to list sit_entry_set in sm_info, sorted ascending order
by count of entries in set. Later we flush entries in set which have fewest
entries into journal as many as we can, and then flush dense set with merged
entries to disk.
In this way we can use sit journal area more effectively, also we will reduce
SIT update, result in gaining in performance and saving lifetime of flash
device.
In my testing environment, it shows this patch can help to reduce SIT block
update obviously.
virtual machine + hard disk:
fsstress -p 20 -n 400 -l 5
sit page num cp count sit pages/cp
based 2006.50 1349.75 1.486
patched 1566.25 1463.25 1.070
Our latency of merging op is small when handling a great number of dirty SIT
entries in flush_sit_entries:
latency(ns) dirty sit count
36038 2151
49168 2123
37174 2232
Signed-off-by: Chao Yu <chao2.yu@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
2014-09-04 18:13:01 +08:00
|
|
|
struct list_head sit_entry_set; /* sit entry set list */
|
|
|
|
|
2013-11-07 12:13:42 +08:00
|
|
|
unsigned int ipu_policy; /* in-place-update policy */
|
|
|
|
unsigned int min_ipu_util; /* in-place-update threshold */
|
2014-09-11 07:53:02 +08:00
|
|
|
unsigned int min_fsync_blocks; /* threshold for fsync */
|
2014-04-02 14:34:36 +08:00
|
|
|
|
|
|
|
/* for flush command control */
|
2014-04-27 14:21:21 +08:00
|
|
|
struct flush_cmd_control *cmd_control_info;
|
|
|
|
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* For superblock
|
|
|
|
*/
|
|
|
|
/*
|
|
|
|
* COUNT_TYPE for monitoring
|
|
|
|
*
|
|
|
|
* f2fs monitors the number of several block types such as on-writeback,
|
|
|
|
* dirty dentry blocks, dirty node blocks, and dirty meta blocks.
|
|
|
|
*/
|
|
|
|
enum count_type {
|
|
|
|
F2FS_WRITEBACK,
|
|
|
|
F2FS_DIRTY_DENTS,
|
|
|
|
F2FS_DIRTY_NODES,
|
|
|
|
F2FS_DIRTY_META,
|
|
|
|
NR_COUNT_TYPE,
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
2014-08-06 22:22:50 +08:00
|
|
|
* The below are the page types of bios used in submit_bio().
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
* The available types are:
|
|
|
|
* DATA User data pages. It operates as async mode.
|
|
|
|
* NODE Node pages. It operates as async mode.
|
|
|
|
* META FS metadata pages such as SIT, NAT, CP.
|
|
|
|
* NR_PAGE_TYPE The number of page types.
|
|
|
|
* META_FLUSH Make sure the previous pages are written
|
|
|
|
* with waiting the bio's completion
|
|
|
|
* ... Only can be used with META.
|
|
|
|
*/
|
2013-11-18 16:13:35 +08:00
|
|
|
#define PAGE_TYPE_OF_BIO(type) ((type) > META ? META : (type))
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
enum page_type {
|
|
|
|
DATA,
|
|
|
|
NODE,
|
|
|
|
META,
|
|
|
|
NR_PAGE_TYPE,
|
|
|
|
META_FLUSH,
|
|
|
|
};
|
|
|
|
|
2013-12-11 12:54:01 +08:00
|
|
|
struct f2fs_io_info {
|
2013-12-20 18:17:49 +08:00
|
|
|
enum page_type type; /* contains DATA/NODE/META/META_FLUSH */
|
|
|
|
int rw; /* contains R/RS/W/WS with REQ_META/REQ_PRIO */
|
2013-12-11 12:54:01 +08:00
|
|
|
};
|
|
|
|
|
2013-11-30 11:51:14 +08:00
|
|
|
#define is_read_io(rw) (((rw) & 1) == READ)
|
2013-11-19 11:47:22 +08:00
|
|
|
struct f2fs_bio_info {
|
2013-12-11 12:54:01 +08:00
|
|
|
struct f2fs_sb_info *sbi; /* f2fs superblock */
|
2013-11-19 11:47:22 +08:00
|
|
|
struct bio *bio; /* bios to merge */
|
|
|
|
sector_t last_block_in_bio; /* last block number */
|
2013-12-11 12:54:01 +08:00
|
|
|
struct f2fs_io_info fio; /* store buffered io info. */
|
2014-03-22 14:57:23 +08:00
|
|
|
struct rw_semaphore io_rwsem; /* blocking op for bio */
|
2013-11-19 11:47:22 +08:00
|
|
|
};
|
|
|
|
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
struct f2fs_sb_info {
|
|
|
|
struct super_block *sb; /* pointer to VFS super block */
|
2013-06-28 11:47:01 +08:00
|
|
|
struct proc_dir_entry *s_proc; /* proc entry */
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
struct buffer_head *raw_super_buf; /* buffer head of raw sb */
|
|
|
|
struct f2fs_super_block *raw_super; /* raw super block pointer */
|
|
|
|
int s_dirty; /* dirty flag for checkpoint */
|
2014-09-03 06:43:52 +08:00
|
|
|
bool need_fsck; /* need fsck.f2fs to fix */
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
|
|
|
|
/* for node-related operations */
|
|
|
|
struct f2fs_nm_info *nm_info; /* node manager */
|
|
|
|
struct inode *node_inode; /* cache node blocks */
|
|
|
|
|
|
|
|
/* for segment-related operations */
|
|
|
|
struct f2fs_sm_info *sm_info; /* segment manager */
|
2013-11-19 11:47:22 +08:00
|
|
|
|
|
|
|
/* for bio operations */
|
2013-11-20 14:46:39 +08:00
|
|
|
struct f2fs_bio_info read_io; /* for read bios */
|
2013-11-19 11:47:22 +08:00
|
|
|
struct f2fs_bio_info write_io[NR_PAGE_TYPE]; /* for write bios */
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
|
|
|
|
/* for checkpoint */
|
|
|
|
struct f2fs_checkpoint *ckpt; /* raw checkpoint pointer */
|
|
|
|
struct inode *meta_inode; /* cache meta blocks */
|
f2fs: introduce a new global lock scheme
In the previous version, f2fs uses global locks according to the usage types,
such as directory operations, block allocation, block write, and so on.
Reference the following lock types in f2fs.h.
enum lock_type {
RENAME, /* for renaming operations */
DENTRY_OPS, /* for directory operations */
DATA_WRITE, /* for data write */
DATA_NEW, /* for data allocation */
DATA_TRUNC, /* for data truncate */
NODE_NEW, /* for node allocation */
NODE_TRUNC, /* for node truncate */
NODE_WRITE, /* for node write */
NR_LOCK_TYPE,
};
In that case, we lose the performance under the multi-threading environment,
since every types of operations must be conducted one at a time.
In order to address the problem, let's share the locks globally with a mutex
array regardless of any types.
So, let users grab a mutex and perform their jobs in parallel as much as
possbile.
For this, I propose a new global lock scheme as follows.
0. Data structure
- f2fs_sb_info -> mutex_lock[NR_GLOBAL_LOCKS]
- f2fs_sb_info -> node_write
1. mutex_lock_op(sbi)
- try to get an avaiable lock from the array.
- returns the index of the gottern lock variable.
2. mutex_unlock_op(sbi, index of the lock)
- unlock the given index of the lock.
3. mutex_lock_all(sbi)
- grab all the locks in the array before the checkpoint.
4. mutex_unlock_all(sbi)
- release all the locks in the array after checkpoint.
5. block_operations()
- call mutex_lock_all()
- sync_dirty_dir_inodes()
- grab node_write
- sync_node_pages()
Note that,
the pairs of mutex_lock_op()/mutex_unlock_op() and
mutex_lock_all()/mutex_unlock_all() should be used together.
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-22 15:21:29 +08:00
|
|
|
struct mutex cp_mutex; /* checkpoint procedure lock */
|
f2fs: use rw_sem instead of fs_lock(locks mutex)
The fs_locks is used to block other ops(ex, recovery) when doing checkpoint.
And each other operate routine(besides checkpoint) needs to acquire a fs_lock,
there is a terrible problem here, if these are too many concurrency threads acquiring
fs_lock, so that they will block each other and may lead to some performance problem,
but this is not the phenomenon we want to see.
Though there are some optimization patches introduced to enhance the usage of fs_lock,
but the thorough solution is using a *rw_sem* to replace the fs_lock.
Checkpoint routine takes write_sem, and other ops take read_sem, so that we can block
other ops(ex, recovery) when doing checkpoint, and other ops will not disturb each other,
this can avoid the problem described above completely.
Because of the weakness of rw_sem, the above change may introduce a potential problem
that the checkpoint thread might get starved if other threads are intensively locking
the read semaphore for I/O.(Pointed out by Xu Jin)
In order to avoid this, a wait_list is introduced, the appending read semaphore ops
will be dropped into the wait_list if checkpoint thread is waiting for write semaphore,
and will be waked up when checkpoint thread gives up write semaphore.
Thanks to Kim's previous review and test, and will be very glad to see other guys'
performance tests about this patch.
V2:
-fix the potential starvation problem.
-use more suitable func name suggested by Xu Jin.
Signed-off-by: Gu Zheng <guz.fnst@cn.fujitsu.com>
[Jaegeuk Kim: adjust minor coding standard]
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2013-09-27 18:08:30 +08:00
|
|
|
struct rw_semaphore cp_rwsem; /* blocking FS operations */
|
2014-07-03 18:58:39 +08:00
|
|
|
struct rw_semaphore node_write; /* locking node writes */
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
struct mutex writepages; /* mutex for writepages() */
|
2013-10-23 12:39:32 +08:00
|
|
|
bool por_doing; /* recovery is doing or not */
|
2013-11-07 11:48:25 +08:00
|
|
|
wait_queue_head_t cp_wait;
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
|
2014-07-26 06:47:17 +08:00
|
|
|
/* for inode management */
|
2014-07-25 09:15:17 +08:00
|
|
|
struct radix_tree_root ino_root[MAX_INO_ENTRY]; /* ino entry array */
|
2014-07-26 06:47:17 +08:00
|
|
|
spinlock_t ino_lock[MAX_INO_ENTRY]; /* for ino entry lock */
|
|
|
|
struct list_head ino_list[MAX_INO_ENTRY]; /* inode list head */
|
|
|
|
|
|
|
|
/* for orphan inode, use 0'th array */
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
unsigned int n_orphans; /* # of orphan inodes */
|
2013-12-26 18:24:19 +08:00
|
|
|
unsigned int max_orphans; /* max orphan inodes */
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
|
|
|
|
/* for directory inode management */
|
|
|
|
struct list_head dir_inode_list; /* dir inode list */
|
|
|
|
spinlock_t dir_inode_lock; /* for dir inode list lock */
|
|
|
|
|
2014-08-06 22:22:50 +08:00
|
|
|
/* basic filesystem units */
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
unsigned int log_sectors_per_block; /* log2 sectors per block */
|
|
|
|
unsigned int log_blocksize; /* log2 block size */
|
|
|
|
unsigned int blocksize; /* block size */
|
|
|
|
unsigned int root_ino_num; /* root inode number*/
|
|
|
|
unsigned int node_ino_num; /* node inode number*/
|
|
|
|
unsigned int meta_ino_num; /* meta inode number*/
|
|
|
|
unsigned int log_blocks_per_seg; /* log2 blocks per segment */
|
|
|
|
unsigned int blocks_per_seg; /* blocks per segment */
|
|
|
|
unsigned int segs_per_sec; /* segments per section */
|
|
|
|
unsigned int secs_per_zone; /* sections per zone */
|
|
|
|
unsigned int total_sections; /* total section count */
|
|
|
|
unsigned int total_node_count; /* total node block count */
|
|
|
|
unsigned int total_valid_node_count; /* valid node block count */
|
|
|
|
unsigned int total_valid_inode_count; /* valid inode count */
|
|
|
|
int active_logs; /* # of active logs */
|
2014-02-27 19:09:05 +08:00
|
|
|
int dir_level; /* directory level */
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
|
|
|
|
block_t user_block_count; /* # of user blocks */
|
|
|
|
block_t total_valid_block_count; /* # of valid blocks */
|
|
|
|
block_t alloc_valid_block_count; /* # of allocated blocks */
|
|
|
|
block_t last_valid_block_count; /* for recovery */
|
|
|
|
u32 s_next_generation; /* for NFS support */
|
|
|
|
atomic_t nr_pages[NR_COUNT_TYPE]; /* # of pages, see count_type */
|
|
|
|
|
|
|
|
struct f2fs_mount_info mount_opt; /* mount options */
|
|
|
|
|
|
|
|
/* for cleaning operations */
|
|
|
|
struct mutex gc_mutex; /* mutex for GC */
|
|
|
|
struct f2fs_gc_kthread *gc_thread; /* GC thread */
|
2013-03-31 12:26:03 +08:00
|
|
|
unsigned int cur_victim_sec; /* current victim section num */
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
|
2014-01-08 12:45:08 +08:00
|
|
|
/* maximum # of trials to find a victim segment for SSR and GC */
|
|
|
|
unsigned int max_victim_search;
|
|
|
|
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
/*
|
|
|
|
* for stat information.
|
|
|
|
* one is for the LFS mode, and the other is for the SSR mode.
|
|
|
|
*/
|
2013-05-23 21:57:53 +08:00
|
|
|
#ifdef CONFIG_F2FS_STAT_FS
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
struct f2fs_stat_info *stat_info; /* FS status information */
|
|
|
|
unsigned int segment_count[2]; /* # of allocated segments */
|
|
|
|
unsigned int block_count[2]; /* # of allocated blocks */
|
|
|
|
int total_hit_ext, read_hit_ext; /* extent cache hit ratio */
|
2013-11-26 10:08:57 +08:00
|
|
|
int inline_inode; /* # of inline_data inodes */
|
2014-10-14 11:00:16 +08:00
|
|
|
int inline_dir; /* # of inline_dentry inodes */
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
int bg_gc; /* background gc calls */
|
2013-05-23 21:57:53 +08:00
|
|
|
unsigned int n_dirty_dirs; /* # of dir inodes */
|
|
|
|
#endif
|
|
|
|
unsigned int last_victim[2]; /* last victim segment # */
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
spinlock_t stat_lock; /* lock for stat operations */
|
2013-08-04 22:09:40 +08:00
|
|
|
|
|
|
|
/* For sysfs suppport */
|
|
|
|
struct kobject s_kobj;
|
|
|
|
struct completion s_kobj_unregister;
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Inline functions
|
|
|
|
*/
|
|
|
|
static inline struct f2fs_inode_info *F2FS_I(struct inode *inode)
|
|
|
|
{
|
|
|
|
return container_of(inode, struct f2fs_inode_info, vfs_inode);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline struct f2fs_sb_info *F2FS_SB(struct super_block *sb)
|
|
|
|
{
|
|
|
|
return sb->s_fs_info;
|
|
|
|
}
|
|
|
|
|
2014-09-03 06:31:18 +08:00
|
|
|
static inline struct f2fs_sb_info *F2FS_I_SB(struct inode *inode)
|
|
|
|
{
|
|
|
|
return F2FS_SB(inode->i_sb);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline struct f2fs_sb_info *F2FS_M_SB(struct address_space *mapping)
|
|
|
|
{
|
|
|
|
return F2FS_I_SB(mapping->host);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline struct f2fs_sb_info *F2FS_P_SB(struct page *page)
|
|
|
|
{
|
|
|
|
return F2FS_M_SB(page->mapping);
|
|
|
|
}
|
|
|
|
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
static inline struct f2fs_super_block *F2FS_RAW_SUPER(struct f2fs_sb_info *sbi)
|
|
|
|
{
|
|
|
|
return (struct f2fs_super_block *)(sbi->raw_super);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline struct f2fs_checkpoint *F2FS_CKPT(struct f2fs_sb_info *sbi)
|
|
|
|
{
|
|
|
|
return (struct f2fs_checkpoint *)(sbi->ckpt);
|
|
|
|
}
|
|
|
|
|
2013-07-15 17:57:38 +08:00
|
|
|
static inline struct f2fs_node *F2FS_NODE(struct page *page)
|
|
|
|
{
|
|
|
|
return (struct f2fs_node *)page_address(page);
|
|
|
|
}
|
|
|
|
|
2013-12-26 15:30:41 +08:00
|
|
|
static inline struct f2fs_inode *F2FS_INODE(struct page *page)
|
|
|
|
{
|
|
|
|
return &((struct f2fs_node *)page_address(page))->i;
|
|
|
|
}
|
|
|
|
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
static inline struct f2fs_nm_info *NM_I(struct f2fs_sb_info *sbi)
|
|
|
|
{
|
|
|
|
return (struct f2fs_nm_info *)(sbi->nm_info);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline struct f2fs_sm_info *SM_I(struct f2fs_sb_info *sbi)
|
|
|
|
{
|
|
|
|
return (struct f2fs_sm_info *)(sbi->sm_info);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline struct sit_info *SIT_I(struct f2fs_sb_info *sbi)
|
|
|
|
{
|
|
|
|
return (struct sit_info *)(SM_I(sbi)->sit_info);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline struct free_segmap_info *FREE_I(struct f2fs_sb_info *sbi)
|
|
|
|
{
|
|
|
|
return (struct free_segmap_info *)(SM_I(sbi)->free_info);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline struct dirty_seglist_info *DIRTY_I(struct f2fs_sb_info *sbi)
|
|
|
|
{
|
|
|
|
return (struct dirty_seglist_info *)(SM_I(sbi)->dirty_info);
|
|
|
|
}
|
|
|
|
|
2014-01-20 18:37:04 +08:00
|
|
|
static inline struct address_space *META_MAPPING(struct f2fs_sb_info *sbi)
|
|
|
|
{
|
|
|
|
return sbi->meta_inode->i_mapping;
|
|
|
|
}
|
|
|
|
|
2014-01-21 17:51:16 +08:00
|
|
|
static inline struct address_space *NODE_MAPPING(struct f2fs_sb_info *sbi)
|
|
|
|
{
|
|
|
|
return sbi->node_inode->i_mapping;
|
|
|
|
}
|
|
|
|
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
static inline void F2FS_SET_SB_DIRT(struct f2fs_sb_info *sbi)
|
|
|
|
{
|
|
|
|
sbi->s_dirty = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void F2FS_RESET_SB_DIRT(struct f2fs_sb_info *sbi)
|
|
|
|
{
|
|
|
|
sbi->s_dirty = 0;
|
|
|
|
}
|
|
|
|
|
2013-08-09 14:03:21 +08:00
|
|
|
static inline unsigned long long cur_cp_version(struct f2fs_checkpoint *cp)
|
|
|
|
{
|
|
|
|
return le64_to_cpu(cp->checkpoint_ver);
|
|
|
|
}
|
|
|
|
|
2012-11-28 15:12:41 +08:00
|
|
|
static inline bool is_set_ckpt_flags(struct f2fs_checkpoint *cp, unsigned int f)
|
|
|
|
{
|
|
|
|
unsigned int ckpt_flags = le32_to_cpu(cp->ckpt_flags);
|
|
|
|
return ckpt_flags & f;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void set_ckpt_flags(struct f2fs_checkpoint *cp, unsigned int f)
|
|
|
|
{
|
|
|
|
unsigned int ckpt_flags = le32_to_cpu(cp->ckpt_flags);
|
|
|
|
ckpt_flags |= f;
|
|
|
|
cp->ckpt_flags = cpu_to_le32(ckpt_flags);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void clear_ckpt_flags(struct f2fs_checkpoint *cp, unsigned int f)
|
|
|
|
{
|
|
|
|
unsigned int ckpt_flags = le32_to_cpu(cp->ckpt_flags);
|
|
|
|
ckpt_flags &= (~f);
|
|
|
|
cp->ckpt_flags = cpu_to_le32(ckpt_flags);
|
|
|
|
}
|
|
|
|
|
f2fs: use rw_sem instead of fs_lock(locks mutex)
The fs_locks is used to block other ops(ex, recovery) when doing checkpoint.
And each other operate routine(besides checkpoint) needs to acquire a fs_lock,
there is a terrible problem here, if these are too many concurrency threads acquiring
fs_lock, so that they will block each other and may lead to some performance problem,
but this is not the phenomenon we want to see.
Though there are some optimization patches introduced to enhance the usage of fs_lock,
but the thorough solution is using a *rw_sem* to replace the fs_lock.
Checkpoint routine takes write_sem, and other ops take read_sem, so that we can block
other ops(ex, recovery) when doing checkpoint, and other ops will not disturb each other,
this can avoid the problem described above completely.
Because of the weakness of rw_sem, the above change may introduce a potential problem
that the checkpoint thread might get starved if other threads are intensively locking
the read semaphore for I/O.(Pointed out by Xu Jin)
In order to avoid this, a wait_list is introduced, the appending read semaphore ops
will be dropped into the wait_list if checkpoint thread is waiting for write semaphore,
and will be waked up when checkpoint thread gives up write semaphore.
Thanks to Kim's previous review and test, and will be very glad to see other guys'
performance tests about this patch.
V2:
-fix the potential starvation problem.
-use more suitable func name suggested by Xu Jin.
Signed-off-by: Gu Zheng <guz.fnst@cn.fujitsu.com>
[Jaegeuk Kim: adjust minor coding standard]
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2013-09-27 18:08:30 +08:00
|
|
|
static inline void f2fs_lock_op(struct f2fs_sb_info *sbi)
|
f2fs: introduce a new global lock scheme
In the previous version, f2fs uses global locks according to the usage types,
such as directory operations, block allocation, block write, and so on.
Reference the following lock types in f2fs.h.
enum lock_type {
RENAME, /* for renaming operations */
DENTRY_OPS, /* for directory operations */
DATA_WRITE, /* for data write */
DATA_NEW, /* for data allocation */
DATA_TRUNC, /* for data truncate */
NODE_NEW, /* for node allocation */
NODE_TRUNC, /* for node truncate */
NODE_WRITE, /* for node write */
NR_LOCK_TYPE,
};
In that case, we lose the performance under the multi-threading environment,
since every types of operations must be conducted one at a time.
In order to address the problem, let's share the locks globally with a mutex
array regardless of any types.
So, let users grab a mutex and perform their jobs in parallel as much as
possbile.
For this, I propose a new global lock scheme as follows.
0. Data structure
- f2fs_sb_info -> mutex_lock[NR_GLOBAL_LOCKS]
- f2fs_sb_info -> node_write
1. mutex_lock_op(sbi)
- try to get an avaiable lock from the array.
- returns the index of the gottern lock variable.
2. mutex_unlock_op(sbi, index of the lock)
- unlock the given index of the lock.
3. mutex_lock_all(sbi)
- grab all the locks in the array before the checkpoint.
4. mutex_unlock_all(sbi)
- release all the locks in the array after checkpoint.
5. block_operations()
- call mutex_lock_all()
- sync_dirty_dir_inodes()
- grab node_write
- sync_node_pages()
Note that,
the pairs of mutex_lock_op()/mutex_unlock_op() and
mutex_lock_all()/mutex_unlock_all() should be used together.
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-22 15:21:29 +08:00
|
|
|
{
|
f2fs: use rw_sem instead of fs_lock(locks mutex)
The fs_locks is used to block other ops(ex, recovery) when doing checkpoint.
And each other operate routine(besides checkpoint) needs to acquire a fs_lock,
there is a terrible problem here, if these are too many concurrency threads acquiring
fs_lock, so that they will block each other and may lead to some performance problem,
but this is not the phenomenon we want to see.
Though there are some optimization patches introduced to enhance the usage of fs_lock,
but the thorough solution is using a *rw_sem* to replace the fs_lock.
Checkpoint routine takes write_sem, and other ops take read_sem, so that we can block
other ops(ex, recovery) when doing checkpoint, and other ops will not disturb each other,
this can avoid the problem described above completely.
Because of the weakness of rw_sem, the above change may introduce a potential problem
that the checkpoint thread might get starved if other threads are intensively locking
the read semaphore for I/O.(Pointed out by Xu Jin)
In order to avoid this, a wait_list is introduced, the appending read semaphore ops
will be dropped into the wait_list if checkpoint thread is waiting for write semaphore,
and will be waked up when checkpoint thread gives up write semaphore.
Thanks to Kim's previous review and test, and will be very glad to see other guys'
performance tests about this patch.
V2:
-fix the potential starvation problem.
-use more suitable func name suggested by Xu Jin.
Signed-off-by: Gu Zheng <guz.fnst@cn.fujitsu.com>
[Jaegeuk Kim: adjust minor coding standard]
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2013-09-27 18:08:30 +08:00
|
|
|
down_read(&sbi->cp_rwsem);
|
f2fs: introduce a new global lock scheme
In the previous version, f2fs uses global locks according to the usage types,
such as directory operations, block allocation, block write, and so on.
Reference the following lock types in f2fs.h.
enum lock_type {
RENAME, /* for renaming operations */
DENTRY_OPS, /* for directory operations */
DATA_WRITE, /* for data write */
DATA_NEW, /* for data allocation */
DATA_TRUNC, /* for data truncate */
NODE_NEW, /* for node allocation */
NODE_TRUNC, /* for node truncate */
NODE_WRITE, /* for node write */
NR_LOCK_TYPE,
};
In that case, we lose the performance under the multi-threading environment,
since every types of operations must be conducted one at a time.
In order to address the problem, let's share the locks globally with a mutex
array regardless of any types.
So, let users grab a mutex and perform their jobs in parallel as much as
possbile.
For this, I propose a new global lock scheme as follows.
0. Data structure
- f2fs_sb_info -> mutex_lock[NR_GLOBAL_LOCKS]
- f2fs_sb_info -> node_write
1. mutex_lock_op(sbi)
- try to get an avaiable lock from the array.
- returns the index of the gottern lock variable.
2. mutex_unlock_op(sbi, index of the lock)
- unlock the given index of the lock.
3. mutex_lock_all(sbi)
- grab all the locks in the array before the checkpoint.
4. mutex_unlock_all(sbi)
- release all the locks in the array after checkpoint.
5. block_operations()
- call mutex_lock_all()
- sync_dirty_dir_inodes()
- grab node_write
- sync_node_pages()
Note that,
the pairs of mutex_lock_op()/mutex_unlock_op() and
mutex_lock_all()/mutex_unlock_all() should be used together.
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-22 15:21:29 +08:00
|
|
|
}
|
|
|
|
|
f2fs: use rw_sem instead of fs_lock(locks mutex)
The fs_locks is used to block other ops(ex, recovery) when doing checkpoint.
And each other operate routine(besides checkpoint) needs to acquire a fs_lock,
there is a terrible problem here, if these are too many concurrency threads acquiring
fs_lock, so that they will block each other and may lead to some performance problem,
but this is not the phenomenon we want to see.
Though there are some optimization patches introduced to enhance the usage of fs_lock,
but the thorough solution is using a *rw_sem* to replace the fs_lock.
Checkpoint routine takes write_sem, and other ops take read_sem, so that we can block
other ops(ex, recovery) when doing checkpoint, and other ops will not disturb each other,
this can avoid the problem described above completely.
Because of the weakness of rw_sem, the above change may introduce a potential problem
that the checkpoint thread might get starved if other threads are intensively locking
the read semaphore for I/O.(Pointed out by Xu Jin)
In order to avoid this, a wait_list is introduced, the appending read semaphore ops
will be dropped into the wait_list if checkpoint thread is waiting for write semaphore,
and will be waked up when checkpoint thread gives up write semaphore.
Thanks to Kim's previous review and test, and will be very glad to see other guys'
performance tests about this patch.
V2:
-fix the potential starvation problem.
-use more suitable func name suggested by Xu Jin.
Signed-off-by: Gu Zheng <guz.fnst@cn.fujitsu.com>
[Jaegeuk Kim: adjust minor coding standard]
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2013-09-27 18:08:30 +08:00
|
|
|
static inline void f2fs_unlock_op(struct f2fs_sb_info *sbi)
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
{
|
f2fs: use rw_sem instead of fs_lock(locks mutex)
The fs_locks is used to block other ops(ex, recovery) when doing checkpoint.
And each other operate routine(besides checkpoint) needs to acquire a fs_lock,
there is a terrible problem here, if these are too many concurrency threads acquiring
fs_lock, so that they will block each other and may lead to some performance problem,
but this is not the phenomenon we want to see.
Though there are some optimization patches introduced to enhance the usage of fs_lock,
but the thorough solution is using a *rw_sem* to replace the fs_lock.
Checkpoint routine takes write_sem, and other ops take read_sem, so that we can block
other ops(ex, recovery) when doing checkpoint, and other ops will not disturb each other,
this can avoid the problem described above completely.
Because of the weakness of rw_sem, the above change may introduce a potential problem
that the checkpoint thread might get starved if other threads are intensively locking
the read semaphore for I/O.(Pointed out by Xu Jin)
In order to avoid this, a wait_list is introduced, the appending read semaphore ops
will be dropped into the wait_list if checkpoint thread is waiting for write semaphore,
and will be waked up when checkpoint thread gives up write semaphore.
Thanks to Kim's previous review and test, and will be very glad to see other guys'
performance tests about this patch.
V2:
-fix the potential starvation problem.
-use more suitable func name suggested by Xu Jin.
Signed-off-by: Gu Zheng <guz.fnst@cn.fujitsu.com>
[Jaegeuk Kim: adjust minor coding standard]
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2013-09-27 18:08:30 +08:00
|
|
|
up_read(&sbi->cp_rwsem);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
}
|
|
|
|
|
f2fs: use rw_sem instead of fs_lock(locks mutex)
The fs_locks is used to block other ops(ex, recovery) when doing checkpoint.
And each other operate routine(besides checkpoint) needs to acquire a fs_lock,
there is a terrible problem here, if these are too many concurrency threads acquiring
fs_lock, so that they will block each other and may lead to some performance problem,
but this is not the phenomenon we want to see.
Though there are some optimization patches introduced to enhance the usage of fs_lock,
but the thorough solution is using a *rw_sem* to replace the fs_lock.
Checkpoint routine takes write_sem, and other ops take read_sem, so that we can block
other ops(ex, recovery) when doing checkpoint, and other ops will not disturb each other,
this can avoid the problem described above completely.
Because of the weakness of rw_sem, the above change may introduce a potential problem
that the checkpoint thread might get starved if other threads are intensively locking
the read semaphore for I/O.(Pointed out by Xu Jin)
In order to avoid this, a wait_list is introduced, the appending read semaphore ops
will be dropped into the wait_list if checkpoint thread is waiting for write semaphore,
and will be waked up when checkpoint thread gives up write semaphore.
Thanks to Kim's previous review and test, and will be very glad to see other guys'
performance tests about this patch.
V2:
-fix the potential starvation problem.
-use more suitable func name suggested by Xu Jin.
Signed-off-by: Gu Zheng <guz.fnst@cn.fujitsu.com>
[Jaegeuk Kim: adjust minor coding standard]
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2013-09-27 18:08:30 +08:00
|
|
|
static inline void f2fs_lock_all(struct f2fs_sb_info *sbi)
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
{
|
2013-11-24 12:50:35 +08:00
|
|
|
f2fs_down_write(&sbi->cp_rwsem, &sbi->cp_mutex);
|
f2fs: introduce a new global lock scheme
In the previous version, f2fs uses global locks according to the usage types,
such as directory operations, block allocation, block write, and so on.
Reference the following lock types in f2fs.h.
enum lock_type {
RENAME, /* for renaming operations */
DENTRY_OPS, /* for directory operations */
DATA_WRITE, /* for data write */
DATA_NEW, /* for data allocation */
DATA_TRUNC, /* for data truncate */
NODE_NEW, /* for node allocation */
NODE_TRUNC, /* for node truncate */
NODE_WRITE, /* for node write */
NR_LOCK_TYPE,
};
In that case, we lose the performance under the multi-threading environment,
since every types of operations must be conducted one at a time.
In order to address the problem, let's share the locks globally with a mutex
array regardless of any types.
So, let users grab a mutex and perform their jobs in parallel as much as
possbile.
For this, I propose a new global lock scheme as follows.
0. Data structure
- f2fs_sb_info -> mutex_lock[NR_GLOBAL_LOCKS]
- f2fs_sb_info -> node_write
1. mutex_lock_op(sbi)
- try to get an avaiable lock from the array.
- returns the index of the gottern lock variable.
2. mutex_unlock_op(sbi, index of the lock)
- unlock the given index of the lock.
3. mutex_lock_all(sbi)
- grab all the locks in the array before the checkpoint.
4. mutex_unlock_all(sbi)
- release all the locks in the array after checkpoint.
5. block_operations()
- call mutex_lock_all()
- sync_dirty_dir_inodes()
- grab node_write
- sync_node_pages()
Note that,
the pairs of mutex_lock_op()/mutex_unlock_op() and
mutex_lock_all()/mutex_unlock_all() should be used together.
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-22 15:21:29 +08:00
|
|
|
}
|
|
|
|
|
f2fs: use rw_sem instead of fs_lock(locks mutex)
The fs_locks is used to block other ops(ex, recovery) when doing checkpoint.
And each other operate routine(besides checkpoint) needs to acquire a fs_lock,
there is a terrible problem here, if these are too many concurrency threads acquiring
fs_lock, so that they will block each other and may lead to some performance problem,
but this is not the phenomenon we want to see.
Though there are some optimization patches introduced to enhance the usage of fs_lock,
but the thorough solution is using a *rw_sem* to replace the fs_lock.
Checkpoint routine takes write_sem, and other ops take read_sem, so that we can block
other ops(ex, recovery) when doing checkpoint, and other ops will not disturb each other,
this can avoid the problem described above completely.
Because of the weakness of rw_sem, the above change may introduce a potential problem
that the checkpoint thread might get starved if other threads are intensively locking
the read semaphore for I/O.(Pointed out by Xu Jin)
In order to avoid this, a wait_list is introduced, the appending read semaphore ops
will be dropped into the wait_list if checkpoint thread is waiting for write semaphore,
and will be waked up when checkpoint thread gives up write semaphore.
Thanks to Kim's previous review and test, and will be very glad to see other guys'
performance tests about this patch.
V2:
-fix the potential starvation problem.
-use more suitable func name suggested by Xu Jin.
Signed-off-by: Gu Zheng <guz.fnst@cn.fujitsu.com>
[Jaegeuk Kim: adjust minor coding standard]
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2013-09-27 18:08:30 +08:00
|
|
|
static inline void f2fs_unlock_all(struct f2fs_sb_info *sbi)
|
f2fs: introduce a new global lock scheme
In the previous version, f2fs uses global locks according to the usage types,
such as directory operations, block allocation, block write, and so on.
Reference the following lock types in f2fs.h.
enum lock_type {
RENAME, /* for renaming operations */
DENTRY_OPS, /* for directory operations */
DATA_WRITE, /* for data write */
DATA_NEW, /* for data allocation */
DATA_TRUNC, /* for data truncate */
NODE_NEW, /* for node allocation */
NODE_TRUNC, /* for node truncate */
NODE_WRITE, /* for node write */
NR_LOCK_TYPE,
};
In that case, we lose the performance under the multi-threading environment,
since every types of operations must be conducted one at a time.
In order to address the problem, let's share the locks globally with a mutex
array regardless of any types.
So, let users grab a mutex and perform their jobs in parallel as much as
possbile.
For this, I propose a new global lock scheme as follows.
0. Data structure
- f2fs_sb_info -> mutex_lock[NR_GLOBAL_LOCKS]
- f2fs_sb_info -> node_write
1. mutex_lock_op(sbi)
- try to get an avaiable lock from the array.
- returns the index of the gottern lock variable.
2. mutex_unlock_op(sbi, index of the lock)
- unlock the given index of the lock.
3. mutex_lock_all(sbi)
- grab all the locks in the array before the checkpoint.
4. mutex_unlock_all(sbi)
- release all the locks in the array after checkpoint.
5. block_operations()
- call mutex_lock_all()
- sync_dirty_dir_inodes()
- grab node_write
- sync_node_pages()
Note that,
the pairs of mutex_lock_op()/mutex_unlock_op() and
mutex_lock_all()/mutex_unlock_all() should be used together.
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-22 15:21:29 +08:00
|
|
|
{
|
f2fs: use rw_sem instead of fs_lock(locks mutex)
The fs_locks is used to block other ops(ex, recovery) when doing checkpoint.
And each other operate routine(besides checkpoint) needs to acquire a fs_lock,
there is a terrible problem here, if these are too many concurrency threads acquiring
fs_lock, so that they will block each other and may lead to some performance problem,
but this is not the phenomenon we want to see.
Though there are some optimization patches introduced to enhance the usage of fs_lock,
but the thorough solution is using a *rw_sem* to replace the fs_lock.
Checkpoint routine takes write_sem, and other ops take read_sem, so that we can block
other ops(ex, recovery) when doing checkpoint, and other ops will not disturb each other,
this can avoid the problem described above completely.
Because of the weakness of rw_sem, the above change may introduce a potential problem
that the checkpoint thread might get starved if other threads are intensively locking
the read semaphore for I/O.(Pointed out by Xu Jin)
In order to avoid this, a wait_list is introduced, the appending read semaphore ops
will be dropped into the wait_list if checkpoint thread is waiting for write semaphore,
and will be waked up when checkpoint thread gives up write semaphore.
Thanks to Kim's previous review and test, and will be very glad to see other guys'
performance tests about this patch.
V2:
-fix the potential starvation problem.
-use more suitable func name suggested by Xu Jin.
Signed-off-by: Gu Zheng <guz.fnst@cn.fujitsu.com>
[Jaegeuk Kim: adjust minor coding standard]
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2013-09-27 18:08:30 +08:00
|
|
|
up_write(&sbi->cp_rwsem);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Check whether the given nid is within node id range.
|
|
|
|
*/
|
2013-03-17 16:27:20 +08:00
|
|
|
static inline int check_nid_range(struct f2fs_sb_info *sbi, nid_t nid)
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
{
|
2014-06-12 13:23:41 +08:00
|
|
|
if (unlikely(nid < F2FS_ROOT_INO(sbi)))
|
|
|
|
return -EINVAL;
|
2013-12-05 17:15:22 +08:00
|
|
|
if (unlikely(nid >= NM_I(sbi)->max_nid))
|
2013-03-17 16:27:20 +08:00
|
|
|
return -EINVAL;
|
|
|
|
return 0;
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
#define F2FS_DEFAULT_ALLOCATED_BLOCKS 1
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Check whether the inode has blocks or not
|
|
|
|
*/
|
|
|
|
static inline int F2FS_HAS_BLOCKS(struct inode *inode)
|
|
|
|
{
|
|
|
|
if (F2FS_I(inode)->i_xattr_nid)
|
2014-01-18 04:44:39 +08:00
|
|
|
return inode->i_blocks > F2FS_DEFAULT_ALLOCATED_BLOCKS + 1;
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
else
|
2014-01-18 04:44:39 +08:00
|
|
|
return inode->i_blocks > F2FS_DEFAULT_ALLOCATED_BLOCKS;
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
}
|
|
|
|
|
2014-03-17 16:35:06 +08:00
|
|
|
static inline bool f2fs_has_xattr_block(unsigned int ofs)
|
|
|
|
{
|
|
|
|
return ofs == XATTR_NODE_OFFSET;
|
|
|
|
}
|
|
|
|
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
static inline bool inc_valid_block_count(struct f2fs_sb_info *sbi,
|
|
|
|
struct inode *inode, blkcnt_t count)
|
|
|
|
{
|
|
|
|
block_t valid_block_count;
|
|
|
|
|
|
|
|
spin_lock(&sbi->stat_lock);
|
|
|
|
valid_block_count =
|
|
|
|
sbi->total_valid_block_count + (block_t)count;
|
2013-12-05 17:15:22 +08:00
|
|
|
if (unlikely(valid_block_count > sbi->user_block_count)) {
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
spin_unlock(&sbi->stat_lock);
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
inode->i_blocks += count;
|
|
|
|
sbi->total_valid_block_count = valid_block_count;
|
|
|
|
sbi->alloc_valid_block_count += (block_t)count;
|
|
|
|
spin_unlock(&sbi->stat_lock);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2013-11-19 18:03:27 +08:00
|
|
|
static inline void dec_valid_block_count(struct f2fs_sb_info *sbi,
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
struct inode *inode,
|
|
|
|
blkcnt_t count)
|
|
|
|
{
|
|
|
|
spin_lock(&sbi->stat_lock);
|
2014-09-03 06:52:58 +08:00
|
|
|
f2fs_bug_on(sbi, sbi->total_valid_block_count < (block_t) count);
|
|
|
|
f2fs_bug_on(sbi, inode->i_blocks < count);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
inode->i_blocks -= count;
|
|
|
|
sbi->total_valid_block_count -= (block_t)count;
|
|
|
|
spin_unlock(&sbi->stat_lock);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void inc_page_count(struct f2fs_sb_info *sbi, int count_type)
|
|
|
|
{
|
|
|
|
atomic_inc(&sbi->nr_pages[count_type]);
|
|
|
|
F2FS_SET_SB_DIRT(sbi);
|
|
|
|
}
|
|
|
|
|
2014-09-13 06:53:45 +08:00
|
|
|
static inline void inode_inc_dirty_pages(struct inode *inode)
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
{
|
2014-09-13 06:53:45 +08:00
|
|
|
atomic_inc(&F2FS_I(inode)->dirty_pages);
|
|
|
|
if (S_ISDIR(inode->i_mode))
|
|
|
|
inc_page_count(F2FS_I_SB(inode), F2FS_DIRTY_DENTS);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
static inline void dec_page_count(struct f2fs_sb_info *sbi, int count_type)
|
|
|
|
{
|
|
|
|
atomic_dec(&sbi->nr_pages[count_type]);
|
|
|
|
}
|
|
|
|
|
2014-09-13 06:53:45 +08:00
|
|
|
static inline void inode_dec_dirty_pages(struct inode *inode)
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
{
|
2014-09-13 06:53:45 +08:00
|
|
|
if (!S_ISDIR(inode->i_mode) && !S_ISREG(inode->i_mode))
|
2014-02-07 09:00:06 +08:00
|
|
|
return;
|
|
|
|
|
2014-09-13 06:53:45 +08:00
|
|
|
atomic_dec(&F2FS_I(inode)->dirty_pages);
|
|
|
|
|
|
|
|
if (S_ISDIR(inode->i_mode))
|
|
|
|
dec_page_count(F2FS_I_SB(inode), F2FS_DIRTY_DENTS);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
static inline int get_pages(struct f2fs_sb_info *sbi, int count_type)
|
|
|
|
{
|
|
|
|
return atomic_read(&sbi->nr_pages[count_type]);
|
|
|
|
}
|
|
|
|
|
2014-09-13 06:53:45 +08:00
|
|
|
static inline int get_dirty_pages(struct inode *inode)
|
2014-03-18 11:33:06 +08:00
|
|
|
{
|
2014-09-13 06:53:45 +08:00
|
|
|
return atomic_read(&F2FS_I(inode)->dirty_pages);
|
2014-03-18 11:33:06 +08:00
|
|
|
}
|
|
|
|
|
2013-02-02 22:52:59 +08:00
|
|
|
static inline int get_blocktype_secs(struct f2fs_sb_info *sbi, int block_type)
|
|
|
|
{
|
|
|
|
unsigned int pages_per_sec = sbi->segs_per_sec *
|
|
|
|
(1 << sbi->log_blocks_per_seg);
|
|
|
|
return ((get_pages(sbi, block_type) + pages_per_sec - 1)
|
|
|
|
>> sbi->log_blocks_per_seg) / sbi->segs_per_sec;
|
|
|
|
}
|
|
|
|
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
static inline block_t valid_user_blocks(struct f2fs_sb_info *sbi)
|
|
|
|
{
|
2014-02-24 12:00:13 +08:00
|
|
|
return sbi->total_valid_block_count;
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
static inline unsigned long __bitmap_size(struct f2fs_sb_info *sbi, int flag)
|
|
|
|
{
|
|
|
|
struct f2fs_checkpoint *ckpt = F2FS_CKPT(sbi);
|
|
|
|
|
|
|
|
/* return NAT or SIT bitmap */
|
|
|
|
if (flag == NAT_BITMAP)
|
|
|
|
return le32_to_cpu(ckpt->nat_ver_bitmap_bytesize);
|
|
|
|
else if (flag == SIT_BITMAP)
|
|
|
|
return le32_to_cpu(ckpt->sit_ver_bitmap_bytesize);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void *__bitmap_ptr(struct f2fs_sb_info *sbi, int flag)
|
|
|
|
{
|
|
|
|
struct f2fs_checkpoint *ckpt = F2FS_CKPT(sbi);
|
2014-05-12 11:27:43 +08:00
|
|
|
int offset;
|
|
|
|
|
|
|
|
if (le32_to_cpu(F2FS_RAW_SUPER(sbi)->cp_payload) > 0) {
|
|
|
|
if (flag == NAT_BITMAP)
|
|
|
|
return &ckpt->sit_nat_version_bitmap;
|
|
|
|
else
|
2014-07-31 08:25:54 +08:00
|
|
|
return (unsigned char *)ckpt + F2FS_BLKSIZE;
|
2014-05-12 11:27:43 +08:00
|
|
|
} else {
|
|
|
|
offset = (flag == NAT_BITMAP) ?
|
2012-11-28 15:12:41 +08:00
|
|
|
le32_to_cpu(ckpt->sit_ver_bitmap_bytesize) : 0;
|
2014-05-12 11:27:43 +08:00
|
|
|
return &ckpt->sit_nat_version_bitmap + offset;
|
|
|
|
}
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
static inline block_t __start_cp_addr(struct f2fs_sb_info *sbi)
|
|
|
|
{
|
|
|
|
block_t start_addr;
|
|
|
|
struct f2fs_checkpoint *ckpt = F2FS_CKPT(sbi);
|
2013-08-09 14:03:21 +08:00
|
|
|
unsigned long long ckpt_version = cur_cp_version(ckpt);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
|
2012-11-28 15:12:41 +08:00
|
|
|
start_addr = le32_to_cpu(F2FS_RAW_SUPER(sbi)->cp_blkaddr);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* odd numbered checkpoint should at cp segment 0
|
2014-08-06 22:22:50 +08:00
|
|
|
* and even segment must be at cp segment 1
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
*/
|
|
|
|
if (!(ckpt_version & 1))
|
|
|
|
start_addr += sbi->blocks_per_seg;
|
|
|
|
|
|
|
|
return start_addr;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline block_t __start_sum_addr(struct f2fs_sb_info *sbi)
|
|
|
|
{
|
|
|
|
return le32_to_cpu(F2FS_CKPT(sbi)->cp_pack_start_sum);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline bool inc_valid_node_count(struct f2fs_sb_info *sbi,
|
2013-11-19 18:03:38 +08:00
|
|
|
struct inode *inode)
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
{
|
|
|
|
block_t valid_block_count;
|
|
|
|
unsigned int valid_node_count;
|
|
|
|
|
|
|
|
spin_lock(&sbi->stat_lock);
|
|
|
|
|
2013-11-19 18:03:38 +08:00
|
|
|
valid_block_count = sbi->total_valid_block_count + 1;
|
2013-12-05 17:15:22 +08:00
|
|
|
if (unlikely(valid_block_count > sbi->user_block_count)) {
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
spin_unlock(&sbi->stat_lock);
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2013-11-19 18:03:38 +08:00
|
|
|
valid_node_count = sbi->total_valid_node_count + 1;
|
2013-12-05 17:15:22 +08:00
|
|
|
if (unlikely(valid_node_count > sbi->total_node_count)) {
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
spin_unlock(&sbi->stat_lock);
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (inode)
|
2013-11-19 18:03:38 +08:00
|
|
|
inode->i_blocks++;
|
|
|
|
|
|
|
|
sbi->alloc_valid_block_count++;
|
|
|
|
sbi->total_valid_node_count++;
|
|
|
|
sbi->total_valid_block_count++;
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
spin_unlock(&sbi->stat_lock);
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void dec_valid_node_count(struct f2fs_sb_info *sbi,
|
2013-11-19 18:03:38 +08:00
|
|
|
struct inode *inode)
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
{
|
|
|
|
spin_lock(&sbi->stat_lock);
|
|
|
|
|
2014-09-03 06:52:58 +08:00
|
|
|
f2fs_bug_on(sbi, !sbi->total_valid_block_count);
|
|
|
|
f2fs_bug_on(sbi, !sbi->total_valid_node_count);
|
|
|
|
f2fs_bug_on(sbi, !inode->i_blocks);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
|
2013-11-19 18:03:38 +08:00
|
|
|
inode->i_blocks--;
|
|
|
|
sbi->total_valid_node_count--;
|
|
|
|
sbi->total_valid_block_count--;
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
|
|
|
|
spin_unlock(&sbi->stat_lock);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline unsigned int valid_node_count(struct f2fs_sb_info *sbi)
|
|
|
|
{
|
2014-02-24 12:00:13 +08:00
|
|
|
return sbi->total_valid_node_count;
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
static inline void inc_valid_inode_count(struct f2fs_sb_info *sbi)
|
|
|
|
{
|
|
|
|
spin_lock(&sbi->stat_lock);
|
2014-09-03 06:52:58 +08:00
|
|
|
f2fs_bug_on(sbi, sbi->total_valid_inode_count == sbi->total_node_count);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
sbi->total_valid_inode_count++;
|
|
|
|
spin_unlock(&sbi->stat_lock);
|
|
|
|
}
|
|
|
|
|
2013-11-26 15:36:20 +08:00
|
|
|
static inline void dec_valid_inode_count(struct f2fs_sb_info *sbi)
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
{
|
|
|
|
spin_lock(&sbi->stat_lock);
|
2014-09-03 06:52:58 +08:00
|
|
|
f2fs_bug_on(sbi, !sbi->total_valid_inode_count);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
sbi->total_valid_inode_count--;
|
|
|
|
spin_unlock(&sbi->stat_lock);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline unsigned int valid_inode_count(struct f2fs_sb_info *sbi)
|
|
|
|
{
|
2014-02-24 12:00:13 +08:00
|
|
|
return sbi->total_valid_inode_count;
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
static inline void f2fs_put_page(struct page *page, int unlock)
|
|
|
|
{
|
2013-11-28 11:55:13 +08:00
|
|
|
if (!page)
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
return;
|
|
|
|
|
|
|
|
if (unlock) {
|
2014-09-03 06:52:58 +08:00
|
|
|
f2fs_bug_on(F2FS_P_SB(page), !PageLocked(page));
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
unlock_page(page);
|
|
|
|
}
|
|
|
|
page_cache_release(page);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void f2fs_put_dnode(struct dnode_of_data *dn)
|
|
|
|
{
|
|
|
|
if (dn->node_page)
|
|
|
|
f2fs_put_page(dn->node_page, 1);
|
|
|
|
if (dn->inode_page && dn->node_page != dn->inode_page)
|
|
|
|
f2fs_put_page(dn->inode_page, 0);
|
|
|
|
dn->node_page = NULL;
|
|
|
|
dn->inode_page = NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline struct kmem_cache *f2fs_kmem_cache_create(const char *name,
|
2014-03-07 18:43:28 +08:00
|
|
|
size_t size)
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
{
|
2014-03-07 18:43:28 +08:00
|
|
|
return kmem_cache_create(name, size, 0, SLAB_RECLAIM_ACCOUNT, NULL);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
}
|
|
|
|
|
2013-10-22 14:52:26 +08:00
|
|
|
static inline void *f2fs_kmem_cache_alloc(struct kmem_cache *cachep,
|
|
|
|
gfp_t flags)
|
|
|
|
{
|
|
|
|
void *entry;
|
|
|
|
retry:
|
|
|
|
entry = kmem_cache_alloc(cachep, flags);
|
|
|
|
if (!entry) {
|
|
|
|
cond_resched();
|
|
|
|
goto retry;
|
|
|
|
}
|
|
|
|
|
|
|
|
return entry;
|
|
|
|
}
|
|
|
|
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
#define RAW_IS_INODE(p) ((p)->footer.nid == (p)->footer.ino)
|
|
|
|
|
|
|
|
static inline bool IS_INODE(struct page *page)
|
|
|
|
{
|
2013-07-15 17:57:38 +08:00
|
|
|
struct f2fs_node *p = F2FS_NODE(page);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
return RAW_IS_INODE(p);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline __le32 *blkaddr_in_node(struct f2fs_node *node)
|
|
|
|
{
|
|
|
|
return RAW_IS_INODE(node) ? node->i.i_addr : node->dn.addr;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline block_t datablock_addr(struct page *node_page,
|
|
|
|
unsigned int offset)
|
|
|
|
{
|
|
|
|
struct f2fs_node *raw_node;
|
|
|
|
__le32 *addr_array;
|
2013-07-15 17:57:38 +08:00
|
|
|
raw_node = F2FS_NODE(node_page);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
addr_array = blkaddr_in_node(raw_node);
|
|
|
|
return le32_to_cpu(addr_array[offset]);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int f2fs_test_bit(unsigned int nr, char *addr)
|
|
|
|
{
|
|
|
|
int mask;
|
|
|
|
|
|
|
|
addr += (nr >> 3);
|
|
|
|
mask = 1 << (7 - (nr & 0x07));
|
|
|
|
return mask & *addr;
|
|
|
|
}
|
|
|
|
|
2014-10-20 17:45:51 +08:00
|
|
|
static inline int f2fs_test_and_set_bit(unsigned int nr, char *addr)
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
{
|
|
|
|
int mask;
|
|
|
|
int ret;
|
|
|
|
|
|
|
|
addr += (nr >> 3);
|
|
|
|
mask = 1 << (7 - (nr & 0x07));
|
|
|
|
ret = mask & *addr;
|
|
|
|
*addr |= mask;
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
2014-10-20 17:45:51 +08:00
|
|
|
static inline int f2fs_test_and_clear_bit(unsigned int nr, char *addr)
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
{
|
|
|
|
int mask;
|
|
|
|
int ret;
|
|
|
|
|
|
|
|
addr += (nr >> 3);
|
|
|
|
mask = 1 << (7 - (nr & 0x07));
|
|
|
|
ret = mask & *addr;
|
|
|
|
*addr &= ~mask;
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
2014-10-20 17:45:50 +08:00
|
|
|
static inline void f2fs_change_bit(unsigned int nr, char *addr)
|
|
|
|
{
|
|
|
|
int mask;
|
|
|
|
|
|
|
|
addr += (nr >> 3);
|
|
|
|
mask = 1 << (7 - (nr & 0x07));
|
|
|
|
*addr ^= mask;
|
|
|
|
}
|
|
|
|
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
/* used for f2fs_inode_info->flags */
|
|
|
|
enum {
|
|
|
|
FI_NEW_INODE, /* indicate newly allocated inode */
|
2013-06-10 08:17:01 +08:00
|
|
|
FI_DIRTY_INODE, /* indicate inode is dirty or not */
|
2014-04-15 10:19:28 +08:00
|
|
|
FI_DIRTY_DIR, /* indicate directory has dirty pages */
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
FI_INC_LINK, /* need to increment i_nlink */
|
|
|
|
FI_ACL_MODE, /* indicate acl mode */
|
|
|
|
FI_NO_ALLOC, /* should not allocate any blocks */
|
2013-06-07 21:08:23 +08:00
|
|
|
FI_UPDATE_DIR, /* should update inode block for consistency */
|
2013-05-15 15:40:02 +08:00
|
|
|
FI_DELAY_IPUT, /* used for the recovery */
|
2013-11-19 09:41:54 +08:00
|
|
|
FI_NO_EXTENT, /* not to use the extent cache */
|
2013-08-08 14:16:22 +08:00
|
|
|
FI_INLINE_XATTR, /* used for inline xattr */
|
2013-11-10 23:13:16 +08:00
|
|
|
FI_INLINE_DATA, /* used for inline data*/
|
2014-09-24 18:15:19 +08:00
|
|
|
FI_INLINE_DENTRY, /* used for inline dentry */
|
2014-07-25 22:40:59 +08:00
|
|
|
FI_APPEND_WRITE, /* inode has appended data */
|
|
|
|
FI_UPDATE_WRITE, /* inode has in-place-update data */
|
2014-10-07 08:39:50 +08:00
|
|
|
FI_NEED_IPU, /* used for ipu per file */
|
|
|
|
FI_ATOMIC_FILE, /* indicate atomic file */
|
2014-10-07 07:11:16 +08:00
|
|
|
FI_VOLATILE_FILE, /* indicate volatile file */
|
2014-10-24 10:48:09 +08:00
|
|
|
FI_DATA_EXIST, /* indicate data exists */
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
static inline void set_inode_flag(struct f2fs_inode_info *fi, int flag)
|
|
|
|
{
|
2014-07-26 06:47:23 +08:00
|
|
|
if (!test_bit(flag, &fi->flags))
|
|
|
|
set_bit(flag, &fi->flags);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
static inline int is_inode_flag_set(struct f2fs_inode_info *fi, int flag)
|
|
|
|
{
|
|
|
|
return test_bit(flag, &fi->flags);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void clear_inode_flag(struct f2fs_inode_info *fi, int flag)
|
|
|
|
{
|
2014-07-26 06:47:23 +08:00
|
|
|
if (test_bit(flag, &fi->flags))
|
|
|
|
clear_bit(flag, &fi->flags);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
static inline void set_acl_inode(struct f2fs_inode_info *fi, umode_t mode)
|
|
|
|
{
|
|
|
|
fi->i_acl_mode = mode;
|
|
|
|
set_inode_flag(fi, FI_ACL_MODE);
|
|
|
|
}
|
|
|
|
|
2013-08-08 14:16:22 +08:00
|
|
|
static inline void get_inline_info(struct f2fs_inode_info *fi,
|
|
|
|
struct f2fs_inode *ri)
|
|
|
|
{
|
|
|
|
if (ri->i_inline & F2FS_INLINE_XATTR)
|
|
|
|
set_inode_flag(fi, FI_INLINE_XATTR);
|
2013-11-10 23:13:16 +08:00
|
|
|
if (ri->i_inline & F2FS_INLINE_DATA)
|
|
|
|
set_inode_flag(fi, FI_INLINE_DATA);
|
2014-09-24 18:15:19 +08:00
|
|
|
if (ri->i_inline & F2FS_INLINE_DENTRY)
|
|
|
|
set_inode_flag(fi, FI_INLINE_DENTRY);
|
2014-10-24 10:48:09 +08:00
|
|
|
if (ri->i_inline & F2FS_DATA_EXIST)
|
|
|
|
set_inode_flag(fi, FI_DATA_EXIST);
|
2013-08-08 14:16:22 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
static inline void set_raw_inline(struct f2fs_inode_info *fi,
|
|
|
|
struct f2fs_inode *ri)
|
|
|
|
{
|
|
|
|
ri->i_inline = 0;
|
|
|
|
|
|
|
|
if (is_inode_flag_set(fi, FI_INLINE_XATTR))
|
|
|
|
ri->i_inline |= F2FS_INLINE_XATTR;
|
2013-11-10 23:13:16 +08:00
|
|
|
if (is_inode_flag_set(fi, FI_INLINE_DATA))
|
|
|
|
ri->i_inline |= F2FS_INLINE_DATA;
|
2014-09-24 18:15:19 +08:00
|
|
|
if (is_inode_flag_set(fi, FI_INLINE_DENTRY))
|
|
|
|
ri->i_inline |= F2FS_INLINE_DENTRY;
|
2014-10-24 10:48:09 +08:00
|
|
|
if (is_inode_flag_set(fi, FI_DATA_EXIST))
|
|
|
|
ri->i_inline |= F2FS_DATA_EXIST;
|
2013-08-08 14:16:22 +08:00
|
|
|
}
|
|
|
|
|
2014-03-12 15:59:03 +08:00
|
|
|
static inline int f2fs_has_inline_xattr(struct inode *inode)
|
|
|
|
{
|
|
|
|
return is_inode_flag_set(F2FS_I(inode), FI_INLINE_XATTR);
|
|
|
|
}
|
|
|
|
|
2013-08-12 20:08:03 +08:00
|
|
|
static inline unsigned int addrs_per_inode(struct f2fs_inode_info *fi)
|
|
|
|
{
|
2014-03-12 15:59:03 +08:00
|
|
|
if (f2fs_has_inline_xattr(&fi->vfs_inode))
|
2013-08-12 20:08:03 +08:00
|
|
|
return DEF_ADDRS_PER_INODE - F2FS_INLINE_XATTR_ADDRS;
|
|
|
|
return DEF_ADDRS_PER_INODE;
|
|
|
|
}
|
|
|
|
|
2013-08-14 20:57:27 +08:00
|
|
|
static inline void *inline_xattr_addr(struct page *page)
|
|
|
|
{
|
2014-02-27 19:52:21 +08:00
|
|
|
struct f2fs_inode *ri = F2FS_INODE(page);
|
2013-08-14 20:57:27 +08:00
|
|
|
return (void *)&(ri->i_addr[DEF_ADDRS_PER_INODE -
|
|
|
|
F2FS_INLINE_XATTR_ADDRS]);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int inline_xattr_size(struct inode *inode)
|
|
|
|
{
|
2014-03-12 15:59:03 +08:00
|
|
|
if (f2fs_has_inline_xattr(inode))
|
2013-08-14 20:57:27 +08:00
|
|
|
return F2FS_INLINE_XATTR_ADDRS << 2;
|
|
|
|
else
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2013-11-26 10:08:57 +08:00
|
|
|
static inline int f2fs_has_inline_data(struct inode *inode)
|
|
|
|
{
|
|
|
|
return is_inode_flag_set(F2FS_I(inode), FI_INLINE_DATA);
|
|
|
|
}
|
|
|
|
|
2014-10-24 10:48:09 +08:00
|
|
|
static inline void f2fs_clear_inline_inode(struct inode *inode)
|
|
|
|
{
|
|
|
|
clear_inode_flag(F2FS_I(inode), FI_INLINE_DATA);
|
|
|
|
clear_inode_flag(F2FS_I(inode), FI_DATA_EXIST);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int f2fs_exist_data(struct inode *inode)
|
|
|
|
{
|
|
|
|
return is_inode_flag_set(F2FS_I(inode), FI_DATA_EXIST);
|
|
|
|
}
|
|
|
|
|
2014-10-07 08:39:50 +08:00
|
|
|
static inline bool f2fs_is_atomic_file(struct inode *inode)
|
|
|
|
{
|
|
|
|
return is_inode_flag_set(F2FS_I(inode), FI_ATOMIC_FILE);
|
|
|
|
}
|
|
|
|
|
2014-10-07 07:11:16 +08:00
|
|
|
static inline bool f2fs_is_volatile_file(struct inode *inode)
|
|
|
|
{
|
|
|
|
return is_inode_flag_set(F2FS_I(inode), FI_VOLATILE_FILE);
|
|
|
|
}
|
|
|
|
|
2013-11-10 23:13:16 +08:00
|
|
|
static inline void *inline_data_addr(struct page *page)
|
|
|
|
{
|
2014-02-27 19:52:21 +08:00
|
|
|
struct f2fs_inode *ri = F2FS_INODE(page);
|
2013-11-10 23:13:16 +08:00
|
|
|
return (void *)&(ri->i_addr[1]);
|
|
|
|
}
|
|
|
|
|
2014-09-24 18:15:19 +08:00
|
|
|
static inline int f2fs_has_inline_dentry(struct inode *inode)
|
|
|
|
{
|
|
|
|
return is_inode_flag_set(F2FS_I(inode), FI_INLINE_DENTRY);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void *inline_dentry_addr(struct page *page)
|
|
|
|
{
|
|
|
|
struct f2fs_inode *ri = F2FS_INODE(page);
|
|
|
|
return (void *)&(ri->i_addr[1]);
|
|
|
|
}
|
|
|
|
|
2013-05-20 19:28:47 +08:00
|
|
|
static inline int f2fs_readonly(struct super_block *sb)
|
|
|
|
{
|
|
|
|
return sb->s_flags & MS_RDONLY;
|
|
|
|
}
|
|
|
|
|
2014-08-12 07:49:25 +08:00
|
|
|
static inline bool f2fs_cp_error(struct f2fs_sb_info *sbi)
|
|
|
|
{
|
|
|
|
return is_set_ckpt_flags(sbi->ckpt, CP_ERROR_FLAG);
|
|
|
|
}
|
|
|
|
|
2014-01-24 08:42:16 +08:00
|
|
|
static inline void f2fs_stop_checkpoint(struct f2fs_sb_info *sbi)
|
|
|
|
{
|
|
|
|
set_ckpt_flags(sbi->ckpt, CP_ERROR_FLAG);
|
|
|
|
sbi->sb->s_flags |= MS_RDONLY;
|
|
|
|
}
|
|
|
|
|
2013-12-20 21:16:45 +08:00
|
|
|
#define get_inode_mode(i) \
|
|
|
|
((is_inode_flag_set(F2FS_I(i), FI_ACL_MODE)) ? \
|
|
|
|
(F2FS_I(i)->i_acl_mode) : ((i)->i_mode))
|
|
|
|
|
2014-04-23 14:10:24 +08:00
|
|
|
/* get offset of first page in next direct node */
|
|
|
|
#define PGOFS_OF_NEXT_DNODE(pgofs, fi) \
|
|
|
|
((pgofs < ADDRS_PER_INODE(fi)) ? ADDRS_PER_INODE(fi) : \
|
|
|
|
(pgofs - ADDRS_PER_INODE(fi) + ADDRS_PER_BLOCK) / \
|
|
|
|
ADDRS_PER_BLOCK * ADDRS_PER_BLOCK + ADDRS_PER_INODE(fi))
|
|
|
|
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
/*
|
|
|
|
* file.c
|
|
|
|
*/
|
|
|
|
int f2fs_sync_file(struct file *, loff_t, loff_t, int);
|
|
|
|
void truncate_data_blocks(struct dnode_of_data *);
|
2014-08-15 07:32:54 +08:00
|
|
|
int truncate_blocks(struct inode *, u64, bool);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
void f2fs_truncate(struct inode *);
|
2013-06-07 15:33:07 +08:00
|
|
|
int f2fs_getattr(struct vfsmount *, struct dentry *, struct kstat *);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
int f2fs_setattr(struct dentry *, struct iattr *);
|
|
|
|
int truncate_hole(struct inode *, pgoff_t, pgoff_t);
|
2013-05-22 07:02:02 +08:00
|
|
|
int truncate_data_blocks_range(struct dnode_of_data *, int);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
long f2fs_ioctl(struct file *, unsigned int, unsigned long);
|
2013-02-04 22:41:41 +08:00
|
|
|
long f2fs_compat_ioctl(struct file *, unsigned int, unsigned long);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* inode.c
|
|
|
|
*/
|
|
|
|
void f2fs_set_inode_flags(struct inode *);
|
|
|
|
struct inode *f2fs_iget(struct super_block *, unsigned long);
|
2013-10-24 13:19:18 +08:00
|
|
|
int try_to_free_nats(struct f2fs_sb_info *, int);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
void update_inode(struct inode *, struct page *);
|
2014-01-24 08:42:16 +08:00
|
|
|
void update_inode_page(struct inode *);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
int f2fs_write_inode(struct inode *, struct writeback_control *);
|
|
|
|
void f2fs_evict_inode(struct inode *);
|
2014-09-26 02:55:53 +08:00
|
|
|
void handle_failed_inode(struct inode *);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* namei.c
|
|
|
|
*/
|
|
|
|
struct dentry *f2fs_get_parent(struct dentry *child);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* dir.c
|
|
|
|
*/
|
2014-09-24 18:17:04 +08:00
|
|
|
extern unsigned char f2fs_filetype_table[F2FS_FT_MAX];
|
|
|
|
void set_de_type(struct f2fs_dir_entry *, struct inode *);
|
2014-10-19 13:52:52 +08:00
|
|
|
struct f2fs_dir_entry *find_target_dentry(struct qstr *, int *,
|
|
|
|
struct f2fs_dentry_ptr *);
|
|
|
|
bool f2fs_fill_dentries(struct dir_context *, struct f2fs_dentry_ptr *,
|
|
|
|
unsigned int);
|
2014-10-19 14:06:41 +08:00
|
|
|
void do_make_empty_dir(struct inode *, struct inode *,
|
|
|
|
struct f2fs_dentry_ptr *);
|
2014-09-24 18:17:04 +08:00
|
|
|
struct page *init_inode_metadata(struct inode *, struct inode *,
|
2014-10-14 10:42:53 +08:00
|
|
|
const struct qstr *, struct page *);
|
2014-09-24 18:17:04 +08:00
|
|
|
void update_parent_metadata(struct inode *, struct inode *, unsigned int);
|
2014-10-14 07:28:13 +08:00
|
|
|
int room_for_filename(const void *, int, int);
|
2014-09-24 18:17:04 +08:00
|
|
|
void f2fs_drop_nlink(struct inode *, struct inode *, struct page *);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
struct f2fs_dir_entry *f2fs_find_entry(struct inode *, struct qstr *,
|
|
|
|
struct page **);
|
|
|
|
struct f2fs_dir_entry *f2fs_parent_dir(struct inode *, struct page **);
|
|
|
|
ino_t f2fs_inode_by_name(struct inode *, struct qstr *);
|
|
|
|
void f2fs_set_link(struct inode *, struct f2fs_dir_entry *,
|
|
|
|
struct page *, struct inode *);
|
2013-07-18 17:02:31 +08:00
|
|
|
int update_dent_inode(struct inode *, const struct qstr *);
|
2013-01-26 05:15:43 +08:00
|
|
|
int __f2fs_add_link(struct inode *, const struct qstr *, struct inode *);
|
2014-09-24 18:17:04 +08:00
|
|
|
void f2fs_delete_entry(struct f2fs_dir_entry *, struct page *, struct inode *,
|
|
|
|
struct inode *);
|
2014-06-21 12:37:02 +08:00
|
|
|
int f2fs_do_tmpfile(struct inode *, struct inode *);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
int f2fs_make_empty(struct inode *, struct inode *);
|
|
|
|
bool f2fs_empty_dir(struct inode *);
|
|
|
|
|
2013-01-26 05:15:43 +08:00
|
|
|
static inline int f2fs_add_link(struct dentry *dentry, struct inode *inode)
|
|
|
|
{
|
|
|
|
return __f2fs_add_link(dentry->d_parent->d_inode, &dentry->d_name,
|
|
|
|
inode);
|
|
|
|
}
|
|
|
|
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
/*
|
|
|
|
* super.c
|
|
|
|
*/
|
|
|
|
int f2fs_sync_fs(struct super_block *, int);
|
2012-12-30 13:52:05 +08:00
|
|
|
extern __printf(3, 4)
|
|
|
|
void f2fs_msg(struct super_block *, const char *, const char *, ...);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* hash.c
|
|
|
|
*/
|
2014-06-24 18:21:23 +08:00
|
|
|
f2fs_hash_t f2fs_dentry_hash(const struct qstr *);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* node.c
|
|
|
|
*/
|
|
|
|
struct dnode_of_data;
|
|
|
|
struct node_info;
|
|
|
|
|
2014-04-16 09:47:06 +08:00
|
|
|
bool available_free_memory(struct f2fs_sb_info *, int);
|
f2fs: fix conditions to remain recovery information in f2fs_sync_file
This patch revisited whole the recovery information during the f2fs_sync_file.
In this patch, there are three information to make a decision.
a) IS_CHECKPOINTED, /* is it checkpointed before? */
b) HAS_FSYNCED_INODE, /* is the inode fsynced before? */
c) HAS_LAST_FSYNC, /* has the latest node fsync mark? */
And, the scenarios for our rule are based on:
[Term] F: fsync_mark, D: dentry_mark
1. inode(x) | CP | inode(x) | dnode(F)
2. inode(x) | CP | inode(F) | dnode(F)
3. inode(x) | CP | dnode(F) | inode(x) | inode(F)
4. inode(x) | CP | dnode(F) | inode(F)
5. CP | inode(x) | dnode(F) | inode(DF)
6. CP | inode(DF) | dnode(F)
7. CP | dnode(F) | inode(DF)
8. CP | dnode(F) | inode(x) | inode(DF)
For example, #3, the three conditions should be changed as follows.
inode(x) | CP | dnode(F) | inode(x) | inode(F)
a) x o o o o
b) x x x x o
c) x o o x o
If f2fs_sync_file stops ------^,
it should write inode(F) --------------^
So, the need_inode_block_update should return true, since
c) get_nat_flag(e, HAS_LAST_FSYNC), is false.
For example, #8,
CP | alloc | dnode(F) | inode(x) | inode(DF)
a) o x x x x
b) x x x o
c) o o x o
If f2fs_sync_file stops -------^,
it should write inode(DF) --------------^
Note that, the roll-forward policy should follow this rule, which means,
if there are any missing blocks, we doesn't need to recover that inode.
Signed-off-by: Huang Ying <ying.huang@intel.com>
Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
2014-09-16 05:50:48 +08:00
|
|
|
bool is_checkpointed_node(struct f2fs_sb_info *, nid_t);
|
|
|
|
bool has_fsynced_inode(struct f2fs_sb_info *, nid_t);
|
|
|
|
bool need_inode_block_update(struct f2fs_sb_info *, nid_t);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
void get_node_info(struct f2fs_sb_info *, nid_t, struct node_info *);
|
|
|
|
int get_dnode_of_data(struct dnode_of_data *, pgoff_t, int);
|
|
|
|
int truncate_inode_blocks(struct inode *, pgoff_t);
|
2013-08-14 19:40:06 +08:00
|
|
|
int truncate_xattr_node(struct inode *, struct page *);
|
2013-10-31 13:57:01 +08:00
|
|
|
int wait_on_node_pages_writeback(struct f2fs_sb_info *, nid_t);
|
2013-11-19 18:03:18 +08:00
|
|
|
void remove_inode_page(struct inode *);
|
2014-06-21 12:44:02 +08:00
|
|
|
struct page *new_inode_page(struct inode *);
|
2013-06-03 18:46:19 +08:00
|
|
|
struct page *new_node_page(struct dnode_of_data *, unsigned int, struct page *);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
void ra_node_page(struct f2fs_sb_info *, nid_t);
|
|
|
|
struct page *get_node_page(struct f2fs_sb_info *, pgoff_t);
|
|
|
|
struct page *get_node_page_ra(struct page *, int);
|
|
|
|
void sync_inode_page(struct dnode_of_data *);
|
|
|
|
int sync_node_pages(struct f2fs_sb_info *, nid_t, struct writeback_control *);
|
|
|
|
bool alloc_nid(struct f2fs_sb_info *, nid_t *);
|
|
|
|
void alloc_nid_done(struct f2fs_sb_info *, nid_t);
|
|
|
|
void alloc_nid_failed(struct f2fs_sb_info *, nid_t);
|
2014-08-02 15:26:04 +08:00
|
|
|
void recover_inline_xattr(struct inode *, struct page *);
|
2014-08-08 14:49:17 +08:00
|
|
|
void recover_xattr_data(struct inode *, struct page *, block_t);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
int recover_inode_page(struct f2fs_sb_info *, struct page *);
|
|
|
|
int restore_node_summary(struct f2fs_sb_info *, unsigned int,
|
|
|
|
struct f2fs_summary_block *);
|
|
|
|
void flush_nat_entries(struct f2fs_sb_info *);
|
|
|
|
int build_node_manager(struct f2fs_sb_info *);
|
|
|
|
void destroy_node_manager(struct f2fs_sb_info *);
|
2013-01-16 23:08:30 +08:00
|
|
|
int __init create_node_manager_caches(void);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
void destroy_node_manager_caches(void);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* segment.c
|
|
|
|
*/
|
2014-10-07 08:39:50 +08:00
|
|
|
void register_inmem_page(struct inode *, struct page *);
|
2014-10-10 04:39:06 +08:00
|
|
|
void invalidate_inmem_page(struct inode *, struct page *);
|
2014-10-07 08:39:50 +08:00
|
|
|
void commit_inmem_pages(struct inode *, bool);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
void f2fs_balance_fs(struct f2fs_sb_info *);
|
2013-10-24 13:19:18 +08:00
|
|
|
void f2fs_balance_fs_bg(struct f2fs_sb_info *);
|
2014-04-02 14:34:36 +08:00
|
|
|
int f2fs_issue_flush(struct f2fs_sb_info *);
|
2014-04-27 14:21:33 +08:00
|
|
|
int create_flush_cmd_control(struct f2fs_sb_info *);
|
|
|
|
void destroy_flush_cmd_control(struct f2fs_sb_info *);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
void invalidate_blocks(struct f2fs_sb_info *, block_t);
|
2014-01-28 11:22:14 +08:00
|
|
|
void refresh_sit_entry(struct f2fs_sb_info *, block_t, block_t);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
void clear_prefree_segments(struct f2fs_sb_info *);
|
2014-09-21 13:06:39 +08:00
|
|
|
void release_discard_addrs(struct f2fs_sb_info *);
|
2014-07-26 06:47:25 +08:00
|
|
|
void discard_next_dnode(struct f2fs_sb_info *, block_t);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
int npages_for_summary_flush(struct f2fs_sb_info *);
|
|
|
|
void allocate_new_segments(struct f2fs_sb_info *);
|
2014-09-21 13:06:39 +08:00
|
|
|
int f2fs_trim_fs(struct f2fs_sb_info *, struct fstrim_range *);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
struct page *get_sum_page(struct f2fs_sb_info *, unsigned int);
|
f2fs: prevent checkpoint once any IO failure is detected
This patch enhances the checkpoint routine to cope with IO errors.
Basically f2fs detects IO errors from end_io_write, and the errors are able to
be occurred during one of data, node, and meta page writes.
In the previous code, when an IO error is occurred during writes, f2fs sets a
flag, CP_ERROR_FLAG, in the raw ckeckpoint buffer which will be written to disk.
Afterwards, write_checkpoint() will check the flag and remount f2fs as a
read-only (ro) mode.
However, even once f2fs is remounted as a ro mode, dirty checkpoint pages are
freely able to be written to disk by flusher or kswapd in background.
In such a case, after cold reboot, f2fs would restore the checkpoint data having
CP_ERROR_FLAG, resulting in disabling write_checkpoint and remounting f2fs as
a ro mode again.
Therefore, let's prevent any checkpoint page (meta) writes once an IO error is
occurred, and remount f2fs as a ro mode right away at that moment.
Reported-by: Oliver Winker <oliver@oli1170.net>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
Reviewed-by: Namjae Jeon <namjae.jeon@samsung.com>
2013-01-24 18:56:11 +08:00
|
|
|
void write_meta_page(struct f2fs_sb_info *, struct page *);
|
2014-01-08 09:09:51 +08:00
|
|
|
void write_node_page(struct f2fs_sb_info *, struct page *,
|
|
|
|
struct f2fs_io_info *, unsigned int, block_t, block_t *);
|
2013-12-11 12:54:01 +08:00
|
|
|
void write_data_page(struct page *, struct dnode_of_data *, block_t *,
|
|
|
|
struct f2fs_io_info *);
|
|
|
|
void rewrite_data_page(struct page *, block_t, struct f2fs_io_info *);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
void recover_data_page(struct f2fs_sb_info *, struct page *,
|
|
|
|
struct f2fs_summary *, block_t, block_t);
|
2013-12-16 18:04:05 +08:00
|
|
|
void allocate_data_block(struct f2fs_sb_info *, struct page *,
|
|
|
|
block_t, block_t *, struct f2fs_summary *, int);
|
2014-01-10 15:26:14 +08:00
|
|
|
void f2fs_wait_on_page_writeback(struct page *, enum page_type);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
void write_data_summaries(struct f2fs_sb_info *, block_t);
|
|
|
|
void write_node_summaries(struct f2fs_sb_info *, block_t);
|
|
|
|
int lookup_journal_in_cursum(struct f2fs_summary_block *,
|
|
|
|
int, unsigned int, int);
|
2014-09-21 13:06:39 +08:00
|
|
|
void flush_sit_entries(struct f2fs_sb_info *, struct cp_control *);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
int build_segment_manager(struct f2fs_sb_info *);
|
|
|
|
void destroy_segment_manager(struct f2fs_sb_info *);
|
2013-11-15 12:55:58 +08:00
|
|
|
int __init create_segment_manager_caches(void);
|
|
|
|
void destroy_segment_manager_caches(void);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* checkpoint.c
|
|
|
|
*/
|
|
|
|
struct page *grab_meta_page(struct f2fs_sb_info *, pgoff_t);
|
|
|
|
struct page *get_meta_page(struct f2fs_sb_info *, pgoff_t);
|
2014-09-12 04:49:55 +08:00
|
|
|
struct page *get_meta_page_ra(struct f2fs_sb_info *, pgoff_t);
|
|
|
|
int ra_meta_pages(struct f2fs_sb_info *, block_t, int, int);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
long sync_meta_pages(struct f2fs_sb_info *, enum page_type, long);
|
2014-07-25 22:40:59 +08:00
|
|
|
void add_dirty_inode(struct f2fs_sb_info *, nid_t, int type);
|
|
|
|
void remove_dirty_inode(struct f2fs_sb_info *, nid_t, int type);
|
2014-08-20 00:48:22 +08:00
|
|
|
void release_dirty_inode(struct f2fs_sb_info *);
|
2014-07-25 22:40:59 +08:00
|
|
|
bool exist_written_data(struct f2fs_sb_info *, nid_t, int);
|
2013-07-30 10:36:53 +08:00
|
|
|
int acquire_orphan_inode(struct f2fs_sb_info *);
|
|
|
|
void release_orphan_inode(struct f2fs_sb_info *);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
void add_orphan_inode(struct f2fs_sb_info *, nid_t);
|
|
|
|
void remove_orphan_inode(struct f2fs_sb_info *, nid_t);
|
2013-11-28 15:43:43 +08:00
|
|
|
void recover_orphan_inodes(struct f2fs_sb_info *);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
int get_valid_checkpoint(struct f2fs_sb_info *);
|
2014-09-13 06:53:45 +08:00
|
|
|
void update_dirty_page(struct inode *, struct page *);
|
2013-06-05 16:42:45 +08:00
|
|
|
void add_dirty_dir_inode(struct inode *);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
void remove_dirty_dir_inode(struct inode *);
|
|
|
|
void sync_dirty_dir_inodes(struct f2fs_sb_info *);
|
2014-09-21 12:57:51 +08:00
|
|
|
void write_checkpoint(struct f2fs_sb_info *, struct cp_control *);
|
2014-07-26 06:47:17 +08:00
|
|
|
void init_ino_entry_info(struct f2fs_sb_info *);
|
2013-01-16 23:08:30 +08:00
|
|
|
int __init create_checkpoint_caches(void);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
void destroy_checkpoint_caches(void);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* data.c
|
|
|
|
*/
|
2013-12-11 12:54:01 +08:00
|
|
|
void f2fs_submit_merged_bio(struct f2fs_sb_info *, enum page_type, int);
|
2013-11-30 11:51:14 +08:00
|
|
|
int f2fs_submit_page_bio(struct f2fs_sb_info *, struct page *, block_t, int);
|
|
|
|
void f2fs_submit_page_mbio(struct f2fs_sb_info *, struct page *, block_t,
|
2013-12-11 12:54:01 +08:00
|
|
|
struct f2fs_io_info *);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
int reserve_new_block(struct dnode_of_data *);
|
2013-11-10 23:13:18 +08:00
|
|
|
int f2fs_reserve_block(struct dnode_of_data *, pgoff_t);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
void update_extent_cache(block_t, struct dnode_of_data *);
|
f2fs: give a chance to merge IOs by IO scheduler
Previously, background GC submits many 4KB read requests to load victim blocks
and/or its (i)node blocks.
...
f2fs_gc : f2fs_readpage: ino = 1, page_index = 0xb61, blkaddr = 0x3b964ed
f2fs_gc : block_rq_complete: 8,16 R () 499854968 + 8 [0]
f2fs_gc : f2fs_readpage: ino = 1, page_index = 0xb6f, blkaddr = 0x3b964ee
f2fs_gc : block_rq_complete: 8,16 R () 499854976 + 8 [0]
f2fs_gc : f2fs_readpage: ino = 1, page_index = 0xb79, blkaddr = 0x3b964ef
f2fs_gc : block_rq_complete: 8,16 R () 499854984 + 8 [0]
...
However, by the fact that many IOs are sequential, we can give a chance to merge
the IOs by IO scheduler.
In order to do that, let's use blk_plug.
...
f2fs_gc : f2fs_iget: ino = 143
f2fs_gc : f2fs_readpage: ino = 143, page_index = 0x1c6, blkaddr = 0x2e6ee
f2fs_gc : f2fs_iget: ino = 143
f2fs_gc : f2fs_readpage: ino = 143, page_index = 0x1c7, blkaddr = 0x2e6ef
<idle> : block_rq_complete: 8,16 R () 1519616 + 8 [0]
<idle> : block_rq_complete: 8,16 R () 1519848 + 8 [0]
<idle> : block_rq_complete: 8,16 R () 1520432 + 96 [0]
<idle> : block_rq_complete: 8,16 R () 1520536 + 104 [0]
<idle> : block_rq_complete: 8,16 R () 1521008 + 112 [0]
<idle> : block_rq_complete: 8,16 R () 1521440 + 152 [0]
<idle> : block_rq_complete: 8,16 R () 1521688 + 144 [0]
<idle> : block_rq_complete: 8,16 R () 1522128 + 192 [0]
<idle> : block_rq_complete: 8,16 R () 1523256 + 328 [0]
...
Note that this issue should be addressed in checkpoint, and some readahead
flows too.
Reviewed-by: Namjae Jeon <namjae.jeon@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2013-04-24 12:19:56 +08:00
|
|
|
struct page *find_data_page(struct inode *, pgoff_t, bool);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
struct page *get_lock_data_page(struct inode *, pgoff_t);
|
2013-05-20 08:55:50 +08:00
|
|
|
struct page *get_new_data_page(struct inode *, struct page *, pgoff_t, bool);
|
2013-12-11 12:54:01 +08:00
|
|
|
int do_write_data_page(struct page *, struct f2fs_io_info *);
|
2014-06-08 03:30:14 +08:00
|
|
|
int f2fs_fiemap(struct inode *inode, struct fiemap_extent_info *, u64, u64);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* gc.c
|
|
|
|
*/
|
|
|
|
int start_gc_thread(struct f2fs_sb_info *);
|
|
|
|
void stop_gc_thread(struct f2fs_sb_info *);
|
2013-08-12 20:08:03 +08:00
|
|
|
block_t start_bidx_of_node(unsigned int, struct f2fs_inode_info *);
|
2013-01-03 16:55:52 +08:00
|
|
|
int f2fs_gc(struct f2fs_sb_info *);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
void build_gc_manager(struct f2fs_sb_info *);
|
2013-01-16 23:08:30 +08:00
|
|
|
int __init create_gc_caches(void);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
void destroy_gc_caches(void);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* recovery.c
|
|
|
|
*/
|
2013-03-20 18:01:06 +08:00
|
|
|
int recover_fsync_data(struct f2fs_sb_info *);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
bool space_for_roll_forward(struct f2fs_sb_info *);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* debug.c
|
|
|
|
*/
|
|
|
|
#ifdef CONFIG_F2FS_STAT_FS
|
|
|
|
struct f2fs_stat_info {
|
|
|
|
struct list_head stat_list;
|
|
|
|
struct f2fs_sb_info *sbi;
|
|
|
|
int all_area_segs, sit_area_segs, nat_area_segs, ssa_area_segs;
|
|
|
|
int main_area_segs, main_area_sections, main_area_zones;
|
|
|
|
int hit_ext, total_ext;
|
|
|
|
int ndirty_node, ndirty_dent, ndirty_dirs, ndirty_meta;
|
|
|
|
int nats, sits, fnids;
|
|
|
|
int total_count, utilization;
|
2014-10-14 11:00:16 +08:00
|
|
|
int bg_gc, inline_inode, inline_dir;
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
unsigned int valid_count, valid_node_count, valid_inode_count;
|
|
|
|
unsigned int bimodal, avg_vblocks;
|
|
|
|
int util_free, util_valid, util_invalid;
|
|
|
|
int rsvd_segs, overp_segs;
|
|
|
|
int dirty_count, node_pages, meta_pages;
|
2014-02-13 14:12:29 +08:00
|
|
|
int prefree_count, call_count, cp_count;
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
int tot_segs, node_segs, data_segs, free_segs, free_secs;
|
|
|
|
int tot_blks, data_blks, node_blks;
|
|
|
|
int curseg[NR_CURSEG_TYPE];
|
|
|
|
int cursec[NR_CURSEG_TYPE];
|
|
|
|
int curzone[NR_CURSEG_TYPE];
|
|
|
|
|
|
|
|
unsigned int segment_count[2];
|
|
|
|
unsigned int block_count[2];
|
|
|
|
unsigned base_mem, cache_mem;
|
|
|
|
};
|
|
|
|
|
2013-07-12 14:47:11 +08:00
|
|
|
static inline struct f2fs_stat_info *F2FS_STAT(struct f2fs_sb_info *sbi)
|
|
|
|
{
|
2014-01-18 04:44:39 +08:00
|
|
|
return (struct f2fs_stat_info *)sbi->stat_info;
|
2013-07-12 14:47:11 +08:00
|
|
|
}
|
|
|
|
|
2014-02-13 14:12:29 +08:00
|
|
|
#define stat_inc_cp_count(si) ((si)->cp_count++)
|
2013-10-22 19:56:10 +08:00
|
|
|
#define stat_inc_call_count(si) ((si)->call_count++)
|
|
|
|
#define stat_inc_bggc_count(sbi) ((sbi)->bg_gc++)
|
|
|
|
#define stat_inc_dirty_dir(sbi) ((sbi)->n_dirty_dirs++)
|
|
|
|
#define stat_dec_dirty_dir(sbi) ((sbi)->n_dirty_dirs--)
|
|
|
|
#define stat_inc_total_hit(sb) ((F2FS_SB(sb))->total_hit_ext++)
|
|
|
|
#define stat_inc_read_hit(sb) ((F2FS_SB(sb))->read_hit_ext++)
|
2013-11-26 10:08:57 +08:00
|
|
|
#define stat_inc_inline_inode(inode) \
|
|
|
|
do { \
|
|
|
|
if (f2fs_has_inline_data(inode)) \
|
2014-09-03 06:31:18 +08:00
|
|
|
((F2FS_I_SB(inode))->inline_inode++); \
|
2013-11-26 10:08:57 +08:00
|
|
|
} while (0)
|
|
|
|
#define stat_dec_inline_inode(inode) \
|
|
|
|
do { \
|
|
|
|
if (f2fs_has_inline_data(inode)) \
|
2014-09-03 06:31:18 +08:00
|
|
|
((F2FS_I_SB(inode))->inline_inode--); \
|
2013-11-26 10:08:57 +08:00
|
|
|
} while (0)
|
2014-10-14 11:00:16 +08:00
|
|
|
#define stat_inc_inline_dir(inode) \
|
|
|
|
do { \
|
|
|
|
if (f2fs_has_inline_dentry(inode)) \
|
|
|
|
((F2FS_I_SB(inode))->inline_dir++); \
|
|
|
|
} while (0)
|
|
|
|
#define stat_dec_inline_dir(inode) \
|
|
|
|
do { \
|
|
|
|
if (f2fs_has_inline_dentry(inode)) \
|
|
|
|
((F2FS_I_SB(inode))->inline_dir--); \
|
|
|
|
} while (0)
|
2013-10-22 19:56:10 +08:00
|
|
|
#define stat_inc_seg_type(sbi, curseg) \
|
|
|
|
((sbi)->segment_count[(curseg)->alloc_type]++)
|
|
|
|
#define stat_inc_block_count(sbi, curseg) \
|
|
|
|
((sbi)->block_count[(curseg)->alloc_type]++)
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
|
|
|
|
#define stat_inc_seg_count(sbi, type) \
|
|
|
|
do { \
|
2013-07-12 14:47:11 +08:00
|
|
|
struct f2fs_stat_info *si = F2FS_STAT(sbi); \
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
(si)->tot_segs++; \
|
|
|
|
if (type == SUM_TYPE_DATA) \
|
|
|
|
si->data_segs++; \
|
|
|
|
else \
|
|
|
|
si->node_segs++; \
|
|
|
|
} while (0)
|
|
|
|
|
|
|
|
#define stat_inc_tot_blk_count(si, blks) \
|
|
|
|
(si->tot_blks += (blks))
|
|
|
|
|
|
|
|
#define stat_inc_data_blk_count(sbi, blks) \
|
|
|
|
do { \
|
2013-07-12 14:47:11 +08:00
|
|
|
struct f2fs_stat_info *si = F2FS_STAT(sbi); \
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
stat_inc_tot_blk_count(si, blks); \
|
|
|
|
si->data_blks += (blks); \
|
|
|
|
} while (0)
|
|
|
|
|
|
|
|
#define stat_inc_node_blk_count(sbi, blks) \
|
|
|
|
do { \
|
2013-07-12 14:47:11 +08:00
|
|
|
struct f2fs_stat_info *si = F2FS_STAT(sbi); \
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
stat_inc_tot_blk_count(si, blks); \
|
|
|
|
si->node_blks += (blks); \
|
|
|
|
} while (0)
|
|
|
|
|
|
|
|
int f2fs_build_stats(struct f2fs_sb_info *);
|
|
|
|
void f2fs_destroy_stats(struct f2fs_sb_info *);
|
2013-01-16 23:08:30 +08:00
|
|
|
void __init f2fs_create_root_stats(void);
|
2013-01-15 18:58:47 +08:00
|
|
|
void f2fs_destroy_root_stats(void);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
#else
|
2014-02-13 14:12:29 +08:00
|
|
|
#define stat_inc_cp_count(si)
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
#define stat_inc_call_count(si)
|
2013-10-22 19:56:10 +08:00
|
|
|
#define stat_inc_bggc_count(si)
|
|
|
|
#define stat_inc_dirty_dir(sbi)
|
|
|
|
#define stat_dec_dirty_dir(sbi)
|
|
|
|
#define stat_inc_total_hit(sb)
|
|
|
|
#define stat_inc_read_hit(sb)
|
2013-11-26 10:08:57 +08:00
|
|
|
#define stat_inc_inline_inode(inode)
|
|
|
|
#define stat_dec_inline_inode(inode)
|
2014-10-14 11:00:16 +08:00
|
|
|
#define stat_inc_inline_dir(inode)
|
|
|
|
#define stat_dec_inline_dir(inode)
|
2013-10-22 19:56:10 +08:00
|
|
|
#define stat_inc_seg_type(sbi, curseg)
|
|
|
|
#define stat_inc_block_count(sbi, curseg)
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
#define stat_inc_seg_count(si, type)
|
|
|
|
#define stat_inc_tot_blk_count(si, blks)
|
|
|
|
#define stat_inc_data_blk_count(si, blks)
|
|
|
|
#define stat_inc_node_blk_count(sbi, blks)
|
|
|
|
|
|
|
|
static inline int f2fs_build_stats(struct f2fs_sb_info *sbi) { return 0; }
|
|
|
|
static inline void f2fs_destroy_stats(struct f2fs_sb_info *sbi) { }
|
2013-01-16 23:08:30 +08:00
|
|
|
static inline void __init f2fs_create_root_stats(void) { }
|
2013-01-15 18:58:47 +08:00
|
|
|
static inline void f2fs_destroy_root_stats(void) { }
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
#endif
|
|
|
|
|
|
|
|
extern const struct file_operations f2fs_dir_operations;
|
|
|
|
extern const struct file_operations f2fs_file_operations;
|
|
|
|
extern const struct inode_operations f2fs_file_inode_operations;
|
|
|
|
extern const struct address_space_operations f2fs_dblock_aops;
|
|
|
|
extern const struct address_space_operations f2fs_node_aops;
|
|
|
|
extern const struct address_space_operations f2fs_meta_aops;
|
|
|
|
extern const struct inode_operations f2fs_dir_inode_operations;
|
|
|
|
extern const struct inode_operations f2fs_symlink_inode_operations;
|
|
|
|
extern const struct inode_operations f2fs_special_inode_operations;
|
2013-11-10 23:13:16 +08:00
|
|
|
|
2013-11-10 23:13:19 +08:00
|
|
|
/*
|
|
|
|
* inline.c
|
|
|
|
*/
|
|
|
|
bool f2fs_may_inline(struct inode *);
|
2014-10-24 10:48:09 +08:00
|
|
|
void read_inline_data(struct page *, struct page *);
|
2013-11-10 23:13:19 +08:00
|
|
|
int f2fs_read_inline_data(struct inode *, struct page *);
|
2014-10-24 10:48:09 +08:00
|
|
|
int f2fs_convert_inline_page(struct dnode_of_data *, struct page *);
|
|
|
|
int f2fs_convert_inline_inode(struct inode *);
|
|
|
|
int f2fs_write_inline_data(struct inode *, struct page *);
|
|
|
|
void truncate_inline_data(struct page *, u64);
|
2014-08-08 07:57:17 +08:00
|
|
|
bool recover_inline_data(struct inode *, struct page *);
|
2014-09-24 18:17:53 +08:00
|
|
|
struct f2fs_dir_entry *find_in_inline_dir(struct inode *, struct qstr *,
|
|
|
|
struct page **);
|
|
|
|
struct f2fs_dir_entry *f2fs_parent_inline_dir(struct inode *, struct page **);
|
|
|
|
int make_empty_inline_dir(struct inode *inode, struct inode *, struct page *);
|
|
|
|
int f2fs_add_inline_entry(struct inode *, const struct qstr *, struct inode *);
|
|
|
|
void f2fs_delete_inline_entry(struct f2fs_dir_entry *, struct page *,
|
|
|
|
struct inode *, struct inode *);
|
|
|
|
bool f2fs_empty_inline_dir(struct inode *);
|
|
|
|
int f2fs_read_inline_dir(struct file *, struct dir_context *);
|
f2fs: add superblock and major in-memory structure
This adds the following major in-memory structures in f2fs.
- f2fs_sb_info:
contains f2fs-specific information, two special inode pointers for node and
meta address spaces, and orphan inode management.
- f2fs_inode_info:
contains vfs_inode and other fs-specific information.
- f2fs_nm_info:
contains node manager information such as NAT entry cache, free nid list,
and NAT page management.
- f2fs_node_info:
represents a node as node id, inode number, block address, and its version.
- f2fs_sm_info:
contains segment manager information such as SIT entry cache, free segment
map, current active logs, dirty segment management, and segment utilization.
The specific structures are sit_info, free_segmap_info, dirty_seglist_info,
curseg_info.
In addition, add F2FS_SUPER_MAGIC in magic.h.
Signed-off-by: Chul Lee <chur.lee@samsung.com>
Signed-off-by: Jaegeuk Kim <jaegeuk.kim@samsung.com>
2012-11-28 12:37:31 +08:00
|
|
|
#endif
|