[14/17] Allow bit_waitqueue to wait on a bit in a vmalloc area

From: Christoph Lameter
Date: Tue Sep 18 2007 - 23:40:47 EST


If bit waitqueue is passed a virtual address then it must use
vmalloc_to_page instead of virt_to_page to get to the page struct.

Signed-off-by: Christoph Lameter <clameter@xxxxxxx>

---
kernel/wait.c | 10 +++++++++-
1 file changed, 9 insertions(+), 1 deletion(-)

Index: linux-2.6/kernel/wait.c
===================================================================
--- linux-2.6.orig/kernel/wait.c 2007-09-18 19:19:27.000000000 -0700
+++ linux-2.6/kernel/wait.c 2007-09-18 20:10:39.000000000 -0700
@@ -9,6 +9,7 @@
#include <linux/mm.h>
#include <linux/wait.h>
#include <linux/hash.h>
+#include <linux/vmalloc.h>

void init_waitqueue_head(wait_queue_head_t *q)
{
@@ -245,9 +246,16 @@ EXPORT_SYMBOL(wake_up_bit);
fastcall wait_queue_head_t *bit_waitqueue(void *word, int bit)
{
const int shift = BITS_PER_LONG == 32 ? 5 : 6;
- const struct zone *zone = page_zone(virt_to_page(word));
unsigned long val = (unsigned long)word << shift | bit;
+ struct page *page;
+ struct zone *zone;

+ if (is_vmalloc_addr(word))
+ page = vmalloc_to_page(word)
+ else
+ page = virt_to_page(word);
+
+ zone = page_zone(page);
return &zone->wait_table[hash_long(val, zone->wait_table_bits)];
}
EXPORT_SYMBOL(bit_waitqueue);

--
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/