xref: /openbmc/linux/net/dccp/ackvec.h (revision bdf13d208dee4ada6d2b422536a12b45d5831aa3)
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>
1502bcf28cSAndrea Bittau #include <linux/list.h>
16ae31c339SArnaldo Carvalho de Melo #include <linux/time.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 */
20*bdf13d20SAndrea Bittau #define DCCP_MAX_ACKVEC_OPT_LEN 253
21*bdf13d20SAndrea Bittau /* We can spread an ack vector across multiple options */
22*bdf13d20SAndrea 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  *
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  *
4602bcf28cSAndrea Bittau  * @dccpav_records - list of dccp_ackvec_record
47ae31c339SArnaldo Carvalho de Melo  * @dccpav_ack_nonce - the one-bit sum of the ECN Nonces for all State 0.
48ae31c339SArnaldo Carvalho de Melo  *
49ae31c339SArnaldo Carvalho de Melo  * @dccpav_time		- the time in usecs
50ae31c339SArnaldo Carvalho de Melo  * @dccpav_buf - circular buffer of acknowledgeable packets
51ae31c339SArnaldo Carvalho de Melo  */
52ae31c339SArnaldo Carvalho de Melo struct dccp_ackvec {
53ae31c339SArnaldo Carvalho de Melo 	u64		dccpav_buf_ackno;
5402bcf28cSAndrea Bittau 	struct list_head dccpav_records;
55ae31c339SArnaldo Carvalho de Melo 	struct timeval	dccpav_time;
56*bdf13d20SAndrea Bittau 	u16		dccpav_buf_head;
57*bdf13d20SAndrea Bittau 	u16		dccpav_vec_len;
58ae31c339SArnaldo Carvalho de Melo 	u8		dccpav_buf_nonce;
59ae31c339SArnaldo Carvalho de Melo 	u8		dccpav_ack_nonce;
607400d781SArnaldo Carvalho de Melo 	u8		dccpav_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  *
6702bcf28cSAndrea Bittau  * The list is sorted by dccpavr_ack_seqno
6802bcf28cSAndrea Bittau  *
6902bcf28cSAndrea Bittau  * @dccpavr_node - node in dccpav_records
7002bcf28cSAndrea Bittau  * @dccpavr_ack_seqno - sequence number of the packet this record was sent on
7102bcf28cSAndrea Bittau  * @dccpavr_ack_ackno - sequence number being acknowledged
7202bcf28cSAndrea Bittau  * @dccpavr_ack_ptr - pointer into dccpav_buf where this record starts
7302bcf28cSAndrea Bittau  * @dccpavr_ack_nonce - dccpav_ack_nonce at the time this record was sent
7402bcf28cSAndrea Bittau  * @dccpavr_sent_len - lenght of the record in dccpav_buf
7502bcf28cSAndrea Bittau  */
7602bcf28cSAndrea Bittau struct dccp_ackvec_record {
7702bcf28cSAndrea Bittau 	struct list_head dccpavr_node;
7802bcf28cSAndrea Bittau 	u64		 dccpavr_ack_seqno;
7902bcf28cSAndrea Bittau 	u64		 dccpavr_ack_ackno;
80*bdf13d20SAndrea Bittau 	u16		 dccpavr_ack_ptr;
81*bdf13d20SAndrea Bittau 	u16		 dccpavr_sent_len;
8202bcf28cSAndrea Bittau 	u8		 dccpavr_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,
101*bdf13d20SAndrea Bittau 			     u64 *ackno, const u8 opt,
102*bdf13d20SAndrea 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 {
1084a0a50fbSAndrea Bittau 	return av->dccpav_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,
141*bdf13d20SAndrea Bittau 				    const u64 *ackno, const u8 opt,
142*bdf13d20SAndrea 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