Dell Emulex Family of Adapters User guide

  • Hello! I am an AI chatbot trained to assist you with the Dell Emulex Family of Adapters User guide. I’ve already reviewed the document and can help you find the information you need or explain it in simple terms. Just ask your questions, and providing more details will help me assist you more effectively!
Broadcom DRVLin-UG128-100
October 26, 2020
Emulex
®
Drivers for Linux
User Guide
Release 12.8
Broadcom, the pulse logo, Connecting everything, Avago Technologies, Avago, the A logo, Brocade, Emulex, ExpressLane,
LightPulse, and OneCommand are among the trademarks of Broadcom and/or its affiliates in the United States, certain other
countries, and/or the EU.
Copyright © 2003–2020 Broadcom. All Rights Reserved.
The term “Broadcom” refers to Broadcom Inc. and/or its subsidiaries. For more information, please visit www.broadcom.com.
Broadcom reserves the right to make changes without further notice to any products or data herein to improve reliability,
function, or design. Information furnished by Broadcom is believed to be accurate and reliable. However, Broadcom does
not assume any liability arising out of the application or use of this information, nor the application or use of any product or
circuit described herein, neither does it convey any license under its patent rights nor the rights of others.
Broadcom DRVLin-UG128-100
3
Emulex Drivers for Linux User Guide
Table of Contents
Chapter 1: Introduction ......................................................................................................................5
1.1 Overview ....................................................................................................................................................................5
1.2 Abbreviations ............................................................................................................................................................5
Chapter 2: Installing and Uninstalling .............................................................................................. 7
2.1 General Installation Requirements..........................................................................................................................7
2.2 Emulex FC Driver Kit ................................................................................................................................................8
2.2.1 Installing the Emulex FC Driver Kit ...................................................................................................................8
2.2.2 Uninstalling the Emulex FC Driver Kit...............................................................................................................9
2.3 Booting from a Nonzero LUN Attached to an Emulex FC Adapter.......................................................................9
2.4 Emulex HBA Manager Application ..........................................................................................................................9
2.5 Updating the Firmware.............................................................................................................................................9
2.6 Installing the NVMe over FC Driver .......................................................................................................................11
2.6.1 Installing the NVMe over FC Driver on SLES Operating Systems..................................................................11
2.6.2 Installing the NVMe over FC Driver on RHEL Operating Systems .................................................................11
Chapter 3: Configuration ................................................................................................................. 12
3.1 FC Driver Configuration .........................................................................................................................................12
3.1.1 FC Driver Parameters.....................................................................................................................................12
3.1.1.1 Static FC Driver Parameters.................................................................................................................12
3.1.1.2 Dynamic FC Driver Parameters............................................................................................................16
3.1.2 Configuring FC Driver Parameters..................................................................................................................20
3.1.2.1 Temporary Configuration with the modprobe Command......................................................................20
3.1.2.2 Persistent Configuration with the elx-lpfc.conf File...............................................................................20
3.1.2.3 Configuring Parameters with the sysfs Command................................................................................21
3.1.3 Creating a New Ramdisk Image .....................................................................................................................22
3.1.4 Dynamically Recognizing LUNs and Targets (Using Scan)............................................................................22
3.1.5 Persistent Naming...........................................................................................................................................22
3.1.5.1 Using udev to Discover Logical-to-Physical Mappings for sd Devices .................................................22
3.1.5.2 Configuring the System to Boot Using Persistent Names ....................................................................23
3.1.5.3 Using udev with st Devices...................................................................................................................24
3.1.5.4 Persistent Naming References.............................................................................................................25
3.1.6 ExpressLane Support .....................................................................................................................................26
3.2 vPort Configuration ................................................................................................................................................26
3.2.1 vPort Configuration Prerequisites ...................................................................................................................26
3.2.2 Creating, Deleting, and Displaying vPorts ......................................................................................................26
3.2.2.1 Creating vPorts Using the mkvport.sh Script........................................................................................27
3.2.2.2 Deleting vPorts Using the rmvport.sh Script.........................................................................................27
3.2.2.3 Displaying vPorts Using the lsvport.sh Script .......................................................................................27
Broadcom DRVLin-UG128-100
4
Emulex Drivers for Linux User Guide
3.2.3 vPort sysfs ......................................................................................................................................................28
3.2.3.1 vPort sysfs Tree....................................................................................................................................28
3.2.3.2 vPort sysfs Entries................................................................................................................................28
3.2.4 Monitoring vPorts with fc_vport.......................................................................................................................31
3.2.5 vPort Configuration Limits...............................................................................................................................31
3.3 FC Driver Performance Tuning..............................................................................................................................32
3.3.1 Overview.........................................................................................................................................................32
3.3.1.1 lpfc_hdw_queue....................................................................................................................................32
3.3.1.2 lpfc_irq_chann ......................................................................................................................................33
Chapter 4: Configuring NVMe over FC ........................................................................................... 34
4.1 Configuring an NVMe over FC Initiator Using Native CLI Commands...............................................................34
4.2 Emulex Support for NVMe CLI Commands ..........................................................................................................37
Chapter 5: Troubleshooting .............................................................................................................38
5.1 Hardware Situations and Resolutions ..................................................................................................................38
5.2 FC Driver Situations and Resolutions...................................................................................................................38
5.3 Dynamic Firmware Logging...................................................................................................................................40
5.4 FC Driver Log Messages ........................................................................................................................................41
5.4.1 Retrieving FC Driver Log Messages...............................................................................................................41
5.4.2 FC Error Log Messages and Their Descriptions.............................................................................................42
Appendix A: FCP Driver BlockGuard Functionality.................................................................... 102
A.1 Overview ...............................................................................................................................................................102
A.2 Enabling BlockGuard ..........................................................................................................................................103
A.3 SCSI Command Support – SCSI Operation Codes ..........................................................................................103
A.4 FCP Driver Module Parameters ..........................................................................................................................104
A.4.1 lpfc_prot_mask ............................................................................................................................................105
A.4.2 lpfc_prot_guard ............................................................................................................................................105
Appendix B: Configuring NVMe over FC on a Target ................................................................. 106
B.1 Configuring the elx-lpfc.conf File ......................................................................................................................106
B.2 Configuring Subsystems, Namespaces, and Ports .........................................................................................107
Appendix C: Native NVMe Multipathing ....................................................................................... 111
Appendix D: Trunking Support ..................................................................................................... 118
Appendix E: FC-SP-2 Authentication (DH-CHAP) Support......................................................... 120
Appendix F: ARM Support............................................................................................................. 121
Broadcom DRVLin-UG128-100
5
Emulex Drivers for Linux User Guide
Chapter 1: Introduction
1.1 Overview
This guide provides procedures for installing, updating, uninstalling, configuring, and troubleshooting several types of drivers
for Linux that are supported by Emulex
®
.
This guide is applicable to several versions of drivers, operating systems, firmware, and adapters. For supported firmware
versions and their latest release, go to www.broadcom.com.
This product supports the following Emulex FC HBAs:
LPe12000-series adapters
LPe16000-series adapters
LPe31000-series adapters
LPe32000-series adapters
LPe35000-series adapters
For a list of Emulex adapters that are compatible with the stand-alone driver kits, go to www.broadcom.com.
Fabric Notifications are a new T11 standard. Version 12.8 Linux drivers introduce Emulex support for Fabric Notifications,
which include FPINs and signaling. For additional information, refer to the Brocade switch documentation.
1.2 Abbreviations
The following table lists the acronyms and abbreviations used in this document.
Table 1: Acronyms and Abbreviations
Acronym/Abbreviation Description
ADISC address discovery
ANA asymmetric namespace access
CDB Command Descriptor Block
CQ completion queue
CQE control queue entry
CQID completion queue identifier
CT common transport
DIF data integrity field
DM Device Mapper
ELS Extended Link Service
EQ event queue
EQE event queue entry
FAN File Area Network
FCFI Fibre Channel Forwarder Indicator
FCP Fibre Channel Protocol
FDMI Fabric-Device Management Interface
FLOGI fabric login
Broadcom DRVLin-UG128-100
6
Emulex Drivers for Linux User Guide
FPIN Fabric Performance Impact Notification
GnuPG GNU Privacy Guard
I/O input/output
IOCB input/output control block
IOCBQ input/output control block queue
IOPS input/output operations per second
IOTAG input/output tag
ISR interrupt service routine
LBA logical block address
LPFC
LightPulse
®
Fibre Channel
MQ mailbox queue
MSI message signaled interrupt
MSI-X extended message signaled interrupt
NAA Network Address Authority
NPIV N_Port ID Virtualization
PLOGI port login
RPI remote port indicator
RPM Red Hat package manager
RQ receive queue
RSCN registered state change notification
SGE scatter-gather element
SGL scatter-gather list
ULP upper layer protocol
VPI virtual path identifier
WQ work queue
WQE work queue entry
Table 1: Acronyms and Abbreviations (Continued)
Acronym/Abbreviation Description
Broadcom DRVLin-UG128-100
7
Emulex Drivers for Linux User Guide
Chapter 2: Installing and Uninstalling
The Linux driver supports both FCP and NVMe over FC.
Emulex releases Linux binary RPMs that are digitally signed using the GnuPG standard. This allows certification of the
contents of the RPMs and verification that the contents have not been modified since they were created by Emulex. The
RPMs have been digitally signed by Emulex with a GnuPG private key that is held only by Emulex. Instructions for creating
the GnuPG public key file are located at:
https://docs.broadcom.com/docs/1334566
2.1 General Installation Requirements
NOTE: Update the latest driver on the operating system before updating the firmware.
Prior to driver installation, follow these general requirements:
Install a supported Emulex adapter in the system. Refer to the adapter's installation guide for specific hardware
installation instructions.
Use a supported operating system. Refer to www.broadcom.com for supported operating systems.
Install the latest driver.
Update to the latest firmware on the adapter.
NOTE: For LPe31000-series, LPe32000-series, and LPe35000-series adapters only:
In some cases, a firmware update requires either a firmware reset or a basic PCIe reset, depending on the features
available in the new firmware. A firmware reset is performed automatically if it is needed, regardless of the
operating system. A basic PCIe reset is also performed automatically, but only on the following Linux operating
systems:
SLES 12 SP4 and later
SLES 15 and later
RHEL 7.6 and later
RHEL 8.0 and later
In some cases, a full reboot is required to activate new firmware or to enable a new feature. In that case, a message
similar to one of the following appears after the firmware download is complete:
Download successfully completed. Please reboot the system to activate new firmware.
Download completed. Some features require an optional reboot. Refer to the Adapter's
Firmware and Boot Code Release Notes for details.
For a list of features that require a reboot to be enabled, refer to the adapter's firmware and boot code release
notes.
Broadcom DRVLin-UG128-100
8
Emulex Drivers for Linux User Guide
2.2 Emulex FC Driver Kit
The Emulex FC driver kit contains the following items:
A zipped tar file that includes the driver binary RPMs for a specific driver version and Linux distribution. On select driver
kits, the zipped tar file might also include any of the following RPMs:
nvmefc-connect RPM
elx-lpfc-extras RPM
NOTE: Use only officially released Linux distribution kernels. The binary RPM packages support only officially
released Linux distribution kernels and do not support prerelease distribution kernels. Refer to the Emulex
Drivers for Linux Release Notes for details of kernel versions that are supported by the driver.
An installation script, elx_lpfc_install.sh, that installs the FC driver binary RPM that corresponds to the target
system's architecture and kernel memory variant.
A README file that provides a description of the kit structure, its contents, and distribution support scope.
2.2.1 Installing the Emulex FC Driver Kit
NOTE: Installing a newer version of the FC driver kit automatically removes any previous versions of the FC driver kit.
After the operating system is installed, perform the following steps to install the Emulex FC driver:
1. Download the driver kit from www.broadcom.com for one of the following operating systems:
RHEL 8.0 and later
RHEL 7.6 and later
SLES 15 and later
SLES 12 SP4 and later
2. Log in to a terminal as root.
3. Untar the driver kit by typing the following command:
tar -zxvf elx-lpfc-dd-<Linux_distribution_version>-<driver_version>-ds-n.tar.gz
4. Change to the directory into which the driver kit was extracted by typing the following command:
cd elx-lpfc-dd-<Linux_distribution_version>-<driver_version>-ds/
To install only the Emulex FC driver kit:
Run the elx_lpfc_install.sh script without options to install the driver kit:
./elx_lpfc_install.sh
After the elx_lpfc_install.sh script has finished running successfully, the Emulex FC driver is loaded, and
devices that are connected to the system are accessible.
To install the Emulex FC driver kit with NVMe:
NOTE: For instructions on setting up boot from SAN on NVMe over FC in Linux, refer to the Emulex Boot for the
Fibre Channel and NVMe over FC Protocols User Guide.
NOTE: On RHEL 8.2 and later and SLES 12 SP5 and later operating systems NVMe is enabled by default and the
-n option is not supported.
Ensure that nvme-cli is installed; otherwise the script ./elx_lpfc_install.sh -n will fail.
To confirm whether nvme-cli is installed, run the rpm -qa | grep nvme-cli command.
Broadcom DRVLin-UG128-100
9
Emulex Drivers for Linux User Guide
Run the elx_lpfc_install.sh script with the -n option:
./elx_lpfc_install.sh -n
This installs the lpfc driver along with nvmefc-connect rpm.
After the elx_lpfc_install.sh script has finished running successfully, the NVMe over FC driver is installed.
5. Reboot the system to enable the newly added driver options in the ramdisk.
6. You can use the following command to verify whether the version of the newly installed LPFC driver is correct:
cat /sys/module/lpfc/version
2.2.2 Uninstalling the Emulex FC Driver Kit
NOTE: You must run the uninstall script that shipped with the version of the driver kit that you want to remove.
To uninstall the Emulex FC driver, perform the following steps:
1. Log in as root.
2. If possible, exit all applications that use FC-attached drives, and then unmount the drives. If you cannot exit all
applications that use FC-attached drives, the uninstall script works properly, but you must reboot after the uninstall is
complete.
3. Run the elx_lpfc_install.sh script with the --uninstall option:
./elx_lpfc_install.sh --uninstall
NOTE: The --uninstall option also uninstalls elx-lpfc-extras and nvmefc-connect.
2.3 Booting from a Nonzero LUN Attached to an Emulex FC Adapter
To configure SLES 12 SPx or SLES 15 SPx to boot from an FC-attached disk device other than a LUN 0 device, refer to the
Boot for the Fibre Channel Protocol User Guide, which is available at www.broadcom.com.
2.4 Emulex HBA Manager Application
NOTE: The Emulex OneCommand
®
Manager application has been renamed as the Emulex HBA Manager application.
The Emulex HBA Manager application is a powerful and centralized adapter management suite. It provides discovery,
reporting, and management of local and remote adapters from a single console anywhere in the SAN and across platforms.
Both a GUI and a CLI are provided. For instructions on installing and using the Emulex HBA Manager application, refer to
the Emulex HBA Manager Application User Guide, which is available at www.broadcom.com.
2.5 Updating the Firmware
You can update the firmware on the adapter using any of the following options:
Using the Emulex HBA Manager application. For information on how to update the firmware using the Emulex HBA
Manager application, refer to the Emulex HBA Manager Application User Guide.
Using the HBACMD application. For information on how to update the firmware using the HBACMD application, refer to
the Emulex HBA Manager Application Command Line Interface User Guide.
Using the sysfs command.
Broadcom DRVLin-UG128-100
10
Emulex Drivers for Linux User Guide
To update the firmware using the sysfs command, perform the following steps:
1. Before you update the firmware, procure the model name of the adapter.
cat /sys/class/scsi_host/<host_no>/modelname
2. Modify the firmware file name to the model name.
3. Copy the firmware file to /lib/firmware with the model name.
cp <firmware_file>.grp /lib/firmware/
4. Run the following command and note the value for lpfc_log_verbose. You must echo the same value to
lpfc_log_verbose after firmware activation.
cat /sys/class/scsi_host/host<X>/lpfc_log_verbose
5. Set the driver parameter lpfc_log_verbose=0x8.
echo 0x8 > /sys/class/scsi_host/host<X>/lpfc_log_verbose
6. Download the firmware to the adapter.
echo 1 > /sys/class/scsi_host/<host_no>/lpfc_req_fw_upgrade
7. Check the dmesg log to determine the appropriate reset action.
8. Depending on the features available in the new firmware, the firmware update requires either a firmware reset or a PCI
bus reset.
To perform a firmware reset, issue the following command:
echo fw_reset > /sys/class/scsi_host/host<X>/board_mode
To perform a PCI bus reset, perform the following steps:
a. Run the following command and note the value for
lpfc_enable_hba_reset. You must echo the same value to
lpfc_enable_hba_reset after firmware activation.
cat /sys/class/scsi_host/host<X>/lpfc_enable_hba_reset
b. Enable HBA reset on the adapter.
echo 2 > /sys/class/scsi_host/host<X>/lpfc_enable_hba_reset
c. Set all ports of the adapter offline.
echo offline > /sys/class/scsi_host/host<X>/board_mode
NOTE: For HBAs with more than one port, run this command for each host (port) entry.
d. Reset the PCI bus of the adapter.
echo pci_bus_reset > /sys/class/scsi_host/host<X>/board_mode
e. Set all ports of the adapter online.
echo online > /sys/class/scsi_host/host<X>/board_mode
NOTE: For HBAs with more than one port, run this command for each host (port) entry.
9. Enter the value of lpfc_enable_hba_reset procured in Step a.
echo <original_value> /sys/class/scsi_host/host<X>/lpfc_enable_hba_reset
10.Enter the value of lpfc_log_verbose procured in Step 4.
echo <original_value> /sys/class/scsi_host/host<X>/lpfc_log_verbose
Broadcom DRVLin-UG128-100
11
Emulex Drivers for Linux User Guide
2.6 Installing the NVMe over FC Driver
This section describes how to install the out-of-box NVMe drivers.
NOTE: The NVMe over FC target drivers are meant for evaluation and testing during development only. They are not
intended for production use.
NVMe over FC is supported on LPe31000-series, LPe32000-series, and LPe35000-series adapters.
2.6.1 Installing the NVMe over FC Driver on SLES Operating Systems
Install the SLES operating system on the computer, following the instructions provided with the operating system. Installing
the operating system automatically installs an inbox initiator and a target NVMe driver. For information about the target NVMe
driver, see Appendix B, Configuring NVMe over FC on a Target.
Installation also allows you to install the nvme-cli utility, which is required on initiators that use NVMe disks. It supports
initiation of new NVMe over fabric connections, and it functions as a general utility that allows you to query and manipulate
an NVMe device.
During the operating system installation, configure the following items:
Select the system role of Default System.
In Installation Settings, select to install NVMe CLI.
2.6.2 Installing the NVMe over FC Driver on RHEL Operating Systems
Install the RHEL operating system on the computer, following the instructions provided with the operating system. Installing
the operating system automatically installs an inbox initiator NVMe driver. At this time, Emulex supports NVMe over FC on
RHEL 7.6 and later and RHEL 8.0 and later.
During the installation, select the system role of Default System.
After the operating system is installed, extract the nvme-cli utility from the operating system .ISO image. The nvme-cli
utility supports initiation of new NVMe over fabric connections, and it functions as a general utility that allows you to query
and manipulate an NVMe device. To install the nvme-cli utility, type this command:
rpm -ivh nvme-cli-x.x.x.rpm
You must update to the latest RHEL kernel and the latest RHEL release of the NVMe CLI package. Refer to the Emulex
Drivers for Linux Release Notes for more information.
Broadcom DRVLin-UG128-100
12
Emulex Drivers for Linux User Guide
Chapter 3: Configuration
3.1 FC Driver Configuration
This section describes how to configure parameters for the FC driver.
3.1.1 FC Driver Parameters
The FC driver parameters determine some aspects of the driver’s behavior. There are two main types, static and dynamic.
Changes to the static parameters require a driver reload for the changes to take effect. Changes to most dynamic parameters
take effect immediately; some do not take effect until there is a link-down and link-up sequence.
For more information on driver parameters, see Section 3.1.1.1, Static FC Driver Parameters, and Section 3.1.1.2, Dynamic
FC Driver Parameters.
3.1.1.1 Static FC Driver Parameters
Changes to static parameters require a driver reload for the changes to take effect. The following table lists the static FC
driver parameters.
Table 2: Static FC Driver Parameters
Parameter Description
sysfs
Visible
Applicable
Adapters
Activation
lpfc_ack0 When enabled, ACK0 is used for Class 2. The enabled
value is 1.
The disabled value is 0 (default).
Yes LPe12000-series
adapters
Driver reload
lpfc_discovery_threads Specifies the maximum number of ELS commands that
can be outstanding for a discovery.
NOTE: The lpfc_discovery_threads parameter
defaults to a value of 64 for private loop topologies
regardless of the configured value. If multiple ports are
configured on the host, the value of 64 is used only for
those ports that are connected in a private loop topology.
The configured value is used for all other ports.
The minimum value is 1. The maximum value is 64. The
default value is 32.
No All Driver reload
lpfc_enable_bg Enables the BlockGuard (T10-DIF) feature. See
Appendix A for more information about the BlockGuard
feature.
The minimum value is 0 (default). The maximum value is
1.
Yes All Driver reload
lpfc_enable_da_id When enabled, the FC driver issues a DA_ID CT
command to the fabric when vPorts log out of the fabric.
The enabled value is 1 (default). The disabled value is 0.
Yes All Driver reload
lpfc_enable_fc4_type When enabled defines the FC4 types that are supported.
The possible values are:
1 = Enables just FCP.
3 = Enables both FCP and NVMe (default).
The default value is 3.
Yes LPe31000-series,
LPe32000-series,
and
LPe35000-series
adapters
Driver reload
Broadcom DRVLin-UG128-100
13
Emulex Drivers for Linux User Guide
lpfc_enable_hba_heartbeat When enabled, the heartbeat logic in the FC driver is able
to detect whether the adapter is functional. If the
heartbeat logic detects that the adapter is not functional,
the driver shuts down the adapter.
The disabled value is 0 (default). The enabled value is 1.
Yes All Driver reload
lpfc_enable_hba_reset When enabled, the FC driver can pass resets to the
adapter. This action is typically used for debugging
purposes.
The enabled value is 1 (default). The disabled value is 0.
Yes All Driver reload
lpfc_enable_npiv When enabled, the FC driver can use NPIV to create
vPorts (if supported by the fabric).
The enabled value is 1 (default). The disabled value is 0.
Yes All Driver reload
lpfc_enable_nvmet Specifies the WWPN of the ports enabled for NVMe
target.
No LPe31000-series,
LPe32000-series,
and
LPe35000-series
adapters
Driver reload
lpfc_enable_SmartSAN Sets up FDMI support for HPE Smart SAN. The disabled
value is 0 (default). The enabled value is 1.
Yes All Driver reload
lpfc_EnableXLane Specifies whether the ExpressLane™ feature is enabled
or disabled. See Section 3.1.6, ExpressLane Support for
more information about the ExpressLane feature.
The minimum value is 0 (default). The maximum value is
1.
Yes LPe31000-series
and
LPe32000-series
adapters
Driver reload
lpfc_fcp_class Specifies whether FC Class 2 or FC Class 3 for FCP
datatransmission. For Class 2, the value is 2. For Class
3, the value is 3 (default).
Yes All Driver reload
lpfc_fdmi_on Specifies if FDMI support is enabled or disabled.
The enabled value is 1 (default). The disabled value is 0.
Yes All Driver reload
lpfc_hba_queue_depth Limits the number of outstanding commands per HBA.
The minimum value is 32. The maximum value is 8192
(default).
Yes All Driver reload
lpfc_hdw_queue Defines the number of I/O channels supported by the
driver.
The default value is 0. A value of 0 means that the driver
will automatically determine a recommended amount of
I/O channels to allocate based on system resources.
NOTE: Non zero values may be ignored when
lpfc_irq_chann is set to its default value of 0.
For more information, see the description of the
lpfc_irq_chann parameter.
The supported range is 0 to 256.
Yes LPe16000-series,
LPe31000-series,
LPe32000-series,
and
LPe35000-series
adapters
Driver reload
Table 2: Static FC Driver Parameters (Continued)
Parameter Description
sysfs
Visible
Applicable
Adapters Activation
Broadcom DRVLin-UG128-100
14
Emulex Drivers for Linux User Guide
lpfc_irq_chann Defines the number of EQs (and MSI-X vectors)
requested.
The default value is 0. A value of 0 means that the driver
automatically determines a recommended amount of
EQs, MSI-X vectors, and lpfc_hdw_queue to allocate
based on system resources. This value is limited by the
lesser of the number of CPUs and lpfc_hdw_queue.
NOTE: Depending on system resources, a default value
of 0 may overwrite any values set for
lpfc_hdw_queue.This is to ensure proper driver
recommended settings between hardware queues, EQs,
and MSI-X vectors.
Yes LPe16000-series,
LPe31000-series,
LPe32000-series,
and
LPe35000-series
adapters
Driver reload
lpfc_lun_queue_depth Specifies the default maximum number of commands
sent to a single logical unit (disk drive).
The minimum value is 1. The maximum value is 512. The
default value is 64.
The value of lpfc_lun_queue_depth is dependent on
the max_xri value received. The max_xri value might
vary per adapter type.
NOTE: This parameter can be dynamically changed
using the Emulex HBA Manager application.
Yes All Driver reload
lpfc_max_luns Specifies the highest available LUN ID that is valid, per
target. For example, a value of 19 means that LUN IDs
from 0 to 19 are valid for the target. The SCSI layer scans
each target until it reaches this specified LUN ID.
The minimum value is 0. The maximum value is 65535.
The default value is 255.
Yes All Driver reload
lpfc_max_scsicmpl_time Uses the specified command completion time to control
queue depth. The units are in milliseconds.
The minimum value is 0 (default). The maximum value is
6000.
Yes All Driver reload
lpfc_nvmet_mrq Configures the allocation of multi-receive queues (NVMe
target mode only). The default value is 0 (the driver sets
the appropriate value). The maximum value is 16.
Yes LPe31000-series,
LPe32000-series,
and
LPe35000-series
adapters
Driver reload
lpfc_ras_fwlog_func Configures the function on which firmware logging
support is enabled.
The minimum value is 0 (default). The maximum value is
7.
The default is logging enabled on Function 0.
Yes LPe31000-series,
LPe32000-series,
and
LPe35000-series
adapters
Driver reload
lpfc_restrict_login When enabled, restricts the vPorts login to remote
initiators.
The enabled value is 1 (default). The disabled value is 0.
No All Driver reload
lpfc_scan_down When enabled, selects the scan down method (scanning
the AL_PA from high to low) to assign a SCSI ID.
The enabled value is 1 (default). The disabled value is 0.
Yes All Driver reload
Table 2: Static FC Driver Parameters (Continued)
Parameter Description
sysfs
Visible
Applicable
Adapters Activation
Broadcom DRVLin-UG128-100
15
Emulex Drivers for Linux User Guide
lpfc_sg_seg_cnt Controls the scatter/gather maximum segment count
passed to the FC driver. This variable is applicable per
SCSI command.
For Emulex LPe12000-series adapters, the minimum
value is 64 (default), and the maximum value is 4096.
For all other adapters, the minimum value is 64 (default),
and the maximum value is 510.
Yes All Driver reload
lpfc_sli_mode Allows you to force the SLI mode requested by the
adapter driver. The possible values are:
0 = Auto-select (default)
2 = SLI-2
3 = SLI-3
No LPe12000-series
adapters
Driver reload
lpfc_use_msi When enabled, this parameter determines whether the
driver uses MSI or MSI-X.
0 = MSI disabled; INTx mode is used.
1 = MSI; allows a maximum of 32 interrupts.
2 = MSI-X; allows a maximum of 2048 interrupts
(default value).
NOTE: The default is 2. This value reverts to 1 if the
system does not support MSI-X. This value reverts to 0 if
the system does not support MSI.
Yes All Driver reload
Table 2: Static FC Driver Parameters (Continued)
Parameter Description
sysfs
Visible
Applicable
Adapters Activation
Broadcom DRVLin-UG128-100
16
Emulex Drivers for Linux User Guide
3.1.1.2 Dynamic FC Driver Parameters
Changes to most dynamic parameters take effect immediately; some do not take effect until a port reset occurs. All lpfc
dynamic parameters are read and written using sysfs. The following table lists the dynamic FC driver parameters.
Table 3: Dynamic FC Driver Parameters
Parameter Description
sysfs
Visible
Applicable
Adapters Activation
lpfc_cr_count Determines the value for I/O coalescing for
lpfc_cr_count outstanding commands.
The minimum value is 1 (default). The maximum value
is 255.
Yes LPe12000-series
adapters
Port reset
lpfc_cr_delay Determines the value for I/O coalescing for
lpfc_cr_delay (milliseconds) outstanding
commands.
The minimum value is 0 (default). The maximum value
is 63.
Yes LPe12000-series
adapters
Port reset
lpfc_devloss_tmo Specifies the number of seconds to hold an I/O error
when a device disappears.
The minimum value is 1. The maximum value is 255.
The default value is 30.
Yes All Dynamic
lpfc_enable_auth Enables or disables DH-CHAP authentication.
The possible values are:
0 = Authentication is disabled (default).
1 = Authentication is enabled.
NOTE: DH-CHAP and Dynamic D_Port are mutually
exclusive. If both features are enabled simultaneously,
warning messages result. You must either disable
DH-CHAP using the lpfc_enable_auth parameter
or disable Dynamic D_Port using the Emulex HBA
Manager application.
Yes LPe16000-series,
LPe31000-series,
LPe32000-series,
and
LPe35000-series
adapters
Dynamic
lpfc_enable_bbcr Specifies whether if the Buffer-to-Buffer Credit
Recovery feature is enabled or disabled.
The minimum value is 0. The maximum value is 1
(default).
Yes LPe16000-series,
LPe31000-series,
LPe32000-series,
and
LPe35000-series
adapters
Port reset
lpfc_enable_mds_diags Enables or disables support for Cisco MDS switch
diagnostics.
The minimum value is 0 (default). The maximum value
is 1.
NOTE: The parameter must be disabled (set to 0) after
diagnostics are complete.
Yes LPe16000-series,
LPe31000-series,
LPe32000-series,
and
LPe35000-series
adapters
Port reset
lpfc_fcp_imax Specifies the maximum number of fast-path FCP
interrupts per second.
The default value is 0. If set to 0 the parameter is OFF.
The minimum value is 5000. The maximum value is
5,000,000.
A value of 0 (default) provides dynamic interrupt
coalescing that adapts to provide low latency or high
IOPs according to I/O load.
Yes LPe16000-series,
LPe31000-series,
LPe32000-series,
and
LPe35000-series
adapters
Dynamic
Broadcom DRVLin-UG128-100
17
Emulex Drivers for Linux User Guide
lpfc_fcp_io_sched Determines which algorithm to use when scheduling
an FC I/O to an I/O channel. For more information, see
Section 3.3, FC Driver Performance Tuning.
The value 0 configures “schedule by hardware queue”
(rather than round robin). A value of 1 (default)
configures “schedule by CPU.”
Yes LPe16000-series,
LPe31000-series,
LPe32000-series,
and
LPe35000-series
adapters
Dynamic
lpfc_first_burst_size Configures the first burst size on targets that support
first burst. The minimum value is 0 (default). The
maximum value is 65,536 bytes.
Yes All Dynamic
lpfc_link_speed Specifies the FC link speed. The possible values are:
0 = Auto-select (default)
2 = 2Gb/s
4 = 4Gb/s
8 = 8Gb/s
16 = 16Gb/s
32 = 32Gb/s
NOTE:
Setting this option incorrectly can cause the
adapter to fail to initialize.
If you configure the link speed in a BIOS utility, the
link speed can be overwritten by the operating
system according to its own configuration settings.
To avoid this issue, configure the link speed in both
the operating system driver and the x86 BootBIOS
or UEFI utility.
Yes All Port reset
lpfc_log_verbose Specifies the log verbosity level of the messages
posted by the driver. When enabled, this parameter
prints extra log messages that are for debugging
purposes.
The minimum value is 0x0 (default). The maximum
value is 0xFFFFFFFF.
NOTE: Setting the lpfc_log_verbose value to
0xffffffff might degrade system performance.
Yes All Dynamic
lpfc_nvme_embed_cmd This is an optional parameter.
When enabled, embeds an NVMe command in WQE.
The possible values are:
0 = Embeds an NVMe command in SGL.
1 = Embeds an NVMe command in WQE (except
LPe35000-series adapters).
2 = Embeds an NVMe command in WQE (force).
Yes LPe31000-series
and
LPe32000-series
adapters
Dynamic
Table 3: Dynamic FC Driver Parameters (Continued)
Parameter Description
sysfs
Visible
Applicable
Adapters Activation
Broadcom DRVLin-UG128-100
18
Emulex Drivers for Linux User Guide
lpfc_nvme_enable_fb Enables NVMe first burst on initiator and target
functions.
For an initiator, enabling this parameter means that an
NVMET PRLI response with FBA enabled and an
FB_SIZE set to a nonzero value is processed by the
initiator for subsequent NVMe FCP I/O.
Currently, this feature is not supported on NVMe
targets.
The possible values are:
0 = Disabled (default)
1 = Enabled
Yes LPe31000-series,
LPe32000-series,
and
LPe35000-series
adapters
Dynamic
lpfc_nvme_oas When enabled, uses the oas bit when sending NVMe/
NVMe target I/Os.
The possible values are:
0 = Disabled (default)
1 = Enabled
Yes LPe31000-series,
LPe32000-series,
and
LPe35000-series
adapters
Dynamic
lpfc_nvmet_fb_size When enabled, communicates the first burst size of
the target to the NVMe initiator in the PRLI response.
lpfc_nvmet_fb_size is used only when the
lpfc_nvme_enable_fb is set and the target sends
a PRLI response.
The possible values are:
0 = Disabled (default)
1 = Enabled
This parameter is supported only on physical ports.
Yes LPe31000-series,
LPe32000-series,
and
LPe35000-series
adapters
Dynamic
lpfc_ras_fwlog_buffsize Specifies the buffer size to be allocated in host
memory for firmware logging.
The possible values are:
0 = Disables the firmware log written to the host
memory (default).
1 = ¼ MB (256K) host memory to be allocated for
the firmware log.
2 = ½ MB (512K) host memory to be allocated for
the firmware log.
3 = ¾ MB (768K) host memory to be allocated for
the firmware log.
4 = 1 MB host memory to be allocated for the
firmware log.
Yes LPe31000-series,
LPe32000-series,
and
LPe35000-series
adapters
Driver reload
lpfc_ras_fwlog_level Configures the firmware logging level. Valid only if
firmware logging is enabled using the
lpfc_ras_fwlog_buffsize parameter.
The minimum value is 0 (default). The maximum value
is 4.
Yes LPe31000-series,
LPe32000-series,
and
LPe35000-series
adapters
Driver reload
lpfc_req_fw_upgrade Set this parameter to 1 to update the firmware. Yes LPe16000-series,
LPe31000-series,
LPe32000-series,
and
LPe35000-series
adapters
Dynamic
Table 3: Dynamic FC Driver Parameters (Continued)
Parameter Description
sysfs
Visible
Applicable
Adapters Activation
Broadcom DRVLin-UG128-100
19
Emulex Drivers for Linux User Guide
lpfc_suppress_rsp Negotiates whether to suppress the RSP from a target
during a PLOGI.
The minimum value is 0. The maximum value is 1.
The default value is 1.
Yes LPe16000-series,
LPe31000-series,
LPe32000-series,
and
LPe35000-series
adapters
Dynamic
lpfc_tgt_queue_depth Limits the number of outstanding commands per target
port. The minimum value is 10. The maximum value is
up to 65,535 (default).
NOTE: The maximum value is determined by the
adapter's capability.
Yes All Dynamic
lpfc_throttle_log_cnt Specifies the number of messages logged within
throttle_log_time.
The minimum value is 1. The maximum value is 1000.
The default value is 10.
Yes All Dynamic
lpfc_throttle_log_time Specifies the time limit in seconds for
throttle_log_cnt.
The minimum value is 1. The maximum value is 60.
The default value is 1.
Yes All Dynamic
lpfc_topology Sets the link topology. The possible values are:
0x0 = Loop first; if loop fails, then point-to-point
(default).
0x2 = Point-to-point only.
0x4 = Loop only.
0x6 = Point-to-point first; if point-to-point fails, then
loop.
NOTE: To configure the topology on LPe31000-series,
LPe32000-series, and LPe35000-series adapters, use
the Emulex HBA Manager application. or the x86
BootBIOS, or the UEFI utility.
LPe31000-series, LPe32000-series, and
LPe35000-series adapters now support loop topology
in addition to point-to-point.
Yes LPe12000-series
adapters
Port reset
lpfc_use_adisc When enabled, an address discovery is sent instead of
a PLOGI for device discovery or RSCN. The enabled
value is 1.
The default value is 0 (disabled).
Yes All Dynamic
lpfc_XLanePriority For Emulex LPe31000-series and LPe32000-series
adapters, when enabled, this parameter defines the
frame priority to be used for the ExpressLane feature.
The minimum value is 0 (default). The maximum value
is 0x7f.
Yes LPe31000-series
and
LPe32000-series
adapters
Dynamic
Table 3: Dynamic FC Driver Parameters (Continued)
Parameter Description
sysfs
Visible
Applicable
Adapters Activation
Broadcom DRVLin-UG128-100
20
Emulex Drivers for Linux User Guide
3.1.2 Configuring FC Driver Parameters
You can configure FC driver parameters using any of the following methods:
The modprobe command for temporary configuration
The elx-lpfc.conf file for persistent configuration
The sysfs interface (to view and modify parameters after loading the FC driver)
NOTE: Not all parameters visible in the sysfs directory can be modified; some are read-only.
The Emulex HBA Manager application (refer to the Emulex HBA Manager Application User Guide for more information)
NOTE: The FC driver parameter changes made using the Emulex HBA Manager application remain after the FC driver is
uninstalled. To return to the default settings, you must reset them using the Emulex HBA Manager application.
3.1.2.1 Temporary Configuration with the modprobe Command
When you manually load the FC driver as a module using the modprobe command and you change one or more driver
parameter values in the command line, the configuration is temporary. These changes are considered temporary because
they are valid only for the current session or until the FC driver is unloaded.
The modprobe command uses the elx-lpfc.conf file, but parameters passed to it using the command line override the
parameters in the elx-lpfc.conf file. Values can be expressed in hexadecimal or decimal notation.
For example, if you want to temporarily set lpfc_lun_queue_depth to 20 (the default is 64) for all HBAs in your system,
load the FC driver with the following command:
modprobe lpfc lpfc_lun_queue_depth=20
3.1.2.2 Persistent Configuration with the elx-lpfc.conf File
To make the FC driver parameters persist across module loads and reboots, perform the following steps:
1. In the /etc/modprobe.d directory, create a file with the driver name elx-lpfc.conf.
2. In /etc/modprobe.d/elx-lpfc.conf, use the options command to add the appropriate FC driver parameters and
their desired values. For example, adding the following command to the elx-lpfc.conf file sets the verbose flag:
options lpfc lpfc_log_verbose=0x3FFFF
If driver parameters are added to the elx-lpfc.conf file, the FC driver must be reloaded for the parameters to take effect.
Also, a new ramdisk image is required if you want the changes to take effect in the next boot. For information on creating a
new ramdisk, see Section 3.1.3, Creating a New Ramdisk Image.
If the same parameter is specified on the modprobe command line and in the elx-lpfc.conf file, the value specified in
the modprobe command line takes precedence.
/