1e887ea33SDavid du Colombier #include <u.h> 2e887ea33SDavid du Colombier #include <libc.h> 3e887ea33SDavid du Colombier #include <bio.h> 4e887ea33SDavid du Colombier #include "../6c/6.out.h" 5e887ea33SDavid du Colombier 6e887ea33SDavid du Colombier #ifndef EXTERN 7e887ea33SDavid du Colombier #define EXTERN extern 8e887ea33SDavid du Colombier #endif 9e887ea33SDavid du Colombier 10e887ea33SDavid du Colombier #define P ((Prog*)0) 11e887ea33SDavid du Colombier #define S ((Sym*)0) 12e887ea33SDavid du Colombier #define TNAME (curtext?curtext->from.sym->name:noname) 13e887ea33SDavid du Colombier #define cput(c)\ 14e887ea33SDavid du Colombier { *cbp++ = c;\ 15e887ea33SDavid du Colombier if(--cbc <= 0)\ 16e887ea33SDavid du Colombier cflush(); } 17e887ea33SDavid du Colombier 18*b87cd620SDavid du Colombier #define LIBNAMELEN 300 19*b87cd620SDavid du Colombier 20e887ea33SDavid du Colombier typedef struct Adr Adr; 21e887ea33SDavid du Colombier typedef struct Prog Prog; 22e887ea33SDavid du Colombier typedef struct Sym Sym; 23e887ea33SDavid du Colombier typedef struct Auto Auto; 24e887ea33SDavid du Colombier typedef struct Optab Optab; 25e887ea33SDavid du Colombier typedef struct Movtab Movtab; 26e887ea33SDavid du Colombier 27e887ea33SDavid du Colombier struct Adr 28e887ea33SDavid du Colombier { 29e887ea33SDavid du Colombier union 30e887ea33SDavid du Colombier { 31e887ea33SDavid du Colombier vlong u0offset; 32e887ea33SDavid du Colombier char u0scon[8]; 33e887ea33SDavid du Colombier Prog *u0cond; /* not used, but should be D_BRANCH */ 34e887ea33SDavid du Colombier Ieee u0ieee; 35e887ea33SDavid du Colombier } u0; 36e887ea33SDavid du Colombier union 37e887ea33SDavid du Colombier { 38e887ea33SDavid du Colombier Auto* u1autom; 39e887ea33SDavid du Colombier Sym* u1sym; 40e887ea33SDavid du Colombier } u1; 41e887ea33SDavid du Colombier short type; 42e887ea33SDavid du Colombier char index; 43e887ea33SDavid du Colombier char scale; 44e887ea33SDavid du Colombier }; 45e887ea33SDavid du Colombier 46e887ea33SDavid du Colombier #define offset u0.u0offset 47e887ea33SDavid du Colombier #define scon u0.u0scon 48e887ea33SDavid du Colombier #define cond u0.u0cond 49e887ea33SDavid du Colombier #define ieee u0.u0ieee 50e887ea33SDavid du Colombier 51e887ea33SDavid du Colombier #define autom u1.u1autom 52e887ea33SDavid du Colombier #define sym u1.u1sym 53e887ea33SDavid du Colombier 54e887ea33SDavid du Colombier struct Prog 55e887ea33SDavid du Colombier { 56e887ea33SDavid du Colombier Adr from; 57e887ea33SDavid du Colombier Adr to; 58e887ea33SDavid du Colombier Prog *forwd; 59e887ea33SDavid du Colombier Prog* link; 60e887ea33SDavid du Colombier Prog* pcond; /* work on this */ 61e887ea33SDavid du Colombier vlong pc; 62e887ea33SDavid du Colombier long line; 63e887ea33SDavid du Colombier uchar mark; /* work on these */ 64e887ea33SDavid du Colombier uchar back; 65e887ea33SDavid du Colombier 66e887ea33SDavid du Colombier short as; 67e887ea33SDavid du Colombier char width; /* fake for DATA */ 68e887ea33SDavid du Colombier char mode; /* 16, 32, or 64 */ 69e887ea33SDavid du Colombier }; 70e887ea33SDavid du Colombier struct Auto 71e887ea33SDavid du Colombier { 72e887ea33SDavid du Colombier Sym* asym; 73e887ea33SDavid du Colombier Auto* link; 74e887ea33SDavid du Colombier long aoffset; 75e887ea33SDavid du Colombier short type; 76e887ea33SDavid du Colombier }; 77e887ea33SDavid du Colombier struct Sym 78e887ea33SDavid du Colombier { 79e887ea33SDavid du Colombier char *name; 80e887ea33SDavid du Colombier short type; 81e887ea33SDavid du Colombier short version; 82e887ea33SDavid du Colombier short become; 83e887ea33SDavid du Colombier short frame; 84e887ea33SDavid du Colombier uchar subtype; 85e887ea33SDavid du Colombier ushort file; 86e887ea33SDavid du Colombier vlong value; 87e887ea33SDavid du Colombier long sig; 88e887ea33SDavid du Colombier Sym* link; 89e887ea33SDavid du Colombier }; 90e887ea33SDavid du Colombier struct Optab 91e887ea33SDavid du Colombier { 92e887ea33SDavid du Colombier short as; 93e887ea33SDavid du Colombier uchar* ytab; 94e887ea33SDavid du Colombier uchar prefix; 95e887ea33SDavid du Colombier uchar op[20]; 96e887ea33SDavid du Colombier }; 97e887ea33SDavid du Colombier struct Movtab 98e887ea33SDavid du Colombier { 99e887ea33SDavid du Colombier short as; 100e887ea33SDavid du Colombier uchar ft; 101e887ea33SDavid du Colombier uchar tt; 102e887ea33SDavid du Colombier uchar code; 103e887ea33SDavid du Colombier uchar op[4]; 104e887ea33SDavid du Colombier }; 105e887ea33SDavid du Colombier 106e887ea33SDavid du Colombier enum 107e887ea33SDavid du Colombier { 108e887ea33SDavid du Colombier STEXT = 1, 109e887ea33SDavid du Colombier SDATA, 110e887ea33SDavid du Colombier SBSS, 111e887ea33SDavid du Colombier SDATA1, 112e887ea33SDavid du Colombier SXREF, 113e887ea33SDavid du Colombier SFILE, 114e887ea33SDavid du Colombier SCONST, 115e887ea33SDavid du Colombier SUNDEF, 116e887ea33SDavid du Colombier 117e887ea33SDavid du Colombier SIMPORT, 118e887ea33SDavid du Colombier SEXPORT, 119e887ea33SDavid du Colombier 120e887ea33SDavid du Colombier NHASH = 10007, 121e887ea33SDavid du Colombier NHUNK = 100000, 122e887ea33SDavid du Colombier MINSIZ = 8, 123e887ea33SDavid du Colombier STRINGSZ = 200, 124e887ea33SDavid du Colombier MINLC = 1, 125e887ea33SDavid du Colombier MAXIO = 8192, 126e887ea33SDavid du Colombier MAXHIST = 20, /* limit of path elements for history symbols */ 127e887ea33SDavid du Colombier 128e887ea33SDavid du Colombier Yxxx = 0, 129e887ea33SDavid du Colombier Ynone, 130e887ea33SDavid du Colombier Yi0, 131e887ea33SDavid du Colombier Yi1, 132e887ea33SDavid du Colombier Yi8, 133e887ea33SDavid du Colombier Ys32, 134e887ea33SDavid du Colombier Yi32, 135e887ea33SDavid du Colombier Yi64, 136e887ea33SDavid du Colombier Yiauto, 137e887ea33SDavid du Colombier Yal, 138e887ea33SDavid du Colombier Ycl, 139e887ea33SDavid du Colombier Yax, 140e887ea33SDavid du Colombier Ycx, 141e887ea33SDavid du Colombier Yrb, 142e887ea33SDavid du Colombier Yrl, 143e887ea33SDavid du Colombier Yrf, 144e887ea33SDavid du Colombier Yf0, 145e887ea33SDavid du Colombier Yrx, 146e887ea33SDavid du Colombier Ymb, 147e887ea33SDavid du Colombier Yml, 148e887ea33SDavid du Colombier Ym, 149e887ea33SDavid du Colombier Ybr, 150e887ea33SDavid du Colombier Ycol, 151e887ea33SDavid du Colombier 152e887ea33SDavid du Colombier Ycs, Yss, Yds, Yes, Yfs, Ygs, 153e887ea33SDavid du Colombier Ygdtr, Yidtr, Yldtr, Ymsw, Ytask, 154e887ea33SDavid du Colombier Ycr0, Ycr1, Ycr2, Ycr3, Ycr4, Ycr5, Ycr6, Ycr7, Ycr8, 155e887ea33SDavid du Colombier Ydr0, Ydr1, Ydr2, Ydr3, Ydr4, Ydr5, Ydr6, Ydr7, 156e887ea33SDavid du Colombier Ytr0, Ytr1, Ytr2, Ytr3, Ytr4, Ytr5, Ytr6, Ytr7, Yrl32, Yrl64, 157e887ea33SDavid du Colombier Ymr, Ymm, 158e887ea33SDavid du Colombier Yxr, Yxm, 159e887ea33SDavid du Colombier Ymax, 160e887ea33SDavid du Colombier 161e887ea33SDavid du Colombier Zxxx = 0, 162e887ea33SDavid du Colombier 163e887ea33SDavid du Colombier Zlit, 164e887ea33SDavid du Colombier Z_rp, 165e887ea33SDavid du Colombier Zbr, 166e887ea33SDavid du Colombier Zcall, 167e887ea33SDavid du Colombier Zib_, 168e887ea33SDavid du Colombier Zib_rp, 169e887ea33SDavid du Colombier Zibo_m, 170e887ea33SDavid du Colombier Zibo_m_xm, 171e887ea33SDavid du Colombier Zil_, 172e887ea33SDavid du Colombier Zil_rp, 173e887ea33SDavid du Colombier Ziq_rp, 174e887ea33SDavid du Colombier Zilo_m, 175e887ea33SDavid du Colombier Ziqo_m, 176e887ea33SDavid du Colombier Zjmp, 177e887ea33SDavid du Colombier Zloop, 178e887ea33SDavid du Colombier Zo_iw, 179e887ea33SDavid du Colombier Zm_o, 180e887ea33SDavid du Colombier Zm_r, 181e887ea33SDavid du Colombier Zm_r_xm, 182e887ea33SDavid du Colombier Zm_r_i_xm, 183e887ea33SDavid du Colombier Zm_r_3d, 184e887ea33SDavid du Colombier Zm_r_xm_nr, 185e887ea33SDavid du Colombier Zr_m_xm_nr, 186e887ea33SDavid du Colombier Zibm_r, /* mmx1,mmx2/mem64,imm8 */ 187e887ea33SDavid du Colombier Zmb_r, 188e887ea33SDavid du Colombier Zaut_r, 189e887ea33SDavid du Colombier Zo_m, 190e887ea33SDavid du Colombier Zo_m64, 191e887ea33SDavid du Colombier Zpseudo, 192e887ea33SDavid du Colombier Zr_m, 193e887ea33SDavid du Colombier Zr_m_xm, 194e887ea33SDavid du Colombier Zr_m_i_xm, 195e887ea33SDavid du Colombier Zrp_, 196e887ea33SDavid du Colombier Z_ib, 197e887ea33SDavid du Colombier Z_il, 198e887ea33SDavid du Colombier Zm_ibo, 199e887ea33SDavid du Colombier Zm_ilo, 200e887ea33SDavid du Colombier Zib_rr, 201e887ea33SDavid du Colombier Zil_rr, 202e887ea33SDavid du Colombier Zclr, 203e887ea33SDavid du Colombier Zbyte, 204e887ea33SDavid du Colombier Zmax, 205e887ea33SDavid du Colombier 206e887ea33SDavid du Colombier Px = 0, 207e887ea33SDavid du Colombier P32 = 0x32, /* 32-bit only */ 208e887ea33SDavid du Colombier Pe = 0x66, /* operand escape */ 209e887ea33SDavid du Colombier Pm = 0x0f, /* 2byte opcode escape */ 210e887ea33SDavid du Colombier Pq = 0xff, /* both escape */ 211e887ea33SDavid du Colombier Pb = 0xfe, /* byte operands */ 212e887ea33SDavid du Colombier Pf2 = 0xf2, /* xmm escape 1 */ 213e887ea33SDavid du Colombier Pf3 = 0xf3, /* xmm escape 2 */ 214e887ea33SDavid du Colombier Pw = 0x48, /* Rex.w */ 215e887ea33SDavid du Colombier Py = 0x80, /* defaults to 64-bit mode */ 216e887ea33SDavid du Colombier 217e887ea33SDavid du Colombier Rxf = 1<<9, /* internal flag for Rxr on from */ 218e887ea33SDavid du Colombier Rxt = 1<<8, /* internal flag for Rxr on to */ 219e887ea33SDavid du Colombier Rxw = 1<<3, /* =1, 64-bit operand size */ 220e887ea33SDavid du Colombier Rxr = 1<<2, /* extend modrm reg */ 221e887ea33SDavid du Colombier Rxx = 1<<1, /* extend sib index */ 222e887ea33SDavid du Colombier Rxb = 1<<0, /* extend modrm r/m, sib base, or opcode reg */ 223e887ea33SDavid du Colombier 224e887ea33SDavid du Colombier Roffset = 22, /* no. bits for offset in relocation address */ 225e887ea33SDavid du Colombier Rindex = 10, /* no. bits for index in relocation address */ 226e887ea33SDavid du Colombier }; 227e887ea33SDavid du Colombier 228e887ea33SDavid du Colombier EXTERN union 229e887ea33SDavid du Colombier { 230e887ea33SDavid du Colombier struct 231e887ea33SDavid du Colombier { 232e887ea33SDavid du Colombier char obuf[MAXIO]; /* output buffer */ 233e887ea33SDavid du Colombier uchar ibuf[MAXIO]; /* input buffer */ 234e887ea33SDavid du Colombier } u; 235e887ea33SDavid du Colombier char dbuf[1]; 236e887ea33SDavid du Colombier } buf; 237e887ea33SDavid du Colombier 238e887ea33SDavid du Colombier #define cbuf u.obuf 239e887ea33SDavid du Colombier #define xbuf u.ibuf 240e887ea33SDavid du Colombier 241e887ea33SDavid du Colombier #pragma varargck type "A" int 242e887ea33SDavid du Colombier #pragma varargck type "A" uint 243e887ea33SDavid du Colombier #pragma varargck type "D" Adr* 244e887ea33SDavid du Colombier #pragma varargck type "P" Prog* 245e887ea33SDavid du Colombier #pragma varargck type "R" int 246e887ea33SDavid du Colombier #pragma varargck type "S" char* 247e887ea33SDavid du Colombier 248e887ea33SDavid du Colombier #pragma varargck argpos diag 1 249e887ea33SDavid du Colombier 250e887ea33SDavid du Colombier EXTERN long HEADR; 251e887ea33SDavid du Colombier EXTERN long HEADTYPE; 252e887ea33SDavid du Colombier EXTERN vlong INITDAT; 253e887ea33SDavid du Colombier EXTERN long INITRND; 254e887ea33SDavid du Colombier EXTERN vlong INITTEXT; 255e887ea33SDavid du Colombier EXTERN char* INITENTRY; /* entry point */ 256e887ea33SDavid du Colombier EXTERN Biobuf bso; 257e887ea33SDavid du Colombier EXTERN long bsssize; 258e887ea33SDavid du Colombier EXTERN int cbc; 259e887ea33SDavid du Colombier EXTERN char* cbp; 260e887ea33SDavid du Colombier EXTERN char* pcstr; 261e887ea33SDavid du Colombier EXTERN int cout; 262e887ea33SDavid du Colombier EXTERN Auto* curauto; 263e887ea33SDavid du Colombier EXTERN Auto* curhist; 264e887ea33SDavid du Colombier EXTERN Prog* curp; 265e887ea33SDavid du Colombier EXTERN Prog* curtext; 266e887ea33SDavid du Colombier EXTERN Prog* datap; 267e887ea33SDavid du Colombier EXTERN Prog* edatap; 268e887ea33SDavid du Colombier EXTERN vlong datsize; 269e887ea33SDavid du Colombier EXTERN char debug[128]; 270e887ea33SDavid du Colombier EXTERN char literal[32]; 271e887ea33SDavid du Colombier EXTERN Prog* etextp; 272e887ea33SDavid du Colombier EXTERN Prog* firstp; 273e887ea33SDavid du Colombier EXTERN uchar fnuxi8[8]; 274e887ea33SDavid du Colombier EXTERN uchar fnuxi4[4]; 275e887ea33SDavid du Colombier EXTERN Sym* hash[NHASH]; 276e887ea33SDavid du Colombier EXTERN Sym* histfrog[MAXHIST]; 277e887ea33SDavid du Colombier EXTERN int histfrogp; 278e887ea33SDavid du Colombier EXTERN int histgen; 279e887ea33SDavid du Colombier EXTERN char* library[50]; 280e887ea33SDavid du Colombier EXTERN char* libraryobj[50]; 281e887ea33SDavid du Colombier EXTERN int libraryp; 282e887ea33SDavid du Colombier EXTERN int xrefresolv; 283e887ea33SDavid du Colombier EXTERN char* hunk; 284e887ea33SDavid du Colombier EXTERN uchar inuxi1[1]; 285e887ea33SDavid du Colombier EXTERN uchar inuxi2[2]; 286e887ea33SDavid du Colombier EXTERN uchar inuxi4[4]; 287e887ea33SDavid du Colombier EXTERN uchar inuxi8[8]; 288e887ea33SDavid du Colombier EXTERN char ycover[Ymax*Ymax]; 289e887ea33SDavid du Colombier EXTERN uchar* andptr; 290e887ea33SDavid du Colombier EXTERN uchar* rexptr; 291e887ea33SDavid du Colombier EXTERN uchar and[30]; 292e887ea33SDavid du Colombier EXTERN int reg[D_NONE]; 293e887ea33SDavid du Colombier EXTERN int regrex[D_NONE+1]; 294e887ea33SDavid du Colombier EXTERN Prog* lastp; 295e887ea33SDavid du Colombier EXTERN long lcsize; 296e887ea33SDavid du Colombier EXTERN int nerrors; 297e887ea33SDavid du Colombier EXTERN long nhunk; 298e887ea33SDavid du Colombier EXTERN long nsymbol; 299e887ea33SDavid du Colombier EXTERN char* noname; 300e887ea33SDavid du Colombier EXTERN char* outfile; 301e887ea33SDavid du Colombier EXTERN vlong pc; 302e887ea33SDavid du Colombier EXTERN long spsize; 303e887ea33SDavid du Colombier EXTERN Sym* symlist; 304e887ea33SDavid du Colombier EXTERN long symsize; 305e887ea33SDavid du Colombier EXTERN Prog* textp; 306e887ea33SDavid du Colombier EXTERN vlong textsize; 307e887ea33SDavid du Colombier EXTERN long thunk; 308e887ea33SDavid du Colombier EXTERN int version; 309e887ea33SDavid du Colombier EXTERN Prog zprg; 310e887ea33SDavid du Colombier EXTERN int dtype; 311e887ea33SDavid du Colombier EXTERN char* paramspace; 312e887ea33SDavid du Colombier 313e887ea33SDavid du Colombier EXTERN Adr* reloca; 314e887ea33SDavid du Colombier EXTERN int doexp, dlm; 315e887ea33SDavid du Colombier EXTERN int imports, nimports; 316e887ea33SDavid du Colombier EXTERN int exports, nexports; 317e887ea33SDavid du Colombier EXTERN char* EXPTAB; 318e887ea33SDavid du Colombier EXTERN Prog undefp; 319e887ea33SDavid du Colombier 320e887ea33SDavid du Colombier #define UP (&undefp) 321e887ea33SDavid du Colombier 322e887ea33SDavid du Colombier extern Optab optab[]; 323e887ea33SDavid du Colombier extern Optab* opindex[]; 324e887ea33SDavid du Colombier extern char* anames[]; 325e887ea33SDavid du Colombier 326e887ea33SDavid du Colombier int Aconv(Fmt*); 327e887ea33SDavid du Colombier int Dconv(Fmt*); 328e887ea33SDavid du Colombier int Pconv(Fmt*); 329e887ea33SDavid du Colombier int Rconv(Fmt*); 330e887ea33SDavid du Colombier int Sconv(Fmt*); 331e887ea33SDavid du Colombier void addhist(long, int); 332*b87cd620SDavid du Colombier void addlibpath(char*); 333e887ea33SDavid du Colombier Prog* appendp(Prog*); 334e887ea33SDavid du Colombier void asmb(void); 335e887ea33SDavid du Colombier void asmdyn(void); 336e887ea33SDavid du Colombier void asmins(Prog*); 337e887ea33SDavid du Colombier void asmlc(void); 338e887ea33SDavid du Colombier void asmsp(void); 339e887ea33SDavid du Colombier void asmsym(void); 340e887ea33SDavid du Colombier vlong atolwhex(char*); 341e887ea33SDavid du Colombier Prog* brchain(Prog*); 342e887ea33SDavid du Colombier Prog* brloop(Prog*); 343e887ea33SDavid du Colombier void buildop(void); 344e887ea33SDavid du Colombier void cflush(void); 345e887ea33SDavid du Colombier void ckoff(Sym*, long); 346e887ea33SDavid du Colombier Prog* copyp(Prog*); 347e887ea33SDavid du Colombier double cputime(void); 348e887ea33SDavid du Colombier void datblk(long, long); 349e887ea33SDavid du Colombier void diag(char*, ...); 350e887ea33SDavid du Colombier void dodata(void); 351e887ea33SDavid du Colombier void doinit(void); 352e887ea33SDavid du Colombier void doprof1(void); 353e887ea33SDavid du Colombier void doprof2(void); 354e887ea33SDavid du Colombier void dostkoff(void); 355e887ea33SDavid du Colombier void dynreloc(Sym*, ulong, int); 356e887ea33SDavid du Colombier vlong entryvalue(void); 357e887ea33SDavid du Colombier void errorexit(void); 358e887ea33SDavid du Colombier void export(void); 359*b87cd620SDavid du Colombier int fileexists(char*); 360e887ea33SDavid du Colombier int find1(long, int); 361e887ea33SDavid du Colombier int find2(long, int); 362*b87cd620SDavid du Colombier char* findlib(char*); 363e887ea33SDavid du Colombier void follow(void); 364e887ea33SDavid du Colombier void gethunk(void); 365e887ea33SDavid du Colombier void histtoauto(void); 366e887ea33SDavid du Colombier double ieeedtod(Ieee*); 367e887ea33SDavid du Colombier long ieeedtof(Ieee*); 368e887ea33SDavid du Colombier void import(void); 369e887ea33SDavid du Colombier void ldobj(int, long, char*); 370e887ea33SDavid du Colombier void loadlib(void); 371e887ea33SDavid du Colombier void listinit(void); 372e887ea33SDavid du Colombier Sym* lookup(char*, int); 373e887ea33SDavid du Colombier void lput(long); 374e887ea33SDavid du Colombier void lputl(long); 375e887ea33SDavid du Colombier void main(int, char*[]); 376e887ea33SDavid du Colombier void mkfwd(void); 377e887ea33SDavid du Colombier void* mysbrk(ulong); 378e887ea33SDavid du Colombier void nuxiinit(void); 379e887ea33SDavid du Colombier void objfile(char*); 380e887ea33SDavid du Colombier int opsize(Prog*); 381e887ea33SDavid du Colombier void patch(void); 382e887ea33SDavid du Colombier Prog* prg(void); 383e887ea33SDavid du Colombier void readundefs(char*, int); 384e887ea33SDavid du Colombier int relinv(int); 385e887ea33SDavid du Colombier long reuse(Prog*, Sym*); 386e887ea33SDavid du Colombier vlong rnd(vlong, vlong); 387e887ea33SDavid du Colombier void span(void); 388e887ea33SDavid du Colombier void undef(void); 389e887ea33SDavid du Colombier void undefsym(Sym*); 390e887ea33SDavid du Colombier vlong vaddr(Adr*); 391e887ea33SDavid du Colombier void wput(ushort); 392e887ea33SDavid du Colombier void xdefine(char*, int, vlong); 393e887ea33SDavid du Colombier void xfol(Prog*); 394e887ea33SDavid du Colombier int zaddr(uchar*, Adr*, Sym*[]); 395e887ea33SDavid du Colombier void zerosig(char*); 396