| ; RUN: llc < %s -mtriple=armv4t-unknown-eabi | FileCheck %s -check-prefix=THUMB |
| ; RUN: llc < %s -mtriple=armv4-unknown-eabi -mcpu=strongarm | FileCheck %s -check-prefix=ARM |
| ; RUN: llc < %s -mtriple=armv7-unknown-eabi -mcpu=cortex-a8 | FileCheck %s -check-prefix=THUMB |
| ; RUN: llc < %s -mtriple=armv6-unknown-eabi | FileCheck %s -check-prefix=THUMB |
| ; RUN: llc < %s -mtriple=armv4-unknown-eabi | FileCheck %s -check-prefix=ARM |
| ; RUN: llc < %s -mtriple=armv4t-unknown-eabi | FileCheck %s -check-prefix=THUMB |
| |
| define i32 @test_return(i32 %a) nounwind readnone { |
| entry: |
| ; ARM-LABEL: test_return |
| ; ARM: mov pc |
| ; THUMB-LABEL: test_return |
| ; THUMB: bx |
| ret i32 %a |
| } |
| |
| @helper = global i32 ()* null, align 4 |
| |
| define i32 @test_indirect() #0 { |
| entry: |
| ; ARM-LABEL: test_indirect |
| ; ARM: mov pc |
| ; THUMB-LABEL: test_indirect |
| ; THUMB: bx |
| %0 = load i32 ()*, i32 ()** @helper, align 4 |
| %call = tail call i32 %0() |
| ret i32 %call |
| } |