1
0
mirror of https://gitlab.com/libvirt/libvirt.git synced 2025-01-26 14:03:49 +03:00

virnetdev allow to set peer address

Signed-off-by: Vasiliy Tolstov <v.tolstov@selfip.ru>
This commit is contained in:
Vasiliy Tolstov 2016-04-04 21:00:02 +00:00 committed by Daniel P. Berrange
parent 216650f14b
commit b3d069872c
4 changed files with 41 additions and 18 deletions

View File

@ -520,7 +520,7 @@ static int lxcContainerRenameAndEnableInterfaces(virDomainDefPtr vmDef,
VIR_DEBUG("Adding IP address '%s/%u' to '%s'", VIR_DEBUG("Adding IP address '%s/%u' to '%s'",
ipStr, ip->prefix, newname); ipStr, ip->prefix, newname);
if (virNetDevSetIPAddress(newname, &ip->address, prefix) < 0) { if (virNetDevSetIPAddress(newname, &ip->address, NULL, prefix) < 0) {
virReportError(VIR_ERR_SYSTEM_ERROR, virReportError(VIR_ERR_SYSTEM_ERROR,
_("Failed to set IP address '%s' on %s"), _("Failed to set IP address '%s' on %s"),
ipStr, newname); ipStr, newname);

View File

@ -1971,7 +1971,7 @@ networkAddAddrToBridge(virNetworkObjPtr network,
} }
if (virNetDevSetIPAddress(network->def->bridge, if (virNetDevSetIPAddress(network->def->bridge,
&ipdef->address, prefix) < 0) &ipdef->address, NULL, prefix) < 0)
return -1; return -1;
return 0; return 0;

View File

@ -1039,21 +1039,28 @@ virNetDevCreateNetlinkAddressMessage(int messageType,
const char *ifname, const char *ifname,
virSocketAddr *addr, virSocketAddr *addr,
unsigned int prefix, unsigned int prefix,
virSocketAddr *broadcast) virSocketAddr *broadcast,
virSocketAddr *peer)
{ {
struct nl_msg *nlmsg = NULL; struct nl_msg *nlmsg = NULL;
struct ifaddrmsg ifa; struct ifaddrmsg ifa;
unsigned int ifindex; unsigned int ifindex;
void *addrData = NULL; void *addrData = NULL;
void *peerData = NULL;
void *broadcastData = NULL; void *broadcastData = NULL;
size_t addrDataLen; size_t addrDataLen;
if (virNetDevGetIPAddressBinary(addr, &addrData, &addrDataLen) < 0) if (virNetDevGetIPAddressBinary(addr, &addrData, &addrDataLen) < 0)
return NULL; return NULL;
if (broadcast && virNetDevGetIPAddressBinary(broadcast, &broadcastData, if (peer && VIR_SOCKET_ADDR_VALID(peer)) {
&addrDataLen) < 0) if (virNetDevGetIPAddressBinary(peer, &peerData, &addrDataLen) < 0)
return NULL; return NULL;
} else if (broadcast) {
if (virNetDevGetIPAddressBinary(broadcast, &broadcastData,
&addrDataLen) < 0)
return NULL;
}
/* Get the interface index */ /* Get the interface index */
if ((ifindex = if_nametoindex(ifname)) == 0) if ((ifindex = if_nametoindex(ifname)) == 0)
@ -1078,12 +1085,15 @@ virNetDevCreateNetlinkAddressMessage(int messageType,
if (nla_put(nlmsg, IFA_LOCAL, addrDataLen, addrData) < 0) if (nla_put(nlmsg, IFA_LOCAL, addrDataLen, addrData) < 0)
goto buffer_too_small; goto buffer_too_small;
if (nla_put(nlmsg, IFA_ADDRESS, addrDataLen, addrData) < 0) if (peerData) {
goto buffer_too_small; if (nla_put(nlmsg, IFA_ADDRESS, addrDataLen, peerData) < 0)
goto buffer_too_small;
}
if (broadcastData && if (broadcastData) {
nla_put(nlmsg, IFA_BROADCAST, addrDataLen, broadcastData) < 0) if (nla_put(nlmsg, IFA_BROADCAST, addrDataLen, broadcastData) < 0)
goto buffer_too_small; goto buffer_too_small;
}
return nlmsg; return nlmsg;
@ -1098,6 +1108,7 @@ virNetDevCreateNetlinkAddressMessage(int messageType,
* virNetDevSetIPAddress: * virNetDevSetIPAddress:
* @ifname: the interface name * @ifname: the interface name
* @addr: the IP address (IPv4 or IPv6) * @addr: the IP address (IPv4 or IPv6)
* @peer: The IP address of peer (IPv4 or IPv6)
* @prefix: number of 1 bits in the netmask * @prefix: number of 1 bits in the netmask
* *
* Add an IP address to an interface. This function *does not* remove * Add an IP address to an interface. This function *does not* remove
@ -1108,6 +1119,7 @@ virNetDevCreateNetlinkAddressMessage(int messageType,
*/ */
int virNetDevSetIPAddress(const char *ifname, int virNetDevSetIPAddress(const char *ifname,
virSocketAddr *addr, virSocketAddr *addr,
virSocketAddr *peer,
unsigned int prefix) unsigned int prefix)
{ {
virSocketAddr *broadcast = NULL; virSocketAddr *broadcast = NULL;
@ -1116,9 +1128,8 @@ int virNetDevSetIPAddress(const char *ifname,
struct nlmsghdr *resp = NULL; struct nlmsghdr *resp = NULL;
unsigned int recvbuflen; unsigned int recvbuflen;
/* The caller needs to provide a correct address */ /* The caller needs to provide a correct address */
if (VIR_SOCKET_ADDR_FAMILY(addr) == AF_INET) { if (VIR_SOCKET_ADDR_FAMILY(addr) == AF_INET && !VIR_SOCKET_ADDR_VALID(peer)) {
/* compute a broadcast address if this is IPv4 */ /* compute a broadcast address if this is IPv4 */
if (VIR_ALLOC(broadcast) < 0) if (VIR_ALLOC(broadcast) < 0)
return -1; return -1;
@ -1129,7 +1140,7 @@ int virNetDevSetIPAddress(const char *ifname,
if (!(nlmsg = virNetDevCreateNetlinkAddressMessage(RTM_NEWADDR, ifname, if (!(nlmsg = virNetDevCreateNetlinkAddressMessage(RTM_NEWADDR, ifname,
addr, prefix, addr, prefix,
broadcast))) broadcast, peer)))
goto cleanup; goto cleanup;
if (virNetlinkCommand(nlmsg, &resp, &recvbuflen, 0, 0, if (virNetlinkCommand(nlmsg, &resp, &recvbuflen, 0, 0,
@ -1288,7 +1299,7 @@ int virNetDevClearIPAddress(const char *ifname,
if (!(nlmsg = virNetDevCreateNetlinkAddressMessage(RTM_DELADDR, ifname, if (!(nlmsg = virNetDevCreateNetlinkAddressMessage(RTM_DELADDR, ifname,
addr, prefix, addr, prefix,
NULL))) NULL, NULL)))
goto cleanup; goto cleanup;
if (virNetlinkCommand(nlmsg, &resp, &recvbuflen, 0, 0, if (virNetlinkCommand(nlmsg, &resp, &recvbuflen, 0, 0,
@ -1423,21 +1434,27 @@ virNetDevWaitDadFinish(virSocketAddrPtr *addrs, size_t count)
int virNetDevSetIPAddress(const char *ifname, int virNetDevSetIPAddress(const char *ifname,
virSocketAddr *addr, virSocketAddr *addr,
virSocketAddr *peer,
unsigned int prefix) unsigned int prefix)
{ {
virCommandPtr cmd = NULL; virCommandPtr cmd = NULL;
char *addrstr = NULL, *bcaststr = NULL; char *addrstr = NULL, *bcaststr = NULL, *peerstr = NULL;
virSocketAddr broadcast; virSocketAddr broadcast;
int ret = -1; int ret = -1;
if (!(addrstr = virSocketAddrFormat(addr))) if (!(addrstr = virSocketAddrFormat(addr)))
goto cleanup; goto cleanup;
if (VIR_SOCKET_ADDR_VALID(peer) && !(peerstr = virSocketAddrFormat(&peer)))
goto cleanup;
/* format up a broadcast address if this is IPv4 */ /* format up a broadcast address if this is IPv4 */
if ((VIR_SOCKET_ADDR_IS_FAMILY(addr, AF_INET)) && if (!peerstr && ((VIR_SOCKET_ADDR_IS_FAMILY(addr, AF_INET)) &&
((virSocketAddrBroadcastByPrefix(addr, prefix, &broadcast) < 0) || ((virSocketAddrBroadcastByPrefix(addr, prefix, &broadcast) < 0) ||
!(bcaststr = virSocketAddrFormat(&broadcast)))) { !(bcaststr = virSocketAddrFormat(&broadcast))))) {
goto cleanup; goto cleanup;
} }
# ifdef IFCONFIG_PATH # ifdef IFCONFIG_PATH
cmd = virCommandNew(IFCONFIG_PATH); cmd = virCommandNew(IFCONFIG_PATH);
virCommandAddArg(cmd, ifname); virCommandAddArg(cmd, ifname);
@ -1446,6 +1463,8 @@ int virNetDevSetIPAddress(const char *ifname,
else else
virCommandAddArg(cmd, "inet"); virCommandAddArg(cmd, "inet");
virCommandAddArgFormat(cmd, "%s/%u", addrstr, prefix); virCommandAddArgFormat(cmd, "%s/%u", addrstr, prefix);
if (peerstr)
virCommandAddArgList(cmd, "pointopoint", peerstr, NULL);
if (bcaststr) if (bcaststr)
virCommandAddArgList(cmd, "broadcast", bcaststr, NULL); virCommandAddArgList(cmd, "broadcast", bcaststr, NULL);
virCommandAddArg(cmd, "alias"); virCommandAddArg(cmd, "alias");
@ -1453,6 +1472,8 @@ int virNetDevSetIPAddress(const char *ifname,
cmd = virCommandNew(IP_PATH); cmd = virCommandNew(IP_PATH);
virCommandAddArgList(cmd, "addr", "add", NULL); virCommandAddArgList(cmd, "addr", "add", NULL);
virCommandAddArgFormat(cmd, "%s/%u", addrstr, prefix); virCommandAddArgFormat(cmd, "%s/%u", addrstr, prefix);
if (peerstr)
virCommandAddArgList(cmd, "peer", peerstr, NULL);
if (bcaststr) if (bcaststr)
virCommandAddArgList(cmd, "broadcast", bcaststr, NULL); virCommandAddArgList(cmd, "broadcast", bcaststr, NULL);
virCommandAddArgList(cmd, "dev", ifname, NULL); virCommandAddArgList(cmd, "dev", ifname, NULL);
@ -1465,6 +1486,7 @@ int virNetDevSetIPAddress(const char *ifname,
cleanup: cleanup:
VIR_FREE(addrstr); VIR_FREE(addrstr);
VIR_FREE(bcaststr); VIR_FREE(bcaststr);
VIR_FREE(peerstr);
virCommandFree(cmd); virCommandFree(cmd);
return ret; return ret;
} }

View File

@ -90,6 +90,7 @@ int virNetDevGetOnline(const char *ifname,
int virNetDevSetIPAddress(const char *ifname, int virNetDevSetIPAddress(const char *ifname,
virSocketAddr *addr, virSocketAddr *addr,
virSocketAddr *peer,
unsigned int prefix) unsigned int prefix)
ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_RETURN_CHECK; ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_RETURN_CHECK;
int virNetDevAddRoute(const char *ifname, int virNetDevAddRoute(const char *ifname,