Commit dba6bb60 authored by Heiko Carstens's avatar Heiko Carstens Committed by Martin Schwidefsky

s390/mm: optimize copy_page

Always use the mvcl instruction to copy a page instead of mvpg or a
couple of mvc instructions.
Copying a huge page is 25% faster this way. Also bypass caches when
copying pages since only parts of a page will be used afterwards.
Especially when copying a huge page this would kick everything out
of the L1 and L2 data caches on a zEC12 machine.
Signed-off-by: default avatarHeiko Carstens <heiko.carstens@de.ibm.com>
parent 26a35f37
...@@ -48,33 +48,21 @@ static inline void clear_page(void *page) ...@@ -48,33 +48,21 @@ static inline void clear_page(void *page)
: "memory", "cc"); : "memory", "cc");
} }
/*
* copy_page uses the mvcl instruction with 0xb0 padding byte in order to
* bypass caches when copying a page. Especially when copying huge pages
* this keeps L1 and L2 data caches alive.
*/
static inline void copy_page(void *to, void *from) static inline void copy_page(void *to, void *from)
{ {
if (MACHINE_HAS_MVPG) { register void *reg2 asm ("2") = to;
register unsigned long reg0 asm ("0") = 0; register unsigned long reg3 asm ("3") = 0x1000;
asm volatile( register void *reg4 asm ("4") = from;
" mvpg %0,%1" register unsigned long reg5 asm ("5") = 0xb0001000;
: : "a" (to), "a" (from), "d" (reg0)
: "memory", "cc");
} else
asm volatile( asm volatile(
" mvc 0(256,%0),0(%1)\n" " mvcl 2,4"
" mvc 256(256,%0),256(%1)\n" : "+d" (reg2), "+d" (reg3), "+d" (reg4), "+d" (reg5)
" mvc 512(256,%0),512(%1)\n" : : "memory", "cc");
" mvc 768(256,%0),768(%1)\n"
" mvc 1024(256,%0),1024(%1)\n"
" mvc 1280(256,%0),1280(%1)\n"
" mvc 1536(256,%0),1536(%1)\n"
" mvc 1792(256,%0),1792(%1)\n"
" mvc 2048(256,%0),2048(%1)\n"
" mvc 2304(256,%0),2304(%1)\n"
" mvc 2560(256,%0),2560(%1)\n"
" mvc 2816(256,%0),2816(%1)\n"
" mvc 3072(256,%0),3072(%1)\n"
" mvc 3328(256,%0),3328(%1)\n"
" mvc 3584(256,%0),3584(%1)\n"
" mvc 3840(256,%0),3840(%1)\n"
: : "a" (to), "a" (from) : "memory");
} }
#define clear_user_page(page, vaddr, pg) clear_page(page) #define clear_user_page(page, vaddr, pg) clear_page(page)
......
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