debug.h 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429
  1. // SPDX-License-Identifier: GPL-2.0
  2. /**
  3. * debug.h - DesignWare USB3 DRD Controller Debug Header
  4. *
  5. * Copyright (C) 2010-2011 Texas Instruments Incorporated - http://www.ti.com
  6. *
  7. * Authors: Felipe Balbi <balbi@ti.com>,
  8. * Sebastian Andrzej Siewior <bigeasy@linutronix.de>
  9. */
  10. #ifndef __DWC3_DEBUG_H
  11. #define __DWC3_DEBUG_H
  12. #include "core.h"
  13. /**
  14. * dwc3_gadget_ep_cmd_string - returns endpoint command string
  15. * @cmd: command code
  16. */
  17. static inline const char *
  18. dwc3_gadget_ep_cmd_string(u8 cmd)
  19. {
  20. switch (cmd) {
  21. case DWC3_DEPCMD_DEPSTARTCFG:
  22. return "Start New Configuration";
  23. case DWC3_DEPCMD_ENDTRANSFER:
  24. return "End Transfer";
  25. case DWC3_DEPCMD_UPDATETRANSFER:
  26. return "Update Transfer";
  27. case DWC3_DEPCMD_STARTTRANSFER:
  28. return "Start Transfer";
  29. case DWC3_DEPCMD_CLEARSTALL:
  30. return "Clear Stall";
  31. case DWC3_DEPCMD_SETSTALL:
  32. return "Set Stall";
  33. case DWC3_DEPCMD_GETEPSTATE:
  34. return "Get Endpoint State";
  35. case DWC3_DEPCMD_SETTRANSFRESOURCE:
  36. return "Set Endpoint Transfer Resource";
  37. case DWC3_DEPCMD_SETEPCONFIG:
  38. return "Set Endpoint Configuration";
  39. default:
  40. return "UNKNOWN command";
  41. }
  42. }
  43. /**
  44. * dwc3_gadget_generic_cmd_string - returns generic command string
  45. * @cmd: command code
  46. */
  47. static inline const char *
  48. dwc3_gadget_generic_cmd_string(u8 cmd)
  49. {
  50. switch (cmd) {
  51. case DWC3_DGCMD_SET_LMP:
  52. return "Set LMP";
  53. case DWC3_DGCMD_SET_PERIODIC_PAR:
  54. return "Set Periodic Parameters";
  55. case DWC3_DGCMD_XMIT_FUNCTION:
  56. return "Transmit Function Wake Device Notification";
  57. case DWC3_DGCMD_SET_SCRATCHPAD_ADDR_LO:
  58. return "Set Scratchpad Buffer Array Address Lo";
  59. case DWC3_DGCMD_SET_SCRATCHPAD_ADDR_HI:
  60. return "Set Scratchpad Buffer Array Address Hi";
  61. case DWC3_DGCMD_SELECTED_FIFO_FLUSH:
  62. return "Selected FIFO Flush";
  63. case DWC3_DGCMD_ALL_FIFO_FLUSH:
  64. return "All FIFO Flush";
  65. case DWC3_DGCMD_SET_ENDPOINT_NRDY:
  66. return "Set Endpoint NRDY";
  67. case DWC3_DGCMD_RUN_SOC_BUS_LOOPBACK:
  68. return "Run SoC Bus Loopback Test";
  69. default:
  70. return "UNKNOWN";
  71. }
  72. }
  73. /**
  74. * dwc3_gadget_link_string - returns link name
  75. * @link_state: link state code
  76. */
  77. static inline const char *
  78. dwc3_gadget_link_string(enum dwc3_link_state link_state)
  79. {
  80. switch (link_state) {
  81. case DWC3_LINK_STATE_U0:
  82. return "U0";
  83. case DWC3_LINK_STATE_U1:
  84. return "U1";
  85. case DWC3_LINK_STATE_U2:
  86. return "U2";
  87. case DWC3_LINK_STATE_U3:
  88. return "U3";
  89. case DWC3_LINK_STATE_SS_DIS:
  90. return "SS.Disabled";
  91. case DWC3_LINK_STATE_RX_DET:
  92. return "RX.Detect";
  93. case DWC3_LINK_STATE_SS_INACT:
  94. return "SS.Inactive";
  95. case DWC3_LINK_STATE_POLL:
  96. return "Polling";
  97. case DWC3_LINK_STATE_RECOV:
  98. return "Recovery";
  99. case DWC3_LINK_STATE_HRESET:
  100. return "Hot Reset";
  101. case DWC3_LINK_STATE_CMPLY:
  102. return "Compliance";
  103. case DWC3_LINK_STATE_LPBK:
  104. return "Loopback";
  105. case DWC3_LINK_STATE_RESET:
  106. return "Reset";
  107. case DWC3_LINK_STATE_RESUME:
  108. return "Resume";
  109. default:
  110. return "UNKNOWN link state\n";
  111. }
  112. }
  113. /**
  114. * dwc3_gadget_hs_link_string - returns highspeed and below link name
  115. * @link_state: link state code
  116. */
  117. static inline const char *
  118. dwc3_gadget_hs_link_string(enum dwc3_link_state link_state)
  119. {
  120. switch (link_state) {
  121. case DWC3_LINK_STATE_U0:
  122. return "On";
  123. case DWC3_LINK_STATE_U2:
  124. return "Sleep";
  125. case DWC3_LINK_STATE_U3:
  126. return "Suspend";
  127. case DWC3_LINK_STATE_SS_DIS:
  128. return "Disconnected";
  129. case DWC3_LINK_STATE_RX_DET:
  130. return "Early Suspend";
  131. case DWC3_LINK_STATE_RECOV:
  132. return "Recovery";
  133. case DWC3_LINK_STATE_RESET:
  134. return "Reset";
  135. case DWC3_LINK_STATE_RESUME:
  136. return "Resume";
  137. default:
  138. return "UNKNOWN link state\n";
  139. }
  140. }
  141. /**
  142. * dwc3_trb_type_string - returns TRB type as a string
  143. * @type: the type of the TRB
  144. */
  145. static inline const char *dwc3_trb_type_string(unsigned int type)
  146. {
  147. switch (type) {
  148. case DWC3_TRBCTL_NORMAL:
  149. return "normal";
  150. case DWC3_TRBCTL_CONTROL_SETUP:
  151. return "setup";
  152. case DWC3_TRBCTL_CONTROL_STATUS2:
  153. return "status2";
  154. case DWC3_TRBCTL_CONTROL_STATUS3:
  155. return "status3";
  156. case DWC3_TRBCTL_CONTROL_DATA:
  157. return "data";
  158. case DWC3_TRBCTL_ISOCHRONOUS_FIRST:
  159. return "isoc-first";
  160. case DWC3_TRBCTL_ISOCHRONOUS:
  161. return "isoc";
  162. case DWC3_TRBCTL_LINK_TRB:
  163. return "link";
  164. default:
  165. return "UNKNOWN";
  166. }
  167. }
  168. static inline const char *dwc3_ep0_state_string(enum dwc3_ep0_state state)
  169. {
  170. switch (state) {
  171. case EP0_UNCONNECTED:
  172. return "Unconnected";
  173. case EP0_SETUP_PHASE:
  174. return "Setup Phase";
  175. case EP0_DATA_PHASE:
  176. return "Data Phase";
  177. case EP0_STATUS_PHASE:
  178. return "Status Phase";
  179. default:
  180. return "UNKNOWN";
  181. }
  182. }
  183. /**
  184. * dwc3_gadget_event_string - returns event name
  185. * @event: the event code
  186. */
  187. static inline const char *dwc3_gadget_event_string(char *str, size_t size,
  188. const struct dwc3_event_devt *event)
  189. {
  190. enum dwc3_link_state state = event->event_info & DWC3_LINK_STATE_MASK;
  191. switch (event->type) {
  192. case DWC3_DEVICE_EVENT_DISCONNECT:
  193. snprintf(str, size, "Disconnect: [%s]",
  194. dwc3_gadget_link_string(state));
  195. break;
  196. case DWC3_DEVICE_EVENT_RESET:
  197. snprintf(str, size, "Reset [%s]",
  198. dwc3_gadget_link_string(state));
  199. break;
  200. case DWC3_DEVICE_EVENT_CONNECT_DONE:
  201. snprintf(str, size, "Connection Done [%s]",
  202. dwc3_gadget_link_string(state));
  203. break;
  204. case DWC3_DEVICE_EVENT_LINK_STATUS_CHANGE:
  205. snprintf(str, size, "Link Change [%s]",
  206. dwc3_gadget_link_string(state));
  207. break;
  208. case DWC3_DEVICE_EVENT_WAKEUP:
  209. snprintf(str, size, "WakeUp [%s]",
  210. dwc3_gadget_link_string(state));
  211. break;
  212. case DWC3_DEVICE_EVENT_EOPF:
  213. snprintf(str, size, "End-Of-Frame [%s]",
  214. dwc3_gadget_link_string(state));
  215. break;
  216. case DWC3_DEVICE_EVENT_SOF:
  217. snprintf(str, size, "Start-Of-Frame [%s]",
  218. dwc3_gadget_link_string(state));
  219. break;
  220. case DWC3_DEVICE_EVENT_ERRATIC_ERROR:
  221. snprintf(str, size, "Erratic Error [%s]",
  222. dwc3_gadget_link_string(state));
  223. break;
  224. case DWC3_DEVICE_EVENT_CMD_CMPL:
  225. snprintf(str, size, "Command Complete [%s]",
  226. dwc3_gadget_link_string(state));
  227. break;
  228. case DWC3_DEVICE_EVENT_OVERFLOW:
  229. snprintf(str, size, "Overflow [%s]",
  230. dwc3_gadget_link_string(state));
  231. break;
  232. default:
  233. snprintf(str, size, "UNKNOWN");
  234. }
  235. return str;
  236. }
  237. /**
  238. * dwc3_ep_event_string - returns event name
  239. * @event: then event code
  240. */
  241. static inline const char *dwc3_ep_event_string(char *str, size_t size,
  242. const struct dwc3_event_depevt *event, u32 ep0state)
  243. {
  244. u8 epnum = event->endpoint_number;
  245. size_t len;
  246. int status;
  247. int ret;
  248. ret = snprintf(str, size, "ep%d%s: ", epnum >> 1,
  249. (epnum & 1) ? "in" : "out");
  250. if (ret < 0)
  251. return "UNKNOWN";
  252. status = event->status;
  253. switch (event->endpoint_event) {
  254. case DWC3_DEPEVT_XFERCOMPLETE:
  255. len = strlen(str);
  256. snprintf(str + len, size - len, "Transfer Complete (%c%c%c)",
  257. status & DEPEVT_STATUS_SHORT ? 'S' : 's',
  258. status & DEPEVT_STATUS_IOC ? 'I' : 'i',
  259. status & DEPEVT_STATUS_LST ? 'L' : 'l');
  260. len = strlen(str);
  261. if (epnum <= 1)
  262. snprintf(str + len, size - len, " [%s]",
  263. dwc3_ep0_state_string(ep0state));
  264. break;
  265. case DWC3_DEPEVT_XFERINPROGRESS:
  266. len = strlen(str);
  267. snprintf(str + len, size - len, "Transfer In Progress [%d] (%c%c%c)",
  268. event->parameters,
  269. status & DEPEVT_STATUS_SHORT ? 'S' : 's',
  270. status & DEPEVT_STATUS_IOC ? 'I' : 'i',
  271. status & DEPEVT_STATUS_LST ? 'M' : 'm');
  272. break;
  273. case DWC3_DEPEVT_XFERNOTREADY:
  274. len = strlen(str);
  275. snprintf(str + len, size - len, "Transfer Not Ready [%d]%s",
  276. event->parameters,
  277. status & DEPEVT_STATUS_TRANSFER_ACTIVE ?
  278. " (Active)" : " (Not Active)");
  279. len = strlen(str);
  280. /* Control Endpoints */
  281. if (epnum <= 1) {
  282. int phase = DEPEVT_STATUS_CONTROL_PHASE(event->status);
  283. switch (phase) {
  284. case DEPEVT_STATUS_CONTROL_DATA:
  285. snprintf(str + ret, size - ret,
  286. " [Data Phase]");
  287. break;
  288. case DEPEVT_STATUS_CONTROL_STATUS:
  289. snprintf(str + ret, size - ret,
  290. " [Status Phase]");
  291. }
  292. }
  293. break;
  294. case DWC3_DEPEVT_RXTXFIFOEVT:
  295. snprintf(str + ret, size - ret, "FIFO");
  296. break;
  297. case DWC3_DEPEVT_STREAMEVT:
  298. status = event->status;
  299. switch (status) {
  300. case DEPEVT_STREAMEVT_FOUND:
  301. snprintf(str + ret, size - ret, " Stream %d Found",
  302. event->parameters);
  303. break;
  304. case DEPEVT_STREAMEVT_NOTFOUND:
  305. default:
  306. snprintf(str + ret, size - ret, " Stream Not Found");
  307. break;
  308. }
  309. break;
  310. case DWC3_DEPEVT_EPCMDCMPLT:
  311. snprintf(str + ret, size - ret, "Endpoint Command Complete");
  312. break;
  313. default:
  314. snprintf(str, size, "UNKNOWN");
  315. }
  316. return str;
  317. }
  318. /**
  319. * dwc3_gadget_event_type_string - return event name
  320. * @event: the event code
  321. */
  322. static inline const char *dwc3_gadget_event_type_string(u8 event)
  323. {
  324. switch (event) {
  325. case DWC3_DEVICE_EVENT_DISCONNECT:
  326. return "Disconnect";
  327. case DWC3_DEVICE_EVENT_RESET:
  328. return "Reset";
  329. case DWC3_DEVICE_EVENT_CONNECT_DONE:
  330. return "Connect Done";
  331. case DWC3_DEVICE_EVENT_LINK_STATUS_CHANGE:
  332. return "Link Status Change";
  333. case DWC3_DEVICE_EVENT_WAKEUP:
  334. return "Wake-Up";
  335. case DWC3_DEVICE_EVENT_HIBER_REQ:
  336. return "Hibernation";
  337. case DWC3_DEVICE_EVENT_EOPF:
  338. return "End of Periodic Frame";
  339. case DWC3_DEVICE_EVENT_SOF:
  340. return "Start of Frame";
  341. case DWC3_DEVICE_EVENT_ERRATIC_ERROR:
  342. return "Erratic Error";
  343. case DWC3_DEVICE_EVENT_CMD_CMPL:
  344. return "Command Complete";
  345. case DWC3_DEVICE_EVENT_OVERFLOW:
  346. return "Overflow";
  347. default:
  348. return "UNKNOWN";
  349. }
  350. }
  351. static inline const char *dwc3_decode_event(char *str, size_t size, u32 event,
  352. u32 ep0state)
  353. {
  354. const union dwc3_event evt = (union dwc3_event) event;
  355. if (evt.type.is_devspec)
  356. return dwc3_gadget_event_string(str, size, &evt.devt);
  357. else
  358. return dwc3_ep_event_string(str, size, &evt.depevt, ep0state);
  359. }
  360. static inline const char *dwc3_ep_cmd_status_string(int status)
  361. {
  362. switch (status) {
  363. case -ETIMEDOUT:
  364. return "Timed Out";
  365. case 0:
  366. return "Successful";
  367. case DEPEVT_TRANSFER_NO_RESOURCE:
  368. return "No Resource";
  369. case DEPEVT_TRANSFER_BUS_EXPIRY:
  370. return "Bus Expiry";
  371. default:
  372. return "UNKNOWN";
  373. }
  374. }
  375. static inline const char *dwc3_gadget_generic_cmd_status_string(int status)
  376. {
  377. switch (status) {
  378. case -ETIMEDOUT:
  379. return "Timed Out";
  380. case 0:
  381. return "Successful";
  382. case 1:
  383. return "Error";
  384. default:
  385. return "UNKNOWN";
  386. }
  387. }
  388. #ifdef CONFIG_DEBUG_FS
  389. extern void dwc3_debugfs_init(struct dwc3 *);
  390. extern void dwc3_debugfs_exit(struct dwc3 *);
  391. #else
  392. static inline void dwc3_debugfs_init(struct dwc3 *d)
  393. { }
  394. static inline void dwc3_debugfs_exit(struct dwc3 *d)
  395. { }
  396. #endif
  397. #endif /* __DWC3_DEBUG_H */