llvm/llvm/test/CodeGen/SPIRV/literals.ll

; RUN: llc -verify-machineinstrs -O0 -mtriple=spirv32-unknown-unknown %s -o - | FileCheck %s
; RUN: %if spirv-tools %{ llc -O0 -mtriple=spirv32-unknown-unknown %s -o - -filetype=obj | spirv-val %}

; RUN: llc -verify-machineinstrs -O0 -mtriple=spirv64-unknown-unknown %s -o - | FileCheck %s
; RUN: %if spirv-tools %{ llc -O0 -mtriple=spirv64-unknown-unknown %s -o - -filetype=obj | spirv-val %}

; RUN: llc -verify-machineinstrs -O0 -mtriple=spirv-unknown-unknown %s -o - | FileCheck %s
; RUN: %if spirv-tools %{ llc -O0 -mtriple=spirv-unknown-unknown %s -o - -filetype=obj | spirv-val %}

; CHECK: %[[#F32:]] = OpTypeFloat 32
; CHECK: %[[#F64:]] = OpTypeFloat 64

define void @main() {
entry:

; CHECK: OpConstant %[[#F32]] 0.5
  %f = alloca float, align 4
  store float 5.000000e-01, ptr %f, align 4

; CHECK: OpConstant %[[#F64]] 0.5
  %d = alloca double, align 8
  store double 5.000000e-01, ptr %d, align 8

; CHECK: OpConstant %[[#F32]] 1.0000016166037976e-39
  %hexf = alloca float, align 4
  store float 0x37D5C73200000000, ptr %hexf, align 4

; CHECK: OpConstant %[[#F32]] 0x1p+128
  %inf = alloca float, align 4
  store float 0x7FF0000000000000, ptr %inf, align 4

; CHECK: OpConstant %[[#F32]] -0x1p+128
  %ninf = alloca float, align 4
  store float 0xFFF0000000000000, ptr %ninf, align 4

; CHECK: OpConstant %[[#F32]] 0x1.8p+128
  %nan = alloca float, align 4
  store float 0x7FF8000000000000, ptr %nan, align 4

  ret void
}