2008-07-30 23:06:12 +04:00
/**************************************************************************
*
* Copyright ( c ) 2006 - 2007 Tungsten Graphics , Inc . , Cedar Park , TX . , USA
* All Rights Reserved .
*
* Permission is hereby granted , free of charge , to any person obtaining a
* copy of this software and associated documentation files ( the
* " Software " ) , to deal in the Software without restriction , including
* without limitation the rights to use , copy , modify , merge , publish ,
* distribute , sub license , and / or sell copies of the Software , and to
* permit persons to whom the Software is furnished to do so , subject to
* the following conditions :
*
* The above copyright notice and this permission notice ( including the
* next paragraph ) shall be included in all copies or substantial portions
* of the Software .
*
* THE SOFTWARE IS PROVIDED " AS IS " , WITHOUT WARRANTY OF ANY KIND , EXPRESS OR
* IMPLIED , INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY ,
* FITNESS FOR A PARTICULAR PURPOSE AND NON - INFRINGEMENT . IN NO EVENT SHALL
* THE COPYRIGHT HOLDERS , AUTHORS AND / OR ITS SUPPLIERS BE LIABLE FOR ANY CLAIM ,
* DAMAGES OR OTHER LIABILITY , WHETHER IN AN ACTION OF CONTRACT , TORT OR
* OTHERWISE , ARISING FROM , OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
* USE OR OTHER DEALINGS IN THE SOFTWARE .
*
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
/*
* Authors : Thomas Hellström < thomas - at - tungstengraphics - dot - com >
*/
# include "drmP.h"
# if defined(CONFIG_X86)
static void
drm_clflush_page ( struct page * page )
{
uint8_t * page_virtual ;
unsigned int i ;
if ( unlikely ( page = = NULL ) )
return ;
page_virtual = kmap_atomic ( page , KM_USER0 ) ;
for ( i = 0 ; i < PAGE_SIZE ; i + = boot_cpu_data . x86_clflush_size )
clflush ( page_virtual + i ) ;
kunmap_atomic ( page_virtual , KM_USER0 ) ;
}
# endif
void
drm_clflush_pages ( struct page * pages [ ] , unsigned long num_pages )
{
# if defined(CONFIG_X86)
if ( cpu_has_clflush ) {
unsigned long i ;
mb ( ) ;
for ( i = 0 ; i < num_pages ; + + i )
drm_clflush_page ( * pages + + ) ;
mb ( ) ;
return ;
}
2008-10-07 07:41:49 +04:00
wbinvd ( ) ;
# endif
2008-07-30 23:06:12 +04:00
}
EXPORT_SYMBOL ( drm_clflush_pages ) ;