|
| 1 | +; RUN: llvm-as < %s -o %t.bc |
| 2 | +; RUN: llvm-spirv %t.bc -o %t.spv |
| 3 | +; RUN: spirv-val %t.spv |
| 4 | +; RUN: llvm-spirv -to-text %t.spv -o - | FileCheck %s |
| 5 | +; RUN: llvm-spirv -r %t.spv -o %t.rev.bc |
| 6 | +; RUN: llvm-dis < %t.rev.bc | FileCheck %s --check-prefix=CHECK-LLVM |
| 7 | + |
| 8 | +target datalayout = "e-i64:64-v16:16-v24:32-v32:32-v48:64-v96:128-v192:256-v256:256-v512:512-v1024:1024-n8:16:32:64" |
| 9 | +target triple = "spir64-unknown-unknown" |
| 10 | + |
| 11 | +define i8 @getConstantI8() { |
| 12 | + ret i8 2 |
| 13 | +} |
| 14 | + |
| 15 | +define i16 @getConstantI16() { |
| 16 | + ret i16 -58 |
| 17 | +} |
| 18 | + |
| 19 | +define i32 @getConstantI32() { |
| 20 | + ret i32 42 |
| 21 | +} |
| 22 | + |
| 23 | +define i64 @getConstantI64() { |
| 24 | + ret i64 123456789 |
| 25 | +} |
| 26 | + |
| 27 | +define i64 @getLargeConstantI64() { |
| 28 | + ret i64 34359738368 |
| 29 | +} |
| 30 | + |
| 31 | +; CHECK: Capability Int64 |
| 32 | +; CHECK: Capability Int16 |
| 33 | +; CHECK: Capability Int8 |
| 34 | +; CHECK: Name [[#I8_FUNC:]] "getConstantI8" |
| 35 | +; CHECK: Name [[#I16_FUNC:]] "getConstantI16" |
| 36 | +; CHECK: Name [[#I32_FUNC:]] "getConstantI32" |
| 37 | +; CHECK: Name [[#I64_FUNC:]] "getConstantI64" |
| 38 | +; CHECK: Name [[#LARGE_I64_FUNC:]] "getLargeConstantI64" |
| 39 | + |
| 40 | +; CHECK: TypeInt [[#I8_TY:]] 8 0 |
| 41 | +; CHECK: TypeInt [[#I16_TY:]] 16 0 |
| 42 | +; CHECK: TypeInt [[#I32_TY:]] 32 0 |
| 43 | +; CHECK: TypeInt [[#I64_TY:]] 64 0 |
| 44 | +; CHECK: Constant [[#I8_TY]] [[#I8_CONST:]] 2 |
| 45 | +; CHECK: Constant [[#I16_TY]] [[#I16_CONST:]] 65478 |
| 46 | +; CHECK: Constant [[#I32_TY]] [[#I32_CONST:]] 42 |
| 47 | +; CHECK: Constant [[#I64_TY]] [[#I64_CONST:]] 123456789 0 |
| 48 | +; For 34359738368 = 0x00000008 00000000, so represented as 0 8 |
| 49 | +; CHECK: Constant [[#I64_TY]] [[#LARGE_I64_CONST:]] 0 8 |
| 50 | + |
| 51 | +; CHECK: Function [[#I8_TY]] [[#I8_FUNC]] 0 [[#]] |
| 52 | +; CHECK: ReturnValue [[#I8_CONST]] |
| 53 | +; CHECK: FunctionEnd |
| 54 | + |
| 55 | +; CHECK: Function [[#I16_TY]] [[#I16_FUNC]] 0 [[#]] |
| 56 | +; CHECK: ReturnValue [[#I16_CONST]] |
| 57 | +; CHECK: FunctionEnd |
| 58 | + |
| 59 | +; CHECK: Function [[#I32_TY]] [[#I32_FUNC]] 0 [[#]] |
| 60 | +; CHECK: ReturnValue [[#I32_CONST]] |
| 61 | +; CHECK: FunctionEnd |
| 62 | + |
| 63 | +; CHECK: Function [[#I64_TY]] [[#I64_FUNC]] 0 [[#]] |
| 64 | +; CHECK: ReturnValue [[#I64_CONST]] |
| 65 | +; CHECK: FunctionEnd |
| 66 | + |
| 67 | +; CHECK: Function [[#I64_TY]] [[#LARGE_I64_FUNC]] 0 [[#]] |
| 68 | +; CHECK: ReturnValue [[#LARGE_I64_CONST]] |
| 69 | +; CHECK: FunctionEnd |
| 70 | + |
| 71 | +; CHECK-LLVM: ret i8 2 |
| 72 | +; CHECK-LLVM: ret i16 -58 |
| 73 | +; CHECK-LLVM: ret i32 42 |
| 74 | +; CHECK-LLVM: ret i64 123456789 |
| 75 | +; CHECK-LLVM: ret i64 34359738368 |
0 commit comments