2005-04-16 15:20:36 -07:00
#
# Network configuration
#
2008-07-30 03:14:01 -07:00
menuconfig NET
2005-04-16 15:20:36 -07:00
bool "Networking support"
2009-03-04 14:53:30 +08:00
select NLATTR
2013-06-04 19:46:26 +03:00
select GENERIC_NET_UTILS
2014-10-23 18:41:08 -07:00
select BPF
2005-04-16 15:20:36 -07:00
---help---
Unless you really know what you are doing, you should say Y here.
The reason is that some programs need kernel networking support even
when running on a stand-alone machine that isn't connected to any
2005-07-11 21:03:49 -07:00
other computer.
If you are upgrading from an older kernel, you
2005-04-16 15:20:36 -07:00
should consider updating your networking tools too because changes
in the kernel and the tools often go hand in hand. The tools are
contained in the package net-tools, the location and version number
of which are given in <file:Documentation/Changes>.
For a general introduction to Linux networking, it is highly
recommended to read the NET-HOWTO, available from
<http://www.tldp.org/docs.html#howto>.
2005-07-11 21:13:56 -07:00
if NET
2005-04-16 15:20:36 -07:00
net/compat/wext: send different messages to compat tasks
Wireless extensions have the unfortunate problem that events
are multicast netlink messages, and are not independent of
pointer size. Thus, currently 32-bit tasks on 64-bit platforms
cannot properly receive events and fail with all kinds of
strange problems, for instance wpa_supplicant never notices
disassociations, due to the way the 64-bit event looks (to a
32-bit process), the fact that the address is all zeroes is
lost, it thinks instead it is 00:00:00:00:01:00.
The same problem existed with the ioctls, until David Miller
fixed those some time ago in an heroic effort.
A different problem caused by this is that we cannot send the
ASSOCREQIE/ASSOCRESPIE events because sending them causes a
32-bit wpa_supplicant on a 64-bit system to overwrite its
internal information, which is worse than it not getting the
information at all -- so we currently resort to sending a
custom string event that it then parses. This, however, has a
severe size limitation we are frequently hitting with modern
access points; this limitation would can be lifted after this
patch by sending the correct binary, not custom, event.
A similar problem apparently happens for some other netlink
users on x86_64 with 32-bit tasks due to the alignment for
64-bit quantities.
In order to fix these problems, I have implemented a way to
send compat messages to tasks. When sending an event, we send
the non-compat event data together with a compat event data in
skb_shinfo(main_skb)->frag_list. Then, when the event is read
from the socket, the netlink code makes sure to pass out only
the skb that is compatible with the task. This approach was
suggested by David Miller, my original approach required
always sending two skbs but that had various small problems.
To determine whether compat is needed or not, I have used the
MSG_CMSG_COMPAT flag, and adjusted the call path for recv and
recvfrom to include it, even if those calls do not have a cmsg
parameter.
I have not solved one small part of the problem, and I don't
think it is necessary to: if a 32-bit application uses read()
rather than any form of recvmsg() it will still get the wrong
(64-bit) event. However, neither do applications actually do
this, nor would it be a regression.
Signed-off-by: Johannes Berg <johannes@sipsolutions.net>
Signed-off-by: David S. Miller <davem@davemloft.net>
2009-07-01 11:26:02 +00:00
config WANT_COMPAT_NETLINK_MESSAGES
bool
help
This option can be selected by other options that need compat
netlink messages.
config COMPAT_NETLINK_MESSAGES
def_bool y
depends on COMPAT
2010-07-26 13:13:49 -07:00
depends on WEXT_CORE || WANT_COMPAT_NETLINK_MESSAGES
net/compat/wext: send different messages to compat tasks
Wireless extensions have the unfortunate problem that events
are multicast netlink messages, and are not independent of
pointer size. Thus, currently 32-bit tasks on 64-bit platforms
cannot properly receive events and fail with all kinds of
strange problems, for instance wpa_supplicant never notices
disassociations, due to the way the 64-bit event looks (to a
32-bit process), the fact that the address is all zeroes is
lost, it thinks instead it is 00:00:00:00:01:00.
The same problem existed with the ioctls, until David Miller
fixed those some time ago in an heroic effort.
A different problem caused by this is that we cannot send the
ASSOCREQIE/ASSOCRESPIE events because sending them causes a
32-bit wpa_supplicant on a 64-bit system to overwrite its
internal information, which is worse than it not getting the
information at all -- so we currently resort to sending a
custom string event that it then parses. This, however, has a
severe size limitation we are frequently hitting with modern
access points; this limitation would can be lifted after this
patch by sending the correct binary, not custom, event.
A similar problem apparently happens for some other netlink
users on x86_64 with 32-bit tasks due to the alignment for
64-bit quantities.
In order to fix these problems, I have implemented a way to
send compat messages to tasks. When sending an event, we send
the non-compat event data together with a compat event data in
skb_shinfo(main_skb)->frag_list. Then, when the event is read
from the socket, the netlink code makes sure to pass out only
the skb that is compatible with the task. This approach was
suggested by David Miller, my original approach required
always sending two skbs but that had various small problems.
To determine whether compat is needed or not, I have used the
MSG_CMSG_COMPAT flag, and adjusted the call path for recv and
recvfrom to include it, even if those calls do not have a cmsg
parameter.
I have not solved one small part of the problem, and I don't
think it is necessary to: if a 32-bit application uses read()
rather than any form of recvmsg() it will still get the wrong
(64-bit) event. However, neither do applications actually do
this, nor would it be a regression.
Signed-off-by: Johannes Berg <johannes@sipsolutions.net>
Signed-off-by: David S. Miller <davem@davemloft.net>
2009-07-01 11:26:02 +00:00
help
This option makes it possible to send different netlink messages
to tasks depending on whether the task is a compat task or not. To
achieve this, you need to set skb_shinfo(skb)->frag_list to the
compat skb before sending the skb, the netlink code will sort out
which message to actually pass to the task.
Newly written code should NEVER need this option but do
compat-independent messages instead!
2015-05-13 18:19:37 +02:00
config NET_INGRESS
bool
net, sched: add clsact qdisc
This work adds a generalization of the ingress qdisc as a qdisc holding
only classifiers. The clsact qdisc works on ingress, but also on egress.
In both cases, it's execution happens without taking the qdisc lock, and
the main difference for the egress part compared to prior version of [1]
is that this can be applied with _any_ underlying real egress qdisc (also
classless ones).
Besides solving the use-case of [1], that is, allowing for more programmability
on assigning skb->priority for the mqprio case that is supported by most
popular 10G+ NICs, it also opens up a lot more flexibility for other tc
applications. The main work on classification can already be done at clsact
egress time if the use-case allows and state stored for later retrieval
f.e. again in skb->priority with major/minors (which is checked by most
classful qdiscs before consulting tc_classify()) and/or in other skb fields
like skb->tc_index for some light-weight post-processing to get to the
eventual classid in case of a classful qdisc. Another use case is that
the clsact egress part allows to have a central egress counterpart to
the ingress classifiers, so that classifiers can easily share state (e.g.
in cls_bpf via eBPF maps) for ingress and egress.
Currently, default setups like mq + pfifo_fast would require for this to
use, for example, prio qdisc instead (to get a tc_classify() run) and to
duplicate the egress classifier for each queue. With clsact, it allows
for leaving the setup as is, it can additionally assign skb->priority to
put the skb in one of pfifo_fast's bands and it can share state with maps.
Moreover, we can access the skb's dst entry (f.e. to retrieve tclassid)
w/o the need to perform a skb_dst_force() to hold on to it any longer. In
lwt case, we can also use this facility to setup dst metadata via cls_bpf
(bpf_skb_set_tunnel_key()) without needing a real egress qdisc just for
that (case of IFF_NO_QUEUE devices, for example).
The realization can be done without any changes to the scheduler core
framework. All it takes is that we have two a-priori defined minors/child
classes, where we can mux between ingress and egress classifier list
(dev->ingress_cl_list and dev->egress_cl_list, latter stored close to
dev->_tx to avoid extra cacheline miss for moderate loads). The egress
part is a bit similar modelled to handle_ing() and patched to a noop in
case the functionality is not used. Both handlers are now called
sch_handle_ingress() and sch_handle_egress(), code sharing among the two
doesn't seem practical as there are various minor differences in both
paths, so that making them conditional in a single handler would rather
slow things down.
Full compatibility to ingress qdisc is provided as well. Since both
piggyback on TC_H_CLSACT, only one of them (ingress/clsact) can exist
per netdevice, and thus ingress qdisc specific behaviour can be retained
for user space. This means, either a user does 'tc qdisc add dev foo ingress'
and configures ingress qdisc as usual, or the 'tc qdisc add dev foo clsact'
alternative, where both, ingress and egress classifier can be configured
as in the below example. ingress qdisc supports attaching classifier to any
minor number whereas clsact has two fixed minors for muxing between the
lists, therefore to not break user space setups, they are better done as
two separate qdiscs.
I decided to extend the sch_ingress module with clsact functionality so
that commonly used code can be reused, the module is being aliased with
sch_clsact so that it can be auto-loaded properly. Alternative would have been
to add a flag when initializing ingress to alter its behaviour plus aliasing
to a different name (as it's more than just ingress). However, the first would
end up, based on the flag, choosing the new/old behaviour by calling different
function implementations to handle each anyway, the latter would require to
register ingress qdisc once again under different alias. So, this really begs
to provide a minimal, cleaner approach to have Qdisc_ops and Qdisc_class_ops
by its own that share callbacks used by both.
Example, adding qdisc:
# tc qdisc add dev foo clsact
# tc qdisc show dev foo
qdisc mq 0: root
qdisc pfifo_fast 0: parent :1 bands 3 priomap 1 2 2 2 1 2 0 0 1 1 1 1 1 1 1 1
qdisc pfifo_fast 0: parent :2 bands 3 priomap 1 2 2 2 1 2 0 0 1 1 1 1 1 1 1 1
qdisc pfifo_fast 0: parent :3 bands 3 priomap 1 2 2 2 1 2 0 0 1 1 1 1 1 1 1 1
qdisc pfifo_fast 0: parent :4 bands 3 priomap 1 2 2 2 1 2 0 0 1 1 1 1 1 1 1 1
qdisc clsact ffff: parent ffff:fff1
Adding filters (deleting, etc works analogous by specifying ingress/egress):
# tc filter add dev foo ingress bpf da obj bar.o sec ingress
# tc filter add dev foo egress bpf da obj bar.o sec egress
# tc filter show dev foo ingress
filter protocol all pref 49152 bpf
filter protocol all pref 49152 bpf handle 0x1 bar.o:[ingress] direct-action
# tc filter show dev foo egress
filter protocol all pref 49152 bpf
filter protocol all pref 49152 bpf handle 0x1 bar.o:[egress] direct-action
A 'tc filter show dev foo' or 'tc filter show dev foo parent ffff:' will
show an empty list for clsact. Either using the parent names (ingress/egress)
or specifying the full major/minor will then show the related filter lists.
Prior work on a mqprio prequeue() facility [1] was done mainly by John Fastabend.
[1] http://patchwork.ozlabs.org/patch/512949/
Signed-off-by: Daniel Borkmann <daniel@iogearbox.net>
Acked-by: John Fastabend <john.r.fastabend@intel.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2016-01-07 22:29:47 +01:00
config NET_EGRESS
bool
2005-07-11 21:13:56 -07:00
menu "Networking options"
2005-04-16 15:20:36 -07:00
2005-07-11 21:13:56 -07:00
source "net/packet/Kconfig"
source "net/unix/Kconfig"
source "net/xfrm/Kconfig"
2007-02-08 13:37:42 -08:00
source "net/iucv/Kconfig"
2005-04-16 15:20:36 -07:00
config INET
bool "TCP/IP networking"
2012-09-04 14:20:14 -04:00
select CRYPTO
select CRYPTO_AES
2005-04-16 15:20:36 -07:00
---help---
These are the protocols used on the Internet and on most local
Ethernets. It is highly recommended to say Y here (this will enlarge
2008-02-12 17:35:16 +09:00
your kernel by about 400 KB), since some programs (e.g. the X window
2005-04-16 15:20:36 -07:00
system) use TCP/IP even if your machine is not connected to any
other computer. You will get the so-called loopback device which
allows you to ping yourself (great fun, that!).
For an excellent introduction to Linux networking, please read the
Linux Networking HOWTO, available from
<http://www.tldp.org/docs.html#howto>.
If you say Y here and also to "/proc file system support" and
"Sysctl support" below, you can change various aspects of the
behavior of the TCP/IP code by writing to the (virtual) files in
/proc/sys/net/ipv4/*; the options are explained in the file
<file:Documentation/networking/ip-sysctl.txt>.
Short answer: say Y.
2005-07-11 21:13:56 -07:00
if INET
2005-04-16 15:20:36 -07:00
source "net/ipv4/Kconfig"
source "net/ipv6/Kconfig"
2006-11-05 16:44:06 -08:00
source "net/netlabel/Kconfig"
2005-04-16 15:20:36 -07:00
2005-07-11 21:13:56 -07:00
endif # if INET
2006-06-09 00:29:17 -07:00
config NETWORK_SECMARK
bool "Security Marking"
help
This enables security marking of network packets, similar
to nfmark, but designated for security purposes.
If you are unsure how to answer this question, answer N.
2014-04-01 16:20:23 +02:00
config NET_PTP_CLASSIFY
def_bool n
2010-07-17 08:49:36 +00:00
config NETWORK_PHY_TIMESTAMPING
bool "Timestamping in PHY devices"
2014-04-01 16:20:23 +02:00
select NET_PTP_CLASSIFY
2010-07-17 08:49:36 +00:00
help
This allows timestamping of network packets by PHYs with
hardware timestamping capabilities. This option adds some
overhead in the transmit and receive paths.
If you are unsure how to answer this question, answer N.
2005-04-16 15:20:36 -07:00
menuconfig NETFILTER
2006-11-29 02:35:43 +01:00
bool "Network packet filtering framework (Netfilter)"
2005-04-16 15:20:36 -07:00
---help---
Netfilter is a framework for filtering and mangling network packets
that pass through your Linux box.
The most common use of packet filtering is to run your Linux box as
a firewall protecting a local network from the Internet. The type of
firewall provided by this kernel support is called a "packet
filter", which means that it can reject individual network packets
based on type, source, destination etc. The other kind of firewall,
a "proxy-based" one, is more secure but more intrusive and more
bothersome to set up; it inspects the network traffic much more
closely, modifies it and has knowledge about the higher level
protocols, which a packet filter lacks. Moreover, proxy-based
firewalls often require changes to the programs running on the local
clients. Proxy-based firewalls don't need support by the kernel, but
they are often combined with a packet filter, which only works if
you say Y here.
You should also say Y here if you intend to use your Linux box as
the gateway to the Internet for a local network of machines without
globally valid IP addresses. This is called "masquerading": if one
of the computers on your local network wants to send something to
the outside, your box can "masquerade" as that computer, i.e. it
forwards the traffic to the intended outside destination, but
modifies the packets to make it look like they came from the
firewall box itself. It works both ways: if the outside host
replies, the Linux box will silently forward the traffic to the
correct local computer. This way, the computers on your local net
are completely invisible to the outside world, even though they can
reach the outside and can receive replies. It is even possible to
run globally visible servers from within a masqueraded local network
using a mechanism called portforwarding. Masquerading is also often
called NAT (Network Address Translation).
Another use of Netfilter is in transparent proxying: if a machine on
the local network tries to connect to an outside host, your Linux
box can transparently forward the traffic to a local server,
typically a caching proxy server.
Yet another use of Netfilter is building a bridging firewall. Using
a bridge with Network packet filtering enabled makes iptables "see"
the bridged traffic. For filtering on the lower network and Ethernet
protocols over the bridge, use ebtables (under bridge netfilter
configuration).
Various modules exist for netfilter which replace the previous
masquerading (ipmasqadm), packet filtering (ipchains), transparent
proxying, and portforwarding mechanisms. Please see
<file:Documentation/Changes> under "iptables" for the location of
these packages.
if NETFILTER
config NETFILTER_DEBUG
bool "Network packet filtering debugging"
depends on NETFILTER
help
You can say Y here if you want to get additional messages useful in
debugging the netfilter code.
2007-12-17 22:47:05 -08:00
config NETFILTER_ADVANCED
bool "Advanced netfilter configuration"
depends on NETFILTER
default y
help
If you say Y here you can select between all the netfilter modules.
2009-01-26 11:12:25 +01:00
If you say N the more unusual ones will not be shown and the
2007-12-17 22:47:05 -08:00
basic ones needed by most people will default to 'M'.
If unsure, say Y.
2005-04-16 15:20:36 -07:00
config BRIDGE_NETFILTER
2014-09-18 11:29:03 +02:00
tristate "Bridged IP/ARP packets filtering"
2014-09-30 10:59:18 +02:00
depends on BRIDGE
2014-09-18 11:29:03 +02:00
depends on NETFILTER && INET
2007-12-17 22:47:05 -08:00
depends on NETFILTER_ADVANCED
2014-09-18 11:29:03 +02:00
default m
2005-04-16 15:20:36 -07:00
---help---
Enabling this option will let arptables resp. iptables see bridged
ARP resp. IP traffic. If you want a bridging firewall, you probably
want this option enabled.
Enabling or disabling this option doesn't enable or disable
ebtables.
If unsure, say N.
2005-09-17 00:41:21 -07:00
source "net/netfilter/Kconfig"
2005-04-16 15:20:36 -07:00
source "net/ipv4/netfilter/Kconfig"
source "net/ipv6/netfilter/Kconfig"
source "net/decnet/netfilter/Kconfig"
source "net/bridge/netfilter/Kconfig"
endif
2005-08-09 20:14:34 -07:00
source "net/dccp/Kconfig"
2005-04-16 15:20:36 -07:00
source "net/sctp/Kconfig"
2009-02-24 15:30:39 +00:00
source "net/rds/Kconfig"
2006-01-16 16:39:13 +01:00
source "net/tipc/Kconfig"
2005-07-11 21:13:56 -07:00
source "net/atm/Kconfig"
2010-04-02 06:18:33 +00:00
source "net/l2tp/Kconfig"
2008-07-05 21:25:39 -07:00
source "net/802/Kconfig"
2005-07-11 21:13:56 -07:00
source "net/bridge/Kconfig"
net: Distributed Switch Architecture protocol support
Distributed Switch Architecture is a protocol for managing hardware
switch chips. It consists of a set of MII management registers and
commands to configure the switch, and an ethernet header format to
signal which of the ports of the switch a packet was received from
or is intended to be sent to.
The switches that this driver supports are typically embedded in
access points and routers, and a typical setup with a DSA switch
looks something like this:
+-----------+ +-----------+
| | RGMII | |
| +-------+ +------ 1000baseT MDI ("WAN")
| | | 6-port +------ 1000baseT MDI ("LAN1")
| CPU | | ethernet +------ 1000baseT MDI ("LAN2")
| |MIImgmt| switch +------ 1000baseT MDI ("LAN3")
| +-------+ w/5 PHYs +------ 1000baseT MDI ("LAN4")
| | | |
+-----------+ +-----------+
The switch driver presents each port on the switch as a separate
network interface to Linux, polls the switch to maintain software
link state of those ports, forwards MII management interface
accesses to those network interfaces (e.g. as done by ethtool) to
the switch, and exposes the switch's hardware statistics counters
via the appropriate Linux kernel interfaces.
This initial patch supports the MII management interface register
layout of the Marvell 88E6123, 88E6161 and 88E6165 switch chips, and
supports the "Ethertype DSA" packet tagging format.
(There is no officially registered ethertype for the Ethertype DSA
packet format, so we just grab a random one. The ethertype to use
is programmed into the switch, and the switch driver uses the value
of ETH_P_EDSA for this, so this define can be changed at any time in
the future if the one we chose is allocated to another protocol or
if Ethertype DSA gets its own officially registered ethertype, and
everything will continue to work.)
Signed-off-by: Lennert Buytenhek <buytenh@marvell.com>
Tested-by: Nicolas Pitre <nico@marvell.com>
Tested-by: Byron Bradley <byron.bbradley@gmail.com>
Tested-by: Tim Ellis <tim.ellis@mac.com>
Tested-by: Peter van Valderen <linux@ddcrew.com>
Tested-by: Dirk Teurlings <dirk@upexia.nl>
Signed-off-by: David S. Miller <davem@davemloft.net>
2008-10-07 13:44:02 +00:00
source "net/dsa/Kconfig"
2005-07-11 21:13:56 -07:00
source "net/8021q/Kconfig"
2005-04-16 15:20:36 -07:00
source "net/decnet/Kconfig"
source "net/llc/Kconfig"
source "net/ipx/Kconfig"
source "drivers/net/appletalk/Kconfig"
2005-07-11 21:13:56 -07:00
source "net/x25/Kconfig"
source "net/lapb/Kconfig"
2009-01-23 03:00:25 +00:00
source "net/phonet/Kconfig"
2014-07-11 10:24:18 +02:00
source "net/6lowpan/Kconfig"
2009-06-08 12:18:48 +00:00
source "net/ieee802154/Kconfig"
2012-05-15 20:50:20 +00:00
source "net/mac802154/Kconfig"
2005-04-16 15:20:36 -07:00
source "net/sched/Kconfig"
2008-11-20 20:52:10 -08:00
source "net/dcb/Kconfig"
2010-08-04 15:16:33 +01:00
source "net/dns_resolver/Kconfig"
2010-12-13 11:19:28 +00:00
source "net/batman-adv/Kconfig"
2011-10-25 19:26:31 -07:00
source "net/openvswitch/Kconfig"
VSOCK: Introduce VM Sockets
VM Sockets allows communication between virtual machines and the hypervisor.
User level applications both in a virtual machine and on the host can use the
VM Sockets API, which facilitates fast and efficient communication between
guest virtual machines and their host. A socket address family, designed to be
compatible with UDP and TCP at the interface level, is provided.
Today, VM Sockets is used by various VMware Tools components inside the guest
for zero-config, network-less access to VMware host services. In addition to
this, VMware's users are using VM Sockets for various applications, where
network access of the virtual machine is restricted or non-existent. Examples
of this are VMs communicating with device proxies for proprietary hardware
running as host applications and automated testing of applications running
within virtual machines.
The VMware VM Sockets are similar to other socket types, like Berkeley UNIX
socket interface. The VM Sockets module supports both connection-oriented
stream sockets like TCP, and connectionless datagram sockets like UDP. The VM
Sockets protocol family is defined as "AF_VSOCK" and the socket operations
split for SOCK_DGRAM and SOCK_STREAM.
For additional information about the use of VM Sockets, please refer to the
VM Sockets Programming Guide available at:
https://www.vmware.com/support/developer/vmci-sdk/
Signed-off-by: George Zhang <georgezhang@vmware.com>
Signed-off-by: Dmitry Torokhov <dtor@vmware.com>
Signed-off-by: Andy king <acking@vmware.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
2013-02-06 14:23:56 +00:00
source "net/vmw_vsock/Kconfig"
2013-03-21 20:33:48 +04:00
source "net/netlink/Kconfig"
2013-05-23 21:02:52 +00:00
source "net/mpls/Kconfig"
2013-10-30 21:10:47 +01:00
source "net/hsr/Kconfig"
2014-11-28 14:34:17 +01:00
source "net/switchdev/Kconfig"
2015-09-29 20:07:11 -07:00
source "net/l3mdev/Kconfig"
2005-04-16 15:20:36 -07:00
2010-03-24 19:13:54 +00:00
config RPS
2014-12-20 15:41:11 -05:00
bool
2013-11-21 14:32:01 -08:00
depends on SMP && SYSFS
2010-03-24 19:13:54 +00:00
default y
2011-01-19 11:03:53 +00:00
config RFS_ACCEL
2014-12-20 15:41:11 -05:00
bool
2013-08-30 09:39:53 +02:00
depends on RPS
2011-01-19 11:03:53 +00:00
select CPU_RMAP
default y
2010-11-26 08:36:09 +00:00
config XPS
2014-12-20 15:41:11 -05:00
bool
2013-11-21 14:32:01 -08:00
depends on SMP
2010-11-26 08:36:09 +00:00
default y
2016-03-14 09:39:04 +01:00
config HWBM
bool
2015-12-07 17:38:52 -05:00
config SOCK_CGROUP_DATA
bool
default n
2013-12-29 17:27:11 +01:00
config CGROUP_NET_PRIO
2014-02-08 10:36:58 -05:00
bool "Network priority cgroup"
2011-11-22 05:10:51 +00:00
depends on CGROUPS
2015-12-07 17:38:52 -05:00
select SOCK_CGROUP_DATA
2011-11-22 05:10:51 +00:00
---help---
Cgroup subsystem for use in assigning processes to network priorities on
2013-12-29 17:27:11 +01:00
a per-interface basis.
2011-11-22 05:10:51 +00:00
2013-12-29 18:27:10 +01:00
config CGROUP_NET_CLASSID
2014-12-20 15:41:11 -05:00
bool "Network classid cgroup"
2013-12-29 18:27:10 +01:00
depends on CGROUPS
2015-12-07 17:38:52 -05:00
select SOCK_CGROUP_DATA
2013-12-29 18:27:10 +01:00
---help---
Cgroup subsystem for use as general purpose socket classid marker that is
being used in cls_cgroup and for netfilter matching.
2013-08-01 11:10:25 +08:00
config NET_RX_BUSY_POLL
2014-12-20 15:41:11 -05:00
bool
2013-06-14 16:33:46 +03:00
default y
2013-06-10 11:39:50 +03:00
2011-11-28 16:33:09 +00:00
config BQL
2014-12-20 15:41:11 -05:00
bool
2011-11-28 16:33:09 +00:00
depends on SYSFS
select DQL
default y
2011-04-20 09:27:32 +00:00
config BPF_JIT
bool "enable BPF Just In Time compiler"
depends on HAVE_BPF_JIT
2011-04-29 10:20:53 -07:00
depends on MODULES
2011-04-20 09:27:32 +00:00
---help---
Berkeley Packet Filter filtering capabilities are normally handled
by an interpreter. This option allows kernel to generate a native
code when filter is loaded in memory. This should speedup
packet sniffing (libpcap/tcpdump). Note : Admin should enable
this feature changing /proc/sys/net/core/bpf_jit_enable
2013-05-20 04:02:32 +00:00
config NET_FLOW_LIMIT
2014-12-20 15:41:11 -05:00
bool
2013-05-20 04:02:32 +00:00
depends on RPS
default y
---help---
The network stack has to drop packets when a receive processing CPU's
backlog reaches netdev_max_backlog. If a few out of many active flows
generate the vast majority of load, drop their traffic earlier to
maintain capacity for the other flows. This feature provides servers
with many clients some protection against DoS by a single (spoofed)
flow that greatly exceeds average workload.
2005-04-16 15:20:36 -07:00
menu "Network testing"
config NET_PKTGEN
tristate "Packet Generator (USE WITH CAUTION)"
2013-07-29 13:44:15 +02:00
depends on INET && PROC_FS
2005-04-16 15:20:36 -07:00
---help---
This module will inject preconfigured packets, at a configurable
rate, out of a given interface. It is used for network interface
stress testing and performance analysis. If you don't understand
what was just said, you don't need it: say N.
Documentation on how to use the packet generator can be found
at <file:Documentation/networking/pktgen.txt>.
To compile this code as a module, choose M here: the
module will be called pktgen.
2006-06-05 17:30:32 -07:00
config NET_TCPPROBE
tristate "TCP connection probing"
2012-10-02 11:19:40 -07:00
depends on INET && PROC_FS && KPROBES
2006-06-05 17:30:32 -07:00
---help---
This module allows for capturing the changes to TCP connection
2006-06-08 23:42:09 -07:00
state in response to incoming packets. It is used for debugging
2006-06-05 17:30:32 -07:00
TCP congestion avoidance modules. If you don't understand
what was just said, you don't need it: say N.
2006-09-25 23:47:14 -07:00
Documentation on how to use TCP connection probing can be found
2010-11-15 19:55:34 +00:00
at:
http://www.linuxfoundation.org/collaborate/workgroups/networking/tcpprobe
2006-06-05 17:30:32 -07:00
To compile this code as a module, choose M here: the
module will be called tcp_probe.
2009-03-11 09:53:16 +00:00
config NET_DROP_MONITOR
2012-05-17 10:04:00 +00:00
tristate "Network packet drop alerting service"
2012-10-02 11:19:40 -07:00
depends on INET && TRACEPOINTS
2009-03-11 09:53:16 +00:00
---help---
This feature provides an alerting service to userspace in the
event that packets are discarded in the network stack. Alerts
are broadcast via netlink socket to any listening user space
process. If you don't need network drop alerts, or if you are ok
just checking the various proc files and other utilities for
drop statistics, say N here.
2005-04-16 15:20:36 -07:00
endmenu
endmenu
source "net/ax25/Kconfig"
2007-11-16 15:52:17 -08:00
source "net/can/Kconfig"
2005-04-16 15:20:36 -07:00
source "net/irda/Kconfig"
source "net/bluetooth/Kconfig"
2007-04-26 15:48:28 -07:00
source "net/rxrpc/Kconfig"
2016-03-07 14:11:06 -08:00
source "net/kcm/Kconfig"
2006-01-21 00:46:55 +01:00
2006-08-04 03:38:38 -07:00
config FIB_RULES
bool
2008-07-24 12:20:09 -04:00
menuconfig WIRELESS
bool "Wireless"
2007-05-10 15:46:01 +02:00
depends on !S390
2008-07-24 12:20:09 -04:00
default y
if WIRELESS
2007-04-23 12:19:12 -07:00
source "net/wireless/Kconfig"
2007-05-05 11:45:53 -07:00
source "net/mac80211/Kconfig"
2007-04-23 12:19:12 -07:00
2008-07-24 12:20:09 -04:00
endif # WIRELESS
2007-04-23 12:19:12 -07:00
2008-12-23 16:18:24 -08:00
source "net/wimax/Kconfig"
2007-05-07 00:34:20 -07:00
source "net/rfkill/Kconfig"
2007-07-10 17:57:28 -05:00
source "net/9p/Kconfig"
2010-03-30 13:56:28 +00:00
source "net/caif/Kconfig"
2010-04-06 15:14:15 -07:00
source "net/ceph/Kconfig"
2011-07-01 19:31:33 -03:00
source "net/nfc/Kconfig"
2010-03-30 13:56:28 +00:00
2015-07-21 10:43:46 +02:00
config LWTUNNEL
bool "Network light weight tunnels"
---help---
This feature provides an infrastructure to support light weight
tunnels like mpls. There is no netdevice associated with a light
weight tunnel endpoint. Tunnel encapsulation parameters are stored
with light weight tunnel state associated with fib routes.
2007-05-07 00:34:20 -07:00
2016-02-12 15:43:53 +01:00
config DST_CACHE
bool "dst cache"
default n
2016-02-26 17:32:23 +01:00
config NET_DEVLINK
tristate "Network physical/parent device Netlink interface"
help
Network physical/parent device Netlink interface provides
infrastructure to support access to physical chip-wide config and
monitoring.
2016-03-02 10:40:54 +01:00
config MAY_USE_DEVLINK
tristate
default m if NET_DEVLINK=m
default y if NET_DEVLINK=y || NET_DEVLINK=n
help
Drivers using the devlink infrastructure should have a dependency
on MAY_USE_DEVLINK to ensure they do not cause link errors when
devlink is a loadable module and the driver using it is built-in.
2005-07-11 21:13:56 -07:00
endif # if NET
2012-05-21 20:45:37 +02:00
# Used by archs to tell that they support BPF_JIT
config HAVE_BPF_JIT
bool