mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-25 10:27:04 +00:00 
			
		
		
		
	Memory operand parsing is a bit haphazzard at the moment, in no small part due to the even more haphazzard representations of memory operands in the .td files. Start cleaning that all up, at least a bit. The addressing modes in the .td files will be being simplified to not be so monolithic, especially with regards to immediate vs. register offsets and post-indexed addressing. addrmode3 is on its way with this patch, for example. This patch is foundational to enable going back to smaller incremental patches for the individual memory referencing instructions themselves. It does just enough to get the basics in place and handle the "make check" regression tests we already have. Follow-up work will be fleshing out the details and adding more robust test cases for the individual instructions, starting with ARM mode and moving from there into Thumb and Thumb2. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@136845 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			19 lines
		
	
	
		
			829 B
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
			
		
		
	
	
			19 lines
		
	
	
		
			829 B
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
| @ RUN: llvm-mc -mcpu=cortex-a8 -triple arm-unknown-unknown -show-encoding %s | FileCheck %s
 | |
| 
 | |
| @ CHECK: ldrsbt  r1, [r0], r2 @ encoding: [0xd2,0x10,0xb0,0xe0]
 | |
| @ CHECK: ldrsbt  r1, [r0], #4 @ encoding: [0xd4,0x10,0xf0,0xe0]
 | |
| @ CHECK: ldrsht  r1, [r0], r2 @ encoding: [0xf2,0x10,0xb0,0xe0]
 | |
| @ CHECK: ldrsht  r1, [r0], #4 @ encoding: [0xf4,0x10,0xf0,0xe0]
 | |
| @ CHECK: ldrht  r1, [r0], r2 @ encoding: [0xb2,0x10,0xb0,0xe0]
 | |
| @ CHECK: ldrht  r1, [r0], #4 @ encoding: [0xb4,0x10,0xf0,0xe0]
 | |
| @ CHECK: strht  r1, [r0], r2 @ encoding: [0xb2,0x10,0xa0,0xe0]
 | |
| @ CHECK: strht  r1, [r0], #4 @ encoding: [0xb4,0x10,0xe0,0xe0]
 | |
|         ldrsbt  r1, [r0], r2
 | |
|         ldrsbt  r1, [r0], #4
 | |
|         ldrsht  r1, [r0], r2
 | |
|         ldrsht  r1, [r0], #4
 | |
|         ldrht  r1, [r0], r2
 | |
|         ldrht  r1, [r0], #4
 | |
|         strht  r1, [r0], r2
 | |
|         strht  r1, [r0], #4
 |