; RUN: llc -mtriple=x86_64-none-linux < %s | FileCheck %s ; Check that all current floating-point types are correctly emitted to assembly ; on a little-endian target. @var128 = global fp128 0xL00000000000000008000000000000000, align 16 @varppc128 = global ppc_fp128 0xM80000000000000000000000000000000, align 16 @var80 = global x86_fp80 0xK80000000000000000000, align 16 @var64 = global double -0.0, align 8 @var32 = global float -0.0, align 4 @var16 = global half -0.0, align 2 @var4f32 = global <4 x float> <float -0.0, float 0.0, float 1.0, float 2.0> @var4f16 = global <4 x half> <half -0.0, half 0.0, half 1.0, half 2.0> ; CHECK: var128: ; CHECK-NEXT: .quad 0 # fp128 -0 ; CHECK-NEXT: .quad -9223372036854775808 ; CHECK-NEXT: .size ; CHECK: varppc128: ; For ppc_fp128, the high double always comes first. ; CHECK-NEXT: .quad -9223372036854775808 # ppc_fp128 -0 ; CHECK-NEXT: .quad 0 ; CHECK-NEXT: .size ; CHECK: var80: ; CHECK-NEXT: .quad 0 # x86_fp80 -0 ; CHECK-NEXT: .short 32768 ; CHECK-NEXT: .zero 6 ; CHECK-NEXT: .size ; CHECK: var64: ; CHECK-NEXT: .quad -9223372036854775808 # double -0 ; CHECK-NEXT: .size ; CHECK: var32: ; CHECK-NEXT: .long 2147483648 # float -0 ; CHECK-NEXT: .size ; CHECK: var16: ; CHECK-NEXT: .short 32768 # half -0 ; CHECK-NEXT: .size ; CHECK: var4f32: ; CHECK-NEXT: .long 2147483648 # float -0 ; CHECK-NEXT: .long 0 # float 0 ; CHECK-NEXT: .long 1065353216 # float 1 ; CHECK-NEXT: .long 1073741824 # float 2 ; CHECK-NEXT: .size ; CHECK: var4f16: ; CHECK-NEXT: .short 32768 # half -0 ; CHECK-NEXT: .short 0 # half 0 ; CHECK-NEXT: .short 15360 # half 1 ; CHECK-NEXT: .short 16384 # half 2 ; CHECK-NEXT: .size