--- memfetch.c.orig Mon Oct 20 20:04:45 2003 +++ memfetch.c Thu Nov 25 15:51:00 2004 @@ -20,6 +20,8 @@ #include #include #include +#include +#include #include #include #include @@ -27,7 +29,8 @@ #include #include #include -#include +/* #include */ +#include #include #include @@ -49,7 +52,7 @@ fprintf(outfile,"** Error message: " x); \ fclose(outfile); \ } \ - if (tracepid>0) ptrace(PTRACE_DETACH,tracepid,0,lastsig); \ + if (tracepid>0) ptrace(PT_DETACH,tracepid,0,lastsig); \ exit(1); \ } @@ -74,6 +77,7 @@ " -a - skip non-anonymous maps (libraries etc)\n" " -w - write index file to stdout instead of mfetch.lst\n" " -m - avoid mmap(), helps prevent hanging on some 2.2 boxes\n" + " - this is the only way to go on FreeBSD, for now.\n" " -S xxx - dump segment containing address xxx (hex) only\n",myname); exit(3); } @@ -124,7 +128,7 @@ if (kill(tracepid,0)) fatal("Process does not exist or is not accessible.\n"); - if (ptrace(PTRACE_ATTACH,tracepid,0,0)) + if (ptrace(PT_ATTACH,tracepid,0,0)) fatal("Cannot attach to this process (already traced?).\n"); if ( wait(&st)<=0 || !WIFSTOPPED(st) ) { @@ -149,7 +153,7 @@ while (1) { - ptrace(PTRACE_CONT,tracepid,0,lastsig); + ptrace(PT_CONTINUE,tracepid,0,lastsig); if (wait(&st)<=0) { debug("[-] Process gone before receiving a fault signal.\n"); @@ -198,7 +202,7 @@ leavewait: // GOTOs for president! - sprintf(tmp,"/proc/%d/maps",tracepid); + sprintf(tmp,"/proc/%d/map",tracepid); mapfile=fopen(tmp,"r"); if (!mapfile) fatal("Cannot open %s for reading.\n",tmp); @@ -237,8 +241,8 @@ int* writeptr; char mapped=1; - if (sscanf(tmp,"%x-%x",&st,&en)!=2) { - debug("[!] Parse error in /proc/%d/maps (mockery?): %s",tracepid,tmp); + if (sscanf(tmp,"%x %x",&st,&en)!=2) { + debug("[!] Parse error in /proc/%d/map (mockery?): %s",tracepid,tmp); continue; } @@ -280,7 +284,7 @@ st,len); if (avoid_mmap) writeptr=MAP_FAILED; else { - for (i=st;i<=en;i+=PAGE_SIZE) ptrace(PTRACE_PEEKDATA,tracepid,i,0); + for (i=st;i<=en;i+=PAGE_SIZE) ptrace(PT_READ_D,tracepid,(caddr_t)i,0); writeptr=mmap(0,len,PROT_READ,MAP_PRIVATE,memfile,st); } @@ -292,7 +296,7 @@ if (lseek(memfile,st,SEEK_SET)!=st || read(memfile,writeptr,len)!=len) { debug("[S] "); for (i=0;i