blob: 09a333153dc66409e4cbf81cb657253fa24fb428 [file] [log] [blame]
Thomas Gleixnerd2912cb2019-06-04 10:11:33 +02001/* SPDX-License-Identifier: GPL-2.0-only */
Linus Torvalds1da177e2005-04-16 15:20:36 -07002/*
3 * linux/arch/arm/lib/memcpy.S
4 *
Nicolas Pitre75494232005-11-01 19:52:23 +00005 * Author: Nicolas Pitre
6 * Created: Sep 28, 2005
7 * Copyright: MontaVista Software, Inc.
Linus Torvalds1da177e2005-04-16 15:20:36 -07008 */
Nicolas Pitre75494232005-11-01 19:52:23 +00009
Linus Torvalds1da177e2005-04-16 15:20:36 -070010#include <linux/linkage.h>
11#include <asm/assembler.h>
Lin Yongting279f4872014-11-26 14:38:33 +010012#include <asm/unwind.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070013
Catalin Marinas8b592782009-07-24 12:32:57 +010014#define LDR1W_SHIFT 0
15#define STR1W_SHIFT 0
16
Nicolas Pitre75494232005-11-01 19:52:23 +000017 .macro ldr1w ptr reg abort
Catalin Marinas8b592782009-07-24 12:32:57 +010018 W(ldr) \reg, [\ptr], #4
Nicolas Pitre75494232005-11-01 19:52:23 +000019 .endm
Linus Torvalds1da177e2005-04-16 15:20:36 -070020
Nicolas Pitre75494232005-11-01 19:52:23 +000021 .macro ldr4w ptr reg1 reg2 reg3 reg4 abort
22 ldmia \ptr!, {\reg1, \reg2, \reg3, \reg4}
23 .endm
Linus Torvalds1da177e2005-04-16 15:20:36 -070024
Nicolas Pitre75494232005-11-01 19:52:23 +000025 .macro ldr8w ptr reg1 reg2 reg3 reg4 reg5 reg6 reg7 reg8 abort
26 ldmia \ptr!, {\reg1, \reg2, \reg3, \reg4, \reg5, \reg6, \reg7, \reg8}
27 .endm
Linus Torvalds1da177e2005-04-16 15:20:36 -070028
Nicolas Pitre75494232005-11-01 19:52:23 +000029 .macro ldr1b ptr reg cond=al abort
Stefan Agnera2163762019-02-18 00:54:36 +010030 ldrb\cond \reg, [\ptr], #1
Nicolas Pitre75494232005-11-01 19:52:23 +000031 .endm
Linus Torvalds1da177e2005-04-16 15:20:36 -070032
Nicolas Pitre75494232005-11-01 19:52:23 +000033 .macro str1w ptr reg abort
Catalin Marinas8b592782009-07-24 12:32:57 +010034 W(str) \reg, [\ptr], #4
Nicolas Pitre75494232005-11-01 19:52:23 +000035 .endm
36
37 .macro str8w ptr reg1 reg2 reg3 reg4 reg5 reg6 reg7 reg8 abort
38 stmia \ptr!, {\reg1, \reg2, \reg3, \reg4, \reg5, \reg6, \reg7, \reg8}
39 .endm
40
41 .macro str1b ptr reg cond=al abort
Stefan Agnera2163762019-02-18 00:54:36 +010042 strb\cond \reg, [\ptr], #1
Nicolas Pitre75494232005-11-01 19:52:23 +000043 .endm
44
45 .macro enter reg1 reg2
46 stmdb sp!, {r0, \reg1, \reg2}
47 .endm
48
Lin Yongting279f4872014-11-26 14:38:33 +010049 .macro usave reg1 reg2
50 UNWIND( .save {r0, \reg1, \reg2} )
51 .endm
52
Nicolas Pitre75494232005-11-01 19:52:23 +000053 .macro exit reg1 reg2
54 ldmfd sp!, {r0, \reg1, \reg2}
55 .endm
56
57 .text
58
59/* Prototype: void *memcpy(void *dest, const void *src, size_t n); */
60
Russell King1bd46782015-07-03 15:22:54 +010061ENTRY(mmiocpy)
Linus Torvalds1da177e2005-04-16 15:20:36 -070062ENTRY(memcpy)
Linus Torvalds1da177e2005-04-16 15:20:36 -070063
Nicolas Pitre75494232005-11-01 19:52:23 +000064#include "copy_template.S"
Linus Torvalds1da177e2005-04-16 15:20:36 -070065
Catalin Marinas93ed3972008-08-28 11:22:32 +010066ENDPROC(memcpy)
Russell King1bd46782015-07-03 15:22:54 +010067ENDPROC(mmiocpy)