Use the newly added pldmfw library to implement device flash update for the Intel ice networking device driver. This support uses the devlink flash update interface. The main parts of the flash include the Option ROM, the netlist module, and the main NVM data. The PLDM firmware file contains modules for each of these components. Using the pldmfw library, the provided firmware file will be scanned for the three major components, "fw.undi" for the Option ROM, "fw.mgmt" for the main NVM module containing the primary device firmware, and "fw.netlist" containing the netlist module. The flash is separated into two banks, the active bank containing the running firmware, and the inactive bank which we use for update. Each module is updated in a staged process. First, the inactive bank is erased, preparing the device for update. Second, the contents of the component are copied to the inactive portion of the flash. After all components are updated, the driver signals the device to switch the active bank during the next EMP reset (which would usually occur during the next reboot). Although the firmware AdminQ interface does report an immediate status for each command, the NVM erase and NVM write commands receive status asynchronously. The driver must not continue writing until previous erase and write commands have finished. The real status of the NVM commands is returned over the receive AdminQ. Implement a simple interface that uses a wait queue so that the main update thread can sleep until the completion status is reported by firmware. For erasing the inactive banks, this can take quite a while in practice. To help visualize the process to the devlink application and other applications based on the devlink netlink interface, status is reported via the devlink_flash_update_status_notify. While we do report status after each 4k block when writing, there is no real status we can report during erasing. We simply must wait for the complete module erasure to finish. With this implementation, basic flash update for the ice hardware is supported. Signed-off-by: Jacob Keller <jacob.e.keller@intel.com> Signed-off-by: David S. Miller <davem@davemloft.net>
		
			
				
	
	
		
			347 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			347 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| # SPDX-License-Identifier: GPL-2.0-only
 | |
| #
 | |
| # Intel network device configuration
 | |
| #
 | |
| 
 | |
| config NET_VENDOR_INTEL
 | |
| 	bool "Intel devices"
 | |
| 	default y
 | |
| 	help
 | |
| 	  If you have a network (Ethernet) card belonging to this class, say Y.
 | |
| 
 | |
| 	  Note that the answer to this question doesn't directly affect the
 | |
| 	  kernel: saying N will just cause the configurator to skip all
 | |
| 	  the questions about Intel cards. If you say Y, you will be asked for
 | |
| 	  your specific card in the following questions.
 | |
| 
 | |
| if NET_VENDOR_INTEL
 | |
| 
 | |
| config E100
 | |
| 	tristate "Intel(R) PRO/100+ support"
 | |
| 	depends on PCI
 | |
| 	select MII
 | |
| 	help
 | |
| 	  This driver supports Intel(R) PRO/100 family of adapters.
 | |
| 	  To verify that your adapter is supported, find the board ID number
 | |
| 	  on the adapter. Look for a label that has a barcode and a number
 | |
| 	  in the format 123456-001 (six digits hyphen three digits).
 | |
| 
 | |
| 	  Use the above information and the Adapter & Driver ID Guide that
 | |
| 	  can be located at:
 | |
| 
 | |
| 	  <http://support.intel.com>
 | |
| 
 | |
| 	  to identify the adapter.
 | |
| 
 | |
| 	  More specific information on configuring the driver is in
 | |
| 	  <file:Documentation/networking/device_drivers/ethernet/intel/e100.rst>.
 | |
| 
 | |
| 	  To compile this driver as a module, choose M here. The module
 | |
| 	  will be called e100.
 | |
| 
 | |
| config E1000
 | |
| 	tristate "Intel(R) PRO/1000 Gigabit Ethernet support"
 | |
| 	depends on PCI
 | |
| 	help
 | |
| 	  This driver supports Intel(R) PRO/1000 gigabit ethernet family of
 | |
| 	  adapters.  For more information on how to identify your adapter, go
 | |
| 	  to the Adapter & Driver ID Guide that can be located at:
 | |
| 
 | |
| 	  <http://support.intel.com>
 | |
| 
 | |
| 	  More specific information on configuring the driver is in
 | |
| 	  <file:Documentation/networking/device_drivers/ethernet/intel/e1000.rst>.
 | |
| 
 | |
| 	  To compile this driver as a module, choose M here. The module
 | |
| 	  will be called e1000.
 | |
| 
 | |
| config E1000E
 | |
| 	tristate "Intel(R) PRO/1000 PCI-Express Gigabit Ethernet support"
 | |
| 	depends on PCI && (!SPARC32 || BROKEN)
 | |
| 	select CRC32
 | |
| 	imply PTP_1588_CLOCK
 | |
| 	help
 | |
| 	  This driver supports the PCI-Express Intel(R) PRO/1000 gigabit
 | |
