summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Target/PowerPC/PPCCCState.cpp
diff options
context:
space:
mode:
authorStrahinja Petrovic <strahinja.petrovic@rt-rk.com>2016-05-09 12:27:39 +0000
committerStrahinja Petrovic <strahinja.petrovic@rt-rk.com>2016-05-09 12:27:39 +0000
commite682b80b8bf410abd9ee1040a643fd4e31413fa2 (patch)
tree7eb75f248c9cdb53b553e7748544d96b3b8c1116 /llvm/lib/Target/PowerPC/PPCCCState.cpp
parente3b8645a1c223237a099243205c1b0b2e587569d (diff)
downloadbcm5719-llvm-e682b80b8bf410abd9ee1040a643fd4e31413fa2.tar.gz
bcm5719-llvm-e682b80b8bf410abd9ee1040a643fd4e31413fa2.zip
[PowerPC] fix register alignment for long double type
This patch fixes register alignment for long double type in soft float mode. Before this patch alignment was 8 and this patch changes it to 4. Differential Revision: http://reviews.llvm.org/D18034 llvm-svn: 268909
Diffstat (limited to 'llvm/lib/Target/PowerPC/PPCCCState.cpp')
-rw-r--r--llvm/lib/Target/PowerPC/PPCCCState.cpp36
1 files changed, 36 insertions, 0 deletions
diff --git a/llvm/lib/Target/PowerPC/PPCCCState.cpp b/llvm/lib/Target/PowerPC/PPCCCState.cpp
new file mode 100644
index 00000000000..5510a95430f
--- /dev/null
+++ b/llvm/lib/Target/PowerPC/PPCCCState.cpp
@@ -0,0 +1,36 @@
+//===---- PPCCCState.cpp - CCState with PowerPC specific extensions ---------===//
+//
+// The LLVM Compiler Infrastructure
+//
+// This file is distributed under the University of Illinois Open Source
+// License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+
+#include "PPCCCState.h"
+#include "PPCSubtarget.h"
+#include "llvm/IR/Module.h"
+using namespace llvm;
+
+// Identify lowered values that originated from ppcf128 arguments and record
+// this.
+void PPCCCState::PreAnalyzeCallOperands(
+ const SmallVectorImpl<ISD::OutputArg> &Outs) {
+ for (const auto &I : Outs) {
+ if (I.ArgVT == llvm::MVT::ppcf128)
+ OriginalArgWasPPCF128.push_back(true);
+ else
+ OriginalArgWasPPCF128.push_back(false);
+ }
+}
+
+void PPCCCState::PreAnalyzeFormalArguments(
+ const SmallVectorImpl<ISD::InputArg> &Ins) {
+ for (const auto &I : Ins) {
+ if (I.ArgVT == llvm::MVT::ppcf128) {
+ OriginalArgWasPPCF128.push_back(true);
+ } else {
+ OriginalArgWasPPCF128.push_back(false);
+ }
+ }
+} \ No newline at end of file
OpenPOWER on IntegriCloud