llvm/lib/Target/PowerPC/PPCCCState.h
Strahinja Petrovic a16fdea51a [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



git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@268909 91177308-0d34-0410-b5e6-96231b3b80d8
2016-05-09 12:27:39 +00:00

43 lines
1.2 KiB
C++

//===---- 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