xref: /freebsd/contrib/ntp/include/recvbuff.h (revision 77a0943ded95b9e6438f7db70c4a28e4d93946d4)
1 #if !defined __recvbuff_h
2 #define __recvbuff_h
3 
4 #ifdef HAVE_CONFIG_H
5 # include <config.h>
6 #endif
7 
8 #include "ntp.h"
9 #include "ntp_fp.h"
10 #include "ntp_types.h"
11 
12 /*
13  * recvbuf memory management
14  */
15 #define RECV_INIT	10	/* 10 buffers initially */
16 #define RECV_LOWAT	3	/* when we're down to three buffers get more */
17 #define RECV_INC	5	/* get 5 more at a time */
18 #define RECV_TOOMANY	40	/* this is way too many buffers */
19 
20 #if defined HAVE_IO_COMPLETION_PORT
21 # include "ntp_iocompletionport.h"
22 #include "ntp_timer.h"
23 
24 # define RECV_BLOCK_IO()	EnterCriticalSection(&RecvCritSection)
25 # define RECV_UNBLOCK_IO()	LeaveCriticalSection(&RecvCritSection)
26 
27 /*  Return the event which is set when items are added to the full list
28  */
29 extern HANDLE	get_recv_buff_event P((void));
30 #else
31 # define RECV_BLOCK_IO()
32 # define RECV_UNBLOCK_IO()
33 #endif
34 
35 
36 /*
37  * Format of a recvbuf.  These are used by the asynchronous receive
38  * routine to store incoming packets and related information.
39  */
40 
41 /*
42  *  the maximum length NTP packet is a full length NTP control message with
43  *  the maximum length message authenticator.  I hate to hard-code 468 and 12,
44  *  but only a few modules include ntp_control.h...
45  */
46 #define	RX_BUFF_SIZE	(468+12+MAX_MAC_LEN)
47 
48 struct recvbuf {
49 	struct recvbuf *next;		/* next buffer in chain */
50 	union {
51 		struct sockaddr_in X_recv_srcadr;
52 		caddr_t X_recv_srcclock;
53 		struct peer *X_recv_peer;
54 	} X_from_where;
55 #define recv_srcadr	X_from_where.X_recv_srcadr
56 #define	recv_srcclock	X_from_where.X_recv_srcclock
57 #define recv_peer	X_from_where.X_recv_peer
58 #if defined HAVE_IO_COMPLETION_PORT
59         IoCompletionInfo	iocompletioninfo;
60 	WSABUF		wsabuff;
61 	DWORD		AddressLength;
62 #else
63 	struct sockaddr_in srcadr;	/* where packet came from */
64 #endif
65 	struct interface *dstadr;	/* interface datagram arrived thru */
66 	int fd;				/* fd on which it was received */
67 	l_fp recv_time;			/* time of arrival */
68 	void (*receiver) P((struct recvbuf *)); /* routine to receive buffer */
69 	int recv_length;		/* number of octets received */
70 	union {
71 		struct pkt X_recv_pkt;
72 		u_char X_recv_buffer[RX_BUFF_SIZE];
73 	} recv_space;
74 #define	recv_pkt	recv_space.X_recv_pkt
75 #define	recv_buffer	recv_space.X_recv_buffer
76 };
77 
78 extern	void	init_recvbuff	P((int));
79 
80 /* freerecvbuf - make a single recvbuf available for reuse
81  */
82 extern	void	freerecvbuf P((struct recvbuf *));
83 
84 
85 extern	struct recvbuf * getrecvbufs P((void));
86 
87 /*  Get a free buffer (typically used so an async
88  *  read can directly place data into the buffer
89  *
90  *  The buffer is removed from the free list. Make sure
91  *  you put it back with freerecvbuf() or
92  */
93 extern	struct recvbuf *get_free_recv_buffer P((void));
94 
95 /*   Add a buffer to the full list
96  */
97 extern	void	add_full_recv_buffer	 P((struct recvbuf *));
98 
99 /*extern	void	process_recv_buffers	 P((void)); */
100 
101 /* number of recvbufs on freelist */
102 extern u_long free_recvbuffs P((void));
103 extern u_long full_recvbuffs P((void));
104 extern u_long total_recvbuffs P((void));
105 extern u_long lowater_additions P((void));
106 
107 /*  Returns the next buffer in the full list.
108  *
109  */
110 extern	struct recvbuf *get_full_recv_buffer P((void));
111 
112 #endif /* defined __recvbuff_h */
113 
114