xref: /openbmc/linux/net/dccp/ackvec.h (revision a47c51044a77124ce66cd8513bba6f4d7673e43d)
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/compiler.h>
15b8bda9d7SArnaldo Carvalho de Melo #include <linux/ktime.h>
1602bcf28cSAndrea Bittau #include <linux/list.h>
17ae31c339SArnaldo Carvalho de Melo #include <linux/types.h>
18ae31c339SArnaldo Carvalho de Melo 
19ae31c339SArnaldo Carvalho de Melo /* Read about the ECN nonce to see why it is 253 */
20bdf13d20SAndrea Bittau #define DCCP_MAX_ACKVEC_OPT_LEN 253
21bdf13d20SAndrea Bittau /* We can spread an ack vector across multiple options */
22bdf13d20SAndrea Bittau #define DCCP_MAX_ACKVEC_LEN (DCCP_MAX_ACKVEC_OPT_LEN * 2)
23ae31c339SArnaldo Carvalho de Melo 
24ae31c339SArnaldo Carvalho de Melo #define DCCP_ACKVEC_STATE_RECEIVED	0
25ae31c339SArnaldo Carvalho de Melo #define DCCP_ACKVEC_STATE_ECN_MARKED	(1 << 6)
26ae31c339SArnaldo Carvalho de Melo #define DCCP_ACKVEC_STATE_NOT_RECEIVED	(3 << 6)
27ae31c339SArnaldo Carvalho de Melo 
28ae31c339SArnaldo Carvalho de Melo #define DCCP_ACKVEC_STATE_MASK		0xC0 /* 11000000 */
29ae31c339SArnaldo Carvalho de Melo #define DCCP_ACKVEC_LEN_MASK		0x3F /* 00111111 */
30ae31c339SArnaldo Carvalho de Melo 
31ae31c339SArnaldo Carvalho de Melo /** struct dccp_ackvec - ack vector
32ae31c339SArnaldo Carvalho de Melo  *
330e64e94eSGerrit Renker  * This data structure is the one defined in RFC 4340, Appendix A.
34ae31c339SArnaldo Carvalho de Melo  *
35*a47c5104SGerrit Renker  * @av_buf_head - circular buffer head
36*a47c5104SGerrit Renker  * @av_buf_tail - circular buffer tail
37*a47c5104SGerrit Renker  * @av_buf_ackno - ack # of the most recent packet acknowledgeable in the
38*a47c5104SGerrit Renker  *		       buffer (i.e. %av_buf_head)
39*a47c5104SGerrit Renker  * @av_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  *
46*a47c5104SGerrit Renker  * @av_records - list of dccp_ackvec_record
47*a47c5104SGerrit Renker  * @av_ack_nonce - the one-bit sum of the ECN Nonces for all State 0.
48ae31c339SArnaldo Carvalho de Melo  *
49*a47c5104SGerrit Renker  * @av_time - the time in usecs
50*a47c5104SGerrit Renker  * @av_buf - circular buffer of acknowledgeable packets
51ae31c339SArnaldo Carvalho de Melo  */
52ae31c339SArnaldo Carvalho de Melo struct dccp_ackvec {
53*a47c5104SGerrit Renker 	u64			av_buf_ackno;
54*a47c5104SGerrit Renker 	struct list_head	av_records;
55*a47c5104SGerrit Renker 	ktime_t			av_time;
56*a47c5104SGerrit Renker 	u16			av_buf_head;
57*a47c5104SGerrit Renker 	u16			av_vec_len;
58*a47c5104SGerrit Renker 	u8			av_buf_nonce;
59*a47c5104SGerrit Renker 	u8			av_ack_nonce;
60*a47c5104SGerrit Renker 	u8			av_buf[DCCP_MAX_ACKVEC_LEN];
61ae31c339SArnaldo Carvalho de Melo };
62ae31c339SArnaldo Carvalho de Melo 
6302bcf28cSAndrea Bittau /** struct dccp_ackvec_record - ack vector record
6402bcf28cSAndrea Bittau  *
6502bcf28cSAndrea Bittau  * ACK vector record as defined in Appendix A of spec.
6602bcf28cSAndrea Bittau  *
67*a47c5104SGerrit Renker  * The list is sorted by avr_ack_seqno
6802bcf28cSAndrea Bittau  *
69*a47c5104SGerrit Renker  * @avr_node - node in av_records
70*a47c5104SGerrit Renker  * @avr_ack_seqno - sequence number of the packet this record was sent on
71*a47c5104SGerrit Renker  * @avr_ack_ackno - sequence number being acknowledged
72*a47c5104SGerrit Renker  * @avr_ack_ptr - pointer into av_buf where this record starts
73*a47c5104SGerrit Renker  * @avr_ack_nonce - av_ack_nonce at the time this record was sent
74*a47c5104SGerrit Renker  * @avr_sent_len - lenght of the record in av_buf
7502bcf28cSAndrea Bittau  */
7602bcf28cSAndrea Bittau struct dccp_ackvec_record {
77*a47c5104SGerrit Renker 	struct list_head avr_node;
78*a47c5104SGerrit Renker 	u64		 avr_ack_seqno;
79*a47c5104SGerrit Renker 	u64		 avr_ack_ackno;
80*a47c5104SGerrit Renker 	u16		 avr_ack_ptr;
81*a47c5104SGerrit Renker 	u16		 avr_sent_len;
82*a47c5104SGerrit Renker 	u8		 avr_ack_nonce;
8302bcf28cSAndrea Bittau };
8402bcf28cSAndrea Bittau 
85ae31c339SArnaldo Carvalho de Melo struct sock;
86ae31c339SArnaldo Carvalho de Melo struct sk_buff;
87ae31c339SArnaldo Carvalho de Melo 
88ae31c339SArnaldo Carvalho de Melo #ifdef CONFIG_IP_DCCP_ACKVEC
899b07ef5dSArnaldo Carvalho de Melo extern int dccp_ackvec_init(void);
909b07ef5dSArnaldo Carvalho de Melo extern void dccp_ackvec_exit(void);
919b07ef5dSArnaldo Carvalho de Melo 
927400d781SArnaldo Carvalho de Melo extern struct dccp_ackvec *dccp_ackvec_alloc(const gfp_t priority);
93ae31c339SArnaldo Carvalho de Melo extern void dccp_ackvec_free(struct dccp_ackvec *av);
94ae31c339SArnaldo Carvalho de Melo 
95ae31c339SArnaldo Carvalho de Melo extern int dccp_ackvec_add(struct dccp_ackvec *av, const struct sock *sk,
96ae31c339SArnaldo Carvalho de Melo 			   const u64 ackno, const u8 state);
97ae31c339SArnaldo Carvalho de Melo 
98ae31c339SArnaldo Carvalho de Melo extern void dccp_ackvec_check_rcv_ackno(struct dccp_ackvec *av,
99ae31c339SArnaldo Carvalho de Melo 					struct sock *sk, const u64 ackno);
100ae31c339SArnaldo Carvalho de Melo extern int dccp_ackvec_parse(struct sock *sk, const struct sk_buff *skb,
101bdf13d20SAndrea Bittau 			     u64 *ackno, const u8 opt,
102bdf13d20SAndrea Bittau 			     const u8 *value, const u8 len);
103ae31c339SArnaldo Carvalho de Melo 
104ae31c339SArnaldo Carvalho de Melo extern int dccp_insert_option_ackvec(struct sock *sk, struct sk_buff *skb);
105ae31c339SArnaldo Carvalho de Melo 
106ae31c339SArnaldo Carvalho de Melo static inline int dccp_ackvec_pending(const struct dccp_ackvec *av)
107ae31c339SArnaldo Carvalho de Melo {
108*a47c5104SGerrit Renker 	return av->av_vec_len;
109ae31c339SArnaldo Carvalho de Melo }
110ae31c339SArnaldo Carvalho de Melo #else /* CONFIG_IP_DCCP_ACKVEC */
1119b07ef5dSArnaldo Carvalho de Melo static inline int dccp_ackvec_init(void)
1129b07ef5dSArnaldo Carvalho de Melo {
1139b07ef5dSArnaldo Carvalho de Melo 	return 0;
1149b07ef5dSArnaldo Carvalho de Melo }
1159b07ef5dSArnaldo Carvalho de Melo 
1169b07ef5dSArnaldo Carvalho de Melo static inline void dccp_ackvec_exit(void)
1179b07ef5dSArnaldo Carvalho de Melo {
1189b07ef5dSArnaldo Carvalho de Melo }
1199b07ef5dSArnaldo Carvalho de Melo 
1207400d781SArnaldo Carvalho de Melo static inline struct dccp_ackvec *dccp_ackvec_alloc(const gfp_t priority)
121ae31c339SArnaldo Carvalho de Melo {
122ae31c339SArnaldo Carvalho de Melo 	return NULL;
123ae31c339SArnaldo Carvalho de Melo }
124ae31c339SArnaldo Carvalho de Melo 
125ae31c339SArnaldo Carvalho de Melo static inline void dccp_ackvec_free(struct dccp_ackvec *av)
126ae31c339SArnaldo Carvalho de Melo {
127ae31c339SArnaldo Carvalho de Melo }
128ae31c339SArnaldo Carvalho de Melo 
129ae31c339SArnaldo Carvalho de Melo static inline int dccp_ackvec_add(struct dccp_ackvec *av, const struct sock *sk,
130ae31c339SArnaldo Carvalho de Melo 				  const u64 ackno, const u8 state)
131ae31c339SArnaldo Carvalho de Melo {
132ae31c339SArnaldo Carvalho de Melo 	return -1;
133ae31c339SArnaldo Carvalho de Melo }
134ae31c339SArnaldo Carvalho de Melo 
135ae31c339SArnaldo Carvalho de Melo static inline void dccp_ackvec_check_rcv_ackno(struct dccp_ackvec *av,
136ae31c339SArnaldo Carvalho de Melo 					       struct sock *sk, const u64 ackno)
137ae31c339SArnaldo Carvalho de Melo {
138ae31c339SArnaldo Carvalho de Melo }
139ae31c339SArnaldo Carvalho de Melo 
140ae31c339SArnaldo Carvalho de Melo static inline int dccp_ackvec_parse(struct sock *sk, const struct sk_buff *skb,
141bdf13d20SAndrea Bittau 				    const u64 *ackno, const u8 opt,
142bdf13d20SAndrea Bittau 				    const u8 *value, const u8 len)
143ae31c339SArnaldo Carvalho de Melo {
144ae31c339SArnaldo Carvalho de Melo 	return -1;
145ae31c339SArnaldo Carvalho de Melo }
146ae31c339SArnaldo Carvalho de Melo 
147ae31c339SArnaldo Carvalho de Melo static inline int dccp_insert_option_ackvec(const struct sock *sk,
148ae31c339SArnaldo Carvalho de Melo 					    const struct sk_buff *skb)
149ae31c339SArnaldo Carvalho de Melo {
150ae31c339SArnaldo Carvalho de Melo 	return -1;
151ae31c339SArnaldo Carvalho de Melo }
152ae31c339SArnaldo Carvalho de Melo 
153ae31c339SArnaldo Carvalho de Melo static inline int dccp_ackvec_pending(const struct dccp_ackvec *av)
154ae31c339SArnaldo Carvalho de Melo {
155ae31c339SArnaldo Carvalho de Melo 	return 0;
156ae31c339SArnaldo Carvalho de Melo }
157ae31c339SArnaldo Carvalho de Melo #endif /* CONFIG_IP_DCCP_ACKVEC */
158ae31c339SArnaldo Carvalho de Melo #endif /* _ACKVEC_H */
159