bnx2fc_debug.h 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. #ifndef __BNX2FC_DEBUG__
  2. #define __BNX2FC_DEBUG__
  3. /* Log level bit mask */
  4. #define LOG_IO 0x01 /* scsi cmd error, cleanup */
  5. #define LOG_TGT 0x02 /* Session setup, cleanup, etc' */
  6. #define LOG_HBA 0x04 /* lport events, link, mtu, etc' */
  7. #define LOG_ELS 0x08 /* ELS logs */
  8. #define LOG_MISC 0x10 /* fcoe L2 frame related logs*/
  9. #define LOG_ALL 0xff /* LOG all messages */
  10. extern unsigned int bnx2fc_debug_level;
  11. #define BNX2FC_CHK_LOGGING(LEVEL, CMD) \
  12. do { \
  13. if (unlikely(bnx2fc_debug_level & LEVEL)) \
  14. do { \
  15. CMD; \
  16. } while (0); \
  17. } while (0)
  18. #define BNX2FC_ELS_DBG(fmt, arg...) \
  19. BNX2FC_CHK_LOGGING(LOG_ELS, \
  20. printk(KERN_INFO PFX fmt, ##arg))
  21. #define BNX2FC_MISC_DBG(fmt, arg...) \
  22. BNX2FC_CHK_LOGGING(LOG_MISC, \
  23. printk(KERN_INFO PFX fmt, ##arg))
  24. #define BNX2FC_IO_DBG(io_req, fmt, arg...) \
  25. do { \
  26. if (!io_req || !io_req->port || !io_req->port->lport || \
  27. !io_req->port->lport->host) \
  28. BNX2FC_CHK_LOGGING(LOG_IO, \
  29. printk(KERN_INFO PFX "NULL " fmt, ##arg)); \
  30. else \
  31. BNX2FC_CHK_LOGGING(LOG_IO, \
  32. shost_printk(KERN_INFO, \
  33. (io_req)->port->lport->host, \
  34. PFX "xid:0x%x " fmt, \
  35. (io_req)->xid, ##arg)); \
  36. } while (0)
  37. #define BNX2FC_TGT_DBG(tgt, fmt, arg...) \
  38. do { \
  39. if (!tgt || !tgt->port || !tgt->port->lport || \
  40. !tgt->port->lport->host || !tgt->rport) \
  41. BNX2FC_CHK_LOGGING(LOG_TGT, \
  42. printk(KERN_INFO PFX "NULL " fmt, ##arg)); \
  43. else \
  44. BNX2FC_CHK_LOGGING(LOG_TGT, \
  45. shost_printk(KERN_INFO, \
  46. (tgt)->port->lport->host, \
  47. PFX "port:%x " fmt, \
  48. (tgt)->rport->port_id, ##arg)); \
  49. } while (0)
  50. #define BNX2FC_HBA_DBG(lport, fmt, arg...) \
  51. do { \
  52. if (!lport || !lport->host) \
  53. BNX2FC_CHK_LOGGING(LOG_HBA, \
  54. printk(KERN_INFO PFX "NULL " fmt, ##arg)); \
  55. else \
  56. BNX2FC_CHK_LOGGING(LOG_HBA, \
  57. shost_printk(KERN_INFO, lport->host, \
  58. PFX fmt, ##arg)); \
  59. } while (0)
  60. #endif