u32 hdr_tag, ncg_tag = 0;
        u64 phys_addr;
        u32 ATAP = 0x0;
-       u32 dir;
+       u32 dir, retfis = 0;
        u32  opc = OPC_INB_SATA_HOST_OPSTART;
 
        memset(&sata_cmd, 0, sizeof(sata_cmd));
        sata_cmd.tag = cpu_to_le32(tag);
        sata_cmd.device_id = cpu_to_le32(pm8001_ha_dev->device_id);
        sata_cmd.data_len = cpu_to_le32(task->total_xfer_len);
-       sata_cmd.ncqtag_atap_dir_m =
-               cpu_to_le32(((ncg_tag & 0xff)<<16)|((ATAP & 0x3f) << 10) | dir);
+       if (task->ata_task.return_fis_on_success)
+               retfis = 1;
+       sata_cmd.retfis_ncqtag_atap_dir_m =
+               cpu_to_le32((retfis << 24) | ((ncg_tag & 0xff) << 16) |
+                           ((ATAP & 0x3f) << 10) | dir);
        sata_cmd.sata_fis = task->ata_task.fis;
        if (likely(!task->ata_task.device_control_reg_update))
                sata_cmd.sata_fis.flags |= 0x80;/* C=1: update ATA cmd reg */
 
        u64 phys_addr, end_addr;
        u32 end_addr_high, end_addr_low;
        u32 ATAP = 0x0;
-       u32 dir;
+       u32 dir, retfis = 0;
        u32 opc = OPC_INB_SATA_HOST_OPSTART;
        memset(&sata_cmd, 0, sizeof(sata_cmd));
 
        sata_cmd.tag = cpu_to_le32(tag);
        sata_cmd.device_id = cpu_to_le32(pm8001_ha_dev->device_id);
        sata_cmd.data_len = cpu_to_le32(task->total_xfer_len);
-
+       if (task->ata_task.return_fis_on_success)
+               retfis = 1;
        sata_cmd.sata_fis = task->ata_task.fis;
        if (likely(!task->ata_task.device_control_reg_update))
                sata_cmd.sata_fis.flags |= 0x80;/* C=1: update ATA cmd reg */
                           "Encryption enabled.Sending Encrypt SATA cmd 0x%x\n",
                           sata_cmd.sata_fis.command);
                opc = OPC_INB_SATA_DIF_ENC_IO;
-
-               /* set encryption bit */
-               sata_cmd.ncqtag_atap_dir_m_dad =
-                       cpu_to_le32(((ncg_tag & 0xff)<<16)|
-                               ((ATAP & 0x3f) << 10) | 0x20 | dir);
-                                                       /* dad (bit 0-1) is 0 */
+               /* set encryption bit; dad (bits 0-1) is 0 */
+               sata_cmd.retfis_ncqtag_atap_dir_m_dad =
+                       cpu_to_le32((retfis << 24) | ((ncg_tag & 0xff) << 16) |
+                                   ((ATAP & 0x3f) << 10) | 0x20 | dir);
                /* fill in PRD (scatter/gather) table, if any */
                if (task->num_scatter > 1) {
                        pm8001_chip_make_sg(task->scatter,
                pm8001_dbg(pm8001_ha, IO,
                           "Sending Normal SATA command 0x%x inb %x\n",
                           sata_cmd.sata_fis.command, q_index);
-               /* dad (bit 0-1) is 0 */
-               sata_cmd.ncqtag_atap_dir_m_dad =
-                       cpu_to_le32(((ncg_tag & 0xff)<<16) |
-                                       ((ATAP & 0x3f) << 10) | dir);
-
+               /* dad (bits 0-1) is 0 */
+               sata_cmd.retfis_ncqtag_atap_dir_m_dad =
+                       cpu_to_le32((retfis << 24) | ((ncg_tag & 0xff) << 16) |
+                                   ((ATAP & 0x3f) << 10) | dir);
                /* fill in PRD (scatter/gather) table, if any */
                if (task->num_scatter > 1) {
                        pm8001_chip_make_sg(task->scatter,