Do not emit comments unless -asm-verbose.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@67580 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Evan Cheng 2009-03-24 00:17:40 +00:00
parent 16581bf931
commit f1c0ae9de5
10 changed files with 229 additions and 134 deletions

View File

@ -1010,30 +1010,42 @@ void AsmPrinter::EmitGlobalConstantFP(const ConstantFP *CFP,
if (CFP->getType() == Type::DoubleTy) { if (CFP->getType() == Type::DoubleTy) {
double Val = CFP->getValueAPF().convertToDouble(); // for comment only double Val = CFP->getValueAPF().convertToDouble(); // for comment only
uint64_t i = CFP->getValueAPF().bitcastToAPInt().getZExtValue(); uint64_t i = CFP->getValueAPF().bitcastToAPInt().getZExtValue();
if (TAI->getData64bitsDirective(AddrSpace)) if (TAI->getData64bitsDirective(AddrSpace)) {
O << TAI->getData64bitsDirective(AddrSpace) << i << '\t' O << TAI->getData64bitsDirective(AddrSpace) << i;
<< TAI->getCommentString() << " double value: " << Val << '\n'; if (VerboseAsm)
else if (TD->isBigEndian()) { O << '\t' << TAI->getCommentString() << " double value: " << Val;
O << TAI->getData32bitsDirective(AddrSpace) << unsigned(i >> 32) O << '\n';
<< '\t' << TAI->getCommentString() } else if (TD->isBigEndian()) {
<< " double most significant word " << Val << '\n'; O << TAI->getData32bitsDirective(AddrSpace) << unsigned(i >> 32);
O << TAI->getData32bitsDirective(AddrSpace) << unsigned(i) if (VerboseAsm)
<< '\t' << TAI->getCommentString() O << '\t' << TAI->getCommentString()
<< " double least significant word " << Val << '\n'; << " double most significant word " << Val;
O << '\n';
O << TAI->getData32bitsDirective(AddrSpace) << unsigned(i);
if (VerboseAsm)
O << '\t' << TAI->getCommentString()
<< " double least significant word " << Val;
O << '\n';
} else { } else {
O << TAI->getData32bitsDirective(AddrSpace) << unsigned(i) O << TAI->getData32bitsDirective(AddrSpace) << unsigned(i);
<< '\t' << TAI->getCommentString() if (VerboseAsm)
<< " double least significant word " << Val << '\n'; O << '\t' << TAI->getCommentString()
O << TAI->getData32bitsDirective(AddrSpace) << unsigned(i >> 32) << " double least significant word " << Val;
<< '\t' << TAI->getCommentString() O << '\n';
<< " double most significant word " << Val << '\n'; O << TAI->getData32bitsDirective(AddrSpace) << unsigned(i >> 32);
if (VerboseAsm)
O << '\t' << TAI->getCommentString()
<< " double most significant word " << Val;
O << '\n';
} }
return; return;
} else if (CFP->getType() == Type::FloatTy) { } else if (CFP->getType() == Type::FloatTy) {
float Val = CFP->getValueAPF().convertToFloat(); // for comment only float Val = CFP->getValueAPF().convertToFloat(); // for comment only
O << TAI->getData32bitsDirective(AddrSpace) O << TAI->getData32bitsDirective(AddrSpace)
<< CFP->getValueAPF().bitcastToAPInt().getZExtValue() << CFP->getValueAPF().bitcastToAPInt().getZExtValue();
<< '\t' << TAI->getCommentString() << " float " << Val << '\n'; if (VerboseAsm)
O << '\t' << TAI->getCommentString() << " float " << Val;
O << '\n';
return; return;
} else if (CFP->getType() == Type::X86_FP80Ty) { } else if (CFP->getType() == Type::X86_FP80Ty) {
// all long double variants are printed as hex // all long double variants are printed as hex
@ -1046,39 +1058,56 @@ void AsmPrinter::EmitGlobalConstantFP(const ConstantFP *CFP,
DoubleVal.convert(APFloat::IEEEdouble, APFloat::rmNearestTiesToEven, DoubleVal.convert(APFloat::IEEEdouble, APFloat::rmNearestTiesToEven,
&ignored); &ignored);
if (TD->isBigEndian()) { if (TD->isBigEndian()) {
O << TAI->getData16bitsDirective(AddrSpace) << uint16_t(p[1]) O << TAI->getData16bitsDirective(AddrSpace) << uint16_t(p[1]);
<< '\t' << TAI->getCommentString() if (VerboseAsm)
<< " long double most significant halfword of ~" O << '\t' << TAI->getCommentString()
<< DoubleVal.convertToDouble() << '\n'; << " long double most significant halfword of ~"
O << TAI->getData16bitsDirective(AddrSpace) << uint16_t(p[0] >> 48) << DoubleVal.convertToDouble();
<< '\t' << TAI->getCommentString() O << '\n';
<< " long double next halfword\n"; O << TAI->getData16bitsDirective(AddrSpace) << uint16_t(p[0] >> 48);
O << TAI->getData16bitsDirective(AddrSpace) << uint16_t(p[0] >> 32) if (VerboseAsm)
<< '\t' << TAI->getCommentString() O << '\t' << TAI->getCommentString() << " long double next halfword";
<< " long double next halfword\n"; O << '\n';
O << TAI->getData16bitsDirective(AddrSpace) << uint16_t(p[0] >> 16) O << TAI->getData16bitsDirective(AddrSpace) << uint16_t(p[0] >> 32);
<< '\t' << TAI->getCommentString() if (VerboseAsm)
<< " long double next halfword\n"; O << '\t' << TAI->getCommentString() << " long double next halfword";
O << TAI->getData16bitsDirective(AddrSpace) << uint16_t(p[0]) O << '\n';
<< '\t' << TAI->getCommentString() O << TAI->getData16bitsDirective(AddrSpace) << uint16_t(p[0] >> 16);
<< " long double least significant halfword\n"; if (VerboseAsm)
O << '\t' << TAI->getCommentString() << " long double next halfword";
O << '\n';
O << TAI->getData16bitsDirective(AddrSpace) << uint16_t(p[0]);
if (VerboseAsm)
O << '\t' << TAI->getCommentString()
<< " long double least significant halfword";
O << '\n';
} else { } else {
O << TAI->getData16bitsDirective(AddrSpace) << uint16_t(p[0]) O << TAI->getData16bitsDirective(AddrSpace) << uint16_t(p[0]);
<< '\t' << TAI->getCommentString() if (VerboseAsm)
<< " long double least significant halfword of ~" O << '\t' << TAI->getCommentString()
<< DoubleVal.convertToDouble() << '\n'; << " long double least significant halfword of ~"
O << TAI->getData16bitsDirective(AddrSpace) << uint16_t(p[0] >> 16) << DoubleVal.convertToDouble();
<< '\t' << TAI->getCommentString() O << '\n';
<< " long double next halfword\n"; O << TAI->getData16bitsDirective(AddrSpace) << uint16_t(p[0] >> 16);
O << TAI->getData16bitsDirective(AddrSpace) << uint16_t(p[0] >> 32) if (VerboseAsm)
<< '\t' << TAI->getCommentString() O << '\t' << TAI->getCommentString()
<< " long double next halfword\n"; << " long double next halfword";
O << TAI->getData16bitsDirective(AddrSpace) << uint16_t(p[0] >> 48) O << '\n';
<< '\t' << TAI->getCommentString() O << TAI->getData16bitsDirective(AddrSpace) << uint16_t(p[0] >> 32);
<< " long double next halfword\n"; if (VerboseAsm)
O << TAI->getData16bitsDirective(AddrSpace) << uint16_t(p[1]) O << '\t' << TAI->getCommentString()
<< '\t' << TAI->getCommentString() << " long double next halfword";
<< " long double most significant halfword\n"; O << '\n';
O << TAI->getData16bitsDirective(AddrSpace) << uint16_t(p[0] >> 48);
if (VerboseAsm)
O << '\t' << TAI->getCommentString()
<< " long double next halfword";
O << '\n';
O << TAI->getData16bitsDirective(AddrSpace) << uint16_t(p[1]);
if (VerboseAsm)
O << '\t' << TAI->getCommentString()
<< " long double most significant halfword";
O << '\n';
} }
EmitZeros(TD->getTypePaddedSize(Type::X86_FP80Ty) - EmitZeros(TD->getTypePaddedSize(Type::X86_FP80Ty) -
TD->getTypeStoreSize(Type::X86_FP80Ty), AddrSpace); TD->getTypeStoreSize(Type::X86_FP80Ty), AddrSpace);
@ -1089,31 +1118,47 @@ void AsmPrinter::EmitGlobalConstantFP(const ConstantFP *CFP,
APInt api = CFP->getValueAPF().bitcastToAPInt(); APInt api = CFP->getValueAPF().bitcastToAPInt();
const uint64_t *p = api.getRawData(); const uint64_t *p = api.getRawData();
if (TD->isBigEndian()) { if (TD->isBigEndian()) {
O << TAI->getData32bitsDirective(AddrSpace) << uint32_t(p[0] >> 32) O << TAI->getData32bitsDirective(AddrSpace) << uint32_t(p[0] >> 32);
<< '\t' << TAI->getCommentString() if (VerboseAsm)
<< " long double most significant word\n"; O << '\t' << TAI->getCommentString()
O << TAI->getData32bitsDirective(AddrSpace) << uint32_t(p[0]) << " long double most significant word";
<< '\t' << TAI->getCommentString() O << '\n';
<< " long double next word\n"; O << TAI->getData32bitsDirective(AddrSpace) << uint32_t(p[0]);
O << TAI->getData32bitsDirective(AddrSpace) << uint32_t(p[1] >> 32) if (VerboseAsm)
<< '\t' << TAI->getCommentString() O << '\t' << TAI->getCommentString()
<< " long double next word\n"; << " long double next word";
O << TAI->getData32bitsDirective(AddrSpace) << uint32_t(p[1]) O << '\n';
<< '\t' << TAI->getCommentString() O << TAI->getData32bitsDirective(AddrSpace) << uint32_t(p[1] >> 32);
<< " long double least significant word\n"; if (VerboseAsm)
O << '\t' << TAI->getCommentString()
<< " long double next word";
O << '\n';
O << TAI->getData32bitsDirective(AddrSpace) << uint32_t(p[1]);
if (VerboseAsm)
O << '\t' << TAI->getCommentString()
<< " long double least significant word";
O << '\n';
} else { } else {
O << TAI->getData32bitsDirective(AddrSpace) << uint32_t(p[1]) O << TAI->getData32bitsDirective(AddrSpace) << uint32_t(p[1]);
<< '\t' << TAI->getCommentString() if (VerboseAsm)
<< " long double least significant word\n"; O << '\t' << TAI->getCommentString()
O << TAI->getData32bitsDirective(AddrSpace) << uint32_t(p[1] >> 32) << " long double least significant word";
<< '\t' << TAI->getCommentString() O << '\n';
<< " long double next word\n"; O << TAI->getData32bitsDirective(AddrSpace) << uint32_t(p[1] >> 32);
O << TAI->getData32bitsDirective(AddrSpace) << uint32_t(p[0]) if (VerboseAsm)
<< '\t' << TAI->getCommentString() O << '\t' << TAI->getCommentString()
<< " long double next word\n"; << " long double next word";
O << TAI->getData32bitsDirective(AddrSpace) << uint32_t(p[0] >> 32) O << '\n';
<< '\t' << TAI->getCommentString() O << TAI->getData32bitsDirective(AddrSpace) << uint32_t(p[0]);
<< " long double most significant word\n"; if (VerboseAsm)
O << '\t' << TAI->getCommentString()
<< " long double next word";
O << '\n';
O << TAI->getData32bitsDirective(AddrSpace) << uint32_t(p[0] >> 32);
if (VerboseAsm)
O << '\t' << TAI->getCommentString()
<< " long double most significant word";
O << '\n';
} }
return; return;
} else assert(0 && "Floating point constant type not handled"); } else assert(0 && "Floating point constant type not handled");
@ -1140,19 +1185,27 @@ void AsmPrinter::EmitGlobalConstantLargeInt(const ConstantInt *CI,
if (TAI->getData64bitsDirective(AddrSpace)) if (TAI->getData64bitsDirective(AddrSpace))
O << TAI->getData64bitsDirective(AddrSpace) << Val << '\n'; O << TAI->getData64bitsDirective(AddrSpace) << Val << '\n';
else if (TD->isBigEndian()) { else if (TD->isBigEndian()) {
O << TAI->getData32bitsDirective(AddrSpace) << unsigned(Val >> 32) O << TAI->getData32bitsDirective(AddrSpace) << unsigned(Val >> 32);
<< '\t' << TAI->getCommentString() if (VerboseAsm)
<< " Double-word most significant word " << Val << '\n'; O << '\t' << TAI->getCommentString()
O << TAI->getData32bitsDirective(AddrSpace) << unsigned(Val) << " Double-word most significant word " << Val;
<< '\t' << TAI->getCommentString() O << '\n';
<< " Double-word least significant word " << Val << '\n'; O << TAI->getData32bitsDirective(AddrSpace) << unsigned(Val);
if (VerboseAsm)
O << '\t' << TAI->getCommentString()
<< " Double-word least significant word " << Val;
O << '\n';
} else { } else {
O << TAI->getData32bitsDirective(AddrSpace) << unsigned(Val) O << TAI->getData32bitsDirective(AddrSpace) << unsigned(Val);
<< '\t' << TAI->getCommentString() if (VerboseAsm)
<< " Double-word least significant word " << Val << '\n'; O << '\t' << TAI->getCommentString()
O << TAI->getData32bitsDirective(AddrSpace) << unsigned(Val >> 32) << " Double-word least significant word " << Val;
<< '\t' << TAI->getCommentString() O << '\n';
<< " Double-word most significant word " << Val << '\n'; O << TAI->getData32bitsDirective(AddrSpace) << unsigned(Val >> 32);
if (VerboseAsm)
O << '\t' << TAI->getCommentString()
<< " Double-word most significant word " << Val;
O << '\n';
} }
} }
} }
@ -1188,10 +1241,12 @@ void AsmPrinter::EmitGlobalConstant(const Constant *CV, unsigned AddrSpace) {
printDataDirective(type, AddrSpace); printDataDirective(type, AddrSpace);
EmitConstantValueOnly(CV); EmitConstantValueOnly(CV);
if (const ConstantInt *CI = dyn_cast<ConstantInt>(CV)) { if (VerboseAsm) {
SmallString<40> S; if (const ConstantInt *CI = dyn_cast<ConstantInt>(CV)) {
CI->getValue().toStringUnsigned(S, 16); SmallString<40> S;
O << "\t\t\t" << TAI->getCommentString() << " 0x" << S.c_str(); CI->getValue().toStringUnsigned(S, 16);
O << "\t\t\t" << TAI->getCommentString() << " 0x" << S.c_str();
}
} }
O << '\n'; O << '\n';
} }
@ -1211,7 +1266,8 @@ void AsmPrinter::PrintSpecial(const MachineInstr *MI, const char *Code) const {
if (!strcmp(Code, "private")) { if (!strcmp(Code, "private")) {
O << TAI->getPrivateGlobalPrefix(); O << TAI->getPrivateGlobalPrefix();
} else if (!strcmp(Code, "comment")) { } else if (!strcmp(Code, "comment")) {
O << TAI->getCommentString(); if (VerboseAsm)
O << TAI->getCommentString();
} else if (!strcmp(Code, "uid")) { } else if (!strcmp(Code, "uid")) {
// Assign a unique ID to this machine instruction. // Assign a unique ID to this machine instruction.
static const MachineInstr *LastMI = 0; static const MachineInstr *LastMI = 0;
@ -1441,8 +1497,9 @@ void AsmPrinter::printInlineAsm(const MachineInstr *MI) const {
/// printImplicitDef - This method prints the specified machine instruction /// printImplicitDef - This method prints the specified machine instruction
/// that is an implicit def. /// that is an implicit def.
void AsmPrinter::printImplicitDef(const MachineInstr *MI) const { void AsmPrinter::printImplicitDef(const MachineInstr *MI) const {
O << '\t' << TAI->getCommentString() << " implicit-def: " if (VerboseAsm)
<< TRI->getAsmName(MI->getOperand(0).getReg()) << '\n'; O << '\t' << TAI->getCommentString() << " implicit-def: "
<< TRI->getAsmName(MI->getOperand(0).getReg()) << '\n';
} }
/// printLabel - This method prints a local label used by debug and /// printLabel - This method prints a local label used by debug and

View File

@ -255,7 +255,7 @@ bool ARMAsmPrinter::runOnMachineFunction(MachineFunction &MF) {
I != E; ++I) { I != E; ++I) {
// Print a label for the basic block. // Print a label for the basic block.
if (I != MF.begin()) { if (I != MF.begin()) {
printBasicBlockLabel(I, true, true); printBasicBlockLabel(I, true, true, VerboseAsm);
O << '\n'; O << '\n';
} }
for (MachineBasicBlock::const_iterator II = I->begin(), E = I->end(); for (MachineBasicBlock::const_iterator II = I->begin(), E = I->end();
@ -356,7 +356,9 @@ static void printSOImm(raw_ostream &O, int64_t V, const TargetAsmInfo *TAI) {
if (Rot) { if (Rot) {
O << "#" << Imm << ", " << Rot; O << "#" << Imm << ", " << Rot;
// Pretty printed version. // Pretty printed version.
O << ' ' << TAI->getCommentString() << ' ' << (int)ARM_AM::rotr32(Imm, Rot); if (VerboseAsm)
O << ' ' << TAI->getCommentString()
<< ' ' << (int)ARM_AM::rotr32(Imm, Rot);
} else { } else {
O << "#" << Imm; O << "#" << Imm;
} }
@ -870,8 +872,11 @@ void ARMAsmPrinter::printModuleLevelGV(const GlobalVariable* GVar) {
O << "\t.globl " << name << '\n' O << "\t.globl " << name << '\n'
<< TAI->getWeakDefDirective() << name << '\n'; << TAI->getWeakDefDirective() << name << '\n';
EmitAlignment(Align, GVar); EmitAlignment(Align, GVar);
O << name << ":\t\t\t\t" << TAI->getCommentString() << ' '; O << name << ":";
PrintUnmangledNameSafely(GVar, O); if (VerboseAsm) {
O << "\t\t\t\t" << TAI->getCommentString() << ' ';
PrintUnmangledNameSafely(GVar, O);
}
O << '\n'; O << '\n';
EmitGlobalConstant(C); EmitGlobalConstant(C);
return; return;
@ -892,8 +897,10 @@ void ARMAsmPrinter::printModuleLevelGV(const GlobalVariable* GVar) {
if (TAI->getCOMMDirectiveTakesAlignment()) if (TAI->getCOMMDirectiveTakesAlignment())
O << "," << (TAI->getAlignmentIsInBytes() ? (1 << Align) : Align); O << "," << (TAI->getAlignmentIsInBytes() ? (1 << Align) : Align);
} }
O << "\t\t" << TAI->getCommentString() << " "; if (VerboseAsm) {
PrintUnmangledNameSafely(GVar, O); O << "\t\t" << TAI->getCommentString() << " ";
PrintUnmangledNameSafely(GVar, O);
}
O << "\n"; O << "\n";
return; return;
} }
@ -928,8 +935,11 @@ void ARMAsmPrinter::printModuleLevelGV(const GlobalVariable* GVar) {
} }
EmitAlignment(Align, GVar); EmitAlignment(Align, GVar);
O << name << ":\t\t\t\t" << TAI->getCommentString() << " "; O << name << ":";
PrintUnmangledNameSafely(GVar, O); if (VerboseAsm) {
O << "\t\t\t\t" << TAI->getCommentString() << " ";
PrintUnmangledNameSafely(GVar, O);
}
O << "\n"; O << "\n";
if (TAI->hasDotTypeDotSizeDirective()) if (TAI->hasDotTypeDotSizeDirective())
O << "\t.size " << name << ", " << Size << "\n"; O << "\t.size " << name << ", " << Size << "\n";

View File

@ -704,9 +704,12 @@ void PPCLinuxAsmPrinter::printModuleLevelGV(const GlobalVariable* GVar) {
} else { } else {
O << ".comm " << name << ',' << Size; O << ".comm " << name << ',' << Size;
} }
O << "\t\t" << TAI->getCommentString() << " '"; if (VerboseAsm) {
PrintUnmangledNameSafely(GVar, O); O << "\t\t" << TAI->getCommentString() << " '";
O << "'\n"; PrintUnmangledNameSafely(GVar, O);
O << "'";
}
O << '\n';
return; return;
} }
@ -737,9 +740,13 @@ void PPCLinuxAsmPrinter::printModuleLevelGV(const GlobalVariable* GVar) {
} }
EmitAlignment(Align, GVar); EmitAlignment(Align, GVar);
O << name << ":\t\t\t\t" << TAI->getCommentString() << " '"; O << name << ":";
PrintUnmangledNameSafely(GVar, O); if (VerboseAsm) {
O << "'\n"; O << "\t\t\t\t" << TAI->getCommentString() << " '";
PrintUnmangledNameSafely(GVar, O);
O << "'";
}
O << '\n';
// If the initializer is a extern weak symbol, remember to emit the weak // If the initializer is a extern weak symbol, remember to emit the weak
// reference! // reference!
@ -819,7 +826,7 @@ bool PPCDarwinAsmPrinter::runOnMachineFunction(MachineFunction &MF) {
I != E; ++I) { I != E; ++I) {
// Print a label for the basic block. // Print a label for the basic block.
if (I != MF.begin()) { if (I != MF.begin()) {
printBasicBlockLabel(I, true, true); printBasicBlockLabel(I, true, true, VerboseAsm);
O << '\n'; O << '\n';
} }
for (MachineBasicBlock::const_iterator II = I->begin(), IE = I->end(); for (MachineBasicBlock::const_iterator II = I->begin(), IE = I->end();
@ -938,8 +945,11 @@ void PPCDarwinAsmPrinter::printModuleLevelGV(const GlobalVariable* GVar) {
O << "\t.globl " << name << '\n' O << "\t.globl " << name << '\n'
<< TAI->getWeakDefDirective() << name << '\n'; << TAI->getWeakDefDirective() << name << '\n';
EmitAlignment(Align, GVar); EmitAlignment(Align, GVar);
O << name << ":\t\t\t\t" << TAI->getCommentString() << " "; O << name << ":";
PrintUnmangledNameSafely(GVar, O); if (VerboseAsm) {
O << "\t\t\t\t" << TAI->getCommentString() << " ";
PrintUnmangledNameSafely(GVar, O);
}
O << '\n'; O << '\n';
EmitGlobalConstant(C); EmitGlobalConstant(C);
return; return;
@ -949,9 +959,12 @@ void PPCDarwinAsmPrinter::printModuleLevelGV(const GlobalVariable* GVar) {
if (Subtarget.isDarwin9()) if (Subtarget.isDarwin9())
O << ',' << Align; O << ',' << Align;
} }
O << "\t\t" << TAI->getCommentString() << " '"; if (VerboseAsm) {
PrintUnmangledNameSafely(GVar, O); O << "\t\t" << TAI->getCommentString() << " '";
O << "'\n"; PrintUnmangledNameSafely(GVar, O);
O << "'";
}
O << '\n';
return; return;
} }
@ -980,9 +993,13 @@ void PPCDarwinAsmPrinter::printModuleLevelGV(const GlobalVariable* GVar) {
} }
EmitAlignment(Align, GVar); EmitAlignment(Align, GVar);
O << name << ":\t\t\t\t" << TAI->getCommentString() << " '"; O << name << ":";
PrintUnmangledNameSafely(GVar, O); if (VerboseAsm) {
O << "'\n"; O << "\t\t\t\t" << TAI->getCommentString() << " '";
PrintUnmangledNameSafely(GVar, O);
O << "'";
}
O << '\n';
// If the initializer is a extern weak symbol, remember to emit the weak // If the initializer is a extern weak symbol, remember to emit the weak
// reference! // reference!

View File

@ -239,7 +239,7 @@ bool X86ATTAsmPrinter::runOnMachineFunction(MachineFunction &MF) {
I != E; ++I) { I != E; ++I) {
// Print a label for the basic block. // Print a label for the basic block.
if (!I->pred_empty()) { if (!I->pred_empty()) {
printBasicBlockLabel(I, true, true); printBasicBlockLabel(I, true, true, VerboseAsm);
O << '\n'; O << '\n';
} }
for (MachineBasicBlock::const_iterator II = I->begin(), IE = I->end(); for (MachineBasicBlock::const_iterator II = I->begin(), IE = I->end();
@ -315,7 +315,7 @@ void X86ATTAsmPrinter::printOperand(const MachineInstr *MI, unsigned OpNo,
O << MO.getImm(); O << MO.getImm();
return; return;
case MachineOperand::MO_MachineBasicBlock: case MachineOperand::MO_MachineBasicBlock:
printBasicBlockLabel(MO.getMBB()); printBasicBlockLabel(MO.getMBB(), false, false, VerboseAsm);
return; return;
case MachineOperand::MO_JumpTableIndex: { case MachineOperand::MO_JumpTableIndex: {
bool isMemOp = Modifier && !strcmp(Modifier, "mem"); bool isMemOp = Modifier && !strcmp(Modifier, "mem");
@ -829,8 +829,11 @@ void X86ATTAsmPrinter::printModuleLevelGV(const GlobalVariable* GVar) {
O << "\t.globl " << name << '\n' O << "\t.globl " << name << '\n'
<< TAI->getWeakDefDirective() << name << '\n'; << TAI->getWeakDefDirective() << name << '\n';
EmitAlignment(Align, GVar); EmitAlignment(Align, GVar);
O << name << ":\t\t\t\t" << TAI->getCommentString() << ' '; O << name << ":";
PrintUnmangledNameSafely(GVar, O); if (VerboseAsm) {
O << name << "\t\t\t\t" << TAI->getCommentString() << ' ';
PrintUnmangledNameSafely(GVar, O);
}
O << '\n'; O << '\n';
EmitGlobalConstant(C); EmitGlobalConstant(C);
return; return;
@ -848,8 +851,10 @@ void X86ATTAsmPrinter::printModuleLevelGV(const GlobalVariable* GVar) {
if (TAI->getCOMMDirectiveTakesAlignment()) if (TAI->getCOMMDirectiveTakesAlignment())
O << ',' << (TAI->getAlignmentIsInBytes() ? (1 << Align) : Align); O << ',' << (TAI->getAlignmentIsInBytes() ? (1 << Align) : Align);
} }
O << "\t\t" << TAI->getCommentString() << ' '; if (VerboseAsm) {
PrintUnmangledNameSafely(GVar, O); O << "\t\t" << TAI->getCommentString() << ' ';
PrintUnmangledNameSafely(GVar, O);
}
O << '\n'; O << '\n';
return; return;
} }
@ -887,8 +892,11 @@ void X86ATTAsmPrinter::printModuleLevelGV(const GlobalVariable* GVar) {
} }
EmitAlignment(Align, GVar); EmitAlignment(Align, GVar);
O << name << ":\t\t\t\t" << TAI->getCommentString() << ' '; O << name << ":";
PrintUnmangledNameSafely(GVar, O); if (VerboseAsm){
O << name << "\t\t\t\t" << TAI->getCommentString() << ' ';
PrintUnmangledNameSafely(GVar, O);
}
O << '\n'; O << '\n';
if (TAI->hasDotTypeDotSizeDirective()) if (TAI->hasDotTypeDotSizeDirective())
O << "\t.size\t" << name << ", " << Size << '\n'; O << "\t.size\t" << name << ", " << Size << '\n';

View File

@ -489,8 +489,11 @@ bool X86IntelAsmPrinter::doFinalization(Module &M) {
if (!bCustomSegment) if (!bCustomSegment)
EmitAlignment(Align, I); EmitAlignment(Align, I);
O << name << ":\t\t\t\t" << TAI->getCommentString() O << name << ":";
<< " " << I->getName() << '\n'; if (VerboseAsm)
O << name << "\t\t\t\t" << TAI->getCommentString()
<< " " << I->getName();
O << '\n';
EmitGlobalConstant(C); EmitGlobalConstant(C);

View File

@ -2,11 +2,11 @@
; RUN: grep {mov r0, #0} | count 1 ; RUN: grep {mov r0, #0} | count 1
; RUN: llvm-as < %s | llc -march=arm | \ ; RUN: llvm-as < %s | llc -march=arm | \
; RUN: grep {mov r0, #255$} | count 1 ; RUN: grep {mov r0, #255$} | count 1
; RUN: llvm-as < %s | llc -march=arm | \ ; RUN: llvm-as < %s | llc -march=arm -asm-verbose | \
; RUN: grep {mov r0.*256} | count 1 ; RUN: grep {mov r0.*256} | count 1
; RUN: llvm-as < %s | llc -march=arm | grep {orr.*256} | count 1 ; RUN: llvm-as < %s | llc -march=arm -asm-verbose | grep {orr.*256} | count 1
; RUN: llvm-as < %s | llc -march=arm | grep {mov r0, .*-1073741761} | count 1 ; RUN: llvm-as < %s | llc -march=arm -asm-verbose | grep {mov r0, .*-1073741761} | count 1
; RUN: llvm-as < %s | llc -march=arm | grep {mov r0, .*1008} | count 1 ; RUN: llvm-as < %s | llc -march=arm -asm-verbose | grep {mov r0, .*1008} | count 1
; RUN: llvm-as < %s | llc -march=arm | grep {cmp r0, #1, 16} | count 1 ; RUN: llvm-as < %s | llc -march=arm | grep {cmp r0, #1, 16} | count 1
define i32 @f1() { define i32 @f1() {

View File

@ -1,4 +1,4 @@
; RUN: llvm-as < %s | llc -march=arm | \ ; RUN: llvm-as < %s | llc -march=arm -asm-verbose | \
; RUN: grep -- {-2147483648} | count 3 ; RUN: grep -- {-2147483648} | count 3
; RUN: llvm-as < %s | llc -march=arm | grep mvn | count 3 ; RUN: llvm-as < %s | llc -march=arm | grep mvn | count 3
; RUN: llvm-as < %s | llc -march=arm | grep adds | count 1 ; RUN: llvm-as < %s | llc -march=arm | grep adds | count 1

View File

@ -1,4 +1,4 @@
; RUN: llvm-as < %s | llc -enable-eh | grep invcont131 ; RUN: llvm-as < %s | llc -enable-eh -asm-verbose | grep invcont131
; PR 1496: tail merge was incorrectly removing this block ; PR 1496: tail merge was incorrectly removing this block
; ModuleID = 'report.1.bc' ; ModuleID = 'report.1.bc'

View File

@ -1,4 +1,4 @@
; RUN: llvm-as < %s | llc -mtriple=i386-apple-darwin | grep {#} | not grep -v {##} ; RUN: llvm-as < %s | llc -mtriple=i386-apple-darwin -asm-verbose | grep {#} | not grep -v {##}
%struct.AGenericCall = type { %struct.AGenericManager*, %struct.ComponentParameters*, i32* } %struct.AGenericCall = type { %struct.AGenericManager*, %struct.ComponentParameters*, i32* }
%struct.AGenericManager = type <{ i8 }> %struct.AGenericManager = type <{ i8 }>

View File

@ -1,4 +1,4 @@
; RUN: llvm-as < %s | llc -march=x86 | grep -A 1 lpad | grep Llabel ; RUN: llvm-as < %s | llc -march=x86 -asm-verbose | grep -A 1 lpad | grep Llabel
; Check that register copies in the landing pad come after the EH_LABEL ; Check that register copies in the landing pad come after the EH_LABEL
declare i32 @f() declare i32 @f()