Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751850AbbLaGgh (ORCPT ); Thu, 31 Dec 2015 01:36:37 -0500 Received: from mailout2.samsung.com ([203.254.224.25]:54230 "EHLO mailout2.samsung.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751177AbbLaGgd (ORCPT ); Thu, 31 Dec 2015 01:36:33 -0500 X-AuditID: cbfee61b-f793c6d00000236c-d2-5684ccef7c24 From: Chao Yu To: Jaegeuk Kim Cc: linux-f2fs-devel@lists.sourceforge.net, linux-kernel@vger.kernel.org Subject: [PATCH] f2fs: introduce max_file_blocks in sbi Date: Thu, 31 Dec 2015 14:35:37 +0800 Message-id: <011601d14395$95f64d70$c1e2e850$@samsung.com> MIME-version: 1.0 Content-type: text/plain; charset=us-ascii Content-transfer-encoding: 7bit X-Mailer: Microsoft Outlook 14.0 Thread-index: AdFDaNujO2YcfsuqTqeT4zXDgEBiCw== Content-language: zh-cn X-Brightmail-Tracker: H4sIAAAAAAAAA+NgFjrJLMWRmVeSWpSXmKPExsVy+t9jQd33Z1rCDJaclLZ4sn4Ws8WlRe4W l3fNYXNg9ti0qpPNY/eCz0wenzfJBTBHcdmkpOZklqUW6dslcGUs+b6WueCCaMXVfWYNjM8F uxg5OSQETCSOL9nLAmGLSVy4t56ti5GLQ0hgFqPEges3WCCcV4wSh39NYwWpYhNQkVje8Z8J xBYBsg8tuswOYjMLeEg0dnwHqxEWMJdoufkNKM7BwSKgKnH1owNImFfAUuJA+xRmCFtQ4sfk eywQrVoS63ceZ4Kw5SU2r3nLDHGQgsSOs68ZQcaICOhJ/D9iBlEiLrHxyC2WCYxARyJMmoVk 0iwkk2YhaVnAyLKKUSK1ILmgOCk91ygvtVyvODG3uDQvXS85P3cTIziAn0nvYDy8y/0QowAH oxIP74K0ljAh1sSy4srcQ4wSHMxKIrz2xUAh3pTEyqrUovz4otKc1OJDjNIcLErivPsuRYYJ CaQnlqRmp6YWpBbBZJk4OKUaGJP4d3Zsy5mlsi9xssFzmdM/d+3JF9MzPFcjdZ2leZPt9fVZ P3OdKs7MrjjzXPPUGpbuA5XPlwXX1Zx579vNqGcTk3rDaYEPQy13t/bNS3pr7xq0yrx4YP12 Nvu2dLNPDw78P7AuPLjl0rU6mV+dk7f62C6zUQ3VltU+aWl3n1nY6UiUy/yZh5RYijMSDbWY i4oTAWK8B7xcAgAA Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2933 Lines: 85 Introduce max_file_blocks in sbi to store max block index of file in f2fs, it could be used to avoid unneeded calculation of max block index in runtime. Signed-off-by: Chao Yu --- fs/f2fs/data.c | 2 +- fs/f2fs/f2fs.h | 2 +- fs/f2fs/super.c | 7 ++++--- 3 files changed, 6 insertions(+), 5 deletions(-) diff --git a/fs/f2fs/data.c b/fs/f2fs/data.c index 5a71017..73b7a8f 100644 --- a/fs/f2fs/data.c +++ b/fs/f2fs/data.c @@ -762,7 +762,7 @@ static int get_data_block_bmap(struct inode *inode, sector_t iblock, struct buffer_head *bh_result, int create) { /* Block number less than F2FS MAX BLOCKS */ - if (unlikely(iblock >= max_file_size(0))) + if (unlikely(iblock >= F2FS_I_SB(inode)->max_file_blocks)) return -EFBIG; return __get_data_block(inode, iblock, bh_result, create, diff --git a/fs/f2fs/f2fs.h b/fs/f2fs/f2fs.h index 9ba6a09..520d8f2 100644 --- a/fs/f2fs/f2fs.h +++ b/fs/f2fs/f2fs.h @@ -786,6 +786,7 @@ struct f2fs_sb_info { 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 */ + unsigned int max_file_blocks; /* max block index of file */ int active_logs; /* # of active logs */ int dir_level; /* directory level */ int serialized_dio_pages; /* serialized direct IO pages */ @@ -1731,7 +1732,6 @@ static inline int f2fs_add_link(struct dentry *dentry, struct inode *inode) * super.c */ int f2fs_commit_super(struct f2fs_sb_info *, bool); -loff_t max_file_size(unsigned bits); int f2fs_sync_fs(struct super_block *, int); extern __printf(3, 4) void f2fs_msg(struct super_block *, const char *, const char *, ...); diff --git a/fs/f2fs/super.c b/fs/f2fs/super.c index f474355..4e5bbd4 100644 --- a/fs/f2fs/super.c +++ b/fs/f2fs/super.c @@ -909,7 +909,7 @@ static const struct export_operations f2fs_export_ops = { .get_parent = f2fs_get_parent, }; -loff_t max_file_size(unsigned bits) +static loff_t max_file_blocks(void) { loff_t result = (DEF_ADDRS_PER_INODE - F2FS_INLINE_XATTR_ADDRS); loff_t leaf_count = ADDRS_PER_BLOCK; @@ -925,7 +925,6 @@ loff_t max_file_size(unsigned bits) leaf_count *= NIDS_PER_BLOCK; result += leaf_count; - result <<= bits; return result; } @@ -1281,7 +1280,9 @@ try_onemore: if (err) goto free_options; - sb->s_maxbytes = max_file_size(le32_to_cpu(raw_super->log_blocksize)); + sbi->max_file_blocks = max_file_blocks(); + sb->s_maxbytes = sbi->max_file_blocks << + le32_to_cpu(raw_super->log_blocksize); sb->s_max_links = F2FS_LINK_MAX; get_random_bytes(&sbi->s_next_generation, sizeof(u32)); -- 2.6.3 -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/