xref: /openbmc/linux/net/dccp/ackvec.h (revision 0e64e94e477f8ed04e9295b11a5898d443c28a47)
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 */
20ae31c339SArnaldo Carvalho de Melo #define DCCP_MAX_ACKVEC_LEN 253
21ae31c339SArnaldo Carvalho de Melo 
22ae31c339SArnaldo Carvalho de Melo #define DCCP_ACKVEC_STATE_RECEIVED	0
23ae31c339SArnaldo Carvalho de Melo #define DCCP_ACKVEC_STATE_ECN_MARKED	(1 << 6)
24ae31c339SArnaldo Carvalho de Melo #define DCCP_ACKVEC_STATE_NOT_RECEIVED	(3 << 6)
25ae31c339SArnaldo Carvalho de Melo 
26ae31c339SArnaldo Carvalho de Melo #define DCCP_ACKVEC_STATE_MASK		0xC0 /* 11000000 */
27ae31c339SArnaldo Carvalho de Melo #define DCCP_ACKVEC_LEN_MASK		0x3F /* 00111111 */
28ae31c339SArnaldo Carvalho de Melo 
29ae31c339SArnaldo Carvalho de Melo /** struct dccp_ackvec - ack vector
30ae31c339SArnaldo Carvalho de Melo  *
31*0e64e94eSGerrit Renker  * This data structure is the one defined in RFC 4340, Appendix A.
32ae31c339SArnaldo Carvalho de Melo  *
33ae31c339SArnaldo Carvalho de Melo  * @dccpav_buf_head - circular buffer head
34ae31c339SArnaldo Carvalho de Melo  * @dccpav_buf_tail - circular buffer tail
35ae31c339SArnaldo Carvalho de Melo  * @dccpav_buf_ackno - ack # of the most recent packet acknowledgeable in the
36ae31c339SArnaldo Carvalho de Melo  * 		       buffer (i.e. %dccpav_buf_head)
37ae31c339SArnaldo Carvalho de Melo  * @dccpav_buf_nonce - the one-bit sum of the ECN Nonces on all packets acked
38ae31c339SArnaldo Carvalho de Melo  * 		       by the buffer with State 0
39ae31c339SArnaldo Carvalho de Melo  *
40ae31c339SArnaldo Carvalho de Melo  * Additionally, the HC-Receiver must keep some information about the
41ae31c339SArnaldo Carvalho de Melo  * Ack Vectors it has recently sent. For each packet sent carrying an
42ae31c339SArnaldo Carvalho de Melo  * Ack Vector, it remembers four variables:
43ae31c339SArnaldo Carvalho de Melo  *
44ae31c339SArnaldo Carvalho de Melo  * @dccpav_ack_ptr - the value of buf_head at the time of acknowledgement.
4502bcf28cSAndrea Bittau  * @dccpav_records - list of dccp_ackvec_record
46ae31c339SArnaldo Carvalho de Melo  * @dccpav_ack_nonce - the one-bit sum of the ECN Nonces for all State 0.
47ae31c339SArnaldo Carvalho de Melo  *
48ae31c339SArnaldo Carvalho de Melo  * @dccpav_time		- the time in usecs
49ae31c339SArnaldo Carvalho de Melo  * @dccpav_buf - circular buffer of acknowledgeable packets
50ae31c339SArnaldo Carvalho de Melo  */
51ae31c339SArnaldo Carvalho de Melo struct dccp_ackvec {
52ae31c339SArnaldo Carvalho de Melo 	u64		dccpav_buf_ackno;
5302bcf28cSAndrea Bittau 	struct list_head dccpav_records;
54ae31c339SArnaldo Carvalho de Melo 	struct timeval	dccpav_time;
55e4dfd449SArnaldo Carvalho de Melo 	u8		dccpav_buf_head;
56e4dfd449SArnaldo Carvalho de Melo 	u8		dccpav_ack_ptr;
57e4dfd449SArnaldo Carvalho de Melo 	u8		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;
8002bcf28cSAndrea Bittau 	u8		 dccpavr_ack_ptr;
8102bcf28cSAndrea Bittau 	u8		 dccpavr_ack_nonce;
8202bcf28cSAndrea Bittau 	u8		 dccpavr_sent_len;
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,
101ae31c339SArnaldo Carvalho de Melo 			     const u8 opt, const u8 *value, const u8 len);
102ae31c339SArnaldo Carvalho de Melo 
103ae31c339SArnaldo Carvalho de Melo extern int dccp_insert_option_ackvec(struct sock *sk, struct sk_buff *skb);
104ae31c339SArnaldo Carvalho de Melo 
105ae31c339SArnaldo Carvalho de Melo static inline int dccp_ackvec_pending(const struct dccp_ackvec *av)
106ae31c339SArnaldo Carvalho de Melo {
1074a0a50fbSAndrea Bittau 	return av->dccpav_vec_len;
108ae31c339SArnaldo Carvalho de Melo }
109ae31c339SArnaldo Carvalho de Melo #else /* CONFIG_IP_DCCP_ACKVEC */
1109b07ef5dSArnaldo Carvalho de Melo static inline int dccp_ackvec_init(void)
1119b07ef5dSArnaldo Carvalho de Melo {
1129b07ef5dSArnaldo Carvalho de Melo 	return 0;
1139b07ef5dSArnaldo Carvalho de Melo }
1149b07ef5dSArnaldo Carvalho de Melo 
1159b07ef5dSArnaldo Carvalho de Melo static inline void dccp_ackvec_exit(void)
1169b07ef5dSArnaldo Carvalho de Melo {
1179b07ef5dSArnaldo Carvalho de Melo }
1189b07ef5dSArnaldo Carvalho de Melo 
1197400d781SArnaldo Carvalho de Melo static inline struct dccp_ackvec *dccp_ackvec_alloc(const gfp_t priority)
120ae31c339SArnaldo Carvalho de Melo {
121ae31c339SArnaldo Carvalho de Melo 	return NULL;
122ae31c339SArnaldo Carvalho de Melo }
123ae31c339SArnaldo Carvalho de Melo 
124ae31c339SArnaldo Carvalho de Melo static inline void dccp_ackvec_free(struct dccp_ackvec *av)
125ae31c339SArnaldo Carvalho de Melo {
126ae31c339SArnaldo Carvalho de Melo }
127ae31c339SArnaldo Carvalho de Melo 
128ae31c339SArnaldo Carvalho de Melo static inline int dccp_ackvec_add(struct dccp_ackvec *av, const struct sock *sk,
129ae31c339SArnaldo Carvalho de Melo 				  const u64 ackno, const u8 state)
130ae31c339SArnaldo Carvalho de Melo {
131ae31c339SArnaldo Carvalho de Melo 	return -1;
132ae31c339SArnaldo Carvalho de Melo }
133ae31c339SArnaldo Carvalho de Melo 
134ae31c339SArnaldo Carvalho de Melo static inline void dccp_ackvec_check_rcv_ackno(struct dccp_ackvec *av,
135ae31c339SArnaldo Carvalho de Melo 					       struct sock *sk, const u64 ackno)
136ae31c339SArnaldo Carvalho de Melo {
137ae31c339SArnaldo Carvalho de Melo }
138ae31c339SArnaldo Carvalho de Melo 
139ae31c339SArnaldo Carvalho de Melo static inline int dccp_ackvec_parse(struct sock *sk, const struct sk_buff *skb,
140ae31c339SArnaldo Carvalho de Melo 				    const u8 opt, const u8 *value, const u8 len)
141ae31c339SArnaldo Carvalho de Melo {
142ae31c339SArnaldo Carvalho de Melo 	return -1;
143ae31c339SArnaldo Carvalho de Melo }
144ae31c339SArnaldo Carvalho de Melo 
145ae31c339SArnaldo Carvalho de Melo static inline int dccp_insert_option_ackvec(const struct sock *sk,
146ae31c339SArnaldo Carvalho de Melo 					    const struct sk_buff *skb)
147ae31c339SArnaldo Carvalho de Melo {
148ae31c339SArnaldo Carvalho de Melo 	return -1;
149ae31c339SArnaldo Carvalho de Melo }
150ae31c339SArnaldo Carvalho de Melo 
151ae31c339SArnaldo Carvalho de Melo static inline int dccp_ackvec_pending(const struct dccp_ackvec *av)
152ae31c339SArnaldo Carvalho de Melo {
153ae31c339SArnaldo Carvalho de Melo 	return 0;
154ae31c339SArnaldo Carvalho de Melo }
155ae31c339SArnaldo Carvalho de Melo #endif /* CONFIG_IP_DCCP_ACKVEC */
156ae31c339SArnaldo Carvalho de Melo #endif /* _ACKVEC_H */
157