Blame view

net/ipv4/Kconfig 25.9 KB
ec8f24b7f   Thomas Gleixner   treewide: Add SPD...
1
  # SPDX-License-Identifier: GPL-2.0-only
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
2
3
4
5
6
  #
  # IP configuration
  #
  config IP_MULTICAST
  	bool "IP: multicasting"
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
7
8
9
10
11
12
  	help
  	  This is code for addressing several networked computers at once,
  	  enlarging your kernel by about 2 KB. You need multicasting if you
  	  intend to participate in the MBONE, a high bandwidth network on top
  	  of the Internet which carries audio and video broadcasts. More
  	  information about the MBONE is on the WWW at
7a6498ebc   Alexander A. Klimov   Replace HTTP link...
13
  	  <https://www.savetz.com/mbone/>. For most people, it's safe to say N.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
14
15
16
  
  config IP_ADVANCED_ROUTER
  	bool "IP: advanced router"
a7f7f6248   Masahiro Yamada   treewide: replace...
17
  	help
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
  	  If you intend to run your Linux box mostly as a router, i.e. as a
  	  computer that forwards and redistributes network packets, say Y; you
  	  will then be presented with several options that allow more precise
  	  control about the routing process.
  
  	  The answer to this question won't directly affect the kernel:
  	  answering N will just cause the configurator to skip all the
  	  questions about advanced routing.
  
  	  Note that your box can only act as a router if you enable IP
  	  forwarding in your kernel; you can do that by saying Y to "/proc
  	  file system support" and "Sysctl support" below and executing the
  	  line
  
  	  echo "1" > /proc/sys/net/ipv4/ip_forward
  
  	  at boot time after the /proc file system has been mounted.
b2cc46a8e   Jesper Dangaard Brouer   ipv4: Fix rp_filt...
35
  	  If you turn on IP forwarding, you should consider the rp_filter, which
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
36
37
38
39
40
41
42
  	  automatically rejects incoming packets if the routing table entry
  	  for their source address doesn't match the network interface they're
  	  arriving on. This has security advantages because it prevents the
  	  so-called IP spoofing, however it can pose problems if you use
  	  asymmetric routing (packets from you to a host take a different path
  	  than packets from that host to you) or if you operate a non-routing
  	  host which has several IP addresses on different interfaces. To turn
d73943720   Dave Jones   [IPV4]: Correct r...
43
  	  rp_filter on use:
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
44

d73943720   Dave Jones   [IPV4]: Correct r...
45
  	  echo 1 > /proc/sys/net/ipv4/conf/<device>/rp_filter
750e9fad8   Nicolas Dichtel   ipv4: minor fix a...
46
  	   or
d73943720   Dave Jones   [IPV4]: Correct r...
47
  	  echo 1 > /proc/sys/net/ipv4/conf/all/rp_filter
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
48

b2cc46a8e   Jesper Dangaard Brouer   ipv4: Fix rp_filt...
49
  	  Note that some distributions enable it in startup scripts.
d18921a0e   Jesper Dangaard Brouer   Doc: Refer to ip-...
50
  	  For details about rp_filter strict and loose mode read
1cec2caca   Mauro Carvalho Chehab   docs: networking:...
51
  	  <file:Documentation/networking/ip-sysctl.rst>.
b2cc46a8e   Jesper Dangaard Brouer   ipv4: Fix rp_filt...
52

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
53
  	  If unsure, say N here.
66a2f7fd2   Stephen Hemminger   [IPV4] fib_trie: ...
54
55
  config IP_FIB_TRIE_STATS
  	bool "FIB TRIE statistics"
3630b7c05   David S. Miller   ipv4: Remove fib_...
56
  	depends on IP_ADVANCED_ROUTER
a7f7f6248   Masahiro Yamada   treewide: replace...
57
  	help
66a2f7fd2   Stephen Hemminger   [IPV4] fib_trie: ...
58
59
  	  Keep track of statistics on structure of FIB TRIE table.
  	  Useful for testing and measuring TRIE performance.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
60
61
62
  config IP_MULTIPLE_TABLES
  	bool "IP: policy routing"
  	depends on IP_ADVANCED_ROUTER
e1ef4bf23   Thomas Graf   [IPV4]: Use Proto...
63
  	select FIB_RULES
a7f7f6248   Masahiro Yamada   treewide: replace...
64
  	help
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
65
66
67
68
69
  	  Normally, a router decides what to do with a received packet based
  	  solely on the packet's final destination address. If you say Y here,
  	  the Linux router will also be able to take the packet's source
  	  address into account. Furthermore, the TOS (Type-Of-Service) field
  	  of the packet can be used for routing decisions as well.
12ed3772b   Stephen Hemminger   ip: update policy...
70
71
  	  If you need more information, see the Linux Advanced
  	  Routing and Traffic Control documentation at
7a6498ebc   Alexander A. Klimov   Replace HTTP link...
72
  	  <https://lartc.org/howto/lartc.rpdb.html>
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
73
74
  
  	  If unsure, say N.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
75
76
77
78
79
80
81
82
83
84
85
  config IP_ROUTE_MULTIPATH
  	bool "IP: equal cost multipath"
  	depends on IP_ADVANCED_ROUTER
  	help
  	  Normally, the routing tables specify a single action to be taken in
  	  a deterministic manner for a given packet. If you say Y here
  	  however, it becomes possible to attach several actions to a packet
  	  pattern, in effect specifying several alternative paths to travel
  	  for those packets. The router considers all these paths to be of
  	  equal "cost" and chooses one of them in a non-deterministic fashion
  	  if a matching packet arrives.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
86
87
88
89
90
91
92
93
94
95
  config IP_ROUTE_VERBOSE
  	bool "IP: verbose route monitoring"
  	depends on IP_ADVANCED_ROUTER
  	help
  	  If you say Y here, which is recommended, then the kernel will print
  	  verbose messages regarding the routing, for example warnings about
  	  received packets which look strange and could be evidence of an
  	  attack or a misconfigured system somewhere. The information is
  	  handled by the klogd daemon which is responsible for kernel messages
  	  ("man klogd").
