# limitations under the License.
lib_LTLIBRARIES += libvnet.la
+noinst_LTLIBRARIES =
libvnet_la_SOURCES =
libvnet_la_DEPENDENCIES = \
libsvmdb.la \
libsvm.la \
libvlibmemory.la
+libvnet_multiversioning_sources =
libvnet_la_LIBADD = $(libvnet_la_DEPENDENCIES) -lm -lpthread -ldl -lrt
# Generic stuff
########################################
libvnet_la_SOURCES += \
+ vnet/buffer.c \
vnet/config.c \
vnet/devices/devices.c \
+ vnet/devices/netlink.c \
+ vnet/flow/flow.c \
+ vnet/flow/flow_cli.c \
vnet/handoff.c \
vnet/interface.c \
vnet/interface_api.c \
vnet/interface_cli.c \
vnet/interface_format.c \
vnet/interface_output.c \
+ vnet/interface_stats.c \
vnet/misc.c \
vnet/replication.c
vnet/buffer.h \
vnet/config.h \
vnet/devices/devices.h \
+ vnet/devices/netlink.h \
+ vnet/flow/flow.h \
vnet/global_funcs.h \
vnet/handoff.h \
vnet/interface.h \
vnet/vnet.h \
vnet/vnet_all_api_h.h \
vnet/vnet_msg_enum.h \
- vnet/util/radix.h
+ vnet/util/radix.h \
+ vnet/util/refcount.h
API_FILES += vnet/interface.api
vnet/ethernet/p2p_ethernet_input.c \
vnet/ethernet/p2p_ethernet_api.c
+libvnet_multiversioning_sources += \
+ vnet/l2/l2_output.c
+
nobase_include_HEADERS += \
vnet/ethernet/arp_packet.h \
vnet/ethernet/error.def \
vnet/l2/l2_fib.c \
vnet/l2/l2_flood.c \
vnet/l2/l2_fwd.c \
- vnet/l2/l2_input_acl.c \
vnet/l2/l2_input.c \
vnet/l2/l2_input_vtr.c \
vnet/l2/l2_learn.c \
- vnet/l2/l2_output_acl.c \
vnet/l2/l2_output.c \
+ vnet/l2/l2_in_out_acl.c \
vnet/l2/l2_patch.c \
vnet/l2/l2_rw.c \
vnet/l2/l2_vtr.c \
API_FILES += vnet/geneve/geneve.api
########################################
-# Layer 2 / CDP
+# Layer 2 / Bonding
########################################
libvnet_la_SOURCES += \
- vnet/cdp/cdp_input.c \
- vnet/cdp/cdp_node.c \
- vnet/cdp/cdp_periodic.c
+ vnet/bonding/cli.c \
+ vnet/bonding/node.c \
+ vnet/bonding/device.c \
+ vnet/bonding/bond_api.c
nobase_include_HEADERS += \
- vnet/cdp/cdp_protocol.h
+ vnet/bonding/node.h \
+ vnet/bonding/bond.api.h
+
+libvnet_multiversioning_sources += \
+ vnet/bonding/node.c
+
+API_FILES += vnet/bonding/bond.api
########################################
# Layer 2 / LLDP
libvnet_la_SOURCES += \
vnet/classify/vnet_classify.c \
vnet/classify/ip_classify.c \
- vnet/classify/input_acl.c \
+ vnet/classify/in_out_acl.c \
vnet/classify/policer_classify.c \
vnet/classify/flow_classify.c \
vnet/classify/flow_classify_node.c \
nobase_include_HEADERS += \
vnet/classify/vnet_classify.h \
- vnet/classify/input_acl.h \
+ vnet/classify/in_out_acl.h \
vnet/classify/policer_classify.h \
vnet/classify/flow_classify.h \
vnet/classify/classify.api.h
vnet/ip/icmp4.c \
vnet/ip/icmp6.c \
vnet/ip/ip46_cli.c \
+ vnet/ip/ip_types_api.c \
vnet/ip/ip4_format.c \
vnet/ip/ip4_forward.c \
vnet/ip/ip4_punt_drop.c \
vnet/ip/ip4_input.c \
+ vnet/ip/ip4_options.c \
vnet/ip/ip4_mtrie.c \
vnet/ip/ip4_pg.c \
vnet/ip/ip4_source_and_port_range_check.c \
vnet/ip/ip4_source_check.c \
+ vnet/ip/ip4_reassembly.c \
vnet/ip/ip6_format.c \
vnet/ip/ip6_forward.c \
+ vnet/ip/ip6_ll_table.c \
+ vnet/ip/ip6_ll_types.c \
vnet/ip/ip6_punt_drop.c \
vnet/ip/ip6_hop_by_hop.c \
vnet/ip/ip6_input.c \
vnet/ip/ip6_neighbor.c \
vnet/ip/ip6_pg.c \
+ vnet/ip/ip6_reassembly.c \
+ vnet/ip/rd_cp.c \
+ vnet/ip/ip_neighbor.c \
vnet/ip/ip_api.c \
vnet/ip/ip_checksum.c \
vnet/ip/ip_frag.c \
vnet/ip/ip.c \
vnet/ip/ip_init.c \
- vnet/ip/ip_input_acl.c \
+ vnet/ip/ip_in_out_acl.c \
vnet/ip/lookup.c \
vnet/ip/ping.c \
+ vnet/ip/punt_api.c \
vnet/ip/punt.c
nobase_include_HEADERS += \
vnet/ip/icmp6.h \
vnet/ip/igmp_packet.h \
vnet/ip/ip.api.h \
+ vnet/ip/rd_cp.api.h \
vnet/ip/ip4_error.h \
vnet/ip/ip4.h \
vnet/ip/ip4_mtrie.h \
vnet/ip/ip.h \
vnet/ip/ip_packet.h \
vnet/ip/ip_source_and_port_range_check.h \
+ vnet/ip/ip_neighbor.h \
vnet/ip/lookup.h \
vnet/ip/ports.def \
vnet/ip/protocols.def \
vnet/ip/punt_error.def \
+ vnet/ip/punt.api.h \
vnet/ip/punt.h
-API_FILES += vnet/ip/ip.api
+API_FILES += \
+ vnet/ip/ip.api \
+ vnet/ip/rd_cp.api \
+ vnet/ip/punt.api
+
+libvnet_multiversioning_sources += \
+ vnet/ip/ip4_input.c
########################################
# Bidirectional Forwarding Detection
vnet/ipsec/ipsec_input.c \
vnet/ipsec/ipsec_if.c \
vnet/ipsec/ipsec_if_in.c \
- vnet/ipsec/ipsec_if_out.c \
vnet/ipsec/esp_format.c \
vnet/ipsec/esp_encrypt.c \
vnet/ipsec/esp_decrypt.c \
+ vnet/ipsec/ah_decrypt.c \
+ vnet/ipsec/ah_encrypt.c \
vnet/ipsec/ikev2.c \
vnet/ipsec/ikev2_crypto.c \
vnet/ipsec/ikev2_cli.c \
nobase_include_HEADERS += \
vnet/ipsec/ipsec.h \
vnet/ipsec/esp.h \
+ vnet/ipsec/ah.h \
vnet/ipsec/ikev2.h \
vnet/ipsec/ikev2_priv.h \
vnet/ipsec/ipsec.api.h
nobase_include_HEADERS += \
vnet/osi/osi.h
-########################################
-# Layer 3 protocol: MAP
-########################################
-libvnet_la_SOURCES += \
- vnet/map/map.c \
- vnet/map/map_dpo.c \
- vnet/map/ip4_map.c \
- vnet/map/ip6_map.c \
- vnet/map/ip4_map_t.c \
- vnet/map/ip6_map_t.c \
- vnet/map/map_api.c
-
-nobase_include_HEADERS += \
- vnet/map/map.h \
- vnet/map/map_dpo.h \
- vnet/map/map.api.h
-
-API_FILES += vnet/map/map.api
-
-if ENABLE_TESTS
-TESTS += test_map
-test_map_SOURCES = \
- vnet/map/test.c
-test_map_CPPFLAGS = $(AM_CPPFLAGS) -DCLIB_DEBUG
-
-test_map_LDADD = libvnet.la libvppinfra.la libvlib.la \
- -lpthread -lvlibmemory -ldl -lsvm -lrt
-
-test_map_LDFLAGS = -static
-endif
-
########################################
# Layer 4 protocol: tcp
########################################
vnet/tcp/tcp_output.c \
vnet/tcp/tcp_input.c \
vnet/tcp/tcp_newreno.c \
- vnet/tcp/builtin_client.c \
- vnet/tcp/builtin_server.c \
- vnet/tcp/builtin_http_server.c \
- vnet/tcp/builtin_proxy.c \
vnet/tcp/tcp_test.c \
vnet/tcp/tcp.c
libvnet_la_SOURCES += \
vnet/udp/udp.c \
vnet/udp/udp_input.c \
- vnet/udp/builtin_server.c \
vnet/udp/udp_format.c \
vnet/udp/udp_local.c \
- vnet/udp/udp_pg.c
+ vnet/udp/udp_pg.c \
+ vnet/udp/udp_encap_node.c \
+ vnet/udp/udp_encap.c \
+ vnet/udp/udp_api.c
nobase_include_HEADERS += \
vnet/udp/udp_error.def \
vnet/udp/udp.h \
- vnet/udp/udp_packet.h
+ vnet/udp/udp_packet.h \
+ vnet/udp/udp.api.h
+
+API_FILES += vnet/udp/udp.api
+
+########################################
+# Layer 4 protocol: sctp
+########################################
+libvnet_la_SOURCES += \
+ vnet/sctp/sctp_api.c \
+ vnet/sctp/sctp.c \
+ vnet/sctp/sctp_pg.c \
+ vnet/sctp/sctp_input.c \
+ vnet/sctp/sctp_output.c \
+ vnet/sctp/sctp_format.c
+
+nobase_include_HEADERS += \
+ vnet/sctp/sctp_error.def \
+ vnet/sctp/sctp_packet.h \
+ vnet/sctp/sctp_timer.h \
+ vnet/sctp/sctp.h \
+ vnet/sctp/sctp.api.h
+
+API_FILES += vnet/sctp/sctp.api
########################################
# Tunnel protocol: gre
API_FILES += vnet/gre/gre.api
+########################################
+# Tunnel protocol: ipip
+########################################
+libvnet_la_SOURCES += \
+ vnet/ipip/ipip.c \
+ vnet/ipip/node.c \
+ vnet/ipip/sixrd.c \
+ vnet/ipip/ipip_api.c \
+ vnet/ipip/ipip_cli.c
+
+nobase_include_HEADERS += \
+ vnet/ipip/ipip.api.h \
+ vnet/ipip/ipip.h
+
+API_FILES += vnet/ipip/ipip.api
+
########################################
# Tunnel protocol: l2tpv3
########################################
########################################
libvnet_la_SOURCES += \
vnet/dhcp/client.c \
- vnet/dhcp/client.h \
+ vnet/dhcp/dhcp_client_detect.c \
+ vnet/dhcp/dhcp6_client_common_dp.c \
+ vnet/dhcp/dhcp6_pd_client_dp.c \
+ vnet/dhcp/dhcp6_pd_client_cp.c \
+ vnet/dhcp/dhcp6_ia_na_client_dp.c \
+ vnet/dhcp/dhcp6_ia_na_client_cp.c \
vnet/dhcp/dhcp_api.c
nobase_include_HEADERS += \
vnet/dhcp/client.h \
- vnet/dhcp/dhcp.api.h
+ vnet/dhcp/dhcp6_client_common_dp.h \
+ vnet/dhcp/dhcp6_pd_client_dp.h \
+ vnet/dhcp/dhcp6_ia_na_client_dp.h \
+ vnet/dhcp/dhcp.api.h \
+ vnet/dhcp/dhcp6_pd_client_cp.api.h \
+ vnet/dhcp/dhcp6_ia_na_client_cp.api.h
-API_FILES += vnet/dhcp/dhcp.api
+API_FILES += \
+ vnet/dhcp/dhcp.api \
+ vnet/dhcp/dhcp6_pd_client_cp.api \
+ vnet/dhcp/dhcp6_ia_na_client_cp.api
########################################
# DHCP proxy
libvnet_la_SOURCES += \
vnet/srmpls/sr_mpls_policy.c \
- vnet/srmpls/sr_mpls_steering.c
+ vnet/srmpls/sr_mpls_steering.c \
+ vnet/srmpls/sr_mpls_api.c
nobase_include_HEADERS += \
- vnet/srmpls/sr.h
+ vnet/srmpls/sr_mpls.h \
+ vnet/srmpls/sr_mpls.api.h
+
+API_FILES += vnet/srmpls/sr_mpls.api
########################################
# IPFIX / netflow v10
########################################
libvnet_la_SOURCES += \
- vnet/flow/flow_report.c \
- vnet/flow/flow_api.c
+ vnet/ipfix-export/flow_report.c \
+ vnet/ipfix-export/flow_api.c
nobase_include_HEADERS += \
- vnet/flow/flow_report.h \
- vnet/flow/ipfix_info_elements.h \
- vnet/flow/ipfix_packet.h \
- vnet/flow/flow.api.h
+ vnet/ipfix-export/flow_report.h \
+ vnet/ipfix-export/ipfix_info_elements.h \
+ vnet/ipfix-export/ipfix_packet.h \
+ vnet/ipfix-export/ipfix_export.api.h
-API_FILES += vnet/flow/flow.api
+API_FILES += vnet/ipfix-export/ipfix_export.api
########################################
# IPFIX classify code
########################################
libvnet_la_SOURCES += \
- vnet/flow/flow_report_classify.c
+ vnet/ipfix-export/flow_report_classify.c
nobase_include_HEADERS += \
- vnet/flow/flow_report_classify.h
+ vnet/ipfix-export/flow_report_classify.h
########################################
# lawful intercept
vnet/dns/dns.h \
vnet/dns/dns_packet.h \
vnet/dns/reply_node.c \
+ vnet/dns/request_node.c \
vnet/dns/resolver_process.c
nobase_include_HEADERS += \
vnet/pg/init.c \
vnet/pg/input.c \
vnet/pg/output.c \
- vnet/pg/stream.c
+ vnet/pg/stream.c \
+ vnet/pg/pg_api.c
nobase_include_HEADERS += \
vnet/pg/pg.h \
- vnet/pg/edit.h
+ vnet/pg/edit.h \
+ vnet/pg/pg.api.h
+
+API_FILES += vnet/pg/pg.api
########################################
# virtio
########################################
-libvnet_la_SOURCES += \
- vnet/devices/virtio/vhost-user.c \
- vnet/devices/virtio/vhost_user_api.c
+libvnet_la_SOURCES += \
+ vnet/devices/virtio/device.c \
+ vnet/devices/virtio/node.c \
+ vnet/devices/virtio/vhost_user.c \
+ vnet/devices/virtio/vhost_user_input.c \
+ vnet/devices/virtio/vhost_user_output.c \
+ vnet/devices/virtio/vhost_user_api.c \
+ vnet/devices/virtio/virtio.c
+
-nobase_include_HEADERS += \
- vnet/devices/virtio/vhost-user.h \
+nobase_include_HEADERS += \
+ vnet/devices/virtio/virtio.h \
+ vnet/devices/virtio/vhost_user.h \
vnet/devices/virtio/vhost_user.api.h
+libvnet_multiversioning_sources += \
+ vnet/devices/virtio/vhost_user_input.c \
+ vnet/devices/virtio/vhost_user_output.c
+
API_FILES += vnet/devices/virtio/vhost_user.api
########################################
-# ssvm ethernet
+# tap interface (with virtio backend)
########################################
-libvnet_la_SOURCES += \
- vnet/devices/ssvm/ssvm_eth.c \
- vnet/devices/ssvm/node.c
-nobase_include_HEADERS += \
- vnet/devices/ssvm/ssvm_eth.h
+libvnet_la_SOURCES += \
+ vnet/devices/tap/cli.c \
+ vnet/devices/tap/tap.c \
+ vnet/devices/tap/tapv2_api.c
+
+nobase_include_HEADERS += \
+ vnet/devices/tap/tap.h \
+ vnet/devices/tap/tapv2.api.h
+
+API_FILES += vnet/devices/tap/tapv2.api
+
+########################################
+# tap interface (with virtio backend)
+########################################
+
+libvnet_la_SOURCES += \
+ vnet/devices/pipe/pipe_api.c \
+ vnet/devices/pipe/pipe.c
+
+nobase_include_HEADERS += \
+ vnet/devices/pipe/pipe.h \
+ vnet/devices/pipe/pipe.api.h
+
+API_FILES += vnet/devices/pipe/pipe.api
########################################
# session managmeent
API_FILES += vnet/session/session.api
+########################################
+# session layer applications
+########################################
+
+libvnet_la_SOURCES += \
+ vnet/session-apps/echo_client.c \
+ vnet/session-apps/echo_server.c \
+ vnet/session-apps/http_server.c \
+ vnet/session-apps/proxy.c
+
+nobase_include_HEADERS += \
+ vnet/session-apps/echo_client.h \
+ vnet/session-apps/proxy.h
+
+########################################
+# TLS protocol
+########################################
+
+libvnet_la_SOURCES += vnet/tls/tls.c
+
+nobase_include_HEADERS += \
+ vnet/tls/tls.h
+
########################################
# Linux packet interface
########################################
libvnet_la_SOURCES += \
vnet/feature/feature.c \
+ vnet/feature/feature_api.c \
vnet/feature/registration.c
nobase_include_HEADERS += \
- vnet/feature/feature.h
+ vnet/feature/feature.h \
+ vnet/feature/feature.api.h
+
+API_FILES += vnet/feature/feature.api
########################################
# Unix kernel related
vnet/fib/fib_entry_src.c \
vnet/fib/fib_entry_src_rr.c \
vnet/fib/fib_entry_src_interface.c \
+ vnet/fib/fib_entry_src_interpose.c \
vnet/fib/fib_entry_src_default_route.c \
vnet/fib/fib_entry_src_special.c \
vnet/fib/fib_entry_src_api.c \
vnet/fib/fib_path_ext.c \
vnet/fib/fib_urpf_list.c \
vnet/fib/fib_attached_export.c \
+ vnet/fib/fib_api.c \
vnet/fib/fib_bfd.c
nobase_include_HEADERS += \
vnet/dpo/dpo.c \
vnet/dpo/drop_dpo.c \
vnet/dpo/ip_null_dpo.c \
+ vnet/dpo/ip6_ll_dpo.c \
vnet/dpo/punt_dpo.c \
vnet/dpo/receive_dpo.c \
vnet/dpo/load_balance.c \
vnet/dpo/mpls_disposition.c \
vnet/dpo/mpls_label_dpo.c \
vnet/dpo/l3_proxy_dpo.c \
- vnet/dpo/l2_bridge_dpo.c
+ vnet/dpo/dvr_dpo.c
nobase_include_HEADERS += \
vnet/dpo/load_balance.h \
########################################
libvnet_la_SOURCES += \
- vnet/util/radix.c \
+ vnet/util/radix.c \
+ vnet/util/refcount.c \
vnet/util/trajectory.c
+########################################
+# QoS
+########################################
+
+libvnet_la_SOURCES += \
+ vnet/qos/qos_types.c \
+ vnet/qos/qos_api.c \
+ vnet/qos/qos_egress_map.c \
+ vnet/qos/qos_record.c \
+ vnet/qos/qos_mark.c
+
+API_FILES += vnet/qos/qos.api
+
+nobase_include_HEADERS += \
+ vnet/qos/qos.api.h
+
+########################################
+# BIER
+########################################
+
+libvnet_la_SOURCES += \
+ vnet/bier/bier_bit_string.c \
+ vnet/bier/bier_entry.c \
+ vnet/bier/bier_fmask.c \
+ vnet/bier/bier_fmask_db.c \
+ vnet/bier/bier_input.c \
+ vnet/bier/bier_lookup.c \
+ vnet/bier/bier_output.c \
+ vnet/bier/bier_table.c \
+ vnet/bier/bier_types.c \
+ vnet/bier/bier_test.c \
+ vnet/bier/bier_api.c \
+ vnet/bier/bier_drop.c \
+ vnet/bier/bier_update.c \
+ vnet/bier/bier_imp_node.c \
+ vnet/bier/bier_imp.c \
+ vnet/bier/bier_disp_entry.c \
+ vnet/bier/bier_disp_lookup_node.c \
+ vnet/bier/bier_disp_dispatch_node.c \
+ vnet/bier/bier_disp_table.c \
+ vnet/bier/bier_bift_table.c
+
+nobase_include_HEADERS += \
+ vnet/bier/bier_types.h \
+ vnet/bier/bier_entry.h \
+ vnet/bier/bier_update.h \
+ vnet/bier/bier.api.h \
+ vnet/bier/bier_table.h
+
+API_FILES += vnet/bier/bier.api
+
+if CPU_X86_64
+if CC_SUPPORTS_AVX2
+###############################################################
+# AVX2
+###############################################################
+libvnet_avx2_la_SOURCES = $(libvnet_multiversioning_sources)
+libvnet_avx2_la_CFLAGS = \
+ $(AM_CFLAGS) @CPU_AVX2_FLAGS@ \
+ -DCLIB_MARCH_VARIANT=avx2
+noinst_LTLIBRARIES += libvnet_avx2.la
+libvnet_la_LIBADD += libvnet_avx2.la
+endif
+
+if CC_SUPPORTS_AVX512
+###############################################################
+# AVX512
+###############################################################
+libvnet_avx512_la_SOURCES = $(libvnet_multiversioning_sources)
+libvnet_avx512_la_CFLAGS = \
+ $(AM_CFLAGS) @CPU_AVX512_FLAGS@ \
+ -DCLIB_MARCH_VARIANT=avx512
+noinst_LTLIBRARIES += libvnet_avx512.la
+libvnet_la_LIBADD += libvnet_avx512.la
+endif
+endif
+
+########################################
+# Test apps
+########################################
+
+noinst_PROGRAMS += tcp_echo udp_echo
+
+TEST_APPS_LDADD = libvlibmemoryclient.la libsvm.la libvppinfra.la
+TEST_APPS_LDADD += -lpthread -lm -lrt
+
+tcp_echo_SOURCES = tests/vnet/session/tcp_echo.c
+tcp_echo_LDADD = $(TEST_APPS_LDADD)
+
+udp_echo_SOURCES = tests/vnet/session/udp_echo.c
+udp_echo_LDADD = $(TEST_APPS_LDADD)
+
########################################
# Plugin client library
########################################
pcap2pg_LDFLAGS = -static
pcap2pg_LDADD = libvnet.la libvppinfra.la -lpthread libvlibmemory.la -lm -ldl
-noinst_PROGRAMS += pcap2pg
+pcap2cinit_SOURCES = \
+ vnet/unix/pcap2cinit.c \
+ vnet/unix/pcap.h
+
+pcap2cinit_LDFLAGS = -static
+pcap2cinit_LDADD = libvnet.la libvppinfra.la -lpthread libvlibmemory.la -lm -ldl
+
+noinst_PROGRAMS += pcap2pg pcap2cinit
# vi:syntax=automake