On Wed, Apr 1, 2015 at 11:08 AM, Al Viro <viro@xxxxxxxxxxxxxxxxxx> wrote: > > IOW, do you have a problem with obtaining a pointer to kernel page and > immediately shoving it into scatterlist? And just to clarify, yes I do. Why the f*ck wasn't it a struct page to begin with? And why do you think that a scatter-list is somehow "safe" and guarantees people won't be playing (invalid and completely broken) games with page counters etc that you cannot play for those things? If this is just about finit_module(), then dammit, why the f*ck does it even try to do zero-copy in the first place? But if that's the only use, maybe we can improve on kernel_read() to do some aio-read on the raw pages instead. And change the "info->hdr" thing to not just do a blind vmalloc, but actually do the page allocations and then do vmap_page_range() to map in the end result after IO etc. IOW, it's fine to do IO on 'struct page', but it should be *controlled* and you damn well need to _own_ that struct page and its lifetime, no just "look up random struct page from some kernel address". Linus -- To unsubscribe from this list: send the line "unsubscribe linux-fsdevel" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html