public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* [PATCH 0/3] scsi: qla2xxx: Fix incorrect sign of error code
@ 2025-09-05  7:54 Qianfeng Rong
  2025-09-05  7:54 ` [PATCH 1/3] scsi: qla2xxx: edif: " Qianfeng Rong
                   ` (3 more replies)
  0 siblings, 4 replies; 5+ messages in thread
From: Qianfeng Rong @ 2025-09-05  7:54 UTC (permalink / raw)
  To: Nilesh Javali,
	maintainer:QLOGIC QLA2XXX FC-SCSI DRIVER,blamed_fixes:1/1=100%,
	James E.J. Bottomley, Martin K. Petersen, Quinn Tran,
	himanshu.madhani, Manish Rangankar,
	open list:QLOGIC QLA2XXX FC-SCSI DRIVER, open list
  Cc: Qianfeng Rong

qla2x00_start_sp() returns only negative error codes or QLA_SUCCESS.
Therefore, comparing its return value with positive error codes 
(e.g., if (_rval == EAGAIN)) causes logical errors.

Qianfeng Rong (3):
  scsi: qla2xxx: edif: Fix incorrect sign of error code
  scsi: qla2xxx: Fix incorrect sign of error code in
    START_SP_W_RETRIES()
  scsi: qla2xxx: Fix incorrect sign of error code in
    qla_nvme_xmt_ls_rsp()

 drivers/scsi/qla2xxx/qla_edif.c | 4 ++--
 drivers/scsi/qla2xxx/qla_init.c | 4 ++--
 drivers/scsi/qla2xxx/qla_nvme.c | 2 +-
 3 files changed, 5 insertions(+), 5 deletions(-)

-- 
2.34.1


^ permalink raw reply	[flat|nested] 5+ messages in thread

* [PATCH 1/3] scsi: qla2xxx: edif: Fix incorrect sign of error code
  2025-09-05  7:54 [PATCH 0/3] scsi: qla2xxx: Fix incorrect sign of error code Qianfeng Rong
@ 2025-09-05  7:54 ` Qianfeng Rong
  2025-09-05  7:54 ` [PATCH 2/3] scsi: qla2xxx: Fix incorrect sign of error code in START_SP_W_RETRIES() Qianfeng Rong
                   ` (2 subsequent siblings)
  3 siblings, 0 replies; 5+ messages in thread
From: Qianfeng Rong @ 2025-09-05  7:54 UTC (permalink / raw)
  To: Nilesh Javali, maintainer:QLOGIC QLA2XXX FC-SCSI DRIVER,
	James E.J. Bottomley, Martin K. Petersen, Quinn Tran,
	open list:QLOGIC QLA2XXX FC-SCSI DRIVER, open list
  Cc: Qianfeng Rong

Change the error code EAGAIN to -EAGAIN in qla24xx_sadb_update() and
qla_edif_process_els() to align with qla2x00_start_sp() returning
negative error codes or QLA_SUCCESS, preventing logical errors.

Fixes: 0b3f3143d473 ("scsi: qla2xxx: edif: Add retry for ELS passthrough")
Signed-off-by: Qianfeng Rong <rongqianfeng@vivo.com>
---
 drivers/scsi/qla2xxx/qla_edif.c | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)

diff --git a/drivers/scsi/qla2xxx/qla_edif.c b/drivers/scsi/qla2xxx/qla_edif.c
index 91bbd3b75bff..ccd4485087a1 100644
--- a/drivers/scsi/qla2xxx/qla_edif.c
+++ b/drivers/scsi/qla2xxx/qla_edif.c
@@ -1798,7 +1798,7 @@ qla24xx_sadb_update(struct bsg_job *bsg_job)
 	switch (rval) {
 	case QLA_SUCCESS:
 		break;
-	case EAGAIN:
+	case -EAGAIN:
 		msleep(EDIF_MSLEEP_INTERVAL);
 		cnt++;
 		if (cnt < EDIF_RETRY_COUNT)
@@ -3649,7 +3649,7 @@ int qla_edif_process_els(scsi_qla_host_t *vha, struct bsg_job *bsg_job)
 		       p->e.extra_rx_xchg_address, p->e.extra_control_flags,
 		       sp->handle, sp->remap.req.len, bsg_job);
 		break;
-	case EAGAIN:
+	case -EAGAIN:
 		msleep(EDIF_MSLEEP_INTERVAL);
 		cnt++;
 		if (cnt < EDIF_RETRY_COUNT)
-- 
2.34.1


^ permalink raw reply related	[flat|nested] 5+ messages in thread

* [PATCH 2/3] scsi: qla2xxx: Fix incorrect sign of error code in START_SP_W_RETRIES()
  2025-09-05  7:54 [PATCH 0/3] scsi: qla2xxx: Fix incorrect sign of error code Qianfeng Rong
  2025-09-05  7:54 ` [PATCH 1/3] scsi: qla2xxx: edif: " Qianfeng Rong
