scsipi_debug.h revision 1.10 1 1.10 christos /* $NetBSD: scsipi_debug.h,v 1.10 1997/10/24 15:44:42 christos Exp $ */
2 1.3 cgd
3 1.1 mycroft /*
4 1.1 mycroft * Written by Julian Elischer (julian (at) tfs.com)
5 1.1 mycroft */
6 1.8 bouyer #ifndef _SCSI_PI_DEBUG_H
7 1.8 bouyer #define _SCSI_PI_DEBUG_H 1
8 1.8 bouyer
9 1.1 mycroft /*
10 1.1 mycroft * These are the new debug bits. (Sat Oct 2 12:46:46 WST 1993)
11 1.1 mycroft * the following DEBUG bits are defined to exist in the flags word of
12 1.1 mycroft * the scsi_link structure.
13 1.1 mycroft */
14 1.8 bouyer #define SDEV_DB1 0x10 /* scsi commands, errors, data */
15 1.1 mycroft #define SDEV_DB2 0x20 /* routine flow tracking */
16 1.8 bouyer #define SDEV_DB3 0x40 /* internal to routine flows */
17 1.1 mycroft #define SDEV_DB4 0x80 /* level 4 debugging for this dev */
18 1.1 mycroft
19 1.8 bouyer /* type, target and LUN we want to debug */
20 1.9 enami #define DEBUGTYPE BUS_ATAPI
21 1.8 bouyer #define DEBUGTARGET -1 /* -1 = disable. This is the drive
22 1.8 bouyer number for ATAPI */
23 1.5 mycroft #define DEBUGLUN 0
24 1.8 bouyer #define DEBUGLEVEL (SDEV_DB1|SDEV_DB2|SDEV_DB3)
25 1.1 mycroft
26 1.1 mycroft /*
27 1.1 mycroft * This is the usual debug macro for use with the above bits
28 1.1 mycroft */
29 1.9 enami #ifdef SCSIDEBUG
30 1.8 bouyer #define SC_DEBUG(sc_link,Level,Printstuff) \
31 1.8 bouyer do { \
32 1.8 bouyer if ((sc_link)->flags & (Level)) { \
33 1.8 bouyer sc_link->sc_print_addr(sc_link); \
34 1.8 bouyer printf Printstuff; \
35 1.8 bouyer } \
36 1.10 christos } while (0)
37 1.8 bouyer
38 1.8 bouyer #define SC_DEBUGN(sc_link,Level,Printstuff) \
39 1.8 bouyer do { \
40 1.8 bouyer if ((sc_link)->flags & (Level)) { \
41 1.8 bouyer printf Printstuff; \
42 1.8 bouyer } \
43 1.10 christos } while (0)
44 1.1 mycroft #else
45 1.5 mycroft #define SC_DEBUG(A,B,C)
46 1.5 mycroft #define SC_DEBUGN(A,B,C)
47 1.1 mycroft #endif
48 1.1 mycroft
49 1.8 bouyer #endif /* _SCSI_PI_DEBUG_H */
50