usb-uhci-debug.h
上传用户:jlfgdled
上传日期:2013-04-10
资源大小:33168k
文件大小:5k
源码类别:

Linux/Unix编程

开发平台:

Unix_Linux

  1. #ifdef DEBUG
  2. static void __attribute__((__unused__)) uhci_show_qh (puhci_desc_t qh)
  3. {
  4. if (qh->type != QH_TYPE) {
  5. dbg("qh has not QH_TYPE");
  6. return;
  7. }
  8. dbg("QH @ %p/%08llX:", qh, (unsigned long long)qh->dma_addr);
  9. if (qh->hw.qh.head & UHCI_PTR_TERM)
  10. dbg("    Head Terminate");
  11. else 
  12. dbg("    Head: %s @ %08X",
  13.     (qh->hw.qh.head & UHCI_PTR_QH?"QH":"TD"),
  14.     qh->hw.qh.head & ~UHCI_PTR_BITS);
  15. if (qh->hw.qh.element & UHCI_PTR_TERM)
  16. dbg("    Element Terminate");
  17. else 
  18. dbg("    Element: %s @ %08X",
  19.     (qh->hw.qh.element & UHCI_PTR_QH?"QH":"TD"),
  20.     qh->hw.qh.element & ~UHCI_PTR_BITS);
  21. }
  22. #endif
  23. #if 0
  24. static void uhci_show_td (puhci_desc_t td)
  25. {
  26. char *spid;
  27. switch (td->hw.td.info & 0xff) {
  28. case USB_PID_SETUP:
  29. spid = "SETUP";
  30. break;
  31. case USB_PID_OUT:
  32. spid = " OUT ";
  33. break;
  34. case USB_PID_IN:
  35. spid = " IN  ";
  36. break;
  37. default:
  38. spid = "  ?  ";
  39. break;
  40. }
  41. warn("  TD @ %p/%08X, MaxLen=%02x DT%d EP=%x Dev=%x PID=(%s) buf=%08x",
  42.      td, td->dma_addr,
  43.      td->hw.td.info >> 21,
  44.      ((td->hw.td.info >> 19) & 1),
  45.      (td->hw.td.info >> 15) & 15,
  46.      (td->hw.td.info >> 8) & 127,
  47.      spid,
  48.      td->hw.td.buffer);
  49. warn("    Len=%02x e%d %s%s%s%s%s%s%s%s%s%s",
  50.      td->hw.td.status & 0x7ff,
  51.      ((td->hw.td.status >> 27) & 3),
  52.      (td->hw.td.status & TD_CTRL_SPD) ? "SPD " : "",
  53.      (td->hw.td.status & TD_CTRL_LS) ? "LS " : "",
  54.      (td->hw.td.status & TD_CTRL_IOC) ? "IOC " : "",
  55.      (td->hw.td.status & TD_CTRL_ACTIVE) ? "Active " : "",
  56.      (td->hw.td.status & TD_CTRL_STALLED) ? "Stalled " : "",
  57.      (td->hw.td.status & TD_CTRL_DBUFERR) ? "DataBufErr " : "",
  58.      (td->hw.td.status & TD_CTRL_BABBLE) ? "Babble " : "",
  59.      (td->hw.td.status & TD_CTRL_NAK) ? "NAK " : "",
  60.      (td->hw.td.status & TD_CTRL_CRCTIMEO) ? "CRC/Timeo " : "",
  61.      (td->hw.td.status & TD_CTRL_BITSTUFF) ? "BitStuff " : ""
  62. );
  63. if (td->hw.td.link & UHCI_PTR_TERM)
  64. warn("   TD Link Terminate");
  65. else 
  66. warn("    Link points to %s @ %08x, %s",
  67.      (td->hw.td.link & UHCI_PTR_QH?"QH":"TD"),
  68.      td->hw.td.link & ~UHCI_PTR_BITS,
  69.      (td->hw.td.link & UHCI_PTR_DEPTH ? "Depth first" : "Breadth first"));
  70. }
  71. #endif
  72. #ifdef DEBUG
  73. static void __attribute__((__unused__)) uhci_show_td_queue (puhci_desc_t td)
  74. {
  75. //dbg("uhci_show_td_queue %p (%08lX):", td, td->dma_addr);
  76. #if 1
  77. return;
  78. #else
  79. while (1) {
  80. uhci_show_td (td);
  81. if (td->hw.td.link & UHCI_PTR_TERM)
  82. break;
  83. if (td != bus_to_virt (td->hw.td.link & ~UHCI_PTR_BITS))
  84. td = bus_to_virt (td->hw.td.link & ~UHCI_PTR_BITS);
  85. else {
  86. dbg("td points to itself!");
  87. break;
  88. }
  89. }
  90. #endif
  91. }
  92. static void __attribute__((__unused__)) uhci_show_queue (puhci_desc_t qh)
  93. {
  94. #if 0
  95. uhci_desc_t *start_qh=qh;
  96. #endif
  97. dbg("uhci_show_queue %p:", qh);
  98. #if 1
  99. return;
  100. #else
  101. while (1) {
  102. uhci_show_qh (qh);
  103. if (!(qh->hw.qh.element & UHCI_PTR_TERM))
  104. uhci_show_td_queue (bus_to_virt (qh->hw.qh.element & ~UHCI_PTR_BITS));
  105. if (qh->hw.qh.head & UHCI_PTR_TERM)
  106. break;
  107. if (qh != bus_to_virt (qh->hw.qh.head & ~UHCI_PTR_BITS))
  108. qh = bus_to_virt (qh->hw.qh.head & ~UHCI_PTR_BITS);
  109. else {
  110. dbg("qh points to itself!");
  111. break;
  112. }
  113. if (qh==start_qh) { // avoid loop
  114. dbg("Loop detect");
  115. break;
  116. }
  117. }
  118. #endif
  119. }
  120. static void __attribute__((__unused__)) uhci_show_sc (int port, unsigned short status)
  121. {
  122. dbg("  stat%d     =     %04x   %s%s%s%s%s%s%s%s",
  123.      port,
  124.      status,
  125.      (status & USBPORTSC_SUSP) ? "PortSuspend " : "",
  126.      (status & USBPORTSC_PR) ? "PortReset " : "",
  127.      (status & USBPORTSC_LSDA) ? "LowSpeed " : "",
  128.      (status & USBPORTSC_RD) ? "ResumeDetect " : "",
  129.      (status & USBPORTSC_PEC) ? "EnableChange " : "",
  130.      (status & USBPORTSC_PE) ? "PortEnabled " : "",
  131.      (status & USBPORTSC_CSC) ? "ConnectChange " : "",
  132.      (status & USBPORTSC_CCS) ? "PortConnected " : "");
  133. }
  134. void uhci_show_status (puhci_t s)
  135. {
  136. unsigned int io_addr = s->io_addr;
  137. unsigned short usbcmd, usbstat, usbint, usbfrnum;
  138. unsigned int flbaseadd;
  139. unsigned char sof;
  140. unsigned short portsc1, portsc2;
  141. usbcmd = inw (io_addr + 0);
  142. usbstat = inw (io_addr + 2);
  143. usbint = inw (io_addr + 4);
  144. usbfrnum = inw (io_addr + 6);
  145. flbaseadd = inl (io_addr + 8);
  146. sof = inb (io_addr + 12);
  147. portsc1 = inw (io_addr + 16);
  148. portsc2 = inw (io_addr + 18);
  149. dbg("  usbcmd    =     %04x   %s%s%s%s%s%s%s%s",
  150.      usbcmd,
  151.      (usbcmd & USBCMD_MAXP) ? "Maxp64 " : "Maxp32 ",
  152.      (usbcmd & USBCMD_CF) ? "CF " : "",
  153.      (usbcmd & USBCMD_SWDBG) ? "SWDBG " : "",
  154.      (usbcmd & USBCMD_FGR) ? "FGR " : "",
  155.      (usbcmd & USBCMD_EGSM) ? "EGSM " : "",
  156.      (usbcmd & USBCMD_GRESET) ? "GRESET " : "",
  157.      (usbcmd & USBCMD_HCRESET) ? "HCRESET " : "",
  158.      (usbcmd & USBCMD_RS) ? "RS " : "");
  159. dbg("  usbstat   =     %04x   %s%s%s%s%s%s",
  160.      usbstat,
  161.      (usbstat & USBSTS_HCH) ? "HCHalted " : "",
  162.      (usbstat & USBSTS_HCPE) ? "HostControllerProcessError " : "",
  163.      (usbstat & USBSTS_HSE) ? "HostSystemError " : "",
  164.      (usbstat & USBSTS_RD) ? "ResumeDetect " : "",
  165.      (usbstat & USBSTS_ERROR) ? "USBError " : "",
  166.      (usbstat & USBSTS_USBINT) ? "USBINT " : "");
  167. dbg("  usbint    =     %04x", usbint);
  168. dbg("  usbfrnum  =   (%d)%03x", (usbfrnum >> 10) & 1,
  169.      0xfff & (4 * (unsigned int) usbfrnum));
  170. dbg("  flbaseadd = %08x", flbaseadd);
  171. dbg("  sof       =       %02x", sof);
  172. uhci_show_sc (1, portsc1);
  173. uhci_show_sc (2, portsc2);
  174. }
  175. #endif