diff options
author | Nemanja Ivanovic <nemanja.i.ibm@gmail.com> | 2019-12-28 11:20:36 -0600 |
---|---|---|
committer | Nemanja Ivanovic <nemanja.i.ibm@gmail.com> | 2019-12-28 11:20:52 -0600 |
commit | a9ad65a2b34f9cbcd207114caa862ef2dc4553c8 (patch) | |
tree | 5d3be0d1f9d8c9e7fa34c08abbadefa71624a76c /llvm/test/CodeGen/PowerPC | |
parent | 34769e0783586c0502567785656ef3c60ef08395 (diff) | |
download | bcm5719-llvm-a9ad65a2b34f9cbcd207114caa862ef2dc4553c8.tar.gz bcm5719-llvm-a9ad65a2b34f9cbcd207114caa862ef2dc4553c8.zip |
[PowerPC] Change default for unaligned FP access for older subtargets
This is a fix for https://bugs.llvm.org/show_bug.cgi?id=40554
Some CPU's trap to the kernel on unaligned floating point access and there are
kernels that do not handle the interrupt. The program then fails with a SIGBUS
according to the PR. This just switches the default for unaligned access to only
allow it on recent server CPUs that are known to allow this.
Differential revision: https://reviews.llvm.org/D71954
Diffstat (limited to 'llvm/test/CodeGen/PowerPC')
-rw-r--r-- | llvm/test/CodeGen/PowerPC/2007-09-08-unaligned.ll | 3 | ||||
-rw-r--r-- | llvm/test/CodeGen/PowerPC/unaligned-floats.ll | 43 |
2 files changed, 45 insertions, 1 deletions
diff --git a/llvm/test/CodeGen/PowerPC/2007-09-08-unaligned.ll b/llvm/test/CodeGen/PowerPC/2007-09-08-unaligned.ll index 86efa0217b6..41ef5ccd0f9 100644 --- a/llvm/test/CodeGen/PowerPC/2007-09-08-unaligned.ll +++ b/llvm/test/CodeGen/PowerPC/2007-09-08-unaligned.ll @@ -1,4 +1,5 @@ -; RUN: llc -verify-machineinstrs -mattr=-vsx < %s | FileCheck %s +; RUN: llc -verify-machineinstrs -mattr=-vsx \ +; RUN: -mattr=+allow-unaligned-fp-access < %s | FileCheck %s ; ModuleID = 'foo.c' target triple = "powerpc-unknown-linux-gnu" diff --git a/llvm/test/CodeGen/PowerPC/unaligned-floats.ll b/llvm/test/CodeGen/PowerPC/unaligned-floats.ll new file mode 100644 index 00000000000..af7d36ac1d0 --- /dev/null +++ b/llvm/test/CodeGen/PowerPC/unaligned-floats.ll @@ -0,0 +1,43 @@ +; RUN: llc -mcpu=pwr7 -ppc-asm-full-reg-names -mtriple=powerpc-- \ +; RUN: -verify-machineinstrs < %s | FileCheck %s +; RUN: llc -mattr=allow-unaligned-fp-access -ppc-asm-full-reg-names \ +; RUN: -mtriple=powerpc-- -verify-machineinstrs < %s | FileCheck %s +; RUN: llc -ppc-asm-full-reg-names -mtriple=powerpc-- \ +; RUN: -verify-machineinstrs < %s | FileCheck %s --check-prefix=UNALIGN + +; Test case as provided by author in https://bugs.llvm.org/show_bug.cgi?id=40554 +%struct.anon = type { i32, [5 x i8] } + +@s = dso_local local_unnamed_addr global %struct.anon { i32 0, [5 x i8] c"\00B\F6\E9y" }, align 4 +@.str = private unnamed_addr constant [4 x i8] c"%g\0A\00", align 1 +; Function Attrs: nofree nounwind +define dso_local i32 @main() local_unnamed_addr { +; CHECK-LABEL: main: +; CHECK: lfs f1, 5(r3) +; CHECK: blr +; +; UNALIGN-LABEL: main: +; UNALIGN: lfs f1, 12(r1) +; UNALIGN: blr +entry: + %0 = load i8, i8* getelementptr inbounds (%struct.anon, %struct.anon* @s, i32 0, i32 1, i32 1), align 1 + %conv = zext i8 %0 to i32 + %shl = shl nuw i32 %conv, 24 + %1 = load i8, i8* getelementptr inbounds (%struct.anon, %struct.anon* @s, i32 0, i32 1, i32 2), align 2 + %conv1 = zext i8 %1 to i32 + %shl2 = shl nuw nsw i32 %conv1, 16 + %add = or i32 %shl2, %shl + %2 = load i8, i8* getelementptr inbounds (%struct.anon, %struct.anon* @s, i32 0, i32 1, i32 3), align 1 + %conv3 = zext i8 %2 to i32 + %shl4 = shl nuw nsw i32 %conv3, 8 + %add5 = or i32 %add, %shl4 + %3 = load i8, i8* getelementptr inbounds (%struct.anon, %struct.anon* @s, i32 0, i32 1, i32 4), align 4 + %conv6 = zext i8 %3 to i32 + %add7 = or i32 %add5, %conv6 + %4 = bitcast i32 %add7 to float + %conv8 = fpext float %4 to double + %call = tail call i32 (i8*, ...) @printf(i8* nonnull dereferenceable(1) getelementptr inbounds ([4 x i8], [4 x i8]* @.str, i32 0, i32 0), double %conv8) + ret i32 0 +} +; Function Attrs: nofree nounwind +declare i32 @printf(i8* nocapture readonly, ...) local_unnamed_addr |