adb.c 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212
  1. /*
  2. * Copyright (C) 1996 Paul Mackerras.
  3. */
  4. #include "nonstdio.h"
  5. #include "privinst.h"
  6. #define scanhex xmon_scanhex
  7. #define skipbl xmon_skipbl
  8. #define ADB_B (*(volatile unsigned char *)0xf3016000)
  9. #define ADB_SR (*(volatile unsigned char *)0xf3017400)
  10. #define ADB_ACR (*(volatile unsigned char *)0xf3017600)
  11. #define ADB_IFR (*(volatile unsigned char *)0xf3017a00)
  12. static inline void eieio(void) { asm volatile ("eieio" : :); }
  13. #define N_ADB_LOG 1000
  14. struct adb_log {
  15. unsigned char b;
  16. unsigned char ifr;
  17. unsigned char acr;
  18. unsigned int time;
  19. } adb_log[N_ADB_LOG];
  20. int n_adb_log;
  21. void
  22. init_adb_log(void)
  23. {
  24. adb_log[0].b = ADB_B;
  25. adb_log[0].ifr = ADB_IFR;
  26. adb_log[0].acr = ADB_ACR;
  27. adb_log[0].time = get_dec();
  28. n_adb_log = 0;
  29. }
  30. void
  31. dump_adb_log(void)
  32. {
  33. unsigned t, t0;
  34. struct adb_log *ap;
  35. int i;
  36. ap = adb_log;
  37. t0 = ap->time;
  38. for (i = 0; i <= n_adb_log; ++i, ++ap) {
  39. t = t0 - ap->time;
  40. printf("b=%x ifr=%x acr=%x at %d.%.7d\n", ap->b, ap->ifr, ap->acr,
  41. t / 1000000000, (t % 1000000000) / 100);
  42. }
  43. }
  44. void
  45. adb_chklog(void)
  46. {
  47. struct adb_log *ap = &adb_log[n_adb_log + 1];
  48. ap->b = ADB_B;
  49. ap->ifr = ADB_IFR;
  50. ap->acr = ADB_ACR;
  51. if (ap->b != ap[-1].b || (ap->ifr & 4) != (ap[-1].ifr & 4)
  52. || ap->acr != ap[-1].acr) {
  53. ap->time = get_dec();
  54. ++n_adb_log;
  55. }
  56. }
  57. int
  58. adb_bitwait(int bmask, int bval, int fmask, int fval)
  59. {
  60. int i;
  61. struct adb_log *ap;
  62. for (i = 10000; i > 0; --i) {
  63. adb_chklog();
  64. ap = &adb_log[n_adb_log];
  65. if ((ap->b & bmask) == bval && (ap->ifr & fmask) == fval)
  66. return 0;
  67. }
  68. return -1;
  69. }
  70. int
  71. adb_wait(void)
  72. {
  73. if (adb_bitwait(0, 0, 4, 4) < 0) {
  74. printf("adb: ready wait timeout\n");
  75. return -1;
  76. }
  77. return 0;
  78. }
  79. void
  80. adb_readin(void)
  81. {
  82. int i, j;
  83. unsigned char d[64];
  84. if (ADB_B & 8) {
  85. printf("ADB_B: %x\n", ADB_B);
  86. return;
  87. }
  88. i = 0;
  89. adb_wait();
  90. j = ADB_SR;
  91. eieio();
  92. ADB_B &= ~0x20;
  93. eieio();
  94. for (;;) {
  95. if (adb_wait() < 0)
  96. break;
  97. d[i++] = ADB_SR;
  98. eieio();
  99. if (ADB_B & 8)
  100. break;
  101. ADB_B ^= 0x10;
  102. eieio();
  103. }
  104. ADB_B |= 0x30;
  105. if (adb_wait() == 0)
  106. j = ADB_SR;
  107. for (j = 0; j < i; ++j)
  108. printf("%.2x ", d[j]);
  109. printf("\n");
  110. }
  111. int
  112. adb_write(unsigned char *d, int i)
  113. {
  114. int j;
  115. unsigned x;
  116. if ((ADB_B & 8) == 0) {
  117. printf("r: ");
  118. adb_readin();
  119. }
  120. for (;;) {
  121. ADB_ACR = 0x1c;
  122. eieio();
  123. ADB_SR = d[0];
  124. eieio();
  125. ADB_B &= ~0x20;
  126. eieio();
  127. if (ADB_B & 8)
  128. break;
  129. ADB_ACR = 0xc;
  130. eieio();
  131. ADB_B |= 0x20;
  132. eieio();
  133. adb_readin();
  134. }
  135. adb_wait();
  136. for (j = 1; j < i; ++j) {
  137. ADB_SR = d[j];
  138. eieio();
  139. ADB_B ^= 0x10;
  140. eieio();
  141. if (adb_wait() < 0)
  142. break;
  143. }
  144. ADB_ACR = 0xc;
  145. eieio();
  146. x = ADB_SR;
  147. eieio();
  148. ADB_B |= 0x30;
  149. return j;
  150. }
  151. void
  152. adbcmds(void)
  153. {
  154. char cmd;
  155. unsigned rtcu, rtcl, dec, pdec, x;
  156. int i, j;
  157. unsigned char d[64];
  158. cmd = skipbl();
  159. switch (cmd) {
  160. case 't':
  161. for (;;) {
  162. rtcl = get_rtcl();
  163. rtcu = get_rtcu();
  164. dec = get_dec();
  165. printf("rtc u=%u l=%u dec=%x (%d = %d.%.7d)\n",
  166. rtcu, rtcl, dec, pdec - dec, (pdec - dec) / 1000000000,
  167. ((pdec - dec) % 1000000000) / 100);
  168. pdec = dec;
  169. if (cmd == 'x')
  170. break;
  171. while (xmon_read(stdin, &cmd, 1) != 1)
  172. ;
  173. }
  174. break;
  175. case 'r':
  176. init_adb_log();
  177. while (adb_bitwait(8, 0, 0, 0) == 0)
  178. adb_readin();
  179. break;
  180. case 'w':
  181. i = 0;
  182. while (scanhex(&x))
  183. d[i++] = x;
  184. init_adb_log();
  185. j = adb_write(d, i);
  186. printf("sent %d bytes\n", j);
  187. while (adb_bitwait(8, 0, 0, 0) == 0)
  188. adb_readin();
  189. break;
  190. case 'l':
  191. dump_adb_log();
  192. break;
  193. }
  194. }