X-Git-Url: https://gerrit.fd.io/r/gitweb?p=vpp.git;a=blobdiff_plain;f=src%2Fvnet%2Fdevices%2Ftap%2Ftap.h;h=19dc88dd7c6a730d5d3f6cdc3d777258e48bc32b;hp=7d07ffb4e82ab738c567f1c4dc6abb8993021ff9;hb=754f24b35;hpb=2df39094d20ae60d2e04316f4ec058f81778cf64 diff --git a/src/vnet/devices/tap/tap.h b/src/vnet/devices/tap/tap.h index 7d07ffb4e82..19dc88dd7c6 100644 --- a/src/vnet/devices/tap/tap.h +++ b/src/vnet/devices/tap/tap.h @@ -29,14 +29,19 @@ typedef struct u8 mac_addr[6]; u16 rx_ring_sz; u16 tx_ring_sz; + u32 tap_flags; u8 *host_namespace; u8 *host_if_name; u8 host_mac_addr[6]; u8 *host_bridge; ip4_address_t host_ip4_addr; - u32 host_ip4_prefix_len; + u8 host_ip4_prefix_len; + ip4_address_t host_ip4_gw; + u8 host_ip4_gw_set; ip6_address_t host_ip6_addr; - u32 host_ip6_prefix_len; + u8 host_ip6_prefix_len; + ip6_address_t host_ip6_gw; + u8 host_ip6_gw_set; /* return */ u32 sw_if_index; int rv; @@ -46,14 +51,29 @@ typedef struct /** TAP interface details struct */ typedef struct { + u32 id; u32 sw_if_index; + u32 tap_flags; u8 dev_name[64]; + u16 tx_ring_sz; + u16 rx_ring_sz; + u8 host_mac_addr[6]; + u8 host_if_name[64]; + u8 host_namespace[64]; + u8 host_bridge[64]; + u8 host_ip4_addr[4]; + u8 host_ip4_prefix_len; + u8 host_ip6_addr[16]; + u8 host_ip6_prefix_len; } tap_interface_details_t; typedef struct { - u32 last_used_interface_id; - uword *dev_instance_by_interface_id; + /* logging */ + vlib_log_class_t log_default; + + /* bit-map of in-use IDs */ + uword *tap_ids; } tap_main_t; void tap_create_if (vlib_main_t * vm, tap_create_if_args_t * args);