[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Xen-devel] libxl: spawning qemu while files are open



I ran into an issue when attempting to resume an HVM guest using the libxl_domain_create_restore call. We are using this in the libxl-version of xenopsd, XenServer's domain manager.

 

The VM's suspend image is stored on a disk that is mounted in dom0 for the duration of the restore operation, and unmounted afterwards. Xenopsd opens the suspend-image file, and hands the file descriptor over to libxl, as a parameter of libxl_domain_create_restore. Libxl successfully created the domain, loaded the memory image, and spawned qemu. However, the following attempt to unmount the disk that hold the suspend image failed.

 

It turned out that qemu was holding on to the fd of the suspend-image, which blocked the umount. Our theory is that when libxl forks and executes the qemu process, qemu inherits all currentl open fds in the xenopsd process, and never gives them away anymore.

 

We could solve this by opening the suspend-image file in xenopsd using the O_CLOEXEC flag, causing the file to be closed when executing qemu. However, we are worried that this behaviour may still cause trouble in multi-threaded programs such as xenopsd, unless all files it ever opens are opened with O_CLOEXEC, which is easily forgotten.

 

Would it be possible for libxl to spawn qemu in such a way that it won't inherit open files?

 

Cheers,

Rob

_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxx
http://lists.xen.org/xen-devel

 


Rackspace

Lists.xenproject.org is hosted with RackSpace, monitoring our
servers 24x7x365 and backed by RackSpace's Fanatical Support®.