VirtualBox

source: vbox/trunk/src/VBox/Devices/Network/slirp/slirp_state.h@ 14275

Last change on this file since 14275 was 14275, checked in by vboxsync, 16 years ago

TCP reassembling (compilable, but not working version)

  • Property svn:eol-style set to native
File size: 7.7 KB
Line 
1/** @file
2 * NAT state/configuration.
3 */
4
5/*
6 * Copyright (C) 2006-2007 Sun Microsystems, Inc.
7 *
8 * This file is part of VirtualBox Open Source Edition (OSE), as
9 * available from http://www.virtualbox.org. This file is free software;
10 * you can redistribute it and/or modify it under the terms of the GNU
11 * General Public License (GPL) as published by the Free Software
12 * Foundation, in version 2 as it comes in the "COPYING" file of the
13 * VirtualBox OSE distribution. VirtualBox OSE is distributed in the
14 * hope that it will be useful, but WITHOUT ANY WARRANTY of any kind.
15 *
16 * Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa
17 * Clara, CA 95054 USA or visit http://www.sun.com if you need
18 * additional information or have any questions.
19 */
20
21#ifndef _slirp_state_h_
22#define _slirp_state_h_
23
24/** Number of DHCP clients supported by NAT. */
25#define NB_ADDR 16
26
27/** Where to start DHCP IP number allocation. */
28#define START_ADDR 15
29
30/** DHCP Lease time. */
31#define LEASE_TIME (24 * 3600)
32
33/** Entry in the table of known DHCP clients. */
34typedef struct {
35 bool allocated;
36 uint8_t macaddr[6];
37} BOOTPClient;
38
39
40/** TFTP session entry. */
41struct tftp_session {
42 int in_use;
43 unsigned char filename[TFTP_FILENAME_MAX];
44
45 struct in_addr client_ip;
46 u_int16_t client_port;
47
48 int timestamp;
49};
50
51
52/** Main state/configuration structure for slirp NAT. */
53typedef struct NATState
54{
55 /* Stuff from boot.c */
56 BOOTPClient bootp_clients[NB_ADDR];
57 const char *bootp_filename;
58 /* Stuff from if.c */
59 int if_mtu, if_mru;
60 int if_comp;
61 int if_maxlinkhdr;
62 int if_queued;
63 int if_thresh;
64 struct mbuf if_fastq;
65 struct mbuf if_batchq;
66 struct mbuf *next_m;
67 /* Stuff from icmp.c */
68 struct icmpstat_t icmpstat;
69 /* Stuff from ip_input.c */
70 struct ipstat_t ipstat;
71#ifndef VBOX_WITH_BSD_REASS
72 struct ipq_t ipq;
73#else /* !VBOX_WITH_BSD_REASS */
74 struct ipqhead ipq[IPREASS_NHASH];
75 int maxnipq; /* Administrative limit on # of reass queues*/
76 int maxfragsperpacket; /* Maximum number of IPv4 fragments allowed per packet */
77 int nipq; /* total number of reass queues */
78#endif /* VBOX_WITH_BSD_REASS */
79 uint16_t ip_currid;
80 /* Stuff from mbuf.c */
81 int mbuf_alloced, mbuf_max;
82 int msize;
83 struct mbuf m_freelist, m_usedlist;
84 /* Stuff from slirp.c */
85 void *pvUser;
86 uint32_t curtime;
87 uint32_t time_fasttimo;
88 uint32_t last_slowtimo;
89 bool do_slowtimo;
90 bool link_up;
91 struct timeval tt;
92 struct in_addr our_addr;
93 struct in_addr alias_addr;
94 struct in_addr special_addr;
95 struct in_addr dns_addr;
96 struct in_addr loopback_addr;
97 uint32_t netmask;
98 uint8_t client_ethaddr[6];
99 struct ex_list *exec_list;
100 char slirp_hostname[33];
101 bool fPassDomain;
102 const char *pszDomain;
103 /* Stuff from tcp_input.c */
104 struct socket tcb;
105 struct socket *tcp_last_so;
106 tcp_seq tcp_iss;
107#if ARCH_BITS == 64
108 /* Stuff from tcp_subr.c */
109 void *apvHash[16384];
110 uint32_t cpvHashUsed;
111 uint32_t cpvHashCollisions;
112 uint64_t cpvHashInserts;
113 uint64_t cpvHashDone;
114#endif
115 /* Stuff from tcp_timer.c */
116 struct tcpstat_t tcpstat;
117 uint32_t tcp_now;
118#ifdef VBOX_WITH_BSD_TCP_REASS
119 int tcp_reass_qsize;
120 int tcp_reass_maxqlen;
121 int tcp_reass_maxseg;
122 int tcp_reass_overflows;
123#endif /* VBOX_WITH_BSD_TCP_REASS */
124 /* Stuff from tftp.c */
125 struct tftp_session tftp_sessions[TFTP_SESSIONS_MAX];
126 const char *tftp_prefix;
127 /* Stuff from udp.c */
128 struct udpstat_t udpstat;
129 struct socket udb;
130 struct socket *udp_last_so;
131#if defined(VBOX_WITH_SIMPLEFIED_SLIRP_SYNC) && defined(RT_OS_WINDOWS)
132# define VBOX_SOCKET_EVENT (pData->phEvents[VBOX_SOCKET_EVENT_INDEX])
133 HANDLE phEvents[VBOX_EVENT_COUNT];
134#endif
135 STAMPROFILE StatFill;
136 STAMPROFILE StatPoll;
137 STAMPROFILE StatFastTimer;
138 STAMPROFILE StatSlowTimer;
139 STAMCOUNTER StatTCP;
140 STAMCOUNTER StatUDP;
141 STAMCOUNTER StatTCPHot;
142 STAMCOUNTER StatUDPHot;
143} NATState;
144
145
146/** Default IP time to live. */
147#define ip_defttl IPDEFTTL
148
149/** Number of permanent buffers in mbuf. */
150#define mbuf_thresh 30
151
152/** Use a fixed time before sending keepalive. */
153#define tcp_keepidle TCPTV_KEEP_IDLE
154
155/** Use a fixed interval between keepalive. */
156#define tcp_keepintvl TCPTV_KEEPINTVL
157
158/** Maximum idle time before timing out a connection. */
159#define tcp_maxidle (TCPTV_KEEPCNT * tcp_keepintvl)
160
161/** Default TCP socket options. */
162#define so_options DO_KEEPALIVE
163
164/** Default TCP MSS value. */
165#define tcp_mssdflt TCP_MSS
166
167/** Default TCP round trip time. */
168#define tcp_rttdflt (TCPTV_SRTTDFLT / PR_SLOWHZ)
169
170/** Enable RFC1323 performance enhancements.
171 * @todo check if it really works, it was turned off before. */
172#define tcp_do_rfc1323 1
173
174/** TCP receive buffer size. */
175#define tcp_rcvspace TCP_RCVSPACE
176
177/** TCP receive buffer size. */
178#define tcp_sndspace TCP_SNDSPACE
179
180/* TCP duplicate ACK retransmit threshold. */
181#define tcprexmtthresh 3
182
183
184#define bootp_filename pData->bootp_filename
185#define bootp_clients pData->bootp_clients
186
187#define if_mtu pData->if_mtu
188#define if_mru pData->if_mru
189#define if_comp pData->if_comp
190#define if_maxlinkhdr pData->if_maxlinkhdr
191#define if_queued pData->if_queued
192#define if_thresh pData->if_thresh
193#define if_fastq pData->if_fastq
194#define if_batchq pData->if_batchq
195#define next_m pData->next_m
196
197#define icmpstat pData->icmpstat
198
199#define ipstat pData->ipstat
200#define ipq pData->ipq
201#define ip_currid pData->ip_currid
202
203#define mbuf_alloced pData->mbuf_alloced
204#define mbuf_max pData->mbuf_max
205#define msize pData->msize
206#define m_freelist pData->m_freelist
207#define m_usedlist pData->m_usedlist
208
209#define curtime pData->curtime
210#define time_fasttimo pData->time_fasttimo
211#define last_slowtimo pData->last_slowtimo
212#define do_slowtimo pData->do_slowtimo
213#define link_up pData->link_up
214#define cUsers pData->cUsers
215#define tt pData->tt
216#define our_addr pData->our_addr
217#define alias_addr pData->alias_addr
218#define special_addr pData->special_addr
219#define dns_addr pData->dns_addr
220#define loopback_addr pData->loopback_addr
221#define client_ethaddr pData->client_ethaddr
222#define exec_list pData->exec_list
223#define slirp_hostname pData->slirp_hostname
224
225#define tcb pData->tcb
226#define tcp_last_so pData->tcp_last_so
227#define tcp_iss pData->tcp_iss
228
229#define tcpstat pData->tcpstat
230#define tcp_now pData->tcp_now
231
232#define tftp_sessions pData->tftp_sessions
233#define tftp_prefix pData->tftp_prefix
234
235#define udpstat pData->udpstat
236#define udb pData->udb
237#define udp_last_so pData->udp_last_so
238
239#ifdef VBOX_WITH_BSD_REASS
240#define maxfragsperpacket pData->maxfragsperpacket
241#define maxnipq pData->maxnipq
242#define nipq pData->nipq
243#endif /* VBOX_WITH_BSD_REASS */
244
245#ifdef VBOX_WITH_BSD_TCP_REASS
246#define tcp_reass_qsize pData->tcp_reass_qsize
247#define tcp_reass_maxqlen pData->tcp_reass_maxqlen
248#define tcp_reass_maxseg pData->tcp_reass_maxseg
249#define tcp_reass_overflows pData->tcp_reass_overflows
250#endif /* VBOX_WITH_BSD_TCP_REASS */
251
252#if SIZEOF_CHAR_P != 4
253 extern void VBoxU32PtrDone(PNATState pData, void *pv, uint32_t iHint);
254 extern uint32_t VBoxU32PtrHashSlow(PNATState pData, void *pv);
255
256 /** Hash the pointer, inserting it if need be. */
257 DECLINLINE(uint32_t) VBoxU32PtrHash(PNATState pData, void *pv)
258 {
259 uint32_t i = ((uintptr_t)pv >> 3) % RT_ELEMENTS(pData->apvHash);
260 if (RT_LIKELY(pData->apvHash[i] == pv && pv))
261 return i;
262 return VBoxU32PtrHashSlow(pData, pv);
263 }
264 /** Lookup the hash value. */
265 DECLINLINE(void *) VBoxU32PtrLookup(PNATState pData, uint32_t i)
266 {
267 void *pv;
268 Assert(i < RT_ELEMENTS(pData->apvHash));
269 pv = pData->apvHash[i];
270 Assert(pv || !i);
271 return pv;
272 }
273#endif
274
275
276#endif /* !_slirp_state_h_ */
Note: See TracBrowser for help on using the repository browser.

© 2024 Oracle Support Privacy / Do Not Sell My Info Terms of Use Trademark Policy Automated Access Etiquette