lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <304247e3-8c09-4fd4-90a9-ec23fcba2420@redhat.com>
Date: Fri, 13 Jun 2025 17:05:14 -0400
From: John Meneghini <jmeneghi@...hat.com>
To: Karan Tilak Kumar <kartilak@...co.com>, sebaddel@...co.com
Cc: arulponn@...co.com, djhawar@...co.com, gcboffa@...co.com,
 mkai2@...co.com, satishkh@...co.com, aeasi@...co.com, jejb@...ux.ibm.com,
 martin.petersen@...cle.com, linux-scsi@...r.kernel.org,
 linux-kernel@...r.kernel.org, revers@...hat.com, dan.carpenter@...aro.org
Subject: Re: [PATCH v4 3/5] scsi: fnic: Add and improve logs in FDMI and FDMI
 ABTS paths

Reviewed-by: John Meneghini <jmeneghi@...hat.com>

On 6/12/25 6:18 PM, Karan Tilak Kumar wrote:
> Add logs in FDMI and FDMI ABTS paths.
> Modify log text in these paths.
> 
> Reviewed-by: Sesidhar Baddela <sebaddel@...co.com>
> Reviewed-by: Arulprabhu Ponnusamy <arulponn@...co.com>
> Reviewed-by: Gian Carlo Boffa <gcboffa@...co.com>
> Reviewed-by: Arun Easi <aeasi@...co.com>
> Signed-off-by: Karan Tilak Kumar <kartilak@...co.com>
> ---
>   drivers/scsi/fnic/fdls_disc.c | 65 +++++++++++++++++++++++++++++++----
>   1 file changed, 58 insertions(+), 7 deletions(-)
> 
> diff --git a/drivers/scsi/fnic/fdls_disc.c b/drivers/scsi/fnic/fdls_disc.c
> index 0ee1b74967b9..9e9939d41fa8 100644
> --- a/drivers/scsi/fnic/fdls_disc.c
> +++ b/drivers/scsi/fnic/fdls_disc.c
> @@ -791,6 +791,7 @@ static uint8_t *fdls_alloc_init_fdmi_abts_frame(struct fnic_iport_s *iport,
>   static void fdls_send_fdmi_abts(struct fnic_iport_s *iport)
>   {
>   	uint8_t *frame;
> +	struct fnic *fnic = iport->fnic;
>   	unsigned long fdmi_tov;
>   	uint16_t frame_size = FNIC_ETH_FCOE_HDRS_OFFSET +
>   			sizeof(struct fc_frame_header);
> @@ -801,6 +802,9 @@ static void fdls_send_fdmi_abts(struct fnic_iport_s *iport)
>   		if (frame == NULL)
>   			return;
>   
> +		FNIC_FCS_DBG(KERN_INFO, fnic->host, fnic->fnic_num,
> +			 "0x%x: FDLS send FDMI PLOGI abts. iport->fabric.state: %d oxid: 0x%x",
> +			 iport->fcid, iport->fabric.state, iport->active_oxid_fdmi_plogi);
>   		fnic_send_fcoe_frame(iport, frame, frame_size);
>   	} else {
>   		if (iport->fabric.fdmi_pending & FDLS_FDMI_REG_HBA_PENDING) {
> @@ -809,6 +813,9 @@ static void fdls_send_fdmi_abts(struct fnic_iport_s *iport)
>   			if (frame == NULL)
>   				return;
>   
> +			FNIC_FCS_DBG(KERN_INFO, fnic->host, fnic->fnic_num,
> +				 "0x%x: FDLS send FDMI RHBA abts. iport->fabric.state: %d oxid: 0x%x",
> +				 iport->fcid, iport->fabric.state, iport->active_oxid_fdmi_rhba);
>   			fnic_send_fcoe_frame(iport, frame, frame_size);
>   		}
>   		if (iport->fabric.fdmi_pending & FDLS_FDMI_RPA_PENDING) {
> @@ -821,6 +828,9 @@ static void fdls_send_fdmi_abts(struct fnic_iport_s *iport)
>   					return;
>   			}
>   
> +			FNIC_FCS_DBG(KERN_INFO, fnic->host, fnic->fnic_num,
> +				 "0x%x: FDLS send FDMI RPA abts. iport->fabric.state: %d oxid: 0x%x",
> +				 iport->fcid, iport->fabric.state, iport->active_oxid_fdmi_rpa);
>   			fnic_send_fcoe_frame(iport, frame, frame_size);
>   		}
>   	}
> @@ -829,6 +839,10 @@ static void fdls_send_fdmi_abts(struct fnic_iport_s *iport)
>   	fdmi_tov = jiffies + msecs_to_jiffies(2 * iport->e_d_tov);
>   	mod_timer(&iport->fabric.fdmi_timer, round_jiffies(fdmi_tov));
>   	iport->fabric.fdmi_pending |= FDLS_FDMI_ABORT_PENDING;
> +
> +	FNIC_FCS_DBG(KERN_INFO, fnic->host, fnic->fnic_num,
> +		 "0x%x: iport->fabric.fdmi_pending: 0x%x",
> +		 iport->fcid, iport->fabric.fdmi_pending);
>   }
>   
>   static void fdls_send_fabric_flogi(struct fnic_iport_s *iport)
> @@ -2292,7 +2306,7 @@ void fdls_fdmi_timer_callback(struct timer_list *t)
>   	spin_lock_irqsave(&fnic->fnic_lock, flags);
>   
>   	FNIC_FCS_DBG(KERN_INFO, fnic->host, fnic->fnic_num,
> -		"fdmi timer callback : 0x%x\n", iport->fabric.fdmi_pending);
> +		"iport->fabric.fdmi_pending: 0x%x\n", iport->fabric.fdmi_pending);
>   
>   	if (!iport->fabric.fdmi_pending) {
>   		/* timer expired after fdmi responses received. */
> @@ -2300,7 +2314,7 @@ void fdls_fdmi_timer_callback(struct timer_list *t)
>   		return;
>   	}
>   	FNIC_FCS_DBG(KERN_INFO, fnic->host, fnic->fnic_num,
> -		"fdmi timer callback : 0x%x\n", iport->fabric.fdmi_pending);
> +		"iport->fabric.fdmi_pending: 0x%x\n", iport->fabric.fdmi_pending);
>   
>   	/* if not abort pending, send an abort */
>   	if (!(iport->fabric.fdmi_pending & FDLS_FDMI_ABORT_PENDING)) {
> @@ -2309,26 +2323,37 @@ void fdls_fdmi_timer_callback(struct timer_list *t)
>   		return;
>   	}
>   	FNIC_FCS_DBG(KERN_INFO, fnic->host, fnic->fnic_num,
> -		"fdmi timer callback : 0x%x\n", iport->fabric.fdmi_pending);
> +		"iport->fabric.fdmi_pending: 0x%x\n", iport->fabric.fdmi_pending);
>   
>   	/* ABTS pending for an active fdmi request that is pending.
>   	 * That means FDMI ABTS timed out
>   	 * Schedule to free the OXID after 2*r_a_tov and proceed
>   	 */
>   	if (iport->fabric.fdmi_pending & FDLS_FDMI_PLOGI_PENDING) {
> +		FNIC_FCS_DBG(KERN_INFO, fnic->host, fnic->fnic_num,
> +			"FDMI PLOGI ABTS timed out. Schedule oxid free: 0x%x\n",
> +			iport->active_oxid_fdmi_plogi);
>   		fdls_schedule_oxid_free(iport, &iport->active_oxid_fdmi_plogi);
>   	} else {
> -		if (iport->fabric.fdmi_pending & FDLS_FDMI_REG_HBA_PENDING)
> +		if (iport->fabric.fdmi_pending & FDLS_FDMI_REG_HBA_PENDING) {
> +			FNIC_FCS_DBG(KERN_INFO, fnic->host, fnic->fnic_num,
> +						"FDMI RHBA ABTS timed out. Schedule oxid free: 0x%x\n",
> +						iport->active_oxid_fdmi_rhba);
>   			fdls_schedule_oxid_free(iport, &iport->active_oxid_fdmi_rhba);
> -		if (iport->fabric.fdmi_pending & FDLS_FDMI_RPA_PENDING)
> +		}
> +		if (iport->fabric.fdmi_pending & FDLS_FDMI_RPA_PENDING) {
> +			FNIC_FCS_DBG(KERN_INFO, fnic->host, fnic->fnic_num,
> +						"FDMI RPA ABTS timed out. Schedule oxid free: 0x%x\n",
> +						iport->active_oxid_fdmi_rpa);
>   			fdls_schedule_oxid_free(iport, &iport->active_oxid_fdmi_rpa);
> +		}
>   	}
>   	FNIC_FCS_DBG(KERN_INFO, fnic->host, fnic->fnic_num,
> -		"fdmi timer callback : 0x%x\n", iport->fabric.fdmi_pending);
> +		"iport->fabric.fdmi_pending: 0x%x\n", iport->fabric.fdmi_pending);
>   
>   	fdls_fdmi_retry_plogi(iport);
>   	FNIC_FCS_DBG(KERN_INFO, fnic->host, fnic->fnic_num,
> -		"fdmi timer callback : 0x%x\n", iport->fabric.fdmi_pending);
> +		"iport->fabric.fdmi_pending: 0x%x\n", iport->fabric.fdmi_pending);
>   	spin_unlock_irqrestore(&fnic->fnic_lock, flags);
>   }
>   
> @@ -3743,12 +3768,26 @@ static void fdls_process_fdmi_abts_rsp(struct fnic_iport_s *iport,
>   
>   	switch (FNIC_FRAME_TYPE(oxid)) {
>   	case FNIC_FRAME_TYPE_FDMI_PLOGI:
> +		FNIC_FCS_DBG(KERN_INFO, fnic->host, fnic->fnic_num,
> +			"Received FDMI PLOGI ABTS rsp with oxid: 0x%x", oxid);
> +		FNIC_FCS_DBG(KERN_INFO, fnic->host, fnic->fnic_num,
> +			 "0x%x: iport->fabric.fdmi_pending: 0x%x",
> +			 iport->fcid, iport->fabric.fdmi_pending);
>   		fdls_free_oxid(iport, oxid, &iport->active_oxid_fdmi_plogi);
>   
>   		iport->fabric.fdmi_pending &= ~FDLS_FDMI_PLOGI_PENDING;
>   		iport->fabric.fdmi_pending &= ~FDLS_FDMI_ABORT_PENDING;
> +		FNIC_FCS_DBG(KERN_INFO, fnic->host, fnic->fnic_num,
> +			 "0x%x: iport->fabric.fdmi_pending: 0x%x",
> +			 iport->fcid, iport->fabric.fdmi_pending);
>   		break;
>   	case FNIC_FRAME_TYPE_FDMI_RHBA:
> +		FNIC_FCS_DBG(KERN_INFO, fnic->host, fnic->fnic_num,
> +			"Received FDMI RHBA ABTS rsp with oxid: 0x%x", oxid);
> +		FNIC_FCS_DBG(KERN_INFO, fnic->host, fnic->fnic_num,
> +			 "0x%x: iport->fabric.fdmi_pending: 0x%x",
> +			 iport->fcid, iport->fabric.fdmi_pending);
> +
>   		iport->fabric.fdmi_pending &= ~FDLS_FDMI_REG_HBA_PENDING;
>   
>   		/* If RPA is still pending, don't turn off ABORT PENDING.
> @@ -3759,8 +3798,17 @@ static void fdls_process_fdmi_abts_rsp(struct fnic_iport_s *iport,
>   			iport->fabric.fdmi_pending &= ~FDLS_FDMI_ABORT_PENDING;
>   
>   		fdls_free_oxid(iport, oxid, &iport->active_oxid_fdmi_rhba);
> +		FNIC_FCS_DBG(KERN_INFO, fnic->host, fnic->fnic_num,
> +			 "0x%x: iport->fabric.fdmi_pending: 0x%x",
> +			 iport->fcid, iport->fabric.fdmi_pending);
>   		break;
>   	case FNIC_FRAME_TYPE_FDMI_RPA:
> +		FNIC_FCS_DBG(KERN_INFO, fnic->host, fnic->fnic_num,
> +			"Received FDMI RPA ABTS rsp with oxid: 0x%x", oxid);
> +		FNIC_FCS_DBG(KERN_INFO, fnic->host, fnic->fnic_num,
> +			 "0x%x: iport->fabric.fdmi_pending: 0x%x",
> +			 iport->fcid, iport->fabric.fdmi_pending);
> +
>   		iport->fabric.fdmi_pending &= ~FDLS_FDMI_RPA_PENDING;
>   
>   		/* If RHBA is still pending, don't turn off ABORT PENDING.
> @@ -3771,6 +3819,9 @@ static void fdls_process_fdmi_abts_rsp(struct fnic_iport_s *iport,
>   			iport->fabric.fdmi_pending &= ~FDLS_FDMI_ABORT_PENDING;
>   
>   		fdls_free_oxid(iport, oxid, &iport->active_oxid_fdmi_rpa);
> +		FNIC_FCS_DBG(KERN_INFO, fnic->host, fnic->fnic_num,
> +			 "0x%x: iport->fabric.fdmi_pending: 0x%x",
> +			 iport->fcid, iport->fabric.fdmi_pending);
>   		break;
>   	default:
>   		FNIC_FCS_DBG(KERN_INFO, fnic->host, fnic->fnic_num,


Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