LKML Archive on lore.kernel.org help / color / mirror / Atom feed
From: Jann Horn <jannh@google.com> To: Peter Oskolkov <posk@google.com> Cc: Peter Oskolkov <posk@posk.io>, Peter Zijlstra <peterz@infradead.org>, Ingo Molnar <mingo@redhat.com>, Thomas Gleixner <tglx@linutronix.de>, linux-kernel@vger.kernel.org, linux-api@vger.kernel.org, Paul Turner <pjt@google.com>, Ben Segall <bsegall@google.com>, Andrei Vagin <avagin@google.com>, Thierry Delisle <tdelisle@uwaterloo.ca>, Andy Lutomirski <luto@kernel.org> Subject: Re: [PATCH 2/4 v0.5] sched/umcg: RFC: add userspace atomic helpers Date: Fri, 10 Sep 2021 01:13:17 +0200 [thread overview] Message-ID: <CAG48ez3dwtpjpSPKAheWzYcxrLvNeZ1=1OJQoiD3HWfYqs8H4Q@mail.gmail.com> (raw) In-Reply-To: <CAPNVh5eF6x8e4Lp=ZDOspwrbRYNOEyjeNW4WC99jCAZyeKLGww@mail.gmail.com> On Fri, Sep 10, 2021 at 12:10 AM Peter Oskolkov <posk@google.com> wrote: > On Thu, Sep 9, 2021 at 2:21 PM Jann Horn <jannh@google.com> wrote: > > > Option 1: as you suggest, pin pages holding struct umcg_task in sys_umcg_ctl; > > > > FWIW, there is a variant on this that might also be an option: > > > > You can create a new memory mapping from kernel code and stuff pages > > into it that were originally allocated as normal kernel pages. This is > > done in a bunch of places, e.g.: > > > > This has the advantage that it avoids pinning random pages that were > > originally allocated from ZONE_MOVABLE blocks. (Or pinning hugepages, > > or something like that.) > > The downsides are that it reduces userspace's freedom to place the > > UAPI structs wherever it wants (so userspace e.g. probably can't > > directly put the struct in thread-local storage, instead it has to > > store a pointer to the struct), and that you need to write a bunch of > > code to create the mapping and allocate slots in these pages for > > userspace threads. > > Thanks again, Jann! Why do you think using custom mapping like this is > preferable to doing just kzalloc(size, GFP_USER), or maybe > alloc_page(GFP_USER)? kzalloc() / alloc_page() just give you kernel memory allocations; but if you want userspace to be able to directly read/write that memory, you have to also map the same physical memory into the userspace pagetables somehow (at a separate address), which requires that you set up a VMA to tell the MM subsystem that that userspace address range is in use, and to specify what should happen when userspace calls memory management syscalls on it, or when pagefaults occur in it. Also, when allocating memory that should also be mapped into userspace, you have to use alloc_page(); memory from kzalloc() (in other words, slab memory) can't be mapped into userspace. (Technically it could be mapped into userspace with PFNMAP, but doing that would be weird.) > The documentation here > https://www.kernel.org/doc/html/latest/core-api/memory-allocation.html > says: > > "GFP_USER means that the allocated memory is not movable and it must > be directly accessible by the kernel", which sounds exactly what we > need here. If you look at the actual definitions of GFP_KERNEL and GFP_USER: #define GFP_KERNEL (__GFP_RECLAIM | __GFP_IO | __GFP_FS) #define GFP_USER (__GFP_RECLAIM | __GFP_IO | __GFP_FS | __GFP_HARDWALL) you can see that the only difference between them is the __GFP_HARDWALL flag, which is documented as follows: * %__GFP_HARDWALL enforces the cpuset memory allocation policy. So this basically just determines whether memory allocations fail if the task's memory allocation policy says they should fail because no memory is available on the right nodes. The choice of GFP flags doesn't influence whether userspace ends up getting access to the allocated memory. (On 32-bit machines, it does influence whether the kernel can easily access the memory though: Normal userspace anonymous memory is GFP_HIGHUSER, which includes __GFP_HIGHMEM, meaning that the returned page doesn't have to be mapped in the kernel's linear mapping, it can be in "high memory".)
next prev parent reply other threads:[~2021-09-09 23:13 UTC|newest] Thread overview: 27+ messages / expand[flat|nested] mbox.gz Atom feed top 2021-09-08 18:49 [PATCH 0/4 v0.5] sched/umcg: RFC UMCG patchset Peter Oskolkov 2021-09-08 18:49 ` [PATCH 1/4 v0.5] sched/umcg: add WF_CURRENT_CPU and externise ttwu Peter Oskolkov 2021-09-08 18:49 ` [PATCH 2/4 v0.5] sched/umcg: RFC: add userspace atomic helpers Peter Oskolkov 2021-09-08 23:38 ` Jann Horn 2021-09-09 1:16 ` Jann Horn 2021-09-09 19:06 ` Peter Oskolkov 2021-09-09 21:20 ` Jann Horn 2021-09-09 22:09 ` Peter Oskolkov 2021-09-09 23:13 ` Jann Horn [this message] 2021-09-14 16:52 ` Andy Lutomirski 2021-09-14 18:11 ` Peter Zijlstra 2021-09-14 18:40 ` Andy Lutomirski 2021-09-15 15:42 ` Peter Zijlstra 2021-09-15 16:50 ` Andy Lutomirski 2021-09-15 19:10 ` Peter Zijlstra 2021-09-14 8:07 ` Peter Zijlstra 2021-09-14 16:29 ` Peter Oskolkov 2021-09-14 18:04 ` Peter Zijlstra 2021-09-14 18:15 ` Peter Zijlstra 2021-09-14 18:29 ` Peter Oskolkov 2021-09-14 18:48 ` Peter Oskolkov 2021-09-08 18:49 ` [PATCH 3/4 v0.5] sched/umcg: RFC: implement UMCG syscalls Peter Oskolkov 2021-09-09 1:39 ` Jann Horn 2021-09-14 16:51 ` Peter Oskolkov 2021-09-08 18:49 ` [PATCH 4/4 v0.5] sched/umcg: add Documentation/userspace-api/umcg.rst Peter Oskolkov 2021-09-14 16:35 ` Tao Zhou 2021-09-14 16:57 ` Peter Oskolkov
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to='CAG48ez3dwtpjpSPKAheWzYcxrLvNeZ1=1OJQoiD3HWfYqs8H4Q@mail.gmail.com' \ --to=jannh@google.com \ --cc=avagin@google.com \ --cc=bsegall@google.com \ --cc=linux-api@vger.kernel.org \ --cc=linux-kernel@vger.kernel.org \ --cc=luto@kernel.org \ --cc=mingo@redhat.com \ --cc=peterz@infradead.org \ --cc=pjt@google.com \ --cc=posk@google.com \ --cc=posk@posk.io \ --cc=tdelisle@uwaterloo.ca \ --cc=tglx@linutronix.de \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: linkBe sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).