Received: by 2002:a05:6358:9144:b0:117:f937:c515 with SMTP id r4csp7408302rwr; Wed, 10 May 2023 07:56:30 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ7pVFmI3k7n/a+78UISaKYsRPishbPAEX8MnaEiq0xaUETdPzXyOi4X1NFqmLrHJx7Usf+x X-Received: by 2002:a17:90b:33cf:b0:247:2152:6391 with SMTP id lk15-20020a17090b33cf00b0024721526391mr17891584pjb.17.1683730590417; Wed, 10 May 2023 07:56:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1683730590; cv=none; d=google.com; s=arc-20160816; b=SLCqBMYSYeSrvYiQemZWBGpI+Du4nq2ZfCTNeEBfv5Dz4toJS/pPoG4hwECaeiYV71 MTvyvBhBH+VnSNPSF16cLn0kGnJcJdz0mVPbqlchFZmecqV9JmeeLPoXa4x8igNlUxzx OQoGEm3cB8vqDWR8BmwVyQX22OCIVUIbJKtL/mcLnwXid22dC9NPdaSROML6tAMvAuGL kyE/rS/dyGHh2AVM81MA2dYi/cptqe34FKz04xSbE06F3eeAlNe5pZzMvyJ9G0RJXOiM kSpaqh0b3ZK6igC/R90iXaiKjgq56O6RYKmetdf4FBSBiRN+rkvNsXubLG7PLkdes660 f6OA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date; bh=gYPlnmy0ABY+fJvzsCO33rUBqyqQlLoF0lL8PJBgGjI=; b=dJQA+PhrF3TQ5nSagAWgpJxAU7SbwjuhAMBmCyUcwCnbUqX0USqPu5RpNwk/0hR9KX Q5X/Y/VBhXI9Y1ofi0Vm8uXVRoNv53LPIq2cDculFNHgK74pjVEWLCQ89ZNBJc0n5KpO VDimFit3rbMF54XpF8P3gDUV3CHxa0R3pSgHYd9Ummr7MagnEU+9CjUrgbRKGEPYHZuw LX/EgAXuRiY6HKf575RfRs7ZSbIrjpxmVCcBJymdpGEC/PT15uH7vBJgWDylHBOOEuYN tHy/HWH0krQGrUJDJpHLfoMflsMq1aCIPMEzgVImDRevbkEjxxj3Hw1+JV0b8wmrucyX AKsw== 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 Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id m12-20020a633f0c000000b00528d30e6990si3996571pga.509.2023.05.10.07.56.15; Wed, 10 May 2023 07:56:30 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230100AbjEJOiv (ORCPT + 99 others); Wed, 10 May 2023 10:38:51 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:42768 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S237117AbjEJOiu (ORCPT ); Wed, 10 May 2023 10:38:50 -0400 Received: from netrider.rowland.org (netrider.rowland.org [192.131.102.5]) by lindbergh.monkeyblade.net (Postfix) with SMTP id 2EE0A268E for ; Wed, 10 May 2023 07:38:49 -0700 (PDT) Received: (qmail 623646 invoked by uid 1000); 10 May 2023 10:38:48 -0400 Date: Wed, 10 May 2023 10:38:48 -0400 From: Alan Stern To: Ruihan Li Cc: linux-mm@kvack.org, linux-usb@vger.kernel.org, linux-kernel@vger.kernel.org, Pasha Tatashin , David Hildenbrand , Matthew Wilcox , Andrew Morton , Christoph Hellwig , Greg Kroah-Hartman , stable@vger.kernel.org Subject: Re: [PATCH 2/4] usb: usbfs: Use consistent mmap functions Message-ID: References: <20230510085527.57953-1-lrh2000@pku.edu.cn> <20230510085527.57953-3-lrh2000@pku.edu.cn> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20230510085527.57953-3-lrh2000@pku.edu.cn> X-Spam-Status: No, score=-1.7 required=5.0 tests=BAYES_00, HEADER_FROM_DIFFERENT_DOMAINS,SPF_HELO_PASS,SPF_PASS, T_SCC_BODY_TEXT_LINE 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 On Wed, May 10, 2023 at 04:55:25PM +0800, Ruihan Li wrote: > When hcd->localmem_pool is non-null, it is used to allocate DMA memory. > In this case, the dma address will be properly returned (in dma_handle), > and dma_mmap_coherent should be used to map this memory into the user > space. However, the current implementation uses pfn_remap_range, which > is supposed to map normal pages (instead of DMA pages). > > Instead of repeating the logic in the memory allocation function, this > patch introduces a more robust solution. To address the previous issue, > this patch checks the type of allocated memory by testing whether > dma_handle is properly set. If dma_handle is properly returned, it means > some DMA pages are allocated and dma_mmap_coherent should be used to map > them. Otherwise, normal pages are allocated and pfn_remap_range should > be called. This ensures that the correct mmap functions are used > consistently, independently with logic details that determine which type > of memory gets allocated. > > Fixes: a0e710a7def4 ("USB: usbfs: fix mmap dma mismatch") > Cc: stable@vger.kernel.org > Signed-off-by: Ruihan Li > --- > drivers/usb/core/devio.c | 10 ++++++++-- > 1 file changed, 8 insertions(+), 2 deletions(-) > > diff --git a/drivers/usb/core/devio.c b/drivers/usb/core/devio.c > index b4cf9e860..5067030b7 100644 > --- a/drivers/usb/core/devio.c > +++ b/drivers/usb/core/devio.c > @@ -235,7 +235,7 @@ static int usbdev_mmap(struct file *file, struct vm_area_struct *vma) > size_t size = vma->vm_end - vma->vm_start; > void *mem; > unsigned long flags; > - dma_addr_t dma_handle; > + dma_addr_t dma_handle = DMA_MAPPING_ERROR; > int ret; > > ret = usbfs_increase_memory_usage(size + sizeof(struct usb_memory)); > @@ -265,7 +265,13 @@ static int usbdev_mmap(struct file *file, struct vm_area_struct *vma) > usbm->vma_use_count = 1; > INIT_LIST_HEAD(&usbm->memlist); > > - if (hcd->localmem_pool || !hcd_uses_dma(hcd)) { > + /* In DMA-unavailable cases, hcd_buffer_alloc_pages allocates > + * normal pages and assigns DMA_MAPPING_ERROR to dma_handle. Check > + * whether we are in such cases, and then use remap_pfn_range (or > + * dma_mmap_coherent) to map normal (or DMA) pages into the user > + * space, respectively. > + */ Another stylistic issue. For multi-line comments, the format we use is: /* * Blah, blah, blah * Blah, blah, blah */ Alan Stern