diff options
author | Saurav Kashyap <saurav.kashyap@qlogic.com> | 2011-07-14 15:00:12 -0400 |
---|---|---|
committer | James Bottomley <JBottomley@Parallels.com> | 2011-07-27 06:12:25 -0400 |
commit | 3ce8866ceae87258cf66d1f7fd72abc918753cec (patch) | |
tree | 655dbace6c920da216275b9145f20a8515c808f9 /drivers/scsi/qla2xxx/qla_os.c | |
parent | 573e5913536a1393362265cfea9e708aa10fdf16 (diff) |
[SCSI] qla2xxx: Basic infrastructure for dynamic logging.
This patch adds the dynamic logging framework to the qla2xxx driver.
The user will be able to change the logging levels on the fly i.e.
without load/unload of the driver. This also enables logging to be
enabled for a particular section of the driver such as initialization,
device discovery etc.
Signed-off-by: Saurav Kashyap <saurav.kashyap@qlogic.com>
Signed-off-by: Giridhar Malavali <giridhar.malavali@qlogic.com>
Signed-off-by: James Bottomley <JBottomley@Parallels.com>
Diffstat (limited to 'drivers/scsi/qla2xxx/qla_os.c')
-rw-r--r-- | drivers/scsi/qla2xxx/qla_os.c | 17 |
1 files changed, 15 insertions, 2 deletions
diff --git a/drivers/scsi/qla2xxx/qla_os.c b/drivers/scsi/qla2xxx/qla_os.c index f461925a9dfc..8aa05c87b653 100644 --- a/drivers/scsi/qla2xxx/qla_os.c +++ b/drivers/scsi/qla2xxx/qla_os.c | |||
@@ -35,6 +35,10 @@ static struct kmem_cache *srb_cachep; | |||
35 | * CT6 CTX allocation cache | 35 | * CT6 CTX allocation cache |
36 | */ | 36 | */ |
37 | static struct kmem_cache *ctx_cachep; | 37 | static struct kmem_cache *ctx_cachep; |
38 | /* | ||
39 | * error level for logging | ||
40 | */ | ||
41 | int ql_errlev = ql_log_all; | ||
38 | 42 | ||
39 | int ql2xlogintimeout = 20; | 43 | int ql2xlogintimeout = 20; |
40 | module_param(ql2xlogintimeout, int, S_IRUGO); | 44 | module_param(ql2xlogintimeout, int, S_IRUGO); |
@@ -69,8 +73,17 @@ MODULE_PARM_DESC(ql2xallocfwdump, | |||
69 | int ql2xextended_error_logging; | 73 | int ql2xextended_error_logging; |
70 | module_param(ql2xextended_error_logging, int, S_IRUGO|S_IWUSR); | 74 | module_param(ql2xextended_error_logging, int, S_IRUGO|S_IWUSR); |
71 | MODULE_PARM_DESC(ql2xextended_error_logging, | 75 | MODULE_PARM_DESC(ql2xextended_error_logging, |
72 | "Option to enable extended error logging, " | 76 | "Option to enable extended error logging,\n" |
73 | "Default is 0 - no logging. 1 - log errors."); | 77 | "\t\tDefault is 0 - no logging. 0x40000000 - Module Init & Probe.\n" |
78 | "\t\t0x20000000 - Mailbox Cmnds. 0x10000000 - Device Discovery.\n" | ||
79 | "\t\t0x08000000 - IO tracing. 0x04000000 - DPC Thread.\n" | ||
80 | "\t\t0x02000000 - Async events. 0x01000000 - Timer routines.\n" | ||
81 | "\t\t0x00800000 - User space. 0x00400000 - Task Management.\n" | ||
82 | "\t\t0x00200000 - AER/EEH. 0x00100000 - Multi Q.\n" | ||
83 | "\t\t0x00080000 - P3P Specific. 0x00040000 - Virtual Port.\n" | ||
84 | "\t\t0x00020000 - Buffer Dump. 0x00010000 - Misc.\n" | ||
85 | "\t\t0x7fffffff - For enabling all logs, can be too many logs.\n" | ||
86 | "\t\tDo LOGICAL OR of the value to enable more than one level"); | ||
74 | 87 | ||
75 | int ql2xshiftctondsd = 6; | 88 | int ql2xshiftctondsd = 6; |
76 | module_param(ql2xshiftctondsd, int, S_IRUGO); | 89 | module_param(ql2xshiftctondsd, int, S_IRUGO); |