cfq-iosched: Add comments on update timing of weight
[firefly-linux-kernel-4.4.55.git] / block / cfq-iosched.c
index d7494637c5db48b7cd2783d86c2b706a40a9e64d..3f31cf9508e6204c144c2b665fb90aa67df3c9a2 100644 (file)
@@ -1272,6 +1272,9 @@ __cfq_group_service_tree_add(struct cfq_rb_root *st, struct cfq_group *cfqg)
        rb_insert_color(&cfqg->rb_node, &st->rb);
 }
 
+/*
+ * This has to be called only on activation of cfqg
+ */
 static void
 cfq_update_group_weight(struct cfq_group *cfqg)
 {
@@ -1303,6 +1306,11 @@ cfq_group_service_tree_add(struct cfq_rb_root *st, struct cfq_group *cfqg)
        /* add to the service tree */
        BUG_ON(!RB_EMPTY_NODE(&cfqg->rb_node));
 
+       /*
+        * Update leaf_weight.  We cannot update weight at this point
+        * because cfqg might already have been activated and is
+        * contributing its current weight to the parent's child_weight.
+        */
        cfq_update_group_leaf_weight(cfqg);
        __cfq_group_service_tree_add(st, cfqg);