libvlib.la \
libsvmdb.la \
libsvm.la \
- libvlibapi.la \
- libvlibmemory.la \
- libvlibmemoryclient.la
+ libvlibmemory.la
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/handoff.c \
vnet/interface.c \
vnet/interface_api.c \
vnet/interface_format.c \
vnet/interface_output.c \
vnet/misc.c \
- vnet/replication.c \
- vnet/rewrite.c
+ vnet/replication.c
nobase_include_HEADERS += \
vnet/api_errno.h \
vnet/buffer.h \
vnet/config.h \
vnet/devices/devices.h \
+ vnet/devices/netlink.h \
vnet/global_funcs.h \
vnet/handoff.h \
vnet/interface.h \
vnet/interface.api.h \
vnet/interface_funcs.h \
+ vnet/ip/ip4_to_ip6.h \
+ vnet/ip/ip6_to_ip4.h \
vnet/l3_types.h \
vnet/pipeline.h \
vnet/replication.h \
- vnet/rewrite.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/init.c \
vnet/ethernet/interface.c \
vnet/ethernet/node.c \
- vnet/ethernet/pg.c
+ vnet/ethernet/pg.c \
+ vnet/ethernet/sfp.c \
+ vnet/ethernet/p2p_ethernet.c \
+ vnet/ethernet/p2p_ethernet_input.c \
+ vnet/ethernet/p2p_ethernet_api.c
nobase_include_HEADERS += \
vnet/ethernet/arp_packet.h \
vnet/ethernet/error.def \
vnet/ethernet/ethernet.h \
vnet/ethernet/packet.h \
- vnet/ethernet/types.def
+ vnet/ethernet/types.def \
+ vnet/ethernet/sfp.h \
+ vnet/ethernet/p2p_ethernet.api.h \
+ vnet/ethernet/p2p_ethernet.h
+
+API_FILES += vnet/ethernet/p2p_ethernet.api
########################################
# Layer 2 protocol: Ethernet bridging
API_FILES += vnet/vxlan/vxlan.api
+########################################
+# Layer 2 / Geneve
+########################################
+libvnet_la_SOURCES += \
+ vnet/geneve/geneve.c \
+ vnet/geneve/encap.c \
+ vnet/geneve/decap.c \
+ vnet/geneve/geneve_api.c
+
+nobase_include_HEADERS += \
+ vnet/geneve/geneve.h \
+ vnet/geneve/geneve_packet.h \
+ vnet/geneve/geneve_error.def \
+ vnet/geneve/geneve.api.h
+
+API_FILES += vnet/geneve/geneve.api
+
########################################
# Layer 2 / CDP
########################################
vnet/lldp/lldp_input.c \
vnet/lldp/lldp_node.c \
vnet/lldp/lldp_output.c \
- vnet/lldp/lldp_cli.c
+ vnet/lldp/lldp_cli.c \
+ vnet/lldp/lldp_api.c
nobase_include_HEADERS += \
- vnet/lldp/lldp_protocol.h
+ vnet/lldp/lldp_protocol.h \
+ vnet/lldp/lldp.h \
+ vnet/lldp/lldp.api.h
+
+API_FILES += vnet/lldp/lldp.api
########################################
# Layer 2/3 "classify"
vnet/ip/ip46_cli.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_mtrie.c \
vnet/ip/ip4_pg.c \
vnet/ip/ip4_source_check.c \
vnet/ip/ip6_format.c \
vnet/ip/ip6_forward.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/ip_api.c \
vnet/ip/ip_checksum.c \
vnet/ip/ip_frag.c \
- vnet/ip/ip.h \
+ vnet/ip/ip.c \
vnet/ip/ip_init.c \
vnet/ip/ip_input_acl.c \
vnet/ip/lookup.c \
vnet/ip/ping.c \
+ vnet/ip/punt_api.c \
vnet/ip/punt.c
nobase_include_HEADERS += \
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/punt.api
########################################
# Bidirectional Forwarding Detection
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
test_map_CPPFLAGS = $(AM_CPPFLAGS) -DCLIB_DEBUG
test_map_LDADD = libvnet.la libvppinfra.la libvlib.la \
- -lpthread -lvlibmemory -lvlibapi \
- -ldl -lsvm -lrt
+ -lpthread -lvlibmemory -ldl -lsvm -lrt
test_map_LDFLAGS = -static
endif
# Layer 4 protocol: tcp
########################################
libvnet_la_SOURCES += \
+ vnet/tcp/tcp_api.c \
vnet/tcp/tcp_format.c \
vnet/tcp/tcp_pg.c \
vnet/tcp/tcp_syn_filter4.c \
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
nobase_include_HEADERS += \
vnet/tcp/tcp_packet.h \
vnet/tcp/tcp_timer.h \
- vnet/tcp/tcp.h
+ vnet/tcp/tcp_debug.h \
+ vnet/tcp/tcp.h \
+ vnet/tcp/tcp.api.h
+
+API_FILES += vnet/tcp/tcp.api
########################################
# Layer 4 protocol: udp
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
########################################
# Tunnel protocol: gre
vnet/mpls/mpls_lookup.c \
vnet/mpls/mpls_output.c \
vnet/mpls/mpls_features.c \
- vnet/mpls/node.c \
+ vnet/mpls/mpls_input.c \
vnet/mpls/interface.c \
vnet/mpls/mpls_tunnel.c \
vnet/mpls/pg.c \
libvlib.la \
libsvm.la \
libsvmdb.la \
- libvlibapi.la \
libvlibmemory.la \
-lpthread -ldl -lrt -lm
API_FILES += vnet/lisp-gpe/lisp_gpe.api
-if ENABLE_TESTS
-TESTS += test_test
-
-test_test_SOURCES = tests/vnet/lisp-gpe/test.c
-
-test_test_CPPFLAGS = $(AM_CPPFLAGS) -DCLIB_DEBUG
-
-test_test_LDADD = $(LIBOBJS)
-
-noinst_PROGRAMS += $(TESTS)
-check_PROGRAMS += $(TESTS)
-endif
-
########################################
# DHCP client
########################################
# ipv6 segment routing
########################################
-if WITH_LIBSSL
libvnet_la_SOURCES += \
- vnet/sr/sr.c \
- vnet/sr/sr_localsid.c \
- vnet/sr/sr_policy_rewrite.c \
- vnet/sr/sr_steering.c \
- vnet/sr/sr_api.c
-endif
+ vnet/srv6/sr.c \
+ vnet/srv6/sr_localsid.c \
+ vnet/srv6/sr_policy_rewrite.c \
+ vnet/srv6/sr_steering.c \
+ vnet/srv6/sr_api.c
nobase_include_HEADERS += \
- vnet/sr/sr_packet.h \
- vnet/sr/sr.h \
- vnet/sr/sr.api.h
+ vnet/srv6/sr_packet.h \
+ vnet/srv6/sr.h \
+ vnet/srv6/sr.api.h
-API_FILES += vnet/sr/sr.api
+API_FILES += vnet/srv6/sr.api
+
+########################################
+# mpls segment routing
+########################################
+
+libvnet_la_SOURCES += \
+ vnet/srmpls/sr_mpls_policy.c \
+ vnet/srmpls/sr_mpls_steering.c
+
+
+nobase_include_HEADERS += \
+ vnet/srmpls/sr.h
########################################
# IPFIX / netflow v10
API_FILES += vnet/span/span.api
+########################################
+# DNS proxy, API
+########################################
+libvnet_la_SOURCES += \
+ vnet/dns/dns.c \
+ 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/dns/dns.api.h \
+ vnet/dns/dns.h
+
+API_FILES += vnet/dns/dns.api
+
########################################
# Packet generator
########################################
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
-if !WITH_DPDK
-libvnet_la_SOURCES += \
- vnet/devices/nic/ixge.c \
- vnet/devices/nic/ixge.h \
- vnet/devices/nic/sfp.c \
- vnet/devices/nic/sfp.h
-endif
+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_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
API_FILES += vnet/devices/virtio/vhost_user.api
+########################################
+# tap interface (with virtio backend)
+########################################
+
+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
+
########################################
# ssvm ethernet
########################################
libvnet_la_SOURCES += \
vnet/session/session.c \
- vnet/session/node.c \
+ vnet/session/session_table.c \
+ vnet/session/session_rules_table.c \
+ vnet/session/session_lookup.c \
+ vnet/session/session_node.c \
vnet/session/transport.c \
vnet/session/application.c \
vnet/session/session_cli.c \
- vnet/session/hashes.c \
vnet/session/application_interface.c \
+ vnet/session/application_namespace.c \
+ vnet/session/segment_manager.c \
+ vnet/session/session_test.c \
vnet/session/session_api.c
nobase_include_HEADERS += \
vnet/session/session.h \
+ vnet/session/session_table.h \
+ vnet/session/session_rules_table.h \
+ vnet/session/stream_session.h \
+ vnet/session/session_lookup.h \
vnet/session/application.h \
vnet/session/transport.h \
- vnet/session/application_interface.h
+ vnet/session/transport_interface.h \
+ vnet/session/application_interface.h \
+ vnet/session/application_namespace.h \
+ vnet/session/session_debug.h \
+ vnet/session/segment_manager.h \
+ vnet/session/mma_template.h \
+ vnet/session/mma_template.c \
+ vnet/session/mma_16.h \
+ vnet/session/mma_40.h \
+ vnet/session/session.api.h
API_FILES += vnet/session/session.api
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_path.c \
vnet/fib/fib_path_ext.c \
vnet/fib/fib_urpf_list.c \
- vnet/fib/fib_attached_export.c
+ vnet/fib/fib_attached_export.c \
+ vnet/fib/fib_bfd.c
nobase_include_HEADERS += \
vnet/fib/fib.h \
vnet/adj/adj_mcast.c \
vnet/adj/adj_l2.c \
vnet/adj/adj_nsh.c \
- vnet/adj/adj.c
+ vnet/adj/adj.c \
+ vnet/adj/rewrite.c \
+ vnet/adj/adj_bfd.c \
+ vnet/adj/adj_delegate.c
nobase_include_HEADERS += \
vnet/adj/adj.h \
vnet/adj/adj_types.h \
vnet/adj/adj_glean.h \
vnet/adj/adj_nsh.h \
- vnet/adj/adj_nbr.h
+ vnet/adj/adj_nbr.h \
+ vnet/adj/rewrite.h
########################################
# Data-Plane Objects
vnet/dpo/lookup_dpo.c \
vnet/dpo/classify_dpo.c \
vnet/dpo/replicate_dpo.c \
- vnet/dpo/mpls_label_dpo.c
+ vnet/dpo/interface_rx_dpo.c \
+ vnet/dpo/interface_tx_dpo.c \
+ vnet/dpo/mpls_disposition.c \
+ vnet/dpo/mpls_label_dpo.c \
+ vnet/dpo/l3_proxy_dpo.c \
+ vnet/dpo/l2_bridge_dpo.c
nobase_include_HEADERS += \
vnet/dpo/load_balance.h \
vnet/dpo/classify_dpo.h \
vnet/dpo/receive_dpo.h \
vnet/dpo/ip_null_dpo.h \
+ vnet/dpo/replicate_dpo.h \
vnet/dpo/dpo.h
########################################
########################################
libvnet_la_SOURCES += \
- vnet/util/radix.c
+ vnet/util/radix.c \
+ vnet/util/refcount.c \
+ vnet/util/trajectory.c
+
+########################################
+# 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
+
+########################################
+# 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