You've already forked linux-packaging-mono
							
							
		
			
	
	
		
			41 lines
		
	
	
		
			988 B
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
		
		
			
		
	
	
			41 lines
		
	
	
		
			988 B
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
|   | # RUN: llc -mtriple=x86_64-- -run-pass=peephole-opt %s -o - | FileCheck %s | ||
|  | --- | | ||
|  |   define void @func() { ret void } | ||
|  | ... | ||
|  | --- | ||
|  | # Check that instructions with MI.isBitcast() are only replaced by COPY if there | ||
|  | # are no SUBREG_TO_REG users. | ||
|  | # CHECK-LABEL: name: func | ||
|  | name: func | ||
|  | registers: | ||
|  |   - { id: 0, class: gr32 } | ||
|  |   - { id: 1, class: fr32 } | ||
|  |   - { id: 2, class: gr32 } | ||
|  | 
 | ||
|  |   - { id: 3, class: gr32 } | ||
|  |   - { id: 4, class: fr32 } | ||
|  |   - { id: 5, class: gr32 } | ||
|  |   - { id: 6, class: gr64 } | ||
|  | 
 | ||
|  | body: | | ||
|  |   bb.0: | ||
|  |     ; CHECK: %1:fr32 = VMOVDI2SSrr %0 | ||
|  |     ; CHECK: %7:gr32 = COPY %0 | ||
|  |     ; CHECK: NOOP implicit %7 | ||
|  |     %0 = MOV32ri 42 | ||
|  |     %1 = VMOVDI2SSrr %0 | ||
|  |     %2 = MOVSS2DIrr %1 | ||
|  |     NOOP implicit %2 | ||
|  | 
 | ||
|  |     ; CHECK: %4:fr32 = VMOVDI2SSrr %3 | ||
|  |     ; CHECK-NOT: COPY | ||
|  |     ; CHECK: %5:gr32 = MOVSS2DIrr %4 | ||
|  |     ; CHECK: %6:gr64 = SUBREG_TO_REG %5, 0 | ||
|  |     ; CHECK: NOOP implicit %6 | ||
|  |     %3 = MOV32ri 42 | ||
|  |     %4 = VMOVDI2SSrr %3 | ||
|  |     %5 = MOVSS2DIrr %4 | ||
|  |     %6 = SUBREG_TO_REG %5, 0, %subreg.sub_32bit | ||
|  |     NOOP implicit %6 | ||
|  | ... |