cfq-iosched: fix sysfs oops when attempting to read unconfigured weights
authorJens Axboe <axboe@fb.com>
Fri, 19 Jun 2015 16:19:36 +0000 (10:19 -0600)
committerJens Axboe <axboe@fb.com>
Fri, 19 Jun 2015 16:19:36 +0000 (10:19 -0600)
If none of the devices in the system are using CFQ, then attempting to
read:

/sys/fs/cgroup/blkio/blkio.leaf_weight

will results in a NULL dereference. Check for a valid cfq_group_data
struct before attempting to dereference it.

Reported-by: Andrey Wagin <avagin@gmail.com>
Fixes: e48453c3 ("block, cgroup: implement policy-specific per-blkcg data")
Signed-off-by: Jens Axboe <axboe@fb.com>
block/cfq-iosched.c

index dbd0207928fb95d2fbc64f854bc0e1dc006dc4c0..ed86fb242cd405281978aa50e81fd5ec5c355131 100644 (file)
@@ -1714,16 +1714,26 @@ static int cfqg_print_leaf_weight_device(struct seq_file *sf, void *v)
 static int cfq_print_weight(struct seq_file *sf, void *v)
 {
        struct blkcg *blkcg = css_to_blkcg(seq_css(sf));
+       struct cfq_group_data *cgd = blkcg_to_cfqgd(blkcg);
+       unsigned int val = 0;
 
-       seq_printf(sf, "%u\n", blkcg_to_cfqgd(blkcg)->weight);
+       if (cgd)
+               val = cgd->weight;
+
+       seq_printf(sf, "%u\n", val);
        return 0;
 }
 
 static int cfq_print_leaf_weight(struct seq_file *sf, void *v)
 {
        struct blkcg *blkcg = css_to_blkcg(seq_css(sf));
+       struct cfq_group_data *cgd = blkcg_to_cfqgd(blkcg);
+       unsigned int val = 0;
+
+       if (cgd)
+               val = cgd->leaf_weight;
 
-       seq_printf(sf, "%u\n", blkcg_to_cfqgd(blkcg)->leaf_weight);
+       seq_printf(sf, "%u\n", val);
        return 0;
 }