diff options
| author | Philippe Guibert <philippe.guibert@6wind.com> | 2017-12-11 15:21:04 +0100 |
|---|---|---|
| committer | Philippe Guibert <philippe.guibert@6wind.com> | 2017-12-13 16:54:10 +0100 |
| commit | e86b71f142b66ca0b74b5d392ea537fd3a30f33c (patch) | |
| tree | 11c35cdb12fdb7c6d8c1be379d0785cfae2df001 | |
| parent | db33b83b1d90458503987fd9f5f21c09c045e9a7 (diff) | |
zebra: ipv6 addressing uses netlink socket instead of standard ioctl
It is possible to configure IPv6 addresses from interfaces by using
netlink socket, intead of using standard sockets.
Signed-off-by: Philippe Guibert <philippe.guibert@6wind.com>
| -rw-r--r-- | zebra/if_netlink.c | 10 | ||||
| -rw-r--r-- | zebra/ioctl.c | 11 | ||||
| -rw-r--r-- | zebra/rt.h | 2 |
3 files changed, 22 insertions, 1 deletions
diff --git a/zebra/if_netlink.c b/zebra/if_netlink.c index af17e49231..f73506bf91 100644 --- a/zebra/if_netlink.c +++ b/zebra/if_netlink.c @@ -838,6 +838,16 @@ int kernel_address_delete_ipv4(struct interface *ifp, struct connected *ifc) return netlink_address(RTM_DELADDR, AF_INET, ifp, ifc); } +int kernel_address_add_ipv6 (struct interface *ifp, struct connected *ifc) +{ + return netlink_address (RTM_NEWADDR, AF_INET6, ifp, ifc); +} + +int kernel_address_delete_ipv6 (struct interface *ifp, struct connected *ifc) +{ + return netlink_address (RTM_DELADDR, AF_INET6, ifp, ifc); +} + int netlink_interface_addr(struct sockaddr_nl *snl, struct nlmsghdr *h, ns_id_t ns_id, int startup) { diff --git a/zebra/ioctl.c b/zebra/ioctl.c index 58118ce006..b5ed3ede97 100644 --- a/zebra/ioctl.c +++ b/zebra/ioctl.c @@ -78,6 +78,7 @@ int if_ioctl(u_long request, caddr_t buffer) return 0; } +#ifndef HAVE_NETLINK static int if_ioctl_ipv6(u_long request, caddr_t buffer) { int sock; @@ -108,6 +109,7 @@ static int if_ioctl_ipv6(u_long request, caddr_t buffer) } return 0; } +#endif /* ! HAVE_NETLINK */ /* * get interface metric @@ -460,10 +462,12 @@ struct in6_ifreq { int ifr6_ifindex; }; #endif /* _LINUX_IN6_H */ - /* Interface's address add/delete functions. */ int if_prefix_add_ipv6(struct interface *ifp, struct connected *ifc) { +#ifdef HAVE_NETLINK + return kernel_address_add_ipv6 (ifp, ifc); +#else /* ! HAVE_NETLINK */ int ret; struct prefix_ipv6 *p; struct in6_ifreq ifreq; @@ -479,10 +483,14 @@ int if_prefix_add_ipv6(struct interface *ifp, struct connected *ifc) ret = if_ioctl_ipv6(SIOCSIFADDR, (caddr_t)&ifreq); return ret; +#endif /* ! HAVE_NETLINK */ } int if_prefix_delete_ipv6(struct interface *ifp, struct connected *ifc) { +#ifdef HAVE_NETLINK + return kernel_address_delete_ipv6 (ifp, ifc); +#else /* ! HAVE_NETLINK */ int ret; struct prefix_ipv6 *p; struct in6_ifreq ifreq; @@ -498,6 +506,7 @@ int if_prefix_delete_ipv6(struct interface *ifp, struct connected *ifc) ret = if_ioctl_ipv6(SIOCDIFADDR, (caddr_t)&ifreq); return ret; +#endif /* ! HAVE_NETLINK */ } #else /* LINUX_IPV6 */ #ifdef HAVE_STRUCT_IN6_ALIASREQ diff --git a/zebra/rt.h b/zebra/rt.h index 6bbe69e983..cead9b8e60 100644 --- a/zebra/rt.h +++ b/zebra/rt.h @@ -74,6 +74,8 @@ extern void kernel_route_rib_pass_fail(struct prefix *p, extern int kernel_address_add_ipv4(struct interface *, struct connected *); extern int kernel_address_delete_ipv4(struct interface *, struct connected *); +extern int kernel_address_add_ipv6 (struct interface *, struct connected *); +extern int kernel_address_delete_ipv6 (struct interface *, struct connected *); extern int kernel_neigh_update(int, int, uint32_t, char *, int); extern int kernel_interface_set_master(struct interface *master, struct interface *slave); |
