2005-04-16 15:20:36 -07:00
/* cache-page.c: whole-page cache wrangling functions for MMU linux
*
* Copyright ( C ) 2004 Red Hat , Inc . All Rights Reserved .
* Written by David Howells ( dhowells @ redhat . com )
*
* This program is free software ; you can redistribute it and / or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation ; either version
* 2 of the License , or ( at your option ) any later version .
*/
# include <linux/sched.h>
# include <linux/mm.h>
# include <linux/highmem.h>
2006-01-08 01:01:19 -08:00
# include <linux/module.h>
2005-04-16 15:20:36 -07:00
# include <asm/pgalloc.h>
/*****************************************************************************/
/*
* DCF takes a virtual address and the page may not currently have one
* - temporarily hijack a kmap_atomic ( ) slot and attach the page to it
*/
void flush_dcache_page ( struct page * page )
{
unsigned long dampr2 ;
void * vaddr ;
dampr2 = __get_DAMPR ( 2 ) ;
2012-06-27 13:02:49 +08:00
vaddr = kmap_atomic_primary ( page ) ;
2005-04-16 15:20:36 -07:00
frv_dcache_writeback ( ( unsigned long ) vaddr , ( unsigned long ) vaddr + PAGE_SIZE ) ;
2012-06-27 13:02:49 +08:00
kunmap_atomic_primary ( vaddr ) ;
2005-04-16 15:20:36 -07:00
if ( dampr2 ) {
__set_DAMPR ( 2 , dampr2 ) ;
__set_IAMPR ( 2 , dampr2 ) ;
}
} /* end flush_dcache_page() */
2006-01-08 01:01:19 -08:00
EXPORT_SYMBOL ( flush_dcache_page ) ;
2005-04-16 15:20:36 -07:00
/*****************************************************************************/
/*
* ICI takes a virtual address and the page may not currently have one
* - so we temporarily attach the page to a bit of virtual space so that is can be flushed
*/
void flush_icache_user_range ( struct vm_area_struct * vma , struct page * page ,
unsigned long start , unsigned long len )
{
unsigned long dampr2 ;
void * vaddr ;
dampr2 = __get_DAMPR ( 2 ) ;
2012-06-27 13:02:49 +08:00
vaddr = kmap_atomic_primary ( page ) ;
2005-04-16 15:20:36 -07:00
start = ( start & ~ PAGE_MASK ) | ( unsigned long ) vaddr ;
frv_cache_wback_inv ( start , start + len ) ;
2012-06-27 13:02:49 +08:00
kunmap_atomic_primary ( vaddr ) ;
2005-04-16 15:20:36 -07:00
if ( dampr2 ) {
__set_DAMPR ( 2 , dampr2 ) ;
__set_IAMPR ( 2 , dampr2 ) ;
}
} /* end flush_icache_user_range() */
2006-01-08 01:01:19 -08:00
EXPORT_SYMBOL ( flush_icache_user_range ) ;