From: Al Viro Date: Tue, 14 Mar 2006 20:32:50 +0000 (-0500) Subject: [PATCH] fix cfq hash lookups X-Git-Tag: v2.6.17-rc1~1187^2~15 X-Git-Url: http://pilppa.com/gitweb/?a=commitdiff_plain;h=b0a6916bcc48f46996d54b8451591a2f2b7b2f64;p=linux-2.6-omap-h63xx.git [PATCH] fix cfq hash lookups If somebody does a hash lookup for cfq_queue while ioprio of an async queue is elevated, they shouldn't end up stuck with lowered ioprio when we go back. Fix is to use ->org_ioprio{,class} in hash lookups. Signed-off-by: Al Viro --- diff --git a/block/cfq-iosched.c b/block/cfq-iosched.c index c8dbe38c81c..37a2a772498 100644 --- a/block/cfq-iosched.c +++ b/block/cfq-iosched.c @@ -1179,7 +1179,7 @@ __cfq_find_cfq_hash(struct cfq_data *cfqd, unsigned int key, unsigned int prio, hlist_for_each_safe(entry, next, hash_list) { struct cfq_queue *__cfqq = list_entry_qhash(entry); - const unsigned short __p = IOPRIO_PRIO_VALUE(__cfqq->ioprio_class, __cfqq->ioprio); + const unsigned short __p = IOPRIO_PRIO_VALUE(__cfqq->org_ioprio_class, __cfqq->org_ioprio); if (__cfqq->key == key && (__p == prio || prio == CFQ_KEY_ANY)) return __cfqq;