diff options
Diffstat (limited to '')
-rw-r--r-- | lib/subdir.am | 640 |
1 files changed, 640 insertions, 0 deletions
diff --git a/lib/subdir.am b/lib/subdir.am new file mode 100644 index 0000000..d7b28ff --- /dev/null +++ b/lib/subdir.am @@ -0,0 +1,640 @@ +# +# libfrr +# + +lib_LTLIBRARIES += lib/libfrr.la +lib_libfrr_la_LDFLAGS = $(LIB_LDFLAGS) -version-info 0:0:0 -Xlinker -e_libfrr_version +lib_libfrr_la_LIBADD = $(LIBCAP) $(UNWIND_LIBS) $(LIBYANG_LIBS) $(LUA_LIB) $(UST_LIBS) $(LIBCRYPT) $(LIBDL) $(LIBM) + +lib_libfrr_la_SOURCES = \ + lib/admin_group.c \ + lib/affinitymap.c \ + lib/affinitymap_cli.c \ + lib/affinitymap_northbound.c \ + lib/agg_table.c \ + lib/atomlist.c \ + lib/asn.c \ + lib/base64.c \ + lib/bfd.c \ + lib/buffer.c \ + lib/checksum.c \ + lib/command.c \ + lib/command_graph.c \ + lib/command_lex.l \ + lib/command_match.c \ + lib/command_parse.y \ + lib/cspf.c \ + lib/csv.c \ + lib/darr.c \ + lib/debug.c \ + lib/defaults.c \ + lib/distribute.c \ + lib/explicit_bzero.c \ + lib/ferr.c \ + lib/filter.c \ + lib/filter_cli.c \ + lib/filter_nb.c \ + lib/flex_algo.c \ + lib/frrcu.c \ + lib/frrlua.c \ + lib/frrscript.c \ + lib/frr_pthread.c \ + lib/frrstr.c \ + lib/grammar_sandbox.c \ + lib/graph.c \ + lib/hash.c \ + lib/hook.c \ + lib/id_alloc.c \ + lib/if.c \ + lib/if_rmap.c \ + lib/imsg-buffer.c \ + lib/imsg.c \ + lib/iso.c \ + lib/jhash.c \ + lib/json.c \ + lib/keychain.c \ + lib/ldp_sync.c \ + lib/lib_errors.c \ + lib/lib_vty.c \ + lib/libfrr.c \ + lib/libfrr_trace.c \ + lib/linklist.c \ + lib/link_state.c \ + lib/log.c \ + lib/log_filter.c \ + lib/log_vty.c \ + lib/md5.c \ + lib/memory.c \ + lib/mgmt_be_client.c \ + lib/mgmt_fe_client.c \ + lib/mgmt_msg.c \ + lib/mlag.c \ + lib/module.c \ + lib/mpls.c \ + lib/srv6.c \ + lib/network.c \ + lib/nexthop.c \ + lib/netns_linux.c \ + lib/netns_other.c \ + lib/nexthop_group.c \ + lib/northbound.c \ + lib/northbound_cli.c \ + lib/northbound_db.c \ + lib/ntop.c \ + lib/openbsd-tree.c \ + lib/pid_output.c \ + lib/plist.c \ + lib/prefix.c \ + lib/privs.c \ + lib/ptm_lib.c \ + lib/pullwr.c \ + lib/qobj.c \ + lib/ringbuf.c \ + lib/routemap.c \ + lib/routemap_cli.c \ + lib/routemap_northbound.c \ + lib/sbuf.c \ + lib/seqlock.c \ + lib/sha256.c \ + lib/sigevent.c \ + lib/skiplist.c \ + lib/sockopt.c \ + lib/sockunion.c \ + lib/spf_backoff.c \ + lib/segment_routing.c \ + lib/srcdest_table.c \ + lib/stream.c \ + lib/strformat.c \ + lib/strlcat.c \ + lib/strlcpy.c \ + lib/systemd.c \ + lib/table.c \ + lib/termtable.c \ + lib/event.c \ + lib/typerb.c \ + lib/typesafe.c \ + lib/vector.c \ + lib/vrf.c \ + lib/vty.c \ + lib/wheel.c \ + lib/workqueue.c \ + lib/xref.c \ + lib/yang.c \ + lib/yang_translator.c \ + lib/yang_wrappers.c \ + lib/zclient.c \ + lib/zlog.c \ + lib/zlog_5424.c \ + lib/zlog_5424_cli.c \ + lib/zlog_live.c \ + lib/zlog_targets.c \ + lib/printf/printf-pos.c \ + lib/printf/vfprintf.c \ + lib/printf/glue.c \ + lib/routing_nb.c \ + lib/routing_nb_config.c \ + lib/tc.c \ + # end + +nodist_lib_libfrr_la_SOURCES = \ + yang/frr-affinity-map.yang.c \ + yang/frr-filter.yang.c \ + yang/frr-if-rmap.yang.c \ + yang/frr-interface.yang.c \ + yang/frr-route-map.yang.c \ + yang/frr-route-types.yang.c \ + yang/frr-vrf.yang.c \ + yang/frr-routing.yang.c \ + yang/frr-nexthop.yang.c \ + yang/ietf/ietf-routing-types.yang.c \ + yang/ietf/ietf-interfaces.yang.c \ + yang/ietf/ietf-bgp-types.yang.c \ + yang/frr-module-translator.yang.c \ + # end + +# Add logic to build mgmt.proto +lib_libfrr_la_LIBADD += $(PROTOBUF_C_LIBS) + +BUILT_SOURCES += \ + lib/mgmt.pb-c.c \ + lib/mgmt.pb-c.h \ + # end + +CLEANFILES += \ + lib/mgmt.pb-c.h \ + lib/mgmt.pb-c.c \ + # end + +lib_libfrr_la_SOURCES += \ + lib/mgmt.pb-c.c \ + #end + +if SQLITE3 +lib_libfrr_la_LIBADD += $(SQLITE3_LIBS) +lib_libfrr_la_SOURCES += lib/db.c +endif + +clippy_scan += \ + lib/affinitymap_cli.c \ + lib/if.c \ + lib/filter_cli.c \ + lib/if_rmap.c \ + lib/log_vty.c \ + lib/mgmt_be_client.c \ + lib/mgmt_fe_client.c \ + lib/nexthop_group.c \ + lib/northbound_cli.c \ + lib/plist.c \ + lib/routemap.c \ + lib/routemap_cli.c \ + lib/event.c \ + lib/vty.c \ + lib/zlog_5424_cli.c \ + # end + +pkginclude_HEADERS += \ + lib/admin_group.h \ + lib/affinitymap.h \ + lib/agg_table.h \ + lib/asn.h \ + lib/atomlist.h \ + lib/base64.h \ + lib/bfd.h \ + lib/bitfield.h \ + lib/buffer.h \ + lib/checksum.h \ + lib/mlag.h \ + lib/command.h \ + lib/command_graph.h \ + lib/command_match.h \ + lib/compiler.h \ + lib/cspf.h \ + lib/csv.h \ + lib/darr.h \ + lib/db.h \ + lib/debug.h \ + lib/defaults.h \ + lib/distribute.h \ + lib/ferr.h \ + lib/filter.h \ + lib/flex_algo.h \ + lib/freebsd-queue.h \ + lib/frrlua.h \ + lib/frrscript.h \ + lib/frr_pthread.h \ + lib/frratomic.h \ + lib/frrcu.h \ + lib/frrstr.h \ + lib/graph.h \ + lib/hash.h \ + lib/hook.h \ + lib/iana_afi.h \ + lib/id_alloc.h \ + lib/if.h \ + lib/if_rmap.h \ + lib/imsg.h \ + lib/ipaddr.h \ + lib/iso.h \ + lib/jhash.h \ + lib/json.h \ + lib/keychain.h \ + lib/ldp_sync.h \ + lib/lib_errors.h \ + lib/lib_vty.h \ + lib/libfrr.h \ + lib/libfrr_trace.h \ + lib/libospf.h \ + lib/linklist.h \ + lib/link_state.h \ + lib/log.h \ + lib/log_vty.h \ + lib/md5.h \ + lib/memory.h \ + lib/mgmt.pb-c.h \ + lib/mgmt_be_client.h \ + lib/mgmt_fe_client.h \ + lib/mgmt_msg.h \ + lib/mgmt_pb.h \ + lib/module.h \ + lib/monotime.h \ + lib/mpls.h \ + lib/srv6.h \ + lib/network.h \ + lib/nexthop.h \ + lib/nexthop_group.h \ + lib/nexthop_group_private.h \ + lib/northbound.h \ + lib/northbound_cli.h \ + lib/northbound_db.h \ + lib/ns.h \ + lib/openbsd-queue.h \ + lib/openbsd-tree.h \ + lib/plist.h \ + lib/prefix.h \ + lib/printfrr.h \ + lib/privs.h \ + lib/ptm_lib.h \ + lib/pullwr.h \ + lib/pw.h \ + lib/qobj.h \ + lib/queue.h \ + lib/ringbuf.h \ + lib/routemap.h \ + lib/route_opaque.h \ + lib/sbuf.h \ + lib/seqlock.h \ + lib/sha256.h \ + lib/sigevent.h \ + lib/skiplist.h \ + lib/smux.h \ + lib/sockopt.h \ + lib/sockunion.h \ + lib/spf_backoff.h \ + lib/segment_routing.h \ + lib/srcdest_table.h \ + lib/srte.h \ + lib/stream.h \ + lib/systemd.h \ + lib/table.h \ + lib/termtable.h \ + lib/frrevent.h \ + lib/trace.h \ + lib/typerb.h \ + lib/typesafe.h \ + lib/vector.h \ + lib/vlan.h \ + lib/vrf.h \ + lib/vrf_int.h \ + lib/vty.h \ + lib/vxlan.h \ + lib/wheel.h \ + lib/workqueue.h \ + lib/xref.h \ + lib/yang.h \ + lib/yang_translator.h \ + lib/yang_wrappers.h \ + lib/zclient.h \ + lib/zebra.h \ + lib/zlog.h \ + lib/zlog_5424.h \ + lib/zlog_live.h \ + lib/zlog_targets.h \ + lib/pbr.h \ + lib/tc.h \ + lib/routing_nb.h \ + \ + lib/assert/assert.h \ + # end + + +nodist_pkginclude_HEADERS += \ + lib/route_types.h \ + lib/version.h \ + # end + +noinst_HEADERS += \ + lib/clippy.h \ + lib/plist_int.h \ + lib/printf/printfcommon.h \ + lib/printf/printflocal.h \ + #end + +# General note about module and module helper library (libfrrsnmp, libfrrzmq) +# linking: If we're linking libfrr statically into daemons, we *must* remove +# libfrr from modules because modules will always link it in dynamically and +# thus 2 copies of libfrr will be loaded... hilarity ensues. +# +# Not linking libfrr into modules should generally work fine because the +# executable refers to libfrr either way and the dynamic linker should make +# libfrr available to modules. If some OS platform has a dynamic linker that +# doesn't do that, libfrr needs to be readded to modules, but _only_ _if_ +# it's not linked into daemons statically. + +# +# SNMP support +# +if SNMP +lib_LTLIBRARIES += lib/libfrrsnmp.la +endif + +lib_libfrrsnmp_la_CFLAGS = $(AM_CFLAGS) $(SNMP_CFLAGS) -std=gnu11 +lib_libfrrsnmp_la_LDFLAGS = $(LIB_LDFLAGS) -version-info 0:0:0 +lib_libfrrsnmp_la_LIBADD = $(SNMP_LIBS) +lib_libfrrsnmp_la_SOURCES = \ + lib/agentx.c \ + lib/snmp.c \ + # end + + +# +# c-ares support +# +if CARES +lib_LTLIBRARIES += lib/libfrrcares.la +pkginclude_HEADERS += lib/resolver.h +endif + +lib_libfrrcares_la_CFLAGS = $(AM_CFLAGS) $(CARES_CFLAGS) +lib_libfrrcares_la_LDFLAGS = $(LIB_LDFLAGS) -version-info 0:0:0 +lib_libfrrcares_la_LIBADD = $(CARES_LIBS) +lib_libfrrcares_la_SOURCES = \ + lib/resolver.c \ + #end + +# +# ZeroMQ support +# +if ZEROMQ +lib_LTLIBRARIES += lib/libfrrzmq.la +pkginclude_HEADERS += lib/frr_zmq.h +endif + +lib_libfrrzmq_la_CFLAGS = $(AM_CFLAGS) $(ZEROMQ_CFLAGS) +lib_libfrrzmq_la_LDFLAGS = $(LIB_LDFLAGS) -version-info 0:0:0 +lib_libfrrzmq_la_LIBADD = $(ZEROMQ_LIBS) +lib_libfrrzmq_la_SOURCES = \ + lib/frr_zmq.c \ + #end + +# +# Tail-f's ConfD support +# +if CONFD +module_LTLIBRARIES += lib/confd.la +endif + +lib_confd_la_CFLAGS = $(AM_CFLAGS) $(CONFD_CFLAGS) +lib_confd_la_LDFLAGS = $(MODULE_LDFLAGS) +lib_confd_la_LIBADD = lib/libfrr.la $(CONFD_LIBS) +lib_confd_la_SOURCES = lib/northbound_confd.c + +# +# Sysrepo support +# +if SYSREPO +module_LTLIBRARIES += lib/sysrepo.la +endif + +lib_sysrepo_la_CFLAGS = $(AM_CFLAGS) $(SYSREPO_CFLAGS) +lib_sysrepo_la_LDFLAGS = $(MODULE_LDFLAGS) +lib_sysrepo_la_LIBADD = lib/libfrr.la $(SYSREPO_LIBS) +lib_sysrepo_la_SOURCES = lib/northbound_sysrepo.c + +# +# gRPC northbound plugin +# +if GRPC +module_LTLIBRARIES += lib/grpc.la +endif + +lib_grpc_la_CXXFLAGS = $(WERROR) $(GRPC_CFLAGS) +lib_grpc_la_LDFLAGS = $(MODULE_LDFLAGS) +lib_grpc_la_LIBADD = lib/libfrr.la grpc/libfrrgrpc_pb.la $(GRPC_LIBS) +lib_grpc_la_SOURCES = lib/northbound_grpc.cpp + +# +# CLI utilities +# +noinst_PROGRAMS += \ + lib/grammar_sandbox \ + # end + +if BUILD_CLIPPY +noinst_PROGRAMS += lib/clippy +else +if HOSTTOOLS_CLIPPY +$(CLIPPY): + @$(MAKE) -C $(top_builddir)/hosttools lib/route_types.h lib/clippy +endif +endif + +lib_grammar_sandbox_SOURCES = \ + lib/grammar_sandbox_main.c +lib_grammar_sandbox_LDADD = \ + lib/libfrr.la + +lib_clippy_CPPFLAGS = $(CPPFLAGS_BASE) -D_GNU_SOURCE -DBUILDING_CLIPPY +lib_clippy_CFLAGS = $(AC_CFLAGS) $(PYTHON_CFLAGS) +lib_clippy_LDADD = $(PYTHON_LIBS) $(UST_LIBS) -lelf +# no $(SAN_FLAGS) here +lib_clippy_LDFLAGS = -export-dynamic $(AC_LDFLAGS) $(AC_LDFLAGS_EXEC) +lib_clippy_SOURCES = \ + lib/jhash.c \ + lib/clippy.c \ + lib/command_graph.c \ + lib/command_lex.l \ + lib/command_parse.y \ + lib/command_py.c \ + lib/defun_lex.l \ + lib/elf_py.c \ + lib/graph.c \ + lib/libfrr_trace.c \ + lib/memory.c \ + lib/typesafe.c \ + lib/vector.c \ + # end + +# (global) clippy rules for all directories + +AM_V_CLIPPY = $(am__v_CLIPPY_$(V)) +am__v_CLIPPY_ = $(am__v_CLIPPY_$(AM_DEFAULT_VERBOSITY)) +am__v_CLIPPY_0 = @echo " CLIPPY " $@; +am__v_CLIPPY_1 = + +CLIPPY_DEPS = $(CLIPPY) $(top_srcdir)/python/clidef.py + +SUFFIXES += _clippy.c +.c_clippy.c: + $(AM_V_CLIPPY) $(CLIPPY) $(top_srcdir)/python/clidef.py -o $@ $< + +# xrelfo, the ELF xref extractor + +AM_V_XRELFO = $(am__v_XRELFO_$(V)) +am__v_XRELFO_ = $(am__v_XRELFO_$(AM_DEFAULT_VERBOSITY)) +am__v_XRELFO_0 = @echo " XRELFO " $@; +am__v_XRELFO_1 = + +XRELFO_FLAGS = -Wlog-format -Wlog-args + +SUFFIXES += .xref +%.xref: % $(CLIPPY) + $(AM_V_XRELFO) $(CLIPPY) $(top_srcdir)/python/xrelfo.py $(WERROR) $(XRELFO_FLAGS) -o $@ $< + +# dependencies added in python/makefile.py +frr.xref: + $(AM_V_XRELFO) $(CLIPPY) $(top_srcdir)/python/xrelfo.py -o $@ -c vtysh/vtysh_cmd.c $^ +all-am: frr.xref + +clean-xref: + -rm -rf $(xrefs) frr.xref +clean-local: clean-xref + +CLEANFILES += vtysh/vtysh_cmd.c +vtysh/vtysh_cmd.c: frr.xref + @test -f $@ || rm -f frr.xref || true + @test -f $@ || $(MAKE) $(AM_MAKEFLAGS) frr.xref + +## automake's "ylwrap" is a great piece of GNU software... not. +.l.c: + $(AM_V_LEX)$(am__skiplex) $(LEXCOMPILE) $< +.y.c: + $(AM_V_YACC)$(am__skipyacc) $(YACCCOMPILE) $< + +# +# generated sources & extra foo +# +EXTRA_DIST += \ + lib/command_lex.h \ + lib/command_parse.h \ + lib/gitversion.pl \ + lib/route_types.pl \ + lib/route_types.txt \ + # end + +BUILT_SOURCES += \ + lib/gitversion.h \ + lib/route_types.h \ + # end + +## force route_types.h +$(lib_clippy_OBJECTS): lib/route_types.h +$(lib_libfrr_la_OBJECTS): lib/route_types.h + +AM_YFLAGS = -d -Dapi.prefix=@BISON_OPENBRACE@cmd_yy@BISON_CLOSEBRACE@ @BISON_VERBOSE@ + +lib/command_lex.h: lib/command_lex.c + @if test ! -f $@; then rm -f "lib/command_lex.c"; else :; fi + @if test ! -f $@; then $(MAKE) $(AM_MAKEFLAGS) "lib/command_lex.c"; else :; fi +lib/command_lex.lo: lib/command_parse.h +lib/command_parse.lo: lib/command_lex.h +lib/clippy-command_lex.$(OBJEXT): lib/command_parse.h +lib/clippy-command_parse.$(OBJEXT): lib/command_lex.h +lib/lib_clippy-command_lex.$(OBJEXT): lib/command_parse.h +lib/lib_clippy-command_parse.$(OBJEXT): lib/command_lex.h + +DISTCLEANFILES += lib/command_lex.h \ + lib/command_lex.c \ + lib/command_parse.h \ + lib/command_parse.c + +rt_enabled = + +if BABELD +rt_enabled += --enabled babeld +endif +if BFDD +rt_enabled += --enabled bfdd +endif +if BGPD +rt_enabled += --enabled bgpd +if ENABLE_BGP_VNC +rt_enabled += --enabled bgpd-vnc +endif +endif +if EIGRPD +rt_enabled += --enabled eigrpd +endif +if ISISD +rt_enabled += --enabled isisd +endif +if FABRICD +rt_enabled += --enabled fabricd +endif +if LDPD +rt_enabled += --enabled ldpd +endif +if NHRPD +rt_enabled += --enabled nhrpd +endif +if OSPFD +rt_enabled += --enabled ospfd +endif +if OSPF6D +rt_enabled += --enabled ospf6d +endif +if PBRD +rt_enabled += --enabled pbrd +endif +if PIMD +rt_enabled += --enabled pimd +endif +if RIPD +rt_enabled += --enabled ripd +endif +if RIPNGD +rt_enabled += --enabled ripngd +endif +if SHARPD +rt_enabled += --enabled sharpd +endif +if ZEBRA +rt_enabled += --enabled zebra +endif + +lib/route_types.h: $(top_srcdir)/lib/route_types.txt $(top_srcdir)/lib/route_types.pl + @$(MKDIR_P) lib + $(PERL) $(top_srcdir)/lib/route_types.pl $(rt_enabled) < $(top_srcdir)/lib/route_types.txt > $@ +DISTCLEANFILES += lib/route_types.h + +if GIT_VERSION +# bit of a trick here to always have up-to-date git stamps without triggering +# unnecessary rebuilds. .PHONY causes the .tmp file to be rebuilt always, +# but if we use that on gitversion.h it'll ripple through the .c file deps. +# (even if gitversion.h's file timestamp doesn't change, make will think it +# did, because of .PHONY...) + +PHONY_GITVERSION=lib/gitversion.h.tmp +.SILENT: lib/gitversion.h lib/gitversion.h.tmp +GITH=lib/gitversion.h +lib/gitversion.h.tmp: $(top_srcdir)/.git + @$(MKDIR_P) lib + $(PERL) $(top_srcdir)/lib/gitversion.pl $(top_srcdir) > ${GITH}.tmp +lib/gitversion.h: lib/gitversion.h.tmp + { test -f ${GITH} && diff -s -q ${GITH}.tmp ${GITH}; } || cp ${GITH}.tmp ${GITH} + +else +PHONY_GITVERSION=lib/gitversion.h +lib/gitversion.h: + true +endif +.PHONY: $(PHONY_GITVERSION) |