mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-26 18:20:39 +00:00 
			
		
		
		
	incorrect instruction sequence due to it not being aware that an inline assembly instruction may reference memory. This patch fixes the problem by causing the scheduler to always assume that any inline assembly code instruction could access memory. This is necessary because the internal representation of the inline instruction does not include any information about memory accesses. This should fix PR13504. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@166929 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			14 lines
		
	
	
		
			328 B
		
	
	
	
		
			LLVM
		
	
	
	
	
	
			
		
		
	
	
			14 lines
		
	
	
		
			328 B
		
	
	
	
		
			LLVM
		
	
	
	
	
	
| ; PR13504
 | |
| ; RUN: llc -march=x86 -mcpu=atom <%s | FileCheck %s
 | |
| ; CHECK: bsfl
 | |
| ; CHECK-NOT: movl
 | |
| 
 | |
| define i32 @foo(i32 %treemap) nounwind uwtable {
 | |
| entry:
 | |
|   %sub = sub i32 0, %treemap
 | |
|   %and = and i32 %treemap, %sub
 | |
|   %0 = tail call i32 asm "bsfl $1,$0\0A\09", "=r,rm,~{dirflag},~{fpsr},~{flags}"(i32 %and) nounwind
 | |
|   ret i32 %0
 | |
| }
 | |
| 
 |