Revert last change by haoliu because of buildbot failure.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@195423 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Hao Liu 2013-11-22 08:34:54 +00:00
parent 7f5a9ca204
commit bb3327f3f0
4 changed files with 44 additions and 44 deletions

View File

@ -261,12 +261,12 @@ multiclass VectorList_operands<string PREFIX, string LAYOUT, int Count,
let Name = PREFIX # LAYOUT # Count; let Name = PREFIX # LAYOUT # Count;
let RenderMethod = "addVectorListOperands"; let RenderMethod = "addVectorListOperands";
let PredicateMethod = let PredicateMethod =
"isVectorList<A64Layout::VL_" # LAYOUT # ", " # Count # ">"; "isVectorList<A64Layout::_" # LAYOUT # ", " # Count # ">";
let ParserMethod = "ParseVectorList"; let ParserMethod = "ParseVectorList";
} }
def _operand : RegisterOperand<RegList, def _operand : RegisterOperand<RegList,
"printVectorList<A64Layout::VL_" # LAYOUT # ", " # Count # ">"> { "printVectorList<A64Layout::_" # LAYOUT # ", " # Count # ">"> {
let ParserMatchClass = let ParserMatchClass =
!cast<AsmOperandClass>(PREFIX # LAYOUT # "_asmoperand"); !cast<AsmOperandClass>(PREFIX # LAYOUT # "_asmoperand");
} }

View File

