goto done_free_sp;
                }
                break;
+       case FXDISC_ABORT_IOCTL:
        default:
                break;
        }
                ql_dump_buffer(ql_dbg_init + ql_dbg_buffer, vha, 0x0146,
                    (uint8_t *)pinfo, 16);
                memcpy(vha->hw->gid_list, pinfo, QLAFX00_TGT_NODE_LIST_SIZE);
-       }
+       } else if (fx_type == FXDISC_ABORT_IOCTL)
+               fdisc->u.fxiocb.result =
+                   (fdisc->u.fxiocb.result == cpu_to_le32(0x68)) ?
+                   cpu_to_le32(QLA_SUCCESS) : cpu_to_le32(QLA_FUNCTION_FAILED);
+
        rval = le32_to_cpu(fdisc->u.fxiocb.result);
 
 done_unmap_dma:
                /* Command not found. */
                return QLA_FUNCTION_FAILED;
        }
+       if (sp->type == SRB_FXIOCB_DCMD)
+               return qlafx00_fx_disc(vha, &vha->hw->mr.fcport,
+                   FXDISC_ABORT_IOCTL);
+
        return qlafx00_async_abt_cmd(sp);
 }
 
 
 #define FXDISC_GET_TGT_NODE_INFO       0x80
 #define FXDISC_GET_TGT_NODE_LIST       0x81
 #define FXDISC_REG_HOST_INFO           0x99
+#define FXDISC_ABORT_IOCTL             0xff
 
 #define QLAFX00_HBA_ICNTRL_REG         0x20B08
 #define QLAFX00_ICR_ENB_MASK            0x80000000