You've already forked linux-packaging-mono
							
							
		
			
				
	
	
		
			40 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
			
		
		
	
	
			40 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
| # RUN: llvm-mc -filetype=obj -triple=riscv32 %s \
 | |
| # RUN:  | llvm-objdump -d - | FileCheck %s -check-prefix=CHECK-INSTR
 | |
| 
 | |
| # RUN: llvm-mc -filetype=obj -triple=riscv32 %s \
 | |
| # RUN:  | llvm-readobj -r | FileCheck %s -check-prefix=CHECK-REL
 | |
| 
 | |
| # Check the assembler can handle hi and lo expressions with a constant 
 | |
| # address, and constant expressions involving labels. Test case derived from 
 | |
| # test/MC/Mips/hilo-addressing.s
 | |
| 
 | |
| # Check that 1 is added to the high 20 bits if bit 11 of the low part is 1.
 | |
| .equ addr, 0xdeadbeef
 | |
|   lui t0, %hi(addr)
 | |
|   lw ra, %lo(addr)(t0)
 | |
| # CHECK-INSTR: lui t0, 912092
 | |
| # CHECK-INSTR: lw ra, -273(t0)
 | |
| 
 | |
| # Check that assembler can handle %hi(label1 - label2) and %lo(label1 - label2)
 | |
| # expressions.
 | |
| 
 | |
| tmp1:
 | |
|   # Emit zeros so that difference between tmp1 and tmp3 is 0x30124 bytes.
 | |
|   .fill 0x30124-8
 | |
| tmp2:
 | |
|   lui t0, %hi(tmp3-tmp1)
 | |
|   lw ra, %lo(tmp3-tmp1)(t0)
 | |
| # CHECK-INSTR: lui t0, 48
 | |
| # CHECK-INSTR: lw ra, 292(t0)
 | |
| 
 | |
| tmp3:
 | |
|   lui t1, %hi(tmp2-tmp3)
 | |
|   lw sp, %lo(tmp2-tmp3)(t1)
 | |
| # CHECK-INSTR: lui t1, 0
 | |
| # CHECK-INSTR: lw sp, -8(t1)
 | |
| 
 | |
| # Check that a relocation isn't emitted for %hi(label1 - label2) and
 | |
| # %lo(label1 - label2) expressions.
 | |
| 
 | |
| # CHECK-REL-NOT: R_RISCV
 |