Received: by 2002:a05:6358:9144:b0:117:f937:c515 with SMTP id r4csp119669rwr; Tue, 25 Apr 2023 18:48:12 -0700 (PDT) X-Google-Smtp-Source: AKy350axcDz5C3YLsbnlDDR/uW/DR/Cg9mQK4Kx3SNoeRAC3Kny5IBtrZgElgzEVRh+QOrHk8jJ1 X-Received: by 2002:a05:6a20:6a22:b0:f3:cac4:ca5d with SMTP id p34-20020a056a206a2200b000f3cac4ca5dmr13315025pzk.35.1682473691740; Tue, 25 Apr 2023 18:48:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1682473691; cv=none; d=google.com; s=arc-20160816; b=SeEpSiiJvzrhpMUB0BYSowR4lsalouGrMmJ+vTKWEzBAmvJACg3+9H1vYaYjv75N85 JMku+gbInirBULROi8hUiaQO90dr9VvCIv0le1jhk9XoRNET7d6O2YpGru39Nvwij0bz 0uC/l7eJWOzpJu6f6vjCMl5KuU7fHF117m7nR9JrpftVM8QAZdz5hk1Sb0n3wKJKTquk r5QTNbtQZRD2fMnrgK3BApVo2bTR+CIapCuer0lnOdHBzd2THbiqtC+Mu68/0oVCClea O3plZODxZID/z3VoVJx2eQkoEUrdtCmzGPbbP6OmG27dLIKtDE+SOvIr7Z5t5kH45InU p3Tg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject; bh=ClHx4UB0vZlxdqQMV0vd5DhL7/dmChDQnAWDRkamEWs=; b=JHhyVoQAWODuN8GSNt62caEAwMK0ccge/MERZxocmLOQqPDdD2n5j7mM1Tu47buHDr 7ThblKUegRjTW7RbxdTb1S/x8izQZFgRzteX1yvsuYEv73EDi2QoQKn8bh8YSpwgcJGD 2NW3BvuhQNJIfcU6Rc3o6Is5Hl66mTnRjOeuPTl/QsIvLtlV1isIW9bRyVFN/t2vnhy7 +2qkdoxuggQpgqACoi4m5k2JM/6ejnn9xqO58n1kUr2DgmYxdcEZ7W2LX2DwU1HFr679 9e8zV6thuC2d4z6xtePXDqHFmvzMBqrdylIRTA27wmlWN6nG5gZYfZLpG2GN44hPRIii 965w== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id c6-20020a655a86000000b0051384f6edeasi14781964pgt.537.2023.04.25.18.47.58; Tue, 25 Apr 2023 18:48:11 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S239026AbjDZBlS (ORCPT + 99 others); Tue, 25 Apr 2023 21:41:18 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45766 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S238177AbjDZBlR (ORCPT ); Tue, 25 Apr 2023 21:41:17 -0400 Received: from szxga02-in.huawei.com (szxga02-in.huawei.com [45.249.212.188]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 87FABB21E; Tue, 25 Apr 2023 18:41:14 -0700 (PDT) Received: from canpemm100004.china.huawei.com (unknown [172.30.72.57]) by szxga02-in.huawei.com (SkyGuard) with ESMTP id 4Q5hN40W2YzLnjb; Wed, 26 Apr 2023 09:38:28 +0800 (CST) Received: from [10.174.179.14] (10.174.179.14) by canpemm100004.china.huawei.com (7.192.105.92) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2507.23; Wed, 26 Apr 2023 09:41:11 +0800 Subject: Re: [PATCH] scsi: libsas: set tf to normal in sas_ata_device_link_abort() To: yangxingui , , , CC: , , , , References: <20230407035618.25123-1-yangxingui@huawei.com> From: Jason Yan Message-ID: <1b39acd7-2028-a080-13be-660ed5c0bfb0@huawei.com> Date: Wed, 26 Apr 2023 09:41:11 +0800 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:78.0) Gecko/20100101 Thunderbird/78.12.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset="utf-8"; format=flowed Content-Language: en-US Content-Transfer-Encoding: 8bit X-Originating-IP: [10.174.179.14] X-ClientProxiedBy: dggems705-chm.china.huawei.com (10.3.19.182) To canpemm100004.china.huawei.com (7.192.105.92) X-CFilter-Loop: Reflected X-Spam-Status: No, score=-5.6 required=5.0 tests=BAYES_00,NICE_REPLY_A, RCVD_IN_DNSWL_MED,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 2023/4/17 16:18, yangxingui wrote: > Hi Jason > > On 2023/4/14 15:36, Jason Yan wrote: >> On 2023/4/7 11:56, Xingui Yang wrote: >>> If the disk returns UNC for more than five times within a short >>> period, the >>> number of retry times for other I/Os may reach scmd->allowed, and the >>> default error "Illegal Request" is returned for other I/Os, as follows: >>> >>> [  273.801770] hisi_sas_v3_hw 0000:b4:02.0: erroneous completion disk >>> err dev id=2 sas_addr=0x5000000000000605 CQ hdr: 0x400903 0x20103 0x0 >>> 0x80470000 >>> [  273.875286] sas: Enter sas_scsi_recover_host busy: 30 failed: 30 >>> [  273.879895] sas: trying to find task 0x00000000d9cfc893 >>> [  273.879896] sas: sas_scsi_find_task: aborting task 0x00000000d9cfc893 >>> [  273.880054] sas: sas_scsi_find_task: task 0x00000000d9cfc893 is done >>> [  273.880055] sas: sas_eh_handle_sas_errors: task 0x00000000d9cfc893 >>> is done >>> [  273.880236] ata6.00: failed command: READ FPDMA QUEUED >>> [  273.880238] ata6.00: cmd 60/08:00:59:27:00/00:00:00:00:00/40 tag >>> 22 ncq dma 4096 in >>>                          res 41/04:00:20:00:00/00:00:00:00:00/00 >>> Emask 0x1 (device error) >>> [  273.880239] ata6.00: status: { DRDY ERR } >>> [  273.880240] ata6.00: error: { ABRT } >>> [  273.880241] ata6.00: failed command: READ FPDMA QUEUED >>> [  273.880243] ata6.00: cmd 60/90:00:d1:26:00/00:00:00:00:00/40 tag >>> 23 ncq dma 73728 in >>>                          res 41/40:90:10:27:00/00:00:00:00:00/00 >>> Emask 0x409 (media error) >>> [  273.880245] ata6.00: status: { DRDY ERR } >>> [  273.880246] ata6.00: error: { UNC } >>> [  273.880247] ata6.00: failed command: READ FPDMA QUEUED >>> [  273.880249] ata6.00: cmd 60/08:00:19:27:00/00:00:00:00:00/40 tag >>> 24 ncq dma 4096 in >>>                          res 41/04:00:20:00:00/00:00:00:00:00/00 >>> Emask 0x1 (device error) >>> [  273.880250] ata6.00: status: { DRDY ERR } >>> [  273.880251] ata6.00: error: { ABRT } >>> [  274.199477] scmd->retries: 3, scmd->allowed: 5 >>> [  274.199478] scmd->retries: 3, scmd->allowed: 5 >>> [  274.199479] scmd->retries: 3, scmd->allowed: 5 >>> [  274.199481] scmd->retries: 3, scmd->allowed: 5 >>> [  274.199482] scmd->retries: 3, scmd->allowed: 5 >>> [  274.199483] scmd->retries: 2, scmd->allowed: 5 >>> [  274.199484] scmd->retries: 3, scmd->allowed: 5 >>> [  274.199485] scmd->retries: 3, scmd->allowed: 5 >>> [  274.199486] scmd->retries: 5, scmd->allowed: 5 >>> [  274.199487] scmd->retries: 2, scmd->allowed: 5 >>> [  274.199488] scmd->retries: 2, scmd->allowed: 5 >>> [  274.199524] sd 6:0:1:0: [sdb] tag#258 FAILED Result: >>> hostbyte=DID_OK driverbyte=DRIVER_SENSE >>> [  274.199527] sd 6:0:1:0: [sdb] tag#258 Sense Key : Illegal Request >>> [current] >>> [  274.199530] sd 6:0:1:0: [sdb] tag#258 Add. Sense: Unaligned write >>> command >>> [  274.199532] sd 6:0:1:0: [sdb] tag#258 CDB: Read(10) 28 00 00 00 27 >>> 59 00 00 08 00 >>> [  274.199535] print_req_error: I/O error, dev sdb, sector 10073 >>> [  274.199573] sd 6:0:1:0: [sdb] tag#259 FAILED Result: >>> hostbyte=DID_OK driverbyte=DRIVER_SENSE >>> [  274.199574] sd 6:0:1:0: [sdb] tag#259 Sense Key : Medium Error >>> [current] >>> [  274.199576] sd 6:0:1:0: [sdb] tag#259 Add. Sense: Unrecovered read >>> error - auto reallocate failed >>> [  274.199578] sd 6:0:1:0: [sdb] tag#259 CDB: Read(10) 28 00 00 00 26 >>> d1 00 00 90 00 >>> [  274.199579] print_req_error: I/O error, dev sdb, sector 10000 >>> [  274.199608] ata6: EH complete >>> [  274.199615] sas: --- Exit sas_scsi_recover_host: busy: 0 failed: >>> 30 tries: 1 >>> >>> As mentioned in ata_eh_qc_retry(), if qc->err_mask is zero then >>> increment >>> scmd->allowed. So set tf to normal may be better. >> >> Hi Xingui, >> >> If we increase scmd->allowed every time, and the device returns UNC >> for too many times, will the other IO pending for too long and cause >> hungtask? And also the runtime check in scsi_cmd_runtime_exceeced() >> will not trigger since cmd->allowed is extended. >> > Thank you for your reply. In scenarios similar to UNC error, where a > disk returns an error through D2H or SDB, no error is reported for other > I/Os in the disk. In this case, AHCI will increase the number of retry > times for other I/Os, and AHCI may face similar problems you say, but > default failures may not be very good for users. I think at least we cannot always retry unconditionally. Failure is better than hung becuase users can deal with failures. They can retry from the userspace. But if the process stuck in kernel, it is a disaster for the userspace and they can do nothing. Is there a way to limit the times of retry? Thanks, Jason > > In addition, for commands with pass through type, other I/Os are > immediately returned with default errors and are not retried, but AHCI > only report one single error I/O. > > Thanks, > Xingui > >> Thanks, >> Jason >> >>> >>> Signed-off-by: Xingui Yang >>> --- >>>   drivers/scsi/libsas/sas_ata.c | 4 ++-- >>>   1 file changed, 2 insertions(+), 2 deletions(-) >>> >>> diff --git a/drivers/scsi/libsas/sas_ata.c >>> b/drivers/scsi/libsas/sas_ata.c >>> index 77714a495cbb..f5047e8dcb59 100644 >>> --- a/drivers/scsi/libsas/sas_ata.c >>> +++ b/drivers/scsi/libsas/sas_ata.c >>> @@ -949,8 +949,8 @@ void sas_ata_device_link_abort(struct >>> domain_device *device, bool force_reset) >>>       unsigned long flags; >>>       spin_lock_irqsave(ap->lock, flags); >>> -    device->sata_dev.fis[2] = ATA_ERR | ATA_DRDY; /* tf status */ >>> -    device->sata_dev.fis[3] = ATA_ABORTED; /* tf error */ >>> +    device->sata_dev.fis[2] = ATA_DRDY; /* tf status */ >>> +    device->sata_dev.fis[3] = 0;        /* tf error */ >>>       link->eh_info.err_mask |= AC_ERR_DEV; >>>       if (force_reset) >>> >> . > .