Blame patches.suse/scsi-qla2xxx-Format-log-strings-only-if-needed.patch
|
Daniel Wagner |
d5351f |
From: Roman Bolshakov <r.bolshakov@yadro.com>
|
|
Daniel Wagner |
d5351f |
Date: Fri, 12 Nov 2021 17:54:46 +0300
|
|
Daniel Wagner |
d5351f |
Subject: scsi: qla2xxx: Format log strings only if needed
|
|
Daniel Wagner |
d5351f |
Patch-mainline: v5.16-rc5
|
|
Daniel Wagner |
d5351f |
Git-commit: 69002c8ce914ef0ae22a6ea14b43bb30b9a9a6a8
|
|
Daniel Wagner |
d5351f |
References: git-fixes
|
|
Daniel Wagner |
d5351f |
|
|
Daniel Wagner |
d5351f |
Commit 598a90f2002c ("scsi: qla2xxx: add ring buffer for tracing debug
|
|
Daniel Wagner |
d5351f |
logs") introduced unconditional log string formatting to ql_dbg() even if
|
|
Daniel Wagner |
d5351f |
ql_dbg_log event is disabled. It harms performance because some strings are
|
|
Daniel Wagner |
d5351f |
formatted in fastpath and/or interrupt context.
|
|
Daniel Wagner |
d5351f |
|
|
Daniel Wagner |
d5351f |
Link: https://lore.kernel.org/r/20211112145446.51210-1-r.bolshakov@yadro.com
|
|
Daniel Wagner |
d5351f |
Fixes: 598a90f2002c ("scsi: qla2xxx: add ring buffer for tracing debug logs")
|
|
Daniel Wagner |
d5351f |
Cc: Rajan Shanmugavelu <rajan.shanmugavelu@oracle.com>
|
|
Daniel Wagner |
d5351f |
Cc: stable@vger.kernel.org
|
|
Daniel Wagner |
d5351f |
Signed-off-by: Roman Bolshakov <r.bolshakov@yadro.com>
|
|
Daniel Wagner |
d5351f |
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
|
|
Daniel Wagner |
d5351f |
Acked-by: Daniel Wagner <dwagner@suse.de>
|
|
Daniel Wagner |
d5351f |
---
|
|
Daniel Wagner |
d5351f |
drivers/scsi/qla2xxx/qla_dbg.c | 3 +++
|
|
Daniel Wagner |
d5351f |
1 file changed, 3 insertions(+)
|
|
Daniel Wagner |
d5351f |
|
|
Daniel Wagner |
d5351f |
--- a/drivers/scsi/qla2xxx/qla_dbg.c
|
|
Daniel Wagner |
d5351f |
+++ b/drivers/scsi/qla2xxx/qla_dbg.c
|
|
Daniel Wagner |
d5351f |
@@ -2492,6 +2492,9 @@ ql_dbg(uint level, scsi_qla_host_t *vha,
|
|
Daniel Wagner |
d5351f |
struct va_format vaf;
|
|
Daniel Wagner |
d5351f |
char pbuf[64];
|
|
Daniel Wagner |
d5351f |
|
|
Daniel Wagner |
d5351f |
+ if (!ql_mask_match(level) && !trace_ql_dbg_log_enabled())
|
|
Daniel Wagner |
d5351f |
+ return;
|
|
Daniel Wagner |
d5351f |
+
|
|
Daniel Wagner |
d5351f |
va_start(va, fmt);
|
|
Daniel Wagner |
d5351f |
|
|
Daniel Wagner |
d5351f |
vaf.fmt = fmt;
|