blob: 00b068a15b9cc5a7a601ca911334ebe71a68ea62 [file] [log] [blame]
Ratheesh Kannoth24fb1db2021-10-20 07:28:06 +05301/*
2 * sfe_ipv4.h
3 * Shortcut forwarding engine header file for IPv4.
4 *
5 * Copyright (c) 2013-2016, 2019-2020, The Linux Foundation. All rights reserved.
Guduri Prathyusha5f27e232022-01-06 14:39:04 +05306 * Copyright (c) 2021-2022 Qualcomm Innovation Center, Inc. All rights reserved.
Ratheesh Kannoth24fb1db2021-10-20 07:28:06 +05307 *
8 * Permission to use, copy, modify, and/or distribute this software for any
9 * purpose with or without fee is hereby granted, provided that the above
10 * copyright notice and this permission notice appear in all copies.
11 *
12 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
13 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
14 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
15 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
16 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
17 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
18 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
19 */
20
Wayne Tanbb7f1782021-12-13 11:16:04 -080021#ifndef __SFE_IPV4_H
22#define __SFE_IPV4_H
23
Ratheesh Kannoth24fb1db2021-10-20 07:28:06 +053024#define SFE_IPV4_DSCP_MASK 0x3
25#define SFE_IPV4_DSCP_SHIFT 2
26
27/*
Ratheesh Kannoth24fb1db2021-10-20 07:28:06 +053028 * Specifies the lower bound on ACK numbers carried in the TCP header
29 */
30#define SFE_IPV4_TCP_MAX_ACK_WINDOW 65520
31
32/*
33 * IPv4 TCP connection match additional data.
34 */
35struct sfe_ipv4_tcp_connection_match {
36 u8 win_scale; /* Window scale */
37 u32 max_win; /* Maximum window size seen */
38 u32 end; /* Sequence number of the next byte to send (seq + segment length) */
39 u32 max_end; /* Sequence number of the last byte to ack */
40};
41
42/*
43 * Bit flags for IPv4 connection matching entry.
44 */
45#define SFE_IPV4_CONNECTION_MATCH_FLAG_XLATE_SRC (1<<0)
46 /* Perform source translation */
47#define SFE_IPV4_CONNECTION_MATCH_FLAG_XLATE_DEST (1<<1)
48 /* Perform destination translation */
49#define SFE_IPV4_CONNECTION_MATCH_FLAG_NO_SEQ_CHECK (1<<2)
50 /* Ignore TCP sequence numbers */
51#define SFE_IPV4_CONNECTION_MATCH_FLAG_WRITE_FAST_ETH_HDR (1<<3)
52 /* Fast Ethernet header write */
53#define SFE_IPV4_CONNECTION_MATCH_FLAG_WRITE_L2_HDR (1<<4)
54 /* Fast Ethernet header write */
55#define SFE_IPV4_CONNECTION_MATCH_FLAG_PRIORITY_REMARK (1<<5)
56 /* remark priority of SKB */
57#define SFE_IPV4_CONNECTION_MATCH_FLAG_DSCP_REMARK (1<<6)
58 /* remark DSCP of packet */
Ratheesh Kannotha3cf0e02021-12-09 09:44:10 +053059#define SFE_IPV4_CONNECTION_MATCH_FLAG_CSUM_OFFLOAD (1<<7)
60 /* checksum offload.*/
Guduri Prathyushaeb31c902021-11-10 20:18:50 +053061#define SFE_IPV4_CONNECTION_MATCH_FLAG_PPPOE_DECAP (1<<8)
62 /* Indicates that PPPoE should be decapsulated */
63#define SFE_IPV4_CONNECTION_MATCH_FLAG_PPPOE_ENCAP (1<<9)
64 /* Indicates that PPPoE should be encapsulated */
Ratheesh Kannoth71fc51e2022-01-05 10:02:47 +053065#define SFE_IPV4_CONNECTION_MATCH_FLAG_BRIDGE_FLOW (1<<10)
66 /* Bridge flow */
Ken Zhu37040ea2021-09-09 21:11:15 -070067#define SFE_IPV4_CONNECTION_MATCH_FLAG_MARK (1<<11)
68 /* skb mark of the packet */
Wayne Tanbb7f1782021-12-13 11:16:04 -080069#define SFE_IPV4_CONNECTION_MATCH_FLAG_INSERT_EGRESS_VLAN_TAG (1<<12)
70 /* Insert VLAN tag */
Ratheesh Kannoth5dee3772022-01-18 11:27:14 +053071#define SFE_IPV4_CONNECTION_MATCH_FLAG_SRC_INTERFACE_CHECK (1<<13)
72 /* Source interface check.*/
Wayne Tanbb7f1782021-12-13 11:16:04 -080073
Ratheesh Kannoth24fb1db2021-10-20 07:28:06 +053074/*
75 * IPv4 connection matching structure.
76 */
77struct sfe_ipv4_connection_match {
78 /*
79 * References to other objects.
80 */
Ratheesh Kannoth94fc5b82021-10-20 07:45:06 +053081 struct hlist_node hnode;
82
Ratheesh Kannoth24fb1db2021-10-20 07:28:06 +053083 struct sfe_ipv4_connection *connection;
84 struct sfe_ipv4_connection_match *counter_match;
85 /* Matches the flow in the opposite direction as the one in *connection */
Ratheesh Kannoth24fb1db2021-10-20 07:28:06 +053086 /*
87 * Characteristics that identify flows that match this rule.
88 */
89 struct net_device *match_dev; /* Network device */
90 u8 match_protocol; /* Protocol */
91 __be32 match_src_ip; /* Source IP address */
92 __be32 match_dest_ip; /* Destination IP address */
93 __be16 match_src_port; /* Source port/connection ident */
94 __be16 match_dest_port; /* Destination port/connection ident */
95
Amitesh Anand63be37d2021-12-24 20:51:48 +053096 struct udp_sock *up; /* Stores UDP sock information; valid only in decap path */
97
Ratheesh Kannoth24fb1db2021-10-20 07:28:06 +053098 /*
99 * Control the operations of the match.
100 */
101 u32 flags; /* Bit flags */
102#ifdef CONFIG_NF_FLOW_COOKIE
103 u32 flow_cookie; /* used flow cookie, for debug */
104#endif
105#ifdef CONFIG_XFRM
106 u32 flow_accel; /* The flow accelerated or not */
107#endif
108
109 /*
110 * Connection state that we track once we match.
111 */
112 union { /* Protocol-specific state */
113 struct sfe_ipv4_tcp_connection_match tcp;
114 } protocol_state;
Wayne Tanbb7f1782021-12-13 11:16:04 -0800115
116 /*
117 * VLAN headers
118 */
119 struct sfe_vlan_hdr ingress_vlan_hdr[SFE_MAX_VLAN_DEPTH];
120 struct sfe_vlan_hdr egress_vlan_hdr[SFE_MAX_VLAN_DEPTH];
121
Ratheesh Kannoth24fb1db2021-10-20 07:28:06 +0530122 /*
123 * Stats recorded in a sync period. These stats will be added to
124 * rx_packet_count64/rx_byte_count64 after a sync period.
125 */
Ratheesh Kannoth94fc5b82021-10-20 07:45:06 +0530126 atomic_t rx_packet_count;
127 atomic_t rx_byte_count;
Ratheesh Kannoth24fb1db2021-10-20 07:28:06 +0530128
129 /*
130 * Packet translation information.
131 */
132 __be32 xlate_src_ip; /* Address after source translation */
133 __be16 xlate_src_port; /* Port/connection ident after source translation */
134 u16 xlate_src_csum_adjustment;
135 /* Transport layer checksum adjustment after source translation */
136 u16 xlate_src_partial_csum_adjustment;
137 /* Transport layer pseudo header checksum adjustment after source translation */
138
139 __be32 xlate_dest_ip; /* Address after destination translation */
140 __be16 xlate_dest_port; /* Port/connection ident after destination translation */
141 u16 xlate_dest_csum_adjustment;
142 /* Transport layer checksum adjustment after destination translation */
143 u16 xlate_dest_partial_csum_adjustment;
144 /* Transport layer pseudo header checksum adjustment after destination translation */
145
146 /*
147 * QoS information
148 */
149 u32 priority;
150 u32 dscp;
Ken Zhu37040ea2021-09-09 21:11:15 -0700151 u32 mark; /* mark for outgoing packet */
Ratheesh Kannoth24fb1db2021-10-20 07:28:06 +0530152
153 /*
154 * Packet transmit information.
155 */
156 struct net_device *xmit_dev; /* Network device on which to transmit */
157 unsigned short int xmit_dev_mtu;
158 /* Interface MTU */
159 u16 xmit_dest_mac[ETH_ALEN / 2];
160 /* Destination MAC address to use when forwarding */
161 u16 xmit_src_mac[ETH_ALEN / 2];
162 /* Source MAC address to use when forwarding */
163
Wayne Tanbb7f1782021-12-13 11:16:04 -0800164 u8 ingress_vlan_hdr_cnt; /* Ingress active vlan headers count */
165 u8 egress_vlan_hdr_cnt; /* Egress active vlan headers count */
166
Ratheesh Kannoth24fb1db2021-10-20 07:28:06 +0530167 /*
168 * Summary stats.
169 */
170 u64 rx_packet_count64;
171 u64 rx_byte_count64;
Guduri Prathyushaeb31c902021-11-10 20:18:50 +0530172
173 /*
174 * PPPoE information
175 */
176 u16 pppoe_session_id;
177 u8 pppoe_remote_mac[ETH_ALEN];
Wayne Tanbb7f1782021-12-13 11:16:04 -0800178
179 /*
180 * Size of all needed L2 headers
181 */
182 u16 l2_hdr_size;
Ratheesh Kannoth24fb1db2021-10-20 07:28:06 +0530183};
184
185/*
186 * Per-connection data structure.
187 */
188struct sfe_ipv4_connection {
189 struct sfe_ipv4_connection *next;
190 /* Pointer to the next entry in a hash chain */
191 struct sfe_ipv4_connection *prev;
192 /* Pointer to the previous entry in a hash chain */
193 int protocol; /* IP protocol number */
194 __be32 src_ip; /* Src IP addr pre-translation */
195 __be32 src_ip_xlate; /* Src IP addr post-translation */
196 __be32 dest_ip; /* Dest IP addr pre-translation */
197 __be32 dest_ip_xlate; /* Dest IP addr post-translation */
198 __be16 src_port; /* Src port pre-translation */
199 __be16 src_port_xlate; /* Src port post-translation */
200 __be16 dest_port; /* Dest port pre-translation */
201 __be16 dest_port_xlate; /* Dest port post-translation */
202 struct sfe_ipv4_connection_match *original_match;
203 /* Original direction matching structure */
204 struct net_device *original_dev;
205 /* Original direction source device */
206 struct sfe_ipv4_connection_match *reply_match;
207 /* Reply direction matching structure */
208 struct net_device *reply_dev; /* Reply direction source device */
209 u64 last_sync_jiffies; /* Jiffies count for the last sync */
210 struct sfe_ipv4_connection *all_connections_next;
211 /* Pointer to the next entry in the list of all connections */
212 struct sfe_ipv4_connection *all_connections_prev;
213 /* Pointer to the previous entry in the list of all connections */
214 u32 mark; /* mark for outgoing packet */
215 u32 debug_read_seq; /* sequence number for debug dump */
Ratheesh Kannoth94fc5b82021-10-20 07:45:06 +0530216 bool removed; /* Indicates the connection is removed */
217 struct rcu_head rcu; /* delay rcu free */
Ratheesh Kannoth24fb1db2021-10-20 07:28:06 +0530218};
219
220/*
221 * IPv4 connections and hash table size information.
222 */
223#define SFE_IPV4_CONNECTION_HASH_SHIFT 12
224#define SFE_IPV4_CONNECTION_HASH_SIZE (1 << SFE_IPV4_CONNECTION_HASH_SHIFT)
225#define SFE_IPV4_CONNECTION_HASH_MASK (SFE_IPV4_CONNECTION_HASH_SIZE - 1)
226
227enum sfe_ipv4_exception_events {
228 SFE_IPV4_EXCEPTION_EVENT_UDP_HEADER_INCOMPLETE,
229 SFE_IPV4_EXCEPTION_EVENT_UDP_NO_CONNECTION,
230 SFE_IPV4_EXCEPTION_EVENT_UDP_IP_OPTIONS_OR_INITIAL_FRAGMENT,
231 SFE_IPV4_EXCEPTION_EVENT_UDP_SMALL_TTL,
232 SFE_IPV4_EXCEPTION_EVENT_UDP_NEEDS_FRAGMENTATION,
233 SFE_IPV4_EXCEPTION_EVENT_TCP_HEADER_INCOMPLETE,
234 SFE_IPV4_EXCEPTION_EVENT_TCP_NO_CONNECTION_SLOW_FLAGS,
235 SFE_IPV4_EXCEPTION_EVENT_TCP_NO_CONNECTION_FAST_FLAGS,
236 SFE_IPV4_EXCEPTION_EVENT_TCP_IP_OPTIONS_OR_INITIAL_FRAGMENT,
237 SFE_IPV4_EXCEPTION_EVENT_TCP_SMALL_TTL,
238 SFE_IPV4_EXCEPTION_EVENT_TCP_NEEDS_FRAGMENTATION,
239 SFE_IPV4_EXCEPTION_EVENT_TCP_FLAGS,
240 SFE_IPV4_EXCEPTION_EVENT_TCP_SEQ_EXCEEDS_RIGHT_EDGE,
241 SFE_IPV4_EXCEPTION_EVENT_TCP_SMALL_DATA_OFFS,
242 SFE_IPV4_EXCEPTION_EVENT_TCP_BAD_SACK,
243 SFE_IPV4_EXCEPTION_EVENT_TCP_BIG_DATA_OFFS,
244 SFE_IPV4_EXCEPTION_EVENT_TCP_SEQ_BEFORE_LEFT_EDGE,
245 SFE_IPV4_EXCEPTION_EVENT_TCP_ACK_EXCEEDS_RIGHT_EDGE,
246 SFE_IPV4_EXCEPTION_EVENT_TCP_ACK_BEFORE_LEFT_EDGE,
247 SFE_IPV4_EXCEPTION_EVENT_ICMP_HEADER_INCOMPLETE,
248 SFE_IPV4_EXCEPTION_EVENT_ICMP_UNHANDLED_TYPE,
249 SFE_IPV4_EXCEPTION_EVENT_ICMP_IPV4_HEADER_INCOMPLETE,
250 SFE_IPV4_EXCEPTION_EVENT_ICMP_IPV4_NON_V4,
251 SFE_IPV4_EXCEPTION_EVENT_ICMP_IPV4_IP_OPTIONS_INCOMPLETE,
252 SFE_IPV4_EXCEPTION_EVENT_ICMP_IPV4_UDP_HEADER_INCOMPLETE,
253 SFE_IPV4_EXCEPTION_EVENT_ICMP_IPV4_TCP_HEADER_INCOMPLETE,
254 SFE_IPV4_EXCEPTION_EVENT_ICMP_IPV4_UNHANDLED_PROTOCOL,
255 SFE_IPV4_EXCEPTION_EVENT_ICMP_NO_CONNECTION,
256 SFE_IPV4_EXCEPTION_EVENT_ICMP_FLUSHED_CONNECTION,
257 SFE_IPV4_EXCEPTION_EVENT_HEADER_INCOMPLETE,
Ratheesh Kannoth43d64f82021-10-20 08:23:29 +0530258 SFE_IPV4_EXCEPTION_EVENT_HEADER_CSUM_BAD,
Ratheesh Kannoth24fb1db2021-10-20 07:28:06 +0530259 SFE_IPV4_EXCEPTION_EVENT_BAD_TOTAL_LENGTH,
260 SFE_IPV4_EXCEPTION_EVENT_NON_V4,
261 SFE_IPV4_EXCEPTION_EVENT_NON_INITIAL_FRAGMENT,
262 SFE_IPV4_EXCEPTION_EVENT_DATAGRAM_INCOMPLETE,
263 SFE_IPV4_EXCEPTION_EVENT_IP_OPTIONS_INCOMPLETE,
264 SFE_IPV4_EXCEPTION_EVENT_UNHANDLED_PROTOCOL,
Guduri Prathyusha5f27e232022-01-06 14:39:04 +0530265 SFE_IPV4_EXCEPTION_EVENT_NO_HEADROOM,
Guduri Prathyusha647fe3e2021-11-22 19:17:51 +0530266 SFE_IPV4_EXCEPTION_EVENT_INVALID_PPPOE_SESSION,
267 SFE_IPV4_EXCEPTION_EVENT_INCORRECT_PPPOE_PARSING,
268 SFE_IPV4_EXCEPTION_EVENT_PPPOE_NOT_SET_IN_CME,
Wayne Tanbb7f1782021-12-13 11:16:04 -0800269 SFE_IPV4_EXCEPTION_EVENT_INGRESS_VLAN_TAG_MISMATCH,
Ratheesh Kannoth5dee3772022-01-18 11:27:14 +0530270 SFE_IPV4_EXCEPTION_EVENT_INVALID_SRC_IFACE,
Ratheesh Kannoth24fb1db2021-10-20 07:28:06 +0530271 SFE_IPV4_EXCEPTION_EVENT_LAST
272};
273
274/*
Ratheesh Kannoth3aeb2892021-10-20 07:57:15 +0530275 * per CPU stats
276 */
277struct sfe_ipv4_stats {
278 /*
279 * Stats recorded in a sync period. These stats will be added to
280 * connection_xxx64 after a sync period.
281 */
282 u64 connection_create_requests64;
283 /* Number of IPv4 connection create requests */
284 u64 connection_create_collisions64;
285 /* Number of IPv4 connection create requests that collided with existing hash table entries */
Ratheesh Kannoth89302a72021-10-20 08:10:37 +0530286 u64 connection_create_failures64;
287 /* Number of IPv4 connection create requests that failed */
Ratheesh Kannoth3aeb2892021-10-20 07:57:15 +0530288 u64 connection_destroy_requests64;
289 /* Number of IPv4 connection destroy requests */
290 u64 connection_destroy_misses64;
291 /* Number of IPv4 connection destroy requests that missed our hash table */
292 u64 connection_match_hash_hits64;
293 /* Number of IPv4 connection match hash hits */
294 u64 connection_match_hash_reorders64;
295 /* Number of IPv4 connection match hash reorders */
296 u64 connection_flushes64; /* Number of IPv4 connection flushes */
Amitesh Anand63be37d2021-12-24 20:51:48 +0530297 u64 packets_dropped64; /* Number of IPv4 packets dropped */
Ratheesh Kannoth3aeb2892021-10-20 07:57:15 +0530298 u64 packets_forwarded64; /* Number of IPv4 packets forwarded */
299 u64 packets_not_forwarded64; /* Number of IPv4 packets not forwarded */
300 u64 exception_events64[SFE_IPV4_EXCEPTION_EVENT_LAST];
Guduri Prathyusha034d6352022-01-12 16:49:04 +0530301 u64 pppoe_encap_packets_forwarded64; /* Number of IPv4 PPPoE encap packets forwarded */
302 u64 pppoe_decap_packets_forwarded64; /* Number of IPv4 PPPoE decap packets forwarded */
303 u64 pppoe_bridge_packets_forwarded64; /* Number of IPv4 PPPoE bridge packets forwarded */
Ratheesh Kannoth3aeb2892021-10-20 07:57:15 +0530304};
305
306/*
Ratheesh Kannoth24fb1db2021-10-20 07:28:06 +0530307 * Per-module structure.
308 */
309struct sfe_ipv4 {
310 spinlock_t lock; /* Lock for SMP correctness */
Ratheesh Kannoth24fb1db2021-10-20 07:28:06 +0530311 struct sfe_ipv4_connection *all_connections_head;
312 /* Head of the list of all connections */
313 struct sfe_ipv4_connection *all_connections_tail;
314 /* Tail of the list of all connections */
315 unsigned int num_connections; /* Number of connections */
Ken Zhu137722d2021-09-23 17:57:36 -0700316 struct delayed_work sync_dwork; /* Work to sync the statistics */
317 unsigned int work_cpu; /* The core to run stats sync on */
318
Ratheesh Kannoth24fb1db2021-10-20 07:28:06 +0530319 sfe_sync_rule_callback_t __rcu sync_rule_callback;
320 /* Callback function registered by a connection manager for stats syncing */
321 struct sfe_ipv4_connection *conn_hash[SFE_IPV4_CONNECTION_HASH_SIZE];
322 /* Connection hash table */
Ratheesh Kannoth94fc5b82021-10-20 07:45:06 +0530323
324 struct hlist_head hlist_conn_match_hash_head[SFE_IPV4_CONNECTION_HASH_SIZE];
Ratheesh Kannoth24fb1db2021-10-20 07:28:06 +0530325 /* Connection match hash table */
Ratheesh Kannoth94fc5b82021-10-20 07:45:06 +0530326
Ratheesh Kannoth24fb1db2021-10-20 07:28:06 +0530327#ifdef CONFIG_NF_FLOW_COOKIE
328 struct sfe_flow_cookie_entry sfe_flow_cookie_table[SFE_FLOW_COOKIE_SIZE];
329 /* flow cookie table*/
330 flow_cookie_set_func_t flow_cookie_set_func;
331 /* function used to configure flow cookie in hardware*/
332 int flow_cookie_enable;
333 /* Enable/disable flow cookie at runtime */
334#endif
335
Ratheesh Kannoth3aeb2892021-10-20 07:57:15 +0530336 struct sfe_ipv4_stats __percpu *stats_pcpu;
337 /* Per CPU statistics. */
Ratheesh Kannoth24fb1db2021-10-20 07:28:06 +0530338
Ken Zhudc423672021-09-02 18:27:01 -0700339 struct sfe_ipv4_connection *wc_next; /* Connection list walk pointer for stats sync */
340
Ratheesh Kannoth24fb1db2021-10-20 07:28:06 +0530341 /*
342 * Control state.
343 */
Ratheesh Kannoth6307bec2021-11-25 08:26:39 +0530344 struct kobject *sys_ipv4; /* sysfs linkage */
Ratheesh Kannoth24fb1db2021-10-20 07:28:06 +0530345 int debug_dev; /* Major number of the debug char device */
346 u32 debug_read_seq; /* sequence number for debug dump */
347};
348
349/*
350 * Enumeration of the XML output.
351 */
352enum sfe_ipv4_debug_xml_states {
353 SFE_IPV4_DEBUG_XML_STATE_START,
354 SFE_IPV4_DEBUG_XML_STATE_CONNECTIONS_START,
355 SFE_IPV4_DEBUG_XML_STATE_CONNECTIONS_CONNECTION,
356 SFE_IPV4_DEBUG_XML_STATE_CONNECTIONS_END,
357 SFE_IPV4_DEBUG_XML_STATE_EXCEPTIONS_START,
358 SFE_IPV4_DEBUG_XML_STATE_EXCEPTIONS_EXCEPTION,
359 SFE_IPV4_DEBUG_XML_STATE_EXCEPTIONS_END,
360 SFE_IPV4_DEBUG_XML_STATE_STATS,
361 SFE_IPV4_DEBUG_XML_STATE_END,
362 SFE_IPV4_DEBUG_XML_STATE_DONE
363};
364
365/*
366 * XML write state.
367 */
368struct sfe_ipv4_debug_xml_write_state {
369 enum sfe_ipv4_debug_xml_states state;
370 /* XML output file state machine state */
371 int iter_exception; /* Next exception iterator */
372};
373
374typedef bool (*sfe_ipv4_debug_xml_write_method_t)(struct sfe_ipv4 *si, char *buffer, char *msg, size_t *length,
375 int *total_read, struct sfe_ipv4_debug_xml_write_state *ws);
376
Ratheesh Kannoth6307bec2021-11-25 08:26:39 +0530377u16 sfe_ipv4_gen_ip_csum(struct iphdr *iph);
378void sfe_ipv4_exception_stats_inc(struct sfe_ipv4 *si, enum sfe_ipv4_exception_events reason);
379bool sfe_ipv4_remove_connection(struct sfe_ipv4 *si, struct sfe_ipv4_connection *c);
380void sfe_ipv4_flush_connection(struct sfe_ipv4 *si, struct sfe_ipv4_connection *c, sfe_sync_reason_t reason);
Ken Zhu88c58152021-12-09 15:12:06 -0800381void sfe_ipv4_sync_status(struct sfe_ipv4 *si, struct sfe_ipv4_connection *c, sfe_sync_reason_t reason);
Ratheesh Kannoth6307bec2021-11-25 08:26:39 +0530382
383struct sfe_ipv4_connection_match *
384sfe_ipv4_find_connection_match_rcu(struct sfe_ipv4 *si, struct net_device *dev, u8 protocol,
385 __be32 src_ip, __be16 src_port,
386 __be32 dest_ip, __be16 dest_port);
387
Ratheesh Kannoth24fb1db2021-10-20 07:28:06 +0530388void sfe_ipv4_exit(void);
389int sfe_ipv4_init(void);
Wayne Tanbb7f1782021-12-13 11:16:04 -0800390
391#endif /* __SFE_IPV4_H */