for (v = 0; v < pf->num_alloc_vfs; v++)
                ice_trigger_vf_reset(&pf->vf[v], is_vflr);
 
-       for (v = 0; v < pf->num_alloc_vfs; v++)
-               if (test_bit(ICE_VF_STATE_QS_ENA, pf->vf[v].vf_states))
-                       ice_dis_vf_qs(&pf->vf[v]);
+       for (v = 0; v < pf->num_alloc_vfs; v++) {
+               struct ice_vsi *vsi;
+
+               vf = &pf->vf[v];
+               vsi = pf->vsi[vf->lan_vsi_idx];
+               if (test_bit(ICE_VF_STATE_QS_ENA, vf->vf_states))
+                       ice_dis_vf_qs(vf);
+               ice_dis_vsi_txq(vsi->port_info, vsi->idx, 0, 0, NULL, NULL,
+                               NULL, ICE_VF_RESET, vf->vf_id, NULL);
+       }
 
        /* HW requires some time to make sure it can flush the FIFO for a VF
         * when it resets it. Poll the VPGEN_VFRSTAT register for each VF in
 
        if (test_bit(ICE_VF_STATE_QS_ENA, vf->vf_states))
                ice_dis_vf_qs(vf);
-       else
-               /* Call Disable LAN Tx queue AQ call even when queues are not
-                * enabled. This is needed for successful completion of VFR
-                */
-               ice_dis_vsi_txq(vsi->port_info, vsi->idx, 0, 0, NULL, NULL,
-                               NULL, ICE_VF_RESET, vf->vf_id, NULL);
+
+       /* Call Disable LAN Tx queue AQ whether or not queues are
+        * enabled. This is needed for successful completion of VFR.
+        */
+       ice_dis_vsi_txq(vsi->port_info, vsi->idx, 0, 0, NULL, NULL,
+                       NULL, ICE_VF_RESET, vf->vf_id, NULL);
 
        hw = &pf->hw;
        /* poll VPGEN_VFRSTAT reg to make sure