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 16*0fca6ea1SDimitry Andric yaml::X86MachineFunctionInfo::X86MachineFunctionInfo( 17*0fca6ea1SDimitry Andric const llvm::X86MachineFunctionInfo &MFI) 18*0fca6ea1SDimitry Andric : AMXProgModel(MFI.getAMXProgModel()) {} 19*0fca6ea1SDimitry Andric 20*0fca6ea1SDimitry Andric void yaml::X86MachineFunctionInfo::mappingImpl(yaml::IO &YamlIO) { 21*0fca6ea1SDimitry Andric MappingTraits<X86MachineFunctionInfo>::mapping(YamlIO, *this); 22*0fca6ea1SDimitry Andric } 23*0fca6ea1SDimitry Andric 2481ad6265SDimitry Andric MachineFunctionInfo *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 31*0fca6ea1SDimitry Andric void X86MachineFunctionInfo::initializeBaseYamlFields( 32*0fca6ea1SDimitry Andric const yaml::X86MachineFunctionInfo &YamlMFI) { 33*0fca6ea1SDimitry Andric AMXProgModel = YamlMFI.AMXProgModel; 34*0fca6ea1SDimitry Andric } 35*0fca6ea1SDimitry Andric 360b57cec5SDimitry Andric void X86MachineFunctionInfo::anchor() { } 370b57cec5SDimitry Andric 380b57cec5SDimitry Andric void 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