Re: [PATCH v2 09/13] qla2xxx: Make tgt_port_database available in initiator mode

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 




> On Sep 2, 2020, at 2:25 AM, Nilesh Javali <njavali@xxxxxxxxxxx> wrote:
> 
> From: Arun Easi <aeasi@xxxxxxxxxxx>
> 
> tgt_port_database data is today exported only in target mode, allow it
> to be shown in initiator mode, as well.
> 
> Signed-off-by: Arun Easi <aeasi@xxxxxxxxxxx>
> Signed-off-by: Nilesh Javali <njavali@xxxxxxxxxxx>
> ---
> drivers/scsi/qla2xxx/qla_dfs.c | 64 +++++++++++++++++-----------------
> 1 file changed, 32 insertions(+), 32 deletions(-)
> 
> diff --git a/drivers/scsi/qla2xxx/qla_dfs.c b/drivers/scsi/qla2xxx/qla_dfs.c
> index 616ce891818d..1e9db568aee3 100644
> --- a/drivers/scsi/qla2xxx/qla_dfs.c
> +++ b/drivers/scsi/qla2xxx/qla_dfs.c
> @@ -138,51 +138,51 @@ qla2x00_dfs_tgt_port_database_show(struct seq_file *s, void *unused)
> {
> 	scsi_qla_host_t *vha = s->private;
> 	struct qla_hw_data *ha = vha->hw;
> -	struct gid_list_info *gid_list, *gid;
> +	struct gid_list_info *gid_list;
> 	dma_addr_t gid_list_dma;
> 	fc_port_t fc_port;
> +	char *id_iter;
> 	int rc, i;
> 	uint16_t entries, loop_id;
> -	struct qla_tgt *tgt = vha->vha_tgt.qla_tgt;
> 
> 	seq_printf(s, "%s\n", vha->host_str);
> -	if (tgt) {
> -		gid_list = dma_alloc_coherent(&ha->pdev->dev,
> -		    qla2x00_gid_list_size(ha),
> -		    &gid_list_dma, GFP_KERNEL);
> -		if (!gid_list) {
> -			ql_dbg(ql_dbg_user, vha, 0x7018,
> -			    "DMA allocation failed for %u\n",
> -			     qla2x00_gid_list_size(ha));
> -			return 0;
> -		}
> +	gid_list = dma_alloc_coherent(&ha->pdev->dev,
> +				      qla2x00_gid_list_size(ha),
> +				      &gid_list_dma, GFP_KERNEL);
> +	if (!gid_list) {
> +		ql_dbg(ql_dbg_user, vha, 0x7018,
> +		       "DMA allocation failed for %u\n",
> +		       qla2x00_gid_list_size(ha));
> +		return 0;
> +	}
> 
> -		rc = qla24xx_gidlist_wait(vha, gid_list, gid_list_dma,
> -		    &entries);
> -		if (rc != QLA_SUCCESS)
> -			goto out_free_id_list;
> +	rc = qla24xx_gidlist_wait(vha, gid_list, gid_list_dma,
> +				  &entries);
> +	if (rc != QLA_SUCCESS)
> +		goto out_free_id_list;
> 
> -		gid = gid_list;
> +	id_iter = (char *)gid_list;
> 
> -		seq_puts(s, "Port Name	Port ID 	Loop ID\n");
> +	seq_puts(s, "Port Name	Port ID		Loop ID\n");
> 
> -		for (i = 0; i < entries; i++) {
> -			loop_id = le16_to_cpu(gid->loop_id);
> -			memset(&fc_port, 0, sizeof(fc_port_t));
> +	for (i = 0; i < entries; i++) {
> +		struct gid_list_info *gid =
> +			(struct gid_list_info *)id_iter;
> +		loop_id = le16_to_cpu(gid->loop_id);
> +		memset(&fc_port, 0, sizeof(fc_port_t));
> 
> -			fc_port.loop_id = loop_id;
> +		fc_port.loop_id = loop_id;
> 
> -			rc = qla24xx_gpdb_wait(vha, &fc_port, 0);
> -			seq_printf(s, "%8phC  %02x%02x%02x  %d\n",
> -				fc_port.port_name, fc_port.d_id.b.domain,
> -				fc_port.d_id.b.area, fc_port.d_id.b.al_pa,
> -				fc_port.loop_id);
> -			gid = (void *)gid + ha->gid_list_info_size;
> -		}
> -out_free_id_list:
> -		dma_free_coherent(&ha->pdev->dev, qla2x00_gid_list_size(ha),
> -		    gid_list, gid_list_dma);
> +		rc = qla24xx_gpdb_wait(vha, &fc_port, 0);
> +		seq_printf(s, "%8phC  %02x%02x%02x  %d\n",
> +			   fc_port.port_name, fc_port.d_id.b.domain,
> +			   fc_port.d_id.b.area, fc_port.d_id.b.al_pa,
> +			   fc_port.loop_id);
> +		id_iter += ha->gid_list_info_size;
> 	}
> +out_free_id_list:
> +	dma_free_coherent(&ha->pdev->dev, qla2x00_gid_list_size(ha),
> +			  gid_list, gid_list_dma);
> 
> 	return 0;
> }
> -- 
> 2.19.0.rc0
> 

Reviewed-by: Himanshu Madhani <himanshu.madhani@xxxxxxxxxx>

--
Himanshu Madhani	 Oracle Linux Engineering





[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Index of Archives]     [SCSI Target Devel]     [Linux SCSI Target Infrastructure]     [Kernel Newbies]     [IDE]     [Security]     [Git]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux ATA RAID]     [Linux IIO]     [Samba]     [Device Mapper]

  Powered by Linux