From d2420e00f7092ffe9aaa2c9a77c65fc1c1360940 Mon Sep 17 00:00:00 2001 From: Jeff Dike Date: Sun, 6 May 2007 14:51:49 -0700 Subject: [PATCH] --- yaml --- r: 54330 b: refs/heads/master c: 1e7371c1a11f041d641cc0ff113bf1daa1bd98b9 h: refs/heads/master v: v3 --- [refs] | 2 +- trunk/arch/um/kernel/skas/tlb.c | 9 +++++++-- 2 files changed, 8 insertions(+), 3 deletions(-) diff --git a/[refs] b/[refs] index 1a577af4a7da..adba2786be42 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 16dd07bc6404c8da0bdfeb7a5cde4e4a63991c00 +refs/heads/master: 1e7371c1a11f041d641cc0ff113bf1daa1bd98b9 diff --git a/trunk/arch/um/kernel/skas/tlb.c b/trunk/arch/um/kernel/skas/tlb.c index b3d722ddde31..c0f0693743ba 100644 --- a/trunk/arch/um/kernel/skas/tlb.c +++ b/trunk/arch/um/kernel/skas/tlb.c @@ -89,8 +89,13 @@ void flush_tlb_mm_skas(struct mm_struct *mm) void force_flush_all_skas(void) { - unsigned long end = proc_mm ? task_size : CONFIG_STUB_START; - fix_range(current->mm, 0, end, 1); + struct mm_struct *mm = current->mm; + struct vm_area_struct *vma = mm->mmap; + + while(vma != NULL) { + fix_range(mm, vma->vm_start, vma->vm_end, 1); + vma = vma->vm_next; + } } void flush_tlb_page_skas(struct vm_area_struct *vma, unsigned long address)