Provided by: freebsd-manpages_12.2-1_all bug

NAME

       ixl — Intel Ethernet 700 Series Driver

SYNOPSIS

       To compile this driver into the kernel, place the following lines in your kernel configuration file:

             device iflib
             device ixl

       To load the driver as a module at boot time, place the following lines in loader.conf(5):

             if_ixl_load="YES"

DESCRIPTION

   Features
       The  ixl  driver  provides  support  for any PCI Express adapter or LOM (LAN On Motherboard) in the Intel
       Ethernet 700 Series.  As of this writing, the series includes devices with these model numbers:

          XL710 (40G)
          X710 (10G)
          XXV710 (25G)
          X722 (10G)

       The driver supports Jumbo Frames, TX/RX checksum offload, TCP segmentation offload (TSO),  Large  Receive
       Offload  (LRO), VLAN tag insertion/extraction, VLAN checksum offload, VLAN TSO, and Receive Side Steering
       (RSS), all for both IPv4 and IPv6.  For further hardware information and questions  related  to  hardware
       requirements, see http://support.intel.com/.

       Support  for  Jumbo  Frames is provided via the interface MTU setting.  Selecting an MTU larger than 1500
       bytes with the ifconfig(8) utility configures the adapter to receive  and  transmit  Jumbo  Frames.   The
       maximum MTU size for Jumbo Frames is 9706.

       Offloads  are also controlled via the interface, for instance, checksumming for both IPv4 and IPv6 can be
       set and unset, TSO4 and/or TSO6, and finally LRO can be set and unset.

       For more information on configuring this device, see ifconfig(8).

   Additional Utilities
       There are additional tools available from Intel to help configure and update the adapters covered by this
       driver.  These tools can be  downloaded  directly  from  Intel  at  https://downloadcenter.intel.com,  by
       searching for their names, or by installing certain packages:

          To  change  the behavior of the QSFP+ ports on XL710 adapters, use the Intel QCU (QSFP+ configuration
           utility); installed by the sysutils/intel-qcu package.

          To update the firmware on an adapter,  use  the  Intel  Non-Volatile  Memory  (NVM)  Update  Utility;
           installed by the sysutils/intel-nvmupdate package.

          Drivers  are  provided by Intel outside of the FreeBSD kernel; install the net/intel-ixl-kmod package
           for the latest driver.

HARDWARE

       Most adapters in the Intel Ethernet 700 Series with SFP+/SFP28/QSFP+ cages have  firmware  that  requires
       that  Intel  qualified  modules  are  used; these qualified modules are listed below.  This qualification
       check cannot be disabled by the driver.

       The ixl driver supports 40Gb Ethernet adapters with these QSFP+ modules:

          Intel 4x10G/40G QSFP+ 40GBASE-SR4 E40GQSFPSR
          Intel 4x10G/40G QSFP+ 40GBASE-LR4 E40GQSFPLR

       The ixl driver supports 25Gb Ethernet adapters with these SFP28 modules:

          Intel 10G/25G SFP28 25GBASE-SR E25GSFP28SR
          Intel 10G/25G SFP28 25GBASE-SR E25GSFP28SRX (Extended Temp)

       The ixl driver supports 25Gb and 10Gb Ethernet adapters with these SFP+ modules:

          Intel 1G/10G SFP+ SR FTLX8571D3BCV-IT
          Intel 1G/10G SFP+ SR AFBR-703SDZ-IN2
          Intel 1G/10G SFP+ LR FTLX1471D3BCV-IT
          Intel 1G/10G SFP+ LR AFCT-701SDZ-IN2
          Intel 1G/10G SFP+ 10GBASE-SR E10GSFPSR
          Intel 10G SFP+ 10GBASE-SR E10GSFPSRX (Extended Temp)
          Intel 1G/10G SFP+ 10GBASE-LR E10GSFPLR

       Note that adapters also support all passive and active limiting direct attach  cables  that  comply  with
       SFF-8431 v4.1 and SFF-8472 v10.4 specifications.

       This  is not an exhaustive list; please consult product documentation for an up-to-date list of supported
       media.

