]> git.proxmox.com Git - mirror_ubuntu-jammy-kernel.git/commitdiff
scsi: qla2xxx: Fix incorrect display of max frame size
authorBikash Hazarika <bhazarika@marvell.com>
Wed, 13 Jul 2022 05:20:37 +0000 (22:20 -0700)
committerStefan Bader <stefan.bader@canonical.com>
Mon, 17 Oct 2022 09:55:50 +0000 (11:55 +0200)
BugLink: https://bugs.launchpad.net/bugs/1990162
commit cf3b4fb655796674e605268bd4bfb47a47c8bce6 upstream.

Replace display field with the correct field.

Link: https://lore.kernel.org/r/20220713052045.10683-3-njavali@marvell.com
Fixes: 8777e4314d39 ("scsi: qla2xxx: Migrate NVME N2N handling into state machine")
Cc: stable@vger.kernel.org
Reviewed-by: Himanshu Madhani <himanshu.madhani@oracle.com>
Signed-off-by: Bikash Hazarika <bhazarika@marvell.com>
Signed-off-by: Nilesh Javali <njavali@marvell.com>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: Kamal Mostafa <kamal@canonical.com>
Signed-off-by: Stefan Bader <stefan.bader@canonical.com>
drivers/scsi/qla2xxx/qla_def.h
drivers/scsi/qla2xxx/qla_gs.c
drivers/scsi/qla2xxx/qla_init.c
drivers/scsi/qla2xxx/qla_isr.c

index 303ad60d1d49d5d8f61443377cc5ca248e350c59..76427c8780f53e4ada0039e8a35080cd7503372b 100644 (file)
@@ -3972,6 +3972,7 @@ struct qla_hw_data {
        /* SRB cache. */
 #define SRB_MIN_REQ     128
        mempool_t       *srb_mempool;
+       u8 port_name[WWN_SIZE];
 
        volatile struct {
                uint32_t        mbox_int                :1;
index da7080c4bd0087f43b726fb72ac9ec48dedc1d7c..c54011510b6a94ca2e2d6493a62470a8577318e6 100644 (file)
@@ -1595,7 +1595,6 @@ qla2x00_hba_attributes(scsi_qla_host_t *vha, void *entries,
        unsigned int callopt)
 {
        struct qla_hw_data *ha = vha->hw;
-       struct init_cb_24xx *icb24 = (void *)ha->init_cb;
        struct new_utsname *p_sysid = utsname();
        struct ct_fdmi_hba_attr *eiter;
        uint16_t alen;
@@ -1757,8 +1756,8 @@ qla2x00_hba_attributes(scsi_qla_host_t *vha, void *entries,
        /* MAX CT Payload Length */
        eiter = entries + size;
        eiter->type = cpu_to_be16(FDMI_HBA_MAXIMUM_CT_PAYLOAD_LENGTH);
-       eiter->a.max_ct_len = cpu_to_be32(le16_to_cpu(IS_FWI2_CAPABLE(ha) ?
-               icb24->frame_payload_size : ha->init_cb->frame_payload_size));
+       eiter->a.max_ct_len = cpu_to_be32(ha->frame_payload_size >> 2);
+
        alen = sizeof(eiter->a.max_ct_len);
        alen += FDMI_ATTR_TYPELEN(eiter);
        eiter->len = cpu_to_be16(alen);
@@ -1850,7 +1849,6 @@ qla2x00_port_attributes(scsi_qla_host_t *vha, void *entries,
        unsigned int callopt)
 {
        struct qla_hw_data *ha = vha->hw;
-       struct init_cb_24xx *icb24 = (void *)ha->init_cb;
        struct new_utsname *p_sysid = utsname();
        char *hostname = p_sysid ?
                p_sysid->nodename : fc_host_system_hostname(vha->host);
@@ -1902,8 +1900,7 @@ qla2x00_port_attributes(scsi_qla_host_t *vha, void *entries,
        /* Max frame size. */
        eiter = entries + size;
        eiter->type = cpu_to_be16(FDMI_PORT_MAX_FRAME_SIZE);
-       eiter->a.max_frame_size = cpu_to_be32(le16_to_cpu(IS_FWI2_CAPABLE(ha) ?
-               icb24->frame_payload_size : ha->init_cb->frame_payload_size));
+       eiter->a.max_frame_size = cpu_to_be32(ha->frame_payload_size);
        alen = sizeof(eiter->a.max_frame_size);
        alen += FDMI_ATTR_TYPELEN(eiter);
        eiter->len = cpu_to_be16(alen);
index b538d65efe292c98df4025f5a43cd5a75eb2092a..be150fc76dbaad1d2e644e370d02df2deeadde5b 100644 (file)
@@ -4490,6 +4490,8 @@ qla2x00_init_rings(scsi_qla_host_t *vha)
                         BIT_6) != 0;
                ql_dbg(ql_dbg_init, vha, 0x00bc, "FA-WWPN Support: %s.\n",
                    (ha->flags.fawwpn_enabled) ? "enabled" : "disabled");
+               /* Init_cb will be reused for other command(s).  Save a backup copy of port_name */
+               memcpy(ha->port_name, ha->init_cb->port_name, WWN_SIZE);
        }
 
        /* ELS pass through payload is limit by frame size. */
index 62d2f14848e7bd956ce284ac0651b02d31c7c17b..c3711ab68c3d6fff9652b771ab8c4b96fa538fc5 100644 (file)
@@ -1354,9 +1354,7 @@ skip_rio:
                        if (!vha->vp_idx) {
                                if (ha->flags.fawwpn_enabled &&
                                    (ha->current_topology == ISP_CFG_F)) {
-                                       void *wwpn = ha->init_cb->port_name;
-
-                                       memcpy(vha->port_name, wwpn, WWN_SIZE);
+                                       memcpy(vha->port_name, ha->port_name, WWN_SIZE);
                                        fc_host_port_name(vha->host) =
                                            wwn_to_u64(vha->port_name);
                                        ql_dbg(ql_dbg_init + ql_dbg_verbose,