1 /* A generic nexthop structure
2 * Copyright (C) 2013 Cumulus Networks, Inc.
4 * This file is part of Quagga.
6 * Quagga is free software; you can redistribute it and/or modify it
7 * under the terms of the GNU General Public License as published by the
8 * Free Software Foundation; either version 2, or (at your option) any
11 * Quagga is distributed in the hope that it will be useful, but
12 * WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * General Public License for more details.
16 * You should have received a copy of the GNU General Public License
17 * along with Quagga; see the file COPYING. If not, write to the Free
18 * Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
30 #include "sockunion.h"
36 /* check if nexthops are same, non-recursive */
38 nexthop_same_no_recurse (struct nexthop
*next1
, struct nexthop
*next2
)
40 if (next1
->type
!= next2
->type
)
45 case NEXTHOP_TYPE_IPV4
:
46 case NEXTHOP_TYPE_IPV4_IFINDEX
:
47 if (! IPV4_ADDR_SAME (&next1
->gate
.ipv4
, &next2
->gate
.ipv4
))
49 if (next1
->ifindex
&& (next1
->ifindex
!= next2
->ifindex
))
52 case NEXTHOP_TYPE_IFINDEX
:
53 if (next1
->ifindex
!= next2
->ifindex
)
56 case NEXTHOP_TYPE_IPV6
:
57 if (! IPV6_ADDR_SAME (&next1
->gate
.ipv6
, &next2
->gate
.ipv6
))
60 case NEXTHOP_TYPE_IPV6_IFINDEX
:
61 if (! IPV6_ADDR_SAME (&next1
->gate
.ipv6
, &next2
->gate
.ipv6
))
63 if (next1
->ifindex
!= next2
->ifindex
)
77 nexthop_type_to_str (enum nexthop_types_t nh_type
)
79 static const char *desc
[] = {
84 "IPv4 nexthop with ifindex",
85 "IPv4 nexthop with ifname",
87 "IPv6 nexthop with ifindex",
88 "IPv6 nexthop with ifname",
92 if (nh_type
>= ZEBRA_NUM_OF (desc
))
93 return "<Invalid nh type>";
101 return XCALLOC (MTYPE_NEXTHOP
, sizeof (struct nexthop
));
104 /* Add nexthop to the end of a nexthop list. */
106 nexthop_add (struct nexthop
**target
, struct nexthop
*nexthop
)
108 struct nexthop
*last
;
110 for (last
= *target
; last
&& last
->next
; last
= last
->next
)
113 last
->next
= nexthop
;
116 nexthop
->prev
= last
;
120 copy_nexthops (struct nexthop
**tnh
, struct nexthop
*nh
)
122 struct nexthop
*nexthop
;
125 for (nh1
= nh
; nh1
; nh1
= nh1
->next
)
127 nexthop
= nexthop_new();
128 nexthop
->flags
= nh
->flags
;
129 nexthop
->type
= nh
->type
;
130 nexthop
->ifindex
= nh
->ifindex
;
131 memcpy(&(nexthop
->gate
), &(nh
->gate
), sizeof(union g_addr
));
132 memcpy(&(nexthop
->src
), &(nh
->src
), sizeof(union g_addr
));
133 nexthop_add(tnh
, nexthop
);
135 if (CHECK_FLAG(nh1
->flags
, NEXTHOP_FLAG_RECURSIVE
))
136 copy_nexthops(&nexthop
->resolved
, nh1
->resolved
);
142 nexthop_free (struct nexthop
*nexthop
)
144 if (nexthop
->resolved
)
145 nexthops_free(nexthop
->resolved
);
146 XFREE (MTYPE_NEXTHOP
, nexthop
);
149 /* Frees a list of nexthops */
151 nexthops_free (struct nexthop
*nexthop
)
153 struct nexthop
*nh
, *next
;
155 for (nh
= nexthop
; nh
; nh
= next
)