]> xenbits.xensource.com Git - people/jgross/xen.git/commitdiff
libxl: cleanup remaining backend xs dirs after driver domain
authorMarek Marczykowski-Górecki <marmarek@invisiblethingslab.com>
Sun, 8 Nov 2020 14:59:42 +0000 (15:59 +0100)
committerWei Liu <wl@xen.org>
Tue, 5 Jan 2021 12:33:55 +0000 (12:33 +0000)
When device is removed, backend domain (which may be a driver domain) is
responsible for removing backend entries from xenstore. But in case of
driver domain, it has no access to remove all of them - specifically the
directory named after frontend-id remains. This may accumulate enough to
exceed xenstore quote of the driver domain, breaking further devices.

Fix this by calling libxl__xs_path_cleanup() on the backend path from
libxl__device_destroy() in the toolstack domain too. Note
libxl__device_destroy() is called when the driver domain already removed
what it can (see device_destroy_be_watch_cb()->device_hotplug_done()).

Signed-off-by: Marek Marczykowski-Górecki <marmarek@invisiblethingslab.com>
Acked-by: Wei Liu <wl@xen.org>
tools/libs/light/libxl_device.c

index ac173a043d31f8103e9f5521beeb9dba5b1fb14c..36c4e41e4dc13cd364118d42118dafa296234619 100644 (file)
@@ -763,6 +763,12 @@ int libxl__device_destroy(libxl__gc *gc, libxl__device *dev)
              * from the backend path.
              */
             libxl__xs_path_cleanup(gc, t, be_path);
+        } else if (domid == LIBXL_TOOLSTACK_DOMID && !libxl_only) {
+            /*
+             * Then, toolstack domain is in charge of removing the parent
+             * directory if empty already.
+             */
+            libxl__xs_path_cleanup(gc, t, be_path);
         }
 
         rc = libxl__xs_transaction_commit(gc, &t);