| 	  ethernet family of adapters. For PCI or PCI-X e1000 adapters,
 | |
| 	  use the regular e1000 driver For more information on how to
 | |
| 	  identify your adapter, go to the Adapter & Driver ID Guide that
 | |
| 	  can be located at:
 | |
| 
 | |
| 	  <http://support.intel.com>
 | |
| 
 | |
| 	  More specific information on configuring the driver is in
 | |
| 	  <file:Documentation/networking/device_drivers/ethernet/intel/e1000e.rst>.
 | |
| 
 | |
| 	  To compile this driver as a module, choose M here. The module
 | |
| 	  will be called e1000e.
 | |
| 
 | |
| config E1000E_HWTS
 | |
| 	bool "Support HW cross-timestamp on PCH devices"
 | |
| 	default y
 | |
| 	depends on E1000E && X86
 | |
| 	help
 | |
| 	 Say Y to enable hardware supported cross-timestamping on PCH
 | |
| 	 devices. The cross-timestamp is available through the PTP clock
 | |
| 	 driver precise cross-timestamp ioctl (PTP_SYS_OFFSET_PRECISE).
 | |
| 
 | |
| config IGB
 | |
| 	tristate "Intel(R) 82575/82576 PCI-Express Gigabit Ethernet support"
 | |
| 	depends on PCI
 | |
| 	imply PTP_1588_CLOCK
 | |
| 	select I2C
 | |
| 	select I2C_ALGOBIT
 | |
| 	help
 | |
| 	  This driver supports Intel(R) 82575/82576 gigabit ethernet family of
 | |
| 	  adapters.  For more information on how to identify your adapter, go
 | |
| 	  to the Adapter & Driver ID Guide that can be located at:
 | |
| 
 | |
| 	  <http://support.intel.com>
 | |
| 
 | |
| 	  More specific information on configuring the driver is in
 | |
| 	  <file:Documentation/networking/device_drivers/ethernet/intel/igb.rst>.
 | |
| 
 | |
| 	  To compile this driver as a module, choose M here. The module
 | |
| 	  will be called igb.
 | |
| 
 | |
| config IGB_HWMON
 | |
| 	bool "Intel(R) PCI-Express Gigabit adapters HWMON support"
 | |
| 	default y
 | |
| 	depends on IGB && HWMON && !(IGB=y && HWMON=m)
 | |
| 	help
 | |
| 	  Say Y if you want to expose thermal sensor data on Intel devices.
 | |
| 
 | |
| 	  Some of our devices contain thermal sensors, both external and internal.
 | |
| 	  This data is available via the hwmon sysfs interface and exposes
 | |
| 	  the onboard sensors.
 | |
| 
 | |
| config IGB_DCA
 | |
| 	bool "Direct Cache Access (DCA) Support"
 | |
| 	default y
 | |
| 	depends on IGB && DCA && !(IGB=y && DCA=m)
 | |
| 	help
 | |
| 	  Say Y here if you want to use Direct Cache Access (DCA) in the
 | |
| 	  driver.  DCA is a method for warming the CPU cache before data
 | |
| 	  is used, with the intent of lessening the impact of cache misses.
 | |
| 
 | |
| config IGBVF
 | |
| 	tristate "Intel(R) 82576 Virtual Function Ethernet support"
 | |
| 	depends on PCI
 | |
| 	help
 | |
| 	  This driver supports Intel(R) 82576 virtual functions.  For more
 | |
| 	  information on how to identify your adapter, go to the Adapter &
 | |
| 	  Driver ID Guide that can be located at:
 | |
| 
 | |
| 	  <http://support.intel.com>
 | |
| 
 | |
| 	  More specific information on configuring the driver is in
 | |
| 	  <file:Documentation/networking/device_drivers/ethernet/intel/igbvf.rst>.
 | |
| 
 | |
| 	  To compile this driver as a module, choose M here. The module
 | |
| 	  will be called igbvf.
 | |
| 
 | |
| config IXGB
 | |
| 	tristate "Intel(R) PRO/10GbE support"
 | |
| 	depends on PCI
 | |
| 	help
 | |
| 	  This driver supports Intel(R) PRO/10GbE family of adapters for
 | |
| 	  PCI-X type cards. For PCI-E type cards, use the "ixgbe" driver
 | |
| 	  instead. For more information on how to identify your adapter, go
 | |
| 	  to the Adapter & Driver ID Guide that can be located at:
 | |
| 
 | |
| 	  <http://support.intel.com>
 | |
| 
 | |
| 	  More specific information on configuring the driver is in
 | |
| 	  <file:Documentation/networking/device_drivers/ethernet/intel/ixgb.rst>.
 | |
