Received: by 2002:a05:6358:d09b:b0:dc:cd0c:909e with SMTP id jc27csp14475197rwb; Mon, 28 Nov 2022 01:09:39 -0800 (PST) X-Google-Smtp-Source: AA0mqf71qRi6EEMhXyj/lgmpzksYmRjOxtb0ad0GHburCaT5WzLmBdLWt1aKhP/E+2N4Lxge6Byy X-Received: by 2002:a17:906:9da4:b0:7ae:100a:8dc0 with SMTP id fq36-20020a1709069da400b007ae100a8dc0mr40437560ejc.424.1669626579573; Mon, 28 Nov 2022 01:09:39 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1669626579; cv=none; d=google.com; s=arc-20160816; b=Mp819XvaZOsMd3Km8P1lzUui7px4HNZGCqQugRAvaRAVXnOr5vnuA9FXnMGrvYUZW3 iuCdBTxc3L//uIVsf6t88qTPzJCAiRVO5UeQhUAx5k92LDvPyXpiRoKOEkILwqTSIYnR 4pHNI/v7nNF+JiJVAYM5hg1MhVmTTI0hJx4sQKmFqUfrk/p/GZesK9iXHZwyCuKiAW2+ BVoPgFOf7vOJZKSAiJPZ9TB2FLPFxVi5b8gNYNFxIfL2ZzpvaQ99aLlxH7YpvK6K5Leh 4eFTZUR9kM5kJmOmJoTlVrRUzpg1+WzFTFqSLOfA0PQ3qEYr4E+fNr2BgnNhlPqgl+sY dvBg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature; bh=iRo5DYRndKCx9sGSXzsZxPr88K/zqtuLTLl1O32mcFE=; b=Fh74Pxq/64epOqDmSSkQgayl/VQQmHvMzRS3+zPDWuQdoM5vnnrn3wKwLX+dM1Pyk2 Gv+7Vf21OOREZBr/msXfkEmFr2rD1fMkhMp/UhgPajPfHFIOCcXmksVfZhmelav2ajN3 cu+P+ZqCFoMdceNdtuvg33/YXdzBPkyxGdg2EmCgprp7WEKb0SgJroWOrcLb8eWQQxyP JX7/hk1tsmrqbPtMHQJj+n2doum6qBcFR8db2TdksAYAwnoNe/Q5GzZ2dzFzKYTWiSEg +ZDXJlmYCxSqpHZzFN+Qe5IV1bDadrFDkuGFUmgzSeS8k40tbkHdwvR+mFhUpWYSEvtr BC8Q== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=XOKEpyQa; 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=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id ho16-20020a1709070e9000b007bd6264c2dbsi6160050ejc.28.2022.11.28.01.09.19; Mon, 28 Nov 2022 01:09:39 -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; dkim=pass header.i=@chromium.org header.s=google header.b=XOKEpyQa; 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=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230225AbiK1I6K (ORCPT + 83 others); Mon, 28 Nov 2022 03:58:10 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33088 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229680AbiK1I6H (ORCPT ); Mon, 28 Nov 2022 03:58:07 -0500 Received: from mail-ed1-x52c.google.com (mail-ed1-x52c.google.com [IPv6:2a00:1450:4864:20::52c]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id C71D05FA8 for ; Mon, 28 Nov 2022 00:58:06 -0800 (PST) Received: by mail-ed1-x52c.google.com with SMTP id b8so14444171edf.11 for ; Mon, 28 Nov 2022 00:58:06 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=cc:to:subject:message-id:date:from:in-reply-to:references :mime-version:from:to:cc:subject:date:message-id:reply-to; bh=iRo5DYRndKCx9sGSXzsZxPr88K/zqtuLTLl1O32mcFE=; b=XOKEpyQaMH8DtU4ghoeum5LLPSyZKKSeL9ukREYJEhE5Pet4ng53VcgxrNVIVOiN3z qM9BvX69vBwubqV7gI66eEPgV5zFoyHzRXj6Y/c3o1k6BVytkDV23dS8hW9lN3urO8Q7 YycsWj1XAMOHph6L7v2J+A4VSfKO7i7WBHunk= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=cc:to:subject:message-id:date:from:in-reply-to:references :mime-version:x-gm-message-state:from:to:cc:subject:date:message-id :reply-to; bh=iRo5DYRndKCx9sGSXzsZxPr88K/zqtuLTLl1O32mcFE=; b=3rrNxfZZIr/4ivzzbVMww71Q/PEmnu8kVRlzhc7QnUIEZpg3Pl1wJmn7QFukcXRpOS PK+Z4EUOclHKhMPP4kcd1e8zXawnopnLKwE4v6JX/WXMV/98F5NjdiQcbPkMdknQDbNj r3iC4JEfrif89MsKjeaxbdwEMn9VTntAPC1eC/Ixm3TJ/Ao/O36PHuJpoYPMaiQUrn5+ f+ij+JDP8a0C60Rq4DMW9hsAEfZGoFCZzgpQkK803bcE5JAcaCr/L6V5PONhIZaWUDtI chnRRefka/IwjDyIChHSP7JfW6HiUlIxO9dpmEjZoY9rJq+k2mLGRvAlLIFCRrJ/my8R my3Q== X-Gm-Message-State: ANoB5plNkXp1uTeWq4rHbY9lyVreh/8a2b8wO1hDy6+eQnNowvqsQUVg +PuFdUzxdjTyB9wRzV3sLnu0MbHhO4DGpw== X-Received: by 2002:a05:6402:528d:b0:468:dc9:ec08 with SMTP id en13-20020a056402528d00b004680dc9ec08mr31444929edb.17.1669625885162; Mon, 28 Nov 2022 00:58:05 -0800 (PST) Received: from mail-ed1-f42.google.com (mail-ed1-f42.google.com. [209.85.208.42]) by smtp.gmail.com with ESMTPSA id c4-20020a056402100400b0046b1d63cfc1sm1497395edu.88.2022.11.28.00.58.04 for (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Mon, 28 Nov 2022 00:58:04 -0800 (PST) Received: by mail-ed1-f42.google.com with SMTP id s5so14426456edc.12 for ; Mon, 28 Nov 2022 00:58:04 -0800 (PST) X-Received: by 2002:aa7:db98:0:b0:46a:d57:d9d0 with SMTP id u24-20020aa7db98000000b0046a0d57d9d0mr25216647edt.113.1669625884043; Mon, 28 Nov 2022 00:58:04 -0800 (PST) MIME-Version: 1.0 References: <20221116102659.70287-1-david@redhat.com> <20221116102659.70287-17-david@redhat.com> <81fb0fa3-2e06-b765-56ac-a7d981194e59@redhat.com> <08b65ac6-6786-1080-18f8-d2be109c85fc@xs4all.nl> <9d0bf98a-3d6a-1082-e992-1338e1525935@redhat.com> In-Reply-To: <9d0bf98a-3d6a-1082-e992-1338e1525935@redhat.com> From: Tomasz Figa Date: Mon, 28 Nov 2022 17:57:51 +0900 X-Gmail-Original-Message-ID: Message-ID: Subject: Re: [PATCH mm-unstable v1 16/20] mm/frame-vector: remove FOLL_FORCE usage To: David Hildenbrand Cc: Hans Verkuil , linux-kernel@vger.kernel.org, Andrew Morton , x86@kernel.org, linux-alpha@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-ia64@vger.kernel.org, linux-mips@vger.kernel.org, linuxppc-dev@lists.ozlabs.org, sparclinux@vger.kernel.org, linux-um@lists.infradead.org, etnaviv@lists.freedesktop.org, dri-devel@lists.freedesktop.org, linux-samsung-soc@vger.kernel.org, linux-rdma@vger.kernel.org, linux-media@vger.kernel.org, linux-fsdevel@vger.kernel.org, linux-mm@kvack.org, linux-perf-users@vger.kernel.org, linux-security-module@vger.kernel.org, linux-kselftest@vger.kernel.org, Linus Torvalds , Jason Gunthorpe , John Hubbard , Peter Xu , Greg Kroah-Hartman , Andrea Arcangeli , Hugh Dickins , Nadav Amit , Vlastimil Babka , Matthew Wilcox , Mike Kravetz , Muchun Song , Shuah Khan , Lucas Stach , David Airlie , Oded Gabbay , Arnd Bergmann , Christoph Hellwig , Alex Williamson , Marek Szyprowski , Mauro Carvalho Chehab Content-Type: text/plain; charset="UTF-8" X-Spam-Status: No, score=-2.1 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_NONE, SPF_HELO_NONE,SPF_PASS autolearn=unavailable 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 Mon, Nov 28, 2022 at 5:19 PM David Hildenbrand wrote: > > On 28.11.22 09:17, Hans Verkuil wrote: > > Hi David, > > > > On 27/11/2022 11:35, David Hildenbrand wrote: > >> On 16.11.22 11:26, David Hildenbrand wrote: > >>> FOLL_FORCE is really only for ptrace access. According to commit > >>> 707947247e95 ("media: videobuf2-vmalloc: get_userptr: buffers are always > >>> writable"), get_vaddr_frames() currently pins all pages writable as a > >>> workaround for issues with read-only buffers. > >>> > >>> FOLL_FORCE, however, seems to be a legacy leftover as it predates > >>> commit 707947247e95 ("media: videobuf2-vmalloc: get_userptr: buffers are > >>> always writable"). Let's just remove it. > >>> > >>> Once the read-only buffer issue has been resolved, FOLL_WRITE could > >>> again be set depending on the DMA direction. > >>> > >>> Cc: Hans Verkuil > >>> Cc: Marek Szyprowski > >>> Cc: Tomasz Figa > >>> Cc: Marek Szyprowski > >>> Cc: Mauro Carvalho Chehab > >>> Signed-off-by: David Hildenbrand > >>> --- > >>> drivers/media/common/videobuf2/frame_vector.c | 2 +- > >>> 1 file changed, 1 insertion(+), 1 deletion(-) > >>> > >>> diff --git a/drivers/media/common/videobuf2/frame_vector.c b/drivers/media/common/videobuf2/frame_vector.c > >>> index 542dde9d2609..062e98148c53 100644 > >>> --- a/drivers/media/common/videobuf2/frame_vector.c > >>> +++ b/drivers/media/common/videobuf2/frame_vector.c > >>> @@ -50,7 +50,7 @@ int get_vaddr_frames(unsigned long start, unsigned int nr_frames, > >>> start = untagged_addr(start); > >>> ret = pin_user_pages_fast(start, nr_frames, > >>> - FOLL_FORCE | FOLL_WRITE | FOLL_LONGTERM, > >>> + FOLL_WRITE | FOLL_LONGTERM, > >>> (struct page **)(vec->ptrs)); > >>> if (ret > 0) { > >>> vec->got_ref = true; > >> > >> > >> Hi Andrew, > >> > >> see the discussion at [1] regarding a conflict and how to proceed with > >> upstreaming. The conflict would be easy to resolve, however, also > >> the patch description doesn't make sense anymore with [1]. > > > > Might it be easier and less confusing if you post a v2 of this series > > with my patch first? That way it is clear that 1) my patch has to come > > first, and 2) that it is part of a single series and should be merged > > by the mm subsystem. > > > > Less chances of things going wrong that way. > > > > Just mention in the v2 cover letter that the first patch was added to > > make it easy to backport that fix without being hampered by merge > > conflicts if it was added after your frame_vector.c patch. > > Yes, that's the way I would naturally do, it, however, Andrew prefers > delta updates for minor changes. > > @Andrew, whatever you prefer! > > Thanks! > However you folks proceed with taking this patch, feel free to add my Acked-by. Thanks! Best regards, Tomasz > -- > Thanks, > > David / dhildenb >