From 69762f7e1ee851865da0ec831439da188b0e3a66 Mon Sep 17 00:00:00 2001 From: David Woodhouse Date: Tue, 28 Jan 2014 23:13:30 +0000 Subject: [PATCH] Tests for mode switching 1. test that inlineasm works 2. test that relaxable instructions are re-encoded in the correct mode. llvm-svn: 200351 --- test/CodeGen/ARM/inlineasm-mode-switch.ll | 23 +++++++++++++++++++++++ test/MC/ARM/fixup-cpu-mode.s | 9 +++++++++ test/MC/X86/fixup-cpu-mode.s | 8 ++++++++ 3 files changed, 40 insertions(+) create mode 100644 test/CodeGen/ARM/inlineasm-mode-switch.ll create mode 100644 test/MC/ARM/fixup-cpu-mode.s create mode 100644 test/MC/X86/fixup-cpu-mode.s diff --git a/test/CodeGen/ARM/inlineasm-mode-switch.ll b/test/CodeGen/ARM/inlineasm-mode-switch.ll new file mode 100644 index 00000000000..8c21bca86db --- /dev/null +++ b/test/CodeGen/ARM/inlineasm-mode-switch.ll @@ -0,0 +1,23 @@ +; RUN: llc < %s -mtriple thumbv7-linux -filetype=obj -o %t +; Two pass decoding needed because llvm-objdump does not respect mapping symbols +; RUN: llvm-objdump -triple thumbv7-linux -d %t | FileCheck --check-prefix=THUMB %s +; RUN: llvm-objdump -triple armv7-linux -d %t | FileCheck --check-prefix=ARM %s + +; THUMB: foo: +; THUMB: a: 18 47 bx r3 +; THUMB: 28: 70 47 bx lr + +; ARM: foo: +; ARM: 10: 04 70 2d e5 str r7, [sp, #-4]! + +define void @foo(i8* %start, i64 %size) { +entry: + %0 = ptrtoint i8* %start to i32 + %conv = zext i32 %0 to i64 + %add = add i64 %conv, %size + %conv1 = trunc i64 %add to i32 + %1 = tail call i32 asm sideeffect "@ Enter ARM Mode \0A\09adr r3, 1f \0A\09bx r3 \0A\09.align 4 \0A\09.arm \0A1: push {r7} \0A\09mov r7, $4 \0A\09add r1, r2, r3 \0A\09pop {r7} \0A\09@ Enter THUMB Mode\0A\09adr r3, 2f+1 \0A\09bx r3 \0A\09.thumb \0A2: \0A\09", "={r0},{r0},{r1},{r2},r,~{r3}"(i32 %0, i32 %conv1, i32 0, i32 254) + ret void +} + + diff --git a/test/MC/ARM/fixup-cpu-mode.s b/test/MC/ARM/fixup-cpu-mode.s new file mode 100644 index 00000000000..17f29f94d2d --- /dev/null +++ b/test/MC/ARM/fixup-cpu-mode.s @@ -0,0 +1,9 @@ +// RUN: llvm-mc -filetype=obj -triple thumbv7-linux-gnu %s -o %t +// RUN: llvm-objdump -triple thumbv7-linux-gnu -d %t | FileCheck %s + +//PR18303 +.code 16 +.global edata +b edata // CHECK: b.w +.code 32 + diff --git a/test/MC/X86/fixup-cpu-mode.s b/test/MC/X86/fixup-cpu-mode.s new file mode 100644 index 00000000000..13e0d462156 --- /dev/null +++ b/test/MC/X86/fixup-cpu-mode.s @@ -0,0 +1,8 @@ +// RUN: llvm-mc -filetype=obj -triple x86_64-pc-linux-gnu %s -o %t +// RUN: llvm-objdump -d %t | FileCheck %s + +//PR18303 +.global edata +sub $edata, %r12 // CHECK: subq $0, %r12 +.code32 +