]> xenbits.xensource.com Git - libvirt.git/commitdiff
interface: add udevIfaceIsActive() to udev backend
authorDoug Goldstein <cardoe@cardoe.com>
Sat, 6 Oct 2012 19:20:29 +0000 (14:20 -0500)
committerEric Blake <eblake@redhat.com>
Tue, 9 Oct 2012 16:29:08 +0000 (10:29 -0600)
Add support to check if a specific interface is active by supporting the
following API function in the udev based virInterface backend:
* virConnectInterfaceIsActive()

src/interface/interface_backend_udev.c

index 75b9f1a6a9ff420b285fb19e3f9676ba84df557f..1cb6dfe17219898f7771addf83eb2377bae44e7c 100644 (file)
@@ -489,6 +489,35 @@ err:
     return ret;
 }
 
+static int
+udevIfaceIsActive(virInterfacePtr ifinfo)
+{
+    struct udev_iface_driver *driverState = ifinfo->conn->interfacePrivateData;
+    struct udev *udev = udev_ref(driverState->udev);
+    struct udev_device *dev;
+    int status;
+
+    dev = udev_device_new_from_subsystem_sysname(udev, "net",
+                                                 ifinfo->name);
+    if (!dev) {
+        virReportError(VIR_ERR_NO_INTERFACE,
+                       _("couldn't find interface named '%s'"),
+                       ifinfo->name);
+        status = -1;
+        goto cleanup;
+    }
+
+    /* Check if it's active or not */
+    status = STREQ(udev_device_get_sysattr_value(dev, "operstate"), "up");
+
+    udev_device_unref(dev);
+
+cleanup:
+    udev_unref(udev);
+
+    return status;
+}
+
 static virInterfaceDriver udevIfaceDriver = {
     "udev",
     .open = udevIfaceOpenInterface, /* 0.10.3 */
@@ -500,6 +529,7 @@ static virInterfaceDriver udevIfaceDriver = {
     .listAllInterfaces = udevIfaceListAllInterfaces, /* 0.10.3 */
     .interfaceLookupByName = udevIfaceLookupByName, /* 0.10.3 */
     .interfaceLookupByMACString = udevIfaceLookupByMACString, /* 0.10.3 */
+    .interfaceIsActive = udevIfaceIsActive, /* 0.10.3 */
 };
 
 int