l.h 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312
  1. #include <u.h>
  2. #include <libc.h>
  3. #include <bio.h>
  4. #include "../7c/7.out.h"
  5. typedef struct Adr Adr;
  6. typedef struct Sym Sym;
  7. typedef struct Autom Auto;
  8. typedef struct Prog Prog;
  9. typedef struct Optab Optab;
  10. typedef struct Oprang Oprang;
  11. typedef uchar Opcross[32][2][32];
  12. typedef struct Count Count;
  13. #define P ((Prog*)0)
  14. #define S ((Sym*)0)
  15. #define TNAME (curtext&&curtext->from.sym?curtext->from.sym->name:noname)
  16. struct Adr
  17. {
  18. union
  19. {
  20. vlong offset;
  21. char* sval;
  22. Ieee* ieee;
  23. };
  24. union
  25. {
  26. Auto* autom;
  27. Sym* sym;
  28. };
  29. char type;
  30. char reg;
  31. char name;
  32. char class;
  33. };
  34. struct Prog
  35. {
  36. Adr from;
  37. Adr to;
  38. union
  39. {
  40. long regused;
  41. Prog* forwd;
  42. };
  43. Prog* cond;
  44. Prog* link;
  45. long pc;
  46. long line;
  47. uchar mark;
  48. uchar optab;
  49. uchar as;
  50. char reg;
  51. };
  52. struct Sym
  53. {
  54. char *name;
  55. short type;
  56. short version;
  57. short become;
  58. short frame;
  59. long value;
  60. Sym* link;
  61. };
  62. struct Autom
  63. {
  64. Sym* sym;
  65. Auto* link;
  66. long offset;
  67. short type;
  68. };
  69. struct Optab
  70. {
  71. uchar as;
  72. char a1;
  73. char a2;
  74. char a3;
  75. char type;
  76. char size;
  77. char param;
  78. };
  79. struct Oprang
  80. {
  81. Optab* start;
  82. Optab* stop;
  83. };
  84. struct Count
  85. {
  86. long count;
  87. long outof;
  88. };
  89. enum
  90. {
  91. STEXT = 1,
  92. SDATA,
  93. SBSS,
  94. SDATA1,
  95. SXREF,
  96. SLEAF,
  97. SFILE,
  98. SCONST,
  99. C_NONE = 0,
  100. C_REG,
  101. C_FREG,
  102. C_FCREG,
  103. C_PREG,
  104. C_PCC,
  105. C_ZCON,
  106. C_BCON,
  107. C_NCON,
  108. C_SCON,
  109. C_UCON,
  110. C_LCON,
  111. C_QCON,
  112. C_SACON,
  113. C_SECON,
  114. C_LACON,
  115. C_LECON,
  116. C_SBRA,
  117. C_LBRA,
  118. C_SAUTO,
  119. C_SEXT,
  120. C_LAUTO,
  121. C_LEXT,
  122. C_ZOREG,
  123. C_SOREG,
  124. C_LOREG,
  125. C_GOK,
  126. NSCHED = 20,
  127. /* mark flags */
  128. FOLL = 1<<0,
  129. LABEL = 1<<1,
  130. LEAF = 1<<2,
  131. SYNC = 1<<3,
  132. BRANCH = 1<<4,
  133. LABEL2 = 1<<5,
  134. COMPARE = 1<<6,
  135. NOSCHED = 1<<7,
  136. BIG = 32760,
  137. STRINGSZ = 200,
  138. NHASH = 10007,
  139. NHUNK = 100000,
  140. MINSIZ = 64,
  141. NENT = 100,
  142. MAXIO = 8192,
  143. MAXHIST = 20, /* limit of path elements for history symbols */
  144. };
  145. union
  146. {
  147. struct
  148. {
  149. uchar cbuf[MAXIO]; /* output buffer */
  150. uchar xbuf[MAXIO]; /* input buffer */
  151. };
  152. char dbuf[1];
  153. } buf;
  154. long HEADR; /* length of header */
  155. int HEADTYPE; /* type of header */
  156. long INITDAT; /* data location */
  157. long INITRND; /* data round above text location */
  158. long INITTEXT; /* text location */
  159. char* INITENTRY; /* entry point */
  160. long autosize;
  161. Biobuf bso;
  162. long bsssize;
  163. int cbc;
  164. uchar* cbp;
  165. int cout;
  166. Auto* curauto;
  167. Auto* curhist;
  168. Prog* curp;
  169. Prog* curtext;
  170. Prog* datap;
  171. long datsize;
  172. char debug[128];
  173. Prog* etextp;
  174. Prog* firstp;
  175. char fnuxi8[8];
  176. char* noname;
  177. Sym* hash[NHASH];
  178. Sym* histfrog[MAXHIST];
  179. int histfrogp;
  180. int histgen;
  181. char* library[50];
  182. char* libraryobj[50];
  183. int libraryp;
  184. int xrefresolv;
  185. char* hunk;
  186. char inuxi1[1];
  187. char inuxi2[2];
  188. char inuxi4[4];
  189. Prog* lastp;
  190. long lcsize;
  191. char literal[32];
  192. int nerrors;
  193. long nhunk;
  194. vlong offset;
  195. Opcross opcross[7];
  196. Oprang oprange[ALAST];
  197. char* outfile;
  198. long pc;
  199. Prog *prog_divq;
  200. Prog *prog_divqu;
  201. Prog *prog_modq;
  202. Prog *prog_modqu;
  203. Prog *prog_divl;
  204. Prog *prog_divlu;
  205. Prog *prog_modl;
  206. Prog *prog_modlu;
  207. uchar repop[ALAST];
  208. long symsize;
  209. Prog* textp;
  210. long textsize;
  211. long thunk;
  212. int version;
  213. char xcmp[32][32];
  214. Prog zprg;
  215. int dtype;
  216. extern char* anames[];
  217. extern Optab optab[];
  218. #pragma varargck type "A" int
  219. #pragma varargck type "D" Adr*
  220. #pragma varargck type "N" Adr*
  221. #pragma varargck type "P" Prog*
  222. #pragma varargck type "S" char*
  223. int Aconv(Fmt*);
  224. int Dconv(Fmt*);
  225. int Nconv(Fmt*);
  226. int Pconv(Fmt*);
  227. int Sconv(Fmt*);
  228. int aclass(Adr*);
  229. void addhist(long, int);
  230. void addnop(Prog*);
  231. void append(Prog*, Prog*);
  232. void asmb(void);
  233. void asmlc(void);
  234. int asmout(Prog*, Optab*);
  235. void asmsym(void);
  236. long atolwhex(char*);
  237. Prog* brloop(Prog*);
  238. Biobuf bso;
  239. void buildop(void);
  240. void buildrep(int, int);
  241. void cflush(void);
  242. int cmp(int, int);
  243. int compound(Prog*);
  244. int conflict(long, long);
  245. double cputime(void);
  246. void datblk(long, long);
  247. int depend(long, long);
  248. void diag(char*, ...);
  249. Prog *divsubr(int);
  250. void dodata(void);
  251. void doprof1(void);
  252. void doprof2(void);
  253. long entryvalue(void);
  254. void errorexit(void);
  255. void exchange(Prog*);
  256. int find1(long, int);
  257. void follow(void);
  258. Prog *genXXX(Prog *, int, Adr*, int, Adr*);
  259. Prog *genRRR(Prog *, int, int, int, int);
  260. Prog *genIRR(Prog *, int, vlong, int, int);
  261. Prog *genstore(Prog *, int, int, vlong, int);
  262. Prog *genload(Prog *, int, vlong, int, int);
  263. Prog *genjmp(Prog *, int, vlong, int);
  264. void gethunk(void);
  265. void histtoauto(void);
  266. double ieeedtod(Ieee*);
  267. long ieeedtof(Ieee*);
  268. void initdiv(void);
  269. void ldobj(int, long, char*);
  270. void loadlib(void);
  271. void listinit(void);
  272. Sym* lookup(char*, int);
  273. void lput(long);
  274. void lputbe(long);
  275. void mkfwd(void);
  276. void names(void);
  277. void nocache(Prog*);
  278. void noops(void);
  279. void nuxiinit(void);
  280. void objfile(char*);
  281. int ocmp(void*, void*);
  282. long opcode(int);
  283. Optab* oplook(Prog*);
  284. void patch(void);
  285. void prasm(Prog*);
  286. void prepend(Prog*, Prog*);
  287. Prog* prg(void);
  288. int pseudo(Prog*);
  289. void putsymb(char*, int, long, int);
  290. vlong regoff(Adr*);
  291. long regused(Prog*);
  292. int relinv(int);
  293. long rnd(long, long);
  294. void sched(Prog*, Prog*);
  295. void span(void);
  296. void vlput(vlong);
  297. void undef(void);
  298. void xdefine(char*, int, long);
  299. void xfol(Prog*);