51 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
			
		
		
	
	
			51 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
| //===------- bswapdi2 - Implement bswapdi2 --------------------------------===//
 | |
| //
 | |
| //                     The LLVM Compiler Infrastructure
 | |
| //
 | |
| // This file is dual licensed under the MIT and the University of Illinois Open
 | |
| // Source Licenses. See LICENSE.TXT for details.
 | |
| //
 | |
| //===----------------------------------------------------------------------===//
 | |
| 
 | |
| #include "../assembly.h"
 | |
| 
 | |
| 	.syntax unified
 | |
| 	.text
 | |
| #if __ARM_ARCH_ISA_THUMB == 2
 | |
| 	.thumb
 | |
| #endif
 | |
| 
 | |
| //
 | |
| // extern uint64_t __bswapdi2(uint64_t);
 | |
| //
 | |
| // Reverse all the bytes in a 64-bit integer.
 | |
| //
 | |
| 	.p2align 2
 | |
| #if __ARM_ARCH_ISA_THUMB == 2
 | |
| DEFINE_COMPILERRT_THUMB_FUNCTION(__bswapdi2)
 | |
| #else
 | |
| DEFINE_COMPILERRT_FUNCTION(__bswapdi2)
 | |
| #endif
 | |
| #if __ARM_ARCH < 6
 | |
|     // before armv6 does not have "rev" instruction
 | |
|     // r2 = rev(r0)
 | |
|     eor r2, r0, r0, ror #16
 | |
|     bic r2, r2, #0xff0000
 | |
|     mov r2, r2, lsr #8
 | |
|     eor r2, r2, r0, ror #8
 | |
|     // r0 = rev(r1)
 | |
|     eor r0, r1, r1, ror #16
 | |
|     bic r0, r0, #0xff0000
 | |
|     mov r0, r0, lsr #8
 | |
|     eor r0, r0, r1, ror #8
 | |
| #else
 | |
|     rev r2, r0  // r2 = rev(r0)
 | |
|     rev r0, r1  // r0 = rev(r1)
 | |
| #endif
 | |
|     mov r1, r2  // r1 = r2 = rev(r0)
 | |
|     JMP(lr)
 | |
| END_COMPILERRT_FUNCTION(__bswapdi2)
 | |
| 
 | |
| NO_EXEC_STACK_DIRECTIVE
 | |
| 
 |