public inbox for passt-dev@passt.top
 help / color / mirror / code / Atom feed
158a0f695830981bc71bd03bd8b7a6b0d7227fec blob 1870 bytes (raw)

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
 
/* 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_flow - Descriptor for a flow of UDP packets
 * @f:		Generic flow information
 * @ttl:	TTL or hop_limit for both sides
 * @closed:	Flow is already closed
 * @flush0:	@s[0] may have datagrams queued for other flows
 * @flush1:	@s[1] may have datagrams queued for other flows
 * @ts:		Activity timestamp
 * @s:		Socket fd (or -1) for each side of the flow
 * @activity:	Activity for each side of the flow
 */
struct udp_flow {
	/* Must be first element */
	struct flow_common f;

	uint8_t ttl[SIDES];

	bool	closed	:1,
		flush0	:1,
		flush1	:1;

	time_t ts;
	int s[SIDES];
	uint8_t activity[SIDES];
};

/**
 * udp_flow_activity() - Track activity of a udp flow
 * @uflow:	UDP flow
 * @sidei:	Side index of the flow
 */
static inline void udp_flow_activity(struct udp_flow *uflow, unsigned int sidei)
{
	if (uflow->activity[sidei] < UINT8_MAX)
		uflow->activity[sidei]++;
}

struct udp_flow *udp_at_sidx(flow_sidx_t sidx);
flow_sidx_t udp_flow_from_sock(const struct ctx *c, uint8_t pif,
			       const union inany_addr *dst, in_port_t port,
			       const union sockaddr_inany *s_in,
			       int rule_hint, 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);
void udp_flow_close(const struct ctx *c, struct udp_flow *uflow);
bool udp_flow_defer(const struct ctx *c, struct udp_flow *uflow,
		    const struct timespec *now);
bool udp_flow_timer(const struct ctx *c, struct udp_flow *uflow,
		    const struct timespec *now);

#endif /* UDP_FLOW_H */
debug log:

solving 158a0f6 ...
found 158a0f6 in https://archives.passt.top/passt-dev/20260212080414.61889-1-yuhuang@redhat.com/
found 14e0f92 in https://passt.top/passt
preparing index
index prepared:
100644 14e0f9200b65027b6d28237d216dd7193ffc931e	udp_flow.h

applying [1/1] https://archives.passt.top/passt-dev/20260212080414.61889-1-yuhuang@redhat.com/
diff --git a/udp_flow.h b/udp_flow.h
index 14e0f92..158a0f6 100644

Checking patch udp_flow.h...
Applied patch udp_flow.h cleanly.

index at:
100644 158a0f695830981bc71bd03bd8b7a6b0d7227fec	udp_flow.h

Code repositories for project(s) associated with this public inbox

	https://passt.top/passt

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for IMAP folder(s).