• Daniel Vetter's avatar
    mm/frame-vector: Use FOLL_LONGTERM · 04769cb1
    Daniel Vetter authored
    This is used by media/videbuf2 for persistent dma mappings, not just
    for a single dma operation and then freed again, so needs
    FOLL_LONGTERM.
    
    Unfortunately current pup_locked doesn't support FOLL_LONGTERM due to
    locking issues. Rework the code to pull the pup path out from the
    mmap_sem critical section as suggested by Jason.
    
    By relying entirely on the vma checks in pin_user_pages and follow_pfn
    (for vm_flags and vma_is_fsdax) we can also streamline the code a lot.
    
    Note that pin_user_pages_fast is a safe replacement despite the
    seeming lack of checking for vma->vm_flasg & (VM_IO | VM_PFNMAP). Such
    ptes are marked with pte_mkspecial (which pup_fast rejects in the
    fastpath), and only architectures supporting that support the
    pin_user_pages_fast fastpath.
    Signed-off-by: default avatarDaniel Vetter <daniel.vetter@intel.com>
    Cc: Christoph Hellwig <hch@infradead.org>
    Cc: Jason Gunthorpe <jgg@ziepe.ca>
    Cc: Pawel Osciak <pawel@osciak.com>
    Cc: Marek Szyprowski <m.szyprowski@samsung.com>
    Cc: Kyungmin Park <kyungmin.park@samsung.com>
    Cc: Tomasz Figa <tfiga@chromium.org>
    Cc: Mauro Carvalho Chehab <mchehab@kernel.org>
    Cc: Andrew Morton <akpm@linux-foundation.org>
    Cc: John Hubbard <jhubbard@nvidia.com>
    Cc: Jérôme Glisse <jglisse@redhat.com>
    Cc: Jan Kara <jack@suse.cz>
    Cc: Dan Williams <dan.j.williams@intel.com>
    Cc: linux-mm@kvack.org
    Cc: linux-arm-kernel@lists.infradead.org
    Cc: linux-samsung-soc@vger.kernel.org
    Cc: linux-media@vger.kernel.org
    Signed-off-by: default avatarDaniel Vetter <daniel.vetter@ffwll.ch>
    Link: https://patchwork.freedesktop.org/patch/msgid/20201127164131.2244124-6-daniel.vetter@ffwll.ch
    04769cb1
frame_vector.c 5.86 KB