summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorHyunchul Lee <cheol.lee@lge.com>2017-11-09 14:51:27 +0900
committerJaegeuk Kim <jaegeuk@kernel.org>2017-11-09 10:18:16 -0800
commit4f0a03d34dd46afcec5d9c9ada8ab97712d64cf8 (patch)
treed5d3d49dc3d7145a7be8c515937c47448a412277
parent2fbaa25fde4615fc5f32f71992510d83e427371b (diff)
downloadlinux-stable-4f0a03d34dd46afcec5d9c9ada8ab97712d64cf8.tar.gz
linux-stable-4f0a03d34dd46afcec5d9c9ada8ab97712d64cf8.tar.bz2
linux-stable-4f0a03d34dd46afcec5d9c9ada8ab97712d64cf8.zip
f2fs: apply write hints to select the type of segments for buffered write
Write hints helps F2FS to determine which type of segments would be selected for buffered write. This patch implements the mapping from write hints to segment types as shown below. hints segment type ----- ------------ WRITE_LIFE_SHORT CURSEG_HOT_DATA WRITE_LIFE_EXTREME CURSEG_COLD_DATA others CURSEG_WARM_DATA the F2FS poliy for hot/cold seperation has precedence over this hints. And hints are not applied in in-place update. Signed-off-by: Hyunchul Lee <cheol.lee@lge.com> Reviewed-by: Chao Yu <yuchao0@huawei.com> Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
-rw-r--r--fs/f2fs/segment.c14
1 files changed, 13 insertions, 1 deletions
diff --git a/fs/f2fs/segment.c b/fs/f2fs/segment.c
index 20722b24f801..c117e0913f2a 100644
--- a/fs/f2fs/segment.c
+++ b/fs/f2fs/segment.c
@@ -2434,6 +2434,18 @@ static bool __has_curseg_space(struct f2fs_sb_info *sbi, int type)
return false;
}
+int rw_hint_to_seg_type(enum rw_hint hint)
+{
+ switch (hint) {
+ case WRITE_LIFE_SHORT:
+ return CURSEG_HOT_DATA;
+ case WRITE_LIFE_EXTREME:
+ return CURSEG_COLD_DATA;
+ default:
+ return CURSEG_WARM_DATA;
+ }
+}
+
static int __get_segment_type_2(struct f2fs_io_info *fio)
{
if (fio->type == DATA)
@@ -2468,7 +2480,7 @@ static int __get_segment_type_6(struct f2fs_io_info *fio)
return CURSEG_COLD_DATA;
if (is_inode_flag_set(inode, FI_HOT_DATA))
return CURSEG_HOT_DATA;
- return CURSEG_WARM_DATA;
+ return rw_hint_to_seg_type(inode->i_write_hint);
} else {
if (IS_DNODE(fio->page))
return is_cold_node(fio->page) ? CURSEG_WARM_NODE :