;; __kernel void test_switch(__global int* res, uchar val) ;; { ;; switch(val) ;; { ;; case 0: ;; *res = 1; ;; break; ;; case 1: ;; *res = 2; ;; break; ;; case 2: ;; *res = 3; ;; break; ;; } ;; } ; RUN: llc -O0 -mtriple=spirv32-unknown-unknown %s -o - | FileCheck %s --check-prefix=CHECK-SPIRV ; CHECK-SPIRV: OpSwitch %[[#]] %[[#]] 0 %[[#]] 1 %[[#]] 2 %[[#]] define spir_kernel void @test_switch(i32 addrspace(1)* %res, i8 zeroext %val) { entry: %res.addr = alloca i32 addrspace(1)*, align 4 %val.addr = alloca i8, align 1 store i32 addrspace(1)* %res, i32 addrspace(1)** %res.addr, align 4 store i8 %val, i8* %val.addr, align 1 %0 = load i8, i8* %val.addr, align 1 switch i8 %0, label %sw.epilog [ i8 0, label %sw.bb i8 1, label %sw.bb1 i8 2, label %sw.bb2 ] sw.bb: ; preds = %entry %1 = load i32 addrspace(1)*, i32 addrspace(1)** %res.addr, align 4 store i32 1, i32 addrspace(1)* %1, align 4 br label %sw.epilog sw.bb1: ; preds = %entry %2 = load i32 addrspace(1)*, i32 addrspace(1)** %res.addr, align 4 store i32 2, i32 addrspace(1)* %2, align 4 br label %sw.epilog sw.bb2: ; preds = %entry %3 = load i32 addrspace(1)*, i32 addrspace(1)** %res.addr, align 4 store i32 3, i32 addrspace(1)* %3, align 4 br label %sw.epilog sw.epilog: ; preds = %entry, %sw.bb2, %sw.bb1, %sw.bb ret void }