| 
 | |
| 	  To compile this driver as a module, choose M here. The module
 | |
| 	  will be called ixgb.
 | |
| 
 | |
| config IXGBE
 | |
| 	tristate "Intel(R) 10GbE PCI Express adapters support"
 | |
| 	depends on PCI
 | |
| 	select MDIO
 | |
| 	select PHYLIB
 | |
| 	imply PTP_1588_CLOCK
 | |
| 	help
 | |
| 	  This driver supports Intel(R) 10GbE PCI Express family of
 | |
| 	  adapters.  For more information on how to identify your adapter, go
 | |
| 	  to the Adapter & Driver ID Guide that can be located at:
 | |
| 
 | |
| 	  <http://support.intel.com>
 | |
| 
 | |
| 	  More specific information on configuring the driver is in
 | |
| 	  <file:Documentation/networking/device_drivers/ethernet/intel/ixgbe.rst>.
 | |
| 
 | |
| 	  To compile this driver as a module, choose M here. The module
 | |
| 	  will be called ixgbe.
 | |
| 
 | |
| config IXGBE_HWMON
 | |
| 	bool "Intel(R) 10GbE PCI Express adapters HWMON support"
 | |
| 	default y
 | |
| 	depends on IXGBE && HWMON && !(IXGBE=y && HWMON=m)
 | |
| 	help
 | |
| 	  Say Y if you want to expose the thermal sensor data on some of
 | |
| 	  our cards, via a hwmon sysfs interface.
 | |
| 
 | |
| config IXGBE_DCA
 | |
| 	bool "Direct Cache Access (DCA) Support"
 | |
| 	default y
 | |
| 	depends on IXGBE && DCA && !(IXGBE=y && DCA=m)
 | |
| 	help
 | |
| 	  Say Y here if you want to use Direct Cache Access (DCA) in the
 | |
| 	  driver.  DCA is a method for warming the CPU cache before data
 | |
| 	  is used, with the intent of lessening the impact of cache misses.
 | |
| 
 | |
| config IXGBE_DCB
 | |
| 	bool "Data Center Bridging (DCB) Support"
 | |
| 	default n
 | |
| 	depends on IXGBE && DCB
 | |
| 	help
 | |
| 	  Say Y here if you want to use Data Center Bridging (DCB) in the
 | |
| 	  driver.
 | |
| 
 | |
| 	  If unsure, say N.
 | |
| 
 | |
| config IXGBE_IPSEC
 | |
| 	bool "IPSec XFRM cryptography-offload acceleration"
 | |
| 	depends on IXGBE
 | |
| 	depends on XFRM_OFFLOAD
 | |
| 	default y
 | |
| 	select XFRM_ALGO
 | |
| 	help
 | |
| 	  Enable support for IPSec offload in ixgbe.ko
 | |
| 
 | |
| config IXGBEVF
 | |
| 	tristate "Intel(R) 10GbE PCI Express Virtual Function Ethernet support"
 | |
| 	depends on PCI_MSI
 | |
| 	help
 | |
| 	  This driver supports Intel(R) PCI Express virtual functions for the
 | |
| 	  Intel(R) ixgbe driver.  For more information on how to identify your
 | |
| 	  adapter, go to the Adapter & Driver ID Guide that can be located at:
 | |
| 
 | |
| 	  <http://support.intel.com>
 | |
| 
 | |
| 	  More specific information on configuring the driver is in
 | |
| 	  <file:Documentation/networking/device_drivers/ethernet/intel/ixgbevf.rst>.
 | |
| 
 | |
| 	  To compile this driver as a module, choose M here. The module
 | |
| 	  will be called ixgbevf.  MSI-X interrupt support is required
 | |
| 	  for this driver to work correctly.
 | |
| 
 | |
| config IXGBEVF_IPSEC
 | |
| 	bool "IPSec XFRM cryptography-offload acceleration"
 | |
| 	depends on IXGBEVF
 | |
| 	depends on XFRM_OFFLOAD
 | |
| 	default y
 | |
| 	select XFRM_ALGO
 | |
| 	help
 | |
| 	  Enable support for IPSec offload in ixgbevf.ko
 | |
| 
 | |
| config I40E
 | |
| 	tristate "Intel(R) Ethernet Controller XL710 Family support"
 | |
| 	imply PTP_1588_CLOCK
 | |
| 	depends on PCI
 | |
| 	help
 | |
| 	  This driver supports Intel(R) Ethernet Controller XL710 Family of
 | |
| 	  devices.  For more information on how to identify your adapter, go
 | |
| 	  to the Adapter & Driver ID Guide that can be located at:
 | |
| 
 | |
