Commit 34403fcc authored by Seth Rohit's avatar Seth Rohit Committed by David Mosberger

[PATCH] ia64: patch to use >256MB purges

Attached is the updated patch that takes the supported purge page size
bits from PAL call.
parent 57ed1dbf
...@@ -22,17 +22,8 @@ ...@@ -22,17 +22,8 @@
#include <asm/pal.h> #include <asm/pal.h>
#include <asm/tlbflush.h> #include <asm/tlbflush.h>
#define SUPPORTED_PGBITS ( \ static unsigned long purge_pgbits;
1 << _PAGE_SIZE_256M | \ static unsigned long max_purge_size;
1 << _PAGE_SIZE_64M | \
1 << _PAGE_SIZE_16M | \
1 << _PAGE_SIZE_4M | \
1 << _PAGE_SIZE_1M | \
1 << _PAGE_SIZE_256K | \
1 << _PAGE_SIZE_64K | \
1 << _PAGE_SIZE_16K | \
1 << _PAGE_SIZE_8K | \
1 << _PAGE_SIZE_4K )
struct ia64_ctx ia64_ctx = { struct ia64_ctx ia64_ctx = {
.lock = SPIN_LOCK_UNLOCKED, .lock = SPIN_LOCK_UNLOCKED,
...@@ -154,22 +145,10 @@ flush_tlb_range (struct vm_area_struct *vma, unsigned long start, unsigned long ...@@ -154,22 +145,10 @@ flush_tlb_range (struct vm_area_struct *vma, unsigned long start, unsigned long
} }
nbits = ia64_fls(size + 0xfff); nbits = ia64_fls(size + 0xfff);
if (((1UL << nbits) & SUPPORTED_PGBITS) == 0) { while ((((1UL << nbits) & purge_pgbits) == 0) && (nbits < max_purge_size))
if (nbits > _PAGE_SIZE_256M)
nbits = _PAGE_SIZE_256M;
else
/*
* Some page sizes are not implemented in the
* IA-64 arch, so if we get asked to clear an
* unsupported page size, round up to the
* nearest page size. Note that we depend on
* the fact that if page size N is not
* implemented, 2*N _is_ implemented.
*/
++nbits; ++nbits;
if (((1UL << nbits) & SUPPORTED_PGBITS) == 0) if (nbits > max_purge_size)
panic("flush_tlb_range: BUG: nbits=%lu\n", nbits); nbits = max_purge_size;
}
start &= ~((1UL << nbits) - 1); start &= ~((1UL << nbits) - 1);
# ifdef CONFIG_SMP # ifdef CONFIG_SMP
...@@ -190,6 +169,12 @@ void __init ...@@ -190,6 +169,12 @@ void __init
ia64_tlb_init (void) ia64_tlb_init (void)
{ {
ia64_ptce_info_t ptce_info; ia64_ptce_info_t ptce_info;
unsigned long tr_pgbits;
long status;
if ((status = ia64_pal_vm_page_size(&tr_pgbits, &purge_pgbits)) !=0)
panic("ia64_pal_vm_page_size=%ld\n", status);
max_purge_size = ia64_fls(purge_pgbits);
ia64_get_ptce(&ptce_info); ia64_get_ptce(&ptce_info);
local_cpu_data->ptce_base = ptce_info.base; local_cpu_data->ptce_base = ptce_info.base;
......
...@@ -75,6 +75,8 @@ ...@@ -75,6 +75,8 @@
#define _PAGE_SIZE_16M 24 #define _PAGE_SIZE_16M 24
#define _PAGE_SIZE_64M 26 #define _PAGE_SIZE_64M 26
#define _PAGE_SIZE_256M 28 #define _PAGE_SIZE_256M 28
#define _PAGE_SIZE_1G 30
#define _PAGE_SIZE_4G 32
#define __ACCESS_BITS _PAGE_ED | _PAGE_A | _PAGE_P | _PAGE_MA_WB #define __ACCESS_BITS _PAGE_ED | _PAGE_A | _PAGE_P | _PAGE_MA_WB
#define __DIRTY_BITS_NO_ED _PAGE_A | _PAGE_P | _PAGE_D | _PAGE_MA_WB #define __DIRTY_BITS_NO_ED _PAGE_A | _PAGE_P | _PAGE_D | _PAGE_MA_WB
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment