monitor: Prevent removing fd from set during init
If an fd is added to an fd set via the command line, and it is not referenced by another command line option (ie. -drive), then clean it up after QEMU initialization is complete. Signed-off-by: Corey Bryant <coreyb@linux.vnet.ibm.com> Reviewed-by: Eric Blake <eblake@redhat.com> Signed-off-by: Kevin Wolf <kwolf@redhat.com>
This commit is contained in:
		
							parent
							
								
									e446f70d54
								
							
						
					
					
						commit
						ebe52b592d
					
				|  | @ -2105,8 +2105,9 @@ static void monitor_fdset_cleanup(MonFdset *mon_fdset) | ||||||
|     MonFdsetFd *mon_fdset_fd_next; |     MonFdsetFd *mon_fdset_fd_next; | ||||||
| 
 | 
 | ||||||
|     QLIST_FOREACH_SAFE(mon_fdset_fd, &mon_fdset->fds, next, mon_fdset_fd_next) { |     QLIST_FOREACH_SAFE(mon_fdset_fd, &mon_fdset->fds, next, mon_fdset_fd_next) { | ||||||
|         if (mon_fdset_fd->removed || |         if ((mon_fdset_fd->removed || | ||||||
|                 (QLIST_EMPTY(&mon_fdset->dup_fds) && mon_refcount == 0)) { |                 (QLIST_EMPTY(&mon_fdset->dup_fds) && mon_refcount == 0)) && | ||||||
|  |                 runstate_is_running()) { | ||||||
|             close(mon_fdset_fd->fd); |             close(mon_fdset_fd->fd); | ||||||
|             g_free(mon_fdset_fd->opaque); |             g_free(mon_fdset_fd->opaque); | ||||||
|             QLIST_REMOVE(mon_fdset_fd, next); |             QLIST_REMOVE(mon_fdset_fd, next); | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	 Corey Bryant
						Corey Bryant