blob: d9f6b372b0586e4b123ac149e08d5c322481cedd [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/io-readsl.S
4 *
5 * Copyright (C) 1995-2000 Russell King
Linus Torvalds1da177e2005-04-16 15:20:36 -07006 */
7#include <linux/linkage.h>
8#include <asm/assembler.h>
9
10ENTRY(__raw_readsl)
11 teq r2, #0 @ do we have to check for the zero len?
Russell King6ebbf2c2014-06-30 16:29:12 +010012 reteq lr
Linus Torvalds1da177e2005-04-16 15:20:36 -070013 ands ip, r1, #3
14 bne 3f
15
16 subs r2, r2, #4
17 bmi 2f
18 stmfd sp!, {r4, lr}
191: ldr r3, [r0, #0]
20 ldr r4, [r0, #0]
21 ldr ip, [r0, #0]
22 ldr lr, [r0, #0]
23 subs r2, r2, #4
24 stmia r1!, {r3, r4, ip, lr}
25 bpl 1b
26 ldmfd sp!, {r4, lr}
272: movs r2, r2, lsl #31
28 ldrcs r3, [r0, #0]
29 ldrcs ip, [r0, #0]
Stefan Agnere44fc382019-02-18 00:57:38 +010030 stmiacs r1!, {r3, ip}
Linus Torvalds1da177e2005-04-16 15:20:36 -070031 ldrne r3, [r0, #0]
32 strne r3, [r1, #0]
Russell King6ebbf2c2014-06-30 16:29:12 +010033 ret lr
Linus Torvalds1da177e2005-04-16 15:20:36 -070034
353: ldr r3, [r0]
36 cmp ip, #2
37 mov ip, r3, get_byte_0
38 strb ip, [r1], #1
39 bgt 6f
40 mov ip, r3, get_byte_1
41 strb ip, [r1], #1
42 beq 5f
43 mov ip, r3, get_byte_2
44 strb ip, [r1], #1
45
464: subs r2, r2, #1
Victor Kamenskyd98b90e2014-02-25 08:41:09 +010047 mov ip, r3, lspull #24
Linus Torvalds1da177e2005-04-16 15:20:36 -070048 ldrne r3, [r0]
Victor Kamenskyd98b90e2014-02-25 08:41:09 +010049 orrne ip, ip, r3, lspush #8
Linus Torvalds1da177e2005-04-16 15:20:36 -070050 strne ip, [r1], #4
51 bne 4b
52 b 8f
53
545: subs r2, r2, #1
Victor Kamenskyd98b90e2014-02-25 08:41:09 +010055 mov ip, r3, lspull #16
Linus Torvalds1da177e2005-04-16 15:20:36 -070056 ldrne r3, [r0]
Victor Kamenskyd98b90e2014-02-25 08:41:09 +010057 orrne ip, ip, r3, lspush #16
Linus Torvalds1da177e2005-04-16 15:20:36 -070058 strne ip, [r1], #4
59 bne 5b
60 b 7f
61
626: subs r2, r2, #1
Victor Kamenskyd98b90e2014-02-25 08:41:09 +010063 mov ip, r3, lspull #8
Linus Torvalds1da177e2005-04-16 15:20:36 -070064 ldrne r3, [r0]
Victor Kamenskyd98b90e2014-02-25 08:41:09 +010065 orrne ip, ip, r3, lspush #24
Linus Torvalds1da177e2005-04-16 15:20:36 -070066 strne ip, [r1], #4
67 bne 6b
68
69 mov r3, ip, get_byte_2
70 strb r3, [r1, #2]
717: mov r3, ip, get_byte_1
72 strb r3, [r1, #1]
738: mov r3, ip, get_byte_0
74 strb r3, [r1, #0]
Russell King6ebbf2c2014-06-30 16:29:12 +010075 ret lr
Catalin Marinas93ed3972008-08-28 11:22:32 +010076ENDPROC(__raw_readsl)