/* esize: prints info from e.out header */ #include #ifndef MAGIC #define MAGIC 07255 #endif MAGIC FILE *load_fp; int eof; /* Much of the code has been borrowed from the EM interpreter */ typedef /* unsigned */ long ptr; /* pointer to EM adress */ long magic; long flags; long uref; long version; long wsize; long psize; long int7; long int8; long ntext; long ndata; long nproc; long entrypoint; long nline; long szdata; long ptr7; long ptr8; main(argc, argv) int argc; char *argv[]; { printf("TPFCRE uref vers w/p text nproc szdata\n"); if (argc == 1) { esize("e.out"); } else { while (argc > 1) { esize(argv[1]); argc--, argv++; } } exit(0); } esize(fname) char *fname; { eof = 0; if (!rd_open(fname)) { printf("%s: cannot open\n", fname); } else { if (!rd_header()) { printf("%s: not EM object format\n", fname); } else { printf("%c", flags&0001 ? 'T' : '-'); printf("%c", flags&0002 ? 'P' : '-'); printf("%c", flags&0004 ? 'F' : '-'); printf("%c", flags&0010 ? 'C' : '-'); printf("%c", flags&0020 ? 'R' : '-'); printf("%c", flags&0040 ? 'E' : '-'); printf("%c", flags&0100 ? '?' : ' '); printf("%c", flags&0200 ? '?' : ' '); printf("%3ld ", uref); printf("%3ld ", version); printf("%1ld/%1ld", wsize, psize); printf("%c", int7 ? '?' : ' '); printf("%c", int8 ? '?' : ' '); printf("%5ld ", ntext); printf("%5ld ", nproc); printf("%6ld", szdata); printf("%c", ptr7 ? '?' : ' '); printf("%c", ptr8 ? '?' : ' '); printf("%s\n", fname); } rd_close(); } } #define btol(a) ((long)(((long) (a)) & 0xFF)) int rd_open(load_file) char *load_file; { return (load_fp = fopen(load_file, "r")) != NULL; } int rd_byte() { int i; if ((i = fgetc(load_fp)) == EOF) eof = 1; return (i); } long rd_int(n) long n; { long l; register int i; l = btol(rd_byte()); for (i = 1; i < n; i++) l = l | (btol(rd_byte()) << (long) (i*8)); return (l); } #define rd_ptr() ((ptr) rd_int(psize)) int rd_header() { magic = rd_int(2L); if (magic != MAGIC || eof) return 0; flags = rd_int(2L); uref = rd_int(2L); version = rd_int(2L); wsize = rd_int(2L); psize = rd_int(2L); int7 = rd_int(2L); /* Entry 7 is unused */ int8 = rd_int(2L); /* Entry 8 is unused */ ntext = rd_ptr(); ndata = rd_ptr(); nproc = rd_ptr(); entrypoint = rd_ptr(); nline = rd_ptr(); szdata = rd_ptr(); ptr7 = rd_ptr(); /* entry 7 is unused */ ptr8 = rd_ptr(); /* entry 8 is unused */ return !eof; } rd_close() { fclose(load_fp); }