2016-07-20 19:09:30 +00:00
|
|
|
//===-- llvm/CodeGen/GlobalISel/LowLevelType.cpp --------------------------===//
|
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
|
|
|
/// \file This file implements the more header-heavy bits of the LLT class to
|
|
|
|
/// avoid polluting users' namespaces.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#include "llvm/CodeGen/LowLevelType.h"
|
2016-08-15 21:13:17 +00:00
|
|
|
#include "llvm/IR/DataLayout.h"
|
2016-07-20 19:09:30 +00:00
|
|
|
#include "llvm/IR/DerivedTypes.h"
|
|
|
|
#include "llvm/Support/raw_ostream.h"
|
|
|
|
using namespace llvm;
|
|
|
|
|
2016-09-15 09:20:34 +00:00
|
|
|
LLT::LLT(Type &Ty, const DataLayout &DL) {
|
2016-07-20 19:09:30 +00:00
|
|
|
if (auto VTy = dyn_cast<VectorType>(&Ty)) {
|
2016-09-15 09:20:34 +00:00
|
|
|
SizeInBits = VTy->getElementType()->getPrimitiveSizeInBits();
|
|
|
|
ElementsOrAddrSpace = VTy->getNumElements();
|
|
|
|
Kind = ElementsOrAddrSpace == 1 ? Scalar : Vector;
|
2016-07-22 16:59:52 +00:00
|
|
|
} else if (auto PTy = dyn_cast<PointerType>(&Ty)) {
|
|
|
|
Kind = Pointer;
|
2016-09-15 09:20:34 +00:00
|
|
|
SizeInBits = DL.getTypeSizeInBits(&Ty);
|
|
|
|
ElementsOrAddrSpace = PTy->getAddressSpace();
|
2016-07-20 19:09:30 +00:00
|
|
|
} else if (Ty.isSized()) {
|
|
|
|
// Aggregates are no different from real scalars as far as GlobalISel is
|
|
|
|
// concerned.
|
|
|
|
Kind = Scalar;
|
2016-09-15 09:20:34 +00:00
|
|
|
SizeInBits = DL.getTypeSizeInBits(&Ty);
|
|
|
|
ElementsOrAddrSpace = 1;
|
|
|
|
assert(SizeInBits != 0 && "invalid zero-sized type");
|
2016-07-20 19:09:30 +00:00
|
|
|
} else {
|
2016-09-15 10:09:59 +00:00
|
|
|
Kind = Invalid;
|
2016-09-15 09:20:34 +00:00
|
|
|
SizeInBits = ElementsOrAddrSpace = 0;
|
2016-07-20 19:09:30 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-09-21 12:57:45 +00:00
|
|
|
LLT::LLT(MVT VT) {
|
|
|
|
if (VT.isVector()) {
|
|
|
|
SizeInBits = VT.getVectorElementType().getSizeInBits();
|
|
|
|
ElementsOrAddrSpace = VT.getVectorNumElements();
|
|
|
|
Kind = ElementsOrAddrSpace == 1 ? Scalar : Vector;
|
|
|
|
} else if (VT.isValid()) {
|
|
|
|
// Aggregates are no different from real scalars as far as GlobalISel is
|
|
|
|
// concerned.
|
|
|
|
Kind = Scalar;
|
|
|
|
SizeInBits = VT.getSizeInBits();
|
|
|
|
ElementsOrAddrSpace = 1;
|
|
|
|
assert(SizeInBits != 0 && "invalid zero-sized type");
|
|
|
|
} else {
|
|
|
|
Kind = Invalid;
|
|
|
|
SizeInBits = ElementsOrAddrSpace = 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-07-20 19:09:30 +00:00
|
|
|
void LLT::print(raw_ostream &OS) const {
|
|
|
|
if (isVector())
|
2016-09-15 09:20:34 +00:00
|
|
|
OS << "<" << ElementsOrAddrSpace << " x s" << SizeInBits << ">";
|
2016-07-22 16:59:52 +00:00
|
|
|
else if (isPointer())
|
|
|
|
OS << "p" << getAddressSpace();
|
2016-09-15 10:09:59 +00:00
|
|
|
else if (isValid()) {
|
|
|
|
assert(isScalar() && "unexpected type");
|
2016-07-22 16:59:52 +00:00
|
|
|
OS << "s" << getScalarSizeInBits();
|
2016-09-15 10:09:59 +00:00
|
|
|
} else
|
2016-07-20 19:09:30 +00:00
|
|
|
llvm_unreachable("trying to print an invalid type");
|
|
|
|
}
|