Received: by 2002:a25:c205:0:0:0:0:0 with SMTP id s5csp915714ybf; Thu, 27 Feb 2020 01:55:44 -0800 (PST) X-Google-Smtp-Source: APXvYqyVG6SioEvj+1B8MXRmz9efCWWOfEOOc5nyCfSZToGrBYNKKB3dnKpGZmXyJMsaloI/kk3s X-Received: by 2002:aca:d954:: with SMTP id q81mr2582694oig.157.1582797344126; Thu, 27 Feb 2020 01:55:44 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1582797344; cv=none; d=google.com; s=arc-20160816; b=Xm+pjTwvOHhzLLoaHqouLPNSbs86MeipsilqRE2sTBwh57lYO+qb00sqZ6dHmtIM9G 941PcNXPsiskMvZ8ozJN0SvwImaZFsTIEIiCF4M6+movjmaGXoka6xH7Uq26yZslqiKN +YuRf+GvjXviXJpB59lburmUEX0vIq+wNCgGwLm/Mejq8rWnXnhdbPxXPKPLZoaKX/uu poot3TiPnoOZKS+6oionmdLtM4OTo7kfNnPs+cwRrjZQ0Q/0isJ0tLv4jdyXrzYLAb2R tmhzx95uSkj9VCIeN7ohPKVosZIKg9X/UHMMrtAzui5sxh2CIb4FxXno5nPIOH1D7W7j PmzA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date; bh=eyIj3y9K4ts+RjfTBb5eeJ9okrEmcBs1HQIusq4t414=; b=Tq+Xi2ce2Y8wn6d+s0BOkj9jJ+Ge5DR7w6+PA1TCYWd9Q96cGePXFQyxc8dm3KUjCp mYkJeqhs/JYFu4bA4bF1mlb7HjdxOf6WX+xgae13ozoxbOe38WyV5iiNwxrGLnGTVPUB EsPrXxwLzWzEPMXJ6Q+aTX+T+8QScUfYr8CCspojNoyqAINGsY7jT6lkEXVQvdk35u0B qUvTFHuMGKFgYSs12j5JAUBXRF6WdG27oK8P3EsS6EIGsMjA+z9W+A8NtxhBY5MaE9Pj 9Y8rQwYIywtPcSNJQZFNcta8gOXvRMoB2rlAZXP3G3r2BtI7jfpBX0Yk/zi1afeHsgYF G2Kg== ARC-Authentication-Results: i=1; mx.google.com; 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 a124si1017036oii.138.2020.02.27.01.55.31; Thu, 27 Feb 2020 01:55:44 -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; 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 S1728684AbgB0Jz0 (ORCPT + 99 others); Thu, 27 Feb 2020 04:55:26 -0500 Received: from foss.arm.com ([217.140.110.172]:47780 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728454AbgB0Jz0 (ORCPT ); Thu, 27 Feb 2020 04:55:26 -0500 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id B70461FB; Thu, 27 Feb 2020 01:55:25 -0800 (PST) Received: from arrakis.emea.arm.com (arrakis.cambridge.arm.com [10.1.196.71]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 4E7FB3F881; Thu, 27 Feb 2020 01:55:23 -0800 (PST) Date: Thu, 27 Feb 2020 09:55:21 +0000 From: Catalin Marinas To: Macpaul Lin Cc: Matthias Brugger , Shen Jing , Sasha Levin , John Stultz , Andrzej Pietrasiewicz , Vincent Pelletier , Jerry Zhang , linux-usb@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org, Mediatek WSD Upstream , CC Hwang , Loda Chou , Al Viro , stable@vger.kernel.org, andreyknvl@google.com, Peter Chen , Miles Chen Subject: Re: [PATCH v4] usb: gadget: f_fs: try to fix AIO issue under ARM 64 bit TAGGED mode Message-ID: <20200227095521.GA3281767@arrakis.emea.arm.com> References: <1582627315-21123-1-git-send-email-macpaul.lin@mediatek.com> <1582718512-28923-1-git-send-email-macpaul.lin@mediatek.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1582718512-28923-1-git-send-email-macpaul.lin@mediatek.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Feb 26, 2020 at 08:01:52PM +0800, Macpaul Lin wrote: > This issue was found when adbd trying to open functionfs with AIO mode. > Usually, we need to set "setprop sys.usb.ffs.aio_compat 0" to enable > adbd with AIO mode on Android. > > When adbd is opening functionfs, it will try to read 24 bytes at the > first read I/O control. If this reading has been failed, adbd will > try to send FUNCTIONFS_CLEAR_HALT to functionfs. When adbd is in AIO > mode, functionfs will be acted with asyncronized I/O path. After the > successful read transfer has been completed by gadget hardware, the > following series of functions will be called. > ffs_epfile_async_io_complete() -> ffs_user_copy_worker() -> > copy_to_iter() -> _copy_to_iter() -> copyout() -> > iterate_and_advance() -> iterate_iovec() > > Adding debug trace to these functions, it has been found that in > copyout(), access_ok() will check if the user space address is valid > to write. However if CONFIG_ARM64_TAGGED_ADDR_ABI is enabled, adbd > always passes user space address start with "0x3C" to gadget's AIO > blocks. This tagged address will cause access_ok() check always fail. > Which causes later calculation in iterate_iovec() turn zero. > Copyout() won't copy data to user space since the length to be copied > "v.iov_len" will be zero. Finally leads ffs_copy_to_iter() always return > -EFAULT, causes adbd cannot open functionfs and send > FUNCTIONFS_CLEAR_HALT. > > Signed-off-by: Macpaul Lin > Cc: Peter Chen > Cc: Catalin Marinas > Cc: Miles Chen > --- > Changes for v4: > - Abandon solution v3 by adding "TIF_TAGGED_ADDR" flag to gadget driver. > According to Catalin's suggestion, change the solution by untagging > user space address passed by AIO in gadget driver. Well, this was suggested in case you have a strong reason not to do the untagging in adbd. As I said, tagged pointers in user space were supported long before we introduced CONFIG_ARM64_TAGGED_ADDR_ABI. How did adb cope with such tagged pointers before? It was not supposed to pass them to the kernel. > diff --git a/drivers/usb/gadget/function/f_fs.c b/drivers/usb/gadget/function/f_fs.c > index ce1d023..192935f 100644 > --- a/drivers/usb/gadget/function/f_fs.c > +++ b/drivers/usb/gadget/function/f_fs.c > @@ -715,7 +715,20 @@ static void ffs_epfile_io_complete(struct usb_ep *_ep, struct usb_request *req) > > static ssize_t ffs_copy_to_iter(void *data, int data_len, struct iov_iter *iter) > { > - ssize_t ret = copy_to_iter(data, data_len, iter); > + ssize_t ret; > + > +#if defined(CONFIG_ARM64) > + /* > + * Replace tagged address passed by user space application before > + * copying. > + */ > + if (IS_ENABLED(CONFIG_ARM64_TAGGED_ADDR_ABI) && > + (iter->type == ITER_IOVEC)) { > + *(unsigned long *)&iter->iov->iov_base = > + (unsigned long)untagged_addr(iter->iov->iov_base); > + } > +#endif > + ret = copy_to_iter(data, data_len, iter); Here you should probably drop all the #ifdefs and IS_ENABLED checks since untagged_addr() is defined globally as a no-op (and overridden by arm64 and sparc). Please don't send another patch until we understand (a) whether this is a user-space problem to fix or (b) if we fix it in the kernel, is this the only/right place? If we settle for the in-kernel untagging, do we explicitly untag the addresses in such kernel threads or we default to TIF_TAGGED_ADDR for all kernel threads, in case they ever call use_mm() (or we could even hook something in use_mm() to set this TIF flag temporarily). Looking for feedback from the Android folk and a better analysis of the possible solution. -- Catalin