From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mail-ot0-f200.google.com (mail-ot0-f200.google.com [74.125.82.200]) by kanga.kvack.org (Postfix) with ESMTP id 6F7006B0003 for ; Sun, 17 Jun 2018 16:10:06 -0400 (EDT) Received: by mail-ot0-f200.google.com with SMTP id y18-v6so9112691otg.14 for ; Sun, 17 Jun 2018 13:10:06 -0700 (PDT) Received: from mail-sor-f65.google.com (mail-sor-f65.google.com. [209.85.220.65]) by mx.google.com with SMTPS id j47-v6sor5219017ota.146.2018.06.17.13.10.05 for (Google Transport Security); Sun, 17 Jun 2018 13:10:05 -0700 (PDT) MIME-Version: 1.0 In-Reply-To: <20180617200432.krw36wrcwidb25cj@ziepe.ca> References: <20180617012510.20139-1-jhubbard@nvidia.com> <20180617012510.20139-3-jhubbard@nvidia.com> <20180617200432.krw36wrcwidb25cj@ziepe.ca> From: Dan Williams Date: Sun, 17 Jun 2018 13:10:04 -0700 Message-ID: Subject: Re: [PATCH 2/2] mm: set PG_dma_pinned on get_user_pages*() Content-Type: text/plain; charset="UTF-8" Sender: owner-linux-mm@kvack.org List-ID: To: Jason Gunthorpe Cc: john.hubbard@gmail.com, Matthew Wilcox , Michal Hocko , Christopher Lameter , Jan Kara , Linux MM , LKML , linux-rdma , John Hubbard , Christoph Hellwig On Sun, Jun 17, 2018 at 1:04 PM, Jason Gunthorpe wrote: > On Sun, Jun 17, 2018 at 12:53:04PM -0700, Dan Williams wrote: >> > diff --git a/mm/rmap.c b/mm/rmap.c >> > index 6db729dc4c50..37576f0a4645 100644 >> > +++ b/mm/rmap.c >> > @@ -1360,6 +1360,8 @@ static bool try_to_unmap_one(struct page *page, struct vm_area_struct *vma, >> > flags & TTU_SPLIT_FREEZE, page); >> > } >> > >> > + if (PageDmaPinned(page)) >> > + return false; >> > /* >> > * We have to assume the worse case ie pmd for invalidation. Note that >> > * the page can not be free in this function as call of try_to_unmap() >> >> We have a similiar problem with DAX and the conclusion we came to is >> that it is not acceptable for userspace to arbitrarily block kernel >> actions. The conclusion there was: 'wait' if the DMA is transient, and >> 'revoke' if the DMA is long lived, or otherwise 'block' long-lived DMA >> if a revocation mechanism is not available. > > This might be the right answer for certain things, but it shouldn't be > the immediate reaction to everthing. There are many user APIs that > block kernel actions and hold kernel resources. > > IMHO, there should be an identifiable objection, eg is blocking going > to create a DOS, dead-lock, insecurity, etc? I believe kernel behavior regression is a primary concern as now fallocate() and truncate() can randomly fail where they didn't before.