c7066f70d   Patrick McHardy   netfilter: fix Kc...
96
97
  config IP_ROUTE_CLASSID
  	bool
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
98
99
  config IP_PNP
  	bool "IP: kernel level autoconfiguration"
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
100
101
102
103
104
105
106
107
108
109
110
111
  	help
  	  This enables automatic configuration of IP addresses of devices and
  	  of the routing table during kernel boot, based on either information
  	  supplied on the kernel command line or by BOOTP or RARP protocols.
  	  You need to say Y only for diskless machines requiring network
  	  access to boot (in which case you want to say Y to "Root file system
  	  on NFS" as well), because all other machines configure the network
  	  in their startup scripts.
  
  config IP_PNP_DHCP
  	bool "IP: DHCP support"
  	depends on IP_PNP
a7f7f6248   Masahiro Yamada   treewide: replace...
112
  	help
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
113
114
115
116
117
118
119
120
121
122
123
  	  If you want your Linux box to mount its whole root file system (the
  	  one containing the directory /) from some other computer over the
  	  net via NFS and you want the IP address of your computer to be
  	  discovered automatically at boot time using the DHCP protocol (a
  	  special protocol designed for doing this job), say Y here. In case
  	  the boot ROM of your network card was designed for booting Linux and
  	  does DHCP itself, providing all necessary information on the kernel
  	  command line, you can say N here.
  
  	  If unsure, say Y. Note that if you want to use DHCP, a DHCP server
  	  must be operating on your network.  Read
3eb30c51a   Niklas Söderlund   Documentation: nf...
124
  	  <file:Documentation/admin-guide/nfs/nfsroot.rst> for details.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
125
126
127
128
  
  config IP_PNP_BOOTP
  	bool "IP: BOOTP support"
  	depends on IP_PNP
a7f7f6248   Masahiro Yamada   treewide: replace...
129
  	help
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
130
131
132
133
134
135
136
137
138
  	  If you want your Linux box to mount its whole root file system (the
  	  one containing the directory /) from some other computer over the
  	  net via NFS and you want the IP address of your computer to be
  	  discovered automatically at boot time using the BOOTP protocol (a
  	  special protocol designed for doing this job), say Y here. In case
  	  the boot ROM of your network card was designed for booting Linux and
  	  does BOOTP itself, providing all necessary information on the kernel
  	  command line, you can say N here. If unsure, say Y. Note that if you
  	  want to use BOOTP, a BOOTP server must be operating on your network.
3eb30c51a   Niklas Söderlund   Documentation: nf...
139
  	  Read <file:Documentation/admin-guide/nfs/nfsroot.rst> for details.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
140
141
142
143
144
145
146
147
148
149
150
  
  config IP_PNP_RARP
  	bool "IP: RARP support"
  	depends on IP_PNP
  	help
  	  If you want your Linux box to mount its whole root file system (the
  	  one containing the directory /) from some other computer over the
  	  net via NFS and you want the IP address of your computer to be
  	  discovered automatically at boot time using the RARP protocol (an
  	  older protocol which is being obsoleted by BOOTP and DHCP), say Y
  	  here. Note that if you want to use RARP, a RARP server must be
6ded55da6   J. Bruce Fields   Documentation: mo...
151
  	  operating on your network. Read
3eb30c51a   Niklas Söderlund   Documentation: nf...
152
  	  <file:Documentation/admin-guide/nfs/nfsroot.rst> for details.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
153

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
154
155
  config NET_IPIP
  	tristate "IP: tunneling"
d2acc3479   Herbert Xu   [INET]: Introduce...
156
  	select INET_TUNNEL
fd58156e4   Pravin B Shelar   IPIP: Use ip-tunn...
157
  	select NET_IP_TUNNEL
a7f7f6248   Masahiro Yamada   treewide: replace...
158
  	help
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
159
160
161
162
163
164
165
166
167
168
169
170
  	  Tunneling means encapsulating data of one protocol type within
  	  another protocol and sending it over a channel that understands the
  	  encapsulating protocol. This particular tunneling driver implements
  	  encapsulation of IP within IP, which sounds kind of pointless, but
  	  can be useful if you want to make your (or some other) machine
  	  appear on a different network than it physically is, or to use
  	  mobile-IP facilities (allowing laptops to seamlessly move between
  	  networks without changing their IP addresses).
  
  	  Saying Y to this option will produce two modules ( = code which can
  	  be inserted in and removed from the running kernel whenever you
  	  want). Most people won't need this and can say N.
00959ade3   Dmitry Kozlov   PPTP: PPP over IP...
171
172
173
  config NET_IPGRE_DEMUX
  	tristate "IP: GRE demultiplexer"
  	help
43da14110   Krzysztof Kozlowski   net: Fix Kconfig ...
174
175
  	  This is helper module to demultiplex GRE packets on GRE version field criteria.
  	  Required by ip_gre and pptp modules.
00959ade3   Dmitry Kozlov   PPTP: PPP over IP...
176

c54419321   Pravin B Shelar   GRE: Refactor GRE...
177
178
  config NET_IP_TUNNEL
  	tristate
e09acddf8   Paolo Abeni   ip_tunnel: replac...
179
  	select DST_CACHE
97e219b7c   Eric Dumazet   gro_cells: move t...
180
  	select GRO_CELLS
c54419321   Pravin B Shelar   GRE: Refactor GRE...
181
  	default n
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
182
183
  config NET_IPGRE
  	tristate "IP: GRE tunnels over IP"
21a180cda   David S. Miller   Merge branch 'mas...
184
  	depends on (IPV6 || IPV6=n) && NET_IPGRE_DEMUX
c54419321   Pravin B Shelar   GRE: Refactor GRE...
185
  	select NET_IP_TUNNEL
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
  	help
  	  Tunneling means encapsulating data of one protocol type within
  	  another protocol and sending it over a channel that understands the
  	  encapsulating protocol. This particular tunneling driver implements
  	  GRE (Generic Routing Encapsulation) and at this time allows
  	  encapsulating of IPv4 or IPv6 over existing IPv4 infrastructure.
  	  This driver is useful if the other endpoint is a Cisco router: Cisco
  	  likes GRE much better than the other Linux tunneling driver ("IP
  	  tunneling" above). In addition, GRE allows multicast redistribution
  	  through the tunnel.
  
  config NET_IPGRE_BROADCAST
  	bool "IP: broadcast GRE over IP"
  	depends on IP_MULTICAST && NET_IPGRE
  	help
  	  One application of GRE/IP is to construct a broadcast WAN (Wide Area
  	  Network), which looks like a normal Ethernet LAN (Local Area
  	  Network), but can be distributed all over the Internet. If you want
  	  to do that, say Y here and to "IP multicast routing" below.
6853f21f7   Yuval Mintz   ipmr,ipmr6: Defin...
205
206
207
  config IP_MROUTE_COMMON
  	bool
  	depends on IP_MROUTE || IPV6_MROUTE
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
208
209
210
  config IP_MROUTE
  	bool "IP: multicast routing"
  	depends on IP_MULTICAST
6853f21f7   Yuval Mintz   ipmr,ipmr6: Defin...
211
  	select IP_MROUTE_COMMON
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
212
213
214
215
216
  	help
  	  This is used if you want your machine to act as a router for IP
  	  packets that have several destination addresses. It is needed on the
  	  MBONE, a high bandwidth network on top of the Internet which carries
  	  audio and video broadcasts. In order to do that, you would most
4960c2c6f   Jean Sacren   Kconfig: remove d...
217
218
  	  likely run the program mrouted. If you haven't heard about it, you
  	  don't need it.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
219

f0ad0860d   Patrick McHardy   ipv4: ipmr: suppo...
220
221
  config IP_MROUTE_MULTIPLE_TABLES
  	bool "IP: multicast policy routing"
66496d497   Patrick McHardy   ipv4: ipmr: fix I...
222
  	depends on IP_MROUTE && IP_ADVANCED_ROUTER
f0ad0860d   Patrick McHardy   ipv4: ipmr: suppo...
223
224
225
226
227
228
229
230
231
232
  	select FIB_RULES
  	help
  	  Normally, a multicast router runs a userspace daemon and decides
  	  what to do with a multicast packet based on the source and
  	  destination addresses. If you say Y here, the multicast router
  	  will also be able to take interfaces and packet marks into
  	  account and run multiple instances of userspace daemons
  	  simultaneously, each one handling a single table.
  
  	  If unsure, say N.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
  config IP_PIMSM_V1
  	bool "IP: PIM-SM version 1 support"
  	depends on IP_MROUTE
  	help
  	  Kernel side support for Sparse Mode PIM (Protocol Independent
  	  Multicast) version 1. This multicast routing protocol is used widely
  	  because Cisco supports it. You need special software to use it
  	  (pimd-v1). Please see <http://netweb.usc.edu/pim/> for more
  	  information about PIM.
  
  	  Say Y if you want to use PIM-SM v1. Note that you can say N here if
  	  you just want to use Dense Mode PIM.
  
  config IP_PIMSM_V2
  	bool "IP: PIM-SM version 2 support"
  	depends on IP_MROUTE
  	help
  	  Kernel side support for Sparse Mode PIM version 2. In order to use
  	  this, you need an experimental routing daemon supporting it (pimd or
  	  gated-5). This routing protocol is not used widely, so say N unless
  	  you want to play with it.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
254
  config SYN_COOKIES
57f1553ee   Florian Westphal   syncookies: remov...
255
  	bool "IP: TCP syncookie support"
a7f7f6248   Masahiro Yamada   treewide: replace...
256
  	help
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
257
258
259
260
261
262
263
264
265
266
267
268
  	  Normal TCP/IP networking is open to an attack known as "SYN
  	  flooding". This denial-of-service attack prevents legitimate remote
  	  users from being able to connect to your computer during an ongoing
  	  attack and requires very little work from the attacker, who can
  	  operate from anywhere on the Internet.
  
  	  SYN cookies provide protection against this type of attack. If you
  	  say Y here, the TCP/IP stack will use a cryptographic challenge
  	  protocol known as "SYN cookies" to enable legitimate users to
  	  continue to connect, even when your machine is under attack. There
  	  is no need for the legitimate users to change their TCP/IP software;
  	  SYN cookies work transparently to them. For technical information
7a6498ebc   Alexander A. Klimov   Replace HTTP link...
269
  	  about SYN cookies, check out <https://cr.yp.to/syncookies.html>.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
270
271
272
273
274
275
276
277
278
  
  	  If you are SYN flooded, the source address reported by the kernel is
  	  likely to have been forged by the attacker; it is only reported as
  	  an aid in tracing the packets to their actual source and should not
  	  be taken as absolute truth.
  
  	  SYN cookies may prevent correct error reporting on clients when the
  	  server is really overloaded. If this happens frequently better turn
  	  them off.
57f1553ee   Florian Westphal   syncookies: remov...
279
280
  	  If you say Y here, you can disable SYN cookies at run time by
  	  saying Y to "/proc file system support" and
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
281
  	  "Sysctl support" below and executing the command
57f1553ee   Florian Westphal   syncookies: remov...
282
  	  echo 0 > /proc/sys/net/ipv4/tcp_syncookies
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
283

57f1553ee   Florian Westphal   syncookies: remov...
284
  	  after the /proc file system has been mounted.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
285
286
  
  	  If unsure, say N.
1181412c1   Saurabh   net/ipv4: VTI sup...
287
288
  config NET_IPVTI
  	tristate "Virtual (secure) IP: tunneling"
f1ed10264   Nicolas Dichtel   vti[6]: fix packe...
289
  	depends on IPV6 || IPV6=n
1181412c1   Saurabh   net/ipv4: VTI sup...
290
  	select INET_TUNNEL
f61dd388a   Pravin B Shelar   Tunneling: use IP...
291
  	select NET_IP_TUNNEL
4c145dce2   Florian Westphal   xfrm: make xfrm m...
292
  	select XFRM
a7f7f6248   Masahiro Yamada   treewide: replace...
293
  	help
1181412c1   Saurabh   net/ipv4: VTI sup...
294
295
296
297
298
  	  Tunneling means encapsulating data of one protocol type within
  	  another protocol and sending it over a channel that understands the
  	  encapsulating protocol. This can be used with xfrm mode tunnel to give
  	  the notion of a secure tunnel for IPSEC and then use routing protocol
  	  on top.
8024e0287   Tom Herbert   udp: Add udp_sock...
299
300
  config NET_UDP_TUNNEL
  	tristate
7c5df8fa1   Andy Zhou   openvswitch: fix ...
301
  	select NET_IP_TUNNEL
8024e0287   Tom Herbert   udp: Add udp_sock...
302
  	default n
23461551c   Tom Herbert   fou: Support for ...
303
304
305
306
  config NET_FOU
  	tristate "IP: Foo (IP protocols) over UDP"
  	select XFRM
  	select NET_UDP_TUNNEL
a7f7f6248   Masahiro Yamada   treewide: replace...
307
  	help
23461551c   Tom Herbert   fou: Support for ...
308
309
310
311
  	  Foo over UDP allows any IP protocol to be directly encapsulated
  	  over UDP include tunnels (IPIP, GRE, SIT). By encapsulating in UDP
  	  network mechanisms and optimizations for UDP (such as ECMP
  	  and RSS) can be leveraged to provide better service.
63487babf   Tom Herbert   net: Move fou_bui...
312
313
314
315
  config NET_FOU_IP_TUNNELS
  	bool "IP: FOU encapsulation of IP tunnels"
  	depends on NET_IPIP || NET_IPGRE || IPV6_SIT
  	select NET_FOU
a7f7f6248   Masahiro Yamada   treewide: replace...
316
  	help
63487babf   Tom Herbert   net: Move fou_bui...
317
318
319
  	  Allow configuration of FOU or GUE encapsulation for IP tunnels.
  	  When this option is enabled IP tunnels can be configured to use
  	  FOU or GUE encapsulation.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
320
321
  config INET_AH
  	tristate "IP: AH transformation"
7d4e39195   Eric Biggers   esp, ah: consolid...
322
  	select XFRM_AH
a7f7f6248   Masahiro Yamada   treewide: replace...
323
  	help
be0136985   Eric Biggers   esp, ah: moderniz...
324
325
326
327
328
329
330
331
  	  Support for IPsec AH (Authentication Header).
  
  	  AH can be used with various authentication algorithms.  Besides
  	  enabling AH support itself, this option enables the generic
  	  implementations of the algorithms that RFC 8221 lists as MUST be
  	  implemented.  If you need any other algorithms, you'll need to enable
  	  them in the crypto API.  You should also enable accelerated
  	  implementations of any needed algorithms when available.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
332
333
334
335
336
  
  	  If unsure, say Y.
  
  config INET_ESP
  	tristate "IP: ESP transformation"
7d4e39195   Eric Biggers   esp, ah: consolid...
337
  	select XFRM_ESP
a7f7f6248   Masahiro Yamada   treewide: replace...
338
  	help
be0136985   Eric Biggers   esp, ah: moderniz...
339
340
341
342
343
344
345
346
  	  Support for IPsec ESP (Encapsulating Security Payload).
  
  	  ESP can be used with various encryption and authentication algorithms.
  	  Besides enabling ESP support itself, this option enables the generic
  	  implementations of the algorithms that RFC 8221 lists as MUST be
  	  implemented.  If you need any other algorithms, you'll need to enable
  	  them in the crypto API.  You should also enable accelerated
  	  implementations of any needed algorithms when available.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
347
348
  
  	  If unsure, say Y.
7785bba29   Steffen Klassert   esp: Add a softwa...
349
350
351
352
353
  config INET_ESP_OFFLOAD
  	tristate "IP: ESP transformation offload"
  	depends on INET_ESP
  	select XFRM_OFFLOAD
  	default n
a7f7f6248   Masahiro Yamada   treewide: replace...
354
  	help
7785bba29   Steffen Klassert   esp: Add a softwa...
355
356
357
358
359
360
  	  Support for ESP transformation offload. This makes sense
  	  only if this system really does IPsec and want to do it
  	  with high throughput. A typical desktop system does not
  	  need it, even if it does IPsec.
  
  	  If unsure, say N.
e27cca96c   Sabrina Dubroca   xfrm: add espintc...
361
362
363
364
365
  config INET_ESPINTCP
  	bool "IP: ESP in TCP encapsulation (RFC 8229)"
  	depends on XFRM && INET_ESP
  	select STREAM_PARSER
  	select NET_SOCK_MSG
26333c37f   Sabrina Dubroca   xfrm: add IPv6 su...
366
  	select XFRM_ESPINTCP
e27cca96c   Sabrina Dubroca   xfrm: add espintc...
367
368
369
370
371
  	help
  	  Support for RFC 8229 encapsulation of ESP and IKE over
  	  TCP/IPv4 sockets.
  
  	  If unsure, say N.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
372
373
  config INET_IPCOMP
  	tristate "IP: IPComp transformation"
d2acc3479   Herbert Xu   [INET]: Introduce...
374
  	select INET_XFRM_TUNNEL
6fccab671   Herbert Xu   ipsec: ipcomp - M...
375
  	select XFRM_IPCOMP
a7f7f6248   Masahiro Yamada   treewide: replace...
376
  	help
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
377
378
  	  Support for IP Payload Compression Protocol (IPComp) (RFC3173),
  	  typically needed for IPsec.
a6e8f27f3   Jesper Dangaard Brouer   ipv4: Clean white...
379

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
380
  	  If unsure, say Y.
d2acc3479   Herbert Xu   [INET]: Introduce...
381
382
383
384
  config INET_XFRM_TUNNEL
  	tristate
  	select INET_TUNNEL
  	default n
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
385
  config INET_TUNNEL
d2acc3479   Herbert Xu   [INET]: Introduce...
386
387
  	tristate
  	default n
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
388

17b085eac   Arnaldo Carvalho de Melo   [INET_DIAG]: Move...
389
390
  config INET_DIAG
  	tristate "INET: socket monitoring interface"
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
391
  	default y
a7f7f6248   Masahiro Yamada   treewide: replace...
392
  	help
73c1f4a03   Arnaldo Carvalho de Melo   [TCPDIAG]: Just r...
393
394
  	  Support for INET (TCP, DCCP, etc) socket monitoring interface used by
  	  native Linux tools such as ss. ss is included in iproute2, currently
c996d8b9a   Michael Witten   Docs/Kconfig: Upd...
395
  	  downloadable at:
e446a2760   Stephen Hemminger   net: remove blank...
396

c996d8b9a   Michael Witten   Docs/Kconfig: Upd...
397
  	    http://www.linuxfoundation.org/collaborate/workgroups/networking/iproute2
a6e8f27f3   Jesper Dangaard Brouer   ipv4: Clean white...
398

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
399
  	  If unsure, say Y.
17b085eac   Arnaldo Carvalho de Melo   [INET_DIAG]: Move...
400
401
402
  config INET_TCP_DIAG
  	depends on INET_DIAG
  	def_tristate INET_DIAG
507dd7961   Pavel Emelyanov   udp_diag: Wire th...
403
  config INET_UDP_DIAG
6d62a66e4   David S. Miller   net: Default UDP ...
404
  	tristate "UDP: socket monitoring interface"
6d25886ee   Anisse Astier   net: Fix build re...
405
  	depends on INET_DIAG && (IPV6 || IPV6=n)
6d62a66e4   David S. Miller   net: Default UDP ...
406
  	default n
a7f7f6248   Masahiro Yamada   treewide: replace...
407
  	help
6d62a66e4   David S. Miller   net: Default UDP ...
408
409
  	  Support for UDP socket monitoring interface used by the ss tool.
  	  If unsure, say Y.
507dd7961   Pavel Emelyanov   udp_diag: Wire th...
410

432490f9d   Cyrill Gorcunov   net: ip, diag -- ...
411
412
413
414
  config INET_RAW_DIAG
  	tristate "RAW: socket monitoring interface"
  	depends on INET_DIAG && (IPV6 || IPV6=n)
  	default n
a7f7f6248   Masahiro Yamada   treewide: replace...
415
  	help
432490f9d   Cyrill Gorcunov   net: ip, diag -- ...
416
417
  	  Support for RAW socket monitoring interface used by the ss tool.
  	  If unsure, say Y.
c1e64e298   Lorenzo Colitti   net: diag: Suppor...
418
419
420
421
  config INET_DIAG_DESTROY
  	bool "INET: allow privileged process to administratively close sockets"
  	depends on INET_DIAG
  	default n
a7f7f6248   Masahiro Yamada   treewide: replace...
422
  	help
c1e64e298   Lorenzo Colitti   net: diag: Suppor...
423
424
425
426
427
428
429
  	  Provides a SOCK_DESTROY operation that allows privileged processes
  	  (e.g., a connection manager or a network administration tool such as
  	  ss) to close sockets opened by other processes. Closing a socket in
  	  this way interrupts any blocking read/write/connect operations on
  	  the socket and causes future socket calls to behave as if the socket
  	  had been disconnected.
  	  If unsure, say N.
3d2573f7e   Stephen Hemminger   [TCP]: default co...
430
  menuconfig TCP_CONG_ADVANCED
a6484045f   David S. Miller   [TCP]: Do not pre...
431
  	bool "TCP: advanced congestion control"
a7f7f6248   Masahiro Yamada   treewide: replace...
432
  	help
a6484045f   David S. Miller   [TCP]: Do not pre...
433
434
435
436
  	  Support for selection of various TCP congestion control
  	  modules.
  
  	  Nearly all users can safely say no here, and a safe default
597811ec1   Stephen Hemminger   [TCP]: make cubic...
437
  	  selection will be made (CUBIC with new Reno as a fallback).
a6484045f   David S. Miller   [TCP]: Do not pre...
438
439
  
  	  If unsure, say N.
3d2573f7e   Stephen Hemminger   [TCP]: default co...
440
  if TCP_CONG_ADVANCED
83803034f   Stephen Hemminger   [TCP]: Add TCP BI...
441
442
443
  
  config TCP_CONG_BIC
  	tristate "Binary Increase Congestion (BIC) control"
597811ec1   Stephen Hemminger   [TCP]: make cubic...
444
  	default m
a7f7f6248   Masahiro Yamada   treewide: replace...
445
  	help
43da14110   Krzysztof Kozlowski   net: Fix Kconfig ...
446
447
448
449
450
451
452
453
454
  	  BIC-TCP is a sender-side only change that ensures a linear RTT
  	  fairness under large windows while offering both scalability and
  	  bounded TCP-friendliness. The protocol combines two schemes
  	  called additive increase and binary search increase. When the
  	  congestion window is large, additive increase with a large
  	  increment ensures linear RTT fairness as well as good
  	  scalability. Under small congestion windows, binary search
  	  increase provides TCP friendliness.
  	  See http://www.csc.ncsu.edu/faculty/rhee/export/bitcp/
83803034f   Stephen Hemminger   [TCP]: Add TCP BI...
455

df3271f33   Stephen Hemminger   [TCP] BIC: CUBIC ...
456
457
  config TCP_CONG_CUBIC
  	tristate "CUBIC TCP"
597811ec1   Stephen Hemminger   [TCP]: make cubic...
458
  	default y
a7f7f6248   Masahiro Yamada   treewide: replace...
459
  	help
43da14110   Krzysztof Kozlowski   net: Fix Kconfig ...
460
461
462
  	  This is version 2.0 of BIC-TCP which uses a cubic growth function
  	  among other techniques.
  	  See http://www.csc.ncsu.edu/faculty/rhee/export/bitcp/cubic-paper.pdf
df3271f33   Stephen Hemminger   [TCP] BIC: CUBIC ...
463

872707628   Stephen Hemminger   [TCP]: Add TCP We...
464
465
  config TCP_CONG_WESTWOOD
  	tristate "TCP Westwood+"
872707628   Stephen Hemminger   [TCP]: Add TCP We...
466
  	default m
a7f7f6248   Masahiro Yamada   treewide: replace...
467
  	help
43da14110   Krzysztof Kozlowski   net: Fix Kconfig ...
468
469
470
471
472
473
474
475
476
  	  TCP Westwood+ is a sender-side only modification of the TCP Reno
  	  protocol stack that optimizes the performance of TCP congestion
  	  control. It is based on end-to-end bandwidth estimation to set
  	  congestion window and slow start threshold after a congestion
  	  episode. Using this estimation, TCP Westwood+ adaptively sets a
  	  slow start threshold and a congestion window which takes into
  	  account the bandwidth used  at the time congestion is experienced.
  	  TCP Westwood+ significantly increases fairness wrt TCP Reno in
  	  wired networks and throughput over wireless links.
872707628   Stephen Hemminger   [TCP]: Add TCP We...
477

a7868ea68   Baruch Even   [TCP]: Add H-TCP ...
478
  config TCP_CONG_HTCP
bf69abad2   Krzysztof Kozlowski   net: Fix Kconfig ...
479
480
  	tristate "H-TCP"
  	default m
a7f7f6248   Masahiro Yamada   treewide: replace...
481
  	help
43da14110   Krzysztof Kozlowski   net: Fix Kconfig ...
482
483
484
485
486
487
  	  H-TCP is a send-side only modifications of the TCP Reno
  	  protocol stack that optimizes the performance of TCP
  	  congestion control for high speed network links. It uses a
  	  modeswitch to change the alpha and beta parameters of TCP Reno
  	  based on network conditions and in a way so as to be fair with
  	  other Reno and H-TCP flows.
a7868ea68   Baruch Even   [TCP]: Add H-TCP ...
488

a628d29b5   John Heffner   [TCP]: Add High S...
489
490
  config TCP_CONG_HSTCP
  	tristate "High Speed TCP"
a628d29b5   John Heffner   [TCP]: Add High S...
491
  	default n
a7f7f6248   Masahiro Yamada   treewide: replace...
492
  	help
43da14110   Krzysztof Kozlowski   net: Fix Kconfig ...
493
494
495
496
  	  Sally Floyd's High Speed TCP (RFC 3649) congestion control.
  	  A modification to TCP's congestion control mechanism for use
  	  with large congestion windows. A table indicates how much to
  	  increase the congestion window by when an ACK is received.
7a6498ebc   Alexander A. Klimov   Replace HTTP link...
497
  	  For more detail see https://www.icir.org/floyd/hstcp.html
a628d29b5   John Heffner   [TCP]: Add High S...
498

835b3f0c0   Daniele Lacamera   [TCP]: Add TCP Hy...
499
500
  config TCP_CONG_HYBLA
  	tristate "TCP-Hybla congestion control algorithm"
835b3f0c0   Daniele Lacamera   [TCP]: Add TCP Hy...
501
  	default n
a7f7f6248   Masahiro Yamada   treewide: replace...
502
  	help
43da14110   Krzysztof Kozlowski   net: Fix Kconfig ...
503
504
505
506
  	  TCP-Hybla is a sender-side only change that eliminates penalization of
  	  long-RTT, large-bandwidth connections, like when satellite legs are
  	  involved, especially when sharing a common bottleneck with normal
  	  terrestrial connections.
835b3f0c0   Daniele Lacamera   [TCP]: Add TCP Hy...
507

b87d8561d   Stephen Hemminger   [TCP]: Add TCP Ve...
508
509
  config TCP_CONG_VEGAS
  	tristate "TCP Vegas"
b87d8561d   Stephen Hemminger   [TCP]: Add TCP Ve...
510
  	default n
a7f7f6248   Masahiro Yamada   treewide: replace...
511
  	help
43da14110   Krzysztof Kozlowski   net: Fix Kconfig ...
512
513
514
515
516
  	  TCP Vegas is a sender-side only change to TCP that anticipates
  	  the onset of congestion by estimating the bandwidth. TCP Vegas
  	  adjusts the sending rate by modifying the congestion
  	  window. TCP Vegas should provide less packet loss, but it is
  	  not as aggressive as TCP Reno.
b87d8561d   Stephen Hemminger   [TCP]: Add TCP Ve...
517

699fafafa   Lawrence Brakmo   tcp: add NV conge...
518
  config TCP_CONG_NV
43da14110   Krzysztof Kozlowski   net: Fix Kconfig ...
519
520
  	tristate "TCP NV"
  	default n
a7f7f6248   Masahiro Yamada   treewide: replace...
521
  	help
43da14110   Krzysztof Kozlowski   net: Fix Kconfig ...
522
523
524
525
  	  TCP NV is a follow up to TCP Vegas. It has been modified to deal with
  	  10G networks, measurement noise introduced by LRO, GRO and interrupt
  	  coalescence. In addition, it will decrease its cwnd multiplicatively
  	  instead of linearly.
699fafafa   Lawrence Brakmo   tcp: add NV conge...
526

43da14110   Krzysztof Kozlowski   net: Fix Kconfig ...
527
528
529
530
  	  Note that in general congestion avoidance (cwnd decreased when # packets
  	  queued grows) cannot coexist with congestion control (cwnd decreased only
  	  when there is packet loss) due to fairness issues. One scenario when they
  	  can coexist safely is when the CA flows have RTTs << CC flows RTTs.
699fafafa   Lawrence Brakmo   tcp: add NV conge...
531

43da14110   Krzysztof Kozlowski   net: Fix Kconfig ...
532
  	  For further details see http://www.brakmo.org/networking/tcp-nv/
699fafafa   Lawrence Brakmo   tcp: add NV conge...
533

0e57976b6   John Heffner   [TCP]: Add Scalab...
534
535
  config TCP_CONG_SCALABLE
  	tristate "Scalable TCP"
0e57976b6   John Heffner   [TCP]: Add Scalab...
536
  	default n
a7f7f6248   Masahiro Yamada   treewide: replace...
537
  	help
43da14110   Krzysztof Kozlowski   net: Fix Kconfig ...
538
539
540
541
  	  Scalable TCP is a sender-side only change to TCP which uses a
  	  MIMD congestion control algorithm which has some nice scaling
  	  properties, though is known to have fairness issues.
  	  See http://www.deneholme.net/tom/scalable/
a7868ea68   Baruch Even   [TCP]: Add H-TCP ...
542

7c106d7e7   Wong Hoi Sing Edison   [TCP]: TCP Low Pr...
543
544
  config TCP_CONG_LP
  	tristate "TCP Low Priority"
7c106d7e7   Wong Hoi Sing Edison   [TCP]: TCP Low Pr...
545
  	default n
a7f7f6248   Masahiro Yamada   treewide: replace...
546
  	help
43da14110   Krzysztof Kozlowski   net: Fix Kconfig ...
547
548
549
550
  	  TCP Low Priority (TCP-LP), a distributed algorithm whose goal is
  	  to utilize only the excess network bandwidth as compared to the
  	  ``fair share`` of bandwidth as targeted by TCP.
  	  See http://www-ece.rice.edu/networks/TCP-LP/
7c106d7e7   Wong Hoi Sing Edison   [TCP]: TCP Low Pr...
551

76f101775   Bin Zhou   [TCP]: TCP Veno c...
552
553
  config TCP_CONG_VENO
  	tristate "TCP Veno"
76f101775   Bin Zhou   [TCP]: TCP Veno c...
554
  	default n
a7f7f6248   Masahiro Yamada   treewide: replace...
555
  	help
43da14110   Krzysztof Kozlowski   net: Fix Kconfig ...
556
557
558
559
560
561
  	  TCP Veno is a sender-side only enhancement of TCP to obtain better
  	  throughput over wireless networks. TCP Veno makes use of state
  	  distinguishing to circumvent the difficult judgment of the packet loss
  	  type. TCP Veno cuts down less congestion window in response to random
  	  loss packets.
  	  See <http://ieeexplore.ieee.org/xpl/freeabs_all.jsp?arnumber=1177186>
76f101775   Bin Zhou   [TCP]: TCP Veno c...
562

5ef814753   Angelo P. Castellani   [TCP] YeAH-TCP: a...
563
564
  config TCP_CONG_YEAH
  	tristate "YeAH TCP"
2ff011efa   David S. Miller   [TCP]: TCP_CONG_Y...
565
  	select TCP_CONG_VEGAS
5ef814753   Angelo P. Castellani   [TCP] YeAH-TCP: a...
566
  	default n
a7f7f6248   Masahiro Yamada   treewide: replace...
567
  	help
43da14110   Krzysztof Kozlowski   net: Fix Kconfig ...
568
569
570
571
572
  	  YeAH-TCP is a sender-side high-speed enabled TCP congestion control
  	  algorithm, which uses a mixed loss/delay approach to compute the
  	  congestion window. It's design goals target high efficiency,
  	  internal, RTT and Reno fairness, resilience to link loss while
  	  keeping network elements load as low as possible.
5ef814753   Angelo P. Castellani   [TCP] YeAH-TCP: a...
573

43da14110   Krzysztof Kozlowski   net: Fix Kconfig ...
574
575
  	  For further details look here:
  	    http://wil.cs.caltech.edu/pfldnet2007/paper/YeAH_TCP.pdf
5ef814753   Angelo P. Castellani   [TCP] YeAH-TCP: a...
576

c462238d6   Stephen Hemminger   [TCP]: TCP Illino...
577
578
  config TCP_CONG_ILLINOIS
  	tristate "TCP Illinois"
c462238d6   Stephen Hemminger   [TCP]: TCP Illino...
579
  	default n
a7f7f6248   Masahiro Yamada   treewide: replace...
580
  	help
43da14110   Krzysztof Kozlowski   net: Fix Kconfig ...
581
582
583
584
  	  TCP-Illinois is a sender-side modification of TCP Reno for
  	  high speed long delay links. It uses round-trip-time to
  	  adjust the alpha and beta parameters to achieve a higher average
  	  throughput and maintain fairness.
c462238d6   Stephen Hemminger   [TCP]: TCP Illino...
585

43da14110   Krzysztof Kozlowski   net: Fix Kconfig ...
586
587
  	  For further details see:
  	    http://www.ews.uiuc.edu/~shaoliu/tcpillinois/index.html
c462238d6   Stephen Hemminger   [TCP]: TCP Illino...
588

e3118e835   Daniel Borkmann   net: tcp: add DCT...
589
590
591
  config TCP_CONG_DCTCP
  	tristate "DataCenter TCP (DCTCP)"
  	default n
a7f7f6248   Masahiro Yamada   treewide: replace...
592
  	help
43da14110   Krzysztof Kozlowski   net: Fix Kconfig ...
593
594
  	  DCTCP leverages Explicit Congestion Notification (ECN) in the network to
  	  provide multi-bit feedback to the end hosts. It is designed to provide:
e3118e835   Daniel Borkmann   net: tcp: add DCT...
595

43da14110   Krzysztof Kozlowski   net: Fix Kconfig ...
596
597
598
599
  	  - High burst tolerance (incast due to partition/aggregate),
  	  - Low latency (short flows, queries),
  	  - High throughput (continuous data updates, large file transfers) with
  	    commodity, shallow-buffered switches.
e3118e835   Daniel Borkmann   net: tcp: add DCT...
600

43da14110   Krzysztof Kozlowski   net: Fix Kconfig ...
601
602
603
604
605
  	  All switches in the data center network running DCTCP must support
  	  ECN marking and be configured for marking when reaching defined switch
  	  buffer thresholds. The default ECN marking threshold heuristic for
  	  DCTCP on switches is 20 packets (30KB) at 1Gbps, and 65 packets
  	  (~100KB) at 10Gbps, but might need further careful tweaking.
e3118e835   Daniel Borkmann   net: tcp: add DCT...
606

43da14110   Krzysztof Kozlowski   net: Fix Kconfig ...
607
608
  	  For further details see:
  	    http://simula.stanford.edu/~alizade/Site/DCTCP_files/dctcp-final.pdf
e3118e835   Daniel Borkmann   net: tcp: add DCT...
609

2b0a8c9ee   Kenneth Klette Jonassen   tcp: add CDG cong...
610
611
612
  config TCP_CONG_CDG
  	tristate "CAIA Delay-Gradient (CDG)"
  	default n
a7f7f6248   Masahiro Yamada   treewide: replace...
613
  	help
43da14110   Krzysztof Kozlowski   net: Fix Kconfig ...
614
615
  	  CAIA Delay-Gradient (CDG) is a TCP congestion control that modifies
  	  the TCP sender in order to:
2b0a8c9ee   Kenneth Klette Jonassen   tcp: add CDG cong...
616
617
618
619
620
  
  	  o Use the delay gradient as a congestion signal.
  	  o Back off with an average probability that is independent of the RTT.
  	  o Coexist with flows that use loss-based congestion control.
  	  o Tolerate packet loss unrelated to congestion.
43da14110   Krzysztof Kozlowski   net: Fix Kconfig ...
621
622
623
  	  For further details see:
  	    D.A. Hayes and G. Armitage. "Revisiting TCP congestion control using
  	    delay gradients." In Networking 2011. Preprint: http://goo.gl/No3vdg
2b0a8c9ee   Kenneth Klette Jonassen   tcp: add CDG cong...
624

0f8782ea1   Neal Cardwell   tcp_bbr: add BBR ...
625
626
627
  config TCP_CONG_BBR
  	tristate "BBR TCP"
  	default n
a7f7f6248   Masahiro Yamada   treewide: replace...
628
  	help
0f8782ea1   Neal Cardwell   tcp_bbr: add BBR ...
629

43da14110   Krzysztof Kozlowski   net: Fix Kconfig ...
630
631
  	  BBR (Bottleneck Bandwidth and RTT) TCP congestion control aims to
  	  maximize network utilization and minimize queues. It builds an explicit
ad6641189   Colin Ian King   net: ipv4: remove...
632
633
634
635
636
637
638
  	  model of the bottleneck delivery rate and path round-trip propagation
  	  delay. It tolerates packet loss and delay unrelated to congestion. It
  	  can operate over LAN, WAN, cellular, wifi, or cable modem links. It can
  	  coexist with flows that use loss-based congestion control, and can
  	  operate with shallow buffers, deep buffers, bufferbloat, policers, or
  	  AQM schemes that do not provide a delay signal. It requires the fq
  	  ("Fair Queue") pacing packet scheduler.
0f8782ea1   Neal Cardwell   tcp_bbr: add BBR ...
639

3d2573f7e   Stephen Hemminger   [TCP]: default co...
640
641
  choice
  	prompt "Default TCP congestion control"
597811ec1   Stephen Hemminger   [TCP]: make cubic...
642
  	default DEFAULT_CUBIC
3d2573f7e   Stephen Hemminger   [TCP]: default co...
643
644
645
646
647
648
649
650
651
652
653
654
  	help
  	  Select the TCP congestion control that will be used by default
  	  for all connections.
  
  	config DEFAULT_BIC
  		bool "Bic" if TCP_CONG_BIC=y
  
  	config DEFAULT_CUBIC
  		bool "Cubic" if TCP_CONG_CUBIC=y
  
  	config DEFAULT_HTCP
  		bool "Htcp" if TCP_CONG_HTCP=y
dd2acaa7b   Jan Engelhardt   net: tcp: make hy...
655
656
  	config DEFAULT_HYBLA
  		bool "Hybla" if TCP_CONG_HYBLA=y
3d2573f7e   Stephen Hemminger   [TCP]: default co...
657
658
  	config DEFAULT_VEGAS
  		bool "Vegas" if TCP_CONG_VEGAS=y
6ce1a6df6   Jan Engelhardt   net: tcp: make ve...
659
660
  	config DEFAULT_VENO
  		bool "Veno" if TCP_CONG_VENO=y
3d2573f7e   Stephen Hemminger   [TCP]: default co...
661
662
  	config DEFAULT_WESTWOOD
  		bool "Westwood" if TCP_CONG_WESTWOOD=y
e3118e835   Daniel Borkmann   net: tcp: add DCT...
663
664
  	config DEFAULT_DCTCP
  		bool "DCTCP" if TCP_CONG_DCTCP=y
2b0a8c9ee   Kenneth Klette Jonassen   tcp: add CDG cong...
665
666
  	config DEFAULT_CDG
  		bool "CDG" if TCP_CONG_CDG=y
0f8782ea1   Neal Cardwell   tcp_bbr: add BBR ...
667
668
  	config DEFAULT_BBR
  		bool "BBR" if TCP_CONG_BBR=y
3d2573f7e   Stephen Hemminger   [TCP]: default co...
669
670
  	config DEFAULT_RENO
  		bool "Reno"
3d2573f7e   Stephen Hemminger   [TCP]: default co...
671
672
673
  endchoice
  
  endif
83803034f   Stephen Hemminger   [TCP]: Add TCP BI...
674

597811ec1   Stephen Hemminger   [TCP]: make cubic...
675
  config TCP_CONG_CUBIC
6c3607676   David S. Miller   [IPV4]: Fix think...
676
  	tristate
a6484045f   David S. Miller   [TCP]: Do not pre...
677
678
  	depends on !TCP_CONG_ADVANCED
  	default y
3d2573f7e   Stephen Hemminger   [TCP]: default co...
679
680
681
682
683
  config DEFAULT_TCP_CONG
  	string
  	default "bic" if DEFAULT_BIC
  	default "cubic" if DEFAULT_CUBIC
  	default "htcp" if DEFAULT_HTCP
dd2acaa7b   Jan Engelhardt   net: tcp: make hy...
684
  	default "hybla" if DEFAULT_HYBLA
3d2573f7e   Stephen Hemminger   [TCP]: default co...
685
686
  	default "vegas" if DEFAULT_VEGAS
  	default "westwood" if DEFAULT_WESTWOOD
6ce1a6df6   Jan Engelhardt   net: tcp: make ve...
687
  	default "veno" if DEFAULT_VENO
3d2573f7e   Stephen Hemminger   [TCP]: default co...
688
  	default "reno" if DEFAULT_RENO
e3118e835   Daniel Borkmann   net: tcp: add DCT...
689
  	default "dctcp" if DEFAULT_DCTCP
2b0a8c9ee   Kenneth Klette Jonassen   tcp: add CDG cong...
690
  	default "cdg" if DEFAULT_CDG
4df21dfcf   Julian Wollrath   tcp: Set DEFAULT_...
691
  	default "bbr" if DEFAULT_BBR
597811ec1   Stephen Hemminger   [TCP]: make cubic...
692
  	default "cubic"
3d2573f7e   Stephen Hemminger   [TCP]: default co...
693

cfb6eeb4c   YOSHIFUJI Hideaki   [TCP]: MD5 Signat...
694
  config TCP_MD5SIG
44fbe9200   Kees Cook   net/ipv4: remove ...
695
  	bool "TCP: MD5 Signature Option support (RFC2385)"
cfb6eeb4c   YOSHIFUJI Hideaki   [TCP]: MD5 Signat...
696
697
  	select CRYPTO
  	select CRYPTO_MD5
a7f7f6248   Masahiro Yamada   treewide: replace...
698
  	help
3dde6ad8f   David Sterba   Fix trivial typos...
699
  	  RFC2385 specifies a method of giving MD5 protection to TCP sessions.
cfb6eeb4c   YOSHIFUJI Hideaki   [TCP]: MD5 Signat...
700
701
702
703
  	  Its main (only?) use is to protect BGP sessions between core routers
  	  on the Internet.
  
  	  If unsure, say N.