74 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C++
		
	
	
	
			
		
		
	
	
			74 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C++
		
	
	
	
//===---- 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
 |