ext4: isolate ext4_extents.h file
authorZheng Liu <wenqing.lz@taobao.com>
Wed, 28 Aug 2013 18:47:06 +0000 (14:47 -0400)
committerTheodore Ts'o <tytso@mit.edu>
Wed, 28 Aug 2013 18:47:06 +0000 (14:47 -0400)
After applied the commit (4a092d73), we have reduced the number of
source files that need to #include ext4_extents.h.  But we can do
better.

This commit defines ext4_zeroout_es() in extents.c and move
EXT_MAX_BLOCKS into ext4.h in order not to include ext4_extents.h in
indirect.c and ioctl.c.  Meanwhile we just need to include this file in
extent_status.c when ES_AGGRESSIVE_TEST is defined.  Otherwise, this
commit removes a duplicated declaration in trace/events/ext4.h.

After applied this patch, we just need to include ext4_extents.h file
in {super,migrate,move_extents,extents}.c, and it is easy for us to
define a new extent disk layout.

Signed-off-by: Zheng Liu <wenqing.lz@taobao.com>
Signed-off-by: "Theodore Ts'o" <tytso@mit.edu>
fs/ext4/ext4.h
fs/ext4/ext4_extents.h
fs/ext4/extents.c
fs/ext4/extents_status.c
fs/ext4/extents_status.h
fs/ext4/indirect.c
fs/ext4/ioctl.c
include/trace/events/ext4.h

