list.c 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236
  1. #define EXTERN
  2. #include "gc.h"
  3. void
  4. listinit(void)
  5. {
  6. fmtinstall('A', Aconv);
  7. fmtinstall('P', Pconv);
  8. fmtinstall('Z', Zconv);
  9. fmtinstall('X', Xconv);
  10. fmtinstall('D', Dconv);
  11. fmtinstall('R', Rconv);
  12. fmtinstall('B', Bconv);
  13. }
  14. int
  15. Bconv(Fmt *fp)
  16. {
  17. char str[STRINGSZ], ss[STRINGSZ], *s;
  18. Bits bits;
  19. int i;
  20. str[0] = 0;
  21. bits = va_arg(fp->args, Bits);
  22. while(bany(&bits)) {
  23. i = bnum(bits);
  24. if(str[0])
  25. strcat(str, " ");
  26. if(var[i].sym == S) {
  27. sprint(ss, "$%ld", var[i].offset);
  28. s = ss;
  29. } else
  30. s = var[i].sym->name;
  31. if(strlen(str) + strlen(s) + 1 >= STRINGSZ)
  32. break;
  33. strcat(str, s);
  34. bits.b[i/32] &= ~(1L << (i%32));
  35. }
  36. return fmtstrcpy(fp, str);
  37. }
  38. int
  39. Pconv(Fmt *fp)
  40. {
  41. char str[STRINGSZ];
  42. Prog *p;
  43. p = va_arg(fp->args, Prog*);
  44. if(p->as == ADATA)
  45. sprint(str, "(%ld) %A %D/%d,%D",
  46. p->lineno, p->as, &p->from, p->from.scale, &p->to);
  47. else
  48. if(p->type != D_NONE) {
  49. if(p->type >= D_R0 && p->type < D_R0+32)
  50. sprint(str, "(%ld) %A %D,%R,%D",
  51. p->lineno, p->as, &p->from, (int)p->type, &p->to);
  52. else
  53. if(p->type == D_CONST)
  54. sprint(str, "(%ld) %A %D,$%d,%D",
  55. p->lineno, p->as, &p->from, p->offset, &p->to);
  56. else
  57. sprint(str, "(%ld) %A %D,gok(%d),%D",
  58. p->lineno, p->as, &p->from, p->type, &p->to);
  59. } else
  60. sprint(str, "(%ld) %A %D,%D",
  61. p->lineno, p->as, &p->from, &p->to);
  62. return fmtstrcpy(fp, str);
  63. }
  64. int
  65. Aconv(Fmt *fp)
  66. {
  67. int i;
  68. i = va_arg(fp->args, int);
  69. return fmtstrcpy(fp, anames[i]);
  70. }
  71. int
  72. Xconv(Fmt *fp)
  73. {
  74. char str[20];
  75. Index x;
  76. str[0] = 0;
  77. x = va_arg(fp->args, Index);
  78. if(x.i0 != D_NONE)
  79. sprint(str, "(%R*%d)", x.i0, x.i1);
  80. return fmtstrcpy(fp, str);
  81. }
  82. int
  83. Dconv(Fmt *fp)
  84. {
  85. char str[40], s[20];
  86. Adr *a;
  87. int i;
  88. a = va_arg(fp->args, Adr*);
  89. i = a->type;
  90. if(i >= D_INDIR) {
  91. if(a->offset)
  92. sprint(str, "%ld(%R)", a->offset, i-D_INDIR);
  93. else
  94. sprint(str, "(%R)", i-D_INDIR);
  95. goto brk;
  96. }
  97. switch(i) {
  98. default:
  99. if(a->offset)
  100. sprint(str, "$%ld,%R", a->offset, i);
  101. else
  102. sprint(str, "%R", i);
  103. break;
  104. case D_NONE:
  105. str[0] = 0;
  106. break;
  107. case D_BRANCH:
  108. sprint(str, "%ld(PC)", a->offset-pc);
  109. break;
  110. case D_EXTERN:
  111. sprint(str, "%s+%ld(SB)", a->sym->name, a->offset);
  112. break;
  113. case D_STATIC:
  114. sprint(str, "%s<>+%ld(SB)", a->sym->name,
  115. a->offset);
  116. break;
  117. case D_AUTO:
  118. sprint(str, "%s+%ld(SP)", a->sym->name, a->offset);
  119. break;
  120. case D_PARAM:
  121. if(a->sym)
  122. sprint(str, "%s+%ld(FP)", a->sym->name, a->offset);
  123. else
  124. sprint(str, "%ld(FP)", a->offset);
  125. break;
  126. case D_CONST:
  127. sprint(str, "$%ld", a->offset);
  128. break;
  129. case D_FCONST:
  130. sprint(str, "$(%.17e)", a->dval);
  131. break;
  132. case D_SCONST:
  133. sprint(str, "$\"%Z\"", a->sval);
  134. break;
  135. case D_ADDR:
  136. a->type = a->index;
  137. a->index = D_NONE;
  138. sprint(str, "$%D", a);
  139. a->index = a->type;
  140. a->type = D_ADDR;
  141. goto conv;
  142. }
  143. brk:
  144. if(a->index != D_NONE) {
  145. sprint(s, "%X", (Index){a->index, a->scale});
  146. strcat(str, s);
  147. }
  148. conv:
  149. return fmtstrcpy(fp, str);
  150. }
  151. int
  152. Rconv(Fmt *fp)
  153. {
  154. char str[20];
  155. int r;
  156. r = va_arg(fp->args, int);
  157. if(r >= D_R0 && r <= D_R0+31)
  158. sprint(str, "R%d", r-D_R0);
  159. else
  160. if(r == D_NONE)
  161. sprint(str, "");
  162. else
  163. sprint(str, "gok(%d)", r);
  164. return fmtstrcpy(fp, str);
  165. }
  166. int
  167. Zconv(Fmt *fp)
  168. {
  169. int i, c;
  170. char str[30], *p, *a;
  171. a = va_arg(fp->args, char*);
  172. p = str;
  173. for(i=0; i<sizeof(double); i++) {
  174. c = a[i] & 0xff;
  175. if(c >= 'a' && c <= 'z' ||
  176. c >= 'A' && c <= 'Z' ||
  177. c >= '0' && c <= '9') {
  178. *p++ = c;
  179. continue;
  180. }
  181. *p++ = '\\';
  182. switch(c) {
  183. default:
  184. if(c < 040 || c >= 0177)
  185. break; /* not portable */
  186. p[-1] = c;
  187. continue;
  188. case 0:
  189. *p++ = 'z';
  190. continue;
  191. case '\\':
  192. case '"':
  193. *p++ = c;
  194. continue;
  195. case '\n':
  196. *p++ = 'n';
  197. continue;
  198. case '\t':
  199. *p++ = 't';
  200. continue;
  201. }
  202. *p++ = (c>>6) + '0';
  203. *p++ = ((c>>3) & 7) + '0';
  204. *p++ = (c & 7) + '0';
  205. }
  206. *p = 0;
  207. return fmtstrcpy(fp, str);
  208. }