qemu源码解析【07】qemu启动初始化流程
2.7.3 分配虚拟机内存
void cpu_exec_init_all(void)
{
qemu_mutex_init(&ram_list.mutex);
finalize_target_page_bits();
io_mem_init();
memory_map_init();
qemu_mutex_init(&map_client_list_lock);
}
- 先在memory分配的io_mem_init()函数处下个断点,一路debug下来,发现最后进了system/memory.c中的memory_region_initfn(),初始化了一些变量,和指针函数,没啥实质性的内存分配。看了以下system/memory.c里面的其他函数,应该是具体分配的时候,去调用g_malloc()这样的glib库函数实现分配具体内存:

- 然后再进memory_map_init()函数,这里面是一些内存的实际分配环节。有点复杂,查了些资料,大概是为虚拟机从host分配一些虚拟内存,然后作为qemu guest的物理内存使用
- 这套逻辑我工作中经常接触,做芯片CModel仿真的时