2024-07-18 15:26:46 +10:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-or-later
|
|
|
|
* Copyright Red Hat
|
|
|
|
* Author: David Gibson <david@gibson.dropbear.id.au>
|
|
|
|
*
|
|
|
|
* UDP flow tracking data structures
|
|
|
|
*/
|
|
|
|
#ifndef UDP_FLOW_H
|
|
|
|
#define UDP_FLOW_H
|
|
|
|
|
|
|
|
/**
|
|
|
|
* struct udp - Descriptor for a flow of UDP packets
|
|
|
|
* @f: Generic flow information
|
2024-09-06 15:17:06 +10:00
|
|
|
* @closed: Flow is already closed
|
2024-07-18 15:26:46 +10:00
|
|
|
* @ts: Activity timestamp
|
2024-07-18 15:26:47 +10:00
|
|
|
* @s: Socket fd (or -1) for each side of the flow
|
2024-07-18 15:26:46 +10:00
|
|
|
*/
|
|
|
|
struct udp_flow {
|
|
|
|
/* Must be first element */
|
|
|
|
struct flow_common f;
|
|
|
|
|
2024-09-06 15:17:06 +10:00
|
|
|
bool closed :1;
|
2024-07-18 15:26:46 +10:00
|
|
|
time_t ts;
|
2024-07-18 15:26:47 +10:00
|
|
|
int s[SIDES];
|
2024-07-18 15:26:46 +10:00
|
|
|
};
|
|
|
|
|
2024-08-02 18:10:36 +02:00
|
|
|
struct udp_flow *udp_at_sidx(flow_sidx_t sidx);
|
|
|
|
flow_sidx_t udp_flow_from_sock(const struct ctx *c, union epoll_ref ref,
|
|
|
|
const union sockaddr_inany *s_in,
|
|
|
|
const struct timespec *now);
|
|
|
|
flow_sidx_t udp_flow_from_tap(const struct ctx *c,
|
|
|
|
uint8_t pif, sa_family_t af,
|
|
|
|
const void *saddr, const void *daddr,
|
|
|
|
in_port_t srcport, in_port_t dstport,
|
|
|
|
const struct timespec *now);
|
2024-09-06 15:17:06 +10:00
|
|
|
void udp_flow_close(const struct ctx *c, struct udp_flow *uflow);
|
|
|
|
bool udp_flow_defer(const struct udp_flow *uflow);
|
2024-07-18 15:26:47 +10:00
|
|
|
bool udp_flow_timer(const struct ctx *c, struct udp_flow *uflow,
|
2024-07-18 15:26:46 +10:00
|
|
|
const struct timespec *now);
|
|
|
|
|
|
|
|
#endif /* UDP_FLOW_H */
|