2011-02-04 20:10:34 +00:00
|
|
|
#ifndef __BNX2FC_DEBUG__
|
|
|
|
#define __BNX2FC_DEBUG__
|
|
|
|
|
|
|
|
/* Log level bit mask */
|
|
|
|
#define LOG_IO 0x01 /* scsi cmd error, cleanup */
|
|
|
|
#define LOG_TGT 0x02 /* Session setup, cleanup, etc' */
|
|
|
|
#define LOG_HBA 0x04 /* lport events, link, mtu, etc' */
|
|
|
|
#define LOG_ELS 0x08 /* ELS logs */
|
|
|
|
#define LOG_MISC 0x10 /* fcoe L2 frame related logs*/
|
|
|
|
#define LOG_ALL 0xff /* LOG all messages */
|
|
|
|
|
|
|
|
extern unsigned int bnx2fc_debug_level;
|
|
|
|
|
|
|
|
#define BNX2FC_CHK_LOGGING(LEVEL, CMD) \
|
|
|
|
do { \
|
|
|
|
if (unlikely(bnx2fc_debug_level & LEVEL)) \
|
|
|
|
do { \
|
|
|
|
CMD; \
|
|
|
|
} while (0); \
|
|
|
|
} while (0)
|
|
|
|
|
|
|
|
#define BNX2FC_ELS_DBG(fmt, arg...) \
|
|
|
|
BNX2FC_CHK_LOGGING(LOG_ELS, \
|
2011-06-28 06:30:53 +00:00
|
|
|
printk(KERN_INFO PFX fmt, ##arg))
|
2011-02-04 20:10:34 +00:00
|
|
|
|
|
|
|
#define BNX2FC_MISC_DBG(fmt, arg...) \
|
|
|
|
BNX2FC_CHK_LOGGING(LOG_MISC, \
|
2011-06-28 06:30:53 +00:00
|
|
|
printk(KERN_INFO PFX fmt, ##arg))
|
2011-02-04 20:10:34 +00:00
|
|
|
|
|
|
|
#define BNX2FC_IO_DBG(io_req, fmt, arg...) \
|
|
|
|
do { \
|
|
|
|
if (!io_req || !io_req->port || !io_req->port->lport || \
|
|
|
|
!io_req->port->lport->host) \
|
|
|
|
BNX2FC_CHK_LOGGING(LOG_IO, \
|
2011-06-28 06:30:53 +00:00
|
|
|
printk(KERN_INFO PFX "NULL " fmt, ##arg)); \
|
2011-02-04 20:10:34 +00:00
|
|
|
else \
|
|
|
|
BNX2FC_CHK_LOGGING(LOG_IO, \
|
2011-06-28 06:30:53 +00:00
|
|
|
shost_printk(KERN_INFO, \
|
2011-02-04 20:10:34 +00:00
|
|
|
(io_req)->port->lport->host, \
|
|
|
|
PFX "xid:0x%x " fmt, \
|
|
|
|
(io_req)->xid, ##arg)); \
|
|
|
|
} while (0)
|
|
|
|
|
|
|
|
#define BNX2FC_TGT_DBG(tgt, fmt, arg...) \
|
|
|
|
do { \
|
|
|
|
if (!tgt || !tgt->port || !tgt->port->lport || \
|
|
|
|
!tgt->port->lport->host || !tgt->rport) \
|
|
|
|
BNX2FC_CHK_LOGGING(LOG_TGT, \
|
2011-06-28 06:30:53 +00:00
|
|
|
printk(KERN_INFO PFX "NULL " fmt, ##arg)); \
|
2011-02-04 20:10:34 +00:00
|
|
|
else \
|
|
|
|
BNX2FC_CHK_LOGGING(LOG_TGT, \
|
2011-06-28 06:30:53 +00:00
|
|
|
shost_printk(KERN_INFO, \
|
2011-02-04 20:10:34 +00:00
|
|
|
(tgt)->port->lport->host, \
|
|
|
|
PFX "port:%x " fmt, \
|
|
|
|
(tgt)->rport->port_id, ##arg)); \
|
|
|
|
} while (0)
|
|
|
|
|
|
|
|
|
|
|
|
#define BNX2FC_HBA_DBG(lport, fmt, arg...) \
|
|
|
|
do { \
|
|
|
|
if (!lport || !lport->host) \
|
|
|
|
BNX2FC_CHK_LOGGING(LOG_HBA, \
|
2011-06-28 06:30:53 +00:00
|
|
|
printk(KERN_INFO PFX "NULL " fmt, ##arg)); \
|
2011-02-04 20:10:34 +00:00
|
|
|
else \
|
|
|
|
BNX2FC_CHK_LOGGING(LOG_HBA, \
|
2011-06-28 06:30:53 +00:00
|
|
|
shost_printk(KERN_INFO, lport->host, \
|
2011-02-04 20:10:34 +00:00
|
|
|
PFX fmt, ##arg)); \
|
|
|
|
} while (0)
|
|
|
|
|
|
|
|
#endif
|