41 lines
		
	
	
		
			1019 B
		
	
	
	
		
			ArmAsm
		
	
	
	
			
		
		
	
	
			41 lines
		
	
	
		
			1019 B
		
	
	
	
		
			ArmAsm
		
	
	
	
| @ RUN: not llvm-mc -triple thumbv7-apple-ios -filetype=obj %s -o /dev/null 2>&1 | FileCheck %s
 | |
|         @ Size: 2 bytes
 | |
|         .thumb_func _f1
 | |
|         .thumb
 | |
|         .globl _f1
 | |
| _f1:
 | |
|         bx lr
 | |
| 
 | |
|         @ A misalgined ARM destination.
 | |
|         .arm
 | |
|         .globl _misaligned
 | |
| _misaligned:
 | |
|         bx lr
 | |
| 
 | |
|         @ And a properly aligned one.
 | |
|         .globl _aligned
 | |
|         .p2align 2
 | |
|         .arm
 | |
| _aligned:
 | |
|         bx lr
 | |
| 
 | |
|         @ Align this Thumb function so we can predict the outcome of
 | |
|         @ "Align(PC, 4)" during blx operation.
 | |
|         .thumb_func _test
 | |
|         .thumb
 | |
|         .p2align 2
 | |
|         .globl _test
 | |
| _test:
 | |
|         blx _misaligned       @ PC=0 (mod 4)
 | |
|         movs r0, r0
 | |
|         blx _misaligned       @ PC=2 (mod 4)
 | |
|         movs r0, r0
 | |
|         blx _aligned          @ PC=0 (mod 4)
 | |
|         movs r0, r0
 | |
|         blx _aligned          @ PC=2 (mod 4)
 | |
| 
 | |
| @ CHECK: error: misaligned ARM call destination
 | |
| @ CHECK:   blx _misaligned
 | |
| @ CHECK: error: misaligned ARM call destination
 | |
| @ CHECK:   blx _misaligned
 |