mirror of
https://github.com/apple/swift.git
synced 2025-12-14 20:36:38 +01:00
Type annotations for instruction operands are omitted, e.g. ``` %3 = struct $S(%1, %2) ``` Operand types are redundant anyway and were only used for sanity checking in the SIL parser. But: operand types _are_ printed if the definition of the operand value was not printed yet. This happens: * if the block with the definition appears after the block where the operand's instruction is located * if a block or instruction is printed in isolation, e.g. in a debugger The old behavior can be restored with `-Xllvm -sil-print-types`. This option is added to many existing test files which check for operand types in their check-lines.
98 lines
3.7 KiB
Plaintext
98 lines
3.7 KiB
Plaintext
// RUN: %target-sil-opt -sil-print-types -enable-sil-verify-all %s -diagnostic-constant-propagation | %FileCheck %s
|
|
// RUN: %target-sil-opt -sil-print-types -enable-sil-verify-all %s -performance-constant-propagation | %FileCheck %s
|
|
//
|
|
// REQUIRES: CPU=i386 || CPU=x86_64
|
|
//
|
|
// Tests that check constant-folding of conversions of floating point values
|
|
// to integer types for x86 architectures.
|
|
|
|
import Swift
|
|
import Builtin
|
|
|
|
sil @foldFPToUInt8UsingDouble : $@convention(thin) () -> UInt8 {
|
|
bb0:
|
|
%0 = float_literal $Builtin.FPIEEE80, 0x4006FF00000000000000 // 255
|
|
%1 = builtin "fptrunc_FPIEEE80_FPIEEE64"(%0 : $Builtin.FPIEEE80) : $Builtin.FPIEEE64
|
|
%2 = struct $Double (%1 : $Builtin.FPIEEE64)
|
|
%3 = struct_extract %2 : $Double, #Double._value
|
|
%4 = builtin "fptoui_FPIEEE64_Int8"(%3 : $Builtin.FPIEEE64) : $Builtin.Int8
|
|
%5 = struct $UInt8 (%4 : $Builtin.Int8)
|
|
return %5 : $UInt8
|
|
|
|
// CHECK-LABEL: sil @foldFPToUInt8UsingDouble
|
|
// CHECK-NOT: float_literal
|
|
// CHECK-NOT: builtin
|
|
// CHECK-NOT: struct $Double
|
|
// CHECK-NOT: struct_extract
|
|
// CHECK: [[LIT:%.*]] = integer_literal $Builtin.Int8, -1
|
|
// CHECK-NEXT: [[RES:%.*]] = struct $UInt8 ([[LIT]] : $Builtin.Int8)
|
|
// CHECK-NEXT: return [[RES]] : $UInt8
|
|
}
|
|
|
|
sil @foldFPToInt64 : $@convention(thin) () -> Builtin.Int64 {
|
|
bb0:
|
|
%0 = float_literal $Builtin.FPIEEE80, 0xC03DFFFFFFFFFFFFFFFE // -9223372036854775807
|
|
%1 = builtin "fptosi_FPIEEE80_Int64"(%0 : $Builtin.FPIEEE80) : $Builtin.Int64
|
|
return %1 : $Builtin.Int64
|
|
|
|
// CHECK-LABEL: sil @foldFPToInt64
|
|
// CHECK-NOT: float_literal
|
|
// CHECK-NOT: builtin
|
|
// CHECK: [[RES:%.*]] = integer_literal $Builtin.Int64, -9223372036854775807
|
|
// CHECK-NEXT: return [[RES]] : $Builtin.Int64
|
|
}
|
|
|
|
sil @foldFPToInt64Unsigned : $@convention(thin) () -> Builtin.Int64 {
|
|
bb0:
|
|
%0 = float_literal $Builtin.FPIEEE80, 0x403EFFFFFFFFFFFFFFFF // 18446744073709551615
|
|
%1 = builtin "fptoui_FPIEEE80_Int64"(%0 : $Builtin.FPIEEE80) : $Builtin.Int64
|
|
return %1 : $Builtin.Int64
|
|
|
|
// CHECK-LABEL: sil @foldFPToInt64Unsigned
|
|
// CHECK-NOT: float_literal
|
|
// CHECK-NOT: builtin
|
|
// CHECK: [[RES:%.*]] = integer_literal $Builtin.Int64, -1
|
|
// CHECK-NEXT: return [[RES]] : $Builtin.Int64
|
|
}
|
|
|
|
// The following tests check folding of FPTrunc instructions.
|
|
|
|
sil @foldFloat80ToFloat: $@convention(thin) () -> Builtin.FPIEEE32 {
|
|
bb0:
|
|
%0 = float_literal $Builtin.FPIEEE80, 0x407D96769950B50D88F4 // 9.99999999999999999993E+37
|
|
%1 = builtin "fptrunc_FPIEEE80_FPIEEE32"(%0 : $Builtin.FPIEEE80) : $Builtin.FPIEEE32
|
|
return %1 : $Builtin.FPIEEE32
|
|
|
|
// CHECK-LABEL: sil @foldFloat80ToFloat
|
|
// CHECK-NOT: float_literal $Builtin.FPIEEE80
|
|
// CHECK-NOT: builtin
|
|
// CHECK: [[RES:%.*]] = float_literal $Builtin.FPIEEE32, 0x7E967699 // 9.99999968E+37
|
|
// CHECK-NEXT: return [[RES]] : $Builtin.FPIEEE32
|
|
}
|
|
|
|
sil @foldFloat80ToDouble: $@convention(thin) () -> Builtin.FPIEEE64 {
|
|
bb0:
|
|
%0 = float_literal $Builtin.FPIEEE80, 0x43FE8E679C2F5E44FF8F // 9.99999999999999999966E+307
|
|
%1 = builtin "fptrunc_FPIEEE80_FPIEEE64"(%0 : $Builtin.FPIEEE80) : $Builtin.FPIEEE64
|
|
return %1 : $Builtin.FPIEEE64
|
|
|
|
// CHECK-LABEL: sil @foldFloat80ToDouble
|
|
// CHECK-NOT: float_literal $Builtin.FPIEEE80
|
|
// CHECK-NOT: builtin
|
|
// CHECK: [[RES:%.*]] = float_literal $Builtin.FPIEEE64, 0x7FE1CCF385EBC8A0 // 1.0E+308
|
|
// CHECK-NEXT: return [[RES]] : $Builtin.FPIEEE64
|
|
}
|
|
|
|
sil @foldFloat80ToFloat2: $@convention(thin) () -> Builtin.FPIEEE32 {
|
|
bb0:
|
|
%0 = float_literal $Builtin.FPIEEE80, 0x3F84881CEA14545C7575 // 9.9999999999999999995E-38
|
|
%1 = builtin "fptrunc_FPIEEE80_FPIEEE32"(%0 : $Builtin.FPIEEE80) : $Builtin.FPIEEE32
|
|
return %1 : $Builtin.FPIEEE32
|
|
|
|
// CHECK-LABEL: sil @foldFloat80ToFloat2
|
|
// CHECK-NOT: float_literal $Builtin.FPIEEE80
|
|
// CHECK-NOT: builtin
|
|
// CHECK: [[RES:%.*]] = float_literal $Builtin.FPIEEE32, 0x2081CEA // 9.99999991E-38
|
|
// CHECK-NEXT: return [[RES]] : $Builtin.FPIEEE32
|
|
}
|