diff options
author | Renato Westphal <renato@cvs.openbsd.org> | 2015-07-21 04:48:43 +0000 |
---|---|---|
committer | Renato Westphal <renato@cvs.openbsd.org> | 2015-07-21 04:48:43 +0000 |
commit | 6e1f964c76fe64a2e4d55765a578dbb338c18266 (patch) | |
tree | 90e8eba625d3d7d29ad14a8f0384fa50bd686f3a | |
parent | 2be2eed7d18722c3b4d91d2a0366ee4f6eacf2df (diff) |
Record all fields of the received label mappings.
Since we implement the Liberal Label Retention mode, we need to record
all fields of the received label mappings so the messages can be processed
later when there is a matching nexthop for the advertised FECs.
This will be important when we implement VPLS because we need to retain
information like the pseudowire's interface MTU and Group ID.
ok claudio@
-rw-r--r-- | usr.sbin/ldpd/lde.c | 4 | ||||
-rw-r--r-- | usr.sbin/ldpd/lde.h | 4 | ||||
-rw-r--r-- | usr.sbin/ldpd/lde_lib.c | 33 |
3 files changed, 17 insertions, 24 deletions
diff --git a/usr.sbin/ldpd/lde.c b/usr.sbin/ldpd/lde.c index 6dd38944f0d..82ff83c444d 100644 --- a/usr.sbin/ldpd/lde.c +++ b/usr.sbin/ldpd/lde.c @@ -1,4 +1,4 @@ -/* $OpenBSD: lde.c,v 1.36 2015/07/21 04:46:51 renato Exp $ */ +/* $OpenBSD: lde.c,v 1.37 2015/07/21 04:48:42 renato Exp $ */ /* * Copyright (c) 2004, 2005 Claudio Jeker <claudio@openbsd.org> @@ -539,7 +539,7 @@ lde_send_labelmapping(struct lde_nbr *ln, struct fec_node *fn) me = (struct lde_map *)fec_find(&ln->sent_map, &fn->fec); if (me == NULL) me = lde_map_add(ln, fn, 1); - me->label = map.label; + memcpy(&me->map, &map, sizeof(map)); } void diff --git a/usr.sbin/ldpd/lde.h b/usr.sbin/ldpd/lde.h index df00fa89427..d1165c09c39 100644 --- a/usr.sbin/ldpd/lde.h +++ b/usr.sbin/ldpd/lde.h @@ -1,4 +1,4 @@ -/* $OpenBSD: lde.h,v 1.27 2015/07/21 04:46:51 renato Exp $ */ +/* $OpenBSD: lde.h,v 1.28 2015/07/21 04:48:42 renato Exp $ */ /* * Copyright (c) 2004, 2005 Esben Norby <norby@openbsd.org> @@ -47,7 +47,7 @@ struct lde_map { struct fec fec; LIST_ENTRY(lde_map) entry; struct lde_nbr *nexthop; - u_int32_t label; + struct map map; }; /* withdraw entries */ diff --git a/usr.sbin/ldpd/lde_lib.c b/usr.sbin/ldpd/lde_lib.c index c9d3576b048..b21c1d92477 100644 --- a/usr.sbin/ldpd/lde_lib.c +++ b/usr.sbin/ldpd/lde_lib.c @@ -1,4 +1,4 @@ -/* $OpenBSD: lde_lib.c,v 1.38 2015/07/21 04:46:51 renato Exp $ */ +/* $OpenBSD: lde_lib.c,v 1.39 2015/07/21 04:48:42 renato Exp $ */ /* * Copyright (c) 2009 Michele Marchetto <michele@openbsd.org> @@ -160,7 +160,7 @@ rt_dump(pid_t pid) LIST_FOREACH(me, &fn->downstream, entry) { rtctl.in_use = lde_nbr_is_nexthop(fn, me->nexthop); rtctl.nexthop = me->nexthop->id; - rtctl.remote_label = me->label; + rtctl.remote_label = me->map.label; lde_imsg_compose_ldpe(IMSG_CTL_SHOW_LIB, 0, pid, &rtctl, sizeof(rtctl)); @@ -338,17 +338,9 @@ lde_kernel_insert(struct kroute *kr) if (ln) { /* FEC.2 */ me = (struct lde_map *)fec_find(&ln->recv_map, &fn->fec); - if (me) { - struct map map; - - bzero(&map, sizeof(map)); - map.prefix.s_addr = me->fec.prefix.s_addr; - map.prefixlen = me->fec.prefixlen; - map.label = me->label; - + if (me) /* FEC.5 */ - lde_check_mapping(&map, ln); - } + lde_check_mapping(&me->map, ln); } } @@ -411,9 +403,9 @@ lde_check_mapping(struct map *map, struct lde_nbr *ln) me = (struct lde_map *)fec_find(&ln->recv_map, &fn->fec); if (me) { /* LMp.10 */ - if (me->label != map->label && lre == NULL) { + if (me->map.label != map->label && lre == NULL) { /* LMp.10a */ - lde_send_labelrelease(ln, fn, me->label); + lde_send_labelrelease(ln, fn, me->map.label); LIST_FOREACH(fnh, &fn->nexthops, entry) TAILQ_FOREACH(addr, &ln->addr_list, entry) @@ -442,14 +434,14 @@ lde_check_mapping(struct map *map, struct lde_nbr *ln) /* LMp.13: perform lsr label release procedure */ if (me == NULL) me = lde_map_add(ln, fn, 0); - me->label = map->label; + memcpy(&me->map, map, sizeof(*map)); return; } /* LMp.16: Record the mapping from this peer */ if (me == NULL) me = lde_map_add(ln, fn, 0); - me->label = map->label; + memcpy(&me->map, map, sizeof(*map)); /* * LMp.17 - LMp.27 are unnecessary since we don't need to implement @@ -530,7 +522,7 @@ lde_check_release(struct map *map, struct lde_nbr *ln) /* LRl.6: check sent map list and remove it if available */ me = (struct lde_map *)fec_find(&ln->sent_map, &fn->fec); - if (me && (map->label == NO_LABEL || map->label == me->label)) + if (me && (map->label == NO_LABEL || map->label == me->map.label)) lde_map_del(ln, me, 1); /* @@ -561,7 +553,7 @@ lde_check_release_wcard(struct map *map, struct lde_nbr *ln) /* LRl.6: check sent map list and remove it if available */ me = (struct lde_map *)fec_find(&ln->sent_map, &fn->fec); if (me && - (map->label == NO_LABEL || map->label == me->label)) { + (map->label == NO_LABEL || map->label == me->map.label)) { lde_map_del(ln, me, 1); } @@ -597,7 +589,7 @@ lde_check_withdraw(struct map *map, struct lde_nbr *ln) /* LWd.3: check previously received label mapping */ me = (struct lde_map *)fec_find(&ln->recv_map, &fn->fec); - if (me && (map->label == NO_LABEL || map->label == me->label)) + if (me && (map->label == NO_LABEL || map->label == me->map.label)) /* LWd.4: remove record of previously received lbl mapping */ lde_map_del(ln, me, 0); } @@ -626,7 +618,8 @@ lde_check_withdraw_wcard(struct map *map, struct lde_nbr *ln) /* LWd.3: check previously received label mapping */ me = (struct lde_map *)fec_find(&ln->recv_map, &fn->fec); - if (me && (map->label == NO_LABEL || map->label == me->label)) + if (me && (map->label == NO_LABEL || + map->label == me->map.label)) /* * LWd.4: remove record of previously received * label mapping |