diff options
author | Benjamin Herrenschmidt <benh@kernel.crashing.org> | 2005-09-19 23:52:50 -0400 |
---|---|---|
committer | Paul Mackerras <paulus@samba.org> | 2005-09-21 05:21:07 -0400 |
commit | 61b1a94254a2158d053458764a5bd30331d73a54 (patch) | |
tree | 4a2aa56ae5d3182c1015b5e9a4351aeb8fab2f3a /arch/ppc64/kernel/pSeries_lpar.c | |
parent | 637a6ff6ce525d8495df944550efea0f023dd521 (diff) |
[PATCH] ppc64: Store virtual address in TLB flush batches
This patch slightly change the TLB flush batch mecanism so that we
store the full vaddr (including vsid) when adding an entry to the
batch so that the flush part doesn't have to get to the context.
This cleans it a bit, and paves the way to future updates like
dynamic vsids.
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Signed-off-by: Paul Mackerras <paulus@samba.org>
Diffstat (limited to 'arch/ppc64/kernel/pSeries_lpar.c')
-rw-r--r-- | arch/ppc64/kernel/pSeries_lpar.c | 5 |
1 files changed, 2 insertions, 3 deletions
diff --git a/arch/ppc64/kernel/pSeries_lpar.c b/arch/ppc64/kernel/pSeries_lpar.c index a6de83f2078f..268d8362dde7 100644 --- a/arch/ppc64/kernel/pSeries_lpar.c +++ b/arch/ppc64/kernel/pSeries_lpar.c | |||
@@ -486,8 +486,7 @@ static void pSeries_lpar_hpte_invalidate(unsigned long slot, unsigned long va, | |||
486 | * Take a spinlock around flushes to avoid bouncing the hypervisor tlbie | 486 | * Take a spinlock around flushes to avoid bouncing the hypervisor tlbie |
487 | * lock. | 487 | * lock. |
488 | */ | 488 | */ |
489 | void pSeries_lpar_flush_hash_range(unsigned long context, unsigned long number, | 489 | void pSeries_lpar_flush_hash_range(unsigned long number, int local) |
490 | int local) | ||
491 | { | 490 | { |
492 | int i; | 491 | int i; |
493 | unsigned long flags = 0; | 492 | unsigned long flags = 0; |
@@ -498,7 +497,7 @@ void pSeries_lpar_flush_hash_range(unsigned long context, unsigned long number, | |||
498 | spin_lock_irqsave(&pSeries_lpar_tlbie_lock, flags); | 497 | spin_lock_irqsave(&pSeries_lpar_tlbie_lock, flags); |
499 | 498 | ||
500 | for (i = 0; i < number; i++) | 499 | for (i = 0; i < number; i++) |
501 | flush_hash_page(context, batch->addr[i], batch->pte[i], local); | 500 | flush_hash_page(batch->vaddr[i], batch->pte[i], local); |
502 | 501 | ||
503 | if (lock_tlbie) | 502 | if (lock_tlbie) |
504 | spin_unlock_irqrestore(&pSeries_lpar_tlbie_lock, flags); | 503 | spin_unlock_irqrestore(&pSeries_lpar_tlbie_lock, flags); |