X86Disassembler: if verbose logging is going to nulls(), disable logging completely.
authorBenjamin Kramer <benny.kra@googlemail.com>
Wed, 21 Sep 2011 21:47:35 +0000 (21:47 +0000)
committerBenjamin Kramer <benny.kra@googlemail.com>
Wed, 21 Sep 2011 21:47:35 +0000 (21:47 +0000)
Otherwise we'll spend a ridiculous amount of time pretty printing debug output and then discarding it.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@140276 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Target/X86/Disassembler/X86Disassembler.cpp

index 884e690efae4fdca1b9a6198364ebe79bdf52fcc..3aacb20e73df670a1623320ea33a0a1f24ea5da2 100644 (file)
@@ -117,11 +117,15 @@ X86GenericDisassembler::getInstruction(MCInst &instr,
                                        raw_ostream &vStream,
                                        raw_ostream &cStream) const {
   InternalInstruction internalInstr;
+
+  dlog_t loggerFn = logger;
+  if (&vStream == &nulls())
+    loggerFn = 0; // Disable logging completely if it's going to nulls().
   
   int ret = decodeInstruction(&internalInstr,
                               regionReader,
                               (void*)&region,
-                              logger,
+                              loggerFn,
                               (void*)&vStream,
                               address,
                               fMode);