mirror of https://gitee.com/openkylin/linux.git
384 lines
15 KiB
ReStructuredText
384 lines
15 KiB
ReStructuredText
.. SPDX-License-Identifier: GPL-2.0+
|
|
|
|
=====================================================
|
|
Linux Driver for Intel(R) Ethernet Network Connection
|
|
=====================================================
|
|
|
|
Intel Gigabit Linux driver.
|
|
Copyright(c) 2008-2018 Intel Corporation.
|
|
|
|
Contents
|
|
========
|
|
|
|
- Identifying Your Adapter
|
|
- Command Line Parameters
|
|
- Additional Configurations
|
|
- Support
|
|
|
|
|
|
Identifying Your Adapter
|
|
========================
|
|
For information on how to identify your adapter, and for the latest Intel
|
|
network drivers, refer to the Intel Support website:
|
|
https://www.intel.com/support
|
|
|
|
|
|
Command Line Parameters
|
|
=======================
|
|
If the driver is built as a module, the following optional parameters are used
|
|
by entering them on the command line with the modprobe command using this
|
|
syntax::
|
|
|
|
modprobe e1000e [<option>=<VAL1>,<VAL2>,...]
|
|
|
|
There needs to be a <VAL#> for each network port in the system supported by
|
|
this driver. The values will be applied to each instance, in function order.
|
|
For example::
|
|
|
|
modprobe e1000e InterruptThrottleRate=16000,16000
|
|
|
|
In this case, there are two network ports supported by e1000e in the system.
|
|
The default value for each parameter is generally the recommended setting,
|
|
unless otherwise noted.
|
|
|
|
NOTE: A descriptor describes a data buffer and attributes related to the data
|
|
buffer. This information is accessed by the hardware.
|
|
|
|
InterruptThrottleRate
|
|
---------------------
|
|
:Valid Range: 0,1,3,4,100-100000
|
|
:Default Value: 3
|
|
|
|
Interrupt Throttle Rate controls the number of interrupts each interrupt
|
|
vector can generate per second. Increasing ITR lowers latency at the cost of
|
|
increased CPU utilization, though it may help throughput in some circumstances.
|
|
|
|
Setting InterruptThrottleRate to a value greater or equal to 100
|
|
will program the adapter to send out a maximum of that many interrupts
|
|
per second, even if more packets have come in. This reduces interrupt
|
|
load on the system and can lower CPU utilization under heavy load,
|
|
but will increase latency as packets are not processed as quickly.
|
|
|
|
The default behaviour of the driver previously assumed a static
|
|
InterruptThrottleRate value of 8000, providing a good fallback value for
|
|
all traffic types, but lacking in small packet performance and latency.
|
|
The hardware can handle many more small packets per second however, and
|
|
for this reason an adaptive interrupt moderation algorithm was implemented.
|
|
|
|
The driver has two adaptive modes (setting 1 or 3) in which
|
|
it dynamically adjusts the InterruptThrottleRate value based on the traffic
|
|
that it receives. After determining the type of incoming traffic in the last
|
|
timeframe, it will adjust the InterruptThrottleRate to an appropriate value
|
|
for that traffic.
|
|
|
|
The algorithm classifies the incoming traffic every interval into
|
|
classes. Once the class is determined, the InterruptThrottleRate value is
|
|
adjusted to suit that traffic type the best. There are three classes defined:
|
|
"Bulk traffic", for large amounts of packets of normal size; "Low latency",
|
|
for small amounts of traffic and/or a significant percentage of small
|
|
packets; and "Lowest latency", for almost completely small packets or
|
|
minimal traffic.
|
|
|
|
- 0: Off
|
|
Turns off any interrupt moderation and may improve small packet latency.
|
|
However, this is generally not suitable for bulk throughput traffic due
|
|
to the increased CPU utilization of the higher interrupt rate.
|
|
- 1: Dynamic mode
|
|
This mode attempts to moderate interrupts per vector while maintaining
|
|
very low latency. This can sometimes cause extra CPU utilization. If
|
|
planning on deploying e1000e in a latency sensitive environment, this
|
|
parameter should be considered.
|
|
- 3: Dynamic Conservative mode (default)
|
|
In dynamic conservative mode, the InterruptThrottleRate value is set to
|
|
4000 for traffic that falls in class "Bulk traffic". If traffic falls in
|
|
the "Low latency" or "Lowest latency" class, the InterruptThrottleRate is
|
|
increased stepwise to 20000. This default mode is suitable for most
|
|
applications.
|
|
- 4: Simplified Balancing mode
|
|
In simplified mode the interrupt rate is based on the ratio of TX and
|
|
RX traffic. If the bytes per second rate is approximately equal, the
|
|
interrupt rate will drop as low as 2000 interrupts per second. If the
|
|
traffic is mostly transmit or mostly receive, the interrupt rate could
|
|
be as high as 8000.
|
|
- 100-100000:
|
|
Setting InterruptThrottleRate to a value greater or equal to 100
|
|
will program the adapter to send at most that many interrupts per second,
|
|
even if more packets have come in. This reduces interrupt load on the
|
|
system and can lower CPU utilization under heavy load, but will increase
|
|
latency as packets are not processed as quickly.
|
|
|
|
NOTE: InterruptThrottleRate takes precedence over the TxAbsIntDelay and
|
|
RxAbsIntDelay parameters. In other words, minimizing the receive and/or
|
|
transmit absolute delays does not force the controller to generate more
|
|
interrupts than what the Interrupt Throttle Rate allows.
|
|
|
|
RxIntDelay
|
|
----------
|
|
:Valid Range: 0-65535 (0=off)
|
|
:Default Value: 0
|
|
|
|
This value delays the generation of receive interrupts in units of 1.024
|
|
microseconds. Receive interrupt reduction can improve CPU efficiency if
|
|
properly tuned for specific network traffic. Increasing this value adds extra
|
|
latency to frame reception and can end up decreasing the throughput of TCP
|
|
traffic. If the system is reporting dropped receives, this value may be set
|
|
too high, causing the driver to run out of available receive descriptors.
|
|
|
|
CAUTION: When setting RxIntDelay to a value other than 0, adapters may hang
|
|
(stop transmitting) under certain network conditions. If this occurs a NETDEV
|
|
WATCHDOG message is logged in the system event log. In addition, the
|
|
controller is automatically reset, restoring the network connection. To
|
|
eliminate the potential for the hang ensure that RxIntDelay is set to 0.
|
|
|
|
RxAbsIntDelay
|
|
-------------
|
|
:Valid Range: 0-65535 (0=off)
|
|
:Default Value: 8
|
|
|
|
This value, in units of 1.024 microseconds, limits the delay in which a
|
|
receive interrupt is generated. This value ensures that an interrupt is
|
|
generated after the initial packet is received within the set amount of time,
|
|
which is useful only if RxIntDelay is non-zero. Proper tuning, along with
|
|
RxIntDelay, may improve traffic throughput in specific network conditions.
|
|
|
|
TxIntDelay
|
|
----------
|
|
:Valid Range: 0-65535 (0=off)
|
|
:Default Value: 8
|
|
|
|
This value delays the generation of transmit interrupts in units of 1.024
|
|
microseconds. Transmit interrupt reduction can improve CPU efficiency if
|
|
properly tuned for specific network traffic. If the system is reporting
|
|
dropped transmits, this value may be set too high causing the driver to run
|
|
out of available transmit descriptors.
|
|
|
|
TxAbsIntDelay
|
|
-------------
|
|
:Valid Range: 0-65535 (0=off)
|
|
:Default Value: 32
|
|
|
|
This value, in units of 1.024 microseconds, limits the delay in which a
|
|
transmit interrupt is generated. It is useful only if TxIntDelay is non-zero.
|
|
It ensures that an interrupt is generated after the initial Packet is sent on
|
|
the wire within the set amount of time. Proper tuning, along with TxIntDelay,
|
|
may improve traffic throughput in specific network conditions.
|
|
|
|
copybreak
|
|
---------
|
|
:Valid Range: 0-xxxxxxx (0=off)
|
|
:Default Value: 256
|
|
|
|
The driver copies all packets below or equaling this size to a fresh receive
|
|
buffer before handing it up the stack.
|
|
This parameter differs from other parameters because it is a single (not 1,1,1
|
|
etc.) parameter applied to all driver instances and it is also available
|
|
during runtime at /sys/module/e1000e/parameters/copybreak.
|
|
|
|
To use copybreak, type::
|
|
|
|
modprobe e1000e.ko copybreak=128
|
|
|
|
SmartPowerDownEnable
|
|
--------------------
|
|
:Valid Range: 0,1
|
|
:Default Value: 0 (disabled)
|
|
|
|
Allows the PHY to turn off in lower power states. The user can turn off this
|
|
parameter in supported chipsets.
|
|
|
|
KumeranLockLoss
|
|
---------------
|
|
:Valid Range: 0,1
|
|
:Default Value: 1 (enabled)
|
|
|
|
This workaround skips resetting the PHY at shutdown for the initial silicon
|
|
releases of ICH8 systems.
|
|
|
|
IntMode
|
|
-------
|
|
:Valid Range: 0-2
|
|
:Default Value: 0
|
|
|
|
+-------+----------------+
|
|
| Value | Interrupt Mode |
|
|
+=======+================+
|
|
| 0 | Legacy |
|
|
+-------+----------------+
|
|
| 1 | MSI |
|
|
+-------+----------------+
|
|
| 2 | MSI-X |
|
|
+-------+----------------+
|
|
|
|
IntMode allows load time control over the type of interrupt registered for by
|
|
the driver. MSI-X is required for multiple queue support, and some kernels and
|
|
combinations of kernel .config options will force a lower level of interrupt
|
|
support.
|
|
|
|
This command will show different values for each type of interrupt::
|
|
|
|
cat /proc/interrupts
|
|
|
|
CrcStripping
|
|
------------
|
|
:Valid Range: 0,1
|
|
:Default Value: 1 (enabled)
|
|
|
|
Strip the CRC from received packets before sending up the network stack. If
|
|
you have a machine with a BMC enabled but cannot receive IPMI traffic after
|
|
loading or enabling the driver, try disabling this feature.
|
|
|
|
WriteProtectNVM
|
|
---------------
|
|
:Valid Range: 0,1
|
|
:Default Value: 1 (enabled)
|
|
|
|
If set to 1, configure the hardware to ignore all write/erase cycles to the
|
|
GbE region in the ICHx NVM (in order to prevent accidental corruption of the
|
|
NVM). This feature can be disabled by setting the parameter to 0 during initial
|
|
driver load.
|
|
|
|
NOTE: The machine must be power cycled (full off/on) when enabling NVM writes
|
|
via setting the parameter to zero. Once the NVM has been locked (via the
|
|
parameter at 1 when the driver loads) it cannot be unlocked except via power
|
|
cycle.
|
|
|
|
Debug
|
|
-----
|
|
:Valid Range: 0-16 (0=none,...,16=all)
|
|
:Default Value: 0
|
|
|
|
This parameter adjusts the level of debug messages displayed in the system logs.
|
|
|
|
|
|
Additional Features and Configurations
|
|
======================================
|
|
|
|
Jumbo Frames
|
|
------------
|
|
Jumbo Frames support is enabled by changing the Maximum Transmission Unit (MTU)
|
|
to a value larger than the default value of 1500.
|
|
|
|
Use the ifconfig command to increase the MTU size. For example, enter the
|
|
following where <x> is the interface number::
|
|
|
|
ifconfig eth<x> mtu 9000 up
|
|
|
|
Alternatively, you can use the ip command as follows::
|
|
|
|
ip link set mtu 9000 dev eth<x>
|
|
ip link set up dev eth<x>
|
|
|
|
This setting is not saved across reboots. The setting change can be made
|
|
permanent by adding 'MTU=9000' to the file:
|
|
|
|
- For RHEL: /etc/sysconfig/network-scripts/ifcfg-eth<x>
|
|
- For SLES: /etc/sysconfig/network/<config_file>
|
|
|
|
NOTE: The maximum MTU setting for Jumbo Frames is 8996. This value coincides
|
|
with the maximum Jumbo Frames size of 9018 bytes.
|
|
|
|
NOTE: Using Jumbo frames at 10 or 100 Mbps is not supported and may result in
|
|
poor performance or loss of link.
|
|
|
|
NOTE: The following adapters limit Jumbo Frames sized packets to a maximum of
|
|
4088 bytes:
|
|
|
|
- Intel(R) 82578DM Gigabit Network Connection
|
|
- Intel(R) 82577LM Gigabit Network Connection
|
|
|
|
The following adapters do not support Jumbo Frames:
|
|
|
|
- Intel(R) PRO/1000 Gigabit Server Adapter
|
|
- Intel(R) PRO/1000 PM Network Connection
|
|
- Intel(R) 82562G 10/100 Network Connection
|
|
- Intel(R) 82562G-2 10/100 Network Connection
|
|
- Intel(R) 82562GT 10/100 Network Connection
|
|
- Intel(R) 82562GT-2 10/100 Network Connection
|
|
- Intel(R) 82562V 10/100 Network Connection
|
|
- Intel(R) 82562V-2 10/100 Network Connection
|
|
- Intel(R) 82566DC Gigabit Network Connection
|
|
- Intel(R) 82566DC-2 Gigabit Network Connection
|
|
- Intel(R) 82566DM Gigabit Network Connection
|
|
- Intel(R) 82566MC Gigabit Network Connection
|
|
- Intel(R) 82566MM Gigabit Network Connection
|
|
- Intel(R) 82567V-3 Gigabit Network Connection
|
|
- Intel(R) 82577LC Gigabit Network Connection
|
|
- Intel(R) 82578DC Gigabit Network Connection
|
|
|
|
NOTE: Jumbo Frames cannot be configured on an 82579-based Network device if
|
|
MACSec is enabled on the system.
|
|
|
|
|
|
ethtool
|
|
-------
|
|
The driver utilizes the ethtool interface for driver configuration and
|
|
diagnostics, as well as displaying statistical information. The latest ethtool
|
|
version is required for this functionality. Download it at:
|
|
|
|
https://www.kernel.org/pub/software/network/ethtool/
|
|
|
|
NOTE: When validating enable/disable tests on some parts (for example, 82578),
|
|
it is necessary to add a few seconds between tests when working with ethtool.
|
|
|
|
|
|
Speed and Duplex Configuration
|
|
------------------------------
|
|
In addressing speed and duplex configuration issues, you need to distinguish
|
|
between copper-based adapters and fiber-based adapters.
|
|
|
|
In the default mode, an Intel(R) Ethernet Network Adapter using copper
|
|
connections will attempt to auto-negotiate with its link partner to determine
|
|
the best setting. If the adapter cannot establish link with the link partner
|
|
using auto-negotiation, you may need to manually configure the adapter and link
|
|
partner to identical settings to establish link and pass packets. This should
|
|
only be needed when attempting to link with an older switch that does not
|
|
support auto-negotiation or one that has been forced to a specific speed or
|
|
duplex mode. Your link partner must match the setting you choose. 1 Gbps speeds
|
|
and higher cannot be forced. Use the autonegotiation advertising setting to
|
|
manually set devices for 1 Gbps and higher.
|
|
|
|
Speed, duplex, and autonegotiation advertising are configured through the
|
|
ethtool utility.
|
|
|
|
Caution: Only experienced network administrators should force speed and duplex
|
|
or change autonegotiation advertising manually. The settings at the switch must
|
|
always match the adapter settings. Adapter performance may suffer or your
|
|
adapter may not operate if you configure the adapter differently from your
|
|
switch.
|
|
|
|
An Intel(R) Ethernet Network Adapter using fiber-based connections, however,
|
|
will not attempt to auto-negotiate with its link partner since those adapters
|
|
operate only in full duplex and only at their native speed.
|
|
|
|
|
|
Enabling Wake on LAN (WoL)
|
|
--------------------------
|
|
WoL is configured through the ethtool utility.
|
|
|
|
WoL will be enabled on the system during the next shut down or reboot. For
|
|
this driver version, in order to enable WoL, the e1000e driver must be loaded
|
|
prior to shutting down or suspending the system.
|
|
|
|
NOTE: Wake on LAN is only supported on port A for the following devices:
|
|
- Intel(R) PRO/1000 PT Dual Port Network Connection
|
|
- Intel(R) PRO/1000 PT Dual Port Server Connection
|
|
- Intel(R) PRO/1000 PT Dual Port Server Adapter
|
|
- Intel(R) PRO/1000 PF Dual Port Server Adapter
|
|
- Intel(R) PRO/1000 PT Quad Port Server Adapter
|
|
- Intel(R) Gigabit PT Quad Port Server ExpressModule
|
|
|
|
|
|
Support
|
|
=======
|
|
For general information, go to the Intel support website at:
|
|
|
|
https://www.intel.com/support/
|
|
|
|
or the Intel Wired Networking project hosted by Sourceforge at:
|
|
|
|
https://sourceforge.net/projects/e1000
|
|
|
|
If an issue is identified with the released source code on a supported kernel
|
|
with a supported adapter, email the specific information related to the issue
|
|
to e1000-devel@lists.sf.net.
|