@ 2025-09-05  7:54 ` Qianfeng Rong
  2025-09-05  7:54 ` [PATCH 3/3] scsi: qla2xxx: Fix incorrect sign of error code in qla_nvme_xmt_ls_rsp() Qianfeng Rong
  2025-09-17  2:06 ` [PATCH 0/3] scsi: qla2xxx: Fix incorrect sign of error code Martin K. Petersen
  3 siblings, 0 replies; 5+ messages in thread
From: Qianfeng Rong @ 2025-09-05  7:54 UTC (permalink / raw)
  To: Nilesh Javali,
	maintainer:QLOGIC QLA2XXX FC-SCSI DRIVER,blamed_fixes:1/1=100%,
	James E.J. Bottomley, Martin K. Petersen, himanshu.madhani,
	Quinn Tran, open list:QLOGIC QLA2XXX FC-SCSI DRIVER, open list
  Cc: Qianfeng Rong

Change the error code EAGAIN to -EAGAIN in START_SP_W_RETRIES() to align
with qla2x00_start_sp() returning negative error codes or QLA_SUCCESS,
preventing logical errors.  Additionally, the '_rval' variable should
store negative error codes to conform to Linux kernel error code
conventions.

Fixes: 9803fb5d2759 ("scsi: qla2xxx: Fix task management cmd failure")
Signed-off-by: Qianfeng Rong <rongqianfeng@vivo.com>
---
 drivers/scsi/qla2xxx/qla_init.c | 4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)

diff --git a/drivers/scsi/qla2xxx/qla_init.c b/drivers/scsi/qla2xxx/qla_init.c
index be211ff22acb..6a2e1c7fd125 100644
--- a/drivers/scsi/qla2xxx/qla_init.c
+++ b/drivers/scsi/qla2xxx/qla_init.c
@@ -2059,11 +2059,11 @@ static void qla_marker_sp_done(srb_t *sp, int res)
 	int cnt = 5; \
 	do { \
 		if (_chip_gen != sp->vha->hw->chip_reset || _login_gen != sp->fcport->login_gen) {\
-			_rval = EINVAL; \
+			_rval = -EINVAL; \
 			break; \
 		} \
 		_rval = qla2x00_start_sp(_sp); \
-		if (_rval == EAGAIN) \
+		if (_rval == -EAGAIN) \
 			msleep(1); \
 		else \
 			break; \
-- 
2.34.1


^ permalink raw reply related	[flat|nested] 5+ messages in thread

* [PATCH 3/3] scsi: qla2xxx: Fix incorrect sign of error code in qla_nvme_xmt_ls_rsp()
  2025-09-05  7:54 [PATCH 0/3] scsi: qla2xxx: Fix incorrect sign of error code Qianfeng Rong
  2025-09-05  7:54 ` [PATCH 1/3] scsi: qla2xxx: edif: " Qianfeng Rong
  2025-09-05  7:54 ` [PATCH 2/3] scsi: qla2xxx: Fix incorrect sign of error code in START_SP_W_RETRIES() Qianfeng Rong
@ 2025-09-05  7:54 ` Qianfeng Rong
  2025-09-17  2:06 ` [PATCH 0/3] scsi: qla2xxx: Fix incorrect sign of error code Martin K. Petersen
  3 siblings, 0 replies; 5+ messages in thread
From: Qianfeng Rong @ 2025-09-05  7:54 UTC (permalink / raw)
  To: Nilesh Javali, maintainer:QLOGIC QLA2XXX FC-SCSI DRIVER,
	James E.J. Bottomley, Martin K. Petersen, Manish Rangankar,
	Himanshu Madhani, open list:QLOGIC QLA2XXX FC-SCSI DRIVER,
	open list
  Cc: Qianfeng Rong

Change the error code EAGAIN to -EAGAIN in qla_nvme_xmt_ls_rsp() to align
with qla2x00_start_sp() returning negative error codes or QLA_SUCCESS,
preventing logical errors.

Fixes: 875386b98857 ("scsi: qla2xxx: Add Unsolicited LS Request and Response Support for NVMe")
Signed-off-by: Qianfeng Rong <rongqianfeng@vivo.com>
---
 drivers/scsi/qla2xxx/qla_nvme.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/drivers/scsi/qla2xxx/qla_nvme.c b/drivers/scsi/qla2xxx/qla_nvme.c
index 92488890bc04..065f9bcca26f 100644
--- a/drivers/scsi/qla2xxx/qla_nvme.c
+++ b/drivers/scsi/qla2xxx/qla_nvme.c
@@ -419,7 +419,7 @@ static int qla_nvme_xmt_ls_rsp(struct nvme_fc_local_port *lport,
 	switch (rval) {
 	case QLA_SUCCESS:
 		break;
-	case EAGAIN:
+	case -EAGAIN:
 		msleep(PURLS_MSLEEP_INTERVAL);
 		cnt++;
 		if (cnt < PURLS_RETRY_COUNT)
-- 
2.34.1


^ permalink raw reply related	[flat|nested] 5+ messages in thread

* Re: [PATCH 0/3] scsi: qla2xxx: Fix incorrect sign of error code
  2025-09-05  7:54 [PATCH 0/3] scsi: qla2xxx: Fix incorrect sign of error code Qianfeng Rong
                   ` (2 preceding siblings ...)
  2025-09-05  7:54 ` [PATCH 3/3] scsi: qla2xxx: Fix incorrect sign of error code in qla_nvme_xmt_ls_rsp() Qianfeng Rong
@ 2025-09-17  2:06 ` Martin K. Petersen
  3 siblings, 0 replies; 5+ messages in thread
