Periodic scan and probe of IP neighbors to maintain neighbor pools
[vpp.git] / src / vnet.am
index 97964c5..3a1e10d 100644 (file)
@@ -31,14 +31,19 @@ endif
 # 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
 
@@ -47,6 +52,8 @@ nobase_include_HEADERS +=                     \
   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                             \
@@ -60,7 +67,8 @@ nobase_include_HEADERS +=                     \
   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
 
@@ -144,12 +152,11 @@ libvnet_la_SOURCES +=                             \
  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                              \
@@ -270,15 +277,19 @@ nobase_include_HEADERS +=                 \
 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
+
+API_FILES += vnet/bonding/bond.api
 
 ########################################
 # Layer 2 / LLDP
@@ -303,7 +314,7 @@ API_FILES += vnet/lldp/lldp.api
 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            \
@@ -312,7 +323,7 @@ libvnet_la_SOURCES +=                               \
 
 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
@@ -339,21 +350,28 @@ libvnet_la_SOURCES +=                             \
  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 +=                      \
@@ -363,6 +381,7 @@ 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                           \
@@ -376,13 +395,18 @@ nobase_include_HEADERS +=                 \
  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
 
 ########################################
 # Bidirectional Forwarding Detection
@@ -420,6 +444,8 @@ libvnet_la_SOURCES +=                               \
  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                                \
@@ -436,6 +462,7 @@ libvnet_la_SOURCES +=                               \
 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
@@ -493,10 +520,6 @@ libvnet_la_SOURCES +=                              \
  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
 
@@ -515,15 +538,40 @@ API_FILES += vnet/tcp/tcp.api
 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
@@ -543,6 +591,22 @@ nobase_include_HEADERS +=                  \
 
 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
 ########################################
@@ -707,7 +771,7 @@ API_FILES += vnet/lisp-gpe/lisp_gpe.api
 ########################################
 libvnet_la_SOURCES +=                          \
  vnet/dhcp/client.c                            \
- vnet/dhcp/client.h                            \
+ vnet/dhcp/dhcp_client_detect.c                        \
  vnet/dhcp/dhcp_api.c
 
 nobase_include_HEADERS +=                      \
@@ -755,36 +819,40 @@ API_FILES += vnet/srv6/sr.api
 
 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
@@ -820,6 +888,7 @@ libvnet_la_SOURCES +=                               \
  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 +=                      \
@@ -838,35 +907,49 @@ libvnet_la_SOURCES +=                             \
   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_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
 
 ########################################
-# 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
 
 ########################################
 # session managmeent
@@ -875,6 +958,7 @@ nobase_include_HEADERS +=                   \
 libvnet_la_SOURCES +=                          \
   vnet/session/session.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                     \
@@ -889,6 +973,7 @@ libvnet_la_SOURCES +=                               \
 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                   \
@@ -898,10 +983,37 @@ nobase_include_HEADERS +=                 \
   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
 
+########################################
+# 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
 ########################################
@@ -942,10 +1054,14 @@ API_FILES += vnet/devices/netmap/netmap.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
@@ -987,6 +1103,7 @@ libvnet_la_SOURCES +=                              \
   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                  \
@@ -1000,6 +1117,7 @@ libvnet_la_SOURCES +=                             \
   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 +=                      \
@@ -1046,6 +1164,7 @@ libvnet_la_SOURCES +=                             \
   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                      \
@@ -1057,7 +1176,8 @@ libvnet_la_SOURCES +=                             \
   vnet/dpo/interface_tx_dpo.c                          \
   vnet/dpo/mpls_disposition.c                  \
   vnet/dpo/mpls_label_dpo.c                    \
-  vnet/dpo/l2_bridge_dpo.c
+  vnet/dpo/l3_proxy_dpo.c                      \
+  vnet/dpo/dvr_dpo.c
 
 nobase_include_HEADERS +=                      \
   vnet/dpo/load_balance.h                      \
@@ -1067,6 +1187,7 @@ nobase_include_HEADERS +=                 \
   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
 
 ########################################
@@ -1094,7 +1215,75 @@ nobase_include_HEADERS +=                        \
 ########################################
 
 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
+
+########################################
+# 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
@@ -1110,6 +1299,13 @@ pcap2pg_SOURCES =                                \
 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