xref: /openbmc/linux/net/dccp/ackvec.h (revision 02bcf28c82c8e4b72c4b89bddbbb6fea1a646d07)
1ae31c339SArnaldo Carvalho de Melo #ifndef _ACKVEC_H
2ae31c339SArnaldo Carvalho de Melo #define _ACKVEC_H
3ae31c339SArnaldo Carvalho de Melo /*
4ae31c339SArnaldo Carvalho de Melo  *  net/dccp/ackvec.h
5ae31c339SArnaldo Carvalho de Melo  *
6ae31c339SArnaldo Carvalho de Melo  *  An implementation of the DCCP protocol
7ae31c339SArnaldo Carvalho de Melo  *  Copyright (c) 2005 Arnaldo Carvalho de Melo <acme@mandriva.com>
8ae31c339SArnaldo Carvalho de Melo  *
9ae31c339SArnaldo Carvalho de Melo  *	This program is free software; you can redistribute it and/or modify it
10ae31c339SArnaldo Carvalho de Melo  *	under the terms of the GNU General Public License version 2 as
11ae31c339SArnaldo Carvalho de Melo  *	published by the Free Software Foundation.
12ae31c339SArnaldo Carvalho de Melo  */
13ae31c339SArnaldo Carvalho de Melo 
14ae31c339SArnaldo Carvalho de Melo #include <linux/config.h>
15ae31c339SArnaldo Carvalho de Melo #include <linux/compiler.h>
16*02bcf28cSAndrea Bittau #include <linux/list.h>
17ae31c339SArnaldo Carvalho de Melo #include <linux/time.h>
18ae31c339SArnaldo Carvalho de Melo #include <linux/types.h>
19ae31c339SArnaldo Carvalho de Melo 
20ae31c339SArnaldo Carvalho de Melo /* Read about the ECN nonce to see why it is 253 */
21ae31c339SArnaldo Carvalho de Melo #define DCCP_MAX_ACKVEC_LEN 253
22ae31c339SArnaldo Carvalho de Melo 
23ae31c339SArnaldo Carvalho de Melo #define DCCP_ACKVEC_STATE_RECEIVED	0
24ae31c339SArnaldo Carvalho de Melo #define DCCP_ACKVEC_STATE_ECN_MARKED	(1 << 6)
25ae31c339SArnaldo Carvalho de Melo #define DCCP_ACKVEC_STATE_NOT_RECEIVED	(3 << 6)
26ae31c339SArnaldo Carvalho de Melo 
27ae31c339SArnaldo Carvalho de Melo #define DCCP_ACKVEC_STATE_MASK		0xC0 /* 11000000 */
28ae31c339SArnaldo Carvalho de Melo #define DCCP_ACKVEC_LEN_MASK		0x3F /* 00111111 */
29ae31c339SArnaldo Carvalho de Melo 
30ae31c339SArnaldo Carvalho de Melo /** struct dccp_ackvec - ack vector
31ae31c339SArnaldo Carvalho de Melo  *
32ae31c339SArnaldo Carvalho de Melo  * This data structure is the one defined in the DCCP draft
33ae31c339SArnaldo Carvalho de Melo  * Appendix A.
34ae31c339SArnaldo Carvalho de Melo  *
35ae31c339SArnaldo Carvalho de Melo  * @dccpav_buf_head - circular buffer head
36ae31c339SArnaldo Carvalho de Melo  * @dccpav_buf_tail - circular buffer tail
37ae31c339SArnaldo Carvalho de Melo  * @dccpav_buf_ackno - ack # of the most recent packet acknowledgeable in the
38ae31c339SArnaldo Carvalho de Melo  * 		       buffer (i.e. %dccpav_buf_head)
39ae31c339SArnaldo Carvalho de Melo  * @dccpav_buf_nonce - the one-bit sum of the ECN Nonces on all packets acked
40ae31c339SArnaldo Carvalho de Melo  * 		       by the buffer with State 0
41ae31c339SArnaldo Carvalho de Melo  *
42ae31c339SArnaldo Carvalho de Melo  * Additionally, the HC-Receiver must keep some information about the
43ae31c339SArnaldo Carvalho de Melo  * Ack Vectors it has recently sent. For each packet sent carrying an
44ae31c339SArnaldo Carvalho de Melo  * Ack Vector, it remembers four variables:
45ae31c339SArnaldo Carvalho de Melo  *
46ae31c339SArnaldo Carvalho de Melo  * @dccpav_ack_ptr - the value of buf_head at the time of acknowledgement.
47*02bcf28cSAndrea Bittau  * @dccpav_records - list of dccp_ackvec_record
48ae31c339SArnaldo Carvalho de Melo  * @dccpav_ack_nonce - the one-bit sum of the ECN Nonces for all State 0.
49ae31c339SArnaldo Carvalho de Melo  *
50ae31c339SArnaldo Carvalho de Melo  * @dccpav_time		- the time in usecs
51ae31c339SArnaldo Carvalho de Melo  * @dccpav_buf - circular buffer of acknowledgeable packets
52ae31c339SArnaldo Carvalho de Melo  */
53ae31c339SArnaldo Carvalho de Melo struct dccp_ackvec {
54ae31c339SArnaldo Carvalho de Melo 	u64		dccpav_buf_ackno;
55*02bcf28cSAndrea Bittau 	struct list_head dccpav_records;
56ae31c339SArnaldo Carvalho de Melo 	struct timeval	dccpav_time;
57e4dfd449SArnaldo Carvalho de Melo 	u8		dccpav_buf_head;
58e4dfd449SArnaldo Carvalho de Melo 	u8		dccpav_buf_tail;
59e4dfd449SArnaldo Carvalho de Melo 	u8		dccpav_ack_ptr;
60e4dfd449SArnaldo Carvalho de Melo 	u8		dccpav_sent_len;
61e4dfd449SArnaldo Carvalho de Melo 	u8		dccpav_vec_len;
62ae31c339SArnaldo Carvalho de Melo 	u8		dccpav_buf_nonce;
63ae31c339SArnaldo Carvalho de Melo 	u8		dccpav_ack_nonce;
647400d781SArnaldo Carvalho de Melo 	u8		dccpav_buf[DCCP_MAX_ACKVEC_LEN];
65ae31c339SArnaldo Carvalho de Melo };
66ae31c339SArnaldo Carvalho de Melo 
67*02bcf28cSAndrea Bittau /** struct dccp_ackvec_record - ack vector record
68*02bcf28cSAndrea Bittau  *
69*02bcf28cSAndrea Bittau  * ACK vector record as defined in Appendix A of spec.
70*02bcf28cSAndrea Bittau  *
71*02bcf28cSAndrea Bittau  * The list is sorted by dccpavr_ack_seqno
72*02bcf28cSAndrea Bittau  *
73*02bcf28cSAndrea Bittau  * @dccpavr_node - node in dccpav_records
74*02bcf28cSAndrea Bittau  * @dccpavr_ack_seqno - sequence number of the packet this record was sent on
75*02bcf28cSAndrea Bittau  * @dccpavr_ack_ackno - sequence number being acknowledged
76*02bcf28cSAndrea Bittau  * @dccpavr_ack_ptr - pointer into dccpav_buf where this record starts
77*02bcf28cSAndrea Bittau  * @dccpavr_ack_nonce - dccpav_ack_nonce at the time this record was sent
78*02bcf28cSAndrea Bittau  * @dccpavr_sent_len - lenght of the record in dccpav_buf
79*02bcf28cSAndrea Bittau  */
80*02bcf28cSAndrea Bittau struct dccp_ackvec_record {
81*02bcf28cSAndrea Bittau 	struct list_head dccpavr_node;
82*02bcf28cSAndrea Bittau 	u64		 dccpavr_ack_seqno;
83*02bcf28cSAndrea Bittau 	u64		 dccpavr_ack_ackno;
84*02bcf28cSAndrea Bittau 	u8		 dccpavr_ack_ptr;
85*02bcf28cSAndrea Bittau 	u8		 dccpavr_ack_nonce;
86*02bcf28cSAndrea Bittau 	u8		 dccpavr_sent_len;
87*02bcf28cSAndrea Bittau };
88*02bcf28cSAndrea Bittau 
89ae31c339SArnaldo Carvalho de Melo struct sock;
90ae31c339SArnaldo Carvalho de Melo struct sk_buff;
91ae31c339SArnaldo Carvalho de Melo 
92ae31c339SArnaldo Carvalho de Melo #ifdef CONFIG_IP_DCCP_ACKVEC
939b07ef5dSArnaldo Carvalho de Melo extern int dccp_ackvec_init(void);
949b07ef5dSArnaldo Carvalho de Melo extern void dccp_ackvec_exit(void);
959b07ef5dSArnaldo Carvalho de Melo 
967400d781SArnaldo Carvalho de Melo extern struct dccp_ackvec *dccp_ackvec_alloc(const gfp_t priority);
97ae31c339SArnaldo Carvalho de Melo extern void dccp_ackvec_free(struct dccp_ackvec *av);
98ae31c339SArnaldo Carvalho de Melo 
99ae31c339SArnaldo Carvalho de Melo extern int dccp_ackvec_add(struct dccp_ackvec *av, const struct sock *sk,
100ae31c339SArnaldo Carvalho de Melo 			   const u64 ackno, const u8 state);
101ae31c339SArnaldo Carvalho de Melo 
102ae31c339SArnaldo Carvalho de Melo extern void dccp_ackvec_check_rcv_ackno(struct dccp_ackvec *av,
103ae31c339SArnaldo Carvalho de Melo 					struct sock *sk, const u64 ackno);
104ae31c339SArnaldo Carvalho de Melo extern int dccp_ackvec_parse(struct sock *sk, const struct sk_buff *skb,
105ae31c339SArnaldo Carvalho de Melo 			     const u8 opt, const u8 *value, const u8 len);
106ae31c339SArnaldo Carvalho de Melo 
107ae31c339SArnaldo Carvalho de Melo extern int dccp_insert_option_ackvec(struct sock *sk, struct sk_buff *skb);
108ae31c339SArnaldo Carvalho de Melo 
109ae31c339SArnaldo Carvalho de Melo static inline int dccp_ackvec_pending(const struct dccp_ackvec *av)
110ae31c339SArnaldo Carvalho de Melo {
111ae31c339SArnaldo Carvalho de Melo 	return av->dccpav_sent_len != av->dccpav_vec_len;
112ae31c339SArnaldo Carvalho de Melo }
113ae31c339SArnaldo Carvalho de Melo #else /* CONFIG_IP_DCCP_ACKVEC */
1149b07ef5dSArnaldo Carvalho de Melo static inline int dccp_ackvec_init(void)
1159b07ef5dSArnaldo Carvalho de Melo {
1169b07ef5dSArnaldo Carvalho de Melo 	return 0;
1179b07ef5dSArnaldo Carvalho de Melo }
1189b07ef5dSArnaldo Carvalho de Melo 
1199b07ef5dSArnaldo Carvalho de Melo static inline void dccp_ackvec_exit(void)
1209b07ef5dSArnaldo Carvalho de Melo {
1219b07ef5dSArnaldo Carvalho de Melo }
1229b07ef5dSArnaldo Carvalho de Melo 
1237400d781SArnaldo Carvalho de Melo static inline struct dccp_ackvec *dccp_ackvec_alloc(const gfp_t priority)
124ae31c339SArnaldo Carvalho de Melo {
125ae31c339SArnaldo Carvalho de Melo 	return NULL;
126ae31c339SArnaldo Carvalho de Melo }
127ae31c339SArnaldo Carvalho de Melo 
128ae31c339SArnaldo Carvalho de Melo static inline void dccp_ackvec_free(struct dccp_ackvec *av)
129ae31c339SArnaldo Carvalho de Melo {
130ae31c339SArnaldo Carvalho de Melo }
131ae31c339SArnaldo Carvalho de Melo 
132ae31c339SArnaldo Carvalho de Melo static inline int dccp_ackvec_add(struct dccp_ackvec *av, const struct sock *sk,
133ae31c339SArnaldo Carvalho de Melo 				  const u64 ackno, const u8 state)
134ae31c339SArnaldo Carvalho de Melo {
135ae31c339SArnaldo Carvalho de Melo 	return -1;
136ae31c339SArnaldo Carvalho de Melo }
137ae31c339SArnaldo Carvalho de Melo 
138ae31c339SArnaldo Carvalho de Melo static inline void dccp_ackvec_check_rcv_ackno(struct dccp_ackvec *av,
139ae31c339SArnaldo Carvalho de Melo 					       struct sock *sk, const u64 ackno)
140ae31c339SArnaldo Carvalho de Melo {
141ae31c339SArnaldo Carvalho de Melo }
142ae31c339SArnaldo Carvalho de Melo 
143ae31c339SArnaldo Carvalho de Melo static inline int dccp_ackvec_parse(struct sock *sk, const struct sk_buff *skb,
144ae31c339SArnaldo Carvalho de Melo 				    const u8 opt, const u8 *value, const u8 len)
145ae31c339SArnaldo Carvalho de Melo {
146ae31c339SArnaldo Carvalho de Melo 	return -1;
147ae31c339SArnaldo Carvalho de Melo }
148ae31c339SArnaldo Carvalho de Melo 
149ae31c339SArnaldo Carvalho de Melo static inline int dccp_insert_option_ackvec(const struct sock *sk,
150ae31c339SArnaldo Carvalho de Melo 					    const struct sk_buff *skb)
151ae31c339SArnaldo Carvalho de Melo {
152ae31c339SArnaldo Carvalho de Melo 	return -1;
153ae31c339SArnaldo Carvalho de Melo }
154ae31c339SArnaldo Carvalho de Melo 
155ae31c339SArnaldo Carvalho de Melo static inline int dccp_ackvec_pending(const struct dccp_ackvec *av)
156ae31c339SArnaldo Carvalho de Melo {
157ae31c339SArnaldo Carvalho de Melo 	return 0;
158ae31c339SArnaldo Carvalho de Melo }
159ae31c339SArnaldo Carvalho de Melo #endif /* CONFIG_IP_DCCP_ACKVEC */
160ae31c339SArnaldo Carvalho de Melo #endif /* _ACKVEC_H */
161