LOADER TUNABLES

       Tunables can be set at the loader(8) prompt before booting the kernel or stored in loader.conf(5).

       hw.ixl.rx_itr
               The RX interrupt rate value, set to 62 (124 usec) by default.

       hw.ixl.tx_itr
               The TX interrupt rate value, set to 122 (244 usec) by default.

       hw.ixl.i2c_access_method
               Access method that driver will use for I2C read and writes via sysctl(8) or  verbose  ifconfig(8)
               information display:

                     0 - best available method
                     1 - bit bang via I2CPARAMS register
                     2 - register read/write via I2CCMD register
                     3 - Use Admin Queue command (default best)

               Using the Admin Queue is only supported on 710 devices with FW version 1.7 or newer.  Set to 0 by
               default.

       hw.ixl.enable_tx_fc_filter
               Filter  out  packets  with  Ethertype  0x8808  from  being sent out by non-adapter sources.  This
               prevents (potentially untrusted) software or  iavf(4)  devices  from  sending  out  flow  control
               packets and creating a DoS (Denial of Service) event.  Enabled by default.

       hw.ixl.enable_head_writeback
               When  the driver is finding the last TX descriptor processed by the hardware, use a value written
               to memory by the hardware instead of scanning the  descriptor  ring  for  completed  descriptors.
               Enabled by default; disable to mimic the TX behavior found in ixgbe(4).

SYSCTL PROCEDURES

       dev.ixl.#.fc
               Sets  the  802.3x  flow  control  mode that the adapter will advertise on the link.  A value of 0
               disables flow control, 3 enables full, 1 is RX, and 2 is TX pause.

               The negotiated flow control setting can be viewed in ifconfig(8), in the interface's media field.

       dev.ixl.#.advertise_speed
               Set the speeds that  the  interface  will  advertise  on  the  link.   dev.ixl.#.supported_speeds
               contains the speeds that are allowed to be set.

       dev.ixl.#.current_speed
               Displays the current speed.

       dev.ixl.#.fw_version
               Displays the current firmware and NVM versions of the adapter.

INTERRUPT STORMS

       It  is  important  to  note that 40G operation can generate high numbers of interrupts, often incorrectly
       being interpreted as a storm condition in the kernel.  It is suggested that this be resolved by setting:

       hw.intr_storm_threshold: 0

IOVCTL OPTIONS

       The driver supports additional optional  parameters  for  created  VFs  (Virtual  Functions)  when  using
       iovctl(8):

       mac-addr (unicast-mac)
               Set  the  Ethernet  MAC address that the VF will use.  If unspecified, the VF will use a randomly
               generated MAC address.

       mac-anti-spoof (bool)
               Prevent the VF from sending Ethernet frames with a source address that does not match its own.

       allow-set-mac (bool)
               Allow the VF to set its own Ethernet MAC address

       allow-promisc (bool)
               Allow the VF to inspect all of the traffic sent to the port.

       num-queues (uint16_t)
               Specify the number of queues the VF will have.  By default, this is set to the  number  of  MSI-X
               vectors supported by the VF minus one.

       An up to date list of parameters and their defaults can be found by using iovctl(8) with the -S option.

SUPPORT

       For general information and support, go to the Intel support website at: http://support.intel.com/.

       If  an  issue is identified with this driver with a supported adapter, email all the specific information
       related to the issue to freebsd@intel.com.

SEE ALSO

       arp(4), iavf(4), iflib(4), netintro(4), vlan(4), ifconfig(8), iovctl(8), iflib(9)

HISTORY

       The ixl device driver first appeared in FreeBSD 10.1.  It was converted to use iflib(9) in FreeBSD 12.

AUTHORS

       The ixl driver was written by Jack Vogel <jfv@freebsd.org> and Eric Joyner <erj@freebsd.org>.

Debian                                            June 27, 2020                                           IXL(4)