From: David Hildenbrand Date: Fri, 17 Dec 2021 13:46:08 +0000 (+0100) Subject: util/oslib-posix: Avoid creating a single thread with MADV_POPULATE_WRITE X-Git-Tag: v7.0.0-rc0~102^2~22 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=ac86e5c37df4963846d1a2e999696bb5031a99cd;p=thirdparty%2Fqemu.git util/oslib-posix: Avoid creating a single thread with MADV_POPULATE_WRITE Let's simplify the case when we only want a single thread and don't have to mess with signal handlers. Reviewed-by: Pankaj Gupta Reviewed-by: Daniel P. Berrangé Reviewed-by: Michal Privoznik Signed-off-by: David Hildenbrand Message-Id: <20211217134611.31172-6-david@redhat.com> Reviewed-by: Michael S. Tsirkin Signed-off-by: Michael S. Tsirkin --- diff --git a/util/oslib-posix.c b/util/oslib-posix.c index 67c08a425eb..efa4f96d562 100644 --- a/util/oslib-posix.c +++ b/util/oslib-posix.c @@ -564,6 +564,14 @@ static int touch_all_pages(char *area, size_t hpagesize, size_t numpages, } if (use_madv_populate_write) { + /* Avoid creating a single thread for MADV_POPULATE_WRITE */ + if (context.num_threads == 1) { + if (qemu_madvise(area, hpagesize * numpages, + QEMU_MADV_POPULATE_WRITE)) { + return -errno; + } + return 0; + } touch_fn = do_madv_populate_write_pages; } else { touch_fn = do_touch_pages;