index 3dbc56eb4849d624ad38e768ff350ea1af463af0..28896655ad41873e45ad15bf594f184ddb9d5c4c 100644 (file)
@@ -2686,6 +2686,12 @@ extern int ext4_check_blockref(const char *, unsigned int,
 struct ext4_ext_path;
 struct ext4_extent;
 
+/*
+ * Maximum number of logical blocks in a file; ext4_extent's ee_block is
+ * __le32.
+ */
+#define EXT_MAX_BLOCKS 0xffffffff
+
 extern int ext4_ext_tree_init(handle_t *handle, struct inode *);
 extern int ext4_ext_writepage_trans_blocks(struct inode *, int);
 extern int ext4_ext_index_trans_blocks(struct inode *inode, int extents);
index 51bc821ade90e2eacf9e894f836dcb50f9617b00..5074fe23f19e5a05544fb9d05095634ddcbe20a8 100644 (file)
@@ -133,12 +133,6 @@ struct ext4_ext_path {
  * structure for external API
  */
 
-/*
- * Maximum number of logical blocks in a file; ext4_extent's ee_block is
- * __le32.
- */
-#define EXT_MAX_BLOCKS 0xffffffff
-
 /*
  * EXT_INIT_MAX_LEN is the maximum number of blocks we can have in an
  * initialized extent. This is 2^15 and not (2^16 - 1), since we use the
index 916e88498c87c7bcca9e8fcf80e13334800f52bb..54d52afcdb198d6b55d28a479cfa9e353ab96100 100644 (file)
@@ -3048,6 +3048,23 @@ void ext4_ext_release(struct super_block *sb)
 #endif
 }
 
+static int ext4_zeroout_es(struct inode *inode, struct ext4_extent *ex)
+{
+       ext4_lblk_t  ee_block;
+       ext4_fsblk_t ee_pblock;
+       unsigned int ee_len;
+
+       ee_block  = le32_to_cpu(ex->ee_block);
+       ee_len    = ext4_ext_get_actual_len(ex);
+       ee_pblock = ext4_ext_pblock(ex);
+
+       if (ee_len == 0)
+               return 0;
+
+       return ext4_es_insert_extent(inode, ee_block, ee_len, ee_pblock,
+                                    EXTENT_STATUS_WRITTEN);
+}
+
 /* FIXME!! we need to try to merge to left or right after zero-out  */
 static int ext4_ext_zeroout(struct inode *inode, struct ext4_extent *ex)
 {
@@ -3200,7 +3217,7 @@ static int ext4_split_extent_at(handle_t *handle,
                        goto fix_extent_len;
 
                /* update extent status tree */
-               err = ext4_es_zeroout(inode, &zero_ex);
+               err = ext4_zeroout_es(inode, &zero_ex);
 
                goto out;
        } else if (err)
@@ -3551,7 +3568,7 @@ static int ext4_ext_convert_to_initialized(handle_t *handle,
 out:
        /* If we have gotten a failure, don't zero out status tree */
        if (!err)
-               err = ext4_es_zeroout(inode, &zero_ex);
+               err = ext4_zeroout_es(inode, &zero_ex);
        return err ? err : allocated;
 }
 
index 0e88a367b535f0b1321e68c6a5d742d910a428e6..2d1bdbe78c0408402c2eff05fac8f781d393f074 100644 (file)
@@ -13,7 +13,6 @@
 #include <linux/list_sort.h>
 #include "ext4.h"
 #include "extents_status.h"
-#include "ext4_extents.h"
 
 #include <trace/events/ext4.h>
 
@@ -409,6 +408,8 @@ ext4_es_try_to_merge_right(struct inode *inode, struct extent_status *es)
 }
 
 #ifdef ES_AGGRESSIVE_TEST
+#include "ext4_extents.h"      /* Needed when ES_AGGRESSIVE_TEST is defined */
+
 static void ext4_es_insert_extent_ext_check(struct inode *inode,
                                            struct extent_status *es)
 {
@@ -903,23 +904,6 @@ int ext4_es_remove_extent(struct inode *inode, ext4_lblk_t lblk,
        return err;
 }
 
-int ext4_es_zeroout(struct inode *inode, struct ext4_extent *ex)
-{
-       ext4_lblk_t  ee_block;
-       ext4_fsblk_t ee_pblock;
-       unsigned int ee_len;
-
-       ee_block  = le32_to_cpu(ex->ee_block);
-       ee_len    = ext4_ext_get_actual_len(ex);
-       ee_pblock = ext4_ext_pblock(ex);
-
-       if (ee_len == 0)
-               return 0;
-
-       return ext4_es_insert_extent(inode, ee_block, ee_len, ee_pblock,
-                                    EXTENT_STATUS_WRITTEN);
-}
-
 static int ext4_inode_touch_time_cmp(void *priv, struct list_head *a,
                                     struct list_head *b)
 {
index 3e83aef3653a03938a0b9f30533ffbd1566b2fe1..167f4ab8ecc35ed27a9af0d90e1f6ae6a315ef37 100644 (file)
@@ -81,7 +81,6 @@ extern void ext4_es_find_delayed_extent_range(struct inode *inode,
                                        struct extent_status *es);
 extern int ext4_es_lookup_extent(struct inode *inode, ext4_lblk_t lblk,
                                 struct extent_status *es);
-extern int ext4_es_zeroout(struct inode *inode, struct ext4_extent *ex);
 
 static inline int ext4_es_is_written(struct extent_status *es)
 {
index 87b30cd357e7f1962b55bf9d452f839376187302..594009f5f523f0fd2228a72f1aa593a6f3ebf66f 100644 (file)
@@ -23,7 +23,6 @@
 #include <linux/aio.h>
 #include "ext4_jbd2.h"
 #include "truncate.h"
-#include "ext4_extents.h"      /* Needed for EXT_MAX_BLOCKS */
 
 #include <trace/events/ext4.h>
 
index 5498f75a16480b6f4b97e170c2f07d03cb0d6baf..a569d335f8049ac4b5c37e4446eedfd3028166e2 100644 (file)
@@ -17,7 +17,6 @@
 #include <asm/uaccess.h>
 #include "ext4_jbd2.h"
 #include "ext4.h"
-#include "ext4_extents.h"
 
 #define MAX_32_NUM ((((unsigned long long) 1) << 32) - 1)
 
index d892b55d91ab84fd00539f54677dae9ce7a064cc..197d3125df2aff526e7a69205c5ee7393b53221a 100644 (file)
@@ -14,7 +14,6 @@ struct ext4_prealloc_space;
 struct ext4_inode_info;
 struct mpage_da_data;
 struct ext4_map_blocks;
-struct ext4_extent;
 struct extent_status;
 
 #define EXT4_I(inode) (container_of(inode, struct ext4_inode_info, vfs_inode))