mail archive of the barebox mailing list
 help / color / mirror / Atom feed
From: Ahmad Fatoum <a.fatoum@pengutronix.de>
To: Sascha Hauer <s.hauer@pengutronix.de>,
	"open list:BAREBOX" <barebox@lists.infradead.org>
Subject: Re: [PATCH 06/10] ARM: update io-* from Linux
Date: Wed, 25 Sep 2024 18:04:57 +0200	[thread overview]
Message-ID: <6f3e816e-44aa-4bd6-bce9-0b008c018968@pengutronix.de> (raw)
In-Reply-To: <20240925-arm-assembly-memmove-v1-6-0d92103658a0@pengutronix.de>

On 25.09.24 15:55, Sascha Hauer wrote:
> This updates io-readsb.S, io-readsl.S, io-readsw-armv4.S, io-writesb.S,
> io-writesl.S and io-writesw-armv4.S from Linux.

Likewise, please add version.

> 
> Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>

Reviewed-by: Ahmad Fatoum <a.fatoum@pengutronix.de>

> ---
>  arch/arm/lib32/io-readsb.S        | 28 +++++++++++++++-------------
>  arch/arm/lib32/io-readsl.S        | 16 +++++++++-------
>  arch/arm/lib32/io-readsw-armv4.S  | 22 ++++++++++++----------
>  arch/arm/lib32/io-writesb.S       | 30 ++++++++++++++++--------------
>  arch/arm/lib32/io-writesl.S       | 20 +++++++++++---------
>  arch/arm/lib32/io-writesw-armv4.S | 18 ++++++++++--------
>  6 files changed, 73 insertions(+), 61 deletions(-)
> 
> diff --git a/arch/arm/lib32/io-readsb.S b/arch/arm/lib32/io-readsb.S
> index 41f68092c5..2777a49b22 100644
> --- a/arch/arm/lib32/io-readsb.S
> +++ b/arch/arm/lib32/io-readsb.S
> @@ -1,12 +1,14 @@
>  /* SPDX-License-Identifier: GPL-2.0-only */
> -/* SPDX-FileCopyrightText: 1995-2000 Russell King */
> -
>  /*
>   *  linux/arch/arm/lib/io-readsb.S
> + *
> + *  Copyright (C) 1995-2000 Russell King
>   */
>  #include <linux/linkage.h>
>  #include <asm/assembler.h>
>  
> +.syntax unified
> +
>  .section .text.__raw_readsb
>  
>  .Linsb_align:	rsb	ip, ip, #4
> @@ -15,16 +17,16 @@
>  		cmp	ip, #2
>  		ldrb	r3, [r0]
>  		strb	r3, [r1], #1
> -		ldrgeb	r3, [r0]
> -		strgeb	r3, [r1], #1
> -		ldrgtb	r3, [r0]
> -		strgtb	r3, [r1], #1
> +		ldrbge	r3, [r0]
> +		strbge	r3, [r1], #1
> +		ldrbgt	r3, [r0]
> +		strbgt	r3, [r1], #1
>  		subs	r2, r2, ip
>  		bne	.Linsb_aligned
>  
>  ENTRY(__raw_readsb)
>  		teq	r2, #0		@ do we have to check for the zero len?
> -		moveq	pc, lr
> +		reteq	lr
>  		ands	ip, r1, #3
>  		bne	.Linsb_align
>  
> @@ -71,7 +73,7 @@ ENTRY(__raw_readsb)
>  		bpl	.Linsb_16_lp
>  
>  		tst	r2, #15
> -		ldmeqfd	sp!, {r4 - r6, pc}
> +		ldmfdeq	sp!, {r4 - r6, pc}
>  
>  .Linsb_no_16:	tst	r2, #8
>  		beq	.Linsb_no_8
> @@ -108,15 +110,15 @@ ENTRY(__raw_readsb)
>  		str	r3, [r1], #4
>  
>  .Linsb_no_4:	ands	r2, r2, #3
> -		ldmeqfd	sp!, {r4 - r6, pc}
> +		ldmfdeq	sp!, {r4 - r6, pc}
>  
>  		cmp	r2, #2
>  		ldrb	r3, [r0]
>  		strb	r3, [r1], #1
> -		ldrgeb	r3, [r0]
> -		strgeb	r3, [r1], #1
> -		ldrgtb	r3, [r0]
> -		strgtb	r3, [r1]
> +		ldrbge	r3, [r0]
> +		strbge	r3, [r1], #1
> +		ldrbgt	r3, [r0]
> +		strbgt	r3, [r1]
>  
>  		ldmfd	sp!, {r4 - r6, pc}
>  ENDPROC(__raw_readsb)
> diff --git a/arch/arm/lib32/io-readsl.S b/arch/arm/lib32/io-readsl.S
> index 7bcd0d45bc..aecac1f9eb 100644
> --- a/arch/arm/lib32/io-readsl.S
> +++ b/arch/arm/lib32/io-readsl.S
> @@ -1,17 +1,19 @@
>  /* SPDX-License-Identifier: GPL-2.0-only */
> -/* SPDX-FileCopyrightText: 1995-2000 Russell King */
> -
>  /*
> - * linux/arch/arm/lib/io-readsl.S
> + *  linux/arch/arm/lib/io-readsl.S
> + *
> + *  Copyright (C) 1995-2000 Russell King
>   */
>  #include <linux/linkage.h>
>  #include <asm/assembler.h>
>  
> +.syntax unified
> +
>  .section .text.__raw_readsl
>  
>  ENTRY(__raw_readsl)
>  		teq	r2, #0		@ do we have to check for the zero len?
> -		moveq	pc, lr
> +		reteq	lr
>  		ands	ip, r1, #3
>  		bne	3f
>  
> @@ -29,10 +31,10 @@ ENTRY(__raw_readsl)
>  2:		movs	r2, r2, lsl #31
>  		ldrcs	r3, [r0, #0]
>  		ldrcs	ip, [r0, #0]
> -		stmcsia	r1!, {r3, ip}
> +		stmiacs	r1!, {r3, ip}
>  		ldrne	r3, [r0, #0]
>  		strne	r3, [r1, #0]
> -		mov	pc, lr
> +		ret	lr
>  
>  3:		ldr	r3, [r0]
>  		cmp	ip, #2
> @@ -74,5 +76,5 @@ ENTRY(__raw_readsl)
>  		strb	r3, [r1, #1]
>  8:		mov	r3, ip, get_byte_0
>  		strb	r3, [r1, #0]
> -		mov	pc, lr
> +		ret	lr
>  ENDPROC(__raw_readsl)
> diff --git a/arch/arm/lib32/io-readsw-armv4.S b/arch/arm/lib32/io-readsw-armv4.S
> index 9fb7fd7576..f5c633027c 100644
> --- a/arch/arm/lib32/io-readsw-armv4.S
> +++ b/arch/arm/lib32/io-readsw-armv4.S
> @@ -1,12 +1,14 @@
>  /* SPDX-License-Identifier: GPL-2.0-only */
> -/* SPDX-FileCopyrightText: 1995-2000 Russell King */
> -
>  /*
> - * linux/arch/arm/lib/io-readsw-armv4.S
> + *  linux/arch/arm/lib/io-readsw-armv4.S
> + *
> + *  Copyright (C) 1995-2000 Russell King
>   */
>  #include <linux/linkage.h>
>  #include <asm/assembler.h>
>  
> +.syntax unified
> +
>  		.macro	pack, rd, hw1, hw2
>  #ifndef __ARMEB__
>  		orr	\rd, \hw1, \hw2, lsl #16
> @@ -25,7 +27,7 @@
>  
>  ENTRY(__raw_readsw)
>  		teq	r2, #0
> -		moveq	pc, lr
> +		reteq	lr
>  		tst	r1, #3
>  		bne	.Linsw_align
>  
> @@ -75,8 +77,8 @@ ENTRY(__raw_readsw)
>  		pack	r3, r3, ip
>  		str	r3, [r1], #4
>  
> -.Lno_insw_2:	ldrneh	r3, [r0]
> -		strneh	r3, [r1]
> +.Lno_insw_2:	ldrhne	r3, [r0]
> +		strhne	r3, [r1]
>  
>  		ldmfd	sp!, {r4, r5, pc}
>  
> @@ -93,7 +95,7 @@ ENTRY(__raw_readsw)
>  #endif
>  
>  .Linsw_noalign:	stmfd	sp!, {r4, lr}
> -		ldrccb	ip, [r1, #-1]!
> +		ldrbcc	ip, [r1, #-1]!
>  		bcc	1f
>  
>  		ldrh	ip, [r0]
> @@ -120,11 +122,11 @@ ENTRY(__raw_readsw)
>  
>  3:		tst	r2, #1
>  		strb	ip, [r1], #1
> -		ldrneh	ip, [r0]
> +		ldrhne	ip, [r0]
>     _BE_ONLY_(	movne	ip, ip, ror #8		)
> -		strneb	ip, [r1], #1
> +		strbne	ip, [r1], #1
>     _LE_ONLY_(	movne	ip, ip, lsr #8		)
>     _BE_ONLY_(	movne	ip, ip, lsr #24		)
> -		strneb	ip, [r1]
> +		strbne	ip, [r1]
>  		ldmfd	sp!, {r4, pc}
>  ENDPROC(__raw_readsw)
> diff --git a/arch/arm/lib32/io-writesb.S b/arch/arm/lib32/io-writesb.S
> index b6ce85f0d4..0bfb1f914e 100644
> --- a/arch/arm/lib32/io-writesb.S
> +++ b/arch/arm/lib32/io-writesb.S
> @@ -1,12 +1,14 @@
>  /* SPDX-License-Identifier: GPL-2.0-only */
> -/* SPDX-FileCopyrightText: 1995-2000 Russell King */
> -
>  /*
> - * linux/arch/arm/lib/io-writesb.S
> + *  linux/arch/arm/lib/io-writesb.S
> + *
> + *  Copyright (C) 1995-2000 Russell King
>   */
>  #include <linux/linkage.h>
>  #include <asm/assembler.h>
>  
> +.syntax unified
> +
>  		.macro	outword, rd
>  #ifndef __ARMEB__
>  		strb	\rd, [r0]
> @@ -35,16 +37,16 @@
>  		cmp	ip, #2
>  		ldrb	r3, [r1], #1
>  		strb	r3, [r0]
> -		ldrgeb	r3, [r1], #1
> -		strgeb	r3, [r0]
> -		ldrgtb	r3, [r1], #1
> -		strgtb	r3, [r0]
> +		ldrbge	r3, [r1], #1
> +		strbge	r3, [r0]
> +		ldrbgt	r3, [r1], #1
> +		strbgt	r3, [r0]
>  		subs	r2, r2, ip
>  		bne	.Loutsb_aligned
>  
>  ENTRY(__raw_writesb)
>  		teq	r2, #0		@ do we have to check for the zero len?
> -		moveq	pc, lr
> +		reteq	lr
>  		ands	ip, r1, #3
>  		bne	.Loutsb_align
>  
> @@ -63,7 +65,7 @@ ENTRY(__raw_writesb)
>  		bpl	.Loutsb_16_lp
>  
>  		tst	r2, #15
> -		ldmeqfd	sp!, {r4, r5, pc}
> +		ldmfdeq	sp!, {r4, r5, pc}
>  
>  .Loutsb_no_16:	tst	r2, #8
>  		beq	.Loutsb_no_8
> @@ -79,15 +81,15 @@ ENTRY(__raw_writesb)
>  		outword	r3
>  
>  .Loutsb_no_4:	ands	r2, r2, #3
> -		ldmeqfd	sp!, {r4, r5, pc}
> +		ldmfdeq	sp!, {r4, r5, pc}
>  
>  		cmp	r2, #2
>  		ldrb	r3, [r1], #1
>  		strb	r3, [r0]
> -		ldrgeb	r3, [r1], #1
> -		strgeb	r3, [r0]
> -		ldrgtb	r3, [r1]
> -		strgtb	r3, [r0]
> +		ldrbge	r3, [r1], #1
> +		strbge	r3, [r0]
> +		ldrbgt	r3, [r1]
> +		strbgt	r3, [r0]
>  
>  		ldmfd	sp!, {r4, r5, pc}
>  ENDPROC(__raw_writesb)
> diff --git a/arch/arm/lib32/io-writesl.S b/arch/arm/lib32/io-writesl.S
> index 61164234de..c300a62daf 100644
> --- a/arch/arm/lib32/io-writesl.S
> +++ b/arch/arm/lib32/io-writesl.S
> @@ -1,17 +1,19 @@
>  /* SPDX-License-Identifier: GPL-2.0-only */
> -/* SPDX-FileCopyrightText: 1995-2000 Russell King */
> -
>  /*
> - * linux/arch/arm/lib/io-writesl.S
> + *  linux/arch/arm/lib/io-writesl.S
> + *
> + *  Copyright (C) 1995-2000 Russell King
>   */
>  #include <linux/linkage.h>
>  #include <asm/assembler.h>
>  
> +.syntax unified
> +
>  .section .text.__raw_writesl
>  
>  ENTRY(__raw_writesl)
>  		teq	r2, #0		@ do we have to check for the zero len?
> -		moveq	pc, lr
> +		reteq	lr
>  		ands	ip, r1, #3
>  		bne	3f
>  
> @@ -27,12 +29,12 @@ ENTRY(__raw_writesl)
>  		bpl	1b
>  		ldmfd	sp!, {r4, lr}
>  2:		movs	r2, r2, lsl #31
> -		ldmcsia	r1!, {r3, ip}
> +		ldmiacs	r1!, {r3, ip}
>  		strcs	r3, [r0, #0]
>  		ldrne	r3, [r1, #0]
>  		strcs	ip, [r0, #0]
>  		strne	r3, [r0, #0]
> -		mov	pc, lr
> +		ret	lr
>  
>  3:		bic	r1, r1, #3
>  		ldr	r3, [r1], #4
> @@ -46,7 +48,7 @@ ENTRY(__raw_writesl)
>  		orr	ip, ip, r3, lspush #16
>  		str	ip, [r0]
>  		bne	4b
> -		mov	pc, lr
> +		ret	lr
>  
>  5:		mov	ip, r3, lspull #8
>  		ldr	r3, [r1], #4
> @@ -54,7 +56,7 @@ ENTRY(__raw_writesl)
>  		orr	ip, ip, r3, lspush #24
>  		str	ip, [r0]
>  		bne	5b
> -		mov	pc, lr
> +		ret	lr
>  
>  6:		mov	ip, r3, lspull #24
>  		ldr	r3, [r1], #4
> @@ -62,5 +64,5 @@ ENTRY(__raw_writesl)
>  		orr	ip, ip, r3, lspush #8
>  		str	ip, [r0]
>  		bne	6b
> -		mov	pc, lr
> +		ret	lr
>  ENDPROC(__raw_writesl)
> diff --git a/arch/arm/lib32/io-writesw-armv4.S b/arch/arm/lib32/io-writesw-armv4.S
> index 5cfa74356c..717237f3cc 100644
> --- a/arch/arm/lib32/io-writesw-armv4.S
> +++ b/arch/arm/lib32/io-writesw-armv4.S
> @@ -1,12 +1,14 @@
>  /* SPDX-License-Identifier: GPL-2.0-only */
> -/* SPDX-FileCopyrightText: 1995-2000 Russell King */
> -
>  /*
> - * linux/arch/arm/lib/io-writesw-armv4.S
> + *  linux/arch/arm/lib/io-writesw-armv4.S
> + *
> + *  Copyright (C) 1995-2000 Russell King
>   */
>  #include <linux/linkage.h>
>  #include <asm/assembler.h>
>  
> +.syntax unified
> +
>  		.macro	outword, rd
>  #ifndef __ARMEB__
>  		strh	\rd, [r0]
> @@ -30,7 +32,7 @@
>  
>  ENTRY(__raw_writesw)
>  		teq	r2, #0
> -		moveq	pc, lr
> +		reteq	lr
>  		ands	r3, r1, #3
>  		bne	.Loutsw_align
>  
> @@ -60,8 +62,8 @@ ENTRY(__raw_writesw)
>  		ldr	r3, [r1], #4
>  		outword	r3
>  
> -.Lno_outsw_2:	ldrneh	r3, [r1]
> -		strneh	r3, [r0]
> +.Lno_outsw_2:	ldrhne	r3, [r1]
> +		strhne	r3, [r0]
>  
>  		ldmfd	sp!, {r4, r5, pc}
>  
> @@ -94,6 +96,6 @@ ENTRY(__raw_writesw)
>  
>  		tst	r2, #1
>  3:		movne	ip, r3, lsr #8
> -		strneh	ip, [r0]
> -		mov	pc, lr
> +		strhne	ip, [r0]
> +		ret	lr
>  ENDPROC(__raw_writesw)
> 


-- 
Pengutronix e.K.                           |                             |
Steuerwalder Str. 21                       | http://www.pengutronix.de/  |
31137 Hildesheim, Germany                  | Phone: +49-5121-206917-0    |
Amtsgericht Hildesheim, HRA 2686           | Fax:   +49-5121-206917-5555 |



  reply	other threads:[~2024-09-25 16:07 UTC|newest]

Thread overview: 24+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2024-09-25 13:55 [PATCH 00/10] ARM: add assembler optimized memmove Sascha Hauer
2024-09-25 13:55 ` [PATCH 01/10] ARM: Use optimized reads[bwl] and writes[bwl] functions Sascha Hauer
2024-09-25 15:45   ` Ahmad Fatoum
2024-09-25 13:55 ` [PATCH 02/10] ARM: rename logical shift macros push pull into lspush lspull Sascha Hauer
2024-09-25 15:52   ` Ahmad Fatoum
2024-09-25 13:55 ` [PATCH 03/10] ARM: convert all "mov.* pc, reg" to "bx reg" for ARMv6+ Sascha Hauer
2024-09-25 15:56   ` Ahmad Fatoum
2024-09-25 13:55 ` [PATCH 04/10] ARM: update lib1funcs.S from Linux Sascha Hauer
2024-09-25 16:02   ` Ahmad Fatoum
2024-09-26  8:22     ` Sascha Hauer
2024-09-26 11:09       ` Ahmad Fatoum
2024-09-25 13:55 ` [PATCH 05/10] ARM: update findbit.S " Sascha Hauer
2024-09-25 16:03   ` Ahmad Fatoum
2024-09-25 13:55 ` [PATCH 06/10] ARM: update io-* " Sascha Hauer
2024-09-25 16:04   ` Ahmad Fatoum [this message]
2024-09-25 13:55 ` [PATCH 07/10] ARM: always assume the unified syntax for assembly code Sascha Hauer
2024-09-25 16:09   ` Ahmad Fatoum
2024-09-25 13:55 ` [PATCH 08/10] ARM: update memcpy.S and memset.S from Linux Sascha Hauer
2024-09-26  5:51   ` Ahmad Fatoum
2024-09-25 13:55 ` [PATCH 09/10] lib/string.c: export non optimized memmove as __default_memmove Sascha Hauer
2024-09-25 16:10   ` Ahmad Fatoum
2024-09-25 13:55 ` [PATCH 10/10] ARM: add optimized memmove Sascha Hauer
2024-09-26  5:48   ` Ahmad Fatoum
2024-09-26 11:12     ` Sascha Hauer

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=6f3e816e-44aa-4bd6-bce9-0b008c018968@pengutronix.de \
    --to=a.fatoum@pengutronix.de \
    --cc=barebox@lists.infradead.org \
    --cc=s.hauer@pengutronix.de \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox