blob: 7796d30bf1190ca4e4535d0c4cf4609ab341920f [file] [log] [blame]
/*
* Copyright (c) 2018, 2020 The Linux Foundation. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are
* met:
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above
* copyright notice, this list of conditions and the following
* disclaimer in the documentation and/or other materials provided
* with the distribution.
* * Neither the name of The Linux Foundation nor the names of its
* contributors may be used to endorse or promote products derived
* from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
* ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
* BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
* CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
* SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
* BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
* OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
* IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#ifndef IPA_IPV6CT_H
#define IPA_IPV6CT_H
#include <stdint.h>
#include <stdbool.h>
#include <linux/msm_ipa.h>
/**
* enum ipa_ipv6_ct_direction_settings_type - direction filter settings
*
* IPA_IPV6CT_DIRECTION_DENY_ALL - deny inbound and outbound
* IPA_IPV6CT_DIRECTION_ALLOW_OUT - allow outbound and deny inbound
* IPA_IPV6CT_DIRECTION_ALLOW_IN - allow inbound and deny outbound
* IPA_IPV6CT_DIRECTION_ALLOW_ALL - allow inbound and outbound
*/
typedef enum
{
IPA_IPV6CT_DIRECTION_DENY_ALL = 0,
IPA_IPV6CT_DIRECTION_ALLOW_OUT = 1,
IPA_IPV6CT_DIRECTION_ALLOW_IN = 2,
IPA_IPV6CT_DIRECTION_ALLOW_ALL = 3
} ipa_ipv6_ct_direction_settings_type;
/**
* struct ipa_ipv6ct_rule - To hold IPv6CT rule
* @src_ipv6_lsb: source IPv6 address LSB
* @src_ipv6_msb: source IPv6 address MSB
* @dest_ipv6_lsb: destination IPv6 address LSB
* @dest_ipv6_msb: destination IPv6 address MSB
* @direction_settings: direction filter settings (inbound/outbound) (see ipa_ipv6_ct_direction_settings_type)
* @src_port: source port
* @dest_port: destination port
* @protocol: protocol of rule (tcp/udp)
* @uc_activation_index: index pointing to uc activation table
* @s: bit indication to use the system or local (1 or 0) addr for above table
* @ucp: enable uc processing
*/
typedef struct {
uint64_t src_ipv6_lsb;
uint64_t src_ipv6_msb;
uint64_t dest_ipv6_lsb;
uint64_t dest_ipv6_msb;
ipa_ipv6_ct_direction_settings_type direction_settings;
bool ucp;
bool s;
uint16_t uc_activation_index;
uint16_t src_port;
uint16_t dest_port;
uint8_t protocol;
} ipa_ipv6ct_rule;
/**
* ipa_ipv6ct_add_tbl() - create IPv6CT table
* @number_of_entries: [in] number of IPv6CT entries
* @table_handle: [out] handle of new IPv6CT table
*
* To create new IPv6CT table
*
* Returns: 0 On Success, negative on failure
*/
int ipa_ipv6ct_add_tbl(uint16_t number_of_entries, uint32_t* table_handle);
/**
* ipa_ipv6ct_del_tbl() - delete IPv6CT table
* @table_handle: [in] Handle of IPv6CT table
*
* To delete given IPv6CT table
*
* Returns: 0 On Success, negative on failure
*/
int ipa_ipv6ct_del_tbl(uint32_t table_handle);
/**
* ipa_ipv6ct_add_rule() - to insert new IPv6CT rule
* @table_handle: [in] handle of IPv6CT table
* @user_rule: [in] Pointer to new rule
* @rule_handle: [out] Return the handle to rule
*
* To insert new rule into a IPv6CT table
*
* Returns: 0 On Success, negative on failure
*/
int ipa_ipv6ct_add_rule(uint32_t table_handle, const ipa_ipv6ct_rule* user_rule, uint32_t* rule_handle);
/**
* ipa_ipv6ct_del_rule() - to delete IPv6CT rule
* @table_handle: [in] handle of IPv6CT table
* @rule_handle: [in] IPv6CT rule handle
*
* To delete a rule from a IPv6CT table
*
* Returns: 0 On Success, negative on failure
*/
int ipa_ipv6ct_del_rule(uint32_t table_handle, uint32_t rule_handle);
/**
* ipa_ipv6ct_query_timestamp() - to query timestamp
* @table_handle: [in] handle of IPv6CT table
* @rule_handle: [in] IPv6CT rule handle
* @time_stamp: [out] time stamp of rule
*
* To retrieve the timestamp that lastly the IPv6CT rule was accessed
*
* Returns: 0 On Success, negative on failure
*/
int ipa_ipv6ct_query_timestamp(uint32_t table_handle, uint32_t rule_handle, uint32_t* time_stamp);
/**
* ipa_ipv6ct_dump_table() - dumps IPv6CT table
* @table_handle: [in] handle of IPv6CT table
*/
void ipa_ipv6ct_dump_table(uint32_t tbl_hdl);
/**
* ipa_ipv6ct_add_uc_act_entry() - add uc activation entry
* @u: [in] structure specifying the uC activation entry
*
* Returns: 0 On Success, negative on failure
*/
int ipa_ipv6ct_add_uc_act_entry(union ipa_ioc_uc_activation_entry *u);
/**
* ipa_ipv6ct_del_uc_act_entry() - del uc activation entry
* @index: [in] index of the uc activation entry to be removed
*
* Returns: 0 On Success, negative on failure
*/
int ipa_ipv6ct_del_uc_act_entry(uint16_t index);
#endif