blob: e6597b35a7dc8a8d67558fe73d44f7fbc05941ed [file] [log] [blame]
Ben Menchaca84f36632014-02-28 20:57:38 +00001/*
2 **************************************************************************
Suman Ghosh812ad302018-05-09 21:07:50 +05303 * Copyright (c) 2014-2018 The Linux Foundation. All rights reserved.
Ben Menchaca84f36632014-02-28 20:57:38 +00004 * Permission to use, copy, modify, and/or distribute this software for
5 * any purpose with or without fee is hereby granted, provided that the
6 * above copyright notice and this permission notice appear in all copies.
7 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
8 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
9 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
10 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
11 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
12 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT
13 * OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
14 **************************************************************************
15 */
16
Murat Sezgineebedb92017-11-17 17:14:32 -080017extern int ecm_interface_src_check; /* Source interface check flag */
18
Ben Menchaca84f36632014-02-28 20:57:38 +000019/*
Ben Menchaca84f36632014-02-28 20:57:38 +000020 * struct ecm_interface_route
21 * An ecm route supports either v4 or v6 routing information
22 */
23struct ecm_interface_route {
Murat Sezgin313f2222016-08-11 12:22:10 -070024 struct dst_entry *dst; /* Both ipv4 and v6 have a common dst entry. It is an overlay pointer of rtv4 or rtv6 */
Ben Menchaca84f36632014-02-28 20:57:38 +000025 union {
26 struct rtable *rtv4; /* IPv4 route */
27 struct rt6_info *rtv6; /* IPv6 route */
28 } rt;
29 bool v4_route; /* True when a v4 route, false when v6 */
30};
31
32/*
Shyam Sunder6358b862015-05-04 15:06:24 +053033 * Netdev Index value for a Loopback device
34 */
35#define ECM_INTERFACE_LOOPBACK_DEV_INDEX 1
36
37/*
Thomas Wu0d645982016-01-24 12:27:54 -080038 * IPSec Core and Interface Definition
39 */
40#define ECM_INTERFACE_IPSEC_DEFAULT_CORE 0x2
41#define ECM_INTERFACE_IPSEC_CORE_OFFSET 24
42#define ECM_INTERFACE_IPSEC_IF_NUM ((ECM_INTERFACE_IPSEC_DEFAULT_CORE << ECM_INTERFACE_IPSEC_CORE_OFFSET) | NSS_IPSEC_RULE_INTERFACE)
43
44/*
Ben Menchaca84f36632014-02-28 20:57:38 +000045 * External defined functions
46 */
47extern struct net_device *bond_get_tx_dev(struct sk_buff *skb, uint8_t *src_mac,
48 uint8_t *dst_mac, void *src,
49 void *dst, uint16_t protocol,
Suman Ghoshfb8e7702015-08-20 15:27:57 +053050 struct net_device *bond_dev,
51 __be16 *layer4hdr);
Murat Sezgin5dae8832015-12-03 14:23:19 -080052bool ecm_interface_mac_addr_get_no_route(struct net_device *dev, ip_addr_t ip_addr, uint8_t *mac_addr);
Ben Menchaca84f36632014-02-28 20:57:38 +000053bool ecm_interface_mac_addr_get(ip_addr_t addr, uint8_t *mac_addr, bool *on_link, ip_addr_t gw_addr);
54bool ecm_interface_find_route_by_addr(ip_addr_t addr, struct ecm_interface_route *ecm_rt);
55void ecm_interface_route_release(struct ecm_interface_route *rt);
Murat Sezgin188b4a32015-06-03 10:58:59 -070056#ifdef ECM_IPV6_ENABLE
57void ecm_interface_send_neighbour_solicitation(struct net_device *dev, ip_addr_t addr);
58#endif
59void ecm_interface_send_arp_request(struct net_device *dest_dev, ip_addr_t dest_addr, bool on_link, ip_addr_t gw_addr);
Xiaoping Fanc7735462015-08-09 18:57:26 -070060struct neighbour *ecm_interface_ipv4_neigh_get(ip_addr_t addr);
61#ifdef ECM_IPV6_ENABLE
62struct neighbour *ecm_interface_ipv6_neigh_get(ip_addr_t addr);
63#endif
Shyam Sunder2ca02492016-08-05 20:55:12 +053064bool ecm_interface_is_pptp(struct sk_buff *skb, const struct net_device *out);
65bool ecm_interface_is_l2tp_packet_by_version(struct sk_buff *skb, const struct net_device *out, int ver);
66bool ecm_interface_is_l2tp_pptp(struct sk_buff *skb, const struct net_device *out);
ratheesh kannotha32fdd12015-09-09 08:02:58 +053067struct ecm_db_iface_instance *ecm_interface_establish_and_ref(struct ecm_front_end_connection_instance *feci, struct net_device *dev, struct sk_buff *skb);
Shyam Sunder6358b862015-05-04 15:06:24 +053068
69#ifdef ECM_MULTICAST_ENABLE
Shyam Sundera2e08ee2015-06-18 21:32:13 +053070int32_t ecm_interface_multicast_heirarchy_construct_routed(struct ecm_front_end_connection_instance *feci, struct ecm_db_iface_instance *interfaces, struct net_device *in_dev, ip_addr_t packet_src_addr, ip_addr_t packet_dest_addr, uint8_t maxvif, uint32_t *dst_dev, uint32_t *to_interface_first, bool mfc_update, __be16 *layer4hdr, struct sk_buff *skb);
Shyam Sunder6358b862015-05-04 15:06:24 +053071
ratheesh kannotha32fdd12015-09-09 08:02:58 +053072int32_t ecm_interface_multicast_heirarchy_construct_bridged(struct ecm_front_end_connection_instance *feci, struct ecm_db_iface_instance *interfaces, struct net_device *br_dev, ip_addr_t src_addr, ip_addr_t dest_addr, uint8_t mc_max_dst, int32_t *mc_dst_dev, uint32_t *to_interface_first, uint8_t *src_node_addr, __be16 *layer4hdr, struct sk_buff *skb);
Shyam Sunder6358b862015-05-04 15:06:24 +053073
74void ecm_interface_multicast_stats_update(struct ecm_db_connection_instance *ci, uint32_t from_tx_packets, uint32_t from_tx_bytes, uint32_t from_rx_packets, uint32_t from_rx_bytes, uint32_t to_tx_packets, uint32_t to_tx_bytes, uint32_t to_rx_packets, uint32_t to_rx_bytes);
75
76bool ecm_interface_multicast_find_updates_to_iface_list(struct ecm_db_connection_instance *ci, struct ecm_multicast_if_update *, uint32_t flags, bool is_br_snooper, uint32_t *dst_dev, uint32_t max_to_dev);
77
78bool ecm_interface_multicast_check_for_br_dev(uint32_t dest_if[], uint8_t max_if);
ratheesh kannothc5df16c2018-03-16 21:07:23 +053079bool ecm_interface_multicast_is_iface_type(int32_t mc_if_index[], int32_t max_if_index, unsigned short type);
Shyam Sundera2e08ee2015-06-18 21:32:13 +053080
81int32_t ecm_interface_multicast_check_for_src_ifindex(int32_t mc_if_index[], int32_t max_if_index, int32_t if_num);
Murat Sezgin5dae8832015-12-03 14:23:19 -080082int32_t ecm_interface_multicast_from_heirarchy_construct(struct ecm_front_end_connection_instance *feci,
Murat Sezgin91c5d712015-06-12 15:16:22 -070083 struct ecm_db_iface_instance *interfaces[],
Murat Sezgin188b4a32015-06-03 10:58:59 -070084 ip_addr_t packet_src_addr, ip_addr_t packet_dest_addr,
85 int ip_version, int packet_protocol,
86 struct net_device *given_dest_dev, bool is_routed,
87 struct net_device *given_src_dev,
Suman Ghoshfb8e7702015-08-20 15:27:57 +053088 uint8_t *dest_node_addr, uint8_t *src_node_addr,
ratheesh kannotha32fdd12015-09-09 08:02:58 +053089 __be16 *layer4hdr, struct sk_buff *skb);
Murat Sezgin5dae8832015-12-03 14:23:19 -080090#endif
91
92int32_t ecm_interface_heirarchy_construct(struct ecm_front_end_connection_instance *feci,
93 struct ecm_db_iface_instance *interfaces[],
94 struct net_device *const_if, struct net_device *other_if,
Murat Sezginf92db492016-07-15 11:33:15 -070095 ip_addr_t lookup_src_addr,
96 ip_addr_t lookup_dest_addr,
97 ip_addr_t real_dest_addr,
Murat Sezgin5dae8832015-12-03 14:23:19 -080098 int ip_version, int packet_protocol,
99 struct net_device *given_dest_dev,
100 bool is_routed, struct net_device *given_src_dev,
101 uint8_t *dest_node_addr, uint8_t *src_node_addr,
102 __be16 *layer4hdr, struct sk_buff *skb);
Murat Sezgin188b4a32015-06-03 10:58:59 -0700103void ecm_interface_stats_update(struct ecm_db_connection_instance *ci, uint32_t from_tx_packets, uint32_t from_tx_bytes, uint32_t from_rx_packets, uint32_t from_rx_bytes, uint32_t to_tx_packets, uint32_t to_tx_bytes, uint32_t to_rx_packets, uint32_t to_rx_bytes);
Gareth Williams46f4b5f2014-06-01 23:35:23 +0100104struct net_device *ecm_interface_dev_find_by_addr(ip_addr_t addr, bool *from_local_addr);
Shyam Sunder6358b862015-05-04 15:06:24 +0530105
Murat Sezginb3731e82014-11-26 12:20:59 -0800106struct net_device *ecm_interface_get_and_hold_dev_master(struct net_device *dev);
Tushar Mathurcccbf282015-01-13 01:22:44 +0530107void ecm_interface_dev_regenerate_connections(struct net_device *dev);
ratheesh kannotha32fdd12015-09-09 08:02:58 +0530108struct net_device *ecm_interface_dev_find_by_local_addr(ip_addr_t addr);
Murat Sezgin5dae8832015-12-03 14:23:19 -0800109bool ecm_interface_find_gateway(ip_addr_t addr, ip_addr_t gw_addr);
Suman Ghosh7a261712016-01-12 21:42:55 +0530110void ecm_interface_dev_defunct_connections(struct net_device *dev);
Murat Sezgin9304d472017-04-14 10:16:52 -0700111void ecm_interface_node_connections_defunct(uint8_t *mac);