1
0
mirror of https://github.com/RPCS3/llvm-mirror.git synced 2024-11-01 08:23:21 +01:00
llvm-mirror/test/CodeGen/X86/switch-or.ll
Benjamin Kramer 632a91cba5 Implement the "if (X == 6 || X == 4)" -> "if ((X|2) == 6)" optimization.
This currently only catches the most basic case, a two-case switch, but can be
extended later.

llvm-svn: 119964
2010-11-22 09:45:38 +00:00

23 lines
433 B
LLVM

; RUN: llc -march=x86 -asm-verbose=false < %s | FileCheck %s
; Check that merging switch cases that differ in one bit works.
; CHECK: orl $2
; CHECK-NEXT: cmpl $6
define void @foo(i32 %variable) nounwind {
entry:
switch i32 %variable, label %if.end [
i32 4, label %if.then
i32 6, label %if.then
]
if.then:
%call = tail call i32 (...)* @bar() nounwind
ret void
if.end:
ret void
}
declare i32 @bar(...) nounwind