diff options
author | Eric Joyner <erj@FreeBSD.org> | 2018-06-18 20:12:54 +0000 |
---|---|---|
committer | Eric Joyner <erj@FreeBSD.org> | 2018-06-18 20:12:54 +0000 |
commit | 1031d839aa127290f6ef6e11d16472bf268616d4 (patch) | |
tree | 58b03910b98dff865ef749a998325fb3020522ad /sys/dev/ixl/ixl_pf.h | |
parent | 52666d36751d3a29959ef36b8d7fa159ee3f5430 (diff) | |
download | src-1031d839aa127290f6ef6e11d16472bf268616d4.tar.gz src-1031d839aa127290f6ef6e11d16472bf268616d4.zip |
ixl(4): Update to use iflib
Update the driver to use iflib in order to bring performance,
maintainability, and (hopefully) stability benefits to the driver.
The driver currently isn't completely ported; features that are missing:
- VF driver (ixlv)
- SR-IOV host support
- RDMA support
The plan is to have these re-added to the driver before the next FreeBSD release.
Reviewed by: gallatin@
Contributions by: gallatin@, mmacy@, krzysztof.galazka@intel.com
Tested by: jeffrey.e.pieper@intel.com
MFC after: 1 month
Sponsored by: Intel Corporation
Differential Revision: https://reviews.freebsd.org/D15577
Notes
Notes:
svn path=/head/; revision=335338
Diffstat (limited to 'sys/dev/ixl/ixl_pf.h')
-rw-r--r-- | sys/dev/ixl/ixl_pf.h | 142 |
1 files changed, 93 insertions, 49 deletions
diff --git a/sys/dev/ixl/ixl_pf.h b/sys/dev/ixl/ixl_pf.h index 1a09a4b67e4b..444de14280c2 100644 --- a/sys/dev/ixl/ixl_pf.h +++ b/sys/dev/ixl/ixl_pf.h @@ -45,16 +45,41 @@ #define VF_FLAG_PROMISC_CAP 0x08 #define VF_FLAG_MAC_ANTI_SPOOF 0x10 -#define IXL_PF_STATE_EMPR_RESETTING (1 << 0) -#define IXL_PF_STATE_FW_LLDP_DISABLED (1 << 1) +#define IXL_ICR0_CRIT_ERR_MASK \ + (I40E_PFINT_ICR0_PCI_EXCEPTION_MASK | \ + I40E_PFINT_ICR0_ECC_ERR_MASK | \ + I40E_PFINT_ICR0_PE_CRITERR_MASK) + +/* VF Interrupts */ +#define IXL_VPINT_LNKLSTN_REG(hw, vector, vf_num) \ + I40E_VPINT_LNKLSTN(((vector) - 1) + \ + (((hw)->func_caps.num_msix_vectors_vf - 1) * (vf_num))) + +#define IXL_VFINT_DYN_CTLN_REG(hw, vector, vf_num) \ + I40E_VFINT_DYN_CTLN(((vector) - 1) + \ + (((hw)->func_caps.num_msix_vectors_vf - 1) * (vf_num))) + +/* Used in struct ixl_pf's state field */ +enum ixl_pf_state { + IXL_PF_STATE_ADAPTER_RESETTING = (1 << 0), + IXL_PF_STATE_MDD_PENDING = (1 << 1), + IXL_PF_STATE_PF_RESET_REQ = (1 << 2), + IXL_PF_STATE_VF_RESET_REQ = (1 << 3), + IXL_PF_STATE_PF_CRIT_ERR = (1 << 4), + IXL_PF_STATE_CORE_RESET_REQ = (1 << 5), + IXL_PF_STATE_GLOB_RESET_REQ = (1 << 6), + IXL_PF_STATE_EMP_RESET_REQ = (1 << 7), + IXL_PF_STATE_FW_LLDP_DISABLED = (1 << 8), +}; struct ixl_vf { struct ixl_vsi vsi; - uint32_t vf_flags; + u32 vf_flags; + u32 num_mdd_events; - uint8_t mac[ETHER_ADDR_LEN]; - uint16_t vf_num; - uint32_t version; + u8 mac[ETHER_ADDR_LEN]; + u16 vf_num; + u32 version; struct ixl_pf_qtag qtag; struct sysctl_ctx_list ctx; @@ -62,31 +87,24 @@ struct ixl_vf { /* Physical controller structure */ struct ixl_pf { + /* + * This is first so that iflib_get_softc can return + * either the VSI or the PF structures. + */ + struct ixl_vsi vsi; + struct i40e_hw hw; struct i40e_osdep osdep; device_t dev; - struct ixl_vsi vsi; struct resource *pci_mem; - struct resource *msix_mem; - /* - * Interrupt resources: this set is - * either used for legacy, or for Link - * when doing MSIX - */ - void *tag; - struct resource *res; - - struct callout timer; - int msix; #ifdef IXL_IW int iw_msix; bool iw_enabled; #endif int if_flags; - int state; - bool init_in_progress; + u32 state; u8 supported_speeds; struct ixl_pf_qmgr qmgr; @@ -101,13 +119,6 @@ struct ixl_pf { int tx_itr; int rx_itr; - struct mtx pf_mtx; - - u32 qbase; - u32 admvec; - struct task adminq; - struct taskqueue *tq; - bool link_up; u32 link_speed; int advertised_speed; @@ -124,6 +135,13 @@ struct ixl_pf { struct i40e_hw_port_stats stats_offsets; bool stat_offsets_loaded; + /* I2C access methods */ + u8 i2c_access_method; + s32 (*read_i2c_byte)(struct ixl_pf *pf, u8 byte_offset, + u8 dev_addr, u8 *data); + s32 (*write_i2c_byte)(struct ixl_pf *pf, u8 byte_offset, + u8 dev_addr, u8 data); + /* SR-IOV */ struct ixl_vf *vfs; int num_vfs; @@ -177,13 +195,38 @@ struct ixl_pf { #define IXL_SYSCTL_HELP_LINK_STATUS \ "\nExecutes a \"Get Link Status\" command on the Admin Queue, and displays" \ -" the response." \ +" the response." #define IXL_SYSCTL_HELP_FW_LLDP \ "\nFW LLDP engine:\n" \ "\t0 - disable\n" \ "\t1 - enable\n" +#define IXL_SYSCTL_HELP_READ_I2C \ +"\nRead a byte from I2C bus\n" \ +"Input: 32-bit value\n" \ +"\tbits 0-7: device address (0xA0 or 0xA2)\n" \ +"\tbits 8-15: offset (0-255)\n" \ +"\tbits 16-31: unused\n" \ +"Output: 8-bit value read" + +#define IXL_SYSCTL_HELP_WRITE_I2C \ +"\nWrite a byte to the I2C bus\n" \ +"Input: 32-bit value\n" \ +"\tbits 0-7: device address (0xA0 or 0xA2)\n" \ +"\tbits 8-15: offset (0-255)\n" \ +"\tbits 16-23: value to write\n" \ +"\tbits 24-31: unused\n" \ +"Output: 8-bit value written" + +#define IXL_SYSCTL_HELP_I2C_METHOD \ +"\nI2C access method that driver will use:\n" \ +"\t0 - best available method\n" \ +"\t1 - bit bang via I2CPARAMS register\n" \ +"\t2 - register read/write via I2CCMD register\n" \ +"\t3 - Use Admin Queue command (best)\n" \ +"Using the Admin Queue is only supported on 710 devices with FW version 1.7 or higher" + extern const char * const ixl_fc_string[6]; MALLOC_DECLARE(M_IXL); @@ -199,13 +242,6 @@ MALLOC_DECLARE(M_IXL); #define i40e_send_vf_nack(pf, vf, op, st) \ ixl_send_vf_nack_msg((pf), (vf), (op), (st), __FILE__, __LINE__) -#define IXL_PF_LOCK_INIT(_sc, _name) \ - mtx_init(&(_sc)->pf_mtx, _name, "IXL PF Lock", MTX_DEF) -#define IXL_PF_LOCK(_sc) mtx_lock(&(_sc)->pf_mtx) -#define IXL_PF_UNLOCK(_sc) mtx_unlock(&(_sc)->pf_mtx) -#define IXL_PF_LOCK_DESTROY(_sc) mtx_destroy(&(_sc)->pf_mtx) -#define IXL_PF_LOCK_ASSERT(_sc) mtx_assert(&(_sc)->pf_mtx, MA_OWNED) - /* Debug printing */ #define ixl_dbg(p, m, s, ...) ixl_debug_core(p, m, s, ##__VA_ARGS__) void ixl_debug_core(struct ixl_pf *, enum ixl_dbg_mask, char *, ...); @@ -216,11 +252,8 @@ void ixl_debug_core(struct ixl_pf *, enum ixl_dbg_mask, char *, ...); /* For netmap(4) compatibility */ #define ixl_disable_intr(vsi) ixl_disable_rings_intr(vsi) -/* - * PF-only function declarations - */ - -int ixl_setup_interface(device_t, struct ixl_vsi *); +/* PF-only function declarations */ +int ixl_setup_interface(device_t, struct ixl_pf *); void ixl_print_nvm_cmd(device_t, struct i40e_nvm_access *); char * ixl_aq_speed_to_str(enum i40e_aq_link_speed); @@ -230,9 +263,9 @@ void ixl_init(void *); void ixl_local_timer(void *); void ixl_register_vlan(void *, struct ifnet *, u16); void ixl_unregister_vlan(void *, struct ifnet *, u16); -void ixl_intr(void *); -void ixl_msix_que(void *); -void ixl_msix_adminq(void *); +int ixl_intr(void *); +int ixl_msix_que(void *); +int ixl_msix_adminq(void *); void ixl_do_adminq(void *, int); int ixl_res_alloc_cmp(const void *, const void *); @@ -264,7 +297,6 @@ void ixl_add_vsi_sysctls(struct ixl_pf *pf, struct ixl_vsi *vsi, struct sysctl_c int ixl_get_hw_capabilities(struct ixl_pf *); void ixl_link_up_msg(struct ixl_pf *); void ixl_update_link_status(struct ixl_pf *); -int ixl_allocate_pci_resources(struct ixl_pf *); int ixl_setup_stations(struct ixl_pf *); int ixl_switch_config(struct ixl_pf *); void ixl_stop_locked(struct ixl_pf *); @@ -304,8 +336,8 @@ void ixl_handle_empr_reset(struct ixl_pf *); int ixl_prepare_for_reset(struct ixl_pf *pf, bool is_up); int ixl_rebuild_hw_structs_after_reset(struct ixl_pf *, bool is_up); -void ixl_set_queue_rx_itr(struct ixl_queue *); -void ixl_set_queue_tx_itr(struct ixl_queue *); +void ixl_set_queue_rx_itr(struct ixl_rx_queue *); +void ixl_set_queue_tx_itr(struct ixl_tx_queue *); void ixl_add_filter(struct ixl_vsi *, const u8 *, s16 vlan); void ixl_del_filter(struct ixl_vsi *, const u8 *, s16 vlan); @@ -345,19 +377,31 @@ void ixl_free_mac_filters(struct ixl_vsi *vsi); void ixl_update_vsi_stats(struct ixl_vsi *); void ixl_vsi_reset_stats(struct ixl_vsi *); -int ixl_vsi_setup_queues(struct ixl_vsi *vsi); void ixl_vsi_free_queues(struct ixl_vsi *vsi); +void ixl_if_init(if_ctx_t ctx); +void ixl_if_stop(if_ctx_t ctx); + /* * I2C Function prototypes */ int ixl_find_i2c_interface(struct ixl_pf *); -s32 ixl_read_i2c_byte(struct ixl_pf *pf, u8 byte_offset, +s32 ixl_read_i2c_byte_bb(struct ixl_pf *pf, u8 byte_offset, + u8 dev_addr, u8 *data); +s32 ixl_write_i2c_byte_bb(struct ixl_pf *pf, u8 byte_offset, + u8 dev_addr, u8 data); +s32 ixl_read_i2c_byte_reg(struct ixl_pf *pf, u8 byte_offset, + u8 dev_addr, u8 *data); +s32 ixl_write_i2c_byte_reg(struct ixl_pf *pf, u8 byte_offset, + u8 dev_addr, u8 data); +s32 ixl_read_i2c_byte_aq(struct ixl_pf *pf, u8 byte_offset, u8 dev_addr, u8 *data); -s32 ixl_write_i2c_byte(struct ixl_pf *pf, u8 byte_offset, +s32 ixl_write_i2c_byte_aq(struct ixl_pf *pf, u8 byte_offset, u8 dev_addr, u8 data); int ixl_get_fw_lldp_status(struct ixl_pf *pf); int ixl_attach_get_link_status(struct ixl_pf *); +u64 ixl_max_aq_speed_to_value(u8); +void ixl_handle_vflr(void *, int); #endif /* _IXL_PF_H_ */ |