| ; RUN: llc -verify-machineinstrs -O0 -mtriple=spirv32-unknown-unknown %s -o - | FileCheck %s |
| |
| ;; FIXME: Are there any attributes that would make the IR invalid for SPIR-V? |
| |
| ;; Names: |
| ; CHECK-DAG: OpName %[[#FN1:]] "fn1" |
| ; CHECK-DAG: OpName %[[#FN2:]] "fn2" |
| ; CHECK-DAG: OpName %[[#FN3:]] "fn3" |
| ; CHECK-DAG: OpName %[[#FN4:]] "fn4" |
| ; CHECK-DAG: OpName %[[#FN5:]] "fn5" |
| ; CHECK-DAG: OpName %[[#FN6:]] "fn6" |
| ; CHECK-DAG: OpName %[[#FN7:]] "fn7" |
| ; CHECK-DAG: OpName %[[#FN8:]] "fn8" |
| ; CHECK-DAG: OpName %[[#FN9:]] "fn9" |
| |
| ;; Types: |
| ; CHECK: %[[#VOID:]] = OpTypeVoid |
| ; CHECK: %[[#FN:]] = OpTypeFunction %[[#VOID]] |
| |
| |
| ;; Functions: |
| |
| define void @fn1() noinline { |
| ret void |
| } |
| ; CHECK: %[[#FN1]] = OpFunction %[[#VOID]] DontInline %[[#FN]] |
| ; CHECK-NOT: OpFunctionParameter |
| ; CHECK: OpFunctionEnd |
| |
| |
| attributes #0 = { noinline } |
| define void @fn2() #0 { |
| ret void |
| } |
| ; CHECK: %[[#FN2]] = OpFunction %[[#VOID]] DontInline %[[#FN]] |
| ; CHECK: OpFunctionEnd |
| |
| |
| define void @fn3() alwaysinline { |
| ret void |
| } |
| ; CHECK: %[[#FN3]] = OpFunction %[[#VOID]] Inline %[[#FN]] |
| ; CHECK: OpFunctionEnd |
| |
| |
| ;; NOTE: inlinehint is not an actual requirement. |
| define void @fn4() inlinehint { |
| ret void |
| } |
| ; CHECK: %[[#FN4]] = OpFunction %[[#VOID]] None %[[#FN]] |
| ; CHECK: OpFunctionEnd |
| |
| |
| define void @fn5() readnone { |
| ret void |
| } |
| ; CHECK: %[[#FN5]] = OpFunction %[[#VOID]] Pure %[[#FN]] |
| ; CHECK: OpFunctionEnd |
| |
| |
| define void @fn6() memory(none) { |
| ret void |
| } |
| ; CHECK: %[[#FN6]] = OpFunction %[[#VOID]] Pure %[[#FN]] |
| ; CHECK: OpFunctionEnd |
| |
| |
| define void @fn7() readonly { |
| ret void |
| } |
| ; CHECK: %[[#FN7]] = OpFunction %[[#VOID]] Const %[[#FN]] |
| ; CHECK: OpFunctionEnd |
| |
| |
| define void @fn8() memory(read) { |
| ret void |
| } |
| ; CHECK: %[[#FN8]] = OpFunction %[[#VOID]] Const %[[#FN]] |
| ; CHECK: OpFunctionEnd |
| |
| |
| define void @fn9() alwaysinline readnone { |
| ret void |
| } |
| ; CHECK: %[[#FN9]] = OpFunction %[[#VOID]] Inline|Pure %[[#FN]] |
| ; CHECK: OpFunctionEnd |