From a38401b6af746794db0b4bdbd3954289b8d00aef Mon Sep 17 00:00:00 2001 From: David Lamparter Date: Mon, 13 Apr 2015 10:21:34 +0200 Subject: [PATCH] lib: hide internal prefix list structures These are about to be touched and there's no point in other code touching into prefix list's internas. Add some isolation. Signed-off-by: David Lamparter --- bgpd/bgpd.c | 4 ++-- lib/Makefile.am | 3 +++ lib/plist.c | 25 ++++++------------------- lib/plist.h | 26 ++------------------------ ospfd/ospf_zebra.c | 4 ++-- 5 files changed, 15 insertions(+), 47 deletions(-) diff --git a/bgpd/bgpd.c b/bgpd/bgpd.c index 2d831acdd2..8ff16e07ac 100644 --- a/bgpd/bgpd.c +++ b/bgpd/bgpd.c @@ -13,7 +13,7 @@ WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. -You should have received a copy of the GNU General Public License +You should have received a copy of the GN5U General Public License along with GNU Zebra; see the file COPYING. If not, write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ @@ -5144,7 +5144,7 @@ peer_prefix_list_update (struct prefix_list *plist) * Update the prefix-list on update groups. */ update_group_policy_update(bgp, BGP_POLICY_PREFIX_LIST, - plist ? plist->name : NULL, 0, 0); + plist ? prefix_list_name(plist) : NULL, 0, 0); for (ALL_LIST_ELEMENTS (bgp->peer, node, nnode, peer)) { diff --git a/lib/Makefile.am b/lib/Makefile.am index 49a721f7f9..43fa906128 100644 --- a/lib/Makefile.am +++ b/lib/Makefile.am @@ -32,6 +32,9 @@ pkginclude_HEADERS = \ workqueue.h route_types.h libospf.h nexthop.h json.h \ ptm_lib.h csv.h bfd.h vrf.h +noinst_HEADERS = \ + plist_int.h + EXTRA_DIST = \ regex.c regex-gnu.h \ queue.h \ diff --git a/lib/plist.c b/lib/plist.c index 2418c8621d..0174a53fec 100644 --- a/lib/plist.c +++ b/lib/plist.c @@ -32,25 +32,7 @@ #include "log.h" #include "routemap.h" -/* Each prefix-list's entry. */ -struct prefix_list_entry -{ - int seq; - - int le; - int ge; - - enum prefix_list_type type; - - int any; - struct prefix prefix; - - unsigned long refcnt; - unsigned long hitcnt; - - struct prefix_list_entry *next; - struct prefix_list_entry *prev; -}; +#include "plist_int.h" /* List of struct prefix_list. */ struct prefix_list_list @@ -127,6 +109,11 @@ prefix_master_get (afi_t afi) return NULL; } +const char *prefix_list_name (struct prefix_list *plist) +{ + return plist->name; +} + /* Lookup prefix_list from list of prefix_list by name. */ struct prefix_list * prefix_list_lookup (afi_t afi, const char *name) diff --git a/lib/plist.h b/lib/plist.h index 4359a8935c..cfc43c781c 100644 --- a/lib/plist.h +++ b/lib/plist.h @@ -31,30 +31,7 @@ enum prefix_list_type PREFIX_PERMIT, }; -enum prefix_name_type -{ - PREFIX_TYPE_STRING, - PREFIX_TYPE_NUMBER -}; - -struct prefix_list -{ - char *name; - char *desc; - - struct prefix_master *master; - - enum prefix_name_type type; - - int count; - int rangecount; - - struct prefix_list_entry *head; - struct prefix_list_entry *tail; - - struct prefix_list *next; - struct prefix_list *prev; -}; +struct prefix_list; struct orf_prefix { @@ -70,6 +47,7 @@ extern void prefix_list_reset (void); extern void prefix_list_add_hook (void (*func) (struct prefix_list *)); extern void prefix_list_delete_hook (void (*func) (struct prefix_list *)); +extern const char *prefix_list_name (struct prefix_list *); extern struct prefix_list *prefix_list_lookup (afi_t, const char *); extern enum prefix_list_type prefix_list_apply (struct prefix_list *, void *); diff --git a/ospfd/ospf_zebra.c b/ospfd/ospf_zebra.c index a95b2e1b67..8119dde5e8 100644 --- a/ospfd/ospf_zebra.c +++ b/ospfd/ospf_zebra.c @@ -1379,7 +1379,7 @@ ospf_prefix_list_update (struct prefix_list *plist) { /* Update filter-list in. */ if (PREFIX_NAME_IN (area)) - if (strcmp (PREFIX_NAME_IN (area), plist->name) == 0) + if (strcmp (PREFIX_NAME_IN (area), prefix_list_name (plist)) == 0) { PREFIX_LIST_IN (area) = prefix_list_lookup (AFI_IP, PREFIX_NAME_IN (area)); @@ -1388,7 +1388,7 @@ ospf_prefix_list_update (struct prefix_list *plist) /* Update filter-list out. */ if (PREFIX_NAME_OUT (area)) - if (strcmp (PREFIX_NAME_OUT (area), plist->name) == 0) + if (strcmp (PREFIX_NAME_OUT (area), prefix_list_name (plist)) == 0) { PREFIX_LIST_IN (area) = prefix_list_lookup (AFI_IP, PREFIX_NAME_OUT (area)); -- 2.39.5