mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-30 02:32:08 +00:00
9f23dee08c
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@101638 91177308-0d34-0410-b5e6-96231b3b80d8
54 lines
1.2 KiB
LLVM
54 lines
1.2 KiB
LLVM
; RUN: llc < %s -march=bfin -verify-machineinstrs | FileCheck %s
|
|
|
|
; CHECK: .section .rodata
|
|
; CHECK: JTI0_0:
|
|
; CHECK: .long .BB0_1
|
|
|
|
define i32 @oper(i32 %op, i32 %A, i32 %B) {
|
|
entry:
|
|
switch i32 %op, label %bbx [
|
|
i32 1 , label %bb1
|
|
i32 2 , label %bb2
|
|
i32 3 , label %bb3
|
|
i32 4 , label %bb4
|
|
i32 5 , label %bb5
|
|
i32 6 , label %bb6
|
|
i32 7 , label %bb7
|
|
i32 8 , label %bb8
|
|
i32 9 , label %bb9
|
|
i32 10, label %bb10
|
|
]
|
|
bb1:
|
|
%R1 = add i32 %A, %B ; <i32> [#uses=1]
|
|
ret i32 %R1
|
|
bb2:
|
|
%R2 = sub i32 %A, %B ; <i32> [#uses=1]
|
|
ret i32 %R2
|
|
bb3:
|
|
%R3 = mul i32 %A, %B ; <i32> [#uses=1]
|
|
ret i32 %R3
|
|
bb4:
|
|
%R4 = sdiv i32 %A, %B ; <i32> [#uses=1]
|
|
ret i32 %R4
|
|
bb5:
|
|
%R5 = udiv i32 %A, %B ; <i32> [#uses=1]
|
|
ret i32 %R5
|
|
bb6:
|
|
%R6 = srem i32 %A, %B ; <i32> [#uses=1]
|
|
ret i32 %R6
|
|
bb7:
|
|
%R7 = urem i32 %A, %B ; <i32> [#uses=1]
|
|
ret i32 %R7
|
|
bb8:
|
|
%R8 = and i32 %A, %B ; <i32> [#uses=1]
|
|
ret i32 %R8
|
|
bb9:
|
|
%R9 = or i32 %A, %B ; <i32> [#uses=1]
|
|
ret i32 %R9
|
|
bb10:
|
|
%R10 = xor i32 %A, %B ; <i32> [#uses=1]
|
|
ret i32 %R10
|
|
bbx:
|
|
ret i32 0
|
|
}
|