diff options
| author | Strahinja Petrovic <strahinja.petrovic@rt-rk.com> | 2016-05-09 12:27:39 +0000 |
|---|---|---|
| committer | Strahinja Petrovic <strahinja.petrovic@rt-rk.com> | 2016-05-09 12:27:39 +0000 |
| commit | e682b80b8bf410abd9ee1040a643fd4e31413fa2 (patch) | |
| tree | 7eb75f248c9cdb53b553e7748544d96b3b8c1116 /llvm/lib/Target/PowerPC/PPCCCState.h | |
| parent | e3b8645a1c223237a099243205c1b0b2e587569d (diff) | |
| download | bcm5719-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.h')
| -rw-r--r-- | llvm/lib/Target/PowerPC/PPCCCState.h | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/llvm/lib/Target/PowerPC/PPCCCState.h b/llvm/lib/Target/PowerPC/PPCCCState.h new file mode 100644 index 00000000000..9be9f11dbea --- /dev/null +++ b/llvm/lib/Target/PowerPC/PPCCCState.h @@ -0,0 +1,42 @@ +//===---- PPCCCState.h - 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. +// +//===----------------------------------------------------------------------===// + +#ifndef PPCCCSTATE_H +#define PPCCCSTATE_H + +#include "PPCISelLowering.h" +#include "llvm/ADT/SmallVector.h" +#include "llvm/CodeGen/CallingConvLower.h" + +namespace llvm { + +class PPCCCState : public CCState { +public: + + void + PreAnalyzeCallOperands(const SmallVectorImpl<ISD::OutputArg> &Outs); + void + PreAnalyzeFormalArguments(const SmallVectorImpl<ISD::InputArg> &Ins); + +private: + + // Records whether the value has been lowered from an ppcf128. + SmallVector<bool, 4> OriginalArgWasPPCF128; + +public: + PPCCCState(CallingConv::ID CC, bool isVarArg, MachineFunction &MF, + SmallVectorImpl<CCValAssign> &locs, LLVMContext &C) + : CCState(CC, isVarArg, MF, locs, C) {} + + bool WasOriginalArgPPCF128(unsigned ValNo) { return OriginalArgWasPPCF128[ValNo]; } + void clearWasPPCF128() { OriginalArgWasPPCF128.clear(); } +}; +} + +#endif |

