On Wed, Jul 14, 2021 at 01:23:03PM +0200, David Hildenbrand wrote: > #1 adds support for MADV_POPULATE_WRITE, #2 cleans up the code to avoid > global variables and prepare for concurrency and #3 makes os_mem_prealloc() > safe to be called from multiple threads concurrently. > > Details regarding MADV_POPULATE_WRITE can be found in introducing upstream > Linux commit 4ca9b3859dac ("mm/madvise: introduce > MADV_POPULATE_(READ|WRITE) to prefault page tables") and in the latest man > page patch [1].
Looking at that commit message, I see your caveat about POPULATE_WRITE used together with shared file mappings, causing an undesirable glut of dirty pages that needs to be flushed back to the underlying storage. Is this something we need to be concerned with for the hostmem-file.c implementation ? While it is mostly used to point to files on tmpfs or hugetlbfs, I think users do something point it to a plain file on a normal filesystem. So will we need to optimize to use the fallocate+POPULATE_READ combination at some point ? Regards, Daniel -- |: https://berrange.com -o- https://www.flickr.com/photos/dberrange :| |: https://libvirt.org -o- https://fstop138.berrange.com :| |: https://entangle-photo.org -o- https://www.instagram.com/dberrange :|