forked from OSchip/llvm-project
				
			
		
			
				
	
	
		
			21 lines
		
	
	
		
			499 B
		
	
	
	
		
			LLVM
		
	
	
	
			
		
		
	
	
			21 lines
		
	
	
		
			499 B
		
	
	
	
		
			LLVM
		
	
	
	
| ; RUN: llc -march=x86-64 < %s | FileCheck %s -check-prefix=CHECK-64
 | |
| 
 | |
| define void @a(i64* nocapture %s, i64* nocapture %t, i64 %a, i64 %b, i64 %c) nounwind {
 | |
| entry:
 | |
|  %0 = zext i64 %a to i128
 | |
|  %1 = zext i64 %b to i128
 | |
|  %2 = add i128 %1, %0
 | |
|  %3 = zext i64 %c to i128
 | |
|  %4 = shl i128 %3, 64
 | |
|  %5 = add i128 %4, %2
 | |
|  %6 = lshr i128 %5, 64
 | |
|  %7 = trunc i128 %6 to i64
 | |
|  store i64 %7, i64* %s, align 8
 | |
|  %8 = trunc i128 %2 to i64
 | |
|  store i64 %8, i64* %t, align 8
 | |
|  ret void
 | |
| 
 | |
| ; CHECK-64: addq
 | |
| ; CHECK-64: adcq $0
 | |
| }
 |