* src/vm/jit/code.c (code_find_codeinfo_for_pc): Use void* instead of
[cacao.git] / src / vm / jit / x86_64 / disass.c
index 2505bd7f67fb76a6869dd17d432fc9d78de14892..0a949b98058a97b69bd2d0bc5649ff94a28c21b3 100644 (file)
@@ -1,9 +1,9 @@
 /* src/vm/jit/x86_64/disass.c - wrapper functions for GNU binutils disassembler
 
-   Copyright (C) 1996-2005 R. Grafl, A. Krall, C. Kruegel, C. Oates,
-   R. Obermaisser, M. Platter, M. Probst, S. Ring, E. Steiner,
-   C. Thalinger, D. Thuernbeck, P. Tomsich, C. Ullrich, J. Wenninger,
-   Institut f. Computersprachen - TU Wien
+   Copyright (C) 1996-2005, 2006 R. Grafl, A. Krall, C. Kruegel,
+   C. Oates, R. Obermaisser, M. Platter, M. Probst, S. Ring,
+   E. Steiner, C. Thalinger, D. Thuernbeck, P. Tomsich, C. Ullrich,
+   J. Wenninger, Institut f. Computersprachen - TU Wien
 
    This file is part of CACAO.
 
 
    You should have received a copy of the GNU General Public License
    along with this program; if not, write to the Free Software
-   Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
-   02111-1307, USA.
+   Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
+   02110-1301, USA.
 
-   Contact: cacao@complang.tuwien.ac.at
+   Contact: cacao@cacaojvm.org
 
    Authors: Andreas  Krall
             Reinhard Grafl
 
    Changes: Christian Thalinger
 
-   $Id: disass.c 3178 2005-09-14 18:14:34Z twisti $
-
 */
 
 
-#include <stdarg.h>
-
-#include "mm/memory.h"
-#include "vm/jit/x86_64/dis-asm.h"
-#include "vm/jit/x86_64/types.h"
-
-
-/* global variables ***********************************************************/
-
-char mylinebuf[512];
-int mylen;
-
-
-/* name table for 16 integer registers */
-
-char *regs[] = {
-       "rax",
-       "rcx",
-       "rdx",
-       "rbx",
-       "rsp",
-       "rbp",
-       "rsi",
-       "rdi",
-    "r8",
-    "r9",
-    "r10",
-    "r11",
-    "r12",
-    "r13",
-    "r14",
-    "r15"
-};
+#include "config.h"
 
+#include <dis-asm.h>
+#include <stdio.h>
 
-void myprintf(PTR p, const char *fmt, ...)
-{
-       va_list ap;
-       va_start(ap, fmt);
-       mylen += vsprintf(mylinebuf + mylen, fmt, ap);
-       va_end(ap);
-}
-
-
-int buffer_read_memory(bfd_vma memaddr, bfd_byte *myaddr, unsigned int length, struct disassemble_info *info)
-{
-       if (length == 1) {
-               *myaddr = *((u1 *) memaddr);
-
-       } else {
-               MCOPY(myaddr, (void *) memaddr, u1, length);
-       }
+#include "vm/types.h"
 
-       return 0;
-}
+#include "vm/global.h"
+#include "vm/jit/disass.h"
 
 
 /* disassinstr *****************************************************************
@@ -102,54 +54,38 @@ int buffer_read_memory(bfd_vma memaddr, bfd_byte *myaddr, unsigned int length, s
 
 u1 *disassinstr(u1 *code)
 {
-       static disassemble_info info;
-       static int dis_initialized;
        s4 seqlen;
        s4 i;
 
-       if (!dis_initialized) {
-               INIT_DISASSEMBLE_INFO(info, NULL, myprintf);
-               info.mach = bfd_mach_x86_64;
-               dis_initialized = 1;
+       if (!disass_initialized) {
+               INIT_DISASSEMBLE_INFO(info, NULL, disass_printf);
+
+               /* setting the struct members must be done after
+                  INIT_DISASSEMBLE_INFO */
+
+               info.mach             = bfd_mach_x86_64;
+               info.read_memory_func = &disass_buffer_read_memory;
+
+               disass_initialized = true;
        }
 
        printf("0x%016lx:   ", (s8) code);
-       mylen = 0;
+
+       disass_len = 0;
+
        seqlen = print_insn_i386((bfd_vma) code, &info);
 
-       for (i = 0; i < seqlen; i++) {
-               printf("%02x ", *(code + i));
+       for (i = 0; i < seqlen; i++, code++) {
+               printf("%02x ", *code);
        }
        
        for (; i < 10; i++) {
                printf("   ");
        }
 
-       printf("   %s\n", mylinebuf);
-
-       return code + seqlen;
-}
-
-
-/* disassemble *****************************************************************
-
-   Outputs a disassembler listing of some machine code on `stdout'.
-
-   code: pointer to first instruction
-   len:  code size
-
-*******************************************************************************/
-
-void disassemble(u1 *start, u1 *end)
-{
-       disassemble_info info;
-
-       INIT_DISASSEMBLE_INFO(info, NULL, myprintf);
-       info.mach = bfd_mach_x86_64;
+       printf("   %s\n", disass_buf);
 
-       printf("  --- disassembler listing ---\n");
-       for (; start < end; )
-               start = disassinstr(start);
+       return code;
 }