Files
clang-p2996/llvm/test/CodeGen/MSP430/jumptable.ll
Vadzim Dambrouski eafb805506 [MSP430] Add SRet support to MSP430 target
This patch adds support for struct return values to the MSP430
target backend. It also reverses the order of argument and return
registers in the calling convention to bring it into closer
alignment with the published EABI from TI.

Patch by Andrew Wygle (awygle).

Differential Revision: https://reviews.llvm.org/D29069

llvm-svn: 296807
2017-03-02 20:25:10 +00:00

55 lines
1.4 KiB
LLVM

; RUN: llc < %s | FileCheck %s
target datalayout = "e-p:16:16:16-i8:8:8-i16:16:16-i32:16:32-n8:16"
target triple = "msp430---elf"
; Function Attrs: nounwind
define i16 @test(i16 %i) #0 {
entry:
; CHECK-LABEL: test:
%retval = alloca i16, align 2
%i.addr = alloca i16, align 2
store i16 %i, i16* %i.addr, align 2
%0 = load i16, i16* %i.addr, align 2
; CHECK: mov.w #2, r13
; CHECK: call #__mulhi3hw_noint
; CHECK: br .LJTI0_0(r12)
switch i16 %0, label %sw.default [
i16 0, label %sw.bb
i16 1, label %sw.bb1
i16 2, label %sw.bb2
i16 3, label %sw.bb3
]
sw.bb: ; preds = %entry
store i16 0, i16* %retval
br label %return
sw.bb1: ; preds = %entry
store i16 1, i16* %retval
br label %return
sw.bb2: ; preds = %entry
store i16 2, i16* %retval
br label %return
sw.bb3: ; preds = %entry
store i16 3, i16* %retval
br label %return
sw.default: ; preds = %entry
store i16 2, i16* %retval
br label %return
return: ; preds = %sw.default, %sw.bb3, %sw.bb2, %sw.bb1, %sw.bb
%1 = load i16, i16* %retval
ret i16 %1
; CHECK: ret
}
; CHECK: .LJTI0_0:
; CHECK-NEXT: .short .LBB0_2
; CHECK-NEXT: .short .LBB0_4
; CHECK-NEXT: .short .LBB0_3
; CHECK-NEXT: .short .LBB0_5