Skip to content

Commit

Permalink
[IA64] Untangle sync_icache_dcache() page size determination
Browse files Browse the repository at this point in the history
Untangle the chaos of page size determination in this function by
simply using PAGE_SIZE << compound_order().

Signed-off-by: Christoph Lameter <clameter@sgi.com>
Signed-off-by: Tony Luck <tony.luck@intel.com>
  • Loading branch information
Christoph Lameter authored and Tony Luck committed Apr 9, 2008
1 parent 5cf1f7c commit 273988f
Showing 1 changed file with 1 addition and 7 deletions.
8 changes: 1 addition & 7 deletions arch/ia64/mm/init.c
Original file line number Diff line number Diff line change
Expand Up @@ -58,20 +58,14 @@ __ia64_sync_icache_dcache (pte_t pte)
{
unsigned long addr;
struct page *page;
unsigned long order;

page = pte_page(pte);
addr = (unsigned long) page_address(page);

if (test_bit(PG_arch_1, &page->flags))
return; /* i-cache is already coherent with d-cache */

if (PageCompound(page)) {
order = compound_order(page);
flush_icache_range(addr, addr + (1UL << order << PAGE_SHIFT));
}
else
flush_icache_range(addr, addr + PAGE_SIZE);
flush_icache_range(addr, addr + (PAGE_SIZE << compound_order(page)));
set_bit(PG_arch_1, &page->flags); /* mark page as clean */
}

Expand Down

0 comments on commit 273988f

Please sign in to comment.