diff options
author | Arnd Bergmann <arnd@arndb.de> | 2022-04-04 23:38:28 +0200 |
---|---|---|
committer | Arnd Bergmann <arnd@arndb.de> | 2022-05-07 22:56:16 +0200 |
commit | c8a91428941b912d66e13a2719fe6ac670150d69 (patch) | |
tree | 38a521a793f0676277f43f23937b5fe785d07dea /arch | |
parent | ARM: pxa: move plat-pxa to drivers/soc/ (diff) | |
download | linux-c8a91428941b912d66e13a2719fe6ac670150d69.tar.xz linux-c8a91428941b912d66e13a2719fe6ac670150d69.zip |
ARM: PXA: fix multi-cpu build of xsc3
On a kernel that includes both ARMv4 and XScale support,
the copypage function fails to build with invalid
instructions.
Since these are only called on an actual XScale processor,
annotate the assembly with the correct .arch directive.
Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Diffstat (limited to 'arch')
-rw-r--r-- | arch/arm/mm/copypage-xsc3.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/arch/arm/mm/copypage-xsc3.c b/arch/arm/mm/copypage-xsc3.c index 6f0909dda2f9..c86e79677ff9 100644 --- a/arch/arm/mm/copypage-xsc3.c +++ b/arch/arm/mm/copypage-xsc3.c @@ -29,6 +29,7 @@ static void xsc3_mc_copy_user_page(void *kto, const void *kfrom) int tmp; asm volatile ("\ +.arch xscale \n\ pld [%1, #0] \n\ pld [%1, #32] \n\ 1: pld [%1, #64] \n\ @@ -80,6 +81,7 @@ void xsc3_mc_clear_user_highpage(struct page *page, unsigned long vaddr) { void *ptr, *kaddr = kmap_atomic(page); asm volatile ("\ +.arch xscale \n\ mov r1, %2 \n\ mov r2, #0 \n\ mov r3, #0 \n\ |