vl.c: daemonize before guest memory allocation
memory allocated for guest before QEMU is daemonized and then mapped later in guest's address space after it is daemonized, leads to EPT violation and QEMU aborts. To avoid this and similar issues switch to daemonized mode early before applying/processing other options. Signed-off-by: Igor Mammedov <imammedo@redhat.com> Acked-by: Peter Crosthwaite <peter.crosthwaite@xilinx.com> Reviewed-by: Michael S. Tsirkin <mst@redhat.com> Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
This commit is contained in:
		
							parent
							
								
									a790f4ecc9
								
							
						
					
					
						commit
						2d9c2725f7
					
				
							
								
								
									
										4
									
								
								vl.c
								
								
								
								
							
							
						
						
									
										4
									
								
								vl.c
								
								
								
								
							| 
						 | 
				
			
			@ -3965,6 +3965,8 @@ int main(int argc, char **argv, char **envp)
 | 
			
		|||
    }
 | 
			
		||||
    loc_set_none();
 | 
			
		||||
 | 
			
		||||
    os_daemonize();
 | 
			
		||||
 | 
			
		||||
    if (qemu_init_main_loop()) {
 | 
			
		||||
        fprintf(stderr, "qemu_init_main_loop failed\n");
 | 
			
		||||
        exit(1);
 | 
			
		||||
| 
						 | 
				
			
			@ -4206,8 +4208,6 @@ int main(int argc, char **argv, char **envp)
 | 
			
		|||
    }
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
    os_daemonize();
 | 
			
		||||
 | 
			
		||||
    if (pid_file && qemu_create_pidfile(pid_file) != 0) {
 | 
			
		||||
        os_pidfile_error();
 | 
			
		||||
        exit(1);
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in New Issue