|
@@ -102,13 +102,13 @@ static void flush_tlb_func(void *info)
|
|
|
|
|
|
if (f->flush_mm != this_cpu_read(cpu_tlbstate.active_mm))
|
|
|
return;
|
|
|
+ if (!f->flush_end)
|
|
|
+ f->flush_end = f->flush_start + PAGE_SIZE;
|
|
|
|
|
|
count_vm_tlb_event(NR_TLB_REMOTE_FLUSH_RECEIVED);
|
|
|
if (this_cpu_read(cpu_tlbstate.state) == TLBSTATE_OK) {
|
|
|
if (f->flush_end == TLB_FLUSH_ALL)
|
|
|
local_flush_tlb();
|
|
|
- else if (!f->flush_end)
|
|
|
- __flush_tlb_single(f->flush_start);
|
|
|
else {
|
|
|
unsigned long addr;
|
|
|
addr = f->flush_start;
|