Received: by 2002:a25:31c3:0:0:0:0:0 with SMTP id x186csp4491793ybx; Mon, 4 Nov 2019 14:18:33 -0800 (PST) X-Google-Smtp-Source: APXvYqwuKV6qE4GVftHI/NJngJHjrXA5EjvNfYTIPM8opFLZ0E1UcKOKnQc6O9+9b0Wl6anD+tBC X-Received: by 2002:a05:6402:339:: with SMTP id q25mr11721840edw.80.1572905913621; Mon, 04 Nov 2019 14:18:33 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1572905913; cv=none; d=google.com; s=arc-20160816; b=lQN0hdAXK6oaX168Ujlc9Nz5EWKlk52+BNGuV9DUYHKfgvVESkG0b0beKhb3feFwcB Hu+caRfy30sT6v7O0KwV9kVahrD/hRZ027dcOIP+6BkSN7fy8s0e6h5pNJq6a9uWix9w PD7wiYnnRaECG+9YYeT6/lbE2GXc63rE4jXPP6h68GSrLivqsdEheMyLrybeRAze2ZWp MrXA/WxP5K0Sa44fzLNh3oDNoSe3DYcqMkqUlL+lyJNNtQVD/22tNst+aZksUJ43YPUG bjte2/8DzDRZgGmM+jbh7/i+XgUV0VDdjBBOEtU4ii4nP2zQR9Hb/0Fb/SdFCBwCbM6x mwBA== 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=5k6emONwf7csWECSdt1lTvWCA+gebC8fCYvAXD8s35g=; b=bDBjWJKYGhS8Wg7k6lmsOIxHsbWj620K0xIXN8hzv5jouzPBBNrUq5m/Ixou/txV2R 2YOuyJ9ay5rLIx4N4ZcT/4+B8WBcjFQXUaeNvxdvAQdr/phNnD7ayVIASGcnWOljqDyD etFtn2DDjWUJ6k8wzeTCDC9Jmz3Dq2/ANIp12qXv34qtEB7Yl4WYdkPZE0YltNWmNyzY P0kBmFHeUPY6/4tqSKrNVX3Up2TP3yP1JLLKHGocjA5RDvn9Y5gkibfROzy4m7o72cjI zW6dpI/0khpIUdEdVc1KMWdfL8D+/1JxzqSCRxQ8WLqCwi7kFhpwPt68/VQD3YwfJ2y5 Ze2A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=GTcSu2B3; 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 f31si8080216edf.75.2019.11.04.14.18.10; Mon, 04 Nov 2019 14:18:33 -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=GTcSu2B3; 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 S2389295AbfKDWCZ (ORCPT + 99 others); Mon, 4 Nov 2019 17:02:25 -0500 Received: from mail.kernel.org ([198.145.29.99]:60180 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2389120AbfKDWB4 (ORCPT ); Mon, 4 Nov 2019 17:01:56 -0500 Received: from localhost (6.204-14-84.ripe.coltfrance.com [84.14.204.6]) (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 C469F20650; Mon, 4 Nov 2019 22:01:54 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1572904915; bh=jMAEKlxyC3ermhSxITfVSGgBVe4mb/AT5OiGWW7wYCw=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=GTcSu2B324WH+JOpYT12V8xoKwjBIVkT9z+5syfn0FaJkfaKy+K+l7lRh2zxUY3dS rOPHKnjqXMY0mL6shLfpL/xTLdCwwTyFVmnHDgT6FxUJY86mwcyDn/p4eWjK7fcO1i pllWitW/jmRmkZMteJ6Dk8VVpeFkUR6ICh3IygAY= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Alan Stern , Oliver Neukum , Christoph Hellwig Subject: [PATCH 4.19 114/149] UAS: Revert commit 3ae62a42090f ("UAS: fix alignment of scatter/gather segments") Date: Mon, 4 Nov 2019 22:45:07 +0100 Message-Id: <20191104212144.343422897@linuxfoundation.org> X-Mailer: git-send-email 2.23.0 In-Reply-To: <20191104212126.090054740@linuxfoundation.org> References: <20191104212126.090054740@linuxfoundation.org> User-Agent: quilt/0.66 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 From: Alan Stern commit 1186f86a71130a7635a20843e355bb880c7349b2 upstream. Commit 3ae62a42090f ("UAS: fix alignment of scatter/gather segments"), copying a similar commit for usb-storage, attempted to solve a problem involving scatter-gather I/O and USB/IP by setting the virt_boundary_mask for mass-storage devices. However, it now turns out that the analogous change in usb-storage interacted badly with commit 09324d32d2a0 ("block: force an unlimited segment size on queues with a virt boundary"), which was added later. A typical error message is: ehci-pci 0000:00:13.2: swiotlb buffer is full (sz: 327680 bytes), total 32768 (slots), used 97 (slots) There is no longer any reason to keep the virt_boundary_mask setting in the uas driver. It was needed in the first place only for handling devices with a block size smaller than the maxpacket size and where the host controller was not capable of fully general scatter-gather operation (that is, able to merge two SG segments into a single USB packet). But: High-speed or slower connections never use a bulk maxpacket value larger than 512; The SCSI layer does not handle block devices with a block size smaller than 512 bytes; All the host controllers capable of SuperSpeed operation can handle fully general SG; Since commit ea44d190764b ("usbip: Implement SG support to vhci-hcd and stub driver") was merged, the USB/IP driver can also handle SG. Therefore all supported device/controller combinations should be okay with no need for any special virt_boundary_mask. So in order to head off potential problems similar to those affecting usb-storage, this patch reverts commit 3ae62a42090f. Signed-off-by: Alan Stern CC: Oliver Neukum CC: Acked-by: Christoph Hellwig Fixes: 3ae62a42090f ("UAS: fix alignment of scatter/gather segments") Link: https://lore.kernel.org/r/Pine.LNX.4.44L0.1910231132470.1878-100000@iolanthe.rowland.org Signed-off-by: Greg Kroah-Hartman --- drivers/usb/storage/uas.c | 20 -------------------- 1 file changed, 20 deletions(-) --- a/drivers/usb/storage/uas.c +++ b/drivers/usb/storage/uas.c @@ -796,30 +796,10 @@ static int uas_slave_alloc(struct scsi_d { struct uas_dev_info *devinfo = (struct uas_dev_info *)sdev->host->hostdata; - int maxp; sdev->hostdata = devinfo; /* - * We have two requirements here. We must satisfy the requirements - * of the physical HC and the demands of the protocol, as we - * definitely want no additional memory allocation in this path - * ruling out using bounce buffers. - * - * For a transmission on USB to continue we must never send - * a package that is smaller than maxpacket. Hence the length of each - * scatterlist element except the last must be divisible by the - * Bulk maxpacket value. - * If the HC does not ensure that through SG, - * the upper layer must do that. We must assume nothing - * about the capabilities off the HC, so we use the most - * pessimistic requirement. - */ - - maxp = usb_maxpacket(devinfo->udev, devinfo->data_in_pipe, 0); - blk_queue_virt_boundary(sdev->request_queue, maxp - 1); - - /* * The protocol has no requirements on alignment in the strict sense. * Controllers may or may not have alignment restrictions. * As this is not exported, we use an extremely conservative guess.