@ -2066,7 +2066,7 @@ AArch64AsmParser::OperandMatchResultTy AArch64AsmParser::ParseVectorList(
A64Layout::VectorLayout Layout = A64StringToVectorLayout(LayoutStr); A64Layout::VectorLayout Layout = A64StringToVectorLayout(LayoutStr);
if (Count > 1) { // If count > 1, create vector list using super register. if (Count > 1) { // If count > 1, create vector list using super register.
bool IsVec64 = (Layout < A64Layout::VL_16B); bool IsVec64 = (Layout < A64Layout::_16B);
static unsigned SupRegIDs[3][2] = { static unsigned SupRegIDs[3][2] = {
{ AArch64::QPairRegClassID, AArch64::DPairRegClassID }, { AArch64::QPairRegClassID, AArch64::DPairRegClassID },
{ AArch64::QTripleRegClassID, AArch64::DTripleRegClassID }, { AArch64::QTripleRegClassID, AArch64::DTripleRegClassID },
@ -2084,10 +2084,10 @@ AArch64AsmParser::OperandMatchResultTy AArch64AsmParser::ParseVectorList(
if (Parser.getTok().is(AsmToken::LBrac)) { if (Parser.getTok().is(AsmToken::LBrac)) {
uint32_t NumLanes = 0; uint32_t NumLanes = 0;
switch(Layout) { switch(Layout) {
case A64Layout::VL_B : NumLanes = 16; break; case A64Layout::_B : NumLanes = 16; break;
case A64Layout::VL_H : NumLanes = 8; break; case A64Layout::_H : NumLanes = 8; break;
case A64Layout::VL_S : NumLanes = 4; break; case A64Layout::_S : NumLanes = 4; break;
case A64Layout::VL_D : NumLanes = 2; break; case A64Layout::_D : NumLanes = 2; break;
default: default:
SMLoc Loc = getLexer().getLoc(); SMLoc Loc = getLexer().getLoc();
Error(Loc, "expected comma before next operand"); Error(Loc, "expected comma before next operand");

View File

@ -521,7 +521,7 @@ void AArch64InstPrinter::printVectorList(const MCInst *MI, unsigned OpNum,
std::string LayoutStr = A64VectorLayoutToString(Layout); std::string LayoutStr = A64VectorLayoutToString(Layout);
O << "{"; O << "{";
if (Count > 1) { // Print sub registers separately if (Count > 1) { // Print sub registers separately
bool IsVec64 = (Layout < A64Layout::VL_16B); bool IsVec64 = (Layout < A64Layout::_16B);
unsigned SubRegIdx = IsVec64 ? AArch64::dsub_0 : AArch64::qsub_0; unsigned SubRegIdx = IsVec64 ? AArch64::dsub_0 : AArch64::qsub_0;
for (unsigned I = 0; I < Count; I++) { for (unsigned I = 0; I < Count; I++) {
std::string Name = getRegisterName(MRI.getSubReg(Reg, SubRegIdx++)); std::string Name = getRegisterName(MRI.getSubReg(Reg, SubRegIdx++));

View File

@ -309,40 +309,40 @@ namespace A64SE {
namespace A64Layout { namespace A64Layout {
enum VectorLayout { enum VectorLayout {
Invalid = -1, Invalid = -1,
VL_8B, _8B,
VL_4H, _4H,
VL_2S, _2S,
VL_1D, _1D,
VL_16B, _16B,
VL_8H, _8H,
VL_4S, _4S,
VL_2D, _2D,
// Bare layout for the 128-bit vector // Bare layout for the 128-bit vector
// (only show ".b", ".h", ".s", ".d" without vector number) // (only show ".b", ".h", ".s", ".d" without vector number)
VL_B, _B,
VL_H, _H,
VL_S, _S,
VL_D _D
}; };
} }
inline static const char * inline static const char *
A64VectorLayoutToString(A64Layout::VectorLayout Layout) { A64VectorLayoutToString(A64Layout::VectorLayout Layout) {
switch (Layout) { switch (Layout) {
case A64Layout::VL_8B: return ".8b"; case A64Layout::_8B: return ".8b";
case A64Layout::VL_4H: return ".4h"; case A64Layout::_4H: return ".4h";
case A64Layout::VL_2S: return ".2s"; case A64Layout::_2S: return ".2s";
case A64Layout::VL_1D: return ".1d"; case A64Layout::_1D: return ".1d";
case A64Layout::VL_16B: return ".16b"; case A64Layout::_16B: return ".16b";
case A64Layout::VL_8H: return ".8h"; case A64Layout::_8H: return ".8h";
case A64Layout::VL_4S: return ".4s"; case A64Layout::_4S: return ".4s";
case A64Layout::VL_2D: return ".2d"; case A64Layout::_2D: return ".2d";
case A64Layout::VL_B: return ".b"; case A64Layout::_B: return ".b";
case A64Layout::VL_H: return ".h"; case A64Layout::_H: return ".h";
case A64Layout::VL_S: return ".s"; case A64Layout::_S: return ".s";
case A64Layout::VL_D: return ".d"; case A64Layout::_D: return ".d";
default: llvm_unreachable("Unknown Vector Layout"); default: llvm_unreachable("Unknown Vector Layout");
} }
} }
@ -350,18 +350,18 @@ A64VectorLayoutToString(A64Layout::VectorLayout Layout) {
inline static A64Layout::VectorLayout inline static A64Layout::VectorLayout
A64StringToVectorLayout(StringRef LayoutStr) { A64StringToVectorLayout(StringRef LayoutStr) {
return StringSwitch<A64Layout::VectorLayout>(LayoutStr) return StringSwitch<A64Layout::VectorLayout>(LayoutStr)
.Case(".8b", A64Layout::VL_8B) .Case(".8b", A64Layout::_8B)
.Case(".4h", A64Layout::VL_4H) .Case(".4h", A64Layout::_4H)
.Case(".2s", A64Layout::VL_2S) .Case(".2s", A64Layout::_2S)
.Case(".1d", A64Layout::VL_1D) .Case(".1d", A64Layout::_1D)
.Case(".16b", A64Layout::VL_16B) .Case(".16b", A64Layout::_16B)
.Case(".8h", A64Layout::VL_8H) .Case(".8h", A64Layout::_8H)
.Case(".4s", A64Layout::VL_4S) .Case(".4s", A64Layout::_4S)
.Case(".2d", A64Layout::VL_2D) .Case(".2d", A64Layout::_2D)
.Case(".b", A64Layout::VL_B) .Case(".b", A64Layout::_B)
.Case(".h", A64Layout::VL_H) .Case(".h", A64Layout::_H)
.Case(".s", A64Layout::VL_S) .Case(".s", A64Layout::_S)
.Case(".d", A64Layout::VL_D) .Case(".d", A64Layout::_D)
.Default(A64Layout::Invalid); .Default(A64Layout::Invalid);
} }