|  | //===---- PPCCCState.h - CCState with PowerPC specific extensions -----------===// | 
|  | // | 
|  | // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. | 
|  | // See https://llvm.org/LICENSE.txt for license information. | 
|  | // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception | 
|  | // | 
|  | //===----------------------------------------------------------------------===// | 
|  |  | 
|  | #ifndef PPCCCSTATE_H | 
|  | #define PPCCCSTATE_H | 
|  |  | 
|  | #include "PPCISelLowering.h" | 
|  | #include "llvm/ADT/BitVector.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(); } | 
|  | }; | 
|  |  | 
|  | class AIXCCState : public CCState { | 
|  | private: | 
|  | BitVector IsFixed; | 
|  |  | 
|  | public: | 
|  | AIXCCState(CallingConv::ID CC, bool IsVarArg, MachineFunction &MF, | 
|  | SmallVectorImpl<CCValAssign> &Locs, LLVMContext &C) | 
|  | : CCState(CC, IsVarArg, MF, Locs, C) {} | 
|  |  | 
|  | void AnalyzeFormalArguments(const SmallVectorImpl<ISD::InputArg> &Ins, | 
|  | CCAssignFn Fn) { | 
|  | // All formal arguments are fixed. | 
|  | IsFixed.resize(Ins.size(), true); | 
|  | CCState::AnalyzeFormalArguments(Ins, Fn); | 
|  | } | 
|  |  | 
|  | void AnalyzeCallOperands(const SmallVectorImpl<ISD::OutputArg> &Outs, | 
|  | CCAssignFn Fn) { | 
|  | // Record whether the call operand was a fixed argument. | 
|  | IsFixed.resize(Outs.size(), false); | 
|  | for (unsigned ValNo = 0, E = Outs.size(); ValNo != E; ++ValNo) | 
|  | if (Outs[ValNo].IsFixed) | 
|  | IsFixed.set(ValNo); | 
|  |  | 
|  | CCState::AnalyzeCallOperands(Outs, Fn); | 
|  | } | 
|  |  | 
|  | bool isFixed(unsigned ValNo) const { return IsFixed.test(ValNo); } | 
|  | }; | 
|  |  | 
|  | } // end namespace llvm | 
|  |  | 
|  | #endif |