staging: rtl8192u: remove redundant assignment to pointer crypt
[linux/fpc-iii.git] / arch / arm64 / lib / copy_page.S
blobbbb8562396afe011add6ad6b33788ae41e6eacd2
1 /* SPDX-License-Identifier: GPL-2.0-only */
2 /*
3  * Copyright (C) 2012 ARM Ltd.
4  */
6 #include <linux/linkage.h>
7 #include <linux/const.h>
8 #include <asm/assembler.h>
9 #include <asm/page.h>
10 #include <asm/cpufeature.h>
11 #include <asm/alternative.h>
14  * Copy a page from src to dest (both are page aligned)
15  *
16  * Parameters:
17  *      x0 - dest
18  *      x1 - src
19  */
20 ENTRY(copy_page)
21 alternative_if ARM64_HAS_NO_HW_PREFETCH
22         // Prefetch three cache lines ahead.
23         prfm    pldl1strm, [x1, #128]
24         prfm    pldl1strm, [x1, #256]
25         prfm    pldl1strm, [x1, #384]
26 alternative_else_nop_endif
28         ldp     x2, x3, [x1]
29         ldp     x4, x5, [x1, #16]
30         ldp     x6, x7, [x1, #32]
31         ldp     x8, x9, [x1, #48]
32         ldp     x10, x11, [x1, #64]
33         ldp     x12, x13, [x1, #80]
34         ldp     x14, x15, [x1, #96]
35         ldp     x16, x17, [x1, #112]
37         mov     x18, #(PAGE_SIZE - 128)
38         add     x1, x1, #128
40         subs    x18, x18, #128
42 alternative_if ARM64_HAS_NO_HW_PREFETCH
43         prfm    pldl1strm, [x1, #384]
44 alternative_else_nop_endif
46         stnp    x2, x3, [x0]
47         ldp     x2, x3, [x1]
48         stnp    x4, x5, [x0, #16]
49         ldp     x4, x5, [x1, #16]
50         stnp    x6, x7, [x0, #32]
51         ldp     x6, x7, [x1, #32]
52         stnp    x8, x9, [x0, #48]
53         ldp     x8, x9, [x1, #48]
54         stnp    x10, x11, [x0, #64]
55         ldp     x10, x11, [x1, #64]
56         stnp    x12, x13, [x0, #80]
57         ldp     x12, x13, [x1, #80]
58         stnp    x14, x15, [x0, #96]
59         ldp     x14, x15, [x1, #96]
60         stnp    x16, x17, [x0, #112]
61         ldp     x16, x17, [x1, #112]
63         add     x0, x0, #128
64         add     x1, x1, #128
66         b.gt    1b
68         stnp    x2, x3, [x0]
69         stnp    x4, x5, [x0, #16]
70         stnp    x6, x7, [x0, #32]
71         stnp    x8, x9, [x0, #48]
72         stnp    x10, x11, [x0, #64]
73         stnp    x12, x13, [x0, #80]
74         stnp    x14, x15, [x0, #96]
75         stnp    x16, x17, [x0, #112]
77         ret
78 ENDPROC(copy_page)
79 EXPORT_SYMBOL(copy_page)