summaryrefslogtreecommitdiff
path: root/block
diff options
context:
space:
mode:
authorJens Axboe <jens.axboe@oracle.com>2009-09-11 22:44:29 +0200
committerGreg Kroah-Hartman <gregkh@suse.de>2009-09-24 08:43:57 -0700
commitc1bb36016b09cf5c4b207f470cb116548f5152e0 (patch)
tree79220106f01b7ef89acbb91545e15a2c51ed20ce /block
parent80c8fadd31216328720d74ae19c89156ecc00f99 (diff)
downloadlwn-c1bb36016b09cf5c4b207f470cb116548f5152e0.tar.gz
lwn-c1bb36016b09cf5c4b207f470cb116548f5152e0.zip
block: don't assume device has a request list backing in nr_requests store
commit b8a9ae779f2c7049071034661e09cb7e1e82250c upstream. Stacked devices do not. For now, just error out with -EINVAL. Later we could make the limit apply on stacked devices too, for throttling reasons. This fixes 5a54cd13353bb3b88887604e2c980aa01e314309 and should go into 2.6.31 stable as well. Signed-off-by: Jens Axboe <jens.axboe@oracle.com> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'block')
-rw-r--r--block/blk-sysfs.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/block/blk-sysfs.c b/block/blk-sysfs.c
index d3aa2aadb3e0..b78c9c3e2670 100644
--- a/block/blk-sysfs.c
+++ b/block/blk-sysfs.c
@@ -40,7 +40,12 @@ queue_requests_store(struct request_queue *q, const char *page, size_t count)
{
struct request_list *rl = &q->rq;
unsigned long nr;
- int ret = queue_var_store(&nr, page, count);
+ int ret;
+
+ if (!q->request_fn)
+ return -EINVAL;
+
+ ret = queue_var_store(&nr, page, count);
if (nr < BLKDEV_MIN_RQ)
nr = BLKDEV_MIN_RQ;