Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp3008878imu; Mon, 19 Nov 2018 09:17:40 -0800 (PST) X-Google-Smtp-Source: AJdET5f96LmDWeJ9JSeQJhPY0zKuKEcZrkQzUjpGWNT3+2RDiyKSBPoEJPUby+np7J8R34rEF5C1 X-Received: by 2002:a17:902:b48b:: with SMTP id y11-v6mr23164454plr.135.1542647860867; Mon, 19 Nov 2018 09:17:40 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1542647860; cv=none; d=google.com; s=arc-20160816; b=FeB20NYjdouM12wIpBW3Els7peQaf4gU+oMGxniKzpho5e/zckMCR3AFZdS5VL2MM+ aIJvUKBGLLtAPN8jPudhGpPBHX+T4HTYXy7W5k/LVDa20Qds8DLSJlwGX1Xht3NmUBA6 b/bMsf4/agelqWTWxVZ4EpizwSA01Sk4fF9mwtc766miV2/JBd9w4oYUriBD4TBxIB+n dF3eVp3elBVsARH85Y1D6Cm6El329mFVyd8D6YQVuFmizpxW0XlP8tE/uXzJjHFy0hIi kTd6NTTA6/hj/WieOOk28+g/2jFESxxuYqcOP76Ie2Xa06ls3OfrOv3RE1kU3nA/3LNp F5hw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=LxHbCKVVdzqmKENHBfNzgXlEcr60wxC/wJKy9ZIpyRs=; b=VLxQemvJ0FDtZL/eREIKEh0ThRe2i03+qP6b4cNOtNLUa7u90NeGTDJgVF9Pv4vb5j df9Aar6jFXWhHhh+HYCJhavpW9UkaOslOhcaKaR98v3VKvE+wJSEucq6mm4EVA4XSIRr amqAILwSbwf9nqZk5kkWDPXuu72FbLuM4LDz+hPaex/rzljBVbtvZAuE510CJ7rBacx5 jIdrdY3IJXpZ55AFtdJTmU5cnPdeJZjG8itYVeD8JUWpqfzircGnC/91lj+p3+p3TS7/ AEdDDLFEYcTpMivkwTRqjwgYFAql3n+iz90d2BG7A+e/uijbiu1zwHg6YW1iuLIuT4hj pNzA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=zFxE7bMJ; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id e6si32444931pgd.428.2018.11.19.09.17.25; Mon, 19 Nov 2018 09:17:40 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=zFxE7bMJ; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2406345AbeKTD2E (ORCPT + 99 others); Mon, 19 Nov 2018 22:28:04 -0500 Received: from mail.kernel.org ([198.145.29.99]:42302 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2405689AbeKTD2E (ORCPT ); Mon, 19 Nov 2018 22:28:04 -0500 Received: from localhost (5356596B.cm-6-7b.dynamic.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 9FFB02154B; Mon, 19 Nov 2018 17:03:46 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1542647027; bh=ceoj3GCtotAeO5Q2sPMKW3wac75oNqTarJlsYHbV6M0=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=zFxE7bMJVIGi8mCytkTnvrug9yPubtzB57x6DePe6LIAU2N/aJ8RtC0j3XodjO7BA ME8uiVgqN3aIt3CKw/fCuyyzT6fTyhTYWMx95HKlU1z/TZXqBWI4uxHO7QI9LeCxXp W2efl1MJGrFSXa0rdstd5Jv/8tMpL2wW+kR9nnWM= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Stan Johnson , Finn Thain , Michael Schmitz , "Martin K. Petersen" , Sasha Levin Subject: [PATCH 3.18 22/90] scsi: esp_scsi: Track residual for PIO transfers Date: Mon, 19 Nov 2018 17:29:04 +0100 Message-Id: <20181119162624.550078832@linuxfoundation.org> X-Mailer: git-send-email 2.19.1 In-Reply-To: <20181119162620.585061184@linuxfoundation.org> References: <20181119162620.585061184@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 3.18-stable review patch. If anyone has any objections, please let me know. ------------------ From: Finn Thain [ Upstream commit fd47d919d0c336e7c22862b51ee94927ffea227a ] If a target disconnects during a PIO data transfer the command may fail when the target reconnects: scsi host1: DMA length is zero! scsi host1: cur adr[04380000] len[00000000] The scsi bus is then reset. This happens because the residual reached zero before the transfer was completed. The usual residual calculation relies on the Transfer Count registers. That works for DMA transfers but not for PIO transfers. Fix the problem by storing the PIO transfer residual and using that to correctly calculate bytes_sent. Fixes: 6fe07aaffbf0 ("[SCSI] m68k: new mac_esp scsi driver") Tested-by: Stan Johnson Signed-off-by: Finn Thain Tested-by: Michael Schmitz Signed-off-by: Martin K. Petersen Signed-off-by: Sasha Levin Signed-off-by: Greg Kroah-Hartman --- drivers/scsi/esp_scsi.c | 1 + drivers/scsi/esp_scsi.h | 2 ++ drivers/scsi/mac_esp.c | 2 ++ 3 files changed, 5 insertions(+) --- a/drivers/scsi/esp_scsi.c +++ b/drivers/scsi/esp_scsi.c @@ -1316,6 +1316,7 @@ static int esp_data_bytes_sent(struct es bytes_sent = esp->data_dma_len; bytes_sent -= ecount; + bytes_sent -= esp->send_cmd_residual; if (!(ent->flags & ESP_CMD_FLAG_WRITE)) bytes_sent -= fifo_cnt; --- a/drivers/scsi/esp_scsi.h +++ b/drivers/scsi/esp_scsi.h @@ -524,6 +524,8 @@ struct esp { void *dma; int dmarev; + + u32 send_cmd_residual; }; /* A front-end driver for the ESP chip should do the following in --- a/drivers/scsi/mac_esp.c +++ b/drivers/scsi/mac_esp.c @@ -426,6 +426,8 @@ static void mac_esp_send_pio_cmd(struct scsi_esp_cmd(esp, ESP_CMD_TI); } } + + esp->send_cmd_residual = esp_count; } static int mac_esp_irq_pending(struct esp *esp)