From: Zhi Yong Wu <wu...@linux.vnet.ibm.com>

Signed-off-by: Zhi Yong Wu <wu...@linux.vnet.ibm.com>
---
 fs/hot_tracking.c |   67 +++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 67 insertions(+), 0 deletions(-)

diff --git a/fs/hot_tracking.c b/fs/hot_tracking.c
index ba4decf..6a5ef53 100644
--- a/fs/hot_tracking.c
+++ b/fs/hot_tracking.c
@@ -389,6 +389,73 @@ static u32 hot_temp_calc(struct hot_freq_data *freq_data)
 }
 
 /*
+ * Calculate a new temperature and, if necessary,
+ * move the list_head corresponding to this inode or range
+ * to the proper list with the new temperature
+ */
+static void hot_map_update(struct hot_freq_data *freq_data,
+                               struct hot_info *root)
+{
+       struct hot_map_head *buckets, *cur_bucket;
+       struct hot_comm_item *comm_item;
+       struct hot_inode_item *he;
+       struct hot_range_item *hr;
+       u32 temp = hot_temp_calc(freq_data);
+       u8 a_temp = (u8)hot_raw_shift((u64)temp, (32 - HEAT_MAP_BITS), false);
+       u8 b_temp = (u8)hot_raw_shift((u64)freq_data->last_temp,
+                                       (32 - HEAT_MAP_BITS), false);
+
+       comm_item = container_of(freq_data,
+                       struct hot_comm_item, hot_freq_data);
+
+       if (freq_data->flags & FREQ_DATA_TYPE_INODE) {
+               he = container_of(comm_item,
+                       struct hot_inode_item, hot_inode);
+               buckets = root->heat_inode_map;
+
+               if (he == NULL)
+                       return;
+
+               spin_lock(&he->hot_inode.lock);
+               if (list_empty(&he->hot_inode.n_list) || (a_temp != b_temp)) {
+                       if (!list_empty(&he->hot_inode.n_list)) {
+                               list_del_init(&he->hot_inode.n_list);
+                               root->hot_map_nr--;
+                       }
+
+                       cur_bucket = buckets + a_temp;
+                       list_add_tail(&he->hot_inode.n_list,
+                                       &cur_bucket->node_list);
+                       root->hot_map_nr++;
+                       freq_data->last_temp = temp;
+               }
+               spin_unlock(&he->hot_inode.lock);
+       } else if (freq_data->flags & FREQ_DATA_TYPE_RANGE) {
+               hr = container_of(comm_item,
+                       struct hot_range_item, hot_range);
+               buckets = root->heat_range_map;
+
+               if (hr == NULL)
+                       return;
+
+               spin_lock(&hr->hot_range.lock);
+               if (list_empty(&hr->hot_range.n_list) || (a_temp != b_temp)) {
+                       if (!list_empty(&hr->hot_range.n_list)) {
+                               list_del_init(&hr->hot_range.n_list);
+                               root->hot_map_nr--;
+                       }
+
+                       cur_bucket = buckets + a_temp;
+                       list_add_tail(&hr->hot_range.n_list,
+                                       &cur_bucket->node_list);
+                       root->hot_map_nr++;
+                       freq_data->last_temp = temp;
+               }
+               spin_unlock(&hr->hot_range.lock);
+       }
+}
+
+/*
  * Initialize inode and range map info.
  */
 static void hot_map_init(struct hot_info *root)
-- 
1.7.6.5

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to