| 	  <http://support.intel.com>
 | |
| 
 | |
| 	  More specific information on configuring the driver is in
 | |
| 	  <file:Documentation/networking/device_drivers/ethernet/intel/i40e.rst>.
 | |
| 
 | |
| 	  To compile this driver as a module, choose M here. The module
 | |
| 	  will be called i40e.
 | |
| 
 | |
| config I40E_DCB
 | |
| 	bool "Data Center Bridging (DCB) Support"
 | |
| 	default n
 | |
| 	depends on I40E && DCB
 | |
| 	help
 | |
| 	  Say Y here if you want to use Data Center Bridging (DCB) in the
 | |
| 	  driver.
 | |
| 
 | |
| 	  If unsure, say N.
 | |
| 
 | |
| # this is here to allow seamless migration from I40EVF --> IAVF name
 | |
| # so that CONFIG_IAVF symbol will always mirror the state of CONFIG_I40EVF
 | |
| config IAVF
 | |
| 	tristate
 | |
| config I40EVF
 | |
| 	tristate "Intel(R) Ethernet Adaptive Virtual Function support"
 | |
| 	select IAVF
 | |
| 	depends on PCI_MSI
 | |
| 	help
 | |
| 	  This driver supports virtual functions for Intel XL710,
 | |
| 	  X710, X722, XXV710, and all devices advertising support for
 | |
| 	  Intel Ethernet Adaptive Virtual Function devices. For more
 | |
| 	  information on how to identify your adapter, go to the Adapter
 | |
| 	  & Driver ID Guide that can be located at:
 | |
| 
 | |
| 	  <https://support.intel.com>
 | |
| 
 | |
| 	  This driver was formerly named i40evf.
 | |
| 
 | |
| 	  More specific information on configuring the driver is in
 | |
| 	  <file:Documentation/networking/device_drivers/ethernet/intel/iavf.rst>.
 | |
| 
 | |
| 	  To compile this driver as a module, choose M here. The module
 | |
| 	  will be called iavf.  MSI-X interrupt support is required
 | |
| 	  for this driver to work correctly.
 | |
| 
 | |
| config ICE
 | |
| 	tristate "Intel(R) Ethernet Connection E800 Series Support"
 | |
| 	default n
 | |
| 	depends on PCI_MSI
 | |
| 	select NET_DEVLINK
 | |
| 	select PLDMFW
 | |
| 	help
 | |
| 	  This driver supports Intel(R) Ethernet Connection E800 Series of
 | |
| 	  devices.  For more information on how to identify your adapter, go
 | |
| 	  to the Adapter & Driver ID Guide that can be located at:
 | |
| 
 | |
| 	  <http://support.intel.com>
 | |
| 
 | |
| 	  More specific information on configuring the driver is in
 | |
| 	  <file:Documentation/networking/device_drivers/ethernet/intel/ice.rst>.
 | |
| 
 | |
| 	  To compile this driver as a module, choose M here. The module
 | |
| 	  will be called ice.
 | |
| 
 | |
| config FM10K
 | |
| 	tristate "Intel(R) FM10000 Ethernet Switch Host Interface Support"
 | |
| 	default n
 | |
| 	depends on PCI_MSI
 | |
| 	imply PTP_1588_CLOCK
 | |
| 	help
 | |
| 	  This driver supports Intel(R) FM10000 Ethernet Switch Host
 | |
| 	  Interface.  For more information on how to identify your adapter,
 | |
| 	  go to the Adapter & Driver ID Guide that can be located at:
 | |
| 
 | |
| 	  <http://support.intel.com>
 | |
| 
 | |
| 	  More specific information on configuring the driver is in
 | |
| 	  <file:Documentation/networking/device_drivers/ethernet/intel/fm10k.rst>.
 | |
| 
 | |
| 	  To compile this driver as a module, choose M here. The module
 | |
| 	  will be called fm10k.  MSI-X interrupt support is required
 | |
| 
 | |
| config IGC
 | |
| 	tristate "Intel(R) Ethernet Controller I225-LM/I225-V support"
 | |
| 	default n
 | |
| 	depends on PCI
 | |
| 	help
 | |
| 	  This driver supports Intel(R) Ethernet Controller I225-LM/I225-V
 | |
| 	  family of adapters.
 | |
| 
 | |
| 	  For more information on how to identify your adapter, go
 | |
| 	  to the Adapter & Driver ID Guide that can be located at:
 | |
| 
 | |
| 	  <http://support.intel.com>
 | |
| 
 | |
| 	  To compile this driver as a module, choose M here. The module
 | |
| 	  will be called igc.
 | |
| 
 | |
| endif # NET_VENDOR_INTEL
 |