Received: by 2002:a05:6358:d09b:b0:dc:cd0c:909e with SMTP id jc27csp4506296rwb; Tue, 8 Nov 2022 18:47:16 -0800 (PST) X-Google-Smtp-Source: AMsMyM62EK9FlSIeJVNHOcMEMWsBPAR8IkbwE430BeL3v4P7uTMWZBklX8DBrGD6cblH+P0+kS1o X-Received: by 2002:a05:6402:22a5:b0:462:b393:f281 with SMTP id cx5-20020a05640222a500b00462b393f281mr58992663edb.379.1667962035823; Tue, 08 Nov 2022 18:47:15 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1667962035; cv=none; d=google.com; s=arc-20160816; b=sVzfc28BWRjb/7qbpCrJsub5++k4f3mUUZ3J4S1ILCum/gWCwyl6Fz/w4wDbJ6D2Dr 8x17UnCLDHxPXV3LsNtqszllNLTtz+shEAHGyl+SR6O0v4EyBgRBWeLBgYd579vF2gnk 8OLRLltDweqZ1v/0LC9zG6zxLcPBctVWTuN8qc6TGOn7TPStxjkmsCLOtlm0Zq7uGH7e C1ekDlKOT4yo943RxFZmzCCuze+MGsukMJvS0bfBsoo85+6b3TvnKL7NsnfCywBwRp1v VlrF7PcuP6bHTiW5g8MvS/NM9ihUKjrivqziqWEXmM69IqQLp3z04UB+LjpTTmIRsK13 IyKg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=Ou0KYs/Nn55Lz1448WqOauMmkvkhnvdv09cVAf56VAk=; b=rsoOFc07o8DDWpTMla8gu0ZheMe1y7faSDQvQaoAD1Q4G0HHcmJR9OYJeSb/Q3wKyY fjVhM539orFG4Yxyg9hGfv9GX+5UtNdUY7wvw0Hnk82pFtcr0jXmfBXAu0LT//G8yMqe w0vmbaWbXBKJsL46UkjNI6o+t4nF8R7gdtAeXTUXC/lLdbOT9igUTGhY/R76hy+nmb8+ E2YjuRZg0M/LmKfCZCkT+oh5B/4MYxW1+c715gYVM6bUAFJ0QRMGrcn2NLAgklQsYOVx 9iMugHnLGH7jVLZ1nkAIDGIWaSUBGNxrzuuKQjtF3+jQxezarFNUoIHI5eBUaaZeY/AA B0RA== 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 sa7-20020a1709076d0700b0078dec48d442si14674006ejc.680.2022.11.08.18.46.53; Tue, 08 Nov 2022 18:47:15 -0800 (PST) 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 S230047AbiKICoL (ORCPT + 93 others); Tue, 8 Nov 2022 21:44:11 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:35156 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229951AbiKICnw (ORCPT ); Tue, 8 Nov 2022 21:43:52 -0500 Received: from szxga02-in.huawei.com (szxga02-in.huawei.com [45.249.212.188]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 5D53210064; Tue, 8 Nov 2022 18:43:51 -0800 (PST) Received: from dggpemm500024.china.huawei.com (unknown [172.30.72.54]) by szxga02-in.huawei.com (SkyGuard) with ESMTP id 4N6Tms09BtzRp7Z; Wed, 9 Nov 2022 10:43:41 +0800 (CST) Received: from dggpemm500017.china.huawei.com (7.185.36.178) by dggpemm500024.china.huawei.com (7.185.36.203) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.31; Wed, 9 Nov 2022 10:43:49 +0800 Received: from build.huawei.com (10.175.101.6) by dggpemm500017.china.huawei.com (7.185.36.178) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.31; Wed, 9 Nov 2022 10:43:49 +0800 From: Wenchao Hao To: "James E . J . Bottomley" , "Martin K . Petersen" , Doug Gilbert CC: , , Wenchao Hao Subject: [RFC PATCH 5/5] scsi:scsi_debug: fail specific scsi command with result and sense data Date: Wed, 9 Nov 2022 10:59:50 -0500 Message-ID: <20221109155950.3536976-6-haowenchao@huawei.com> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20221109155950.3536976-1-haowenchao@huawei.com> References: <20221109155950.3536976-1-haowenchao@huawei.com> MIME-Version: 1.0 Content-Transfer-Encoding: 7BIT Content-Type: text/plain; charset=US-ASCII X-Originating-IP: [10.175.101.6] X-ClientProxiedBy: dggems703-chm.china.huawei.com (10.3.19.180) To dggpemm500017.china.huawei.com (7.185.36.178) X-CFilter-Loop: Reflected X-Spam-Status: No, score=-1.0 required=5.0 tests=BAYES_00,DATE_IN_FUTURE_12_24, RCVD_IN_DNSWL_MED,SPF_HELO_NONE,SPF_PASS autolearn=no 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 If a fail commnd error is injected for specific scsi command, set the scsi command's status and sense data, then finish this scsi command. For example, the following command would make read(0x88) command finished with UNC for 8 times: error=/sys/block/sdb/device/error_inject/error echo "2 -8 0x88 0 0 0x2 0x3 0x11 0x0" >$error Signed-off-by: Wenchao Hao --- drivers/scsi/scsi_debug.c | 46 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 46 insertions(+) diff --git a/drivers/scsi/scsi_debug.c b/drivers/scsi/scsi_debug.c index 217a9e892391..06fe2914117f 100644 --- a/drivers/scsi/scsi_debug.c +++ b/drivers/scsi/scsi_debug.c @@ -7832,6 +7832,41 @@ static int sdebug_fail_queue_cmd(struct scsi_cmnd *cmnd) return 0; } +static int sdebug_fail_cmd(struct scsi_cmnd *cmnd, int *retval, + struct sdebug_err_inject *info) +{ + struct scsi_device *sdp = cmnd->device; + struct sdebug_dev_info *devip = (struct sdebug_dev_info *)sdp->hostdata; + struct sdebug_err_inject *err; + unsigned char *cmd = cmnd->cmnd; + int ret = 0; + int result; + + if (devip == NULL) + return 0; + + list_for_each_entry(err, &devip->inject_err_list, list) { + if (err->type == ERR_FAIL_CMD && + (err->cmd == cmd[0] || err->cmd == 0xff)) { + if (!err->cnt) + return 0; + ret = !!err->cnt; + goto out_handle; + } + } + return 0; + +out_handle: + if (err->cnt < 0) + err->cnt++; + mk_sense_buffer(cmnd, err->sense_key, err->asc, err->asq); + result = err->status_byte | err->host_byte << 16 | err->driver_byte << 24; + *info = *err; + *retval = schedule_resp(cmnd, devip, result, NULL, 0, 0); + + return ret; +} + static int scsi_debug_queuecommand(struct Scsi_Host *shost, struct scsi_cmnd *scp) { @@ -7852,6 +7887,7 @@ static int scsi_debug_queuecommand(struct Scsi_Host *shost, bool has_wlun_rl; bool inject_now; int ret = 0; + struct sdebug_err_inject err; scsi_set_resid(scp, 0); if (sdebug_statistics) { @@ -7904,6 +7940,16 @@ static int scsi_debug_queuecommand(struct Scsi_Host *shost, return ret; } + if (sdebug_fail_cmd(scp, &ret, &err)) { + scmd_printk(KERN_INFO, scp, + "fail command 0x%x with hostbyte=0x%x, " + "driverbyte=0x%x, statusbyte=0x%x, " + "sense_key=0x%x, asc=0x%x, asq=0x%x\n", + opcode, err.host_byte, err.driver_byte, + err.status_byte, err.sense_key, err.asc, err.asq); + return ret; + } + if (unlikely(inject_now && !atomic_read(&sdeb_inject_pending))) atomic_set(&sdeb_inject_pending, 1); -- 2.35.3