virtio_mem是kernel的新feature,以virtio设备的形式给虚拟机热插拔内存。
kexec是可以在当前系统上替换运行kernel的feature。
当虚拟机中通过virtio_mem添加内存后再通过kexec去替换现有的kernel可能会产生一些意想不到的问题。因此需要让kexec避免使用这段新添加的内存。kexec有多种形式。主要是kexec_load和kexec_file_load两种。在第一中形式中,kexec会通过扫描/proc/iomem来准备new kernel的内存,通常这不会产生问题,因为virtio_mem插入的新内存在/proc/iomem中会以System RAM (virtio-mem)的形式出现,区别于“System RAM”。这是从用户态的角度避免了问题的产生。第二种形式下kenel中kexec的服务会扫描整个memblock,这会包含virtio_mem添加进来的内存。为了避免这种问题,kexec在扫描内存时应该忽略掉这段内存。
来自redhat的david已经提交了patch去fix这个问题。参见[v2,0/5] mm/memory_hotplug: full support for add_memory_driver_managed() with CONFIG_ARCH_KEEP_MEMBLOCK - Patchwork