mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-15 09:34:17 +00:00
powerpc: Simplify 4k/64k copy_page logic
To make it easier to add optimised versions of copy_page, remove the 4kB loop for 64kB pages and just do all the work in copy_page. Signed-off-by: Anton Blanchard <anton@samba.org> Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
This commit is contained in:
parent
37e0c21e9b
commit
d988f0e3f8
@ -59,24 +59,7 @@ static __inline__ void clear_page(void *addr)
|
|||||||
: "ctr", "memory");
|
: "ctr", "memory");
|
||||||
}
|
}
|
||||||
|
|
||||||
extern void copy_4K_page(void *to, void *from);
|
extern void copy_page(void *to, void *from);
|
||||||
|
|
||||||
#ifdef CONFIG_PPC_64K_PAGES
|
|
||||||
static inline void copy_page(void *to, void *from)
|
|
||||||
{
|
|
||||||
unsigned int i;
|
|
||||||
for (i=0; i < (1 << (PAGE_SHIFT - 12)); i++) {
|
|
||||||
copy_4K_page(to, from);
|
|
||||||
to += 4096;
|
|
||||||
from += 4096;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#else /* CONFIG_PPC_64K_PAGES */
|
|
||||||
static inline void copy_page(void *to, void *from)
|
|
||||||
{
|
|
||||||
copy_4K_page(to, from);
|
|
||||||
}
|
|
||||||
#endif /* CONFIG_PPC_64K_PAGES */
|
|
||||||
|
|
||||||
/* Log 2 of page table size */
|
/* Log 2 of page table size */
|
||||||
extern u64 ppc64_pft_size;
|
extern u64 ppc64_pft_size;
|
||||||
|
@ -54,7 +54,6 @@ extern void single_step_exception(struct pt_regs *regs);
|
|||||||
extern int sys_sigreturn(struct pt_regs *regs);
|
extern int sys_sigreturn(struct pt_regs *regs);
|
||||||
|
|
||||||
EXPORT_SYMBOL(clear_pages);
|
EXPORT_SYMBOL(clear_pages);
|
||||||
EXPORT_SYMBOL(copy_page);
|
|
||||||
EXPORT_SYMBOL(ISA_DMA_THRESHOLD);
|
EXPORT_SYMBOL(ISA_DMA_THRESHOLD);
|
||||||
EXPORT_SYMBOL(DMA_MODE_READ);
|
EXPORT_SYMBOL(DMA_MODE_READ);
|
||||||
EXPORT_SYMBOL(DMA_MODE_WRITE);
|
EXPORT_SYMBOL(DMA_MODE_WRITE);
|
||||||
@ -88,9 +87,7 @@ EXPORT_SYMBOL(__copy_tofrom_user);
|
|||||||
EXPORT_SYMBOL(__clear_user);
|
EXPORT_SYMBOL(__clear_user);
|
||||||
EXPORT_SYMBOL(__strncpy_from_user);
|
EXPORT_SYMBOL(__strncpy_from_user);
|
||||||
EXPORT_SYMBOL(__strnlen_user);
|
EXPORT_SYMBOL(__strnlen_user);
|
||||||
#ifdef CONFIG_PPC64
|
EXPORT_SYMBOL(copy_page);
|
||||||
EXPORT_SYMBOL(copy_4K_page);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(CONFIG_PCI) && defined(CONFIG_PPC32)
|
#if defined(CONFIG_PCI) && defined(CONFIG_PPC32)
|
||||||
EXPORT_SYMBOL(isa_io_base);
|
EXPORT_SYMBOL(isa_io_base);
|
||||||
|
@ -6,6 +6,7 @@
|
|||||||
* as published by the Free Software Foundation; either version
|
* as published by the Free Software Foundation; either version
|
||||||
* 2 of the License, or (at your option) any later version.
|
* 2 of the License, or (at your option) any later version.
|
||||||
*/
|
*/
|
||||||
|
#include <asm/page.h>
|
||||||
#include <asm/processor.h>
|
#include <asm/processor.h>
|
||||||
#include <asm/ppc_asm.h>
|
#include <asm/ppc_asm.h>
|
||||||
#include <asm/asm-offsets.h>
|
#include <asm/asm-offsets.h>
|
||||||
@ -15,9 +16,9 @@ PPC64_CACHES:
|
|||||||
.tc ppc64_caches[TC],ppc64_caches
|
.tc ppc64_caches[TC],ppc64_caches
|
||||||
.section ".text"
|
.section ".text"
|
||||||
|
|
||||||
|
_GLOBAL(copy_page)
|
||||||
_GLOBAL(copy_4K_page)
|
lis r5,PAGE_SIZE@h
|
||||||
li r5,4096 /* 4K page size */
|
ori r5,r5,PAGE_SIZE@l
|
||||||
BEGIN_FTR_SECTION
|
BEGIN_FTR_SECTION
|
||||||
ld r10,PPC64_CACHES@toc(r2)
|
ld r10,PPC64_CACHES@toc(r2)
|
||||||
lwz r11,DCACHEL1LOGLINESIZE(r10) /* log2 of cache line size */
|
lwz r11,DCACHEL1LOGLINESIZE(r10) /* log2 of cache line size */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user