1# RUN: llc -march=x86-64 -start-after branch-folder -stop-after branch-folder -o - %s | FileCheck %s 2# This test ensures that the MIR parser parses constant pool constants and 3# constant pool operands correctly. 4 5--- | 6 7 define double @test(double %a, float %b) { 8 entry: 9 %c = fadd double %a, 3.250000e+00 10 %d = fadd float %b, 6.250000e+00 11 %e = fpext float %d to double 12 %f = fmul double %c, %e 13 ret double %f 14 } 15 16 define double @test2(double %a, float %b) { 17 entry: 18 %c = fadd double %a, 3.250000e+00 19 %d = fadd float %b, 6.250000e+00 20 %e = fpext float %d to double 21 %f = fmul double %c, %e 22 ret double %f 23 } 24 25 define double @test3(double %a, float %b) { 26 entry: 27 %c = fadd double %a, 3.250000e+00 28 %d = fadd float %b, 6.250000e+00 29 %e = fpext float %d to double 30 %f = fmul double %c, %e 31 ret double %f 32 } 33 34 define double @test4(double %a, float %b) { 35 entry: 36 %c = fadd double %a, 3.250000e+00 37 %d = fadd float %b, 6.250000e+00 38 %e = fpext float %d to double 39 %f = fmul double %c, %e 40 ret double %f 41 } 42... 43--- 44# CHECK: name: test 45# CHECK: constants: 46# CHECK-NEXT: - id: 0 47# CHECK-NEXT: value: 'double 3.250000e+00' 48# CHECK-NEXT: alignment: 8 49# CHECK-NEXT: - id: 1 50# CHECK-NEXT: value: 'float 6.250000e+00' 51# CHECK-NEXT: alignment: 4 52name: test 53constants: 54 - id: 0 55 value: 'double 3.250000e+00' 56 alignment: 8 57 - id: 1 58 value: 'float 6.250000e+00' 59 alignment: 4 60body: | 61 bb.0.entry: 62 ; CHECK: %xmm0 = ADDSDrm killed %xmm0, %rip, 1, _, %const.0, _ 63 ; CHECK-NEXT: %xmm1 = ADDSSrm killed %xmm1, %rip, 1, _, %const.1, _ 64 %xmm0 = ADDSDrm killed %xmm0, %rip, 1, _, %const.0, _ 65 %xmm1 = ADDSSrm killed %xmm1, %rip, 1, _, %const.1, _ 66 %xmm1 = CVTSS2SDrr killed %xmm1 67 %xmm0 = MULSDrr killed %xmm0, killed %xmm1 68 RETQ %xmm0 69... 70--- 71# Verify that alignment can be inferred: 72# CHECK: name: test2 73# CHECK: constants: 74# CHECK-NEXT: - id: 0 75# CHECK-NEXT: value: 'double 3.250000e+00' 76# CHECK-NEXT: alignment: 8 77# CHECK-NEXT: - id: 1 78# CHECK-NEXT: value: 'float 6.250000e+00' 79# CHECK-NEXT: alignment: 4 80name: test2 81constants: 82 - id: 0 83 value: 'double 3.250000e+00' 84 - id: 1 85 value: 'float 6.250000e+00' 86body: | 87 bb.0.entry: 88 %xmm0 = ADDSDrm killed %xmm0, %rip, 1, _, %const.0, _ 89 %xmm1 = ADDSSrm killed %xmm1, %rip, 1, _, %const.1, _ 90 %xmm1 = CVTSS2SDrr killed %xmm1 91 %xmm0 = MULSDrr killed %xmm0, killed %xmm1 92 RETQ %xmm0 93... 94--- 95# Verify that the non-standard alignments are respected: 96# CHECK: name: test3 97# CHECK: constants: 98# CHECK-NEXT: - id: 0 99# CHECK-NEXT: value: 'double 3.250000e+00' 100# CHECK-NEXT: alignment: 128 101# CHECK-NEXT: - id: 1 102# CHECK-NEXT: value: 'float 6.250000e+00' 103# CHECK-NEXT: alignment: 1 104name: test3 105constants: 106 - id: 0 107 value: 'double 3.250000e+00' 108 alignment: 128 109 - id: 1 110 value: 'float 6.250000e+00' 111 alignment: 1 112body: | 113 bb.0.entry: 114 ; CHECK: %xmm0 = ADDSDrm killed %xmm0, %rip, 1, _, %const.0, _ 115 ; CHECK-NEXT: %xmm1 = ADDSSrm killed %xmm1, %rip, 1, _, %const.1, _ 116 %xmm0 = ADDSDrm killed %xmm0, %rip, 1, _, %const.0, _ 117 %xmm1 = ADDSSrm killed %xmm1, %rip, 1, _, %const.1, _ 118 %xmm1 = CVTSS2SDrr killed %xmm1 119 %xmm0 = MULSDrr killed %xmm0, killed %xmm1 120 RETQ %xmm0 121... 122--- 123# CHECK: name: test4 124name: test4 125constants: 126 - id: 0 127 value: 'double 3.250000e+00' 128 - id: 1 129 value: 'float 6.250000e+00' 130body: | 131 bb.0.entry: 132 ; CHECK: %xmm0 = ADDSDrm killed %xmm0, %rip, 1, _, %const.1 - 12, _ 133 ; CHECK-NEXT: %xmm1 = ADDSSrm killed %xmm1, %rip, 1, _, %const.0 + 8, _ 134 %xmm0 = ADDSDrm killed %xmm0, %rip, 1, _, %const.1 - 12, _ 135 %xmm1 = ADDSSrm killed %xmm1, %rip, 1, _, %const.0 + 8, _ 136 %xmm1 = CVTSS2SDrr killed %xmm1 137 %xmm0 = MULSDrr killed %xmm0, killed %xmm1 138 RETQ %xmm0 139... 140