linux-mm.kvack.org archive mirror
 help / color / mirror / Atom feed
* [RFC] theoretical race between memory hotplug and pfn iterator
@ 2015-12-21  3:15 Joonsoo Kim
  2015-12-21  7:00 ` Zhu Guihua
  0 siblings, 1 reply; 5+ messages in thread
From: Joonsoo Kim @ 2015-12-21  3:15 UTC (permalink / raw)
  To: linux-mm
  Cc: Andrew Morton, Gu Zheng, Tang Chen, Naoya Horiguchi, Toshi Kani,
	Mel Gorman, Vlastimil Babka, linux-kernel

Hello, memory-hotplug folks.

I found theoretical problems between memory hotplug and pfn iterator.
For example, pfn iterator works something like below.

for (pfn = zone_start_pfn; pfn < zone_end_pfn; pfn++) {
        if (!pfn_valid(pfn))
                continue;

        page = pfn_to_page(pfn);
        /* Do whatever we want */
}

Sequence of hotplug is something like below.

1) add memmap (after then, pfn_valid will return valid)
2) memmap_init_zone()

So, if pfn iterator runs between 1) and 2), it could access
uninitialized page information.

This problem could be solved by re-ordering initialization steps.

Hot-remove also has a problem. If memory is hot-removed after
pfn_valid() succeed in pfn iterator, access to page would cause NULL
deference because hot-remove frees corresponding memmap. There is no
guard against free in any pfn iterators.

This problem can be solved by inserting get_online_mems() in all pfn
iterators but this looks error-prone for future usage. Another idea is
that delaying free corresponding memmap until synchronization point such
as system suspend. It will guarantee that there is no running pfn
iterator. Do any have a better idea?

Btw, I tried to memory-hotremove with QEMU 2.5.5 but it didn't work. I
followed sequences in doc/memory-hotplug. Do you have any comment on this?

Thanks.

--
To unsubscribe, send a message with 'unsubscribe linux-mm' in
the body to majordomo@kvack.org.  For more info on Linux MM,
see: http://www.linux-mm.org/ .
Don't email: <a href=mailto:"dont@kvack.org"> email@kvack.org </a>

^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2015-12-21 12:09 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2015-12-21  3:15 [RFC] theoretical race between memory hotplug and pfn iterator Joonsoo Kim
2015-12-21  7:00 ` Zhu Guihua
2015-12-21  7:17   ` Joonsoo Kim
2015-12-21  8:00     ` Zhu Guihua
2015-12-21 12:09       ` Joonsoo Kim

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox