10b57cec5SDimitry Andric //===-- X86MachineFunctionInfo.cpp - X86 machine function info ------------===// 20b57cec5SDimitry Andric // 30b57cec5SDimitry Andric // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 40b57cec5SDimitry Andric // See https://llvm.org/LICENSE.txt for license information. 50b57cec5SDimitry Andric // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 60b57cec5SDimitry Andric // 70b57cec5SDimitry Andric //===----------------------------------------------------------------------===// 80b57cec5SDimitry Andric 90b57cec5SDimitry Andric #include "X86MachineFunctionInfo.h" 100b57cec5SDimitry Andric #include "X86RegisterInfo.h" 110b57cec5SDimitry Andric #include "llvm/CodeGen/MachineRegisterInfo.h" 120b57cec5SDimitry Andric #include "llvm/CodeGen/TargetSubtargetInfo.h" 130b57cec5SDimitry Andric 140b57cec5SDimitry Andric using namespace llvm; 150b57cec5SDimitry Andric X86MachineFunctionInfo(const llvm::X86MachineFunctionInfo & MFI)16*0fca6ea1SDimitry Andricyaml::X86MachineFunctionInfo::X86MachineFunctionInfo( 17*0fca6ea1SDimitry Andric const llvm::X86MachineFunctionInfo &MFI) 18*0fca6ea1SDimitry Andric : AMXProgModel(MFI.getAMXProgModel()) {} 19*0fca6ea1SDimitry Andric mappingImpl(yaml::IO & YamlIO)20*0fca6ea1SDimitry Andricvoid yaml::X86MachineFunctionInfo::mappingImpl(yaml::IO &YamlIO) { 21*0fca6ea1SDimitry Andric MappingTraits<X86MachineFunctionInfo>::mapping(YamlIO, *this); 22*0fca6ea1SDimitry Andric } 23*0fca6ea1SDimitry Andric clone(BumpPtrAllocator & Allocator,MachineFunction & DestMF,const DenseMap<MachineBasicBlock *,MachineBasicBlock * > & Src2DstMBB) const2481ad6265SDimitry AndricMachineFunctionInfo *X86MachineFunctionInfo::clone( 2581ad6265SDimitry Andric BumpPtrAllocator &Allocator, MachineFunction &DestMF, 2681ad6265SDimitry Andric const DenseMap<MachineBasicBlock *, MachineBasicBlock *> &Src2DstMBB) 2781ad6265SDimitry Andric const { 2881ad6265SDimitry Andric return DestMF.cloneInfo<X86MachineFunctionInfo>(*this); 2981ad6265SDimitry Andric } 3081ad6265SDimitry Andric initializeBaseYamlFields(const yaml::X86MachineFunctionInfo & YamlMFI)31*0fca6ea1SDimitry Andricvoid X86MachineFunctionInfo::initializeBaseYamlFields( 32*0fca6ea1SDimitry Andric const yaml::X86MachineFunctionInfo &YamlMFI) { 33*0fca6ea1SDimitry Andric AMXProgModel = YamlMFI.AMXProgModel; 34*0fca6ea1SDimitry Andric } 35*0fca6ea1SDimitry Andric anchor()360b57cec5SDimitry Andricvoid X86MachineFunctionInfo::anchor() { } 370b57cec5SDimitry Andric setRestoreBasePointer(const MachineFunction * MF)380b57cec5SDimitry Andricvoid X86MachineFunctionInfo::setRestoreBasePointer(const MachineFunction *MF) { 390b57cec5SDimitry Andric if (!RestoreBasePointerOffset) { 400b57cec5SDimitry Andric const X86RegisterInfo *RegInfo = static_cast<const X86RegisterInfo *>( 410b57cec5SDimitry Andric MF->getSubtarget().getRegisterInfo()); 420b57cec5SDimitry Andric unsigned SlotSize = RegInfo->getSlotSize(); 430b57cec5SDimitry Andric for (const MCPhysReg *CSR = MF->getRegInfo().getCalleeSavedRegs(); 440b57cec5SDimitry Andric unsigned Reg = *CSR; ++CSR) { 450b57cec5SDimitry Andric if (X86::GR64RegClass.contains(Reg) || X86::GR32RegClass.contains(Reg)) 460b57cec5SDimitry Andric RestoreBasePointerOffset -= SlotSize; 470b57cec5SDimitry Andric } 480b57cec5SDimitry Andric } 490b57cec5SDimitry Andric } 500b57cec5SDimitry Andric 51