Moved disassembler to libSystem
authorAnton Korobeynikov <asl@math.spbu.ru>
Tue, 23 Jan 2007 10:26:08 +0000 (10:26 +0000)
committerAnton Korobeynikov <asl@math.spbu.ru>
Tue, 23 Jan 2007 10:26:08 +0000 (10:26 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@33461 91177308-0d34-0410-b5e6-96231b3b80d8

include/llvm/Support/Disassembler.h [deleted file]
include/llvm/System/Disassembler.h [new file with mode: 0644]
lib/ExecutionEngine/JIT/JITEmitter.cpp
lib/Support/Disassembler.cpp [deleted file]
lib/System/Disassembler.cpp [new file with mode: 0644]

diff --git a/include/llvm/Support/Disassembler.h b/include/llvm/Support/Disassembler.h
deleted file mode 100644 (file)
index 3d0d798..0000000
+++ /dev/null
@@ -1,36 +0,0 @@
-//===- llvm/Support/Disassembler.h ------------------------------*- C++ -*-===//
-//
-//                     The LLVM Compiler Infrastructure
-//
-// This file was developed by Anton Korobeynikov and is distributed under the
-// University of Illinois Open Source License. See LICENSE.TXT for details.
-//
-//===----------------------------------------------------------------------===//
-//
-// This file implements the necessary glue to call external disassembler
-// libraries.
-//
-//===----------------------------------------------------------------------===//
-
-#ifndef LLVM_SUPPORT_DISASSEMBLER_H
-#define LLVM_SUPPORT_DISASSEMBLER_H
-
-#include "llvm/Support/DataTypes.h"
-#include <string>
-
-namespace llvm {
-
-namespace Disassembler {
-  enum Type {
-    X86_32,
-    X86_64,
-    Undefined
-  };
-}
-  
-
-std::string disassembleBuffer(uint8_t* start, size_t length,
-                              Disassembler::Type type, uint64_t pc);
-}
-
-#endif // LLVM_SUPPORT_DISASSEMBLER_H
diff --git a/include/llvm/System/Disassembler.h b/include/llvm/System/Disassembler.h
new file mode 100644 (file)
index 0000000..37a8761
--- /dev/null
@@ -0,0 +1,31 @@
+//===- llvm/Support/Disassembler.h ------------------------------*- C++ -*-===//
+//
+//                     The LLVM Compiler Infrastructure
+//
+// This file was developed by Anton Korobeynikov and is distributed under the
+// University of Illinois Open Source License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+//
+// This file implements the necessary glue to call external disassembler
+// libraries.
+//
+//===----------------------------------------------------------------------===//
+
+#ifndef LLVM_SYSTEM_DISASSEMBLER_H
+#define LLVM_SYSTEM_DISASSEMBLER_H
+
+#include "llvm/Support/DataTypes.h"
+#include <string>
+
+namespace llvm {
+namespace sys {
+
+/// This function provides some "glue" code to call external disassembler
+/// libraries.
+std::string disassembleBuffer(uint8_t* start, size_t length, uint64_t pc = 0);
+
+}
+}
+
+#endif // LLVM_SYSTEM_DISASSEMBLER_H
index 176c22a028cbfcf320550fc0b24dc590c2fd31df..4c3b9fdb07b83046536286f54a4f512703dd3cba 100644 (file)
@@ -27,8 +27,8 @@
 #include "llvm/Target/TargetJITInfo.h"
 #include "llvm/Target/TargetMachine.h"
 #include "llvm/Support/Debug.h"
-#include "llvm/Support/Disassembler.h"
 #include "llvm/Support/MutexGuard.h"
+#include "llvm/System/Disassembler.h"
 #include "llvm/ADT/Statistic.h"
 #include "llvm/System/Memory.h"
 #include <algorithm>
@@ -868,15 +868,7 @@ bool JITEmitter::finishFunction(MachineFunction &F) {
 
 #ifndef NDEBUG
   DOUT << "Disassembled code:\n"
-#if defined(__i386__)
-       << disassembleBuffer(FnStart, FnEnd-FnStart,
-                            Disassembler::X86_32, (uint32_t)FnStart);
-#elif defined(__amd64__) || defined(__x86_64__)
-       << disassembleBuffer(FnStart, FnEnd-FnStart,
-                            Disassembler::X86_64, (uint64_t)FnStart);
-#else
-       << "N/A\n";
-#endif
+       << sys::disassembleBuffer(FnStart, FnEnd-FnStart, (uintptr_t)FnStart);
 #endif
   
   return false;
diff --git a/lib/Support/Disassembler.cpp b/lib/Support/Disassembler.cpp
deleted file mode 100644 (file)
index cc1f5e4..0000000
+++ /dev/null
@@ -1,53 +0,0 @@
-//===- lib/Support/Disassembler.cpp -----------------------------*- C++ -*-===//
-//
-//                     The LLVM Compiler Infrastructure
-//
-// This file was developed by Anton Korobeynikov and is distributed under the
-// University of Illinois Open Source License. See LICENSE.TXT for details.
-//
-//===----------------------------------------------------------------------===//
-//
-// This file implements the necessary glue to call external disassembler
-// libraries.
-//
-//===----------------------------------------------------------------------===//
-
-#include "llvm/Config/config.h"
-#include "llvm/Support/Disassembler.h"
-
-#include <cassert>
-#include <iomanip>
-#include <string>
-#include <sstream>
-
-#if USE_UDIS86
-#include <udis86.h>
-#endif
-
-using namespace llvm;
-
-std::string llvm::disassembleBuffer(uint8_t* start, size_t length,
-                              Disassembler::Type type, uint64_t pc) {
-  std::stringstream res;
-  
-  if (type == Disassembler::X86_32 || type == Disassembler::X86_64) {
-#if USE_UDIS86
-    ud_t ud_obj;
-   
-    ud_init(&ud_obj);
-    ud_set_input_buffer(&ud_obj, start, length);
-    ud_set_mode(&ud_obj, (type == Disassembler::X86_32 ? 32 : 64));
-    ud_set_pc(&ud_obj, pc);
-    ud_set_syntax(&ud_obj, UD_SYN_ATT);
-
-    res << std::setbase(16)
-        << std::setw((type == Disassembler::X86_32 ? 8 : 16));
-
-    while (ud_disassemble(&ud_obj)) {
-      res << ud_insn_off(&ud_obj) << ":\t" << ud_insn_asm(&ud_obj) << "\n";
-    }
-#endif
-  }
-
-  return res.str();
-}
diff --git a/lib/System/Disassembler.cpp b/lib/System/Disassembler.cpp
new file mode 100644 (file)
index 0000000..8a01562
--- /dev/null
@@ -0,0 +1,65 @@
+//===- lib/System/Disassembler.cpp ------------------------------*- C++ -*-===//
+//
+//                     The LLVM Compiler Infrastructure
+//
+// This file was developed by Anton Korobeynikov and is distributed under the
+// University of Illinois Open Source License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+//
+// This file implements the necessary glue to call external disassembler
+// libraries.
+//
+//===----------------------------------------------------------------------===//
+
+#include "llvm/Config/config.h"
+#include "llvm/System/Disassembler.h"
+
+#include <cassert>
+#include <iomanip>
+#include <string>
+#include <sstream>
+
+#if USE_UDIS86
+#include <udis86.h>
+#endif
+
+using namespace llvm;
+
+std::string llvm::sys::disassembleBuffer(uint8_t* start, size_t length,
+                                         uint64_t pc) {
+  std::stringstream res;
+
+#if defined (__i386__) || defined (__amd64__) || defined (__x86_64__)
+  unsigned bits;
+# if defined(__i386__)
+  bits = 32;
+# else
+  bits = 64;
+# endif
+  
+# if USE_UDIS86
+  ud_t ud_obj;
+   
+  ud_init(&ud_obj);
+  ud_set_input_buffer(&ud_obj, start, length);
+  ud_set_mode(&ud_obj, bits);
+  ud_set_pc(&ud_obj, pc);
+  ud_set_syntax(&ud_obj, UD_SYN_ATT);
+  
+  res << std::setbase(16)
+      << std::setw(bits/4);
+  
+  while (ud_disassemble(&ud_obj)) {
+    res << ud_insn_off(&ud_obj) << ":\t" << ud_insn_asm(&ud_obj) << "\n";
+  }
+# else
+  res << "No disassembler available. See configure help for avaiable options.\n";
+# endif
+  
+#else
+  res << "No disassembler available. See configure help for avaiable options.\n";
+#endif
+
+  return res.str();
+}