mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-31 08:16:47 +00:00 
			
		
		
		
	This was done with the following sed invocation to catch label lines demarking function boundaries:
    sed -i '' "s/^;\( *\)\([A-Z0-9_]*\):\( *\)test\([A-Za-z0-9_-]*\):\( *\)$/;\1\2-LABEL:\3test\4:\5/g" test/CodeGen/*/*.ll
which was written conservatively to avoid false positives rather than false negatives. I scanned through all the changes and everything looks correct.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@186258 91177308-0d34-0410-b5e6-96231b3b80d8
		
	
		
			
				
	
	
		
			32 lines
		
	
	
		
			775 B
		
	
	
	
		
			LLVM
		
	
	
	
	
	
			
		
		
	
	
			32 lines
		
	
	
		
			775 B
		
	
	
	
		
			LLVM
		
	
	
	
	
	
| ; RUN: llc -verify-machineinstrs < %s -mtriple=aarch64-none-linux-gnu | FileCheck %s
 | |
| 
 | |
| @var32 = global i32 0
 | |
| @var64 = global i64 0
 | |
| 
 | |
| define void @test_zr() {
 | |
| ; CHECK-LABEL: test_zr:
 | |
| 
 | |
|   store i32 0, i32* @var32
 | |
| ; CHECK: str wzr, [{{x[0-9]+}}, #:lo12:var32]
 | |
|   store i64 0, i64* @var64
 | |
| ; CHECK: str xzr, [{{x[0-9]+}}, #:lo12:var64]
 | |
| 
 | |
|   ret void
 | |
| ; CHECK: ret
 | |
| }
 | |
| 
 | |
| define void @test_sp(i32 %val) {
 | |
| ; CHECK-LABEL: test_sp:
 | |
| 
 | |
| ; Important correctness point here is that LLVM doesn't try to use xzr
 | |
| ; as an addressing register: "str w0, [xzr]" is not a valid A64
 | |
| ; instruction (0b11111 in the Rn field would mean "sp").
 | |
|   %addr = getelementptr i32* null, i64 0
 | |
|   store i32 %val, i32* %addr
 | |
| ; CHECK: mov x[[NULL:[0-9]+]], xzr
 | |
| ; CHECK: str {{w[0-9]+}}, [x[[NULL]]]
 | |
| 
 | |
|   ret void
 | |
| ; CHECK: ret
 | |
| }
 |