2005-04-17 06:20:36 +08:00
|
|
|
#
|
|
|
|
# Network configuration
|
|
|
|
#
|
|
|
|
|
2008-07-30 18:14:01 +08:00
|
|
|
menuconfig NET
|
2005-04-17 06:20:36 +08:00
|
|
|
bool "Networking support"
|
2009-03-04 14:53:30 +08:00
|
|
|
select NLATTR
|
2013-06-05 00:46:26 +08:00
|
|
|
select GENERIC_NET_UTILS
|
2014-10-24 09:41:08 +08:00
|
|
|
select BPF
|
2005-04-17 06:20:36 +08: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-12 12:03:49 +08:00
|
|
|
other computer.
|
|
|
|
|
|
|
|
If you are upgrading from an older kernel, you
|
2005-04-17 06:20:36 +08: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-12 12:13:56 +08:00
|
|
|
if NET
|
2005-04-17 06:20:36 +08: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 19:26:02 +08: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-27 04:13:49 +08: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 19:26:02 +08: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-14 00:19:37 +08: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-08 05:29:47 +08:00
|
|
|
config NET_EGRESS
|
|
|
|
bool
|
|
|
|
|
2005-07-12 12:13:56 +08:00
|
|
|
menu "Networking options"
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2005-07-12 12:13:56 +08:00
|
|
|
source "net/packet/Kconfig"
|
|
|
|
source "net/unix/Kconfig"
|
|
|
|
source "net/xfrm/Kconfig"
|
2007-02-09 05:37:42 +08:00
|
|
|
source "net/iucv/Kconfig"
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
config INET
|
|
|
|
bool "TCP/IP networking"
|
2012-09-05 02:20:14 +08:00
|
|
|
select CRYPTO
|
|
|
|
select CRYPTO_AES
|
2005-04-17 06:20:36 +08: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 16:35:16 +08:00
|
|
|
your kernel by about 400 KB), since some programs (e.g. the X window
|
2005-04-17 06:20:36 +08: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-12 12:13:56 +08:00
|
|
|
if INET
|
2005-04-17 06:20:36 +08:00
|
|
|
source "net/ipv4/Kconfig"
|
|
|
|
source "net/ipv6/Kconfig"
|
2006-11-06 08:44:06 +08:00
|
|
|
source "net/netlabel/Kconfig"
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2005-07-12 12:13:56 +08:00
|
|
|
endif # if INET
|
|
|
|
|
2006-06-09 15:29:17 +08: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 22:20:23 +08:00
|
|
|
config NET_PTP_CLASSIFY
|
|
|
|
def_bool n
|
|
|
|
|
2010-07-17 16:49:36 +08:00
|
|
|
config NETWORK_PHY_TIMESTAMPING
|
|
|
|
bool "Timestamping in PHY devices"
|
2014-04-01 22:20:23 +08:00
|
|
|
select NET_PTP_CLASSIFY
|
2010-07-17 16:49:36 +08: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-17 06:20:36 +08:00
|
|
|
menuconfig NETFILTER
|
2006-11-29 09:35:43 +08:00
|
|
|
bool "Network packet filtering framework (Netfilter)"
|
2005-04-17 06:20:36 +08: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-18 14: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 18:12:25 +08:00
|
|
|
If you say N the more unusual ones will not be shown and the
|
2007-12-18 14:47:05 +08:00
|
|
|
basic ones needed by most people will default to 'M'.
|
|
|
|
|
|
|
|
If unsure, say Y.
|
|
|
|
|
2005-04-17 06:20:36 +08:00
|
|
|
config BRIDGE_NETFILTER
|
2014-09-18 17:29:03 +08:00
|
|
|
tristate "Bridged IP/ARP packets filtering"
|
2014-09-30 16:59:18 +08:00
|
|
|
depends on BRIDGE
|
2014-09-18 17:29:03 +08:00
|
|
|
depends on NETFILTER && INET
|
2007-12-18 14:47:05 +08:00
|
|
|
depends on NETFILTER_ADVANCED
|
2014-09-18 17:29:03 +08:00
|
|
|
default m
|
2005-04-17 06:20:36 +08: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 15:41:21 +08:00
|
|
|
source "net/netfilter/Kconfig"
|
2005-04-17 06:20:36 +08:00
|
|
|
source "net/ipv4/netfilter/Kconfig"
|
|
|
|
source "net/ipv6/netfilter/Kconfig"
|
|
|
|
source "net/decnet/netfilter/Kconfig"
|
|
|
|
source "net/bridge/netfilter/Kconfig"
|
|
|
|
|
|
|
|
endif
|
|
|
|
|
2005-08-10 11:14:34 +08:00
|
|
|
source "net/dccp/Kconfig"
|
2005-04-17 06:20:36 +08:00
|
|
|
source "net/sctp/Kconfig"
|
2009-02-24 23:30:39 +08:00
|
|
|
source "net/rds/Kconfig"
|
2006-01-16 23:39:13 +08:00
|
|
|
source "net/tipc/Kconfig"
|
2005-07-12 12:13:56 +08:00
|
|
|
source "net/atm/Kconfig"
|
2010-04-02 14:18:33 +08:00
|
|
|
source "net/l2tp/Kconfig"
|
2008-07-06 12:25:39 +08:00
|
|
|
source "net/802/Kconfig"
|
2005-07-12 12:13:56 +08: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 21:44:02 +08:00
|
|
|
source "net/dsa/Kconfig"
|
2005-07-12 12:13:56 +08:00
|
|
|
source "net/8021q/Kconfig"
|
2005-04-17 06:20:36 +08:00
|
|
|
source "net/decnet/Kconfig"
|
|
|
|
source "net/llc/Kconfig"
|
|
|
|
source "net/ipx/Kconfig"
|
|
|
|
source "drivers/net/appletalk/Kconfig"
|
2005-07-12 12:13:56 +08:00
|
|
|
source "net/x25/Kconfig"
|
|
|
|
source "net/lapb/Kconfig"
|
2009-01-23 11:00:25 +08:00
|
|
|
source "net/phonet/Kconfig"
|
2014-07-11 16:24:18 +08:00
|
|
|
source "net/6lowpan/Kconfig"
|
2009-06-08 20:18:48 +08:00
|
|
|
source "net/ieee802154/Kconfig"
|
2012-05-16 04:50:20 +08:00
|
|
|
source "net/mac802154/Kconfig"
|
2005-04-17 06:20:36 +08:00
|
|
|
source "net/sched/Kconfig"
|
2008-11-21 12:52:10 +08:00
|
|
|
source "net/dcb/Kconfig"
|
2010-08-04 22:16:33 +08:00
|
|
|
source "net/dns_resolver/Kconfig"
|
2010-12-13 19:19:28 +08:00
|
|
|
source "net/batman-adv/Kconfig"
|
2011-10-26 10:26:31 +08: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 22:23:56 +08:00
|
|
|
source "net/vmw_vsock/Kconfig"
|
2013-03-22 00:33:48 +08:00
|
|
|
source "net/netlink/Kconfig"
|
2013-05-24 05:02:52 +08:00
|
|
|
source "net/mpls/Kconfig"
|
2013-10-31 04:10:47 +08:00
|
|
|
source "net/hsr/Kconfig"
|
2014-11-28 21:34:17 +08:00
|
|
|
source "net/switchdev/Kconfig"
|
2015-09-30 11:07:11 +08:00
|
|
|
source "net/l3mdev/Kconfig"
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2010-03-25 03:13:54 +08:00
|
|
|
config RPS
|
2014-12-21 04:41:11 +08:00
|
|
|
bool
|
2013-11-22 06:32:01 +08:00
|
|
|
depends on SMP && SYSFS
|
2010-03-25 03:13:54 +08:00
|
|
|
default y
|
|
|
|
|
2011-01-19 19:03:53 +08:00
|
|
|
config RFS_ACCEL
|
2014-12-21 04:41:11 +08:00
|
|
|
bool
|
2013-08-30 15:39:53 +08:00
|
|
|
depends on RPS
|
2011-01-19 19:03:53 +08:00
|
|
|
select CPU_RMAP
|
|
|
|
default y
|
|
|
|
|
2010-11-26 16:36:09 +08:00
|
|
|
config XPS
|
2014-12-21 04:41:11 +08:00
|
|
|
bool
|
2013-11-22 06:32:01 +08:00
|
|
|
depends on SMP
|
2010-11-26 16:36:09 +08:00
|
|
|
default y
|
|
|
|
|
2016-03-14 16:39:04 +08:00
|
|
|
config HWBM
|
|
|
|
bool
|
|
|
|
|
2015-12-08 06:38:52 +08:00
|
|
|
config SOCK_CGROUP_DATA
|
|
|
|
bool
|
|
|
|
default n
|
|
|
|
|
2013-12-30 00:27:11 +08:00
|
|
|
config CGROUP_NET_PRIO
|
2014-02-08 23:36:58 +08:00
|
|
|
bool "Network priority cgroup"
|
2011-11-22 13:10:51 +08:00
|
|
|
depends on CGROUPS
|
2015-12-08 06:38:52 +08:00
|
|
|
select SOCK_CGROUP_DATA
|
2011-11-22 13:10:51 +08:00
|
|
|
---help---
|
|
|
|
Cgroup subsystem for use in assigning processes to network priorities on
|
2013-12-30 00:27:11 +08:00
|
|
|
a per-interface basis.
|
2011-11-22 13:10:51 +08:00
|
|
|
|
2013-12-30 01:27:10 +08:00
|
|
|
config CGROUP_NET_CLASSID
|
2014-12-21 04:41:11 +08:00
|
|
|
bool "Network classid cgroup"
|
2013-12-30 01:27:10 +08:00
|
|
|
depends on CGROUPS
|
2015-12-08 06:38:52 +08:00
|
|
|
select SOCK_CGROUP_DATA
|
2013-12-30 01:27:10 +08: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-21 04:41:11 +08:00
|
|
|
bool
|
2013-06-14 21:33:46 +08:00
|
|
|
default y
|
2013-06-10 16:39:50 +08:00
|
|
|
|
2011-11-29 00:33:09 +08:00
|
|
|
config BQL
|
2014-12-21 04:41:11 +08:00
|
|
|
bool
|
2011-11-29 00:33:09 +08:00
|
|
|
depends on SYSFS
|
|
|
|
select DQL
|
|
|
|
default y
|
|
|
|
|
2011-04-20 17:27:32 +08:00
|
|
|
config BPF_JIT
|
|
|
|
bool "enable BPF Just In Time compiler"
|
|
|
|
depends on HAVE_BPF_JIT
|
2011-04-30 01:20:53 +08:00
|
|
|
depends on MODULES
|
2011-04-20 17:27:32 +08: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 12:02:32 +08:00
|
|
|
config NET_FLOW_LIMIT
|
2014-12-21 04:41:11 +08:00
|
|
|
bool
|
2013-05-20 12:02:32 +08: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-17 06:20:36 +08:00
|
|
|
menu "Network testing"
|
|
|
|
|
|
|
|
config NET_PKTGEN
|
|
|
|
tristate "Packet Generator (USE WITH CAUTION)"
|
2013-07-29 19:44:15 +08:00
|
|
|
depends on INET && PROC_FS
|
2005-04-17 06:20:36 +08: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-06 08:30:32 +08:00
|
|
|
config NET_TCPPROBE
|
|
|
|
tristate "TCP connection probing"
|
2012-10-03 02:19:40 +08:00
|
|
|
depends on INET && PROC_FS && KPROBES
|
2006-06-06 08:30:32 +08:00
|
|
|
---help---
|
|
|
|
This module allows for capturing the changes to TCP connection
|
2006-06-09 14:42:09 +08:00
|
|
|
state in response to incoming packets. It is used for debugging
|
2006-06-06 08:30:32 +08:00
|
|
|
TCP congestion avoidance modules. If you don't understand
|
|
|
|
what was just said, you don't need it: say N.
|
|
|
|
|
2006-09-26 14:47:14 +08:00
|
|
|
Documentation on how to use TCP connection probing can be found
|
2010-11-16 03:55:34 +08:00
|
|
|
at:
|
|
|
|
|
|
|
|
http://www.linuxfoundation.org/collaborate/workgroups/networking/tcpprobe
|
2006-06-06 08:30:32 +08:00
|
|
|
|
|
|
|
To compile this code as a module, choose M here: the
|
|
|
|
module will be called tcp_probe.
|
|
|
|
|
2009-03-11 17:53:16 +08:00
|
|
|
config NET_DROP_MONITOR
|
2012-05-17 18:04:00 +08:00
|
|
|
tristate "Network packet drop alerting service"
|
2012-10-03 02:19:40 +08:00
|
|
|
depends on INET && TRACEPOINTS
|
2009-03-11 17:53:16 +08: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-17 06:20:36 +08:00
|
|
|
endmenu
|
|
|
|
|
|
|
|
endmenu
|
|
|
|
|
|
|
|
source "net/ax25/Kconfig"
|
2007-11-17 07:52:17 +08:00
|
|
|
source "net/can/Kconfig"
|
2005-04-17 06:20:36 +08:00
|
|
|
source "net/irda/Kconfig"
|
|
|
|
source "net/bluetooth/Kconfig"
|
2007-04-27 06:48:28 +08:00
|
|
|
source "net/rxrpc/Kconfig"
|
2016-03-08 06:11:06 +08:00
|
|
|
source "net/kcm/Kconfig"
|
2006-01-21 07:46:55 +08:00
|
|
|
|
2006-08-04 18:38:38 +08:00
|
|
|
config FIB_RULES
|
|
|
|
bool
|
|
|
|
|
2008-07-25 00:20:09 +08:00
|
|
|
menuconfig WIRELESS
|
|
|
|
bool "Wireless"
|
2007-05-10 21:46:01 +08:00
|
|
|
depends on !S390
|
2008-07-25 00:20:09 +08:00
|
|
|
default y
|
|
|
|
|
|
|
|
if WIRELESS
|
2007-04-24 03:19:12 +08:00
|
|
|
|
|
|
|
source "net/wireless/Kconfig"
|
2007-05-06 02:45:53 +08:00
|
|
|
source "net/mac80211/Kconfig"
|
2007-04-24 03:19:12 +08:00
|
|
|
|
2008-07-25 00:20:09 +08:00
|
|
|
endif # WIRELESS
|
2007-04-24 03:19:12 +08:00
|
|
|
|
2008-12-24 08:18:24 +08:00
|
|
|
source "net/wimax/Kconfig"
|
|
|
|
|
2007-05-07 15:34:20 +08:00
|
|
|
source "net/rfkill/Kconfig"
|
2007-07-11 06:57:28 +08:00
|
|
|
source "net/9p/Kconfig"
|
2010-03-30 21:56:28 +08:00
|
|
|
source "net/caif/Kconfig"
|
2010-04-07 06:14:15 +08:00
|
|
|
source "net/ceph/Kconfig"
|
2011-07-02 06:31:33 +08:00
|
|
|
source "net/nfc/Kconfig"
|
2010-03-30 21:56:28 +08:00
|
|
|
|
2015-07-21 16:43:46 +08: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 15:34:20 +08:00
|
|
|
|
2016-02-12 22:43:53 +08:00
|
|
|
config DST_CACHE
|
|
|
|
bool "dst cache"
|
|
|
|
default n
|
|
|
|
|
2016-02-27 00:32:23 +08: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 17:40:54 +08: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-12 12:13:56 +08:00
|
|
|
endif # if NET
|
2012-05-22 02:45:37 +08:00
|
|
|
|
|
|
|
# Used by archs to tell that they support BPF_JIT
|
|
|
|
config HAVE_BPF_JIT
|
|
|
|
bool
|