68 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			LLVM
		
	
	
	
			
		
		
	
	
			68 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			LLVM
		
	
	
	
| ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
 | |
| ; RUN: llc -mcpu=pwr9 -ppc-asm-full-reg-names -ppc-vsr-nums-as-vr \
 | |
| ; RUN:   -mtriple=powerpc64le-unknown-unknown < %s | FileCheck %s \
 | |
| ; RUN:   -check-prefix=CHECK-P9
 | |
| 
 | |
| @_ZL3num = external dso_local unnamed_addr global float, align 4
 | |
| 
 | |
| define dso_local void @main() local_unnamed_addr personality i8* bitcast (i32 (...)* @__gxx_personality_v0 to i8*) {
 | |
| ; CHECK-P9-LABEL: main:
 | |
| ; CHECK-P9:       # %bb.0: # %bb
 | |
| ; CHECK-P9-NEXT:    mflr r0
 | |
| ; CHECK-P9-NEXT:    std r0, 16(r1)
 | |
| ; CHECK-P9-NEXT:    stdu r1, -32(r1)
 | |
| ; CHECK-P9-NEXT:    .cfi_def_cfa_offset 32
 | |
| ; CHECK-P9-NEXT:    .cfi_offset lr, 16
 | |
| ; CHECK-P9-NEXT:    bl malloc
 | |
| ; CHECK-P9-NEXT:    nop
 | |
| ; CHECK-P9-NEXT:    addis r4, r2, _ZL3num@toc@ha
 | |
| ; CHECK-P9-NEXT:    addi r3, r3, -25400
 | |
| ; CHECK-P9-NEXT:    lfs f0, _ZL3num@toc@l(r4)
 | |
| ; CHECK-P9-NEXT:    addis r4, r2, .LCPI0_0@toc@ha
 | |
| ; CHECK-P9-NEXT:    lfs f1, .LCPI0_0@toc@l(r4)
 | |
| ; CHECK-P9-NEXT:    li r4, 0
 | |
| ; CHECK-P9-NEXT:    xsmulsp f0, f0, f1
 | |
| ; CHECK-P9-NEXT:    cmpldi r4, 0
 | |
| ; CHECK-P9-NEXT:    beq- cr0, .LBB0_2
 | |
| ; CHECK-P9-NEXT:    .p2align 5
 | |
| ; CHECK-P9-NEXT:  .LBB0_1: # %bb5
 | |
| ; CHECK-P9-NEXT:    #
 | |
| ; CHECK-P9-NEXT:    addi r3, r3, 25400
 | |
| ; CHECK-P9-NEXT:    addi r4, r4, 25400
 | |
| ; CHECK-P9-NEXT:    stfs f0, 15240(r3)
 | |
| ; CHECK-P9-NEXT:    cmpldi r4, 0
 | |
| ; CHECK-P9-NEXT:    bne+ cr0, .LBB0_1
 | |
| ; CHECK-P9-NEXT:  .LBB0_2: # %bb16
 | |
| bb:
 | |
|   %i = tail call noalias dereferenceable_or_null(6451600) i8* @malloc()
 | |
|   %i1 = bitcast i8* %i to float*
 | |
|   br label %bb2
 | |
| 
 | |
| bb2:                                              ; preds = %bb5, %bb
 | |
|   %i3 = phi i64 [ 0, %bb ], [ %i15, %bb5 ]
 | |
|   %i4 = icmp eq i64 %i3, 0
 | |
|   br i1 %i4, label %bb16, label %bb5
 | |
| 
 | |
| bb5:                                              ; preds = %bb2
 | |
|   %i6 = mul nuw nsw i64 %i3, 1270
 | |
|   %i7 = add nuw nsw i64 %i6, 0
 | |
|   %i8 = getelementptr inbounds float, float* %i1, i64 %i7
 | |
|   store float undef, float* %i8, align 4
 | |
|   %i9 = add nuw nsw i64 %i3, 3
 | |
|   %i10 = load float, float* @_ZL3num, align 4
 | |
|   %i11 = fmul float %i10, 0x3E00000000000000
 | |
|   %i12 = mul nuw nsw i64 %i9, 1270
 | |
|   %i13 = add nuw nsw i64 %i12, 0
 | |
|   %i14 = getelementptr inbounds float, float* %i1, i64 %i13
 | |
|   store float %i11, float* %i14, align 4
 | |
|   %i15 = add nuw nsw i64 %i3, 5
 | |
|   br label %bb2
 | |
| 
 | |
| bb16:                                             ; preds = %bb2
 | |
|   unreachable
 | |
| }
 | |
| 
 | |
| declare i32 @__gxx_personality_v0(...)
 | |
| 
 | |
| declare i8* @malloc() local_unnamed_addr
 |