2016-05-09 20:27:39 +08:00
|
|
|
//===---- PPCCCState.cpp - CCState with PowerPC specific extensions ---------===//
|
|
|
|
//
|
2019-01-19 16:50:56 +08:00
|
|
|
// 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
|
2016-05-09 20:27:39 +08:00
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#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);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|