From: Martin K. Petersen @ 2025-09-17  2:06 UTC (permalink / raw)
  To: Qianfeng Rong
  Cc: Nilesh Javali,
	maintainer:QLOGIC QLA2XXX FC-SCSI DRIVER,blamed_fixes:1/1=100%,
	James E.J. Bottomley, Martin K. Petersen, Quinn Tran,
	himanshu.madhani, Manish Rangankar,
	open list:QLOGIC QLA2XXX FC-SCSI DRIVER, open list


Qianfeng,

> qla2x00_start_sp() returns only negative error codes or QLA_SUCCESS.
> Therefore, comparing its return value with positive error codes 
> (e.g., if (_rval == EAGAIN)) causes logical errors.

Applied to 6.18/scsi-staging, thanks!

-- 
Martin K. Petersen

^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2025-09-17  2:09 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2025-09-05  7:54 [PATCH 0/3] scsi: qla2xxx: Fix incorrect sign of error code Qianfeng Rong
2025-09-05  7:54 ` [PATCH 1/3] scsi: qla2xxx: edif: " Qianfeng Rong
2025-09-05  7:54 ` [PATCH 2/3] scsi: qla2xxx: Fix incorrect sign of error code in START_SP_W_RETRIES() Qianfeng Rong
2025-09-05  7:54 ` [PATCH 3/3] scsi: qla2xxx: Fix incorrect sign of error code in qla_nvme_xmt_ls_rsp() Qianfeng Rong
2025-09-17  2:06 ` [PATCH 0/3] scsi: qla2xxx: Fix incorrect sign of error code Martin K. Petersen

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox