CC68.P
上传用户:hlzzc88
上传日期:2007-01-06
资源大小:220k
文件大小:7k
源码类别:

编译器/解释器

开发平台:

Others

  1. /* Protogen Version 1.00 Saturday May 31, 1997  17:24:44 */
  2.                               /* Gexpr68.c */
  3. int chksize(int lsize, int rsize);
  4. AMODE    *make_label(int lab);
  5. AMODE    *makebf(ENODE *node, AMODE *ap1, int size);
  6. AMODE    *make_immed(long i);
  7. AMODE    *make_offset(ENODE *node);
  8. void tofloat(AMODE *ap,int size);
  9. void make_legal(AMODE *ap,int flags,int size);
  10. void doshift(int op, AMODE *ap2, AMODE *ap1, int size);
  11. void bit_legal(AMODE *ap,ENODE *node, int size);
  12. AMODE *get_bitval(AMODE *ap,ENODE *node, int size);
  13. void bit_move(AMODE *ap1, AMODE *ap2, ENODE *node, int flags, int sizein, int sizeout);
  14. void do_extend(AMODE *ap,int isize,int osize,int flags);
  15. int     isshort(ENODE *node);
  16. int     isbyte(ENODE *node);
  17. int isamshort(AMODE *ap);
  18. int isamshort2(AMODE *ap, AMODE *ap2);
  19. int isambyte(AMODE *ap);
  20. int isambyte2(AMODE *ap, AMODE *ap2);
  21. AMODE    *gen_index(int siz1,ENODE *node);
  22. AMODE    *gen_deref(ENODE *node, int flags,int size, int flag);
  23. AMODE    *gen_unary(ENODE *node,int flags,int size,int op, int fop);
  24. AMODE    *gen_binary(ENODE *node,int flags,int size,int op, int fop);
  25. AMODE    *gen_xbin(ENODE *node,int flags,int size,int op, int fop);
  26. AMODE    *gen_shift(ENODE *node, int flags, int size, int op);
  27. AMODE    *gen_modiv(ENODE *node, int flags, int size, int op, int modflag);
  28. void swap_nodes(ENODE *node);
  29. AMODE * gen_pdiv(ENODE *node, int flags, int size);
  30. AMODE * gen_pmul(ENODE *node, int flags, int size);
  31. AMODE    *gen_mul(ENODE *node, int flags, int size, int op);
  32. AMODE    *gen_hook(ENODE *node, int flags, int size);
  33. AMODE    *gen_asadd(ENODE *node, int flags, int size, int op, int fop);
  34. AMODE    *gen_aslogic(ENODE *node, int flags, int size, int op);
  35. AMODE *gen_asshift(ENODE *node, int flags, int size, int op);
  36. AMODE    *gen_asmul(ENODE *node, int flags, int size,int op);
  37. AMODE    *gen_asmodiv(ENODE *node, int flags, int size, int op, int modflag);
  38. AMODE *gen_moveblock(ENODE *node, int flags, int size);
  39. int count_regs(AMODE *ap1, AMODE *ap2);
  40. AMODE    *gen_assign(ENODE *node, int flags, int size);
  41. AMODE    *gen_refassign(ENODE *node, int flags, int size);
  42. AMODE    *gen_aincdec(ENODE *node, int flags, int size, int op);
  43. int push_param(ENODE *ep,int size);
  44. int push_stackblock(ENODE *ep);
  45. int     gen_parms(ENODE *plist,int size);
  46. AMODE    *gen_fcall(ENODE *node,int flags, int size);
  47. AMODE    *gen_pfcall(ENODE *node,int flags, int size);
  48. AMODE    *gen_expr(ENODE *node, int flags, int size);
  49. int     natural_size(ENODE *node);
  50. void gen_compare(ENODE *node, int btype1, int btype2, int btype3, int btype4, int label);
  51. void truejp(ENODE *node, int label);
  52. void falsejp(ENODE *node, int label);
  53.                               /* Gstmt68.c */
  54. void genstmtini(void);
  55. AMODE    *makedreg(int r);
  56. AMODE    *makeareg(int r);
  57. AMODE    *makefreg(int r);
  58. AMODE    *make_mask(int mask, int reverse, int floatflag);
  59. AMODE    *make_direct(int i);
  60. AMODE    *make_strlab(char *s);
  61. void genwhile(SNODE *stmt);
  62. void gen_for(SNODE *stmt);
  63. void genif(SNODE *stmt);
  64. void gendo(SNODE *stmt);
  65. void gen_genword(SNODE *stmt);
  66. AMODE *set_symbol(char *name, int isproc);
  67. AMODE *flush_for_libcall(void);
  68. AMODE *call_library(char *lib_name,int size);
  69. int analyzeswitch(SNODE *stmt);
  70. void bingen(int lower, int avg, int higher,AMODE *ap1, int deflab, int size, long *switchids, int *switchlabels, int *switchbinlabels);
  71. void genbinaryswitch(SNODE *stmt, int deflab);
  72. void gencompactswitch(SNODE *stmt, int deflab);
  73. void gencase(SNODE *stmt);
  74. void genxswitch(SNODE *stmt);
  75. void genreturn(SNODE *stmt,int flag);
  76. void genstmt(SNODE *stmt);
  77. void scppinit(void);
  78. void genfunc(SNODE *stmt);
  79.                               /* Outas68.c */
  80. void outcodeini(void);
  81. void datalink(int flag);
  82. void nl(void);
  83. void outop(char *name);
  84. void putop(int op);
  85. void putconst(ENODE *offset);
  86. void putlen(int l);
  87. void putamode(AMODE *ap);
  88. void put_code(OCODE *cd);
  89. void put_fmask(int mask, int reverse);
  90. void put_mask(int mask, int reverse);
  91. void putreg(int r);
  92. void gen_strlab(SYM *sp);
  93. void put_label(OCODE *cd);
  94. void put_staticlabel(long label);
  95. void genfloat(float val);
  96. void gendouble(double val);
  97. void genlongdouble(long double val);
  98. int genstring(char *str, int uselong);
  99. void genbyte(long val);
  100. void genword(long val);
  101. void genlong(long val);
  102. void gensrref(SYM *sp,int val);
  103. void genref(SYM *sp,int offset);
  104. void genpcref(SYM *sp,int offset);
  105. void genstorage(int nbytes);
  106. void gen_labref(int n);
  107. int     stringlit(char *s, int uselong);
  108. void dumplits(void);
  109. void cseg(void);
  110. void dseg(void);
  111. void bssseg(void);
  112. void startupseg(void);
  113. void rundownseg(void);
  114. void cppseg(void);
  115. void gen_virtual(char *name);
  116. void gen_endvirtual(char *name);
  117. void genlongref(DATALINK *p);
  118. void asm_header(void);
  119. void globaldef(SYM *sp);
  120. void putexterns(void);
  121.                               /* Peep68.c */
  122. void peepini(void);
  123. AMODE    *copy_addr(AMODE *ap);
  124. void gen_code(int op,int len,AMODE *ap1,AMODE *ap2);
  125. void gen_lea(int size, AMODE *ap1, AMODE * ap2);
  126. void gen_codelab(SYM *lab);
  127. void gen_line(SNODE *stmt);
  128. void gen_codef(int op, int len, AMODE *ap1, AMODE *ap2);
  129. void gen_code3(int op, int len, AMODE *ap1, AMODE *ap2, AMODE *ap3);
  130. void add_peep(OCODE *new);
  131. void gen_label(int labno);
  132. void flush_peep(void);
  133. void peep_move(OCODE *ip);
  134. int peep_tst(OCODE *ip);
  135. int     equal_address(AMODE *ap1, AMODE *ap2);
  136. void peep_add(OCODE *ip);
  137. void peep_sub(OCODE *ip);
  138. void     peep_cmp(OCODE *ip);
  139. void peep_muldiv(OCODE *ip, int op);
  140. void peep_uctran(OCODE *ip);
  141. void peep_label(OCODE *ip);
  142. void opt3(void);
  143.                                /* Reg68.c */
  144. void regini(void);
  145. void gen_push(int reg, int rmode, int flag);
  146. void gen_pop(int reg, int rmode, int flag);
  147. void initstack(void);
  148. void mark(void);
  149. void release(void);
  150. AMODE    *temp_data(void);
  151. AMODE    *temp_addr(void);
  152. AMODE    *temp_float(void);
  153. void freedata(int dreg);
  154. void freeaddr(int areg);
  155. void freeop(AMODE *ap);
  156.                                /* An68.c */
  157. void reserveregs(int *datareg, int *addreg, int *floatreg);
  158. void allocate(int datareg, int addreg, int floatreg, SNODE *block );
  159.                               /* Conf68.c */
  160. int confcodegen(char s, int bool);
  161. void confsetup(void);
  162. int     alignment(int type, TYP *tp);                             /* STATIC */
  163. int getalign(int sc, TYP *tp);
  164. long getautoval(long val);
  165. int funcvaluesize(int size);
  166. /* Protogen Version 1.00 Saturday May 31, 1997  17:24:47 */
  167.                               /* Inasm68.c */
  168. void inasmini(void);
  169. SNODE *asm_statement (int shortfin);