On Mon 11-02-19 11:06:54, Jason Gunthorpe wrote: > On Mon, Feb 11, 2019 at 09:22:58AM -0800, Dan Williams wrote: > > > I honestly don't like the idea that random subsystems can pin down > > file blocks as a side effect of gup on the result of mmap. Recall that > > it's not just RDMA that wants this guarantee. It seems safer to have > > the file be in an explicit block-allocation-immutable-mode so that the > > fallocate man page can describe this error case. Otherwise how would > > you describe the scenarios under which FALLOC_FL_PUNCH_HOLE fails? > > I rather liked CL's version of this - ftruncate/etc is simply racing > with a parallel pwrite - and it doesn't fail.
The problem is page pins are not really like pwrite(). They are more like mmap access. And that will just SIGBUS after truncate. So from user point of view I agree the result may not be that surprising (it would seem just as if somebody did additional pwrite) but from filesystem point of view it is very different and it would mean a special handling in lots of places. So I think that locking down the file before allowing gup_longterm() looks like a more viable alternative. Honza -- Jan Kara <j...@suse.com> SUSE Labs, CR