⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 sdisasm.c

📁 二进制翻译的一个软件
💻 C
字号:
/* * Copyright (c) 2005, Johns Hopkins University and The EROS Group, LLC. * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * *  * Redistributions of source code must retain the above copyright *    notice, this list of conditions and the following disclaimer. *  * Redistributions in binary form must reproduce the above *    copyright notice, this list of conditions and the following *    disclaimer in the documentation and/or other materials provided *    with the distribution. * *  * Neither the name of the Johns Hopkins University, nor the name *    of The EROS Group, LLC, nor the names of their contributors may *    be used to endorse or promote products derived from this *    software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED * OF THE POSSIBILITY OF SUCH DAMAGE. */#include <stdio.h>#include <stdbool.h>#include <signal.h>#include <asm/sigcontext.h>#include <sys/mman.h>#include <dlfcn.h>#include "switches.h"#include "debug.h"#include "util.h"#include "machine.h"#include "decode.h"#include "emit.h"#include "xlcore.h"#include <unistd.h>#include <sys/types.h>#include <sys/stat.h>#include <fcntl.h>#include <errno.h>#include <string.h>#include <stdlib.h>#include <elf.h>#include <bfd.h>int main(int argc, char *argv[]){  unsigned long prog_start, prog_end;  char buf[400]; /* Buffer overflow */  FILE *F;  unsigned long a, i=0, j=0;  unsigned long cnt = 0;  if(argc < 2) {    printf("Arg(s) Missing\n");    exit(1);  }  system("./clean-dumps.sh");  sprintf(buf, "nm %s | grep '[0-9]* [A-Z] _start' | awk '{print $1}'\                > /tmp/vdebug-dump/._start", argv[1]);  system(buf);  F = fopen("/tmp/vdebug-dump/._start", "r");  fscanf(F, "%lx", &prog_start);  fclose(F);  sprintf(buf, "nm %s | grep '[0-9]* [A-Z] _end' | awk '{print $1}'\                > /tmp/vdebug-dump/._end", argv[1]);  system(buf);  F = fopen("/tmp/vdebug-dump/._end", "r");  fscanf(F, "%lx", &prog_end);  fclose(F);  printf("_start = %lx _end = %lx\n", prog_start, prog_end);#if 0  bfd *abfd = bfd_openr(argv[1], "i686-pc-linux-gnu");  asection *sec;  for (sec = abfd->sections; sec != (asection *) NULL; sec = sec->next) {    		printf("Start = %lx, end = %lx\n", sec->vma, sec->vma + bfd_section_size(abfd, sec) / bfd_octets_per_byte(abfd));  }#endif  sprintf(buf, "../../disasm-0.1/disasm -d -P ../../disasm-0.1/digraphs/istats %s | awk -f grab-blocks.awk > their", argv[1]);  system(buf);  sprintf(buf, "./Nvdbg.sh");  for(i=1; i<argc; i++) {	strcat(buf, " ");	strcat(buf, argv[i]);  }  system(buf);   F= fopen("bbstat", "r");  FILE *FF = fopen("our", "w");  while(fscanf(F, "%lx", &a) != -1) {    if(a > prog_start && a < prog_end) 	   fprintf(FF, "%lx\n", a);  }  fclose(F);  fclose(FF);  //system("sort our | uniq | awk '{if($1 != 0) print $1}'| cat - > our1");  system("sort our | uniq | awk '{if ($1 != 0) print $1}' | cat - > our1");  system("mv our1 our");}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -