summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--usr.sbin/ldpd/interface.c3
-rw-r--r--usr.sbin/ldpd/kroute.c15
-rw-r--r--usr.sbin/ldpd/ldpd.c11
-rw-r--r--usr.sbin/ldpd/ldpd.conf.510
-rw-r--r--usr.sbin/ldpd/ldpd.h7
-rw-r--r--usr.sbin/ldpd/parse.y34
-rw-r--r--usr.sbin/ldpd/printconf.c3
7 files changed, 67 insertions, 16 deletions
diff --git a/usr.sbin/ldpd/interface.c b/usr.sbin/ldpd/interface.c
index 7988448bd68..eb928356256 100644
--- a/usr.sbin/ldpd/interface.c
+++ b/usr.sbin/ldpd/interface.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: interface.c,v 1.48 2016/09/03 16:07:08 renato Exp $ */
+/* $OpenBSD: interface.c,v 1.49 2017/03/03 23:36:06 renato Exp $ */
/*
* Copyright (c) 2013, 2016 Renato Westphal <renato@openbsd.org>
@@ -61,6 +61,7 @@ if_new(struct kif *kif)
/* get index and flags */
LIST_INIT(&iface->addr_list);
iface->ifindex = kif->ifindex;
+ iface->rdomain = kif->rdomain;
iface->flags = kif->flags;
iface->linkstate = kif->link_state;
iface->if_type = kif->if_type;
diff --git a/usr.sbin/ldpd/kroute.c b/usr.sbin/ldpd/kroute.c
index fefc57af341..a65e039fa8e 100644
--- a/usr.sbin/ldpd/kroute.c
+++ b/usr.sbin/ldpd/kroute.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: kroute.c,v 1.62 2017/01/20 12:19:18 benno Exp $ */
+/* $OpenBSD: kroute.c,v 1.63 2017/03/03 23:36:06 renato Exp $ */
/*
* Copyright (c) 2015, 2016 Renato Westphal <renato@openbsd.org>
@@ -43,6 +43,7 @@ struct {
int fd;
int ioctl_fd;
struct event ev;
+ unsigned int rdomain;
} kr_state;
struct kroute_node {
@@ -143,13 +144,14 @@ kif_init(void)
}
int
-kr_init(int fs)
+kr_init(int fs, unsigned int rdomain)
{
int opt = 0, rcvbuf, default_rcvbuf;
socklen_t optlen;
unsigned int rtfilter;
kr_state.fib_sync = fs;
+ kr_state.rdomain = rdomain;
if ((kr_state.fd = socket(AF_ROUTE,
SOCK_RAW | SOCK_CLOEXEC | SOCK_NONBLOCK, 0)) == -1) {
@@ -211,6 +213,9 @@ kif_redistribute(const char *ifname)
struct kif_addr *ka;
RB_FOREACH(kif, kif_tree, &kit) {
+ if (kif->k.rdomain != kr_state.rdomain)
+ continue;
+
if (ifname && strcmp(kif->k.ifname, ifname) != 0)
continue;
@@ -871,6 +876,7 @@ kif_update(unsigned short ifindex, int flags, struct if_data *ifd,
kif->k.if_type = ifd->ifi_type;
kif->k.baudrate = ifd->ifi_baudrate;
kif->k.mtu = ifd->ifi_mtu;
+ kif->k.rdomain = ifd->ifi_rdomain;
if (sdl && sdl->sdl_family == AF_LINK) {
if (sdl->sdl_nlen >= sizeof(kif->k.ifname))
@@ -1194,6 +1200,7 @@ send_rtmsg_v4(int fd, int action, struct kroute *kr, int family)
hdr.rtm_msglen = sizeof(hdr);
hdr.rtm_hdrlen = sizeof(struct rt_msghdr);
hdr.rtm_priority = kr->priority;
+ hdr.rtm_tableid = kr_state.rdomain; /* rtableid */
/* adjust iovec */
iov[iovcnt].iov_base = &hdr;
iov[iovcnt++].iov_len = sizeof(hdr);
@@ -1318,7 +1325,7 @@ fetchtable(void)
mib[3] = 0;
mib[4] = NET_RT_DUMP;
mib[5] = 0;
- mib[6] = 0; /* rtableid */
+ mib[6] = kr_state.rdomain; /* rtableid */
if (sysctl(mib, 7, NULL, &len, NULL, 0) == -1) {
log_warn("sysctl");
@@ -1426,7 +1433,7 @@ rtmsg_process(char *buf, size_t len)
if (rtm->rtm_errno) /* failed attempts... */
continue;
- if (rtm->rtm_tableid != 0)
+ if (rtm->rtm_tableid != kr_state.rdomain)
continue;
if (rtm->rtm_type == RTM_GET &&
diff --git a/usr.sbin/ldpd/ldpd.c b/usr.sbin/ldpd/ldpd.c
index c8c888bcc38..901df833a91 100644
--- a/usr.sbin/ldpd/ldpd.c
+++ b/usr.sbin/ldpd/ldpd.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ldpd.c,v 1.61 2017/03/03 23:30:57 renato Exp $ */
+/* $OpenBSD: ldpd.c,v 1.62 2017/03/03 23:36:06 renato Exp $ */
/*
* Copyright (c) 2013, 2016 Renato Westphal <renato@openbsd.org>
@@ -255,12 +255,13 @@ main(int argc, char *argv[])
fatal("could not establish imsg links");
main_imsg_send_config(ldpd_conf);
+ if (kr_init(!(ldpd_conf->flags & F_LDPD_NO_FIB_UPDATE),
+ ldpd_conf->rdomain) == -1)
+ fatalx("kr_init failed");
+
/* notify ldpe about existing interfaces and addresses */
kif_redistribute(NULL);
- if (kr_init(!(ldpd_conf->flags & F_LDPD_NO_FIB_UPDATE)) == -1)
- fatalx("kr_init failed");
-
if (ldpd_conf->ipv4.flags & F_LDPD_AF_ENABLED)
main_imsg_send_net_sockets(AF_INET);
if (ldpd_conf->ipv6.flags & F_LDPD_AF_ENABLED)
@@ -772,6 +773,8 @@ merge_global(struct ldpd_conf *conf, struct ldpd_conf *xconf)
conf->rtr_id = xconf->rtr_id;
}
+ conf->rdomain= xconf->rdomain;
+
if (conf->trans_pref != xconf->trans_pref) {
if (ldpd_process == PROC_LDP_ENGINE)
ldpe_reset_ds_nbrs();
diff --git a/usr.sbin/ldpd/ldpd.conf.5 b/usr.sbin/ldpd/ldpd.conf.5
index a5e95e8675f..1f8e85fd8f0 100644
--- a/usr.sbin/ldpd/ldpd.conf.5
+++ b/usr.sbin/ldpd/ldpd.conf.5
@@ -1,4 +1,4 @@
-.\" $OpenBSD: ldpd.conf.5,v 1.33 2016/07/07 19:56:27 rzalamena Exp $
+.\" $OpenBSD: ldpd.conf.5,v 1.34 2017/03/03 23:36:06 renato Exp $
.\"
.\" Copyright (c) 2013, 2016 Renato Westphal <renato@openbsd.org>
.\" Copyright (c) 2009 Michele Marchetto <michele@openbsd.org>
@@ -19,7 +19,7 @@
.\" ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
.\" OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
.\"
-.Dd $Mdocdate: July 7 2016 $
+.Dd $Mdocdate: March 3 2017 $
.Dt LDPD.CONF 5
.Os
.Sh NAME
@@ -108,6 +108,12 @@ table.
The default is
.Ic yes .
.Pp
+.It Ic rdomain Ar tableid
+Specifies the routing table
+.Xr ldpd 8
+should modify.
+Table 0 is the default table.
+.Pp
.It Ic router-id Ar address
Set the router ID; in combination with labelspace it forms the LSR-ID.
If not specified, the numerically lowest IP address of the router will be used.
diff --git a/usr.sbin/ldpd/ldpd.h b/usr.sbin/ldpd/ldpd.h
index 94346b966c8..f5b2a96cac1 100644
--- a/usr.sbin/ldpd/ldpd.h
+++ b/usr.sbin/ldpd/ldpd.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: ldpd.h,v 1.82 2017/03/03 23:30:57 renato Exp $ */
+/* $OpenBSD: ldpd.h,v 1.83 2017/03/03 23:36:06 renato Exp $ */
/*
* Copyright (c) 2013, 2016 Renato Westphal <renato@openbsd.org>
@@ -258,6 +258,7 @@ struct iface {
LIST_ENTRY(iface) entry;
char name[IF_NAMESIZE];
unsigned int ifindex;
+ unsigned int rdomain;
struct if_addr_head addr_list;
struct in6_addr linklocal;
enum iface_type type;
@@ -388,6 +389,7 @@ struct ldpd_af_conf {
struct ldpd_conf {
struct in_addr rtr_id;
+ unsigned int rdomain;
struct ldpd_af_conf ipv4;
struct ldpd_af_conf ipv6;
LIST_HEAD(, iface) iface_list;
@@ -460,6 +462,7 @@ struct kif {
int flags;
uint8_t link_state;
int mtu;
+ unsigned int rdomain;
uint8_t if_type;
uint64_t baudrate;
};
@@ -533,7 +536,7 @@ int cmdline_symset(char *);
/* kroute.c */
int kif_init(void);
-int kr_init(int);
+int kr_init(int, unsigned int);
void kif_redistribute(const char *);
int kr_change(struct kroute *);
int kr_delete(struct kroute *);
diff --git a/usr.sbin/ldpd/parse.y b/usr.sbin/ldpd/parse.y
index 593058acf97..aa34df21666 100644
--- a/usr.sbin/ldpd/parse.y
+++ b/usr.sbin/ldpd/parse.y
@@ -1,4 +1,4 @@
-/* $OpenBSD: parse.y,v 1.59 2017/01/05 13:53:09 krw Exp $ */
+/* $OpenBSD: parse.y,v 1.60 2017/03/03 23:36:06 renato Exp $ */
/*
* Copyright (c) 2013, 2015, 2016 Renato Westphal <renato@openbsd.org>
@@ -99,6 +99,7 @@ static struct nbr_params *conf_get_nbrp(struct in_addr);
static struct l2vpn *conf_get_l2vpn(char *);
static struct l2vpn_if *conf_get_l2vpn_if(struct l2vpn *, struct kif *);
static struct l2vpn_pw *conf_get_l2vpn_pw(struct l2vpn *, struct kif *);
+int conf_check_rdomain(unsigned int);
static void clear_config(struct ldpd_conf *xconf);
static uint32_t get_rtr_id(void);
static int get_address(const char *, union ldpd_addr *);
@@ -133,7 +134,7 @@ static int pushback_index;
%}
-%token INTERFACE TNEIGHBOR ROUTERID FIBUPDATE EXPNULL
+%token INTERFACE TNEIGHBOR ROUTERID FIBUPDATE RDOMAIN EXPNULL
%token LHELLOHOLDTIME LHELLOINTERVAL
%token THELLOHOLDTIME THELLOINTERVAL
%token THELLOACCEPT AF IPV4 IPV6 GTSMENABLE GTSMHOPS
@@ -243,6 +244,13 @@ conf_main : ROUTERID STRING {
else
conf->flags &= ~F_LDPD_NO_FIB_UPDATE;
}
+ | RDOMAIN NUMBER {
+ if ($2 < 0 || $2 > RT_TABLEID_MAX) {
+ yyerror("invalid rdomain");
+ YYERROR;
+ }
+ conf->rdomain = $2;
+ }
| TRANSPREFERENCE ldp_af {
conf->trans_pref = $2;
@@ -842,6 +850,7 @@ lookup(char *s)
{"pseudowire", PSEUDOWIRE},
{"pw-id", PWID},
{"pw-type", PWTYPE},
+ {"rdomain", RDOMAIN},
{"router-id", ROUTERID},
{"status-tlv", STATUSTLV},
{"targeted-hello-accept", THELLOACCEPT},
@@ -1174,6 +1183,7 @@ parse_config(char *filename)
struct sym *sym, *next;
conf = config_new_empty();
+ conf->rdomain = 0;
conf->trans_pref = DUAL_STACK_LDPOV6;
defs = &globaldefs;
@@ -1208,6 +1218,9 @@ parse_config(char *filename)
}
}
+ /* check that all interfaces belong to the configured rdomain */
+ errors += conf_check_rdomain(conf->rdomain);
+
/* free global config defaults */
if (errors) {
clear_config(conf);
@@ -1438,6 +1451,23 @@ conf_get_l2vpn_pw(struct l2vpn *l, struct kif *kif)
return (p);
}
+int
+conf_check_rdomain(unsigned int rdomain)
+{
+ struct iface *i;
+ int errs = 0;
+
+ LIST_FOREACH(i, &conf->iface_list, entry) {
+ if (i->rdomain != rdomain) {
+ logit(LOG_CRIT, "interface %s not in rdomain %u",
+ i->name, rdomain);
+ errs++;
+ }
+ }
+
+ return (errs);
+}
+
static void
clear_config(struct ldpd_conf *xconf)
{
diff --git a/usr.sbin/ldpd/printconf.c b/usr.sbin/ldpd/printconf.c
index 32db88109df..e39b43f8336 100644
--- a/usr.sbin/ldpd/printconf.c
+++ b/usr.sbin/ldpd/printconf.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: printconf.c,v 1.26 2016/07/01 23:14:31 renato Exp $ */
+/* $OpenBSD: printconf.c,v 1.27 2017/03/03 23:36:06 renato Exp $ */
/*
* Copyright (c) 2013, 2016 Renato Westphal <renato@openbsd.org>
@@ -44,6 +44,7 @@ print_mainconf(struct ldpd_conf *conf)
else
printf("fib-update yes\n");
+ printf("rdomain %u\n", conf->rdomain);
if (conf->trans_pref == DUAL_STACK_LDPOV4)
printf("transport-preference ipv4\n");
else if (conf->trans_pref == DUAL_STACK_LDPOV6)