[Date Prev][Date Next] [Thread Prev][Thread Next]
[Thread Index]
[Date Index]
[Author Index]
[dm-devel] Re: [PATCH 05/18] io-controller: Common hierarchical fair queuing code in elevaotor layer
- From: Andrea Righi <righi andrea gmail com>
- To: Vivek Goyal <vgoyal redhat com>
- Cc: dhaval linux vnet ibm com, snitzer redhat com, dm-devel redhat com, dpshah google com, jens axboe oracle com, agk redhat com, balbir linux vnet ibm com, paolo valente unimore it, guijianfeng cn fujitsu com, fernando oss ntt co jp, mikew google com, jmoyer redhat com, nauman google com, m-ikeda ds jp nec com, lizf cn fujitsu com, fchecconi gmail com, s-uchida ap jp nec com, containers lists linux-foundation org, linux-kernel vger kernel org, akpm linux-foundation org
- Subject: [dm-devel] Re: [PATCH 05/18] io-controller: Common hierarchical fair queuing code in elevaotor layer
- Date: Fri, 08 May 2009 21:10:02 -0000
On Tue, May 05, 2009 at 03:58:32PM -0400, Vivek Goyal wrote:
> +#define STORE_FUNCTION(__VAR, __MIN, __MAX) \
> +static int io_cgroup_##__VAR##_write(struct cgroup *cgroup, \
> + struct cftype *cftype, \
> + u64 val) \
> +{ \
> + struct io_cgroup *iocg; \
> + struct io_group *iog; \
> + struct hlist_node *n; \
> + \
> + if (val < (__MIN) || val > (__MAX)) \
> + return -EINVAL; \
> + \
> + if (!cgroup_lock_live_group(cgroup)) \
> + return -ENODEV; \
> + \
> + iocg = cgroup_to_io_cgroup(cgroup); \
> + \
> + spin_lock_irq(&iocg->lock); \
> + iocg->__VAR = (unsigned long)val; \
> + hlist_for_each_entry(iog, n, &iocg->group_data, group_node) { \
> + iog->entity.new_##__VAR = (unsigned long)val; \
> + smp_wmb(); \
> + iog->entity.ioprio_changed = 1; \
> + } \
> + spin_unlock_irq(&iocg->lock); \
> + \
> + cgroup_unlock(); \
> + \
> + return 0; \
> +}
> +
> +STORE_FUNCTION(weight, 0, WEIGHT_MAX);
A small fix: io.weight should be strictly greater than 0 if we don't
want to automatically trigger the BUG_ON(entity->weight == 0) in
bfq_calc_finish().
Signed-off-by: Andrea Righi <righi andrea gmail com>
---
block/elevator-fq.c | 2 +-
1 files changed, 1 insertions(+), 1 deletions(-)
diff --git a/block/elevator-fq.c b/block/elevator-fq.c
index 9500619..de25f44 100644
--- a/block/elevator-fq.c
+++ b/block/elevator-fq.c
@@ -1136,7 +1136,7 @@ static int io_cgroup_##__VAR##_write(struct cgroup *cgroup, \
return 0; \
}
-STORE_FUNCTION(weight, 0, WEIGHT_MAX);
+STORE_FUNCTION(weight, 1, WEIGHT_MAX);
STORE_FUNCTION(ioprio_class, IOPRIO_CLASS_RT, IOPRIO_CLASS_IDLE);
#undef STORE_FUNCTION
[Date Prev][Date Next] [Thread Prev][Thread Next]
[Thread Index]
[Date Index]
[Author Index]