xref: /linux/net/Kconfig (revision b251f9f63a3bea7864bf627960926d978e97814d)
11da177e4SLinus Torvalds#
21da177e4SLinus Torvalds# Network configuration
31da177e4SLinus Torvalds#
41da177e4SLinus Torvalds
5031cf19eSRobert P. J. Daymenuconfig NET
61da177e4SLinus Torvalds	bool "Networking support"
7e9cc8bddSGeert Uytterhoeven	select NLATTR
84cd5773aSAndy Shevchenko	select GENERIC_NET_UTILS
9f89b7755SAlexei Starovoitov	select BPF
101da177e4SLinus Torvalds	---help---
111da177e4SLinus Torvalds	  Unless you really know what you are doing, you should say Y here.
121da177e4SLinus Torvalds	  The reason is that some programs need kernel networking support even
131da177e4SLinus Torvalds	  when running on a stand-alone machine that isn't connected to any
14d5950b43SSam Ravnborg	  other computer.
15d5950b43SSam Ravnborg
16d5950b43SSam Ravnborg	  If you are upgrading from an older kernel, you
171da177e4SLinus Torvalds	  should consider updating your networking tools too because changes
181da177e4SLinus Torvalds	  in the kernel and the tools often go hand in hand. The tools are
191da177e4SLinus Torvalds	  contained in the package net-tools, the location and version number
201da177e4SLinus Torvalds	  of which are given in <file:Documentation/Changes>.
211da177e4SLinus Torvalds
221da177e4SLinus Torvalds	  For a general introduction to Linux networking, it is highly
231da177e4SLinus Torvalds	  recommended to read the NET-HOWTO, available from
241da177e4SLinus Torvalds	  <http://www.tldp.org/docs.html#howto>.
251da177e4SLinus Torvalds
266a2e9b73SSam Ravnborgif NET
276a2e9b73SSam Ravnborg
281dacc76dSJohannes Bergconfig WANT_COMPAT_NETLINK_MESSAGES
291dacc76dSJohannes Berg	bool
301dacc76dSJohannes Berg	help
311dacc76dSJohannes Berg	  This option can be selected by other options that need compat
321dacc76dSJohannes Berg	  netlink messages.
331dacc76dSJohannes Berg
341dacc76dSJohannes Bergconfig COMPAT_NETLINK_MESSAGES
351dacc76dSJohannes Berg	def_bool y
361dacc76dSJohannes Berg	depends on COMPAT
3740b53d8aSDavid S. Miller	depends on WEXT_CORE || WANT_COMPAT_NETLINK_MESSAGES
381dacc76dSJohannes Berg	help
391dacc76dSJohannes Berg	  This option makes it possible to send different netlink messages
401dacc76dSJohannes Berg	  to tasks depending on whether the task is a compat task or not. To
411dacc76dSJohannes Berg	  achieve this, you need to set skb_shinfo(skb)->frag_list to the
421dacc76dSJohannes Berg	  compat skb before sending the skb, the netlink code will sort out
431dacc76dSJohannes Berg	  which message to actually pass to the task.
441dacc76dSJohannes Berg
451dacc76dSJohannes Berg	  Newly written code should NEVER need this option but do
461dacc76dSJohannes Berg	  compat-independent messages instead!
471dacc76dSJohannes Berg
481cf51900SPablo Neiraconfig NET_INGRESS
491cf51900SPablo Neira	bool
501cf51900SPablo Neira
511f211a1bSDaniel Borkmannconfig NET_EGRESS
521f211a1bSDaniel Borkmann	bool
531f211a1bSDaniel Borkmann
54df5042f4SFlorian Westphalconfig SKB_EXTENSIONS
55df5042f4SFlorian Westphal	bool
56df5042f4SFlorian Westphal
571da177e4SLinus Torvaldsmenu "Networking options"
581da177e4SLinus Torvalds
596a2e9b73SSam Ravnborgsource "net/packet/Kconfig"
606a2e9b73SSam Ravnborgsource "net/unix/Kconfig"
613c4d7559SDave Watsonsource "net/tls/Kconfig"
626a2e9b73SSam Ravnborgsource "net/xfrm/Kconfig"
632356f4cbSMartin Schwidefskysource "net/iucv/Kconfig"
64ac713874SUrsula Braunsource "net/smc/Kconfig"
6568e8b849SBjörn Töpelsource "net/xdp/Kconfig"
661da177e4SLinus Torvalds
671da177e4SLinus Torvaldsconfig INET
681da177e4SLinus Torvalds	bool "TCP/IP networking"
69798b2cbfSDavid S. Miller	select CRYPTO
70798b2cbfSDavid S. Miller	select CRYPTO_AES
711da177e4SLinus Torvalds	---help---
721da177e4SLinus Torvalds	  These are the protocols used on the Internet and on most local
731da177e4SLinus Torvalds	  Ethernets. It is highly recommended to say Y here (this will enlarge
74cf80efc2SYOSHIFUJI Hideaki	  your kernel by about 400 KB), since some programs (e.g. the X window
751da177e4SLinus Torvalds	  system) use TCP/IP even if your machine is not connected to any
761da177e4SLinus Torvalds	  other computer. You will get the so-called loopback device which
771da177e4SLinus Torvalds	  allows you to ping yourself (great fun, that!).
781da177e4SLinus Torvalds
791da177e4SLinus Torvalds	  For an excellent introduction to Linux networking, please read the
801da177e4SLinus Torvalds	  Linux Networking HOWTO, available from
811da177e4SLinus Torvalds	  <http://www.tldp.org/docs.html#howto>.
821da177e4SLinus Torvalds
831da177e4SLinus Torvalds	  If you say Y here and also to "/proc file system support" and
841da177e4SLinus Torvalds	  "Sysctl support" below, you can change various aspects of the
851da177e4SLinus Torvalds	  behavior of the TCP/IP code by writing to the (virtual) files in
861da177e4SLinus Torvalds	  /proc/sys/net/ipv4/*; the options are explained in the file
871da177e4SLinus Torvalds	  <file:Documentation/networking/ip-sysctl.txt>.
881da177e4SLinus Torvalds
891da177e4SLinus Torvalds	  Short answer: say Y.
901da177e4SLinus Torvalds
916a2e9b73SSam Ravnborgif INET
921da177e4SLinus Torvaldssource "net/ipv4/Kconfig"
931da177e4SLinus Torvaldssource "net/ipv6/Kconfig"
9438c94377SPaul Mooresource "net/netlabel/Kconfig"
951da177e4SLinus Torvalds
966a2e9b73SSam Ravnborgendif # if INET
976a2e9b73SSam Ravnborg
98984bc16cSJames Morrisconfig NETWORK_SECMARK
99984bc16cSJames Morris	bool "Security Marking"
100984bc16cSJames Morris	help
101984bc16cSJames Morris	  This enables security marking of network packets, similar
102984bc16cSJames Morris	  to nfmark, but designated for security purposes.
103984bc16cSJames Morris	  If you are unsure how to answer this question, answer N.
104984bc16cSJames Morris
105408eccceSDaniel Borkmannconfig NET_PTP_CLASSIFY
106408eccceSDaniel Borkmann	def_bool n
107408eccceSDaniel Borkmann
108c1f19b51SRichard Cochranconfig NETWORK_PHY_TIMESTAMPING
109c1f19b51SRichard Cochran	bool "Timestamping in PHY devices"
110408eccceSDaniel Borkmann	select NET_PTP_CLASSIFY
111c1f19b51SRichard Cochran	help
112c1f19b51SRichard Cochran	  This allows timestamping of network packets by PHYs with
113c1f19b51SRichard Cochran	  hardware timestamping capabilities. This option adds some
114c1f19b51SRichard Cochran	  overhead in the transmit and receive paths.
115c1f19b51SRichard Cochran
116c1f19b51SRichard Cochran	  If you are unsure how to answer this question, answer N.
117c1f19b51SRichard Cochran
1181da177e4SLinus Torvaldsmenuconfig NETFILTER
119ef91fd52SPablo Neira Ayuso	bool "Network packet filtering framework (Netfilter)"
1201da177e4SLinus Torvalds	---help---
1211da177e4SLinus Torvalds	  Netfilter is a framework for filtering and mangling network packets
1221da177e4SLinus Torvalds	  that pass through your Linux box.
1231da177e4SLinus Torvalds
1241da177e4SLinus Torvalds	  The most common use of packet filtering is to run your Linux box as
1251da177e4SLinus Torvalds	  a firewall protecting a local network from the Internet. The type of
1261da177e4SLinus Torvalds	  firewall provided by this kernel support is called a "packet
1271da177e4SLinus Torvalds	  filter", which means that it can reject individual network packets
1281da177e4SLinus Torvalds	  based on type, source, destination etc. The other kind of firewall,
1291da177e4SLinus Torvalds	  a "proxy-based" one, is more secure but more intrusive and more
1301da177e4SLinus Torvalds	  bothersome to set up; it inspects the network traffic much more
1311da177e4SLinus Torvalds	  closely, modifies it and has knowledge about the higher level
1321da177e4SLinus Torvalds	  protocols, which a packet filter lacks. Moreover, proxy-based
1331da177e4SLinus Torvalds	  firewalls often require changes to the programs running on the local
1341da177e4SLinus Torvalds	  clients. Proxy-based firewalls don't need support by the kernel, but
1351da177e4SLinus Torvalds	  they are often combined with a packet filter, which only works if
1361da177e4SLinus Torvalds	  you say Y here.
1371da177e4SLinus Torvalds
1381da177e4SLinus Torvalds	  You should also say Y here if you intend to use your Linux box as
1391da177e4SLinus Torvalds	  the gateway to the Internet for a local network of machines without
1401da177e4SLinus Torvalds	  globally valid IP addresses. This is called "masquerading": if one
1411da177e4SLinus Torvalds	  of the computers on your local network wants to send something to
1421da177e4SLinus Torvalds	  the outside, your box can "masquerade" as that computer, i.e. it
1431da177e4SLinus Torvalds	  forwards the traffic to the intended outside destination, but
1441da177e4SLinus Torvalds	  modifies the packets to make it look like they came from the
1451da177e4SLinus Torvalds	  firewall box itself. It works both ways: if the outside host
1461da177e4SLinus Torvalds	  replies, the Linux box will silently forward the traffic to the
1471da177e4SLinus Torvalds	  correct local computer. This way, the computers on your local net
1481da177e4SLinus Torvalds	  are completely invisible to the outside world, even though they can
1491da177e4SLinus Torvalds	  reach the outside and can receive replies. It is even possible to
1501da177e4SLinus Torvalds	  run globally visible servers from within a masqueraded local network
1511da177e4SLinus Torvalds	  using a mechanism called portforwarding. Masquerading is also often
1521da177e4SLinus Torvalds	  called NAT (Network Address Translation).
1531da177e4SLinus Torvalds
1541da177e4SLinus Torvalds	  Another use of Netfilter is in transparent proxying: if a machine on
1551da177e4SLinus Torvalds	  the local network tries to connect to an outside host, your Linux
1561da177e4SLinus Torvalds	  box can transparently forward the traffic to a local server,
1571da177e4SLinus Torvalds	  typically a caching proxy server.
1581da177e4SLinus Torvalds
1591da177e4SLinus Torvalds	  Yet another use of Netfilter is building a bridging firewall. Using
1601da177e4SLinus Torvalds	  a bridge with Network packet filtering enabled makes iptables "see"
1611da177e4SLinus Torvalds	  the bridged traffic. For filtering on the lower network and Ethernet
1621da177e4SLinus Torvalds	  protocols over the bridge, use ebtables (under bridge netfilter
1631da177e4SLinus Torvalds	  configuration).
1641da177e4SLinus Torvalds
1651da177e4SLinus Torvalds	  Various modules exist for netfilter which replace the previous
1661da177e4SLinus Torvalds	  masquerading (ipmasqadm), packet filtering (ipchains), transparent
1671da177e4SLinus Torvalds	  proxying, and portforwarding mechanisms. Please see
1681da177e4SLinus Torvalds	  <file:Documentation/Changes> under "iptables" for the location of
1691da177e4SLinus Torvalds	  these packages.
1701da177e4SLinus Torvalds
1711da177e4SLinus Torvaldsif NETFILTER
1721da177e4SLinus Torvalds
17333b8e776SPatrick McHardyconfig NETFILTER_ADVANCED
17433b8e776SPatrick McHardy	bool "Advanced netfilter configuration"
17533b8e776SPatrick McHardy	depends on NETFILTER
17633b8e776SPatrick McHardy	default y
17733b8e776SPatrick McHardy	help
17833b8e776SPatrick McHardy	  If you say Y here you can select between all the netfilter modules.
179692105b8SMatt LaPlante	  If you say N the more unusual ones will not be shown and the
18033b8e776SPatrick McHardy	  basic ones needed by most people will default to 'M'.
18133b8e776SPatrick McHardy
18233b8e776SPatrick McHardy	  If unsure, say Y.
18333b8e776SPatrick McHardy
1841da177e4SLinus Torvaldsconfig BRIDGE_NETFILTER
18534666d46SPablo Neira Ayuso	tristate "Bridged IP/ARP packets filtering"
18657f5877cSFlorian Westphal	depends on BRIDGE
18734666d46SPablo Neira Ayuso	depends on NETFILTER && INET
18833b8e776SPatrick McHardy	depends on NETFILTER_ADVANCED
1892a95183aSFlorian Westphal	select NETFILTER_FAMILY_BRIDGE
190de8bda1dSFlorian Westphal	select SKB_EXTENSIONS
19134666d46SPablo Neira Ayuso	default m
1921da177e4SLinus Torvalds	---help---
1931da177e4SLinus Torvalds	  Enabling this option will let arptables resp. iptables see bridged
1941da177e4SLinus Torvalds	  ARP resp. IP traffic. If you want a bridging firewall, you probably
1951da177e4SLinus Torvalds	  want this option enabled.
1961da177e4SLinus Torvalds	  Enabling or disabling this option doesn't enable or disable
1971da177e4SLinus Torvalds	  ebtables.
1981da177e4SLinus Torvalds
1991da177e4SLinus Torvalds	  If unsure, say N.
2001da177e4SLinus Torvalds
2019eb0eec7SHarald Weltesource "net/netfilter/Kconfig"
2021da177e4SLinus Torvaldssource "net/ipv4/netfilter/Kconfig"
2031da177e4SLinus Torvaldssource "net/ipv6/netfilter/Kconfig"
2041da177e4SLinus Torvaldssource "net/decnet/netfilter/Kconfig"
2051da177e4SLinus Torvaldssource "net/bridge/netfilter/Kconfig"
2061da177e4SLinus Torvalds
2071da177e4SLinus Torvaldsendif
2081da177e4SLinus Torvalds
209d2ba09c1SAlexei Starovoitovsource "net/bpfilter/Kconfig"
210d2ba09c1SAlexei Starovoitov
2117c657876SArnaldo Carvalho de Melosource "net/dccp/Kconfig"
2121da177e4SLinus Torvaldssource "net/sctp/Kconfig"
213fe17f84fSAndy Groversource "net/rds/Kconfig"
2141e63e681SPer Lidensource "net/tipc/Kconfig"
2156a2e9b73SSam Ravnborgsource "net/atm/Kconfig"
216fd558d18SJames Chapmansource "net/l2tp/Kconfig"
217a19800d7SPatrick McHardysource "net/802/Kconfig"
2186a2e9b73SSam Ravnborgsource "net/bridge/Kconfig"
21991da11f8SLennert Buytenheksource "net/dsa/Kconfig"
2206a2e9b73SSam Ravnborgsource "net/8021q/Kconfig"
2211da177e4SLinus Torvaldssource "net/decnet/Kconfig"
2221da177e4SLinus Torvaldssource "net/llc/Kconfig"
2231da177e4SLinus Torvaldssource "drivers/net/appletalk/Kconfig"
2246a2e9b73SSam Ravnborgsource "net/x25/Kconfig"
2256a2e9b73SSam Ravnborgsource "net/lapb/Kconfig"
2265075138dSremi.denis-courmont@nokiasource "net/phonet/Kconfig"
2272c6bed7cSAlexander Aringsource "net/6lowpan/Kconfig"
2289ec76716SSergey Lapinsource "net/ieee802154/Kconfig"
2291010f540Salex.bluesman.smirnov@gmail.comsource "net/mac802154/Kconfig"
2301da177e4SLinus Torvaldssource "net/sched/Kconfig"
2312f90b865SAlexander Duycksource "net/dcb/Kconfig"
2321a4240f4SWang Leisource "net/dns_resolver/Kconfig"
233c6c8fea2SSven Eckelmannsource "net/batman-adv/Kconfig"
234ccb1352eSJesse Grosssource "net/openvswitch/Kconfig"
235d021c344SAndy Kingsource "net/vmw_vsock/Kconfig"
236eaaa3139SAndrey Vaginsource "net/netlink/Kconfig"
2370d89d203SSimon Hormansource "net/mpls/Kconfig"
238c411ed85SJiri Bencsource "net/nsh/Kconfig"
239f421436aSArvid Brodinsource "net/hsr/Kconfig"
240007f790cSJiri Pirkosource "net/switchdev/Kconfig"
2411b69c6d0SDavid Ahernsource "net/l3mdev/Kconfig"
242bdabad3eSCourtney Cavinsource "net/qrtr/Kconfig"
2432d283bddSGavin Shansource "net/ncsi/Kconfig"
2441da177e4SLinus Torvalds
245df334545SEric Dumazetconfig RPS
2466341e62bSChristoph Jaeger	bool
247044c8d4bSYuanhan Liu	depends on SMP && SYSFS
248df334545SEric Dumazet	default y
249df334545SEric Dumazet
250c445477dSBen Hutchingsconfig RFS_ACCEL
2516341e62bSChristoph Jaeger	bool
2520244ad00SMartin Schwidefsky	depends on RPS
253c445477dSBen Hutchings	select CPU_RMAP
254c445477dSBen Hutchings	default y
255c445477dSBen Hutchings
256bf264145STom Herbertconfig XPS
2576341e62bSChristoph Jaeger	bool
258044c8d4bSYuanhan Liu	depends on SMP
259bf264145STom Herbert	default y
260bf264145STom Herbert
2618cb2d8bfSGregory CLEMENTconfig HWBM
2628cb2d8bfSGregory CLEMENT       bool
2638cb2d8bfSGregory CLEMENT
26486f8515fSDaniel Borkmannconfig CGROUP_NET_PRIO
265af636337STejun Heo	bool "Network priority cgroup"
2665bc1421eSNeil Horman	depends on CGROUPS
2672a56a1feSTejun Heo	select SOCK_CGROUP_DATA
2685bc1421eSNeil Horman	---help---
2695bc1421eSNeil Horman	  Cgroup subsystem for use in assigning processes to network priorities on
27086f8515fSDaniel Borkmann	  a per-interface basis.
2715bc1421eSNeil Horman
272fe1217c4SDaniel Borkmannconfig CGROUP_NET_CLASSID
2736341e62bSChristoph Jaeger	bool "Network classid cgroup"
274fe1217c4SDaniel Borkmann	depends on CGROUPS
2752a56a1feSTejun Heo	select SOCK_CGROUP_DATA
276fe1217c4SDaniel Borkmann	---help---
277fe1217c4SDaniel Borkmann	  Cgroup subsystem for use as general purpose socket classid marker that is
278fe1217c4SDaniel Borkmann	  being used in cls_cgroup and for netfilter matching.
279fe1217c4SDaniel Borkmann
280e0d1095aSCong Wangconfig NET_RX_BUSY_POLL
2816341e62bSChristoph Jaeger	bool
28289bf1b5aSEliezer Tamir	default y
28306021292SEliezer Tamir
284114cf580STom Herbertconfig BQL
2856341e62bSChristoph Jaeger	bool
286114cf580STom Herbert	depends on SYSFS
287114cf580STom Herbert	select DQL
288114cf580STom Herbert	default y
289114cf580STom Herbert
2900a14842fSEric Dumazetconfig BPF_JIT
2910a14842fSEric Dumazet	bool "enable BPF Just In Time compiler"
2926077776bSDaniel Borkmann	depends on HAVE_CBPF_JIT || HAVE_EBPF_JIT
293b6202f97SEric Dumazet	depends on MODULES
2940a14842fSEric Dumazet	---help---
2950a14842fSEric Dumazet	  Berkeley Packet Filter filtering capabilities are normally handled
2960a14842fSEric Dumazet	  by an interpreter. This option allows kernel to generate a native
2970a14842fSEric Dumazet	  code when filter is loaded in memory. This should speedup
2984f3446bbSDaniel Borkmann	  packet sniffing (libpcap/tcpdump).
2994f3446bbSDaniel Borkmann
3004f3446bbSDaniel Borkmann	  Note, admin should enable this feature changing:
3014f3446bbSDaniel Borkmann	  /proc/sys/net/core/bpf_jit_enable
3024f3446bbSDaniel Borkmann	  /proc/sys/net/core/bpf_jit_harden   (optional)
30374451e66SDaniel Borkmann	  /proc/sys/net/core/bpf_jit_kallsyms (optional)
3040a14842fSEric Dumazet
30508848246SJohn Fastabendconfig BPF_STREAM_PARSER
30608848246SJohn Fastabend	bool "enable BPF STREAM_PARSER"
307604326b4SDaniel Borkmann	depends on INET
30808848246SJohn Fastabend	depends on BPF_SYSCALL
309604326b4SDaniel Borkmann	depends on CGROUP_BPF
31008848246SJohn Fastabend	select STREAM_PARSER
311604326b4SDaniel Borkmann	select NET_SOCK_MSG
31208848246SJohn Fastabend	---help---
31308848246SJohn Fastabend	 Enabling this allows a stream parser to be used with
31408848246SJohn Fastabend	 BPF_MAP_TYPE_SOCKMAP.
31508848246SJohn Fastabend
31608848246SJohn Fastabend	 BPF_MAP_TYPE_SOCKMAP provides a map type to use with network sockets.
31708848246SJohn Fastabend	 It can be used to enforce socket policy, implement socket redirects,
31808848246SJohn Fastabend	 etc.
31908848246SJohn Fastabend
32099bbc707SWillem de Bruijnconfig NET_FLOW_LIMIT
3216341e62bSChristoph Jaeger	bool
32299bbc707SWillem de Bruijn	depends on RPS
32399bbc707SWillem de Bruijn	default y
32499bbc707SWillem de Bruijn	---help---
32599bbc707SWillem de Bruijn	  The network stack has to drop packets when a receive processing CPU's
32699bbc707SWillem de Bruijn	  backlog reaches netdev_max_backlog. If a few out of many active flows
32799bbc707SWillem de Bruijn	  generate the vast majority of load, drop their traffic earlier to
32899bbc707SWillem de Bruijn	  maintain capacity for the other flows. This feature provides servers
32999bbc707SWillem de Bruijn	  with many clients some protection against DoS by a single (spoofed)
33099bbc707SWillem de Bruijn	  flow that greatly exceeds average workload.
33199bbc707SWillem de Bruijn
3321da177e4SLinus Torvaldsmenu "Network testing"
3331da177e4SLinus Torvalds
3341da177e4SLinus Torvaldsconfig NET_PKTGEN
3351da177e4SLinus Torvalds	tristate "Packet Generator (USE WITH CAUTION)"
336ffd756b3SThomas Graf	depends on INET && PROC_FS
3371da177e4SLinus Torvalds	---help---
3381da177e4SLinus Torvalds	  This module will inject preconfigured packets, at a configurable
3391da177e4SLinus Torvalds	  rate, out of a given interface.  It is used for network interface
3401da177e4SLinus Torvalds	  stress testing and performance analysis.  If you don't understand
3411da177e4SLinus Torvalds	  what was just said, you don't need it: say N.
3421da177e4SLinus Torvalds
3431da177e4SLinus Torvalds	  Documentation on how to use the packet generator can be found
3441da177e4SLinus Torvalds	  at <file:Documentation/networking/pktgen.txt>.
3451da177e4SLinus Torvalds
3461da177e4SLinus Torvalds	  To compile this code as a module, choose M here: the
3471da177e4SLinus Torvalds	  module will be called pktgen.
3481da177e4SLinus Torvalds
349273ae44bSNeil Hormanconfig NET_DROP_MONITOR
350cad456d5SNeil Horman	tristate "Network packet drop alerting service"
351911f8635SKees Cook	depends on INET && TRACEPOINTS
352273ae44bSNeil Horman	---help---
353273ae44bSNeil Horman	This feature provides an alerting service to userspace in the
354273ae44bSNeil Horman	event that packets are discarded in the network stack.  Alerts
355273ae44bSNeil Horman	are broadcast via netlink socket to any listening user space
356273ae44bSNeil Horman	process.  If you don't need network drop alerts, or if you are ok
357273ae44bSNeil Horman	just checking the various proc files and other utilities for
358273ae44bSNeil Horman	drop statistics, say N here.
359273ae44bSNeil Horman
3601da177e4SLinus Torvaldsendmenu
3611da177e4SLinus Torvalds
3621da177e4SLinus Torvaldsendmenu
3631da177e4SLinus Torvalds
3641da177e4SLinus Torvaldssource "net/ax25/Kconfig"
3650d66548aSOliver Hartkoppsource "net/can/Kconfig"
3661da177e4SLinus Torvaldssource "net/bluetooth/Kconfig"
36717926a79SDavid Howellssource "net/rxrpc/Kconfig"
368ab7ac4ebSTom Herbertsource "net/kcm/Kconfig"
36943a0c675STom Herbertsource "net/strparser/Kconfig"
370d86b5e0eSAdrian Bunk
37114c0b97dSThomas Grafconfig FIB_RULES
37214c0b97dSThomas Graf	bool
37314c0b97dSThomas Graf
3745442060cSRobert P. J. Daymenuconfig WIRELESS
3755442060cSRobert P. J. Day	bool "Wireless"
376f54bfc0eSMartin Schwidefsky	depends on !S390
3775442060cSRobert P. J. Day	default y
3785442060cSRobert P. J. Day
3795442060cSRobert P. J. Dayif WIRELESS
3802a5e1c0eSJohannes Berg
3812a5e1c0eSJohannes Bergsource "net/wireless/Kconfig"
382f0706e82SJiri Bencsource "net/mac80211/Kconfig"
3832a5e1c0eSJohannes Berg
3845442060cSRobert P. J. Dayendif # WIRELESS
3852a5e1c0eSJohannes Berg
386b0c83ae1SInaky Perez-Gonzalezsource "net/wimax/Kconfig"
387b0c83ae1SInaky Perez-Gonzalez
388cf4328cdSIvo van Doornsource "net/rfkill/Kconfig"
389bd238fb4SLatchesar Ionkovsource "net/9p/Kconfig"
3903908c690SSjur Braendelandsource "net/caif/Kconfig"
3913d14c5d2SYehuda Sadehsource "net/ceph/Kconfig"
3923e256b8fSLauro Ramos Venanciosource "net/nfc/Kconfig"
3936ae0a628SYotam Gigisource "net/psample/Kconfig"
3941ce84604SYotam Gigisource "net/ife/Kconfig"
3953908c690SSjur Braendeland
396499a2425SRoopa Prabhuconfig LWTUNNEL
397499a2425SRoopa Prabhu	bool "Network light weight tunnels"
398499a2425SRoopa Prabhu	---help---
399499a2425SRoopa Prabhu	  This feature provides an infrastructure to support light weight
400499a2425SRoopa Prabhu	  tunnels like mpls. There is no netdevice associated with a light
401499a2425SRoopa Prabhu	  weight tunnel endpoint. Tunnel encapsulation parameters are stored
402499a2425SRoopa Prabhu	  with light weight tunnel state associated with fib routes.
403cf4328cdSIvo van Doorn
4043a0af8fdSThomas Grafconfig LWTUNNEL_BPF
4053a0af8fdSThomas Graf	bool "Execute BPF program as route nexthop action"
406*b251f9f6SPeter Oskolkov	depends on LWTUNNEL && INET
4073a0af8fdSThomas Graf	default y if LWTUNNEL=y
4083a0af8fdSThomas Graf	---help---
4093a0af8fdSThomas Graf	  Allows to run BPF programs as a nexthop action following a route
4103a0af8fdSThomas Graf	  lookup for incoming and outgoing packets.
4113a0af8fdSThomas Graf
412911362c7SPaolo Abeniconfig DST_CACHE
4139b246841SDave Jones	bool
414911362c7SPaolo Abeni	default n
415911362c7SPaolo Abeni
41697e219b7SEric Dumazetconfig GRO_CELLS
41797e219b7SEric Dumazet	bool
41897e219b7SEric Dumazet	default n
41997e219b7SEric Dumazet
420ebf4e808SIlya Lesokhinconfig SOCK_VALIDATE_XMIT
421ebf4e808SIlya Lesokhin	bool
422ebf4e808SIlya Lesokhin
423604326b4SDaniel Borkmannconfig NET_SOCK_MSG
424604326b4SDaniel Borkmann	bool
425604326b4SDaniel Borkmann	default n
426604326b4SDaniel Borkmann	help
427604326b4SDaniel Borkmann	  The NET_SOCK_MSG provides a framework for plain sockets (e.g. TCP) or
428604326b4SDaniel Borkmann	  ULPs (upper layer modules, e.g. TLS) to process L7 application data
429604326b4SDaniel Borkmann	  with the help of BPF programs.
430604326b4SDaniel Borkmann
431bfcd3a46SJiri Pirkoconfig NET_DEVLINK
432bfcd3a46SJiri Pirko	tristate "Network physical/parent device Netlink interface"
433bfcd3a46SJiri Pirko	help
434bfcd3a46SJiri Pirko	  Network physical/parent device Netlink interface provides
435bfcd3a46SJiri Pirko	  infrastructure to support access to physical chip-wide config and
436bfcd3a46SJiri Pirko	  monitoring.
437bfcd3a46SJiri Pirko
4383d1cbe83SArnd Bergmannconfig MAY_USE_DEVLINK
4393d1cbe83SArnd Bergmann	tristate
4403d1cbe83SArnd Bergmann	default m if NET_DEVLINK=m
4413d1cbe83SArnd Bergmann	default y if NET_DEVLINK=y || NET_DEVLINK=n
4423d1cbe83SArnd Bergmann	help
4433d1cbe83SArnd Bergmann	  Drivers using the devlink infrastructure should have a dependency
4443d1cbe83SArnd Bergmann	  on MAY_USE_DEVLINK to ensure they do not cause link errors when
4453d1cbe83SArnd Bergmann	  devlink is a loadable module and the driver using it is built-in.
4463d1cbe83SArnd Bergmann
447ff7d6b27SJesper Dangaard Brouerconfig PAGE_POOL
448ff7d6b27SJesper Dangaard Brouer       bool
449ff7d6b27SJesper Dangaard Brouer
45030c8bd5aSSridhar Samudralaconfig FAILOVER
45130c8bd5aSSridhar Samudrala	tristate "Generic failover module"
45230c8bd5aSSridhar Samudrala	help
45330c8bd5aSSridhar Samudrala	  The failover module provides a generic interface for paravirtual
45430c8bd5aSSridhar Samudrala	  drivers to register a netdev and a set of ops with a failover
45530c8bd5aSSridhar Samudrala	  instance. The ops are used as event handlers that get called to
45630c8bd5aSSridhar Samudrala	  handle netdev register/unregister/link change/name change events
45730c8bd5aSSridhar Samudrala	  on slave pci ethernet devices with the same mac address as the
45830c8bd5aSSridhar Samudrala	  failover netdev. This enables paravirtual drivers to use a
45930c8bd5aSSridhar Samudrala	  VF as an accelerated low latency datapath. It also allows live
46030c8bd5aSSridhar Samudrala	  migration of VMs with direct attached VFs by failing over to the
46130c8bd5aSSridhar Samudrala	  paravirtual datapath when the VF is unplugged.
46230c8bd5aSSridhar Samudrala
4636a2e9b73SSam Ravnborgendif   # if NET
464e47b65b0SSam Ravnborg
4656077776bSDaniel Borkmann# Used by archs to tell that they support BPF JIT compiler plus which flavour.
4666077776bSDaniel Borkmann# Only one of the two can be selected for a specific arch since eBPF JIT supersedes
4676077776bSDaniel Borkmann# the cBPF JIT.
4686077776bSDaniel Borkmann
4696077776bSDaniel Borkmann# Classic BPF JIT (cBPF)
4706077776bSDaniel Borkmannconfig HAVE_CBPF_JIT
4716077776bSDaniel Borkmann	bool
4726077776bSDaniel Borkmann
4736077776bSDaniel Borkmann# Extended BPF JIT (eBPF)
4746077776bSDaniel Borkmannconfig HAVE_EBPF_JIT
475e47b65b0SSam Ravnborg	bool
476