blob: 5116f0d121f42ca1d778a45d8a5ae7e897933fa3 [file] [log] [blame]
//===---- PPCCCState.cpp - 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
//
//===----------------------------------------------------------------------===//
#include "PPCCCState.h"
#include "PPCSubtarget.h"
#include "llvm/IR/Module.h"
using namespace llvm;
// Identify lowered values that originated from ppcf128 arguments and record
// this.
void PPCCCState::PreAnalyzeCallOperands(
const SmallVectorImpl<ISD::OutputArg> &Outs) {
for (const auto &I : Outs) {
if (I.ArgVT == llvm::MVT::ppcf128)
OriginalArgWasPPCF128.push_back(true);
else
OriginalArgWasPPCF128.push_back(false);
}
}
void PPCCCState::PreAnalyzeFormalArguments(
const SmallVectorImpl<ISD::InputArg> &Ins) {
for (const auto &I : Ins) {
if (I.ArgVT == llvm::MVT::ppcf128) {
OriginalArgWasPPCF128.push_back(true);
} else {
OriginalArgWasPPCF128.push_back(false);
}
}
}