blob: cd915e332c985c1ae139bfca9470c0d0c26b8655 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#
2# IPv6 configuration
Sam Ravnborg6a2e9b72005-07-11 21:13:56 -07003#
4
5# IPv6 as module will cause a CRASH if you try to unload it
Jan Engelhardt0b185422008-04-13 23:30:47 -07006menuconfig IPV6
Sam Ravnborg6a2e9b72005-07-11 21:13:56 -07007 tristate "The IPv6 protocol"
Tom Herbertde551f22015-07-13 08:48:00 -07008 default y
Sam Ravnborg6a2e9b72005-07-11 21:13:56 -07009 ---help---
Tom Herbertde551f22015-07-13 08:48:00 -070010 Support for IP version 6 (IPv6).
Sam Ravnborg6a2e9b72005-07-11 21:13:56 -070011
12 For general information about IPv6, see
Christian Kujau242260f2013-02-21 16:43:05 -080013 <https://en.wikipedia.org/wiki/IPv6>.
Tom Herbertde551f22015-07-13 08:48:00 -070014 For specific information about IPv6 under Linux, see
15 Documentation/networking/ipv6.txt and read the HOWTO at
16 <http://www.tldp.org/HOWTO/Linux+IPv6-HOWTO/>
Sam Ravnborg6a2e9b72005-07-11 21:13:56 -070017
Stephen Hemmingere446a272018-07-24 12:29:18 -070018 To compile this protocol support as a module, choose M here: the
Sam Ravnborg6a2e9b72005-07-11 21:13:56 -070019 module will be called ipv6.
20
Jan Engelhardt0b185422008-04-13 23:30:47 -070021if IPV6
22
YOSHIFUJI Hideakiebacaaa2006-03-20 17:04:53 -080023config IPV6_ROUTER_PREF
24 bool "IPv6: Router Preference (RFC 4191) support"
YOSHIFUJI Hideakiebacaaa2006-03-20 17:04:53 -080025 ---help---
26 Router Preference is an optional extension to the Router
Matt LaPlante692105b2009-01-26 11:12:25 +010027 Advertisement message which improves the ability of hosts
28 to pick an appropriate router, especially when the hosts
29 are placed in a multi-homed network.
YOSHIFUJI Hideakiebacaaa2006-03-20 17:04:53 -080030
31 If unsure, say N.
32
YOSHIFUJI Hideaki70ceb4f2006-03-20 17:06:24 -080033config IPV6_ROUTE_INFO
Kees Cookf9ceb162012-10-02 11:19:49 -070034 bool "IPv6: Route Information (RFC 4191) support"
35 depends on IPV6_ROUTER_PREF
YOSHIFUJI Hideaki70ceb4f2006-03-20 17:06:24 -080036 ---help---
Georg Hofmanna9f71d02018-05-07 14:03:18 +020037 Support of Route Information.
YOSHIFUJI Hideaki70ceb4f2006-03-20 17:06:24 -080038
39 If unsure, say N.
40
Neil Horman95c385b2007-04-25 17:08:10 -070041config IPV6_OPTIMISTIC_DAD
Kees Cookf9ceb162012-10-02 11:19:49 -070042 bool "IPv6: Enable RFC 4429 Optimistic DAD"
Neil Horman95c385b2007-04-25 17:08:10 -070043 ---help---
Georg Hofmanna9f71d02018-05-07 14:03:18 +020044 Support for optimistic Duplicate Address Detection. It allows for
45 autoconfigured addresses to be used more quickly.
Neil Horman95c385b2007-04-25 17:08:10 -070046
47 If unsure, say N.
48
Linus Torvalds1da177e2005-04-16 15:20:36 -070049config INET6_AH
50 tristate "IPv6: AH transformation"
Jan Beulich7e152522012-05-15 01:57:44 +000051 select XFRM_ALGO
Linus Torvalds1da177e2005-04-16 15:20:36 -070052 select CRYPTO
53 select CRYPTO_HMAC
54 select CRYPTO_MD5
55 select CRYPTO_SHA1
56 ---help---
57 Support for IPsec AH.
58
59 If unsure, say Y.
60
61config INET6_ESP
62 tristate "IPv6: ESP transformation"
Jan Beulich7e152522012-05-15 01:57:44 +000063 select XFRM_ALGO
Linus Torvalds1da177e2005-04-16 15:20:36 -070064 select CRYPTO
Herbert Xued58dd42008-03-04 14:29:21 -080065 select CRYPTO_AUTHENC
Linus Torvalds1da177e2005-04-16 15:20:36 -070066 select CRYPTO_HMAC
67 select CRYPTO_MD5
Herbert Xu6b7326c2006-07-30 15:41:01 +100068 select CRYPTO_CBC
Linus Torvalds1da177e2005-04-16 15:20:36 -070069 select CRYPTO_SHA1
70 select CRYPTO_DES
Thomas Egerer32b6170c2016-01-25 12:58:44 +010071 select CRYPTO_ECHAINIV
Linus Torvalds1da177e2005-04-16 15:20:36 -070072 ---help---
73 Support for IPsec ESP.
74
75 If unsure, say Y.
76
Steffen Klassert7785bba2017-02-15 09:40:00 +010077config INET6_ESP_OFFLOAD
78 tristate "IPv6: ESP transformation offload"
79 depends on INET6_ESP
80 select XFRM_OFFLOAD
81 default n
82 ---help---
83 Support for ESP transformation offload. This makes sense
84 only if this system really does IPsec and want to do it
85 with high throughput. A typical desktop system does not
86 need it, even if it does IPsec.
87
88 If unsure, say N.
89
Linus Torvalds1da177e2005-04-16 15:20:36 -070090config INET6_IPCOMP
91 tristate "IPv6: IPComp transformation"
Herbert Xud2acc342006-03-28 01:12:13 -080092 select INET6_XFRM_TUNNEL
Herbert Xu6fccab62008-07-25 02:54:40 -070093 select XFRM_IPCOMP
Linus Torvalds1da177e2005-04-16 15:20:36 -070094 ---help---
95 Support for IP Payload Compression Protocol (IPComp) (RFC3173),
96 typically needed for IPsec.
97
98 If unsure, say Y.
99
Masahide NAKAMURAee538262006-08-23 19:13:46 -0700100config IPV6_MIP6
Kees Cookf9ceb162012-10-02 11:19:49 -0700101 tristate "IPv6: Mobility"
Masahide NAKAMURAee538262006-08-23 19:13:46 -0700102 select XFRM
103 ---help---
104 Support for IPv6 Mobility described in RFC 3775.
105
106 If unsure, say N.
107
Tom Herbert65d7ab82015-08-17 13:42:27 -0700108config IPV6_ILA
109 tristate "IPv6: Identifier Locator Addressing (ILA)"
Arnd Bergmann8cb964d2015-12-18 15:37:37 +0100110 depends on NETFILTER
Arnd Bergmann83ed7d12018-07-18 10:48:56 +0200111 select DST_CACHE
Tom Herbert65d7ab82015-08-17 13:42:27 -0700112 select LWTUNNEL
113 ---help---
114 Support for IPv6 Identifier Locator Addressing (ILA).
115
116 ILA is a mechanism to do network virtualization without
117 encapsulation. The basic concept of ILA is that we split an
118 IPv6 address into a 64 bit locator and 64 bit identifier. The
119 identifier is the identity of an entity in communication
120 ("who") and the locator expresses the location of the
121 entity ("where").
122
123 ILA can be configured using the "encap ila" option with
124 "ip -6 route" command. ILA is described in
125 https://tools.ietf.org/html/draft-herbert-nvo3-ila-00.
126
127 If unsure, say N.
128
Herbert Xud2acc342006-03-28 01:12:13 -0800129config INET6_XFRM_TUNNEL
130 tristate
131 select INET6_TUNNEL
132 default n
133
Linus Torvalds1da177e2005-04-16 15:20:36 -0700134config INET6_TUNNEL
Herbert Xud2acc342006-03-28 01:12:13 -0800135 tristate
136 default n
Linus Torvalds1da177e2005-04-16 15:20:36 -0700137
Steffen Klasserted1efb22013-08-19 08:07:34 +0200138config IPV6_VTI
139tristate "Virtual (secure) IPv6: tunneling"
140 select IPV6_TUNNEL
Steffen Klassert876fc032014-02-19 13:33:23 +0100141 select NET_IP_TUNNEL
Florian Westphal4c145dc2019-03-29 21:16:31 +0100142 select XFRM
Steffen Klasserted1efb22013-08-19 08:07:34 +0200143 ---help---
144 Tunneling means encapsulating data of one protocol type within
145 another protocol and sending it over a channel that understands the
146 encapsulating protocol. This can be used with xfrm mode tunnel to give
147 the notion of a secure tunnel for IPSEC and then use routing protocol
148 on top.
149
Joerg Roedel989e5b92006-10-10 14:47:44 -0700150config IPV6_SIT
151 tristate "IPv6: IPv6-in-IPv4 tunnel (SIT driver)"
Kazunori MIYAZAWAc73cb5a2007-02-13 12:55:25 -0800152 select INET_TUNNEL
Pravin B Shelarf61dd382013-03-25 14:50:00 +0000153 select NET_IP_TUNNEL
YOSHIFUJI Hideakide357cc2008-03-15 23:59:18 -0400154 select IPV6_NDISC_NODETYPE
Joerg Roedel989e5b92006-10-10 14:47:44 -0700155 default y
156 ---help---
157 Tunneling means encapsulating data of one protocol type within
158 another protocol and sending it over a channel that understands the
159 encapsulating protocol. This driver implements encapsulation of IPv6
David S. Miller5c5d6da2008-04-26 22:50:57 -0700160 into IPv4 packets. This is useful if you want to connect two IPv6
Joerg Roedel989e5b92006-10-10 14:47:44 -0700161 networks over an IPv4-only path.
162
Pavel Machek4737f092009-06-05 00:44:53 +0200163 Saying M here will produce a module called sit. If unsure, say Y.
Joerg Roedel989e5b92006-10-10 14:47:44 -0700164
YOSHIFUJI Hideaki / 吉藤英明fa857af2009-09-22 23:43:14 +0000165config IPV6_SIT_6RD
Kees Cookf9ceb162012-10-02 11:19:49 -0700166 bool "IPv6: IPv6 Rapid Deployment (6RD)"
167 depends on IPV6_SIT
YOSHIFUJI Hideaki / 吉藤英明fa857af2009-09-22 23:43:14 +0000168 default n
169 ---help---
170 IPv6 Rapid Deployment (6rd; draft-ietf-softwire-ipv6-6rd) builds upon
171 mechanisms of 6to4 (RFC3056) to enable a service provider to rapidly
172 deploy IPv6 unicast service to IPv4 sites to which it provides
173 customer premise equipment. Like 6to4, it utilizes stateless IPv6 in
174 IPv4 encapsulation in order to transit IPv4-only network
175 infrastructure. Unlike 6to4, a 6rd service provider uses an IPv6
176 prefix of its own in place of the fixed 6to4 prefix.
177
178 With this option enabled, the SIT driver offers 6rd functionality by
179 providing additional ioctl API to configure the IPv6 Prefix for in
180 stead of static 2002::/16 for 6to4.
181
182 If unsure, say N.
183
YOSHIFUJI Hideakide357cc2008-03-15 23:59:18 -0400184config IPV6_NDISC_NODETYPE
185 bool
186
Linus Torvalds1da177e2005-04-16 15:20:36 -0700187config IPV6_TUNNEL
YOSHIFUJI Hideaki38fe9992008-03-20 16:13:58 -0700188 tristate "IPv6: IP-in-IPv6 tunnel (RFC2473)"
Herbert Xud2acc342006-03-28 01:12:13 -0800189 select INET6_TUNNEL
Paolo Abeni607f7252016-02-12 15:43:54 +0100190 select DST_CACHE
Eric Dumazet97e219b2017-02-07 15:37:15 -0800191 select GRO_CELLS
Linus Torvalds1da177e2005-04-16 15:20:36 -0700192 ---help---
YOSHIFUJI Hideaki38fe9992008-03-20 16:13:58 -0700193 Support for IPv6-in-IPv6 and IPv4-in-IPv6 tunnels described in
194 RFC 2473.
Linus Torvalds1da177e2005-04-16 15:20:36 -0700195
196 If unsure, say N.
197
xeb@mail.ruc12b3952012-08-10 00:51:50 +0000198config IPV6_GRE
199 tristate "IPv6: GRE tunnel"
200 select IPV6_TUNNEL
Pravin B Shelarf61dd382013-03-25 14:50:00 +0000201 select NET_IP_TUNNEL
Arnd Bergmann8bf42e92016-05-03 17:19:57 +0200202 depends on NET_IPGRE_DEMUX
xeb@mail.ruc12b3952012-08-10 00:51:50 +0000203 ---help---
204 Tunneling means encapsulating data of one protocol type within
205 another protocol and sending it over a channel that understands the
206 encapsulating protocol. This particular tunneling driver implements
207 GRE (Generic Routing Encapsulation) and at this time allows
208 encapsulating of IPv4 or IPv6 over existing IPv6 infrastructure.
209 This driver is useful if the other endpoint is a Cisco router: Cisco
210 likes GRE much better than the other Linux tunneling driver ("IP
211 tunneling" above). In addition, GRE allows multicast redistribution
212 through the tunnel.
213
214 Saying M here will produce a module called ip6_gre. If unsure, say N.
215
Arnd Bergmannfabb13d2016-05-25 16:50:46 +0200216config IPV6_FOU
217 tristate
218 default NET_FOU && IPV6
219
220config IPV6_FOU_TUNNEL
221 tristate
222 default NET_FOU_IP_TUNNELS && IPV6_FOU
Arnd Bergmann95e4daa2016-05-31 22:42:11 +0200223 select IPV6_TUNNEL
Arnd Bergmannfabb13d2016-05-25 16:50:46 +0200224
Ville Nuorvala264e91b2006-10-16 22:12:21 -0700225config IPV6_MULTIPLE_TABLES
226 bool "IPv6: Multiple Routing Tables"
Ville Nuorvala264e91b2006-10-16 22:12:21 -0700227 select FIB_RULES
228 ---help---
229 Support multiple routing tables.
230
YOSHIFUJI Hideaki4e96c2b2006-08-23 17:23:39 -0700231config IPV6_SUBTREES
232 bool "IPv6: source address based routing"
Ville Nuorvala264e91b2006-10-16 22:12:21 -0700233 depends on IPV6_MULTIPLE_TABLES
YOSHIFUJI Hideaki4e96c2b2006-08-23 17:23:39 -0700234 ---help---
235 Enable routing by source address or prefix.
236
237 The destination address is still the primary routing key, so mixing
238 normal and source prefix specific routes in the same routing table
239 may sometimes lead to unintended routing behavior. This can be
240 avoided by defining different routing tables for the normal and
241 source prefix specific routes.
242
243 If unsure, say N.
244
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +0900245config IPV6_MROUTE
Kees Cookf9ceb162012-10-02 11:19:49 -0700246 bool "IPv6: multicast routing"
247 depends on IPV6
Yuval Mintz6853f212018-02-28 23:29:29 +0200248 select IP_MROUTE_COMMON
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +0900249 ---help---
Georg Hofmanna9f71d02018-05-07 14:03:18 +0200250 Support for IPv6 multicast forwarding.
YOSHIFUJI Hideaki7bc570c2008-04-03 09:22:53 +0900251 If unsure, say N.
252
Patrick McHardyd1db2752010-05-11 14:40:55 +0200253config IPV6_MROUTE_MULTIPLE_TABLES
254 bool "IPv6: multicast policy routing"
255 depends on IPV6_MROUTE
256 select FIB_RULES
257 help
258 Normally, a multicast router runs a userspace daemon and decides
259 what to do with a multicast packet based on the source and
260 destination addresses. If you say Y here, the multicast router
261 will also be able to take interfaces and packet marks into
262 account and run multiple instances of userspace daemons
263 simultaneously, each one handling a single table.
264
265 If unsure, say N.
266
YOSHIFUJI Hideaki14fb64e2008-04-03 09:22:54 +0900267config IPV6_PIMSM_V2
Kees Cookf9ceb162012-10-02 11:19:49 -0700268 bool "IPv6: PIM-SM version 2 support"
YOSHIFUJI Hideaki14fb64e2008-04-03 09:22:54 +0900269 depends on IPV6_MROUTE
270 ---help---
271 Support for IPv6 PIM multicast routing protocol PIM-SMv2.
272 If unsure, say N.
273
David Lebrun46738b12016-11-15 16:14:04 +0100274config IPV6_SEG6_LWTUNNEL
275 bool "IPv6: Segment Routing Header encapsulation support"
276 depends on IPV6
277 select LWTUNNEL
David Lebrun402a5bc2017-03-27 11:43:59 +0200278 select DST_CACHE
David Lebrund7a669d2017-08-25 09:56:47 +0200279 select IPV6_MULTIPLE_TABLES
David Lebrun46738b12016-11-15 16:14:04 +0100280 ---help---
281 Support for encapsulation of packets within an outer IPv6
282 header and a Segment Routing Header using the lightweight
David Lebrund1df6fd2017-08-05 12:38:26 +0200283 tunnels mechanism. Also enable support for advanced local
284 processing of SRv6 packets based on their active segment.
David Lebrun46738b12016-11-15 16:14:04 +0100285
286 If unsure, say N.
287
David Lebrunbf355b82016-11-08 14:57:42 +0100288config IPV6_SEG6_HMAC
289 bool "IPv6: Segment Routing HMAC support"
290 depends on IPV6
291 select CRYPTO_HMAC
292 select CRYPTO_SHA1
293 select CRYPTO_SHA256
294 ---help---
295 Support for HMAC signature generation and verification
296 of SR-enabled packets.
297
298 If unsure, say N.
299
Mathieu Xhonneuxfe94cc22018-05-20 14:58:14 +0100300config IPV6_SEG6_BPF
301 def_bool y
302 depends on IPV6_SEG6_LWTUNNEL
303 depends on IPV6 = y
304
Jan Engelhardt0b185422008-04-13 23:30:47 -0700305endif # IPV6