Make sure to initialize the global link list element
[mpls-ldp-portable.git] / ldp / ldp_nexthop.c
blob49c486f9ed4ff3a6a04a6618ee5ead815d1f93be
2 /*
3 * Copyright (C) James R. Leu 2003
4 * jleu@mindspring.com
6 * This software is covered under the LGPL, for more
7 * info check out http://www.gnu.org/copyleft/lgpl.html
8 */
10 #include "ldp_struct.h"
11 #include "ldp_fec.h"
12 #include "ldp_if.h"
13 #include "ldp_addr.h"
14 #include "ldp_session.h"
15 #include "ldp_outlabel.h"
16 #include "ldp_global.h"
17 #include "mpls_assert.h"
18 #include "mpls_compare.h"
19 #include "mpls_mm_impl.h"
20 #include "mpls_tree_impl.h"
21 #include "mpls_policy_impl.h"
22 #include "mpls_trace_impl.h"
24 #if MPLS_USE_LSR
25 #include "lsr_cfg.h"
26 #else
27 #include "mpls_mpls_impl.h"
28 #endif
30 static uint32_t _ldp_nexthop_next_index = 1;
31 static uint32_t _ldp_nexthop_get_next_index();
33 void mpls_nexthop2ldp_nexthop(mpls_nexthop *mnh, ldp_nexthop *lnh)
35 memcpy(&lnh->info, mnh, sizeof(mpls_nexthop));
38 ldp_nexthop *ldp_nexthop_for_fec_session(ldp_fec *fec, ldp_session *s)
40 ldp_nexthop *nh = MPLS_LIST_HEAD(&fec->nh_root);
41 ldp_session *sp;
42 while (nh) {
43 sp = ldp_session_for_nexthop(nh);
44 if (sp && (sp->index == s->index)) {
45 return nh;
47 nh = MPLS_LIST_NEXT(&fec->nh_root, nh, _fec);
49 return NULL;
52 ldp_nexthop *ldp_nexthop_create(ldp_global *g, mpls_nexthop *n)
54 ldp_nexthop *nh = (ldp_nexthop *) mpls_malloc(sizeof(ldp_nexthop));
56 if (nh != NULL) {
57 memset(nh, 0, sizeof(ldp_nexthop));
58 MPLS_REFCNT_INIT(nh, 0);
59 MPLS_LIST_INIT(&nh->outlabel_root, ldp_outlabel);
60 MPLS_LIST_ELEM_INIT(nh, _global);
61 MPLS_LIST_ELEM_INIT(nh, _fec);
62 MPLS_LIST_ELEM_INIT(nh, _addr);
63 MPLS_LIST_ELEM_INIT(nh, _if);
64 MPLS_LIST_ELEM_INIT(nh, _outlabel);
65 nh->index = _ldp_nexthop_get_next_index();
66 mpls_nexthop2ldp_nexthop(n, nh);
67 _ldp_global_add_nexthop(g, nh);
69 return nh;
72 void ldp_nexthop_delete(ldp_global *g, ldp_nexthop *nh)
74 fprintf(stderr, "nexthop delete: %p\n", nh);
75 MPLS_REFCNT_ASSERT(nh, 0);
76 _ldp_global_del_nexthop(g, nh);
77 mpls_free(nh);
80 void ldp_nexthop_add_if(ldp_nexthop * nh, ldp_if * i)
82 MPLS_ASSERT(nh && i);
83 MPLS_REFCNT_HOLD(i);
84 nh->info.if_handle = i->handle;
85 nh->iff = i;
88 void ldp_nexthop_del_if(ldp_global *g, ldp_nexthop * nh)
90 MPLS_ASSERT(nh);
91 MPLS_REFCNT_RELEASE2(g, nh->iff, ldp_if_delete);
92 nh->iff = NULL;
95 void ldp_nexthop_add_addr(ldp_nexthop * nh, ldp_addr * a)
97 MPLS_ASSERT(nh && a);
98 MPLS_REFCNT_HOLD(a);
99 nh->addr = a;
102 void ldp_nexthop_del_addr(ldp_global *g, ldp_nexthop * nh)
104 MPLS_ASSERT(nh);
105 MPLS_REFCNT_RELEASE2(g, nh->addr, ldp_addr_delete);
106 nh->addr = NULL;
109 void ldp_nexthop_add_outlabel(ldp_nexthop * nh, ldp_outlabel * o)
111 MPLS_ASSERT(nh && o);
112 MPLS_REFCNT_HOLD(o);
113 nh->outlabel = o;
116 void ldp_nexthop_del_outlabel(ldp_nexthop * nh)
118 MPLS_ASSERT(nh);
119 MPLS_REFCNT_RELEASE(nh->outlabel, ldp_outlabel_delete);
120 nh->outlabel = NULL;
123 void ldp_nexthop_add_outlabel2(ldp_nexthop * n, ldp_outlabel * o)
125 MPLS_ASSERT(n && o);
126 MPLS_REFCNT_HOLD(o);
127 MPLS_LIST_ADD_HEAD(&n->outlabel_root, o, _nexthop, ldp_outlabel);
128 memcpy(&o->info.nexthop, &n->info, sizeof(mpls_nexthop));
131 void ldp_nexthop_del_outlabel2(ldp_global *g, ldp_nexthop * n, ldp_outlabel * o)
133 MPLS_ASSERT(n && o);
134 MPLS_LIST_REMOVE(&n->outlabel_root, o, _nexthop);
135 ldp_outlabel_del_nexthop2(g, o);
136 MPLS_REFCNT_RELEASE(o, ldp_outlabel_delete);
139 void ldp_nexthop_add_fec(ldp_nexthop *nh, ldp_fec *f)
141 MPLS_ASSERT(nh && f);
142 MPLS_REFCNT_HOLD(f);
143 nh->fec = f;
146 void ldp_nexthop_del_fec(ldp_global *g, ldp_nexthop * nh)
148 MPLS_ASSERT(nh);
149 MPLS_REFCNT_RELEASE2(g, nh->fec, ldp_fec_delete);
150 nh->fec = NULL;
153 static uint32_t _ldp_nexthop_get_next_index()
155 uint32_t retval = _ldp_nexthop_next_index;
157 _ldp_nexthop_next_index++;
158 if (retval > _ldp_nexthop_next_index) {
159 _ldp_nexthop_next_index = 1;
161 return retval;