73 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			73 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/*
 | 
						|
 * arch/xtensa/mm/pgtable.c
 | 
						|
 *
 | 
						|
 * This file is subject to the terms and conditions of the GNU General Public
 | 
						|
 * License.  See the file "COPYING" in the main directory of this archive
 | 
						|
 * for more details.
 | 
						|
 *
 | 
						|
 * Copyright (C) 2001 - 2005 Tensilica Inc.
 | 
						|
 *
 | 
						|
 * Chris Zankel <chris@zankel.net>
 | 
						|
 */
 | 
						|
 | 
						|
#if (DCACHE_SIZE > PAGE_SIZE)
 | 
						|
 | 
						|
pte_t* pte_alloc_one_kernel(struct mm_struct *mm, unsigned long address)
 | 
						|
{
 | 
						|
	pte_t *pte = NULL, *p;
 | 
						|
	int color = ADDR_COLOR(address);
 | 
						|
	int i;
 | 
						|
 | 
						|
	p = (pte_t*) __get_free_pages(GFP_KERNEL|__GFP_REPEAT, COLOR_ORDER);
 | 
						|
 | 
						|
	if (likely(p)) {
 | 
						|
		split_page(virt_to_page(p), COLOR_ORDER);
 | 
						|
 | 
						|
		for (i = 0; i < COLOR_SIZE; i++) {
 | 
						|
			if (ADDR_COLOR(p) == color)
 | 
						|
				pte = p;
 | 
						|
			else
 | 
						|
				free_page(p);
 | 
						|
			p += PTRS_PER_PTE;
 | 
						|
		}
 | 
						|
		clear_page(pte);
 | 
						|
	}
 | 
						|
	return pte;
 | 
						|
}
 | 
						|
 | 
						|
#ifdef PROFILING
 | 
						|
 | 
						|
int mask;
 | 
						|
int hit;
 | 
						|
int flush;
 | 
						|
 | 
						|
#endif
 | 
						|
 | 
						|
struct page* pte_alloc_one(struct mm_struct *mm, unsigned long address)
 | 
						|
{
 | 
						|
	struct page *page = NULL, *p;
 | 
						|
	int color = ADDR_COLOR(address);
 | 
						|
 | 
						|
	p = alloc_pages(GFP_KERNEL | __GFP_REPEAT, PTE_ORDER);
 | 
						|
 | 
						|
	if (likely(p)) {
 | 
						|
		split_page(p, COLOR_ORDER);
 | 
						|
 | 
						|
		for (i = 0; i < PAGE_ORDER; i++) {
 | 
						|
			if (PADDR_COLOR(page_address(p)) == color)
 | 
						|
				page = p;
 | 
						|
			else
 | 
						|
				__free_page(p);
 | 
						|
			p++;
 | 
						|
		}
 | 
						|
		clear_highpage(page);
 | 
						|
	}
 | 
						|
 | 
						|
	return page;
 | 
						|
}
 | 
						|
 | 
						|
#endif
 | 
						|
 | 
						|
 | 
						|
 |