diff options
author | Andrew Vasquez <andrew.vasquez@qlogic.com> | 2006-06-23 19:11:10 -0400 |
---|---|---|
committer | James Bottomley <jejb@mulgrave.il.steeleye.com> | 2006-06-26 17:24:36 -0400 |
commit | 0181944fe647cae18d545ac1167df3d15d393701 (patch) | |
tree | 6889c9782bf1ce84345a3d128e82797a732f4cf9 | |
parent | 744f11fdb1118c9306303529263e5ed09b463a0f (diff) |
[SCSI] qla2xxx: Add support for extended error logging.
Similar in form to QLogic's standard offering -- via
the 'extended_error_logging' module parameter.
Signed-off-by: Andrew Vasquez <andrew.vasquez@qlogic.com>
Signed-off-by: James Bottomley <James.Bottomley@SteelEye.com>
-rw-r--r-- | drivers/scsi/qla2xxx/qla_dbg.h | 50 | ||||
-rw-r--r-- | drivers/scsi/qla2xxx/qla_gbl.h | 1 | ||||
-rw-r--r-- | drivers/scsi/qla2xxx/qla_init.c | 2 | ||||
-rw-r--r-- | drivers/scsi/qla2xxx/qla_os.c | 12 |
4 files changed, 19 insertions, 46 deletions
diff --git a/drivers/scsi/qla2xxx/qla_dbg.h b/drivers/scsi/qla2xxx/qla_dbg.h index 2cea0097fbab..533425338e05 100644 --- a/drivers/scsi/qla2xxx/qla_dbg.h +++ b/drivers/scsi/qla2xxx/qla_dbg.h | |||
@@ -38,11 +38,7 @@ | |||
38 | * Macros use for debugging the driver. | 38 | * Macros use for debugging the driver. |
39 | */ | 39 | */ |
40 | 40 | ||
41 | #if DEBUG_QLA2100 | 41 | #define DEBUG(x) do { if (extended_error_logging) { x; } } while (0) |
42 | #define DEBUG(x) do {x;} while (0) | ||
43 | #else | ||
44 | #define DEBUG(x) do {} while (0) | ||
45 | #endif | ||
46 | 42 | ||
47 | #if defined(QL_DEBUG_LEVEL_1) | 43 | #if defined(QL_DEBUG_LEVEL_1) |
48 | #define DEBUG1(x) do {x;} while (0) | 44 | #define DEBUG1(x) do {x;} while (0) |
@@ -50,27 +46,18 @@ | |||
50 | #define DEBUG1(x) do {} while (0) | 46 | #define DEBUG1(x) do {} while (0) |
51 | #endif | 47 | #endif |
52 | 48 | ||
53 | #if defined(QL_DEBUG_LEVEL_2) | 49 | #define DEBUG2(x) do { if (extended_error_logging) { x; } } while (0) |
54 | #define DEBUG2(x) do {x;} while (0) | 50 | #define DEBUG2_3(x) do { if (extended_error_logging) { x; } } while (0) |
55 | #define DEBUG2_3(x) do {x;} while (0) | 51 | #define DEBUG2_3_11(x) do { if (extended_error_logging) { x; } } while (0) |
56 | #define DEBUG2_3_11(x) do {x;} while (0) | 52 | #define DEBUG2_9_10(x) do { if (extended_error_logging) { x; } } while (0) |
57 | #define DEBUG2_9_10(x) do {x;} while (0) | 53 | #define DEBUG2_11(x) do { if (extended_error_logging) { x; } } while (0) |
58 | #define DEBUG2_11(x) do {x;} while (0) | 54 | #define DEBUG2_13(x) do { if (extended_error_logging) { x; } } while (0) |
59 | #define DEBUG2_13(x) do {x;} while (0) | ||
60 | #else | ||
61 | #define DEBUG2(x) do {} while (0) | ||
62 | #endif | ||
63 | 55 | ||
64 | #if defined(QL_DEBUG_LEVEL_3) | 56 | #if defined(QL_DEBUG_LEVEL_3) |
65 | #define DEBUG3(x) do {x;} while (0) | 57 | #define DEBUG3(x) do {x;} while (0) |
66 | #define DEBUG2_3(x) do {x;} while (0) | ||
67 | #define DEBUG2_3_11(x) do {x;} while (0) | ||
68 | #define DEBUG3_11(x) do {x;} while (0) | 58 | #define DEBUG3_11(x) do {x;} while (0) |
69 | #else | 59 | #else |
70 | #define DEBUG3(x) do {} while (0) | 60 | #define DEBUG3(x) do {} while (0) |
71 | #if !defined(QL_DEBUG_LEVEL_2) | ||
72 | #define DEBUG2_3(x) do {} while (0) | ||
73 | #endif | ||
74 | #endif | 61 | #endif |
75 | 62 | ||
76 | #if defined(QL_DEBUG_LEVEL_4) | 63 | #if defined(QL_DEBUG_LEVEL_4) |
@@ -94,20 +81,15 @@ | |||
94 | #if defined(QL_DEBUG_LEVEL_9) | 81 | #if defined(QL_DEBUG_LEVEL_9) |
95 | #define DEBUG9(x) do {x;} while (0) | 82 | #define DEBUG9(x) do {x;} while (0) |
96 | #define DEBUG9_10(x) do {x;} while (0) | 83 | #define DEBUG9_10(x) do {x;} while (0) |
97 | #define DEBUG2_9_10(x) do {x;} while (0) | ||
98 | #else | 84 | #else |
99 | #define DEBUG9(x) do {} while (0) | 85 | #define DEBUG9(x) do {} while (0) |
100 | #endif | 86 | #endif |
101 | 87 | ||
102 | #if defined(QL_DEBUG_LEVEL_10) | 88 | #if defined(QL_DEBUG_LEVEL_10) |
103 | #define DEBUG10(x) do {x;} while (0) | 89 | #define DEBUG10(x) do {x;} while (0) |
104 | #define DEBUG2_9_10(x) do {x;} while (0) | ||
105 | #define DEBUG9_10(x) do {x;} while (0) | 90 | #define DEBUG9_10(x) do {x;} while (0) |
106 | #else | 91 | #else |
107 | #define DEBUG10(x) do {} while (0) | 92 | #define DEBUG10(x) do {} while (0) |
108 | #if !defined(DEBUG2_9_10) | ||
109 | #define DEBUG2_9_10(x) do {} while (0) | ||
110 | #endif | ||
111 | #if !defined(DEBUG9_10) | 93 | #if !defined(DEBUG9_10) |
112 | #define DEBUG9_10(x) do {} while (0) | 94 | #define DEBUG9_10(x) do {} while (0) |
113 | #endif | 95 | #endif |
@@ -115,23 +97,11 @@ | |||
115 | 97 | ||
116 | #if defined(QL_DEBUG_LEVEL_11) | 98 | #if defined(QL_DEBUG_LEVEL_11) |
117 | #define DEBUG11(x) do{x;} while(0) | 99 | #define DEBUG11(x) do{x;} while(0) |
118 | #if !defined(DEBUG2_11) | ||
119 | #define DEBUG2_11(x) do{x;} while(0) | ||
120 | #endif | ||
121 | #if !defined(DEBUG2_3_11) | ||
122 | #define DEBUG2_3_11(x) do{x;} while(0) | ||
123 | #endif | ||
124 | #if !defined(DEBUG3_11) | 100 | #if !defined(DEBUG3_11) |
125 | #define DEBUG3_11(x) do{x;} while(0) | 101 | #define DEBUG3_11(x) do{x;} while(0) |
126 | #endif | 102 | #endif |
127 | #else | 103 | #else |
128 | #define DEBUG11(x) do{} while(0) | 104 | #define DEBUG11(x) do{} while(0) |
129 | #if !defined(QL_DEBUG_LEVEL_2) | ||
130 | #define DEBUG2_11(x) do{} while(0) | ||
131 | #if !defined(QL_DEBUG_LEVEL_3) | ||
132 | #define DEBUG2_3_11(x) do{} while(0) | ||
133 | #endif | ||
134 | #endif | ||
135 | #if !defined(QL_DEBUG_LEVEL_3) | 105 | #if !defined(QL_DEBUG_LEVEL_3) |
136 | #define DEBUG3_11(x) do{} while(0) | 106 | #define DEBUG3_11(x) do{} while(0) |
137 | #endif | 107 | #endif |
@@ -145,14 +115,8 @@ | |||
145 | 115 | ||
146 | #if defined(QL_DEBUG_LEVEL_13) | 116 | #if defined(QL_DEBUG_LEVEL_13) |
147 | #define DEBUG13(x) do {x;} while (0) | 117 | #define DEBUG13(x) do {x;} while (0) |
148 | #if !defined(DEBUG2_13) | ||
149 | #define DEBUG2_13(x) do {x;} while(0) | ||
150 | #endif | ||
151 | #else | 118 | #else |
152 | #define DEBUG13(x) do {} while (0) | 119 | #define DEBUG13(x) do {} while (0) |
153 | #if !defined(QL_DEBUG_LEVEL_2) | ||
154 | #define DEBUG2_13(x) do {} while(0) | ||
155 | #endif | ||
156 | #endif | 120 | #endif |
157 | 121 | ||
158 | #if defined(QL_DEBUG_LEVEL_14) | 122 | #if defined(QL_DEBUG_LEVEL_14) |
diff --git a/drivers/scsi/qla2xxx/qla_gbl.h b/drivers/scsi/qla2xxx/qla_gbl.h index 9ff3298405cd..750aef11c2ef 100644 --- a/drivers/scsi/qla2xxx/qla_gbl.h +++ b/drivers/scsi/qla2xxx/qla_gbl.h | |||
@@ -64,6 +64,7 @@ extern int ql2xplogiabsentdevice; | |||
64 | extern int ql2xloginretrycount; | 64 | extern int ql2xloginretrycount; |
65 | extern int ql2xfdmienable; | 65 | extern int ql2xfdmienable; |
66 | extern int ql2xallocfwdump; | 66 | extern int ql2xallocfwdump; |
67 | extern int extended_error_logging; | ||
67 | 68 | ||
68 | extern void qla2x00_sp_compl(scsi_qla_host_t *, srb_t *); | 69 | extern void qla2x00_sp_compl(scsi_qla_host_t *, srb_t *); |
69 | 70 | ||
diff --git a/drivers/scsi/qla2xxx/qla_init.c b/drivers/scsi/qla2xxx/qla_init.c index 101cf12b9a47..761dd1f7e3f1 100644 --- a/drivers/scsi/qla2xxx/qla_init.c +++ b/drivers/scsi/qla2xxx/qla_init.c | |||
@@ -1642,6 +1642,8 @@ qla2x00_nvram_config(scsi_qla_host_t *ha) | |||
1642 | /* | 1642 | /* |
1643 | * Set host adapter parameters. | 1643 | * Set host adapter parameters. |
1644 | */ | 1644 | */ |
1645 | if (nv->host_p[0] & BIT_7) | ||
1646 | extended_error_logging = 1; | ||
1645 | ha->flags.disable_risc_code_load = ((nv->host_p[0] & BIT_4) ? 1 : 0); | 1647 | ha->flags.disable_risc_code_load = ((nv->host_p[0] & BIT_4) ? 1 : 0); |
1646 | /* Always load RISC code on non ISP2[12]00 chips. */ | 1648 | /* Always load RISC code on non ISP2[12]00 chips. */ |
1647 | if (!IS_QLA2100(ha) && !IS_QLA2200(ha)) | 1649 | if (!IS_QLA2100(ha) && !IS_QLA2200(ha)) |
diff --git a/drivers/scsi/qla2xxx/qla_os.c b/drivers/scsi/qla2xxx/qla_os.c index fedf2f17808d..a15b60908133 100644 --- a/drivers/scsi/qla2xxx/qla_os.c +++ b/drivers/scsi/qla2xxx/qla_os.c | |||
@@ -61,6 +61,12 @@ MODULE_PARM_DESC(ql2xallocfwdump, | |||
61 | "during HBA initialization. Memory allocation requirements " | 61 | "during HBA initialization. Memory allocation requirements " |
62 | "vary by ISP type. Default is 1 - allocate memory."); | 62 | "vary by ISP type. Default is 1 - allocate memory."); |
63 | 63 | ||
64 | int extended_error_logging; | ||
65 | module_param(extended_error_logging, int, S_IRUGO|S_IRUSR); | ||
66 | MODULE_PARM_DESC(extended_error_logging, | ||
67 | "Option to enable extended error logging, " | ||
68 | "Default is 0 - no logging. 1 - log errors."); | ||
69 | |||
64 | static void qla2x00_free_device(scsi_qla_host_t *); | 70 | static void qla2x00_free_device(scsi_qla_host_t *); |
65 | 71 | ||
66 | static void qla2x00_config_dma_addressing(scsi_qla_host_t *ha); | 72 | static void qla2x00_config_dma_addressing(scsi_qla_host_t *ha); |
@@ -2691,9 +2697,9 @@ qla2x00_module_init(void) | |||
2691 | 2697 | ||
2692 | /* Derive version string. */ | 2698 | /* Derive version string. */ |
2693 | strcpy(qla2x00_version_str, QLA2XXX_VERSION); | 2699 | strcpy(qla2x00_version_str, QLA2XXX_VERSION); |
2694 | #if DEBUG_QLA2100 | 2700 | if (extended_error_logging) |
2695 | strcat(qla2x00_version_str, "-debug"); | 2701 | strcat(qla2x00_version_str, "-debug"); |
2696 | #endif | 2702 | |
2697 | qla2xxx_transport_template = | 2703 | qla2xxx_transport_template = |
2698 | fc_attach_transport(&qla2xxx_transport_functions); | 2704 | fc_attach_transport(&qla2xxx_transport_functions); |
2699 | if (!qla2xxx_transport_template) | 2705 | if (!qla2xxx_transport_template) |