blob: ec627899a3fc68adebf66cbdb75ae186325514ec [file] [log] [blame]
/*
* Copyright (c) 2019 Cisco and/or its affiliates.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at:
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/**
* @file
* @brief NAT active-passive HA
*/
#ifndef __included_nat_ha_h__
#define __included_nat_ha_h__
#include <vnet/vnet.h>
#include <vnet/ip/ip.h>
/* Call back functions for received HA events on passive/failover */
typedef void (*nat_ha_sadd_cb_t) (ip4_address_t * in_addr, u16 in_port,
ip4_address_t * out_addr, u16 out_port,
ip4_address_t * eh_addr, u16 eh_port,
ip4_address_t * ehn_addr, u16 ehn_port,
u8 proto, u32 fib_index, u16 flags,
u32 thread_index);
typedef void (*nat_ha_sdel_cb_t) (ip4_address_t * out_addr, u16 out_port,
ip4_address_t * eh_addr, u16 eh_port,
u8 proto, u32 fib_index, u32 thread_index);
typedef void (*nat_ha_sref_cb_t) (ip4_address_t * out_addr, u16 out_port,
ip4_address_t * eh_addr, u16 eh_port,
u8 proto, u32 fib_index, u32 total_pkts,
u64 total_bytes, u32 thread_index);
/**
* @brief Initialize NAT HA
*/
void nat_ha_init (vlib_main_t * vm, nat_ha_sadd_cb_t sadd_cb,
nat_ha_sdel_cb_t sdel_cb, nat_ha_sref_cb_t sref_cb);
/**
* @brief Set HA listener (local settings)
*
* @param addr local IP4 address
* @param port local UDP port number
* @param path_mtu path MTU between local and failover
*
* @returns 0 on success, non-zero value otherwise.
*/
int nat_ha_set_listener (ip4_address_t * addr, u16 port, u32 path_mtu);
/**
* @brief Get HA listener/local configuration
*/
void nat_ha_get_listener (ip4_address_t * addr, u16 * port, u32 * path_mtu);
/**
* @brief Set HA failover (remote settings)
*
* @param addr failover IP4 address
* @param port failvoer UDP port number
* @param session_refresh_interval number of seconds after which to send
* session counters refresh
*
* @returns 0 on success, non-zero value otherwise.
*/
int nat_ha_set_failover (ip4_address_t * addr, u16 port,
u32 session_refresh_interval);
/**
* @brief Get HA failover/remote settings
*/
void nat_ha_get_failover (ip4_address_t * addr, u16 * port,
u32 * session_refresh_interval);
/**
* @brief Create session add HA event
*
* @param in_addr inside IPv4 address
* @param in_port inside L4 port number
* @param out_addr outside IPv4 address
* @param out_port outside L4 port number
* @param eh_addr external host IPv4 address
* @param eh_port external host L4 port number
* @param ehn_addr external host IPv4 address after translation
* @param ehn_port external host L4 port number after translation
* @param proto L4 protocol
* @param fib_index fib index
* @param flags session flags
* @param thread_index thread index
* @param is_resync 1 if HA resync
*/
void nat_ha_sadd (ip4_address_t * in_addr, u16 in_port,
ip4_address_t * out_addr, u16 out_port,
ip4_address_t * eh_addr, u16 eh_port,
ip4_address_t * ehn_addr, u16 ehn_port, u8 proto,
u32 fib_index, u16 flags, u32 thread_index, u8 is_resync);
/**
* @brief Create session delete HA event
*
* @param out_addr outside IPv4 address
* @param out_port outside L4 port number
* @param eh_addr external host IPv4 address
* @param eh_port external host L4 port number
* @param proto L4 protocol
* @param fib_index fib index
* @param thread_index thread index
*/
void nat_ha_sdel (ip4_address_t * out_addr, u16 out_port,
ip4_address_t * eh_addr, u16 eh_port, u8 proto,
u32 fib_index, u32 thread_index);
/**
* @brief Create session refresh HA event
*
* @param out_addr outside IPv4 address
* @param out_port outside L4 port number
* @param eh_addr external host IPv4 address
* @param eh_port external host L4 port number
* @param proto L4 protocol
* @param fib_index fib index
* @param total_pkts total packets processed
* @param total_bytes total bytes processed
* @param thread_index thread index
* @param last_refreshed last session refresh time
* @param now current time
*/
void nat_ha_sref (ip4_address_t * out_addr, u16 out_port,
ip4_address_t * eh_addr, u16 eh_port, u8 proto,
u32 fib_index, u32 total_pkts, u64 total_bytes,
u32 thread_index, f64 * last_refreshed, f64 now);
/**
* @brief Flush the current HA data (for testing)
*/
void nat_ha_flush (u8 is_resync);
typedef void (*nat_ha_resync_event_cb_t) (u32 client_index, u32 pid,
u32 missed_count);
/**
* @brief Resync HA (resend existing sessions to new failover)
*/
int nat_ha_resync (u32 client_index, u32 pid,
nat_ha_resync_event_cb_t event_callback);
/**
* @brief Get resync status
*
* @param in_resync 1 if resync in progress
* @param resync_ack_missed number of missed (not ACKed) messages
*/
void nat_ha_get_resync_status (u8 * in_resync, u32 * resync_ack_missed);
#endif /* __included_nat_ha_h__ */
/*
* fd.io coding-style-patch-verification: ON
*
* Local Variables:
* eval: (c-set-style "gnu")
* End:
*/