This patch adds the ARM/Thumb-2 unified support for the arch/arm/lib/* files. Signed-off-by: Catalin Marinas <catalin.marinas@arm.com>
		
			
				
	
	
		
			100 lines
		
	
	
	
		
			1.7 KiB
			
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
			
		
		
	
	
			100 lines
		
	
	
	
		
			1.7 KiB
			
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
/*
 | 
						|
 *  linux/arch/arm/lib/io-writesw-armv4.S
 | 
						|
 *
 | 
						|
 *  Copyright (C) 1995-2000 Russell King
 | 
						|
 *
 | 
						|
 * This program is free software; you can redistribute it and/or modify
 | 
						|
 * it under the terms of the GNU General Public License version 2 as
 | 
						|
 * published by the Free Software Foundation.
 | 
						|
 */
 | 
						|
#include <linux/linkage.h>
 | 
						|
#include <asm/assembler.h>
 | 
						|
 | 
						|
		.macro	outword, rd
 | 
						|
#ifndef __ARMEB__
 | 
						|
		strh	\rd, [r0]
 | 
						|
		mov	\rd, \rd, lsr #16
 | 
						|
		strh	\rd, [r0]
 | 
						|
#else
 | 
						|
		mov	lr, \rd, lsr #16
 | 
						|
		strh	lr, [r0]
 | 
						|
		strh	\rd, [r0]
 | 
						|
#endif
 | 
						|
		.endm
 | 
						|
 | 
						|
.Loutsw_align:	movs	ip, r1, lsl #31
 | 
						|
		bne	.Loutsw_noalign
 | 
						|
 | 
						|
		ldrh	r3, [r1], #2
 | 
						|
		sub	r2, r2, #1
 | 
						|
		strh	r3, [r0]
 | 
						|
 | 
						|
ENTRY(__raw_writesw)
 | 
						|
		teq	r2, #0
 | 
						|
		moveq	pc, lr
 | 
						|
		ands	r3, r1, #3
 | 
						|
		bne	.Loutsw_align
 | 
						|
 | 
						|
		stmfd	sp!, {r4, r5, lr}
 | 
						|
 | 
						|
		subs	r2, r2, #8
 | 
						|
		bmi	.Lno_outsw_8
 | 
						|
 | 
						|
.Loutsw_8_lp:	ldmia	r1!, {r3, r4, r5, ip}
 | 
						|
		subs	r2, r2, #8
 | 
						|
		outword	r3
 | 
						|
		outword	r4
 | 
						|
		outword	r5
 | 
						|
		outword	ip
 | 
						|
		bpl	.Loutsw_8_lp
 | 
						|
 | 
						|
.Lno_outsw_8:	tst	r2, #4
 | 
						|
		beq	.Lno_outsw_4
 | 
						|
 | 
						|
		ldmia	r1!, {r3, ip}
 | 
						|
		outword	r3
 | 
						|
		outword	ip
 | 
						|
 | 
						|
.Lno_outsw_4:	movs	r2, r2, lsl #31
 | 
						|
		bcc	.Lno_outsw_2
 | 
						|
 | 
						|
		ldr	r3, [r1], #4
 | 
						|
		outword	r3
 | 
						|
 | 
						|
.Lno_outsw_2:	ldrneh	r3, [r1]
 | 
						|
		strneh	r3, [r0]
 | 
						|
 | 
						|
		ldmfd	sp!, {r4, r5, pc}
 | 
						|
 | 
						|
#ifdef __ARMEB__
 | 
						|
#define pull_hbyte0	lsl #8
 | 
						|
#define push_hbyte1	lsr #24
 | 
						|
#else
 | 
						|
#define pull_hbyte0	lsr #24
 | 
						|
#define push_hbyte1	lsl #8
 | 
						|
#endif
 | 
						|
 | 
						|
.Loutsw_noalign:
 | 
						|
 ARM(		ldr	r3, [r1, -r3]!	)
 | 
						|
 THUMB(		rsb	r3, r3, #0	)
 | 
						|
 THUMB(		ldr	r3, [r1, r3]	)
 | 
						|
 THUMB(		sub	r1, r3		)
 | 
						|
		subcs	r2, r2, #1
 | 
						|
		bcs	2f
 | 
						|
		subs	r2, r2, #2
 | 
						|
		bmi	3f
 | 
						|
 | 
						|
1:		mov	ip, r3, lsr #8
 | 
						|
		strh	ip, [r0]
 | 
						|
2:		mov	ip, r3, pull_hbyte0
 | 
						|
		ldr	r3, [r1, #4]!
 | 
						|
		subs	r2, r2, #2
 | 
						|
		orr	ip, ip, r3, push_hbyte1
 | 
						|
		strh	ip, [r0]
 | 
						|
		bpl	1b
 | 
						|
 | 
						|
		tst	r2, #1
 | 
						|
3:		movne	ip, r3, lsr #8
 | 
						|
		strneh	ip, [r0]
 | 
						|
		mov	pc, lr
 | 
						|
ENDPROC(__raw_writesw)
 |