return ret;
 
        qla_printk(KERN_INFO, vha->hw,
-           "scsi(%ld:%d:%d): LOOP RESET ISSUED.\n", vha->host_no, id, lun);
+           "scsi(%ld:%d:%d): BUS RESET ISSUED.\n", vha->host_no, id, lun);
 
        if (qla2x00_wait_for_hba_online(vha) != QLA_SUCCESS) {
                DEBUG2(printk("%s failed:board disabled\n",__func__));
        struct fc_port *fcport;
        struct qla_hw_data *ha = vha->hw;
 
-       if (ha->flags.enable_lip_full_login) {
+       if (ha->flags.enable_lip_full_login && !vha->vp_idx) {
                ret = qla2x00_full_login_lip(vha);
                if (ret != QLA_SUCCESS) {
-                       DEBUG2_3(printk("%s(%ld): bus_reset failed: "
+                       DEBUG2_3(printk("%s(%ld): failed: "
                            "full_login_lip=%d.\n", __func__, vha->host_no,
                            ret));
-               } else
-                       qla2x00_wait_for_loop_ready(vha);
+               }
+               atomic_set(&vha->loop_state, LOOP_DOWN);
+               atomic_set(&vha->loop_down_timer, LOOP_DOWN_TIME);
+               qla2x00_mark_all_devices_lost(vha, 0);
+               qla2x00_wait_for_loop_ready(vha);
        }
 
-       if (ha->flags.enable_lip_reset) {
+       if (ha->flags.enable_lip_reset && !vha->vp_idx) {
                ret = qla2x00_lip_reset(vha);
                if (ret != QLA_SUCCESS) {
-                       DEBUG2_3(printk("%s(%ld): bus_reset failed: "
+                       DEBUG2_3(printk("%s(%ld): failed: "
                            "lip_reset=%d.\n", __func__, vha->host_no, ret));
                } else
                        qla2x00_wait_for_loop_ready(vha);