[libvirt] [PATCH] libxl: add .domainInterfaceAddresses

Chun Yan Liu cyliu at suse.com
Mon May 16 10:06:47 UTC 2016



>>> On 5/14/2016 at 07:47 AM, in message <5736677D.8030209 at suse.com>, Jim Fehlig
<jfehlig at suse.com> wrote: 
> On 05/13/2016 12:21 AM, Chunyan Liu wrote: 
> > Add .domainInterfaceAddresses so that user can have a way to 
> > get domain interface address by 'virsh domifaddr'. Currently 
> > it only supports '--source lease'. 
> > 
> > Signed-off: Chunyan Liu <cyliu at suse.com> 
> > --- 
> >  src/libxl/libxl_driver.c | 140  
> +++++++++++++++++++++++++++++++++++++++++++++++ 
> >  1 file changed, 140 insertions(+) 
> > 
> > diff --git a/src/libxl/libxl_driver.c b/src/libxl/libxl_driver.c 
> > index 062d6f8..f2bd6fa 100644 
> > --- a/src/libxl/libxl_driver.c 
> > +++ b/src/libxl/libxl_driver.c 
> > @@ -5425,6 +5425,145 @@ static int libxlNodeGetSecurityModel(virConnectPtr  
> conn, 
> >      return 0; 
> >  } 
> >   
> > +static int 
> > +libxlGetDHCPInterfaces(virDomainPtr dom, 
> > +                       virDomainObjPtr vm, 
> > +                       virDomainInterfacePtr **ifaces) 
> > +{ 
> > +    int rv = -1; 
> > +    int n_leases = 0; 
> > +    size_t i, j; 
> > +    size_t ifaces_count = 0; 
> > +    virNetworkPtr network = NULL; 
> > +    char macaddr[VIR_MAC_STRING_BUFLEN]; 
> > +    virDomainInterfacePtr iface = NULL; 
> > +    virNetworkDHCPLeasePtr *leases = NULL; 
> > +    virDomainInterfacePtr *ifaces_ret = NULL; 
> > + 
> > +    if (!dom->conn->networkDriver || 
> > +        !dom->conn->networkDriver->networkGetDHCPLeases) { 
> > +        virReportError(VIR_ERR_INTERNAL_ERROR, "%s", 
> > +                       _("Network driver does not support DHCP lease  
> query")); 
> > +        return -1; 
> > +    } 
> > + 
> > +    for (i = 0; i < vm->def->nnets; i++) { 
> > +        if (vm->def->nets[i]->type != VIR_DOMAIN_NET_TYPE_NETWORK) 
> > +            continue; 
> > + 
> > +        virMacAddrFormat(&(vm->def->nets[i]->mac), macaddr); 
> > +        virObjectUnref(network); 
> > +        network = virNetworkLookupByName(dom->conn, 
> > +                                         vm->def->nets[i]->data.network.name); 
> > + 
> > +        if ((n_leases = virNetworkGetDHCPLeases(network, macaddr, 
> > +                                                &leases, 0)) < 0) 
> > +            goto error; 
> > + 
> > +        if (n_leases) { 
> > +            if (VIR_EXPAND_N(ifaces_ret, ifaces_count, 1) < 0) 
> > +                goto error; 
> > + 
> > +            if (VIR_ALLOC(ifaces_ret[ifaces_count - 1]) < 0) 
> > +                goto error; 
> > + 
> > +            iface = ifaces_ret[ifaces_count - 1]; 
> > +            /* Assuming each lease corresponds to a separate IP */ 
> > +            iface->naddrs = n_leases; 
> > + 
> > +            if (VIR_ALLOC_N(iface->addrs, iface->naddrs) < 0) 
> > +                goto error; 
> > + 
> > +            if (VIR_STRDUP(iface->name, vm->def->nets[i]->ifname) < 0) 
> > +                goto cleanup; 
> > + 
> > +            if (VIR_STRDUP(iface->hwaddr, macaddr) < 0) 
> > +                goto cleanup; 
> > +        } 
> > + 
> > +        for (j = 0; j < n_leases; j++) { 
> > +            virNetworkDHCPLeasePtr lease = leases[j]; 
> > +            virDomainIPAddressPtr ip_addr = &iface->addrs[j]; 
> > + 
> > +            if (VIR_STRDUP(ip_addr->addr, lease->ipaddr) < 0) 
> > +                goto cleanup; 
> > + 
> > +            ip_addr->type = lease->type; 
> > +            ip_addr->prefix = lease->prefix; 
> > +        } 
> > + 
> > +        for (j = 0; j < n_leases; j++) 
> > +            virNetworkDHCPLeaseFree(leases[j]); 
> > + 
> > +        VIR_FREE(leases); 
> > +    } 
> > + 
> > +    *ifaces = ifaces_ret; 
> > +    ifaces_ret = NULL; 
> > +    rv = ifaces_count; 
> > + 
> > + cleanup: 
> > +    virObjectUnref(network); 
> > +    if (leases) { 
> > +        for (i = 0; i < n_leases; i++) 
> > +            virNetworkDHCPLeaseFree(leases[i]); 
> > +    } 
> > +    VIR_FREE(leases); 
> > + 
> > +    return rv; 
> > + 
> > + error: 
> > +    if (ifaces_ret) { 
> > +        for (i = 0; i < ifaces_count; i++) 
> > +            virDomainInterfaceFree(ifaces_ret[i]); 
> > +    } 
> > +    VIR_FREE(ifaces_ret); 
> > + 
> > +    goto cleanup; 
> > +} 
>  
> It's unfortunate this is a copy-paste from the qemu driver. The code is not 
> trivial and any bug fixes in one copy could be missed in the other. A lot of  
> the 
> function is domain related, so probably can't be abstracted further to the 
> network code. Have you considered approaches that allow the drivers to share 
> this code?

Well, it can be extracted and placed in bridge_driver.c as networkGetDHCPInterfaces,
but I don't know if that is acceptable?

Chunyan

>  
> Regards, 
> Jim 
>  
>  





More information about the libvir-list mailing list