]> asedeno.scripts.mit.edu Git - linux.git/commitdiff
ext4: uninline ext4_inode_journal_mode()
authorEric Biggers <ebiggers@google.com>
Mon, 9 Dec 2019 23:36:02 +0000 (15:36 -0800)
committerTheodore Ts'o <tytso@mit.edu>
Fri, 17 Jan 2020 21:24:52 +0000 (16:24 -0500)
Determining an inode's journaling mode has gotten more complicated over
time.  Move ext4_inode_journal_mode() from an inline function into
ext4_jbd2.c to reduce the compiled code size.

Signed-off-by: Eric Biggers <ebiggers@google.com>
Link: https://lore.kernel.org/r/20191209233602.117778-1-ebiggers@kernel.org
Signed-off-by: Theodore Ts'o <tytso@mit.edu>
Reviewed-by: Jan Kara <jack@suse.cz>
fs/ext4/ext4_jbd2.c
fs/ext4/ext4_jbd2.h

index 19217a3f1ae4a18d34c8fda6dd917eb64782d17e..1f53d64e42a5122ae124b4c03b9224d46d225bc5 100644 (file)
@@ -7,6 +7,28 @@
 
 #include <trace/events/ext4.h>
 
+int ext4_inode_journal_mode(struct inode *inode)
+{
+       if (EXT4_JOURNAL(inode) == NULL)
+               return EXT4_INODE_WRITEBACK_DATA_MODE;  /* writeback */
+       /* We do not support data journalling with delayed allocation */
+       if (!S_ISREG(inode->i_mode) ||
+           ext4_test_inode_flag(inode, EXT4_INODE_EA_INODE) ||
+           test_opt(inode->i_sb, DATA_FLAGS) == EXT4_MOUNT_JOURNAL_DATA ||
+           (ext4_test_inode_flag(inode, EXT4_INODE_JOURNAL_DATA) &&
+           !test_opt(inode->i_sb, DELALLOC))) {
+               /* We do not support data journalling for encrypted data */
+               if (S_ISREG(inode->i_mode) && IS_ENCRYPTED(inode))
+                       return EXT4_INODE_ORDERED_DATA_MODE;  /* ordered */
+               return EXT4_INODE_JOURNAL_DATA_MODE;    /* journal data */
+       }
+       if (test_opt(inode->i_sb, DATA_FLAGS) == EXT4_MOUNT_ORDERED_DATA)
+               return EXT4_INODE_ORDERED_DATA_MODE;    /* ordered */
+       if (test_opt(inode->i_sb, DATA_FLAGS) == EXT4_MOUNT_WRITEBACK_DATA)
+               return EXT4_INODE_WRITEBACK_DATA_MODE;  /* writeback */
+       BUG();
+}
+
 /* Just increment the non-pointer handle value */
 static handle_t *ext4_get_nojournal(void)
 {
index a6b9b66dbfade76a5f5d8bb31ad9337af5fd22d1..7ea4f6fa173b4794266f7921851d57aa7940e974 100644 (file)
@@ -463,27 +463,7 @@ int ext4_force_commit(struct super_block *sb);
 #define EXT4_INODE_ORDERED_DATA_MODE   0x02 /* ordered data mode */
 #define EXT4_INODE_WRITEBACK_DATA_MODE 0x04 /* writeback data mode */
 
-static inline int ext4_inode_journal_mode(struct inode *inode)
-{
-       if (EXT4_JOURNAL(inode) == NULL)
-               return EXT4_INODE_WRITEBACK_DATA_MODE;  /* writeback */
-       /* We do not support data journalling with delayed allocation */
-       if (!S_ISREG(inode->i_mode) ||
-           ext4_test_inode_flag(inode, EXT4_INODE_EA_INODE) ||
-           test_opt(inode->i_sb, DATA_FLAGS) == EXT4_MOUNT_JOURNAL_DATA ||
-           (ext4_test_inode_flag(inode, EXT4_INODE_JOURNAL_DATA) &&
-           !test_opt(inode->i_sb, DELALLOC))) {
-               /* We do not support data journalling for encrypted data */
-               if (S_ISREG(inode->i_mode) && IS_ENCRYPTED(inode))
-                       return EXT4_INODE_ORDERED_DATA_MODE;  /* ordered */
-               return EXT4_INODE_JOURNAL_DATA_MODE;    /* journal data */
-       }
-       if (test_opt(inode->i_sb, DATA_FLAGS) == EXT4_MOUNT_ORDERED_DATA)
-               return EXT4_INODE_ORDERED_DATA_MODE;    /* ordered */
-       if (test_opt(inode->i_sb, DATA_FLAGS) == EXT4_MOUNT_WRITEBACK_DATA)
-               return EXT4_INODE_WRITEBACK_DATA_MODE;  /* writeback */
-       BUG();
-}
+int ext4_inode_journal_mode(struct inode *inode);
 
 static inline int ext4_should_journal_data(struct inode *inode)
 {