cregit-Linux how code gets into the kernel

Release 4.10 drivers/net/ethernet/emulex/benet/be_main.c

/*
 * Copyright (C) 2005 - 2016 Broadcom
 * All rights reserved.
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU General Public License version 2
 * as published by the Free Software Foundation.  The full GNU General
 * Public License is included in this distribution in the file called COPYING.
 *
 * Contact Information:
 * linux-drivers@emulex.com
 *
 * Emulex
 * 3333 Susan Street
 * Costa Mesa, CA 92626
 */

#include <linux/prefetch.h>
#include <linux/module.h>
#include "be.h"
#include "be_cmds.h"
#include <asm/div64.h>
#include <linux/aer.h>
#include <linux/if_bridge.h>
#include <net/busy_poll.h>
#include <net/vxlan.h>


MODULE_VERSION(DRV_VER);
MODULE_DESCRIPTION(DRV_DESC " " DRV_VER);
MODULE_AUTHOR("Emulex Corporation");
MODULE_LICENSE("GPL");

/* num_vfs module param is obsolete.
 * Use sysfs method to enable/disable VFs.
 */

static unsigned int num_vfs;
module_param(num_vfs, uint, S_IRUGO);
MODULE_PARM_DESC(num_vfs, "Number of PCI VFs to initialize");


static ushort rx_frag_size = 2048;
module_param(rx_frag_size, ushort, S_IRUGO);
MODULE_PARM_DESC(rx_frag_size, "Size of a fragment that holds rcvd data.");

/* Per-module error detection/recovery workq shared across all functions.
 * Each function schedules its own work request on this shared workq.
 */

static struct workqueue_struct *be_err_recovery_workq;


static const struct pci_device_id be_dev_ids[] = {
	{ PCI_DEVICE(BE_VENDOR_ID, BE_DEVICE_ID1) },
	{ PCI_DEVICE(BE_VENDOR_ID, BE_DEVICE_ID2) },
	{ PCI_DEVICE(BE_VENDOR_ID, OC_DEVICE_ID1) },
	{ PCI_DEVICE(BE_VENDOR_ID, OC_DEVICE_ID2) },
	{ PCI_DEVICE(EMULEX_VENDOR_ID, OC_DEVICE_ID3)},
	{ PCI_DEVICE(EMULEX_VENDOR_ID, OC_DEVICE_ID4)},
	{ PCI_DEVICE(EMULEX_VENDOR_ID, OC_DEVICE_ID5)},
	{ PCI_DEVICE(EMULEX_VENDOR_ID, OC_DEVICE_ID6)},
	{ 0 }
};
MODULE_DEVICE_TABLE(pci, be_dev_ids);

/* Workqueue used by all functions for defering cmd calls to the adapter */

static struct workqueue_struct *be_wq;

/* UE Status Low CSR */

static const char * const ue_status_low_desc[] = {
	"CEV",
	"CTX",
	"DBUF",
	"ERX",
	"Host",
	"MPU",
	"NDMA",
	"PTC ",
	"RDMA ",
	"RXF ",
	"RXIPS ",
	"RXULP0 ",
	"RXULP1 ",
	"RXULP2 ",
	"TIM ",
	"TPOST ",
	"TPRE ",
	"TXIPS ",
	"TXULP0 ",
	"TXULP1 ",
	"UC ",
	"WDMA ",
	"TXULP2 ",
	"HOST1 ",
	"P0_OB_LINK ",
	"P1_OB_LINK ",
	"HOST_GPIO ",
	"MBOX ",
	"ERX2 ",
	"SPARE ",
	"JTAG ",
	"MPU_INTPEND "
};

/* UE Status High CSR */

static const char * const ue_status_hi_desc[] = {
	"LPCMEMHOST",
	"MGMT_MAC",
	"PCS0ONLINE",
	"MPU_IRAM",
	"PCS1ONLINE",
	"PCTL0",
	"PCTL1",
	"PMEM",
	"RR",
	"TXPB",
	"RXPP",
	"XAUI",
	"TXP",
	"ARM",
	"IPC",
	"HOST2",
	"HOST3",
	"HOST4",
	"HOST5",
	"HOST6",
	"HOST7",
	"ECRC",
	"Poison TLP",
	"NETC",
	"PERIPH",
	"LLTXULP",
	"D2P",
	"RCON",
	"LDMA",
	"LLTXP",
	"LLTXPB",
	"Unknown"
};


#define BE_VF_IF_EN_FLAGS	(BE_IF_FLAGS_UNTAGGED | \
                                 BE_IF_FLAGS_BROADCAST | \
                                 BE_IF_FLAGS_MULTICAST | \
                                 BE_IF_FLAGS_PASS_L3L4_ERRORS)


static void be_queue_free(struct be_adapter *adapter, struct be_queue_info *q) { struct be_dma_mem *mem = &q->dma_mem; if (mem->va) { dma_free_coherent(&adapter->pdev->dev, mem->size, mem->va, mem->dma); mem->va = NULL; } }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla5893.55%266.67%
ivan veceraivan vecera46.45%133.33%
Total62100.00%3100.00%


static int be_queue_alloc(struct be_adapter *adapter, struct be_queue_info *q, u16 len, u16 entry_size) { struct be_dma_mem *mem = &q->dma_mem; memset(q, 0, sizeof(*q)); q->len = len; q->entry_size = entry_size; mem->size = len * entry_size; mem->va = dma_zalloc_coherent(&adapter->pdev->dev, mem->size, &mem->dma, GFP_KERNEL); if (!mem->va) return -ENOMEM; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla9894.23%250.00%
ivan veceraivan vecera54.81%125.00%
joe perchesjoe perches10.96%125.00%
Total104100.00%4100.00%


static void be_reg_intr_set(struct be_adapter *adapter, bool enable) { u32 reg, enabled; pci_read_config_dword(adapter->pdev, PCICFG_MEMBAR_CTRL_INT_CTRL_OFFSET, &reg); enabled = reg & MEMBAR_CTRL_INT_CTRL_HOSTINTR_MASK; if (!enabled && enable) reg |= MEMBAR_CTRL_INT_CTRL_HOSTINTR_MASK; else if (enabled && !enable) reg &= ~MEMBAR_CTRL_INT_CTRL_HOSTINTR_MASK; else return; pci_write_config_dword(adapter->pdev, PCICFG_MEMBAR_CTRL_INT_CTRL_OFFSET, reg); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla7398.65%480.00%
somnath kotursomnath kotur11.35%120.00%
Total74100.00%5100.00%


static void be_intr_set(struct be_adapter *adapter, bool enable) { int status = 0; /* On lancer interrupts can't be controlled via this register */ if (lancer_chip(adapter)) return; if (be_check_error(adapter, BE_ERROR_EEH)) return; status = be_cmd_intr_set(adapter, enable); if (status) be_reg_intr_set(adapter, enable); }

Contributors

PersonTokensPropCommitsCommitProp
somnath kotursomnath kotur5391.38%150.00%
venkat duvvuruvenkat duvvuru58.62%150.00%
Total58100.00%2100.00%


static void be_rxq_notify(struct be_adapter *adapter, u16 qid, u16 posted) { u32 val = 0; if (be_check_error(adapter, BE_ERROR_HW)) return; val |= qid & DB_RQ_RING_ID_MASK; val |= posted << DB_RQ_NUM_POSTED_SHIFT; wmb(); iowrite32(val, adapter->db + DB_RQ_OFFSET); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla4882.76%375.00%
venkat duvvuruvenkat duvvuru1017.24%125.00%
Total58100.00%4100.00%


static void be_txq_notify(struct be_adapter *adapter, struct be_tx_obj *txo, u16 posted) { u32 val = 0; if (be_check_error(adapter, BE_ERROR_HW)) return; val |= txo->q.id & DB_TXULP_RING_ID_MASK; val |= (posted & DB_TXULP_NUM_POSTED_MASK) << DB_TXULP_NUM_POSTED_SHIFT; wmb(); iowrite32(val, adapter->db + txo->db_offset); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla4868.57%360.00%
vasundhara volamvasundhara volam1217.14%120.00%
venkat duvvuruvenkat duvvuru1014.29%120.00%
Total70100.00%5100.00%


static void be_eq_notify(struct be_adapter *adapter, u16 qid, bool arm, bool clear_int, u16 num_popped, u32 eq_delay_mult_enc) { u32 val = 0; val |= qid & DB_EQ_RING_ID_MASK; val |= ((qid & DB_EQ_RING_ID_EXT_MASK) << DB_EQ_RING_ID_EXT_MASK_SHIFT); if (be_check_error(adapter, BE_ERROR_HW)) return; if (arm) val |= 1 << DB_EQ_REARM_SHIFT; if (clear_int) val |= 1 << DB_EQ_CLR_SHIFT; val |= 1 << DB_EQ_EVNT_SHIFT; val |= num_popped << DB_EQ_NUM_POPPED_SHIFT; val |= eq_delay_mult_enc << DB_EQ_R2I_DLY_SHIFT; iowrite32(val, adapter->db + DB_EQ_OFFSET); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla9487.04%466.67%
padmanabh ratnakarpadmanabh ratnakar98.33%116.67%
venkat duvvuruvenkat duvvuru54.63%116.67%
Total108100.00%6100.00%


void be_cq_notify(struct be_adapter *adapter, u16 qid, bool arm, u16 num_popped) { u32 val = 0; val |= qid & DB_CQ_RING_ID_MASK; val |= ((qid & DB_CQ_RING_ID_EXT_MASK) << DB_CQ_RING_ID_EXT_MASK_SHIFT); if (be_check_error(adapter, BE_ERROR_HW)) return; if (arm) val |= 1 << DB_CQ_REARM_SHIFT; val |= num_popped << DB_CQ_NUM_POPPED_SHIFT; iowrite32(val, adapter->db + DB_CQ_OFFSET); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla7493.67%480.00%
venkat duvvuruvenkat duvvuru56.33%120.00%
Total79100.00%5100.00%


static int be_dev_mac_add(struct be_adapter *adapter, u8 *mac) { int i; /* Check if mac has already been added as part of uc-list */ for (i = 0; i < adapter->uc_macs; i++) { if (ether_addr_equal(adapter->uc_list[i].mac, mac)) { /* mac already added, skip addition */ adapter->pmac_id[0] = adapter->pmac_id[i + 1]; return 0; } } return be_cmd_pmac_add(adapter, mac, adapter->if_handle, &adapter->pmac_id[0], 0); }

Contributors

PersonTokensPropCommitsCommitProp
suresh reddysuresh reddy9497.92%150.00%
ivan veceraivan vecera22.08%150.00%
Total96100.00%2100.00%


static void be_dev_mac_del(struct be_adapter *adapter, int pmac_id) { int i; /* Skip deletion if the programmed mac is * being used in uc-list */ for (i = 0; i < adapter->uc_macs; i++) { if (adapter->pmac_id[i + 1] == pmac_id) return; } be_cmd_pmac_del(adapter, adapter->if_handle, pmac_id, 0); }

Contributors

PersonTokensPropCommitsCommitProp
suresh reddysuresh reddy62100.00%1100.00%
Total62100.00%1100.00%


static int be_mac_addr_set(struct net_device *netdev, void *p) { struct be_adapter *adapter = netdev_priv(netdev); struct device *dev = &adapter->pdev->dev; struct sockaddr *addr = p; int status; u8 mac[ETH_ALEN]; u32 old_pmac_id = adapter->pmac_id[0]; if (!is_valid_ether_addr(addr->sa_data)) return -EADDRNOTAVAIL; /* Proceed further only if, User provided MAC is different * from active MAC */ if (ether_addr_equal(addr->sa_data, adapter->dev_mac)) return 0; /* BE3 VFs without FILTMGMT privilege are not allowed to set its MAC * address */ if (BEx_chip(adapter) && be_virtfn(adapter) && !check_privilege(adapter, BE_PRIV_FILTMGMT)) return -EPERM; /* if device is not running, copy MAC to netdev->dev_addr */ if (!netif_running(netdev)) goto done; /* The PMAC_ADD cmd may fail if the VF doesn't have FILTMGMT * privilege or if PF did not provision the new MAC address. * On BE3, this cmd will always fail if the VF doesn't have the * FILTMGMT privilege. This failure is OK, only if the PF programmed * the MAC for the VF. */ mutex_lock(&adapter->rx_filter_lock); status = be_dev_mac_add(adapter, (u8 *)addr->sa_data); if (!status) { /* Delete the old programmed MAC. This call may fail if the * old MAC was already deleted by the PF driver. */ if (adapter->pmac_id[0] != old_pmac_id) be_dev_mac_del(adapter, old_pmac_id); } mutex_unlock(&adapter->rx_filter_lock); /* Decide if the new MAC is successfully activated only after * querying the FW */ status = be_cmd_get_active_mac(adapter, adapter->pmac_id[0], mac, adapter->if_handle, true, 0); if (status) goto err; /* The MAC change did not happen, either due to lack of privilege * or PF didn't pre-provision. */ if (!ether_addr_equal(addr->sa_data, mac)) { status = -EPERM; goto err; } /* Remember currently programmed MAC */ ether_addr_copy(adapter->dev_mac, addr->sa_data); done: ether_addr_copy(netdev->dev_addr, addr->sa_data); dev_info(dev, "MAC address changed to %pM\n", addr->sa_data); return 0; err: dev_warn(dev, "MAC address change to %pM failed\n", addr->sa_data); return status; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla13043.48%213.33%
suresh reddysuresh reddy4515.05%320.00%
somnath kotursomnath kotur3210.70%16.67%
ivan veceraivan vecera289.36%213.33%
ajit khapardeajit khaparde186.02%320.00%
kalesh purayilkalesh purayil165.35%16.67%
vasundhara volamvasundhara volam155.02%16.67%
padmanabh ratnakarpadmanabh ratnakar134.35%16.67%
ding tianhongding tianhong20.67%16.67%
Total299100.00%15100.00%

/* BE2 supports only v0 cmd */
static void *hw_stats_from_cmd(struct be_adapter *adapter) { if (BE2_chip(adapter)) { struct be_cmd_resp_get_stats_v0 *cmd = adapter->stats_cmd.va; return &cmd->hw_stats; } else if (BE3_chip(adapter)) { struct be_cmd_resp_get_stats_v1 *cmd = adapter->stats_cmd.va; return &cmd->hw_stats; } else { struct be_cmd_resp_get_stats_v2 *cmd = adapter->stats_cmd.va; return &cmd->hw_stats; } }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla5564.71%133.33%
ajit khapardeajit khaparde3035.29%266.67%
Total85100.00%3100.00%

/* BE2 supports only v0 cmd */
static void *be_erx_stats_from_cmd(struct be_adapter *adapter) { if (BE2_chip(adapter)) { struct be_hw_stats_v0 *hw_stats = hw_stats_from_cmd(adapter); return &hw_stats->erx; } else if (BE3_chip(adapter)) { struct be_hw_stats_v1 *hw_stats = hw_stats_from_cmd(adapter); return &hw_stats->erx; } else { struct be_hw_stats_v2 *hw_stats = hw_stats_from_cmd(adapter); return &hw_stats->erx; } }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla5567.07%150.00%
ajit khapardeajit khaparde2732.93%150.00%
Total82100.00%2100.00%


static void populate_be_v0_stats(struct be_adapter *adapter) { struct be_hw_stats_v0 *hw_stats = hw_stats_from_cmd(adapter); struct be_pmem_stats *pmem_sts = &hw_stats->pmem; struct be_rxf_stats_v0 *rxf_stats = &hw_stats->rxf; struct be_port_rxf_stats_v0 *port_stats = &rxf_stats->port[adapter->port_num]; struct be_drv_stats *drvs = &adapter->drv_stats; be_dws_le_to_cpu(hw_stats, sizeof(*hw_stats)); drvs->rx_pause_frames = port_stats->rx_pause_frames; drvs->rx_crc_errors = port_stats->rx_crc_errors; drvs->rx_control_frames = port_stats->rx_control_frames; drvs->rx_in_range_errors = port_stats->rx_in_range_errors; drvs->rx_frame_too_long = port_stats->rx_frame_too_long; drvs->rx_dropped_runt = port_stats->rx_dropped_runt; drvs->rx_ip_checksum_errs = port_stats->rx_ip_checksum_errs; drvs->rx_tcp_checksum_errs = port_stats->rx_tcp_checksum_errs; drvs->rx_udp_checksum_errs = port_stats->rx_udp_checksum_errs; drvs->rxpp_fifo_overflow_drop = port_stats->rx_fifo_overflow; drvs->rx_dropped_tcp_length = port_stats->rx_dropped_tcp_length; drvs->rx_dropped_too_small = port_stats->rx_dropped_too_small; drvs->rx_dropped_too_short = port_stats->rx_dropped_too_short; drvs->rx_out_range_errors = port_stats->rx_out_range_errors; drvs->rx_input_fifo_overflow_drop = port_stats->rx_input_fifo_overflow; drvs->rx_dropped_header_too_small = port_stats->rx_dropped_header_too_small; drvs->rx_address_filtered = port_stats->rx_address_filtered + port_stats->rx_vlan_filtered; drvs->rx_alignment_symbol_errors = port_stats->rx_alignment_symbol_errors; drvs->tx_pauseframes = port_stats->tx_pauseframes; drvs->tx_controlframes = port_stats->tx_controlframes; if (adapter->port_num) drvs->jabber_events = rxf_stats->port1_jabber_events; else drvs->jabber_events = rxf_stats->port0_jabber_events; drvs->rx_drops_no_pbuf = rxf_stats->rx_drops_no_pbuf; drvs->rx_drops_no_erx_descr = rxf_stats->rx_drops_no_erx_descr; drvs->forwarded_packets = rxf_stats->forwarded_packets; drvs->rx_drops_mtu = rxf_stats->rx_drops_mtu; drvs->rx_drops_no_tpre_descr = rxf_stats->rx_drops_no_tpre_descr; drvs->rx_drops_too_many_frags = rxf_stats->rx_drops_too_many_frags; adapter->drv_stats.eth_red_drops = pmem_sts->eth_red_drops; }

Contributors

PersonTokensPropCommitsCommitProp
ajit khapardeajit khaparde27083.85%120.00%
sathya perlasathya perla4915.22%360.00%
suresh reddysuresh reddy30.93%120.00%
Total322100.00%5100.00%


static void populate_be_v1_stats(struct be_adapter *adapter) { struct be_hw_stats_v1 *hw_stats = hw_stats_from_cmd(adapter); struct be_pmem_stats *pmem_sts = &hw_stats->pmem; struct be_rxf_stats_v1 *rxf_stats = &hw_stats->rxf; struct be_port_rxf_stats_v1 *port_stats = &rxf_stats->port[adapter->port_num]; struct be_drv_stats *drvs = &adapter->drv_stats; be_dws_le_to_cpu(hw_stats, sizeof(*hw_stats)); drvs->pmem_fifo_overflow_drop = port_stats->pmem_fifo_overflow_drop; drvs->rx_priority_pause_frames = port_stats->rx_priority_pause_frames; drvs->rx_pause_frames = port_stats->rx_pause_frames; drvs->rx_crc_errors = port_stats->rx_crc_errors; drvs->rx_control_frames = port_stats->rx_control_frames; drvs->rx_in_range_errors = port_stats->rx_in_range_errors; drvs->rx_frame_too_long = port_stats->rx_frame_too_long; drvs->rx_dropped_runt = port_stats->rx_dropped_runt; drvs->rx_ip_checksum_errs = port_stats->rx_ip_checksum_errs; drvs->rx_tcp_checksum_errs = port_stats->rx_tcp_checksum_errs; drvs->rx_udp_checksum_errs = port_stats->rx_udp_checksum_errs; drvs->rx_dropped_tcp_length = port_stats->rx_dropped_tcp_length; drvs->rx_dropped_too_small = port_stats->rx_dropped_too_small; drvs->rx_dropped_too_short = port_stats->rx_dropped_too_short; drvs->rx_out_range_errors = port_stats->rx_out_range_errors; drvs->rx_dropped_header_too_small = port_stats->rx_dropped_header_too_small; drvs->rx_input_fifo_overflow_drop = port_stats->rx_input_fifo_overflow_drop; drvs->rx_address_filtered = port_stats->rx_address_filtered; drvs->rx_alignment_symbol_errors = port_stats->rx_alignment_symbol_errors; drvs->rxpp_fifo_overflow_drop = port_stats->rxpp_fifo_overflow_drop; drvs->tx_pauseframes = port_stats->tx_pauseframes; drvs->tx_controlframes = port_stats->tx_controlframes; drvs->tx_priority_pauseframes = port_stats->tx_priority_pauseframes; drvs->jabber_events = port_stats->jabber_events; drvs->rx_drops_no_pbuf = rxf_stats->rx_drops_no_pbuf; drvs->rx_drops_no_erx_descr = rxf_stats->rx_drops_no_erx_descr; drvs->forwarded_packets = rxf_stats->forwarded_packets; drvs->rx_drops_mtu = rxf_stats->rx_drops_mtu; drvs->rx_drops_no_tpre_descr = rxf_stats->rx_drops_no_tpre_descr; drvs->rx_drops_too_many_frags = rxf_stats->rx_drops_too_many_frags; adapter->drv_stats.eth_red_drops = pmem_sts->eth_red_drops; }

Contributors

PersonTokensPropCommitsCommitProp
ajit khapardeajit khaparde28587.16%350.00%
sathya perlasathya perla4012.23%233.33%
suresh reddysuresh reddy20.61%116.67%
Total327100.00%6100.00%


static void populate_be_v2_stats(struct be_adapter *adapter) { struct be_hw_stats_v2 *hw_stats = hw_stats_from_cmd(adapter); struct be_pmem_stats *pmem_sts = &hw_stats->pmem; struct be_rxf_stats_v2 *rxf_stats = &hw_stats->rxf; struct be_port_rxf_stats_v2 *port_stats = &rxf_stats->port[adapter->port_num]; struct be_drv_stats *drvs = &adapter->drv_stats; be_dws_le_to_cpu(hw_stats, sizeof(*hw_stats)); drvs->pmem_fifo_overflow_drop = port_stats->pmem_fifo_overflow_drop; drvs->rx_priority_pause_frames = port_stats->rx_priority_pause_frames; drvs->rx_pause_frames = port_stats->rx_pause_frames; drvs->rx_crc_errors = port_stats->rx_crc_errors; drvs->rx_control_frames = port_stats->rx_control_frames; drvs->rx_in_range_errors = port_stats->rx_in_range_errors; drvs->rx_frame_too_long = port_stats->rx_frame_too_long; drvs->rx_dropped_runt = port_stats->rx_dropped_runt; drvs->rx_ip_checksum_errs = port_stats->rx_ip_checksum_errs; drvs->rx_tcp_checksum_errs = port_stats->rx_tcp_checksum_errs; drvs->rx_udp_checksum_errs = port_stats->rx_udp_checksum_errs; drvs->rx_dropped_tcp_length = port_stats->rx_dropped_tcp_length; drvs->rx_dropped_too_small = port_stats->rx_dropped_too_small; drvs->rx_dropped_too_short = port_stats->rx_dropped_too_short; drvs->rx_out_range_errors = port_stats->rx_out_range_errors; drvs->rx_dropped_header_too_small = port_stats->rx_dropped_header_too_small; drvs->rx_input_fifo_overflow_drop = port_stats->rx_input_fifo_overflow_drop; drvs->rx_address_filtered = port_stats->rx_address_filtered; drvs->rx_alignment_symbol_errors = port_stats->rx_alignment_symbol_errors; drvs->rxpp_fifo_overflow_drop = port_stats->rxpp_fifo_overflow_drop; drvs->tx_pauseframes = port_stats->tx_pauseframes; drvs->tx_controlframes = port_stats->tx_controlframes; drvs->tx_priority_pauseframes = port_stats->tx_priority_pauseframes; drvs->jabber_events = port_stats->jabber_events; drvs->rx_drops_no_pbuf = rxf_stats->rx_drops_no_pbuf; drvs->rx_drops_no_erx_descr = rxf_stats->rx_drops_no_erx_descr; drvs->forwarded_packets = rxf_stats->forwarded_packets; drvs->rx_drops_mtu = rxf_stats->rx_drops_mtu; drvs->rx_drops_no_tpre_descr = rxf_stats->rx_drops_no_tpre_descr; drvs->rx_drops_too_many_frags = rxf_stats->rx_drops_too_many_frags; adapter->drv_stats.eth_red_drops = pmem_sts->eth_red_drops; if (be_roce_supported(adapter)) { drvs->rx_roce_bytes_lsd = port_stats->roce_bytes_received_lsd; drvs->rx_roce_bytes_msd = port_stats->roce_bytes_received_msd; drvs->rx_roce_frames = port_stats->roce_frames_received; drvs->roce_drops_crc = port_stats->roce_drops_crc; drvs->roce_drops_payload_len = port_stats->roce_drops_payload_len; } }

Contributors

PersonTokensPropCommitsCommitProp
ajit khapardeajit khaparde376100.00%2100.00%
Total376100.00%2100.00%


static void populate_lancer_stats(struct be_adapter *adapter) { struct be_drv_stats *drvs = &adapter->drv_stats; struct lancer_pport_stats *pport_stats = pport_stats_from_cmd(adapter); be_dws_le_to_cpu(pport_stats, sizeof(*pport_stats)); drvs->rx_pause_frames = pport_stats->rx_pause_frames_lo; drvs->rx_crc_errors = pport_stats->rx_crc_errors_lo; drvs->rx_control_frames = pport_stats->rx_control_frames_lo; drvs->rx_in_range_errors = pport_stats->rx_in_range_errors; drvs->rx_frame_too_long = pport_stats->rx_frames_too_long_lo; drvs->rx_dropped_runt = pport_stats->rx_dropped_runt; drvs->rx_ip_checksum_errs = pport_stats->rx_ip_checksum_errors; drvs->rx_tcp_checksum_errs = pport_stats->rx_tcp_checksum_errors; drvs->rx_udp_checksum_errs = pport_stats->rx_udp_checksum_errors; drvs->rx_dropped_tcp_length = pport_stats->rx_dropped_invalid_tcp_length; drvs->rx_dropped_too_small = pport_stats->rx_dropped_too_small; drvs->rx_dropped_too_short = pport_stats->rx_dropped_too_short; drvs->rx_out_range_errors = pport_stats->rx_out_of_range_errors; drvs->rx_dropped_header_too_small = pport_stats->rx_dropped_header_too_small; drvs->rx_input_fifo_overflow_drop = pport_stats->rx_fifo_overflow; drvs->rx_address_filtered = pport_stats->rx_address_filtered + pport_stats->rx_vlan_filtered; drvs->rx_alignment_symbol_errors = pport_stats->rx_symbol_errors_lo; drvs->rxpp_fifo_overflow_drop = pport_stats->rx_fifo_overflow; drvs->tx_pauseframes = pport_stats->tx_pause_frames_lo; drvs->tx_controlframes = pport_stats->tx_control_frames_lo; drvs->jabber_events = pport_stats->rx_jabbers; drvs->forwarded_packets = pport_stats->num_forwards_lo; drvs->rx_drops_mtu = pport_stats->rx_drops_mtu_lo; drvs->rx_drops_too_many_frags = pport_stats->rx_drops_too_many_frags_lo; }

Contributors

PersonTokensPropCommitsCommitProp
selvin xavierselvin xavier22192.86%240.00%
sathya perlasathya perla145.88%240.00%
suresh reddysuresh reddy31.26%120.00%
Total238100.00%5100.00%


static void accumulate_16bit_val(u32 *acc, u16 val) { #define lo(x) (x & 0xFFFF) #define hi(x) (x & 0xFFFF0000) bool wrapped = val < lo(*acc); u32 newacc = hi(*acc) + val; if (wrapped) newacc += 65536; ACCESS_ONCE(*acc) = newacc; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla65100.00%1100.00%
Total65100.00%1100.00%


static void populate_erx_stats(struct be_adapter *adapter, struct be_rx_obj *rxo, u32 erx_stat) { if (!BEx_chip(adapter)) rx_stats(rxo)->rx_drops_no_frags = erx_stat; else /* below erx HW counter can actually wrap around after * 65535. Driver accumulates a 32-bit value */ accumulate_16bit_val(&rx_stats(rxo)->rx_drops_no_frags, (u16)erx_stat); }

Contributors

PersonTokensPropCommitsCommitProp
ajit khapardeajit khaparde5398.15%150.00%
jingoo hanjingoo han11.85%150.00%
Total54100.00%2100.00%


void be_parse_stats(struct be_adapter *adapter) { struct be_erx_stats_v2 *erx = be_erx_stats_from_cmd(adapter); struct be_rx_obj *rxo; int i; u32 erx_stat; if (lancer_chip(adapter)) { populate_lancer_stats(adapter); } else { if (BE2_chip(adapter)) populate_be_v0_stats(adapter); else if (BE3_chip(adapter)) /* for BE3 */ populate_be_v1_stats(adapter); else populate_be_v2_stats(adapter); /* erx_v2 is longer than v0, v1. use v2 for v0, v1 access */ for_all_rx_queues(adapter, rxo, i) { erx_stat = erx->rx_drops_no_fragments[rxo->q.id]; populate_erx_stats(adapter, rxo, erx_stat); } } }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla5952.21%444.44%
ajit khapardeajit khaparde3934.51%333.33%
selvin xavierselvin xavier1210.62%111.11%
padmanabh ratnakarpadmanabh ratnakar32.65%111.11%
Total113100.00%9100.00%


static struct rtnl_link_stats64 *be_get_stats64(struct net_device *netdev, struct rtnl_link_stats64 *stats) { struct be_adapter *adapter = netdev_priv(netdev); struct be_drv_stats *drvs = &adapter->drv_stats; struct be_rx_obj *rxo; struct be_tx_obj *txo; u64 pkts, bytes; unsigned int start; int i; for_all_rx_queues(adapter, rxo, i) { const struct be_rx_stats *rx_stats = rx_stats(rxo); do { start = u64_stats_fetch_begin_irq(&rx_stats->sync); pkts = rx_stats(rxo)->rx_pkts; bytes = rx_stats(rxo)->rx_bytes; } while (u64_stats_fetch_retry_irq(&rx_stats->sync, start)); stats->rx_packets += pkts; stats->rx_bytes += bytes; stats->multicast += rx_stats(rxo)->rx_mcast_pkts; stats->rx_dropped += rx_stats(rxo)->rx_drops_no_skbs + rx_stats(rxo)->rx_drops_no_frags; } for_all_tx_queues(adapter, txo, i) { const struct be_tx_stats *tx_stats = tx_stats(txo); do { start = u64_stats_fetch_begin_irq(&tx_stats->sync); pkts = tx_stats(txo)->tx_pkts; bytes = tx_stats(txo)->tx_bytes; } while (u64_stats_fetch_retry_irq(&tx_stats->sync, start)); stats->tx_packets += pkts; stats->tx_bytes += bytes; } /* bad pkts received */ stats->rx_errors = drvs->rx_crc_errors + drvs->rx_alignment_symbol_errors + drvs->rx_in_range_errors + drvs->rx_out_range_errors + drvs->rx_frame_too_long + drvs->rx_dropped_too_small + drvs->rx_dropped_too_short + drvs->rx_dropped_header_too_small + drvs->rx_dropped_tcp_length + drvs->rx_dropped_runt; /* detailed rx errors */ stats->rx_length_errors = drvs->rx_in_range_errors + drvs->rx_out_range_errors + drvs->rx_frame_too_long; stats->rx_crc_errors = drvs->rx_crc_errors; /* frame alignment errors */ stats->rx_frame_errors = drvs->rx_alignment_symbol_errors; /* receiver fifo overrun */ /* drops_no_pbuf is no per i/f, it's per BE card */ stats->rx_fifo_errors = drvs->rxpp_fifo_overflow_drop + drvs->rx_input_fifo_overflow_drop + drvs->rx_drops_no_pbuf; return stats; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla30087.46%758.33%
ajit khapardeajit khaparde339.62%325.00%
eric dumazeteric dumazet61.75%18.33%
eric w. biedermaneric w. biederman41.17%18.33%
Total343100.00%12100.00%


void be_link_status_update(struct be_adapter *adapter, u8 link_status) { struct net_device *netdev = adapter->netdev; if (!(adapter->flags & BE_FLAGS_LINK_STATUS_INIT)) { netif_carrier_off(netdev); adapter->flags |= BE_FLAGS_LINK_STATUS_INIT; } if (link_status) netif_carrier_on(netdev); else netif_carrier_off(netdev); netdev_info(netdev, "Link is %s\n", link_status ? "Up" : "Down"); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla3648.65%555.56%
ajit khapardeajit khaparde2432.43%222.22%
ivan veceraivan vecera1317.57%111.11%
stephen hemmingerstephen hemminger11.35%111.11%
Total74100.00%9100.00%


static int be_gso_hdr_len(struct sk_buff *skb) { if (skb->encapsulation) return skb_inner_transport_offset(skb) + inner_tcp_hdrlen(skb); return skb_transport_offset(skb) + tcp_hdrlen(skb); }

Contributors

PersonTokensPropCommitsCommitProp
sriharsha basavapatnasriharsha basavapatna39100.00%1100.00%
Total39100.00%1100.00%


static void be_tx_stats_update(struct be_tx_obj *txo, struct sk_buff *skb) { struct be_tx_stats *stats = tx_stats(txo); u32 tx_pkts = skb_shinfo(skb)->gso_segs ? : 1; /* Account for headers which get duplicated in TSO pkt */ u32 dup_hdr_len = tx_pkts > 1 ? be_gso_hdr_len(skb) * (tx_pkts - 1) : 0; u64_stats_update_begin(&stats->sync); stats->tx_reqs++; stats->tx_bytes += skb->len + dup_hdr_len; stats->tx_pkts += tx_pkts; if (skb->encapsulation && skb->ip_summed == CHECKSUM_PARTIAL) stats->tx_vxlan_offload_pkts += tx_pkts; u64_stats_update_end(&stats->sync); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla5850.43%666.67%
sriharsha basavapatnasriharsha basavapatna5346.09%222.22%
ajit khapardeajit khaparde43.48%111.11%
Total115100.00%9100.00%

/* Returns number of WRBs needed for the skb */
static u32 skb_wrb_cnt(struct sk_buff *skb) { /* +1 for the header wrb */ return 1 + (skb_headlen(skb) ? 1 : 0) + skb_shinfo(skb)->nr_frags; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla3193.94%266.67%
david s. millerdavid s. miller26.06%133.33%
Total33100.00%3100.00%


static inline void wrb_fill(struct be_eth_wrb *wrb, u64 addr, int len) { wrb->frag_pa_hi = cpu_to_le32(upper_32_bits(addr)); wrb->frag_pa_lo = cpu_to_le32(lower_32_bits(addr)); wrb->frag_len = cpu_to_le32(len & ETH_WRB_FRAG_LEN_MASK); wrb->rsvd0 = 0; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla59100.00%2100.00%
Total59100.00%2100.00%

/* A dummy wrb is just all zeros. Using a separate routine for dummy-wrb * to avoid the swap and shift/mask operations in wrb_fill(). */
static inline void wrb_fill_dummy(struct be_eth_wrb *wrb) { wrb->frag_pa_hi = 0; wrb->frag_pa_lo = 0; wrb->frag_len = 0; wrb->rsvd0 = 0; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla3083.33%266.67%
somnath kotursomnath kotur616.67%133.33%
Total36100.00%3100.00%


static inline u16 be_get_tx_vlan_tag(struct be_adapter *adapter, struct sk_buff *skb) { u8 vlan_prio; u16 vlan_tag; vlan_tag = skb_vlan_tag_get(skb); vlan_prio = (vlan_tag & VLAN_PRIO_MASK) >> VLAN_PRIO_SHIFT; /* If vlan priority provided by OS is NOT in available bmap */ if (!(adapter->vlan_prio_bmap & (1 << vlan_prio))) vlan_tag = (vlan_tag & ~VLAN_PRIO_MASK) | adapter->recommended_prio_bits; return vlan_tag; }

Contributors

PersonTokensPropCommitsCommitProp
ajit khapardeajit khaparde7097.22%133.33%
sathya perlasathya perla11.39%133.33%
jiri pirkojiri pirko11.39%133.33%
Total72100.00%3100.00%

/* Used only for IP tunnel packets */
static u16 skb_inner_ip_proto(struct sk_buff *skb) { return (inner_ip_hdr(skb)->version == 4) ? inner_ip_hdr(skb)->protocol : inner_ipv6_hdr(skb)->nexthdr; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla37100.00%1100.00%
Total37100.00%1100.00%


static u16 skb_ip_proto(struct sk_buff *skb) { return (ip_hdr(skb)->version == 4) ? ip_hdr(skb)->protocol : ipv6_hdr(skb)->nexthdr; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla37100.00%1100.00%
Total37100.00%1100.00%


static inline bool be_is_txq_full(struct be_tx_obj *txo) { return atomic_read(&txo->q.used) + BE_MAX_TX_FRAG_COUNT >= txo->q.len; }

Contributors

PersonTokensPropCommitsCommitProp
sriharsha basavapatnasriharsha basavapatna31100.00%1100.00%
Total31100.00%1100.00%


static inline bool be_can_txq_wake(struct be_tx_obj *txo) { return atomic_read(&txo->q.used) < txo->q.len / 2; }

Contributors

PersonTokensPropCommitsCommitProp
sriharsha basavapatnasriharsha basavapatna31100.00%1100.00%
Total31100.00%1100.00%


static inline bool be_is_tx_compl_pending(struct be_tx_obj *txo) { return atomic_read(&txo->q.used) > txo->pend_wrb_cnt; }

Contributors

PersonTokensPropCommitsCommitProp
sriharsha basavapatnasriharsha basavapatna27100.00%1100.00%
Total27100.00%1100.00%


static void be_get_wrb_params_from_skb(struct be_adapter *adapter, struct sk_buff *skb, struct be_wrb_params *wrb_params) { u16 proto; if (skb_is_gso(skb)) { BE_WRB_F_SET(wrb_params->features, LSO, 1); wrb_params->lso_mss = skb_shinfo(skb)->gso_size; if (skb_is_gso_v6(skb) && !lancer_chip(adapter)) BE_WRB_F_SET(wrb_params->features, LSO6, 1); } else if (skb->ip_summed == CHECKSUM_PARTIAL) { if (skb->encapsulation) { BE_WRB_F_SET(wrb_params->features, IPCS, 1); proto = skb_inner_ip_proto(skb); } else { proto = skb_ip_proto(skb); } if (proto == IPPROTO_TCP) BE_WRB_F_SET(wrb_params->features, TCPCS, 1); else if (proto == IPPROTO_UDP) BE_WRB_F_SET(wrb_params->features, UDPCS, 1); } if (skb_vlan_tag_present(skb)) { BE_WRB_F_SET(wrb_params->features, VLAN, 1); wrb_params->vlan_tag = be_get_tx_vlan_tag(adapter, skb); } BE_WRB_F_SET(wrb_params->features, CRC, 1); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla11958.62%337.50%
sriharsha basavapatnasriharsha basavapatna5326.11%112.50%
ajit khapardeajit khaparde178.37%225.00%
somnath kotursomnath kotur136.40%112.50%
jiri pirkojiri pirko10.49%112.50%
Total203100.00%8100.00%


static void wrb_fill_hdr(struct be_adapter *adapter, struct be_eth_hdr_wrb *hdr, struct be_wrb_params *wrb_params, struct sk_buff *skb) { memset(hdr, 0, sizeof(*hdr)); SET_TX_WRB_HDR_BITS(crc, hdr, BE_WRB_F_GET(wrb_params->features, CRC)); SET_TX_WRB_HDR_BITS(ipcs, hdr, BE_WRB_F_GET(wrb_params->features, IPCS)); SET_TX_WRB_HDR_BITS(tcpcs, hdr, BE_WRB_F_GET(wrb_params->features, TCPCS)); SET_TX_WRB_HDR_BITS(udpcs, hdr, BE_WRB_F_GET(wrb_params->features, UDPCS)); SET_TX_WRB_HDR_BITS(lso, hdr, BE_WRB_F_GET(wrb_params->features, LSO)); SET_TX_WRB_HDR_BITS(lso6, hdr, BE_WRB_F_GET(wrb_params->features, LSO6)); SET_TX_WRB_HDR_BITS(lso_mss, hdr, wrb_params->lso_mss); /* Hack to skip HW VLAN tagging needs evt = 1, compl = 0. When this * hack is not needed, the evt bit is set while ringing DB. */ SET_TX_WRB_HDR_BITS(event, hdr, BE_WRB_F_GET(wrb_params->features, VLAN_SKIP_HW)); SET_TX_WRB_HDR_BITS(vlan, hdr, BE_WRB_F_GET(wrb_params->features, VLAN)); SET_TX_WRB_HDR_BITS(vlan_tag, hdr, wrb_params->vlan_tag); SET_TX_WRB_HDR_BITS(num_wrb, hdr, skb_wrb_cnt(skb)); SET_TX_WRB_HDR_BITS(len, hdr, skb->len); SET_TX_WRB_HDR_BITS(mgmt, hdr, BE_WRB_F_GET(wrb_params->features, OS2BMC)); }

Contributors

PersonTokensPropCommitsCommitProp
sriharsha basavapatnasriharsha basavapatna18379.91%120.00%
sathya perlasathya perla3013.10%360.00%
venkat duvvuruvenkat duvvuru166.99%120.00%
Total229100.00%5100.00%


static void unmap_tx_frag(struct device *dev, struct be_eth_wrb *wrb, bool unmap_single) { dma_addr_t dma; u32 frag_len = le32_to_cpu(wrb->frag_len); dma = (u64)le32_to_cpu(wrb->frag_pa_hi) << 32 | (u64)le32_to_cpu(wrb->frag_pa_lo); if (frag_len) { if (unmap_single) dma_unmap_single(dev, dma, frag_len, DMA_TO_DEVICE); else dma_unmap_page(dev, dma, frag_len, DMA_TO_DEVICE); } }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla8089.89%250.00%
ivan veceraivan vecera88.99%125.00%
fujita tomonorifujita tomonori11.12%125.00%
Total89100.00%4100.00%

/* Grab a WRB header for xmit */
static u32 be_tx_get_wrb_hdr(struct be_tx_obj *txo) { u32 head = txo->q.head; queue_head_inc(&txo->q); return head; }

Contributors

PersonTokensPropCommitsCommitProp
sriharsha basavapatnasriharsha basavapatna2993.55%150.00%
ajit khapardeajit khaparde26.45%150.00%
Total31100.00%2100.00%

/* Set up the WRB header for xmit */
static void be_tx_setup_wrb_hdr(struct be_adapter *adapter, struct be_tx_obj *txo, struct be_wrb_params *wrb_params, struct sk_buff *skb, u16 head) { u32 num_frags = skb_wrb_cnt(skb); struct be_queue_info *txq = &txo->q; struct be_eth_hdr_wrb *hdr = queue_index_node(txq, head); wrb_fill_hdr(adapter, hdr, wrb_params, skb); be_dws_cpu_to_le(hdr, sizeof(*hdr)); BUG_ON(txo->sent_skb_list[head]); txo->sent_skb_list[head] = skb; txo->last_req_hdr = head; atomic_add(num_frags, &txq->used); txo->last_req_wrb_cnt = num_frags; txo->pend_wrb_cnt += num_frags; }

Contributors

PersonTokensPropCommitsCommitProp
sriharsha basavapatnasriharsha basavapatna128100.00%1100.00%
Total128100.00%1100.00%

/* Setup a WRB fragment (buffer descriptor) for xmit */
static void be_tx_setup_wrb_frag(struct be_tx_obj *txo, dma_addr_t busaddr, int len) { struct be_eth_wrb *wrb; struct be_queue_info *txq = &txo->q; wrb = queue_head_node(txq); wrb_fill(wrb, busaddr, len); queue_head_inc(txq); }

Contributors

PersonTokensPropCommitsCommitProp
sriharsha basavapatnasriharsha basavapatna53100.00%1100.00%
Total53100.00%1100.00%

/* Bring the queue back to the state it was in before be_xmit_enqueue() routine * was invoked. The producer index is restored to the previous packet and the * WRBs of the current packet are unmapped. Invoked to handle tx setup errors. */
static void be_xmit_restore(struct be_adapter *adapter, struct be_tx_obj *txo, u32 head, bool map_single, u32 copied) { struct device *dev; struct be_eth_wrb *wrb; struct be_queue_info *txq = &txo->q; dev = &adapter->pdev->dev; txq->head = head; /* skip the first wrb (hdr); it's not mapped */ queue_head_inc(txq); while (copied) { wrb = queue_head_node(txq); unmap_tx_frag(dev, wrb, map_single); map_single = false; copied -= le32_to_cpu(wrb->frag_len); queue_head_inc(txq); } txq->head = head; }

Contributors

PersonTokensPropCommitsCommitProp
sriharsha basavapatnasriharsha basavapatna11199.11%150.00%
ajit khapardeajit khaparde10.89%150.00%
Total112100.00%2100.00%

/* Enqueue the given packet for transmit. This routine allocates WRBs for the * packet, dma maps the packet buffers and sets up the WRBs. Returns the number * of WRBs used up by the packet. */
static u32 be_xmit_enqueue(struct be_adapter *adapter, struct be_tx_obj *txo, struct sk_buff *skb, struct be_wrb_params *wrb_params) { u32 i, copied = 0, wrb_cnt = skb_wrb_cnt(skb); struct device *dev = &adapter->pdev->dev; struct be_queue_info *txq = &txo->q; bool map_single = false; u32 head = txq->head; dma_addr_t busaddr; int len; head = be_tx_get_wrb_hdr(txo); if (skb->len > skb->data_len) { len = skb_headlen(skb); busaddr = dma_map_single(dev, skb->data, len, DMA_TO_DEVICE); if (dma_mapping_error(dev, busaddr)) goto dma_err; map_single = true; be_tx_setup_wrb_frag(txo, busaddr, len); copied += len; } for (i = 0; i < skb_shinfo(skb)->nr_frags; i++) { const struct skb_frag_struct *frag = &skb_shinfo(skb)->frags[i]; len = skb_frag_size(frag); busaddr = skb_frag_dma_map(dev, frag, 0, len, DMA_TO_DEVICE); if (dma_mapping_error(dev, busaddr)) goto dma_err; be_tx_setup_wrb_frag(txo, busaddr, len); copied += len; } be_tx_setup_wrb_hdr(adapter, txo, wrb_params, skb, head); be_tx_stats_update(txo, skb); return wrb_cnt; dma_err: adapter->drv_stats.dma_map_errors++; be_xmit_restore(adapter, txo, head, map_single, copied); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla19167.73%428.57%
sriharsha basavapatnasriharsha basavapatna4616.31%214.29%
ivan veceraivan vecera144.96%17.14%
alexander duyckalexander duyck144.96%17.14%
vasundhara volamvasundhara volam72.48%17.14%
eric dumazeteric dumazet41.42%214.29%
ajit khapardeajit khaparde41.42%214.29%
ian campbellian campbell20.71%17.14%
Total282100.00%14100.00%


static inline int qnq_async_evt_rcvd(struct be_adapter *adapter) { return adapter->flags & BE_FLAGS_QNQ_ASYNC_EVT_RCVD; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla19100.00%1100.00%
Total19100.00%1100.00%


static struct sk_buff *be_insert_vlan_in_pkt(struct be_adapter *adapter, struct sk_buff *skb, struct be_wrb_params *wrb_params) { u16 vlan_tag = 0; skb = skb_share_check(skb, GFP_ATOMIC); if (unlikely(!skb)) return skb; if (skb_vlan_tag_present(skb)) vlan_tag = be_get_tx_vlan_tag(adapter, skb); if (qnq_async_evt_rcvd(adapter) && adapter->pvid) { if (!vlan_tag) vlan_tag = adapter->pvid; /* f/w workaround to set skip_hw_vlan = 1, informs the F/W to * skip VLAN insertion */ BE_WRB_F_SET(wrb_params->features, VLAN_SKIP_HW, 1); } if (vlan_tag) { skb = vlan_insert_tag_set_proto(skb, htons(ETH_P_8021Q), vlan_tag); if (unlikely(!skb)) return skb; skb->vlan_tci = 0; } /* Insert the outer VLAN, if any */ if (adapter->qnq_vid) { vlan_tag = adapter->qnq_vid; skb = vlan_insert_tag_set_proto(skb, htons(ETH_P_8021Q), vlan_tag); if (unlikely(!skb)) return skb; BE_WRB_F_SET(wrb_params->features, VLAN_SKIP_HW, 1); } return skb; }

Contributors

PersonTokensPropCommitsCommitProp
ajit khapardeajit khaparde8544.50%114.29%
somnath kotursomnath kotur6131.94%114.29%
sriharsha basavapatnasriharsha basavapatna2312.04%114.29%
david s. millerdavid s. miller105.24%114.29%
sarveshwar bandisarveshwar bandi94.71%114.29%
jiri pirkojiri pirko31.57%228.57%
Total191100.00%7100.00%


static bool be_ipv6_exthdr_check(struct sk_buff *skb) { struct ethhdr *eh = (struct ethhdr *)skb->data; u16 offset = ETH_HLEN; if (eh->h_proto == htons(ETH_P_IPV6)) { struct ipv6hdr *ip6h = (struct ipv6hdr *)(skb->data + offset); offset += sizeof(struct ipv6hdr); if (ip6h->nexthdr != NEXTHDR_TCP && ip6h->nexthdr != NEXTHDR_UDP) { struct ipv6_opt_hdr *ehdr = (struct ipv6_opt_hdr *)(skb->data + offset); /* offending pkt: 2nd byte following IPv6 hdr is 0xff */ if (ehdr->hdrlen == 0xff) return true; } } return false; }

Contributors

PersonTokensPropCommitsCommitProp
ajit khapardeajit khaparde118100.00%1100.00%
Total118100.00%1100.00%


static int be_vlan_tag_tx_chk(struct be_adapter *adapter, struct sk_buff *skb) { return skb_vlan_tag_present(skb) || adapter->pvid || adapter->qnq_vid; }

Contributors

PersonTokensPropCommitsCommitProp
ajit khapardeajit khaparde2996.67%150.00%
jiri pirkojiri pirko13.33%150.00%
Total30100.00%2100.00%


static int be_ipv6_tx_stall_chk(struct be_adapter *adapter, struct sk_buff *skb) { return BE3_chip(adapter) && be_ipv6_exthdr_check(skb); }

Contributors

PersonTokensPropCommitsCommitProp
ajit khapardeajit khaparde2385.19%150.00%
somnath kotursomnath kotur414.81%150.00%
Total27100.00%2100.00%


static struct sk_buff *be_lancer_xmit_workarounds(struct be_adapter *adapter, struct sk_buff *skb, struct be_wrb_params *wrb_params) { struct vlan_ethhdr *veh = (struct vlan_ethhdr *)skb->data; unsigned int eth_hdr_len; struct iphdr *ip; /* For padded packets, BE HW modifies tot_len field in IP header * incorrecly when VLAN tag is inserted by HW. * For padded packets, Lancer computes incorrect checksum. */ eth_hdr_len = ntohs(skb->protocol) == ETH_P_8021Q ? VLAN_ETH_HLEN : ETH_HLEN; if (skb->len <= 60 && (lancer_chip(adapter) || skb_vlan_tag_present(skb)) && is_ipv4_pkt(skb)) { ip = (struct iphdr *)ip_hdr(skb); pskb_trim(skb, eth_hdr_len + ntohs(ip->tot_len)); } /* If vlan tag is already inlined in the packet, skip HW VLAN * tagging in pvid-tagging mode */ if (be_pvid_tagging_enabled(adapter) && veh->h_vlan_proto == htons(ETH_P_8021Q)) BE_WRB_F_SET(wrb_params->features, VLAN_SKIP_HW, 1); /* HW has a bug wherein it will calculate CSUM for VLAN * pkts even though it is disabled. * Manually insert VLAN in pkt. */ if (skb->ip_summed != CHECKSUM_PARTIAL && skb_vlan_tag_present(skb)) { skb = be_insert_vlan_in_pkt(adapter, skb, wrb_params); if (unlikely(!skb)) goto err; } /* HW may lockup when VLAN HW tagging is requested on * certain ipv6 packets. Drop such pkts if the HW workaround to * skip HW tagging is not enabled by FW. */ if (unlikely(be_ipv6_tx_stall_chk(adapter, skb) && (adapter->pvid || adapter->qnq_vid) && !qnq_async_evt_rcvd(adapter))) goto tx_drop; /* Manual VLAN tag insertion to prevent: * ASIC lockup when the ASIC inserts VLAN tag into * certain ipv6 packets. Insert VLAN tags in driver, * and set event, completion, vlan bits accordingly * in the Tx WRB. */ if (be_ipv6_tx_stall_chk(adapter, skb) && be_vlan_tag_tx_chk(adapter, skb)) { skb = be_insert_vlan_in_pkt(adapter, skb, wrb_params); if (unlikely(!skb)) goto err; } return skb; tx_drop: dev_kfree_skb_any(skb); err: return NULL; }

Contributors

PersonTokensPropCommitsCommitProp
ajit khapardeajit khaparde13750.93%323.08%
somnath kotursomnath kotur6524.16%215.38%
sathya perlasathya perla4115.24%323.08%
sriharsha basavapatnasriharsha basavapatna155.58%17.69%
vasundhara volamvasundhara volam93.35%323.08%
jiri pirkojiri pirko20.74%17.69%
Total269100.00%13100.00%


static struct sk_buff *be_xmit_workarounds(struct be_adapter *adapter, struct sk_buff *skb, struct be_wrb_params *wrb_params) { int err; /* Lancer, SH and BE3 in SRIOV mode have a bug wherein * packets that are 32b or less may cause a transmit stall * on that port. The workaround is to pad such packets * (len <= 32 bytes) to a minimum length of 36b. */ if (skb->len <= 32) { if (skb_put_padto(skb, 36)) return NULL; } if (BEx_chip(adapter) || lancer_chip(adapter)) { skb = be_lancer_xmit_workarounds(adapter, skb, wrb_params); if (!skb) return NULL; } /* The stack can send us skbs with length greater than * what the HW can handle. Trim the extra bytes. */ WARN_ON_ONCE(skb->len > BE_MAX_GSO_SIZE); err = pskb_trim(skb, BE_MAX_GSO_SIZE); WARN_ON(err); return skb; }

Contributors

PersonTokensPropCommitsCommitProp
vasundhara volamvasundhara volam7669.72%120.00%
ajit khapardeajit khaparde2724.77%120.00%
sriharsha basavapatnasriharsha basavapatna43.67%120.00%
alexander duyckalexander duyck10.92%120.00%
suresh reddysuresh reddy10.92%120.00%
Total109100.00%5100.00%


static void be_xmit_flush(struct be_adapter *adapter, struct be_tx_obj *txo) { struct be_queue_info *txq = &txo->q; struct be_eth_hdr_wrb *hdr = queue_index_node(txq, txo->last_req_hdr); /* Mark the last request eventable if it hasn't been marked already */ if (!(hdr->dw[2] & cpu_to_le32(TX_HDR_WRB_EVT))) hdr->dw[2] |= cpu_to_le32(TX_HDR_WRB_EVT | TX_HDR_WRB_COMPL); /* compose a dummy wrb if there are odd set of wrbs to notify */ if (!lancer_chip(adapter) && (txo->pend_wrb_cnt & 1)) { wrb_fill_dummy(queue_head_node(txq)); queue_head_inc(txq); atomic_inc(&txq->used); txo->pend_wrb_cnt++; hdr->dw[2] &= ~cpu_to_le32(TX_HDR_WRB_NUM_MASK << TX_HDR_WRB_NUM_SHIFT); hdr->dw[2] |= cpu_to_le32((txo->last_req_wrb_cnt + 1) << TX_HDR_WRB_NUM_SHIFT); } be_txq_notify(adapter, txo, txo->pend_wrb_cnt); txo->pend_wrb_cnt = 0; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla169100.00%2100.00%
Total169100.00%2100.00%

/* OS2BMC related */ #define DHCP_CLIENT_PORT 68 #define DHCP_SERVER_PORT 67 #define NET_BIOS_PORT1 137 #define NET_BIOS_PORT2 138 #define DHCPV6_RAS_PORT 547 #define is_mc_allowed_on_bmc(adapter, eh) \ (!is_multicast_filt_enabled(adapter) && \ is_multicast_ether_addr(eh->h_dest) && \ !is_broadcast_ether_addr(eh->h_dest)) #define is_bc_allowed_on_bmc(adapter, eh) \ (!is_broadcast_filt_enabled(adapter) && \ is_broadcast_ether_addr(eh->h_dest)) #define is_arp_allowed_on_bmc(adapter, skb) \ (is_arp(skb) && is_arp_filt_enabled(adapter)) #define is_broadcast_packet(eh, adapter) \ (is_multicast_ether_addr(eh->h_dest) && \ !compare_ether_addr(eh->h_dest, adapter->netdev->broadcast)) #define is_arp(skb) (skb->protocol == htons(ETH_P_ARP)) #define is_arp_filt_enabled(adapter) \ (adapter->bmc_filt_mask & (BMC_FILT_BROADCAST_ARP)) #define is_dhcp_client_filt_enabled(adapter) \ (adapter->bmc_filt_mask & BMC_FILT_BROADCAST_DHCP_CLIENT) #define is_dhcp_srvr_filt_enabled(adapter) \ (adapter->bmc_filt_mask & BMC_FILT_BROADCAST_DHCP_SERVER) #define is_nbios_filt_enabled(adapter) \ (adapter->bmc_filt_mask & BMC_FILT_BROADCAST_NET_BIOS) #define is_ipv6_na_filt_enabled(adapter) \ (adapter->bmc_filt_mask & \ BMC_FILT_MULTICAST_IPV6_NEIGH_ADVER) #define is_ipv6_ra_filt_enabled(adapter) \ (adapter->bmc_filt_mask & BMC_FILT_MULTICAST_IPV6_RA) #define is_ipv6_ras_filt_enabled(adapter) \ (adapter->bmc_filt_mask & BMC_FILT_MULTICAST_IPV6_RAS) #define is_broadcast_filt_enabled(adapter) \ (adapter->bmc_filt_mask & BMC_FILT_BROADCAST) #define is_multicast_filt_enabled(adapter) \ (adapter->bmc_filt_mask & BMC_FILT_MULTICAST)
static bool be_send_pkt_to_bmc(struct be_adapter *adapter, struct sk_buff **skb) { struct ethhdr *eh = (struct ethhdr *)(*skb)->data; bool os2bmc = false; if (!be_is_os2bmc_enabled(adapter)) goto done; if (!is_multicast_ether_addr(eh->h_dest)) goto done; if (is_mc_allowed_on_bmc(adapter, eh) || is_bc_allowed_on_bmc(adapter, eh) || is_arp_allowed_on_bmc(adapter, (*skb))) { os2bmc = true; goto done; } if ((*skb)->protocol == htons(ETH_P_IPV6)) { struct ipv6hdr *hdr = ipv6_hdr((*skb)); u8 nexthdr = hdr->nexthdr; if (nexthdr == IPPROTO_ICMPV6) { struct icmp6hdr *icmp6 = icmp6_hdr((*skb)); switch (icmp6->icmp6_type) { case NDISC_ROUTER_ADVERTISEMENT: os2bmc = is_ipv6_ra_filt_enabled(adapter); goto done; case NDISC_NEIGHBOUR_ADVERTISEMENT: os2bmc = is_ipv6_na_filt_enabled(adapter); goto done; default: break; } } } if (is_udp_pkt((*skb))) { struct udphdr *udp = udp_hdr((*skb)); switch (ntohs(udp->dest)) { case DHCP_CLIENT_PORT: os2bmc = is_dhcp_client_filt_enabled(adapter); goto done; case DHCP_SERVER_PORT: os2bmc = is_dhcp_srvr_filt_enabled(adapter); goto done; case NET_BIOS_PORT1: case NET_BIOS_PORT2: os2bmc = is_nbios_filt_enabled(adapter); goto done; case DHCPV6_RAS_PORT: os2bmc = is_ipv6_ras_filt_enabled(adapter); goto done; default: break; } } done: /* For packets over a vlan, which are destined * to BMC, asic expects the vlan to be inline in the packet. */ if (os2bmc) *skb = be_insert_vlan_in_pkt(adapter, *skb, NULL); return os2bmc; }

Contributors

PersonTokensPropCommitsCommitProp
venkat duvvuruvenkat duvvuru307100.00%2100.00%
Total307100.00%2100.00%


static netdev_tx_t be_xmit(struct sk_buff *skb, struct net_device *netdev) { struct be_adapter *adapter = netdev_priv(netdev); u16 q_idx = skb_get_queue_mapping(skb); struct be_tx_obj *txo = &adapter->tx_obj[q_idx]; struct be_wrb_params wrb_params = { 0 }; bool flush = !skb->xmit_more; u16 wrb_cnt; skb = be_xmit_workarounds(adapter, skb, &wrb_params); if (unlikely(!skb)) goto drop; be_get_wrb_params_from_skb(adapter, skb, &wrb_params); wrb_cnt = be_xmit_enqueue(adapter, txo, skb, &wrb_params); if (unlikely(!wrb_cnt)) { dev_kfree_skb_any(skb); goto drop; } /* if os2bmc is enabled and if the pkt is destined to bmc, * enqueue the pkt a 2nd time with mgmt bit set. */ if (be_send_pkt_to_bmc(adapter, &skb)) { BE_WRB_F_SET(wrb_params.features, OS2BMC, 1); wrb_cnt = be_xmit_enqueue(adapter, txo, skb, &wrb_params); if (unlikely(!wrb_cnt)) goto drop; else skb_get(skb); } if (be_is_txq_full(txo)) { netif_stop_subqueue(netdev, q_idx); tx_stats(txo)->tx_stops++; } if (flush || __netif_subqueue_stopped(netdev, q_idx)) be_xmit_flush(adapter, txo); return NETDEV_TX_OK; drop: tx_stats(txo)->tx_drv_drops++; /* Flush the already enqueued tx requests */ if (flush && txo->pend_wrb_cnt) be_xmit_flush(adapter, txo); return NETDEV_TX_OK; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla16663.85%750.00%
venkat duvvuruvenkat duvvuru5521.15%17.14%
sriharsha basavapatnasriharsha basavapatna3011.54%214.29%
ajit khapardeajit khaparde62.31%214.29%
eric dumazeteric dumazet20.77%17.14%
vasundhara volamvasundhara volam10.38%17.14%
Total260100.00%14100.00%


static inline bool be_in_all_promisc(struct be_adapter *adapter) { return (adapter->if_flags & BE_IF_FLAGS_ALL_PROMISCUOUS) == BE_IF_FLAGS_ALL_PROMISCUOUS; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla23100.00%1100.00%
Total23100.00%1100.00%


static int be_set_vlan_promisc(struct be_adapter *adapter) { struct device *dev = &adapter->pdev->dev; int status; if (adapter->if_flags & BE_IF_FLAGS_VLAN_PROMISCUOUS) return 0; status = be_cmd_rx_filter(adapter, BE_IF_FLAGS_VLAN_PROMISCUOUS, ON); if (!status) { dev_info(dev, "Enabled VLAN promiscuous mode\n"); adapter->if_flags |= BE_IF_FLAGS_VLAN_PROMISCUOUS; } else { dev_err(dev, "Failed to enable VLAN promiscuous mode\n"); } return status; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla81100.00%1100.00%
Total81100.00%1100.00%


static int be_clear_vlan_promisc(struct be_adapter *adapter) { struct device *dev = &adapter->pdev->dev; int status; status = be_cmd_rx_filter(adapter, BE_IF_FLAGS_VLAN_PROMISCUOUS, OFF); if (!status) { dev_info(dev, "Disabling VLAN promiscuous mode\n"); adapter->if_flags &= ~BE_IF_FLAGS_VLAN_PROMISCUOUS; } return status; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla61100.00%1100.00%
Total61100.00%1100.00%

/* * A max of 64 (BE_NUM_VLANS_SUPPORTED) vlans can be configured in BE. * If the user configures more, place BE in vlan promiscuous mode. */
static int be_vid_config(struct be_adapter *adapter) { struct device *dev = &adapter->pdev->dev; u16 vids[BE_NUM_VLANS_SUPPORTED]; u16 num = 0, i = 0; int status = 0; /* No need to change the VLAN state if the I/F is in promiscuous */ if (adapter->netdev->flags & IFF_PROMISC) return 0; if (adapter->vlans_added > be_max_vlans(adapter)) return be_set_vlan_promisc(adapter); if (adapter->if_flags & BE_IF_FLAGS_VLAN_PROMISCUOUS) { status = be_clear_vlan_promisc(adapter); if (status) return status; } /* Construct VLAN Table to give to HW */ for_each_set_bit(i, adapter->vids, VLAN_N_VID) vids[num++] = cpu_to_le16(i); status = be_cmd_vlan_config(adapter, adapter->if_handle, vids, num, 0); if (status) { dev_err(dev, "Setting HW VLAN filtering failed\n"); /* Set to VLAN promisc mode as setting VLAN filter failed */ if (addl_status(status) == MCC_ADDL_STATUS_INSUFFICIENT_VLANS || addl_status(status) == MCC_ADDL_STATUS_INSUFFICIENT_RESOURCES) return be_set_vlan_promisc(adapter); } return status; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla8850.57%741.18%
somnath kotursomnath kotur2413.79%15.88%
ajit khapardeajit khaparde148.05%211.76%
vasundhara volamvasundhara volam148.05%211.76%
kalesh purayilkalesh purayil116.32%211.76%
ravikumar nelavelliravikumar nelavelli105.75%15.88%
sriharsha basavapatnasriharsha basavapatna74.02%15.88%
padmanabh ratnakarpadmanabh ratnakar63.45%15.88%
Total174100.00%17100.00%


static int be_vlan_add_vid(struct net_device *netdev, __be16 proto, u16 vid) { struct be_adapter *adapter = netdev_priv(netdev); int status = 0; mutex_lock(&adapter->rx_filter_lock); /* Packets with VID 0 are always received by Lancer by default */ if (lancer_chip(adapter) && vid == 0) goto done; if (test_bit(vid, adapter->vids)) goto done; set_bit(vid, adapter->vids); adapter->vlans_added++; status = be_vid_config(adapter); done: mutex_unlock(&adapter->rx_filter_lock); return status; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla5957.28%538.46%
ravikumar nelavelliravikumar nelavelli1211.65%17.69%
padmanabh ratnakarpadmanabh ratnakar1211.65%17.69%
ajit khapardeajit khaparde87.77%215.38%
vasundhara volamvasundhara volam54.85%17.69%
patrick mchardypatrick mchardy32.91%17.69%
somnath kotursomnath kotur21.94%17.69%
jiri pirkojiri pirko21.94%17.69%
Total103100.00%13100.00%


static int be_vlan_rem_vid(struct net_device *netdev, __be16 proto, u16 vid) { struct be_adapter *adapter = netdev_priv(netdev); int status = 0; mutex_lock(&adapter->rx_filter_lock); /* Packets with VID 0 are always received by Lancer by default */ if (lancer_chip(adapter) && vid == 0) goto done; if (!test_bit(vid, adapter->vids)) goto done; clear_bit(vid, adapter->vids); adapter->vlans_added--; status = be_vid_config(adapter); done: mutex_unlock(&adapter->rx_filter_lock); return status; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla6057.69%222.22%
sriharsha basavapatnasriharsha basavapatna1211.54%111.11%
padmanabh ratnakarpadmanabh ratnakar1211.54%111.11%
ravikumar nelavelliravikumar nelavelli87.69%111.11%
ajit khapardeajit khaparde65.77%111.11%
patrick mchardypatrick mchardy32.88%111.11%
jiri pirkojiri pirko21.92%111.11%
kalesh purayilkalesh purayil10.96%111.11%
Total104100.00%9100.00%


static void be_set_all_promisc(struct be_adapter *adapter) { be_cmd_rx_filter(adapter, BE_IF_FLAGS_ALL_PROMISCUOUS, ON); adapter->if_flags |= BE_IF_FLAGS_ALL_PROMISCUOUS; }

Contributors

PersonTokensPropCommitsCommitProp
somnath kotursomnath kotur1453.85%133.33%
sathya perlasathya perla934.62%133.33%
sriharsha basavapatnasriharsha basavapatna311.54%133.33%
Total26100.00%3100.00%


static void be_set_mc_promisc(struct be_adapter *adapter) { int status; if (adapter->if_flags & BE_IF_FLAGS_MCAST_PROMISCUOUS) return; status = be_cmd_rx_filter(adapter, BE_IF_FLAGS_MCAST_PROMISCUOUS, ON); if (!status) adapter->if_flags |= BE_IF_FLAGS_MCAST_PROMISCUOUS; }

Contributors

PersonTokensPropCommitsCommitProp
sriharsha basavapatnasriharsha basavapatna2248.89%133.33%
sathya perlasathya perla1533.33%133.33%
somnath kotursomnath kotur817.78%133.33%
Total45100.00%3100.00%


static void be_set_uc_promisc(struct be_adapter *adapter) { int status; if (adapter->if_flags & BE_IF_FLAGS_PROMISCUOUS) return; status = be_cmd_rx_filter(adapter, BE_IF_FLAGS_PROMISCUOUS, ON); if (!status) adapter->if_flags |= BE_IF_FLAGS_PROMISCUOUS; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla3680.00%571.43%
sriharsha basavapatnasriharsha basavapatna613.33%114.29%
padmanabh ratnakarpadmanabh ratnakar36.67%114.29%
Total45100.00%7100.00%


static void be_clear_uc_promisc(struct be_adapter *adapter) { int status; if (!(adapter->if_flags & BE_IF_FLAGS_PROMISCUOUS)) return; status = be_cmd_rx_filter(adapter, BE_IF_FLAGS_PROMISCUOUS, OFF); if (!status) adapter->if_flags &= ~BE_IF_FLAGS_PROMISCUOUS; }

Contributors

PersonTokensPropCommitsCommitProp
sriharsha basavapatnasriharsha basavapatna49100.00%1100.00%
Total49100.00%1100.00%

/* The below 2 functions are the callback args for __dev_mc_sync/dev_uc_sync(). * We use a single callback function for both sync and unsync. We really don't * add/remove addresses through this callback. But, we use it to detect changes * to the uc/mc lists. The entire uc/mc list is programmed in be_set_rx_mode(). */
static int be_uc_list_update(struct net_device *netdev, const unsigned char *addr) { struct be_adapter *adapter = netdev_priv(netdev); adapter->update_uc_list = true; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
sriharsha basavapatnasriharsha basavapatna3597.22%150.00%
sathya perlasathya perla12.78%150.00%
Total36100.00%2100.00%


static int be_mc_list_update(struct net_device *netdev, const unsigned char *addr) { struct be_adapter *adapter = netdev_priv(netdev); adapter->update_mc_list = true; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
sriharsha basavapatnasriharsha basavapatna3597.22%150.00%
sathya perlasathya perla12.78%150.00%
Total36100.00%2100.00%


static void be_set_mc_list(struct be_adapter *adapter) { struct net_device *netdev = adapter->netdev; struct netdev_hw_addr *ha; bool mc_promisc = false; int status; netif_addr_lock_bh(netdev); __dev_mc_sync(netdev, be_mc_list_update, be_mc_list_update); if (netdev->flags & IFF_PROMISC) { adapter->update_mc_list = false; } else if (netdev->flags & IFF_ALLMULTI || netdev_mc_count(netdev) > be_max_mc(adapter)) { /* Enable multicast promisc if num configured exceeds * what we support */ mc_promisc = true; adapter->update_mc_list = false; } else if (adapter->if_flags & BE_IF_FLAGS_MCAST_PROMISCUOUS) { /* Update mc-list unconditionally if the iface was previously * in mc-promisc mode and now is out of that mode. */ adapter->update_mc_list = true; } if (adapter->update_mc_list) { int i = 0; /* cache the mc-list in adapter */ netdev_for_each_mc_addr(ha, netdev) { ether_addr_copy(adapter->mc_list[i].mac, ha->addr); i++; } adapter->mc_count = netdev_mc_count(netdev); } netif_addr_unlock_bh(netdev); if (mc_promisc) { be_set_mc_promisc(adapter); } else if (adapter->update_mc_list) { status = be_cmd_rx_filter(adapter, BE_IF_FLAGS_MULTICAST, ON); if (!status) adapter->if_flags &= ~BE_IF_FLAGS_MCAST_PROMISCUOUS; else be_set_mc_promisc(adapter); adapter->update_mc_list = false; } }

Contributors

PersonTokensPropCommitsCommitProp
sriharsha basavapatnasriharsha basavapatna11652.02%114.29%
sathya perlasathya perla10747.98%685.71%
Total223100.00%7100.00%


static void be_clear_mc_list(struct be_adapter *adapter) { struct net_device *netdev = adapter->netdev; __dev_mc_unsync(netdev, NULL); be_cmd_rx_filter(adapter, BE_IF_FLAGS_MULTICAST, OFF); adapter->mc_count = 0; }

Contributors

PersonTokensPropCommitsCommitProp
sriharsha basavapatnasriharsha basavapatna3583.33%133.33%
sathya perlasathya perla716.67%266.67%
Total42100.00%3100.00%


static int be_uc_mac_add(struct be_adapter *adapter, int uc_idx) { if (ether_addr_equal(adapter->uc_list[uc_idx].mac, adapter->dev_mac)) { adapter->pmac_id[uc_idx + 1] = adapter->pmac_id[0]; return 0; } return be_cmd_pmac_add(adapter, adapter->uc_list[uc_idx].mac, adapter->if_handle, &adapter->pmac_id[uc_idx + 1], 0); }

Contributors

PersonTokensPropCommitsCommitProp
suresh reddysuresh reddy8095.24%266.67%
ivan veceraivan vecera44.76%133.33%
Total84100.00%3100.00%


static void be_uc_mac_del(struct be_adapter *adapter, int pmac_id) { if (pmac_id == adapter->pmac_id[0]) return; be_cmd_pmac_del(adapter, adapter->if_handle, pmac_id, 0); }

Contributors

PersonTokensPropCommitsCommitProp
suresh reddysuresh reddy39100.00%1100.00%
Total39100.00%1100.00%


static void be_set_uc_list(struct be_adapter *adapter) { struct net_device *netdev = adapter->netdev; struct netdev_hw_addr *ha; bool uc_promisc = false; int curr_uc_macs = 0, i; netif_addr_lock_bh(netdev); __dev_uc_sync(netdev, be_uc_list_update, be_uc_list_update); if (netdev->flags & IFF_PROMISC) { adapter->update_uc_list = false; } else if (netdev_uc_count(netdev) > (be_max_uc(adapter) - 1)) { uc_promisc = true; adapter->update_uc_list = false; } else if (adapter->if_flags & BE_IF_FLAGS_PROMISCUOUS) { /* Update uc-list unconditionally if the iface was previously * in uc-promisc mode and now is out of that mode. */ adapter->update_uc_list = true; } if (adapter->update_uc_list) { /* cache the uc-list in adapter array */ i = 0; netdev_for_each_uc_addr(ha, netdev) { ether_addr_copy(adapter->uc_list[i].mac, ha->addr); i++; } curr_uc_macs = netdev_uc_count(netdev); } netif_addr_unlock_bh(netdev); if (uc_promisc) { be_set_uc_promisc(adapter); } else if (adapter->update_uc_list) { be_clear_uc_promisc(adapter); for (i = 0; i < adapter->uc_macs; i++) be_uc_mac_del(adapter, adapter->pmac_id[i + 1]); for (i = 0; i < curr_uc_macs; i++) be_uc_mac_add(adapter, i); adapter->uc_macs = curr_uc_macs; adapter->update_uc_list = false; } }

Contributors

PersonTokensPropCommitsCommitProp
sriharsha basavapatnasriharsha basavapatna11746.43%116.67%
sathya perlasathya perla9336.90%233.33%
ajit khapardeajit khaparde3815.08%116.67%
suresh reddysuresh reddy20.79%116.67%
ivan veceraivan vecera20.79%116.67%
Total252100.00%6100.00%


static void be_clear_uc_list(struct be_adapter *adapter) { struct net_device *netdev = adapter->netdev; int i; __dev_uc_unsync(netdev, NULL); for (i = 0; i < adapter->uc_macs; i++) be_uc_mac_del(adapter, adapter->pmac_id[i + 1]); adapter->uc_macs = 0; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla4772.31%457.14%
sriharsha basavapatnasriharsha basavapatna1624.62%114.29%
suresh reddysuresh reddy11.54%114.29%
padmanabh ratnakarpadmanabh ratnakar11.54%114.29%
Total65100.00%7100.00%


static void __be_set_rx_mode(struct be_adapter *adapter) { struct net_device *netdev = adapter->netdev; mutex_lock(&adapter->rx_filter_lock); if (netdev->flags & IFF_PROMISC) { if (!be_in_all_promisc(adapter)) be_set_all_promisc(adapter); } else if (be_in_all_promisc(adapter)) { /* We need to re-program the vlan-list or clear * vlan-promisc mode (if needed) when the interface * comes out of promisc mode. */ be_vid_config(adapter); } be_set_uc_list(adapter); be_set_mc_list(adapter); mutex_unlock(&adapter->rx_filter_lock); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla6171.76%240.00%
padmanabh ratnakarpadmanabh ratnakar1011.76%120.00%
kalesh purayilkalesh purayil89.41%120.00%
sriharsha basavapatnasriharsha basavapatna67.06%120.00%
Total85100.00%5100.00%


static void be_work_set_rx_mode(struct work_struct *work) { struct be_cmd_work *cmd_work = container_of(work, struct be_cmd_work, work); __be_set_rx_mode(cmd_work->adapter); kfree(cmd_work); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla38100.00%2100.00%
Total38100.00%2100.00%


static int be_set_vf_mac(struct net_device *netdev, int vf, u8 *mac) { struct be_adapter *adapter = netdev_priv(netdev); struct be_vf_cfg *vf_cfg = &adapter->vf_cfg[vf]; int status; if (!sriov_enabled(adapter)) return -EPERM; if (!is_valid_ether_addr(mac) || vf >= adapter->num_vfs) return -EINVAL; /* Proceed further only if user provided MAC is different * from active MAC */ if (ether_addr_equal(mac, vf_cfg->mac_addr)) return 0; if (BEx_chip(adapter)) { be_cmd_pmac_del(adapter, vf_cfg->if_handle, vf_cfg->pmac_id, vf + 1); status = be_cmd_pmac_add(adapter, mac, vf_cfg->if_handle, &vf_cfg->pmac_id, vf + 1); } else { status = be_cmd_set_mac(adapter, mac, vf_cfg->if_handle, vf + 1); } if (status) { dev_err(&adapter->pdev->dev, "MAC %pM set on VF %d Failed: %#x", mac, vf, status); return be_cmd_status(status); } ether_addr_copy(vf_cfg->mac_addr, mac); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
sarveshwar bandisarveshwar bandi9045.23%111.11%
sathya perlasathya perla3517.59%222.22%
padmanabh ratnakarpadmanabh ratnakar3015.08%222.22%
ajit khapardeajit khaparde168.04%222.22%
vasundhara volamvasundhara volam157.54%111.11%
kalesh purayilkalesh purayil136.53%111.11%
Total199100.00%9100.00%


static int be_get_vf_config(struct net_device *netdev, int vf, struct ifla_vf_info *vi) { struct be_adapter *adapter = netdev_priv(netdev); struct be_vf_cfg *vf_cfg = &adapter->vf_cfg[vf]; if (!sriov_enabled(adapter)) return -EPERM; if (vf >= adapter->num_vfs) return -EINVAL; vi->vf = vf; vi->max_tx_rate = vf_cfg->tx_rate; vi->min_tx_rate = 0; vi->vlan = vf_cfg->vlan_tag & VLAN_VID_MASK; vi->qos = vf_cfg->vlan_tag >> VLAN_PRIO_SHIFT; memcpy(&vi->mac, vf_cfg->mac_addr, ETH_ALEN); vi->linkstate = adapter->vf_cfg[vf].plink_tracking; vi->spoofchk = adapter->vf_cfg[vf].spoofchk; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
ajit khapardeajit khaparde9261.74%450.00%
sathya perlasathya perla2416.11%112.50%
kalesh purayilkalesh purayil138.72%112.50%
suresh reddysuresh reddy138.72%112.50%
sucheta chakrabortysucheta chakraborty74.70%112.50%
Total149100.00%8100.00%


static int be_set_vf_tvt(struct be_adapter *adapter, int vf, u16 vlan) { struct be_vf_cfg *vf_cfg = &adapter->vf_cfg[vf]; u16 vids[BE_NUM_VLANS_SUPPORTED]; int vf_if_id = vf_cfg->if_handle; int status; /* Enable Transparent VLAN Tagging */ status = be_cmd_set_hsw_config(adapter, vlan, vf + 1, vf_if_id, 0, 0); if (status) return status; /* Clear pre-programmed VLAN filters on VF if any, if TVT is enabled */ vids[0] = 0; status = be_cmd_vlan_config(adapter, vf_if_id, vids, 1, vf + 1); if (!status) dev_info(&adapter->pdev->dev, "Cleared guest VLANs on VF%d", vf); /* After TVT is enabled, disallow VFs to program VLAN filters */ if (vf_cfg->privileges & BE_PRIV_FILTMGMT) { status = be_cmd_set_fn_privileges(adapter, vf_cfg->privileges & ~BE_PRIV_FILTMGMT, vf + 1); if (!status) vf_cfg->privileges &= ~BE_PRIV_FILTMGMT; } return 0; }

Contributors

PersonTokensPropCommitsCommitProp
vasundhara volamvasundhara volam15998.76%150.00%
kalesh purayilkalesh purayil21.24%150.00%
Total161100.00%2100.00%


static int be_clear_vf_tvt(struct be_adapter *adapter, int vf) { struct be_vf_cfg *vf_cfg = &adapter->vf_cfg[vf]; struct device *dev = &adapter->pdev->dev; int status; /* Reset Transparent VLAN Tagging. */ status = be_cmd_set_hsw_config(adapter, BE_RESET_VLAN_TAG_ID, vf + 1, vf_cfg->if_handle, 0, 0); if (status) return status; /* Allow VFs to program VLAN filtering */ if (!(vf_cfg->privileges & BE_PRIV_FILTMGMT)) { status = be_cmd_set_fn_privileges(adapter, vf_cfg->privileges | BE_PRIV_FILTMGMT, vf + 1); if (!status) { vf_cfg->privileges |= BE_PRIV_FILTMGMT; dev_info(dev, "VF%d: FILTMGMT priv enabled", vf); } } dev_info(dev, "Disable/re-enable i/f in VM to clear Transparent VLAN tag"); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
vasundhara volamvasundhara volam13298.51%150.00%
kalesh purayilkalesh purayil21.49%150.00%
Total134100.00%2100.00%


static int be_set_vf_vlan(struct net_device *netdev, int vf, u16 vlan, u8 qos, __be16 vlan_proto) { struct be_adapter *adapter = netdev_priv(netdev); struct be_vf_cfg *vf_cfg = &adapter->vf_cfg[vf]; int status; if (!sriov_enabled(adapter)) return -EPERM; if (vf >= adapter->num_vfs || vlan > 4095 || qos > 7) return -EINVAL; if (vlan_proto != htons(ETH_P_8021Q)) return -EPROTONOSUPPORT; if (vlan || qos) { vlan |= qos << VLAN_PRIO_SHIFT; status = be_set_vf_tvt(adapter, vf, vlan); } else { status = be_clear_vf_tvt(adapter, vf); } if (status) { dev_err(&adapter->pdev->dev, "VLAN %d config on VF %d failed : %#x\n", vlan, vf, status); return be_cmd_status(status); } vf_cfg->vlan_tag = vlan; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
ajit khapardeajit khaparde12875.29%342.86%
kalesh purayilkalesh purayil1810.59%114.29%
moshe shemeshmoshe shemesh169.41%114.29%
sathya perlasathya perla52.94%114.29%
vasundhara volamvasundhara volam31.76%114.29%
Total170100.00%7100.00%


static int be_set_vf_tx_rate(struct net_device *netdev, int vf, int min_tx_rate, int max_tx_rate) { struct be_adapter *adapter = netdev_priv(netdev); struct device *dev = &adapter->pdev->dev; int percent_rate, status = 0; u16 link_speed = 0; u8 link_status; if (!sriov_enabled(adapter)) return -EPERM; if (vf >= adapter->num_vfs) return -EINVAL; if (min_tx_rate) return -EINVAL; if (!max_tx_rate) goto config_qos; status = be_cmd_link_status_query(adapter, &link_speed, &link_status, 0); if (status) goto err; if (!link_status) { dev_err(dev, "TX-rate setting not allowed when link is down\n"); status = -ENETDOWN; goto err; } if (max_tx_rate < 100 || max_tx_rate > link_speed) { dev_err(dev, "TX-rate must be between 100 and %d Mbps\n", link_speed); status = -EINVAL; goto err; } /* On Skyhawk the QOS setting must be done only as a % value */ percent_rate = link_speed / 100; if (skyhawk_chip(adapter) && (max_tx_rate % percent_rate)) { dev_err(dev, "TX-rate must be a multiple of %d Mbps\n", percent_rate); status = -EINVAL; goto err; } config_qos: status = be_cmd_config_qos(adapter, max_tx_rate, link_speed, vf + 1); if (status) goto err; adapter->vf_cfg[vf].tx_rate = max_tx_rate; return 0; err: dev_err(dev, "TX-rate setting of %dMbps on VF%d failed\n", max_tx_rate, vf); return be_cmd_status(status); }

Contributors

PersonTokensPropCommitsCommitProp
ravikumar nelavelliravikumar nelavelli14454.14%111.11%
ajit khapardeajit khaparde9636.09%333.33%
sucheta chakrabortysucheta chakraborty166.02%111.11%
sathya perlasathya perla62.26%222.22%
kalesh purayilkalesh purayil41.50%222.22%
Total266100.00%9100.00%


static int be_set_vf_link_state(struct net_device *netdev, int vf, int link_state) { struct be_adapter *adapter = netdev_priv(netdev); int status; if (!sriov_enabled(adapter)) return -EPERM; if (vf >= adapter->num_vfs) return -EINVAL; status = be_cmd_set_logical_link_config(adapter, link_state, vf+1); if (status) { dev_err(&adapter->pdev->dev, "Link state change on VF %d failed: %#x\n", vf, status); return be_cmd_status(status); } adapter->vf_cfg[vf].plink_tracking = link_state; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
suresh reddysuresh reddy8477.06%150.00%
kalesh purayilkalesh purayil2522.94%150.00%
Total109100.00%2100.00%


static int be_set_vf_spoofchk(struct net_device *netdev, int vf, bool enable) { struct be_adapter *adapter = netdev_priv(netdev); struct be_vf_cfg *vf_cfg = &adapter->vf_cfg[vf]; u8 spoofchk; int status; if (!sriov_enabled(adapter)) return -EPERM; if (vf >= adapter->num_vfs) return -EINVAL; if (BEx_chip(adapter)) return -EOPNOTSUPP; if (enable == vf_cfg->spoofchk) return 0; spoofchk = enable ? ENABLE_MAC_SPOOFCHK : DISABLE_MAC_SPOOFCHK; status = be_cmd_set_hsw_config(adapter, 0, vf + 1, vf_cfg->if_handle, 0, spoofchk); if (status) { dev_err(&adapter->pdev->dev, "Spoofchk change on VF %d failed: %#x\n", vf, status); return be_cmd_status(status); } vf_cfg->spoofchk = enable; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
kalesh purayilkalesh purayil158100.00%1100.00%
Total158100.00%1100.00%


static void be_aic_update(struct be_aic_obj *aic, u64 rx_pkts, u64 tx_pkts, ulong now) { aic->rx_pkts_prev = rx_pkts; aic->tx_reqs_prev = tx_pkts; aic->jiffies = now; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla38100.00%1100.00%
Total38100.00%1100.00%


static int be_get_new_eqd(struct be_eq_obj *eqo) { struct be_adapter *adapter = eqo->adapter; int eqd, start; struct be_aic_obj *aic; struct be_rx_obj *rxo; struct be_tx_obj *txo; u64 rx_pkts = 0, tx_pkts = 0; ulong now; u32 pps, delta; int i; aic = &adapter->aic_obj[eqo->idx]; if (!aic->enable) { if (aic->jiffies) aic->jiffies = 0; eqd = aic->et_eqd; return eqd; } for_all_rx_queues_on_eq(adapter, eqo, rxo, i) { do { start = u64_stats_fetch_begin_irq(&rxo->stats.sync); rx_pkts += rxo->stats.rx_pkts; } while (u64_stats_fetch_retry_irq(&rxo->stats.sync, start)); } for_all_tx_queues_on_eq(adapter, eqo, txo, i) { do { start = u64_stats_fetch_begin_irq(&txo->stats.sync); tx_pkts += txo->stats.tx_reqs; } while (u64_stats_fetch_retry_irq(&txo->stats.sync, start)); } /* Skip, if wrapped around or first calculation */ now = jiffies; if (!aic->jiffies || time_before(now, aic->jiffies) || rx_pkts < aic->rx_pkts_prev || tx_pkts < aic->tx_reqs_prev) { be_aic_update(aic, rx_pkts, tx_pkts, now); return aic->prev_eqd; } delta = jiffies_to_msecs(now - aic->jiffies); if (delta == 0) return aic->prev_eqd; pps = (((u32)(rx_pkts - aic->rx_pkts_prev) * 1000) / delta) + (((u32)(tx_pkts - aic->tx_reqs_prev) * 1000) / delta); eqd = (pps / 15000) << 2; if (eqd < 8) eqd = 0; eqd = min_t(u32, eqd, aic->max_eqd); eqd = max_t(u32, eqd, aic->min_eqd); be_aic_update(aic, rx_pkts, tx_pkts, now); return eqd; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla29979.73%660.00%
padmanabh ratnakarpadmanabh ratnakar6717.87%110.00%
eric dumazeteric dumazet41.07%110.00%
eric w. biedermaneric w. biederman41.07%110.00%
stephen hemmingerstephen hemminger10.27%110.00%
Total375100.00%10100.00%

/* For Skyhawk-R only */
static u32 be_get_eq_delay_mult_enc(struct be_eq_obj *eqo) { struct be_adapter *adapter = eqo->adapter; struct be_aic_obj *aic = &adapter->aic_obj[eqo->idx]; ulong now = jiffies; int eqd; u32 mult_enc; if (!aic->enable) return 0; if (jiffies_to_msecs(now - aic->jiffies) < 1) eqd = aic->prev_eqd; else eqd = be_get_new_eqd(eqo); if (eqd > 100) mult_enc = R2I_DLY_ENC_1; else if (eqd > 60) mult_enc = R2I_DLY_ENC_2; else if (eqd > 20) mult_enc = R2I_DLY_ENC_3; else mult_enc = R2I_DLY_ENC_0; aic->prev_eqd = eqd; return mult_enc; }

Contributors

PersonTokensPropCommitsCommitProp
padmanabh ratnakarpadmanabh ratnakar12798.45%150.00%
sathya perlasathya perla21.55%150.00%
Total129100.00%2100.00%


void be_eqd_update(struct be_adapter *adapter, bool force_update) { struct be_set_eqd set_eqd[MAX_EVT_QS]; struct be_aic_obj *aic; struct be_eq_obj *eqo; int i, num = 0, eqd; for_all_evt_queues(adapter, eqo, i) { aic = &adapter->aic_obj[eqo->idx]; eqd = be_get_new_eqd(eqo); if (force_update || eqd != aic->prev_eqd) { set_eqd[num].delay_multiplier = (eqd * 65)/100; set_eqd[num].eq_id = eqo->q.id; aic->prev_eqd = eqd; num++; } } if (num) be_cmd_modify_eqd(adapter, set_eqd, num); }

Contributors

PersonTokensPropCommitsCommitProp
padmanabh ratnakarpadmanabh ratnakar7053.85%120.00%
sathya perlasathya perla6046.15%480.00%
Total130100.00%5100.00%


static void be_rx_stats_update(struct be_rx_obj *rxo, struct be_rx_compl_info *rxcp) { struct be_rx_stats *stats = rx_stats(rxo); u64_stats_update_begin(&stats->sync); stats->rx_compl++; stats->rx_bytes += rxcp->pkt_size; stats->rx_pkts++; if (rxcp->tunneled) stats->rx_vxlan_offload_pkts++; if (rxcp->pkt_type == BE_MULTICAST_PACKET) stats->rx_mcast_pkts++; if (rxcp->err) stats->rx_compl_err++; u64_stats_update_end(&stats->sync); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla7073.68%562.50%
ajit khapardeajit khaparde1414.74%225.00%
sriharsha basavapatnasriharsha basavapatna1111.58%112.50%
Total95100.00%8100.00%


static inline bool csum_passed(struct be_rx_compl_info *rxcp) { /* L4 checksum is not reliable for non TCP/UDP packets. * Also ignore ipcksm for ipv6 pkts */ return (rxcp->tcpf || rxcp->udpf) && rxcp->l4_csum && (rxcp->ip_csum || rxcp->ipv6) && !rxcp->err; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla1944.19%240.00%
ajit khapardeajit khaparde1432.56%120.00%
padmanabh ratnakarpadmanabh ratnakar613.95%120.00%
somnath kotursomnath kotur49.30%120.00%
Total43100.00%5100.00%


static struct be_rx_page_info *get_rx_page_info(struct be_rx_obj *rxo) { struct be_adapter *adapter = rxo->adapter; struct be_rx_page_info *rx_page_info; struct be_queue_info *rxq = &rxo->q; u32 frag_idx = rxq->tail; rx_page_info = &rxo->page_info_tbl[frag_idx]; BUG_ON(!rx_page_info->page); if (rx_page_info->last_frag) { dma_unmap_page(&adapter->pdev->dev, dma_unmap_addr(rx_page_info, bus), adapter->big_page_size, DMA_FROM_DEVICE); rx_page_info->last_frag = false; } else { dma_sync_single_for_cpu(&adapter->pdev->dev, dma_unmap_addr(rx_page_info, bus), rx_frag_size, DMA_FROM_DEVICE); } queue_tail_inc(rxq); atomic_dec(&rxq->used); return rx_page_info; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla11482.01%444.44%
suresh reddysuresh reddy117.91%111.11%
ajit khapardeajit khaparde85.76%222.22%
ivan veceraivan vecera53.60%111.11%
fujita tomonorifujita tomonori10.72%111.11%
Total139100.00%9100.00%

/* Throwaway the data in the Rx completion */
static void be_rx_compl_discard(struct be_rx_obj *rxo, struct be_rx_compl_info *rxcp) { struct be_rx_page_info *page_info; u16 i, num_rcvd = rxcp->num_rcvd; for (i = 0; i < num_rcvd; i++) { page_info = get_rx_page_info(rxo); put_page(page_info->page); memset(page_info, 0, sizeof(*page_info)); } }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla72100.00%3100.00%
Total72100.00%3100.00%

/* * skb_fill_rx_data forms a complete skb for an ether frame * indicated by rxcp. */
static void skb_fill_rx_data(struct be_rx_obj *rxo, struct sk_buff *skb, struct be_rx_compl_info *rxcp) { struct be_rx_page_info *page_info; u16 i, j; u16 hdr_len, curr_frag_len, remaining; u8 *start; page_info = get_rx_page_info(rxo); start = page_address(page_info->page) + page_info->page_offset; prefetch(start); /* Copy data in the first descriptor of this completion */ curr_frag_len = min(rxcp->pkt_size, rx_frag_size); skb->len = curr_frag_len; if (curr_frag_len <= BE_HDR_LEN) { /* tiny packet */ memcpy(skb->data, start, curr_frag_len); /* Complete packet has now been moved to data */ put_page(page_info->page); skb->data_len = 0; skb->tail += curr_frag_len; } else { hdr_len = ETH_HLEN; memcpy(skb->data, start, hdr_len); skb_shinfo(skb)->nr_frags = 1; skb_frag_set_page(skb, 0, page_info->page); skb_shinfo(skb)->frags[0].page_offset = page_info->page_offset + hdr_len; skb_frag_size_set(&skb_shinfo(skb)->frags[0], curr_frag_len - hdr_len); skb->data_len = curr_frag_len - hdr_len; skb->truesize += rx_frag_size; skb->tail += hdr_len; } page_info->page = NULL; if (rxcp->pkt_size <= rx_frag_size) { BUG_ON(rxcp->num_rcvd != 1); return; } /* More frags present for this completion */ remaining = rxcp->pkt_size - curr_frag_len; for (i = 1, j = 0; i < rxcp->num_rcvd; i++) { page_info = get_rx_page_info(rxo); curr_frag_len = min(remaining, rx_frag_size); /* Coalesce all frags from the same physical page in one slot */ if (page_info->page_offset == 0) { /* Fresh page */ j++; skb_frag_set_page(skb, j, page_info->page); skb_shinfo(skb)->frags[j].page_offset = page_info->page_offset; skb_frag_size_set(&skb_shinfo(skb)->frags[j], 0); skb_shinfo(skb)->nr_frags++; } else { put_page(page_info->page); } skb_frag_size_add(&skb_shinfo(skb)->frags[j], curr_frag_len); skb->len += curr_frag_len; skb->data_len += curr_frag_len; skb->truesize += rx_frag_size; remaining -= curr_frag_len; page_info->page = NULL; } BUG_ON(j > MAX_SKB_FRAGS); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla29069.38%330.00%
ajit khapardeajit khaparde6716.03%330.00%
eric dumazeteric dumazet5312.68%330.00%
ian campbellian campbell81.91%110.00%
Total418100.00%10100.00%

/* Process the RX completion indicated by rxcp when GRO is disabled */
static void be_rx_compl_process(struct be_rx_obj *rxo, struct napi_struct *napi, struct be_rx_compl_info *rxcp) { struct be_adapter *adapter = rxo->adapter; struct net_device *netdev = adapter->netdev; struct sk_buff *skb; skb = netdev_alloc_skb_ip_align(netdev, BE_RX_SKB_ALLOC_SIZE); if (unlikely(!skb)) { rx_stats(rxo)->rx_drops_no_skbs++; be_rx_compl_discard(rxo, rxcp); return; } skb_fill_rx_data(rxo, skb, rxcp); if (likely((netdev->features & NETIF_F_RXCSUM) && csum_passed(rxcp))) skb->ip_summed = CHECKSUM_UNNECESSARY; else skb_checksum_none_assert(skb); skb->protocol = eth_type_trans(skb, netdev); skb_record_rx_queue(skb, rxo - &adapter->rx_obj[0]); if (netdev->features & NETIF_F_RXHASH) skb_set_hash(skb, rxcp->rss_hash, PKT_HASH_TYPE_L3); skb->csum_level = rxcp->tunneled; skb_mark_napi_id(skb, napi); if (rxcp->vlanf) __vlan_hwaccel_put_tag(skb, htons(ETH_P_8021Q), rxcp->vlan_tag); netif_receive_skb(skb); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla12360.59%833.33%
somnath kotursomnath kotur2813.79%312.50%
ajit khapardeajit khaparde199.36%520.83%
michal miroslawmichal miroslaw157.39%14.17%
tom herberttom herbert73.45%28.33%
eric dumazeteric dumazet62.96%416.67%
patrick mchardypatrick mchardy52.46%14.17%
Total203100.00%24100.00%

/* Process the RX completion indicated by rxcp when GRO is enabled */
static void be_rx_compl_process_gro(struct be_rx_obj *rxo, struct napi_struct *napi, struct be_rx_compl_info *rxcp) { struct be_adapter *adapter = rxo->adapter; struct be_rx_page_info *page_info; struct sk_buff *skb = NULL; u16 remaining, curr_frag_len; u16 i, j; skb = napi_get_frags(napi); if (!skb) { be_rx_compl_discard(rxo, rxcp); return; } remaining = rxcp->pkt_size; for (i = 0, j = -1; i < rxcp->num_rcvd; i++) { page_info = get_rx_page_info(rxo); curr_frag_len = min(remaining, rx_frag_size); /* Coalesce all frags from the same physical page in one slot */ if (i == 0 || page_info->page_offset == 0) { /* First frag or Fresh page */ j++; skb_frag_set_page(skb, j, page_info->page); skb_shinfo(skb)->frags[j].page_offset = page_info->page_offset; skb_frag_size_set(&skb_shinfo(skb)->frags[j], 0); } else { put_page(page_info->page); } skb_frag_size_add(&skb_shinfo(skb)->frags[j], curr_frag_len); skb->truesize += rx_frag_size; remaining -= curr_frag_len; memset(page_info, 0, sizeof(*page_info)); } BUG_ON(j > MAX_SKB_FRAGS); skb_shinfo(skb)->nr_frags = j + 1; skb->len = rxcp->pkt_size; skb->data_len = rxcp->pkt_size; skb->ip_summed = CHECKSUM_UNNECESSARY; skb_record_rx_queue(skb, rxo - &adapter->rx_obj[0]); if (adapter->netdev->features & NETIF_F_RXHASH) skb_set_hash(skb, rxcp->rss_hash, PKT_HASH_TYPE_L3); skb->csum_level = rxcp->tunneled; if (rxcp->vlanf) __vlan_hwaccel_put_tag(skb, htons(ETH_P_8021Q), rxcp->vlan_tag); napi_gro_frags(napi); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla16348.22%526.32%
ajit khapardeajit khaparde12737.57%631.58%
eric dumazeteric dumazet164.73%210.53%
somnath kotursomnath kotur154.44%15.26%
tom herberttom herbert72.07%210.53%
patrick mchardypatrick mchardy51.48%15.26%
ian campbellian campbell41.18%15.26%
jingoo hanjingoo han10.30%15.26%
Total338100.00%19100.00%


static void be_parse_rx_compl_v1(struct be_eth_rx_compl *compl, struct be_rx_compl_info *rxcp) { rxcp->pkt_size = GET_RX_COMPL_V1_BITS(pktsize, compl); rxcp->vlanf = GET_RX_COMPL_V1_BITS(vtp, compl); rxcp->err = GET_RX_COMPL_V1_BITS(err, compl); rxcp->tcpf = GET_RX_COMPL_V1_BITS(tcpf, compl); rxcp->udpf = GET_RX_COMPL_V1_BITS(udpf, compl); rxcp->ip_csum = GET_RX_COMPL_V1_BITS(ipcksm, compl); rxcp->l4_csum = GET_RX_COMPL_V1_BITS(l4_cksm, compl); rxcp->ipv6 = GET_RX_COMPL_V1_BITS(ip_version, compl); rxcp->num_rcvd = GET_RX_COMPL_V1_BITS(numfrags, compl); rxcp->pkt_type = GET_RX_COMPL_V1_BITS(cast_enc, compl); rxcp->rss_hash = GET_RX_COMPL_V1_BITS(rsshash, compl); if (rxcp->vlanf) { rxcp->qnq = GET_RX_COMPL_V1_BITS(qnq, compl); rxcp->vlan_tag = GET_RX_COMPL_V1_BITS(vlan_tag, compl); } rxcp->port = GET_RX_COMPL_V1_BITS(port, compl); rxcp->tunneled = GET_RX_COMPL_V1_BITS(tunneled, compl); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla16687.83%758.33%
padmanabh ratnakarpadmanabh ratnakar105.29%18.33%
ajit khapardeajit khaparde94.76%18.33%
vasundhara volamvasundhara volam21.06%18.33%
somnath kotursomnath kotur10.53%18.33%
sarveshwar bandisarveshwar bandi10.53%18.33%
Total189100.00%12100.00%


static void be_parse_rx_compl_v0(struct be_eth_rx_compl *compl, struct be_rx_compl_info *rxcp) { rxcp->pkt_size = GET_RX_COMPL_V0_BITS(pktsize, compl); rxcp->vlanf = GET_RX_COMPL_V0_BITS(vtp, compl); rxcp->err = GET_RX_COMPL_V0_BITS(err, compl); rxcp->tcpf = GET_RX_COMPL_V0_BITS(tcpf, compl); rxcp->udpf = GET_RX_COMPL_V0_BITS(udpf, compl); rxcp->ip_csum = GET_RX_COMPL_V0_BITS(ipcksm, compl); rxcp->l4_csum = GET_RX_COMPL_V0_BITS(l4_cksm, compl); rxcp->ipv6 = GET_RX_COMPL_V0_BITS(ip_version, compl); rxcp->num_rcvd = GET_RX_COMPL_V0_BITS(numfrags, compl); rxcp->pkt_type = GET_RX_COMPL_V0_BITS(cast_enc, compl); rxcp->rss_hash = GET_RX_COMPL_V0_BITS(rsshash, compl); if (rxcp->vlanf) { rxcp->qnq = GET_RX_COMPL_V0_BITS(qnq, compl); rxcp->vlan_tag = GET_RX_COMPL_V0_BITS(vlan_tag, compl); } rxcp->port = GET_RX_COMPL_V0_BITS(port, compl); rxcp->ip_frag = GET_RX_COMPL_V0_BITS(ip_frag, compl); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla15682.54%545.45%
somnath kotursomnath kotur115.82%218.18%
padmanabh ratnakarpadmanabh ratnakar105.29%19.09%
ajit khapardeajit khaparde94.76%19.09%
vasundhara volamvasundhara volam21.06%19.09%
sarveshwar bandisarveshwar bandi10.53%19.09%
Total189100.00%11100.00%


static struct be_rx_compl_info *be_rx_compl_get(struct be_rx_obj *rxo) { struct be_eth_rx_compl *compl = queue_tail_node(&rxo->cq); struct be_rx_compl_info *rxcp = &rxo->rxcp; struct be_adapter *adapter = rxo->adapter; /* For checking the valid bit it is Ok to use either definition as the * valid bit is at the same position in both v0 and v1 Rx compl */ if (compl->dw[offsetof(struct amap_eth_rx_compl_v1, valid) / 32] == 0) return NULL; rmb(); be_dws_le_to_cpu(compl, sizeof(*compl)); if (adapter->be3_native) be_parse_rx_compl_v1(compl, rxcp); else be_parse_rx_compl_v0(compl, rxcp); if (rxcp->ip_frag) rxcp->l4_csum = 0; if (rxcp->vlanf) { /* In QNQ modes, if qnq bit is not set, then the packet was * tagged only with the transparent outer vlan-tag and must * not be treated as a vlan packet by host */ if (be_is_qnq_mode(adapter) && !rxcp->qnq) rxcp->vlanf = 0; if (!lancer_chip(adapter)) rxcp->vlan_tag = swab16(rxcp->vlan_tag); if (adapter->pvid == (rxcp->vlan_tag & VLAN_VID_MASK) && !test_bit(rxcp->vlan_tag, adapter->vids)) rxcp->vlanf = 0; } /* As the compl has been parsed, reset it; we wont touch it again */ compl->dw[offsetof(struct amap_eth_rx_compl_v1, valid) / 32] = 0; queue_tail_inc(&rxo->cq); return rxcp; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla19085.59%660.00%
somnath kotursomnath kotur209.01%220.00%
ravikumar nelavelliravikumar nelavelli73.15%110.00%
vasundhara volamvasundhara volam52.25%110.00%
Total222100.00%10100.00%


static inline struct page *be_alloc_pages(u32 size, gfp_t gfp) { u32 order = get_order(size); if (order > 0) gfp |= __GFP_COMP; return alloc_pages(gfp, order); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla3687.80%150.00%
eric dumazeteric dumazet512.20%150.00%
Total41100.00%2100.00%

/* * Allocate a page, split it to fragments of size rx_frag_size and post as * receive buffers to BE */
static void be_post_rx_frags(struct be_rx_obj *rxo, gfp_t gfp, u32 frags_needed) { struct be_adapter *adapter = rxo->adapter; struct be_rx_page_info *page_info = NULL, *prev_page_info = NULL; struct be_queue_info *rxq = &rxo->q; struct page *pagep = NULL; struct device *dev = &adapter->pdev->dev; struct be_eth_rx_d *rxd; u64 page_dmaaddr = 0, frag_dmaaddr; u32 posted, page_offset = 0, notify = 0; page_info = &rxo->page_info_tbl[rxq->head]; for (posted = 0; posted < frags_needed && !page_info->page; posted++) { if (!pagep) { pagep = be_alloc_pages(adapter->big_page_size, gfp); if (unlikely(!pagep)) { rx_stats(rxo)->rx_post_fail++; break; } page_dmaaddr = dma_map_page(dev, pagep, 0, adapter->big_page_size, DMA_FROM_DEVICE); if (dma_mapping_error(dev, page_dmaaddr)) { put_page(pagep); pagep = NULL; adapter->drv_stats.dma_map_errors++; break; } page_offset = 0; } else { get_page(pagep); page_offset += rx_frag_size; } page_info->page_offset = page_offset; page_info->page = pagep; rxd = queue_head_node(rxq); frag_dmaaddr = page_dmaaddr + page_info->page_offset; rxd->fragpa_lo = cpu_to_le32(frag_dmaaddr & 0xFFFFFFFF); rxd->fragpa_hi = cpu_to_le32(upper_32_bits(frag_dmaaddr)); /* Any space left in the current big page for another frag? */ if ((page_offset + rx_frag_size + rx_frag_size) > adapter->big_page_size) { pagep = NULL; page_info->last_frag = true; dma_unmap_addr_set(page_info, bus, page_dmaaddr); } else { dma_unmap_addr_set(page_info, bus, frag_dmaaddr); } prev_page_info = page_info; queue_head_inc(rxq); page_info = &rxo->page_info_tbl[rxq->head]; } /* Mark the last frag of a page when we break out of the above loop * with no more slots available in the RXQ */ if (pagep) { prev_page_info->last_frag = true; dma_unmap_addr_set(prev_page_info, bus, page_dmaaddr); } if (posted) { atomic_add(posted, &rxq->used); if (rxo->rx_post_starved) rxo->rx_post_starved = false; do { notify = min(MAX_NUM_POST_ERX_DB, posted); be_rxq_notify(adapter, rxq->id, notify); posted -= notify; } while (posted); } else if (atomic_read(&rxq->used) == 0) { /* Let be_worker replenish when memory is available */ rxo->rx_post_starved = true; } }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla36582.39%857.14%
ivan veceraivan vecera398.80%214.29%
ajit khapardeajit khaparde306.77%214.29%
eric dumazeteric dumazet51.13%17.14%
vasundhara volamvasundhara volam40.90%17.14%
Total443100.00%14100.00%


static struct be_tx_compl_info *be_tx_compl_get(struct be_tx_obj *txo) { struct be_queue_info *tx_cq = &txo->cq; struct be_tx_compl_info *txcp = &txo->txcp; struct be_eth_tx_compl *compl = queue_tail_node(tx_cq); if (compl->dw[offsetof(struct amap_eth_tx_compl, valid) / 32] == 0) return NULL; /* Ensure load ordering of valid bit dword and other dwords below */ rmb(); be_dws_le_to_cpu(compl, sizeof(*compl)); txcp->status = GET_TX_COMPL_BITS(status, compl); txcp->end_index = GET_TX_COMPL_BITS(wrb_index, compl); compl->dw[offsetof(struct amap_eth_tx_compl, valid) / 32] = 0; queue_tail_inc(tx_cq); return txcp; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla7760.63%375.00%
sriharsha basavapatnasriharsha basavapatna5039.37%125.00%
Total127100.00%4100.00%


static u16 be_tx_compl_process(struct be_adapter *adapter, struct be_tx_obj *txo, u16 last_index) { struct sk_buff **sent_skbs = txo->sent_skb_list; struct be_queue_info *txq = &txo->q; struct sk_buff *skb = NULL; bool unmap_skb_hdr = false; struct be_eth_wrb *wrb; u16 num_wrbs = 0; u32 frag_index; do { if (sent_skbs[txq->tail]) { /* Free skb from prev req */ if (skb) dev_consume_skb_any(skb); skb = sent_skbs[txq->tail]; sent_skbs[txq->tail] = NULL; queue_tail_inc(txq); /* skip hdr wrb */ num_wrbs++; unmap_skb_hdr = true; } wrb = queue_tail_node(txq); frag_index = txq->tail; unmap_tx_frag(&adapter->pdev->dev, wrb, (unmap_skb_hdr && skb_headlen(skb))); unmap_skb_hdr = false; queue_tail_inc(txq); num_wrbs++; } while (frag_index != last_index); dev_consume_skb_any(skb); return num_wrbs; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla13977.22%436.36%
alexander duyckalexander duyck179.44%19.09%
ajit khapardeajit khaparde137.22%218.18%
padmanabh ratnakarpadmanabh ratnakar42.22%19.09%
ivan veceraivan vecera31.67%19.09%
eric dumazeteric dumazet31.67%19.09%
rick jonesrick jones10.56%19.09%
Total180100.00%11100.00%

/* Return the number of events in the event queue */
static inline int events_get(struct be_eq_obj *eqo) { struct be_eq_entry *eqe; int num = 0; do { eqe = queue_tail_node(&eqo->q); if (eqe->evt == 0) break; rmb(); eqe->evt = 0; num++; queue_tail_inc(&eqo->q); } while (true); return num; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla72100.00%3100.00%
Total72100.00%3100.00%

/* Leaves the EQ is disarmed state */
static void be_eq_clean(struct be_eq_obj *eqo) { int num = events_get(eqo); be_eq_notify(eqo->adapter, eqo->q.id, false, true, num, 0); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla3895.00%266.67%
padmanabh ratnakarpadmanabh ratnakar25.00%133.33%
Total40100.00%3100.00%

/* Free posted rx buffers that were not used */
static void be_rxq_clean(struct be_rx_obj *rxo) { struct be_queue_info *rxq = &rxo->q; struct be_rx_page_info *page_info; while (atomic_read(&rxq->used) > 0) { page_info = get_rx_page_info(rxo); put_page(page_info->page); memset(page_info, 0, sizeof(*page_info)); } BUG_ON(atomic_read(&rxq->used)); rxq->tail = 0; rxq->head = 0; }

Contributors

PersonTokensPropCommitsCommitProp
kalesh purayilkalesh purayil7077.78%133.33%
sathya perlasathya perla2022.22%266.67%
Total90100.00%3100.00%


static void be_rx_cq_clean(struct be_rx_obj *rxo) { struct be_queue_info *rx_cq = &rxo->cq; struct be_rx_compl_info *rxcp; struct be_adapter *adapter = rxo->adapter; int flush_wait = 0; /* Consume pending rx completions. * Wait for the flush completion (identified by zero num_rcvd) * to arrive. Notify CQ even when there are no more CQ entries * for HW to flush partially coalesced CQ entries. * In Lancer, there is no need to wait for flush compl. */ for (;;) { rxcp = be_rx_compl_get(rxo); if (!rxcp) { if (lancer_chip(adapter)) break; if (flush_wait++ > 50 || be_check_error(adapter, BE_ERROR_HW)) { dev_warn(&adapter->pdev->dev, "did not receive flush compl\n"); break; } be_cq_notify(adapter, rx_cq->id, true, 0); mdelay(1); } else { be_rx_compl_discard(rxo, rxcp); be_cq_notify(adapter, rx_cq->id, false, 1); if (rxcp->num_rcvd == 0) break; } } /* After cleanup, leave the CQ in unarmed state */ be_cq_notify(adapter, rx_cq->id, false, 0); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla14790.18%562.50%
kalesh purayilkalesh purayil127.36%225.00%
venkat duvvuruvenkat duvvuru42.45%112.50%
Total163100.00%8100.00%


static void be_tx_compl_clean(struct be_adapter *adapter) { struct device *dev = &adapter->pdev->dev; u16 cmpl = 0, timeo = 0, num_wrbs = 0; struct be_tx_compl_info *txcp; struct be_queue_info *txq; u32 end_idx, notified_idx; struct be_tx_obj *txo; int i, pending_txqs; /* Stop polling for compls when HW has been silent for 10ms */ do { pending_txqs = adapter->num_tx_qs; for_all_tx_queues(adapter, txo, i) { cmpl = 0; num_wrbs = 0; txq = &txo->q; while ((txcp = be_tx_compl_get(txo))) { num_wrbs += be_tx_compl_process(adapter, txo, txcp->end_index); cmpl++; } if (cmpl) { be_cq_notify(adapter, txo->cq.id, false, cmpl); atomic_sub(num_wrbs, &txq->used); timeo = 0; } if (!be_is_tx_compl_pending(txo)) pending_txqs--; } if (pending_txqs == 0 || ++timeo > 10 || be_check_error(adapter, BE_ERROR_HW)) break; mdelay(1); } while (true); /* Free enqueued TX that was never notified to HW */ for_all_tx_queues(adapter, txo, i) { txq = &txo->q; if (atomic_read(&txq->used)) { dev_info(dev, "txq%d: cleaning %d pending tx-wrbs\n", i, atomic_read(&txq->used)); notified_idx = txq->tail; end_idx = txq->tail; index_adv(&end_idx, atomic_read(&txq->used) - 1, txq->len); /* Use the tx-compl process logic to handle requests * that were not sent to the HW. */ num_wrbs = be_tx_compl_process(adapter, txo, end_idx); atomic_sub(num_wrbs, &txq->used); BUG_ON(atomic_read(&txq->used)); txo->pend_wrb_cnt = 0; /* Since hw was never notified of these requests, * reset TXQ indices */ txq->head = notified_idx; txq->tail = notified_idx; } } }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla25577.04%650.00%
padmanabh ratnakarpadmanabh ratnakar319.37%18.33%
ajit khapardeajit khaparde175.14%18.33%
vasundhara volamvasundhara volam154.53%18.33%
sriharsha basavapatnasriharsha basavapatna103.02%216.67%
venkat duvvuruvenkat duvvuru30.91%18.33%
Total331100.00%12100.00%


static void be_evt_queues_destroy(struct be_adapter *adapter) { struct be_eq_obj *eqo; int i; for_all_evt_queues(adapter, eqo, i) { if (eqo->q.created) { be_eq_clean(eqo); be_cmd_q_destroy(adapter, &eqo->q, QTYPE_EQ); netif_napi_del(&eqo->napi); free_cpumask_var(eqo->affinity_mask); } be_queue_free(adapter, &eqo->q); } }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla6782.72%457.14%
padmanabh ratnakarpadmanabh ratnakar1316.05%228.57%
kalesh purayilkalesh purayil11.23%114.29%
Total81100.00%7100.00%


static int be_evt_queues_create(struct be_adapter *adapter) { struct be_queue_info *eq; struct be_eq_obj *eqo; struct be_aic_obj *aic; int i, rc; /* need enough EQs to service both RX and TX queues */ adapter->num_evt_qs = min_t(u16, num_irqs(adapter), max(adapter->cfg_num_rx_irqs, adapter->cfg_num_tx_irqs)); for_all_evt_queues(adapter, eqo, i) { int numa_node = dev_to_node(&adapter->pdev->dev); aic = &adapter->aic_obj[i]; eqo->adapter = adapter; eqo->idx = i; aic->max_eqd = BE_MAX_EQD; aic->enable = true; eq = &eqo->q; rc = be_queue_alloc(adapter, eq, EVNT_Q_LEN, sizeof(struct be_eq_entry)); if (rc) return rc; rc = be_cmd_eq_create(adapter, eqo); if (rc) return rc; if (!zalloc_cpumask_var(&eqo->affinity_mask, GFP_KERNEL)) return -ENOMEM; cpumask_set_cpu(cpumask_local_spread(i, numa_node), eqo->affinity_mask); netif_napi_add(adapter->netdev, &eqo->napi, be_poll, BE_NAPI_WEIGHT); } return 0; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla15372.51%880.00%
kalesh purayilkalesh purayil4521.33%110.00%
rusty russellrusty russell136.16%110.00%
Total211100.00%10100.00%


static void be_mcc_queues_destroy(struct be_adapter *adapter) { struct be_queue_info *q; q = &adapter->mcc_obj.q; if (q->created) be_cmd_q_destroy(adapter, q, QTYPE_MCCQ); be_queue_free(adapter, q); q = &adapter->mcc_obj.cq; if (q->created) be_cmd_q_destroy(adapter, q, QTYPE_CQ); be_queue_free(adapter, q); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla78100.00%1100.00%
Total78100.00%1100.00%

/* Must be called only after TX qs are created as MCC shares TX EQ */
static int be_mcc_queues_create(struct be_adapter *adapter) { struct be_queue_info *q, *cq; cq = &adapter->mcc_obj.cq; if (be_queue_alloc(adapter, cq, MCC_CQ_LEN, sizeof(struct be_mcc_compl))) goto err; /* Use the default EQ for MCC completions */ if (be_cmd_cq_create(adapter, cq, &mcc_eqo(adapter)->q, true, 0)) goto mcc_cq_free; q = &adapter->mcc_obj.q; if (be_queue_alloc(adapter, q, MCC_Q_LEN, sizeof(struct be_mcc_wrb))) goto mcc_cq_destroy; if (be_cmd_mccq_create(adapter, q, cq)) goto mcc_q_free; return 0; mcc_q_free: be_queue_free(adapter, q); mcc_cq_destroy: be_cmd_q_destroy(adapter, cq, QTYPE_CQ); mcc_cq_free: be_queue_free(adapter, cq); err: return -1; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla154100.00%3100.00%
Total154100.00%3100.00%


static void be_tx_queues_destroy(struct be_adapter *adapter) { struct be_queue_info *q; struct be_tx_obj *txo; u8 i; for_all_tx_queues(adapter, txo, i) { q = &txo->q; if (q->created) be_cmd_q_destroy(adapter, q, QTYPE_TXQ); be_queue_free(adapter, q); q = &txo->cq; if (q->created) be_cmd_q_destroy(adapter, q, QTYPE_CQ); be_queue_free(adapter, q); } }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla92100.00%2100.00%
Total92100.00%2100.00%


static int be_tx_qs_create(struct be_adapter *adapter) { struct be_queue_info *cq; struct be_tx_obj *txo; struct be_eq_obj *eqo; int status, i; adapter->num_tx_qs = min(adapter->num_evt_qs, adapter->cfg_num_tx_irqs); for_all_tx_queues(adapter, txo, i) { cq = &txo->cq; status = be_queue_alloc(adapter, cq, TX_CQ_LEN, sizeof(struct be_eth_tx_compl)); if (status) return status; u64_stats_init(&txo->stats.sync); u64_stats_init(&txo->stats.sync_compl); /* If num_evt_qs is less than num_tx_qs, then more than * one txq share an eq */ eqo = &adapter->eq_obj[i % adapter->num_evt_qs]; status = be_cmd_cq_create(adapter, cq, &eqo->q, false, 3); if (status) return status; status = be_queue_alloc(adapter, &txo->q, TX_Q_LEN, sizeof(struct be_eth_wrb)); if (status) return status; status = be_cmd_txq_create(adapter, txo); if (status) return status; netif_set_xps_queue(adapter->netdev, eqo->affinity_mask, eqo->idx); } dev_info(&adapter->pdev->dev, "created %d TX queue(s)\n", adapter->num_tx_qs); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla20491.07%1090.91%
john stultzjohn stultz208.93%19.09%
Total224100.00%11100.00%


static void be_rx_cqs_destroy(struct be_adapter *adapter) { struct be_queue_info *q; struct be_rx_obj *rxo; int i; for_all_rx_queues(adapter, rxo, i) { q = &rxo->cq; if (q->created) be_cmd_q_destroy(adapter, q, QTYPE_CQ); be_queue_free(adapter, q); } }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla63100.00%3100.00%
Total63100.00%3100.00%


static int be_rx_cqs_create(struct be_adapter *adapter) { struct be_queue_info *eq, *cq; struct be_rx_obj *rxo; int rc, i; adapter->num_rss_qs = min(adapter->num_evt_qs, adapter->cfg_num_rx_irqs); /* We'll use RSS only if atleast 2 RSS rings are supported. */ if (adapter->num_rss_qs < 2) adapter->num_rss_qs = 0; adapter->num_rx_qs = adapter->num_rss_qs + adapter->need_def_rxq; /* When the interface is not capable of RSS rings (and there is no * need to create a default RXQ) we'll still need one RXQ */ if (adapter->num_rx_qs == 0) adapter->num_rx_qs = 1; adapter->big_page_size = (1 << get_order(rx_frag_size)) * PAGE_SIZE; for_all_rx_queues(adapter, rxo, i) { rxo->adapter = adapter; cq = &rxo->cq; rc = be_queue_alloc(adapter, cq, RX_CQ_LEN, sizeof(struct be_eth_rx_compl)); if (rc) return rc; u64_stats_init(&rxo->stats.sync); eq = &adapter->eq_obj[i % adapter->num_evt_qs].q; rc = be_cmd_cq_create(adapter, cq, eq, false, 3); if (rc) return rc; } dev_info(&adapter->pdev->dev, "created %d RX queue(s)\n", adapter->num_rx_qs); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla17280.00%981.82%
vasundhara volamvasundhara volam3315.35%19.09%
john stultzjohn stultz104.65%19.09%
Total215100.00%11100.00%


static irqreturn_t be_intx(int irq, void *dev) { struct be_eq_obj *eqo = dev; struct be_adapter *adapter = eqo->adapter; int num_evts = 0; /* IRQ is not expected when NAPI is scheduled as the EQ * will not be armed. * But, this can happen on Lancer INTx where it takes * a while to de-assert INTx or in BE2 where occasionaly * an interrupt may be raised even when EQ is unarmed. * If NAPI is already scheduled, then counting & notifying * events will orphan them. */ if (napi_schedule_prep(&eqo->napi)) { num_evts = events_get(eqo); __napi_schedule(&eqo->napi); if (num_evts) eqo->spurious_intr = 0; } be_eq_notify(adapter, eqo->q.id, false, true, num_evts, 0); /* Return IRQ_HANDLED only for the the first spurious intr * after a valid intr to stop the kernel from branding * this irq as a bad one! */ if (num_evts || eqo->spurious_intr++ == 0) return IRQ_HANDLED; else return IRQ_NONE; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla10898.18%480.00%
padmanabh ratnakarpadmanabh ratnakar21.82%120.00%
Total110100.00%5100.00%


static irqreturn_t be_msix(int irq, void *dev) { struct be_eq_obj *eqo = dev; be_eq_notify(eqo->adapter, eqo->q.id, false, true, 0, 0); napi_schedule(&eqo->napi); return IRQ_HANDLED; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla5096.15%375.00%
padmanabh ratnakarpadmanabh ratnakar23.85%125.00%
Total52100.00%4100.00%


static inline bool do_gro(struct be_rx_compl_info *rxcp) { return (rxcp->tcpf && !rxcp->err && rxcp->l4_csum) ? true : false; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla2371.88%250.00%
ajit khapardeajit khaparde515.62%125.00%
somnath kotursomnath kotur412.50%125.00%
Total32100.00%4100.00%


static int be_process_rx(struct be_rx_obj *rxo, struct napi_struct *napi, int budget, int polling) { struct be_adapter *adapter = rxo->adapter; struct be_queue_info *rx_cq = &rxo->cq; struct be_rx_compl_info *rxcp; u32 work_done; u32 frags_consumed = 0; for (work_done = 0; work_done < budget; work_done++) { rxcp = be_rx_compl_get(rxo); if (!rxcp) break; /* Is it a flush compl that has no data */ if (unlikely(rxcp->num_rcvd == 0)) goto loop_continue; /* Discard compl with partial DMA Lancer B0 */ if (unlikely(!rxcp->pkt_size)) { be_rx_compl_discard(rxo, rxcp); goto loop_continue; } /* On BE drop pkts that arrive due to imperfect filtering in * promiscuous mode on some skews */ if (unlikely(rxcp->port != adapter->port_num && !lancer_chip(adapter))) { be_rx_compl_discard(rxo, rxcp); goto loop_continue; } /* Don't do gro when we're busy_polling */ if (do_gro(rxcp) && polling != BUSY_POLLING) be_rx_compl_process_gro(rxo, napi, rxcp); else be_rx_compl_process(rxo, napi, rxcp); loop_continue: frags_consumed += rxcp->num_rcvd; be_rx_stats_update(rxo, rxcp); } if (work_done) { be_cq_notify(adapter, rx_cq->id, true, work_done); /* When an rx-obj gets into post_starved state, just * let be_worker do the posting. */ if (atomic_read(&rxo->q.used) < RX_FRAGS_REFILL_WM && !rxo->rx_post_starved) be_post_rx_frags(rxo, GFP_ATOMIC, max_t(u32, MAX_RX_POST, frags_consumed)); } return work_done; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla21182.42%861.54%
padmanabh ratnakarpadmanabh ratnakar228.59%215.38%
ajit khapardeajit khaparde207.81%17.69%
eric dumazeteric dumazet20.78%17.69%
stephen hemmingerstephen hemminger10.39%17.69%
Total256100.00%13100.00%


static inline void be_update_tx_err(struct be_tx_obj *txo, u8 status) { switch (status) { case BE_TX_COMP_HDR_PARSE_ERR: tx_stats(txo)->tx_hdr_parse_err++; break; case BE_TX_COMP_NDMA_ERR: tx_stats(txo)->tx_dma_err++; break; case BE_TX_COMP_ACL_ERR: tx_stats(txo)->tx_spoof_check_err++; break; } }

Contributors

PersonTokensPropCommitsCommitProp
kalesh purayilkalesh purayil5698.25%150.00%
sriharsha basavapatnasriharsha basavapatna11.75%150.00%
Total57100.00%2100.00%


static inline void lancer_update_tx_err(struct be_tx_obj *txo, u8 status) { switch (status) { case LANCER_TX_COMP_LSO_ERR: tx_stats(txo)->tx_tso_err++; break; case LANCER_TX_COMP_HSW_DROP_MAC_ERR: case LANCER_TX_COMP_HSW_DROP_VLAN_ERR: tx_stats(txo)->tx_spoof_check_err++; break; case LANCER_TX_COMP_QINQ_ERR: tx_stats(txo)->tx_qinq_err++; break; case LANCER_TX_COMP_PARITY_ERR: tx_stats(txo)->tx_internal_parity_err++; break; case LANCER_TX_COMP_DMA_ERR: tx_stats(txo)->tx_dma_err++; break; } }

Contributors

PersonTokensPropCommitsCommitProp
kalesh purayilkalesh purayil8398.81%150.00%
sriharsha basavapatnasriharsha basavapatna11.19%150.00%
Total84100.00%2100.00%


static void be_process_tx(struct be_adapter *adapter, struct be_tx_obj *txo, int idx) { int num_wrbs = 0, work_done = 0; struct be_tx_compl_info *txcp; while ((txcp = be_tx_compl_get(txo))) { num_wrbs += be_tx_compl_process(adapter, txo, txcp->end_index); work_done++; if (txcp->status) { if (lancer_chip(adapter)) lancer_update_tx_err(txo, txcp->status); else be_update_tx_err(txo, txcp->status); } } if (work_done) { be_cq_notify(adapter, txo->cq.id, true, work_done); atomic_sub(num_wrbs, &txo->q.used); /* As Tx wrbs have been freed up, wake up netdev queue * if it was stopped due to lack of tx wrbs. */ if (__netif_subqueue_stopped(adapter->netdev, idx) && be_can_txq_wake(txo)) { netif_wake_subqueue(adapter->netdev, idx); } u64_stats_update_begin(&tx_stats(txo)->sync_compl); tx_stats(txo)->tx_compl += work_done; u64_stats_update_end(&tx_stats(txo)->sync_compl); } }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla13471.28%861.54%
kalesh purayilkalesh purayil2513.30%17.69%
sriharsha basavapatnasriharsha basavapatna179.04%215.38%
padmanabh ratnakarpadmanabh ratnakar126.38%215.38%
Total188100.00%13100.00%

#ifdef CONFIG_NET_RX_BUSY_POLL
static inline bool be_lock_napi(struct be_eq_obj *eqo) { bool status = true; spin_lock(&eqo->lock); /* BH is already disabled */ if (eqo->state & BE_EQ_LOCKED) { WARN_ON(eqo->state & BE_EQ_NAPI); eqo->state |= BE_EQ_NAPI_YIELD; status = false; } else { eqo->state = BE_EQ_NAPI; } spin_unlock(&eqo->lock); return status; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla75100.00%1100.00%
Total75100.00%1100.00%


static inline void be_unlock_napi(struct be_eq_obj *eqo) { spin_lock(&eqo->lock); /* BH is already disabled */ WARN_ON(eqo->state & (BE_EQ_POLL | BE_EQ_NAPI_YIELD)); eqo->state = BE_EQ_IDLE; spin_unlock(&eqo->lock); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla48100.00%1100.00%
Total48100.00%1100.00%


static inline bool be_lock_busy_poll(struct be_eq_obj *eqo) { bool status = true; spin_lock_bh(&eqo->lock); if (eqo->state & BE_EQ_LOCKED) { eqo->state |= BE_EQ_POLL_YIELD; status = false; } else { eqo->state |= BE_EQ_POLL; } spin_unlock_bh(&eqo->lock); return status; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla65100.00%1100.00%
Total65100.00%1100.00%


static inline void be_unlock_busy_poll(struct be_eq_obj *eqo) { spin_lock_bh(&eqo->lock); WARN_ON(eqo->state & (BE_EQ_NAPI)); eqo->state = BE_EQ_IDLE; spin_unlock_bh(&eqo->lock); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla45100.00%1100.00%
Total45100.00%1100.00%


static inline void be_enable_busy_poll(struct be_eq_obj *eqo) { spin_lock_init(&eqo->lock); eqo->state = BE_EQ_IDLE; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla26100.00%1100.00%
Total26100.00%1100.00%


static inline void be_disable_busy_poll(struct be_eq_obj *eqo) { local_bh_disable(); /* It's enough to just acquire napi lock on the eqo to stop * be_busy_poll() from processing any queueus. */ while (!be_lock_napi(eqo)) mdelay(1); local_bh_enable(); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla32100.00%1100.00%
Total32100.00%1100.00%

#else /* CONFIG_NET_RX_BUSY_POLL */
static inline bool be_lock_napi(struct be_eq_obj *eqo) { return true; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla15100.00%1100.00%
Total15100.00%1100.00%


static inline void be_unlock_napi(struct be_eq_obj *eqo) { }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla11100.00%1100.00%
Total11100.00%1100.00%


static inline bool be_lock_busy_poll(struct be_eq_obj *eqo) { return false; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla15100.00%1100.00%
Total15100.00%1100.00%


static inline void be_unlock_busy_poll(struct be_eq_obj *eqo) { }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla11100.00%1100.00%
Total11100.00%1100.00%


static inline void be_enable_busy_poll(struct be_eq_obj *eqo) { }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla11100.00%1100.00%
Total11100.00%1100.00%


static inline void be_disable_busy_poll(struct be_eq_obj *eqo) { }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla11100.00%1100.00%
Total11100.00%1100.00%

#endif /* CONFIG_NET_RX_BUSY_POLL */
int be_poll(struct napi_struct *napi, int budget) { struct be_eq_obj *eqo = container_of(napi, struct be_eq_obj, napi); struct be_adapter *adapter = eqo->adapter; int max_work = 0, work, i, num_evts; struct be_rx_obj *rxo; struct be_tx_obj *txo; u32 mult_enc = 0; num_evts = events_get(eqo); for_all_tx_queues_on_eq(adapter, eqo, txo, i) be_process_tx(adapter, txo, i); if (be_lock_napi(eqo)) { /* This loop will iterate twice for EQ0 in which * completions of the last RXQ (default one) are also processed * For other EQs the loop iterates only once */ for_all_rx_queues_on_eq(adapter, eqo, rxo, i) { work = be_process_rx(rxo, napi, budget, NAPI_POLLING); max_work = max(work, max_work); } be_unlock_napi(eqo); } else { max_work = budget; } if (is_mcc_eqo(eqo)) be_process_mcc(adapter); if (max_work < budget) { napi_complete(napi); /* Skyhawk EQ_DB has a provision to set the rearm to interrupt * delay via a delay multiplier encoding value */ if (skyhawk_chip(adapter)) mult_enc = be_get_eq_delay_mult_enc(eqo); be_eq_notify(adapter, eqo->q.id, true, false, num_evts, mult_enc); } else { /* As we'll continue in polling mode, count and clear events */ be_eq_notify(adapter, eqo->q.id, false, false, num_evts, 0); } return max_work; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla18279.13%675.00%
padmanabh ratnakarpadmanabh ratnakar4820.87%225.00%
Total230100.00%8100.00%

#ifdef CONFIG_NET_RX_BUSY_POLL
static int be_busy_poll(struct napi_struct *napi) { struct be_eq_obj *eqo = container_of(napi, struct be_eq_obj, napi); struct be_adapter *adapter = eqo->adapter; struct be_rx_obj *rxo; int i, work = 0; if (!be_lock_busy_poll(eqo)) return LL_FLUSH_BUSY; for_all_rx_queues_on_eq(adapter, eqo, rxo, i) { work = be_process_rx(rxo, napi, 4, BUSY_POLLING); if (work) break; } be_unlock_busy_poll(eqo); return work; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla96100.00%1100.00%
Total96100.00%1100.00%

#endif
void be_detect_error(struct be_adapter *adapter) { u32 ue_lo = 0, ue_hi = 0, ue_lo_mask = 0, ue_hi_mask = 0; u32 sliport_status = 0, sliport_err1 = 0, sliport_err2 = 0; u32 i; struct device *dev = &adapter->pdev->dev; if (be_check_error(adapter, BE_ERROR_HW)) return; if (lancer_chip(adapter)) { sliport_status = ioread32(adapter->db + SLIPORT_STATUS_OFFSET); if (sliport_status & SLIPORT_STATUS_ERR_MASK) { be_set_error(adapter, BE_ERROR_UE); sliport_err1 = ioread32(adapter->db + SLIPORT_ERROR1_OFFSET); sliport_err2 = ioread32(adapter->db + SLIPORT_ERROR2_OFFSET); /* Do not log error messages if its a FW reset */ if (sliport_err1 == SLIPORT_ERROR_FW_RESET1 && sliport_err2 == SLIPORT_ERROR_FW_RESET2) { dev_info(dev, "Firmware update in progress\n"); } else { dev_err(dev, "Error detected in the card\n"); dev_err(dev, "ERR: sliport status 0x%x\n", sliport_status); dev_err(dev, "ERR: sliport error1 0x%x\n", sliport_err1); dev_err(dev, "ERR: sliport error2 0x%x\n", sliport_err2); } } } else { ue_lo = ioread32(adapter->pcicfg + PCICFG_UE_STATUS_LOW); ue_hi = ioread32(adapter->pcicfg + PCICFG_UE_STATUS_HIGH); ue_lo_mask = ioread32(adapter->pcicfg + PCICFG_UE_STATUS_LOW_MASK); ue_hi_mask = ioread32(adapter->pcicfg + PCICFG_UE_STATUS_HI_MASK); ue_lo = (ue_lo & ~ue_lo_mask); ue_hi = (ue_hi & ~ue_hi_mask); /* On certain platforms BE hardware can indicate spurious UEs. * Allow HW to stop working completely in case of a real UE. * Hence not setting the hw_error for UE detection. */ if (ue_lo || ue_hi) { dev_err(dev, "Error detected in the adapter"); if (skyhawk_chip(adapter)) be_set_error(adapter, BE_ERROR_UE); for (i = 0; ue_lo; ue_lo >>= 1, i++) { if (ue_lo & 1) dev_err(dev, "UE: %s bit set\n", ue_status_low_desc[i]); } for (i = 0; ue_hi; ue_hi >>= 1, i++) { if (ue_hi & 1) dev_err(dev, "UE: %s bit set\n", ue_status_hi_desc[i]); } } } }

Contributors

PersonTokensPropCommitsCommitProp
ajit khapardeajit khaparde12436.05%220.00%
padmanabh ratnakarpadmanabh ratnakar9928.78%220.00%
somnath kotursomnath kotur8023.26%220.00%
suresh reddysuresh reddy205.81%110.00%
venkat duvvuruvenkat duvvuru154.36%110.00%
sathya perlasathya perla51.45%110.00%
sriharsha basavapatnasriharsha basavapatna10.29%110.00%
Total344100.00%10100.00%


static void be_msix_disable(struct be_adapter *adapter) { if (msix_enabled(adapter)) { pci_disable_msix(adapter->pdev); adapter->num_msix_vec = 0; adapter->num_msix_roce_vec = 0; } }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla39100.00%4100.00%
Total39100.00%4100.00%


static int be_msix_enable(struct be_adapter *adapter) { unsigned int i, max_roce_eqs; struct device *dev = &adapter->pdev->dev; int num_vec; /* If RoCE is supported, program the max number of vectors that * could be used for NIC and RoCE, else, just program the number * we'll use initially. */ if (be_roce_supported(adapter)) { max_roce_eqs = be_max_func_eqs(adapter) - be_max_nic_eqs(adapter); max_roce_eqs = min(max_roce_eqs, num_online_cpus()); num_vec = be_max_any_irqs(adapter) + max_roce_eqs; } else { num_vec = max(adapter->cfg_num_rx_irqs, adapter->cfg_num_tx_irqs); } for (i = 0; i < num_vec; i++) adapter->msix_entries[i].entry = i; num_vec = pci_enable_msix_range(adapter->pdev, adapter->msix_entries, MIN_MSIX_VECTORS, num_vec); if (num_vec < 0) goto fail; if (be_roce_supported(adapter) && num_vec > MIN_MSIX_VECTORS) { adapter->num_msix_roce_vec = num_vec / 2; dev_info(dev, "enabled %d MSI-x vector(s) for RoCE\n", adapter->num_msix_roce_vec); } adapter->num_msix_vec = num_vec - adapter->num_msix_roce_vec; dev_info(dev, "enabled %d MSI-x vector(s) for NIC\n", adapter->num_msix_vec); return 0; fail: dev_warn(dev, "MSIx enable failed\n"); /* INTx is not supported in VFs, so fail probe if enable_msix fails */ if (be_virtfn(adapter)) return num_vec; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla14064.22%861.54%
parav panditparav pandit3917.89%17.69%
alexander gordeevalexander gordeev2812.84%17.69%
somnath kotursomnath kotur73.21%17.69%
dan carpenterdan carpenter31.38%17.69%
kalesh purayilkalesh purayil10.46%17.69%
Total218100.00%13100.00%


static inline int be_msix_vec_get(struct be_adapter *adapter, struct be_eq_obj *eqo) { return adapter->msix_entries[eqo->msix_idx].vector; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla2068.97%360.00%
sarveshwar bandisarveshwar bandi931.03%240.00%
Total29100.00%5100.00%


static int be_msix_register(struct be_adapter *adapter) { struct net_device *netdev = adapter->netdev; struct be_eq_obj *eqo; int status, i, vec; for_all_evt_queues(adapter, eqo, i) { sprintf(eqo->desc, "%s-q%d", netdev->name, i); vec = be_msix_vec_get(adapter, eqo); status = request_irq(vec, be_msix, 0, eqo->desc, eqo); if (status) goto err_msix; irq_set_affinity_hint(vec, eqo->affinity_mask); } return 0; err_msix: for (i--; i >= 0; i--) { eqo = &adapter->eq_obj[i]; free_irq(be_msix_vec_get(adapter, eqo), eqo); } dev_warn(&adapter->pdev->dev, "MSIX Request IRQ failed - err %d\n", status); be_msix_disable(adapter); return status; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla12979.63%758.33%
ajit khapardeajit khaparde116.79%216.67%
venkat duvvuruvenkat duvvuru116.79%18.33%
padmanabh ratnakarpadmanabh ratnakar95.56%18.33%
sarveshwar bandisarveshwar bandi21.23%18.33%
Total162100.00%12100.00%


static int be_irq_register(struct be_adapter *adapter) { struct net_device *netdev = adapter->netdev; int status; if (msix_enabled(adapter)) { status = be_msix_register(adapter); if (status == 0) goto done; /* INTx is not supported for VF */ if (be_virtfn(adapter)) return status; } /* INTx: only the first EQ is used */ netdev->irq = adapter->pdev->irq; status = request_irq(netdev->irq, be_intx, IRQF_SHARED, netdev->name, &adapter->eq_obj[0]); if (status) { dev_err(&adapter->pdev->dev, "INTx request IRQ failed - err %d\n", status); return status; } done: adapter->isr_registered = true; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla11689.92%360.00%
sarveshwar bandisarveshwar bandi129.30%120.00%
kalesh purayilkalesh purayil10.78%120.00%
Total129100.00%5100.00%


static void be_irq_unregister(struct be_adapter *adapter) { struct net_device *netdev = adapter->netdev; struct be_eq_obj *eqo; int i, vec; if (!adapter->isr_registered) return; /* INTx */ if (!msix_enabled(adapter)) { free_irq(netdev->irq, &adapter->eq_obj[0]); goto done; } /* MSIx */ for_all_evt_queues(adapter, eqo, i) { vec = be_msix_vec_get(adapter, eqo); irq_set_affinity_hint(vec, NULL); free_irq(vec, eqo); } done: adapter->isr_registered = false; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla9284.40%583.33%
padmanabh ratnakarpadmanabh ratnakar1715.60%116.67%
Total109100.00%6100.00%


static void be_rx_qs_destroy(struct be_adapter *adapter) { struct rss_info *rss = &adapter->rss_info; struct be_queue_info *q; struct be_rx_obj *rxo; int i; for_all_rx_queues(adapter, rxo, i) { q = &rxo->q; if (q->created) { /* If RXQs are destroyed while in an "out of buffer" * state, there is a possibility of an HW stall on * Lancer. So, post 64 buffers to each queue to relieve * the "out of buffer" condition. * Make sure there's space in the RXQ before posting. */ if (lancer_chip(adapter)) { be_rx_cq_clean(rxo); if (atomic_read(&q->used) == 0) be_post_rx_frags(rxo, GFP_KERNEL, MAX_RX_POST); } be_cmd_rxq_destroy(adapter, q); be_rx_cq_clean(rxo); be_rxq_clean(rxo); } be_queue_free(adapter, q); } if (rss->rss_flags) { rss->rss_flags = RSS_ENABLE_NONE; be_cmd_rss_config(adapter, rss->rsstable, rss->rss_flags, 128, rss->rss_hkey); } }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla6844.74%250.00%
ajit khapardeajit khaparde4328.29%125.00%
kalesh purayilkalesh purayil4126.97%125.00%
Total152100.00%4100.00%


static void be_disable_if_filters(struct be_adapter *adapter) { /* Don't delete MAC on BE3 VFs without FILTMGMT privilege */ if (!BEx_chip(adapter) || !be_virtfn(adapter) || check_privilege(adapter, BE_PRIV_FILTMGMT)) { be_dev_mac_del(adapter, adapter->pmac_id[0]); eth_zero_addr(adapter->dev_mac); } be_clear_uc_list(adapter); be_clear_mc_list(adapter); /* The IFACE flags are enabled in the open path and cleared * in the close path. When a VF gets detached from the host and * assigned to a VM the following happens: * - VF's IFACE flags get cleared in the detach path * - IFACE create is issued by the VF in the attach path * Due to a bug in the BE3/Skyhawk-R FW * (Lancer FW doesn't have the bug), the IFACE capability flags * specified along with the IFACE create cmd issued by a VF are not * honoured by FW. As a consequence, if a *new* driver * (that enables/disables IFACE flags in open/close) * is loaded in the host and an *old* driver is * used by a VM/VF, * the IFACE gets created *without* the needed flags. * To avoid this, disable RX-filter flags only for Lancer. */ if (lancer_chip(adapter)) { be_cmd_rx_filter(adapter, BE_IF_ALL_FILT_FLAGS, OFF); adapter->if_flags &= ~BE_IF_ALL_FILT_FLAGS; } }

Contributors

PersonTokensPropCommitsCommitProp
kalesh purayilkalesh purayil5358.89%120.00%
ivan veceraivan vecera3134.44%240.00%
sriharsha basavapatnasriharsha basavapatna55.56%120.00%
suresh reddysuresh reddy11.11%120.00%
Total90100.00%5100.00%


static int be_close(struct net_device *netdev) { struct be_adapter *adapter = netdev_priv(netdev); struct be_eq_obj *eqo; int i; /* This protection is needed as be_close() may be called even when the * adapter is in cleared state (after eeh perm failure) */ if (!(adapter->flags & BE_FLAGS_SETUP_DONE)) return 0; /* Before attempting cleanup ensure all the pending cmds in the * config_wq have finished execution */ flush_workqueue(be_wq); be_disable_if_filters(adapter); if (adapter->flags & BE_FLAGS_NAPI_ENABLED) { for_all_evt_queues(adapter, eqo, i) { napi_disable(&eqo->napi); be_disable_busy_poll(eqo); } adapter->flags &= ~BE_FLAGS_NAPI_ENABLED; } be_async_mcc_disable(adapter); /* Wait for all pending tx completions to arrive so that * all tx skbs are freed. */ netif_tx_disable(netdev); be_tx_compl_clean(adapter); be_rx_qs_destroy(adapter); for_all_evt_queues(adapter, eqo, i) { if (msix_enabled(adapter)) synchronize_irq(be_msix_vec_get(adapter, eqo)); else synchronize_irq(netdev->irq); be_eq_clean(eqo); } be_irq_unregister(adapter); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla11469.51%1062.50%
kalesh purayilkalesh purayil2012.20%212.50%
somnath kotursomnath kotur169.76%16.25%
ivan veceraivan vecera95.49%16.25%
padmanabh ratnakarpadmanabh ratnakar42.44%16.25%
david s. millerdavid s. miller10.61%16.25%
Total164100.00%16100.00%


static int be_rx_qs_create(struct be_adapter *adapter) { struct rss_info *rss = &adapter->rss_info; u8 rss_key[RSS_HASH_KEY_LEN]; struct be_rx_obj *rxo; int rc, i, j; for_all_rx_queues(adapter, rxo, i) { rc = be_queue_alloc(adapter, &rxo->q, RX_Q_LEN, sizeof(struct be_eth_rx_d)); if (rc) return rc; } if (adapter->need_def_rxq || !adapter->num_rss_qs) { rxo = default_rxo(adapter); rc = be_cmd_rxq_create(adapter, &rxo->q, rxo->cq.id, rx_frag_size, adapter->if_handle, false, &rxo->rss_id); if (rc) return rc; } for_all_rss_queues(adapter, rxo, i) { rc = be_cmd_rxq_create(adapter, &rxo->q, rxo->cq.id, rx_frag_size, adapter->if_handle, true, &rxo->rss_id); if (rc) return rc; } if (be_multi_rxq(adapter)) { for (j = 0; j < RSS_INDIR_TABLE_LEN; j += adapter->num_rss_qs) { for_all_rss_queues(adapter, rxo, i) { if ((j + i) >= RSS_INDIR_TABLE_LEN) break; rss->rsstable[j + i] = rxo->rss_id; rss->rss_queue[j + i] = i; } } rss->rss_flags = RSS_ENABLE_TCP_IPV4 | RSS_ENABLE_IPV4 | RSS_ENABLE_TCP_IPV6 | RSS_ENABLE_IPV6; if (!BEx_chip(adapter)) rss->rss_flags |= RSS_ENABLE_UDP_IPV4 | RSS_ENABLE_UDP_IPV6; netdev_rss_key_fill(rss_key, RSS_HASH_KEY_LEN); rc = be_cmd_rss_config(adapter, rss->rsstable, rss->rss_flags, RSS_INDIR_TABLE_LEN, rss_key); if (rc) { rss->rss_flags = RSS_ENABLE_NONE; return rc; } memcpy(rss->rss_hkey, rss_key, RSS_HASH_KEY_LEN); } else { /* Disable RSS, if only default RX Q is created */ rss->rss_flags = RSS_ENABLE_NONE; } /* Post 1 less than RXQ-len to avoid head being equal to tail, * which is a queue empty condition */ for_all_rx_queues(adapter, rxo, i) be_post_rx_frags(rxo, GFP_KERNEL, RX_Q_LEN - 1); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla21257.77%323.08%
suresh reddysuresh reddy3810.35%215.38%
venkat duvvuruvenkat duvvuru3710.08%17.69%
padmanabh ratnakarpadmanabh ratnakar328.72%17.69%
eric dumazeteric dumazet205.45%17.69%
vasundhara volamvasundhara volam154.09%215.38%
ajit khapardeajit khaparde123.27%215.38%
ivan veceraivan vecera10.27%17.69%
Total367100.00%13100.00%


static int be_enable_if_filters(struct be_adapter *adapter) { int status; status = be_cmd_rx_filter(adapter, BE_IF_FILT_FLAGS_BASIC, ON); if (status) return status; /* Normally this condition usually true as the ->dev_mac is zeroed. * But on BE3 VFs the initial MAC is pre-programmed by PF and * subsequent be_dev_mac_add() can fail (after fresh boot) */ if (!ether_addr_equal(adapter->dev_mac, adapter->netdev->dev_addr)) { int old_pmac_id = -1; /* Remember old programmed MAC if any - can happen on BE3 VF */ if (!is_zero_ether_addr(adapter->dev_mac)) old_pmac_id = adapter->pmac_id[0]; status = be_dev_mac_add(adapter, adapter->netdev->dev_addr); if (status) return status; /* Delete the old programmed MAC as we successfully programmed * a new MAC */ if (old_pmac_id >= 0 && old_pmac_id != adapter->pmac_id[0]) be_dev_mac_del(adapter, old_pmac_id); ether_addr_copy(adapter->dev_mac, adapter->netdev->dev_addr); } if (adapter->vlans_added) be_vid_config(adapter); __be_set_rx_mode(adapter); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
kalesh purayilkalesh purayil7750.66%114.29%
ivan veceraivan vecera5938.82%228.57%
suresh reddysuresh reddy149.21%228.57%
sathya perlasathya perla10.66%114.29%
venkat duvvuruvenkat duvvuru10.66%114.29%
Total152100.00%7100.00%


static int be_open(struct net_device *netdev) { struct be_adapter *adapter = netdev_priv(netdev); struct be_eq_obj *eqo; struct be_rx_obj *rxo; struct be_tx_obj *txo; u8 link_status; int status, i; status = be_rx_qs_create(adapter); if (status) goto err; status = be_enable_if_filters(adapter); if (status) goto err; status = be_irq_register(adapter); if (status) goto err; for_all_rx_queues(adapter, rxo, i) be_cq_notify(adapter, rxo->cq.id, true, 0); for_all_tx_queues(adapter, txo, i) be_cq_notify(adapter, txo->cq.id, true, 0); be_async_mcc_enable(adapter); for_all_evt_queues(adapter, eqo, i) { napi_enable(&eqo->napi); be_enable_busy_poll(eqo); be_eq_notify(adapter, eqo->q.id, true, true, 0, 0); } adapter->flags |= BE_FLAGS_NAPI_ENABLED; status = be_cmd_link_status_query(adapter, NULL, &link_status, 0); if (!status) be_link_status_update(adapter, link_status); netif_tx_start_all_queues(netdev); if (skyhawk_chip(adapter)) udp_tunnel_get_rx_info(netdev); return 0; err: be_close(adapter->netdev); return -EIO; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla18274.59%1161.11%
ajit khapardeajit khaparde2911.89%15.56%
somnath kotursomnath kotur156.15%211.11%
kalesh purayilkalesh purayil145.74%15.56%
padmanabh ratnakarpadmanabh ratnakar20.82%15.56%
suresh reddysuresh reddy10.41%15.56%
alexander duyckalexander duyck10.41%15.56%
Total244100.00%18100.00%


static void be_vf_eth_addr_generate(struct be_adapter *adapter, u8 *mac) { u32 addr; addr = jhash(adapter->netdev->dev_addr, ETH_ALEN, 0); mac[5] = (u8)(addr & 0xFF); mac[4] = (u8)((addr >> 8) & 0xFF); mac[3] = (u8)((addr >> 16) & 0xFF); /* Use the OUI from the current MAC address */ memcpy(mac, adapter->netdev->dev_addr, 3); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla97100.00%1100.00%
Total97100.00%1100.00%

/* * Generate a seed MAC address from the PF MAC Address using jhash. * MAC Address for VFs are assigned incrementally starting from the seed. * These addresses are programmed in the ASIC by the PF and the VF driver * queries for the MAC address during its probe. */
static int be_vf_eth_addr_config(struct be_adapter *adapter) { u32 vf; int status = 0; u8 mac[ETH_ALEN]; struct be_vf_cfg *vf_cfg; be_vf_eth_addr_generate(adapter, mac); for_all_vfs(adapter, vf_cfg, vf) { if (BEx_chip(adapter)) status = be_cmd_pmac_add(adapter, mac, vf_cfg->if_handle, &vf_cfg->pmac_id, vf + 1); else status = be_cmd_set_mac(adapter, mac, vf_cfg->if_handle, vf + 1); if (status) dev_err(&adapter->pdev->dev, "Mac address assignment failed for VF %d\n", vf); else memcpy(vf_cfg->mac_addr, mac, ETH_ALEN); mac[5] += 1; } return status; }

Contributors

PersonTokensPropCommitsCommitProp
ajit khapardeajit khaparde8361.94%233.33%
sathya perlasathya perla3022.39%350.00%
padmanabh ratnakarpadmanabh ratnakar2115.67%116.67%
Total134100.00%6100.00%


static int be_vfs_mac_query(struct be_adapter *adapter) { int status, vf; u8 mac[ETH_ALEN]; struct be_vf_cfg *vf_cfg; for_all_vfs(adapter, vf_cfg, vf) { status = be_cmd_get_active_mac(adapter, vf_cfg->pmac_id, mac, vf_cfg->if_handle, false, vf+1); if (status) return status; memcpy(vf_cfg->mac_addr, mac, ETH_ALEN); } return 0; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla7390.12%150.00%
suresh reddysuresh reddy89.88%150.00%
Total81100.00%2100.00%


static void be_vf_clear(struct be_adapter *adapter) { struct be_vf_cfg *vf_cfg; u32 vf; if (pci_vfs_assigned(adapter->pdev)) { dev_warn(&adapter->pdev->dev, "VFs are assigned to VMs: not disabling VFs\n"); goto done; } pci_disable_sriov(adapter->pdev); for_all_vfs(adapter, vf_cfg, vf) { if (BEx_chip(adapter)) be_cmd_pmac_del(adapter, vf_cfg->if_handle, vf_cfg->pmac_id, vf + 1); else be_cmd_set_mac(adapter, NULL, vf_cfg->if_handle, vf + 1); be_cmd_if_destroy(adapter, vf_cfg->if_handle, vf + 1); } if (BE3_chip(adapter)) be_cmd_set_hsw_config(adapter, 0, 0, adapter->if_handle, PORT_FWD_TYPE_PASSTHRU, 0); done: kfree(adapter->vf_cfg); adapter->num_vfs = 0; adapter->flags &= ~BE_FLAGS_SRIOV_ENABLED; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla9055.90%861.54%
somnath kotursomnath kotur2414.91%17.69%
ajit khapardeajit khaparde2213.66%215.38%
padmanabh ratnakarpadmanabh ratnakar1811.18%17.69%
vasundhara volamvasundhara volam74.35%17.69%
Total161100.00%13100.00%


static void be_clear_queues(struct be_adapter *adapter) { be_mcc_queues_destroy(adapter); be_rx_cqs_destroy(adapter); be_tx_queues_destroy(adapter); be_evt_queues_destroy(adapter); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla31100.00%1100.00%
Total31100.00%1100.00%


static void be_cancel_worker(struct be_adapter *adapter) { if (adapter->flags & BE_FLAGS_WORKER_SCHEDULED) { cancel_delayed_work_sync(&adapter->work); adapter->flags &= ~BE_FLAGS_WORKER_SCHEDULED; } }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla36100.00%3100.00%
Total36100.00%3100.00%


static void be_cancel_err_detection(struct be_adapter *adapter) { struct be_error_recovery *err_rec = &adapter->error_recovery; if (!be_err_recovery_workq) return; if (adapter->flags & BE_FLAGS_ERR_DETECTION_SCHEDULED) { cancel_delayed_work_sync(&err_rec->err_detection_work); adapter->flags &= ~BE_FLAGS_ERR_DETECTION_SCHEDULED; } }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla3465.38%150.00%
sriharsha basavapatnasriharsha basavapatna1834.62%150.00%
Total52100.00%2100.00%


static void be_disable_vxlan_offloads(struct be_adapter *adapter) { struct net_device *netdev = adapter->netdev; if (adapter->flags & BE_FLAGS_VXLAN_OFFLOADS) be_cmd_manage_iface(adapter, adapter->if_handle, OP_CONVERT_TUNNEL_TO_NORMAL); if (adapter->vxlan_port) be_cmd_set_vxlan_port(adapter, 0); adapter->flags &= ~BE_FLAGS_VXLAN_OFFLOADS; adapter->vxlan_port = 0; netdev->hw_enc_features = 0; netdev->hw_features &= ~(NETIF_F_GSO_UDP_TUNNEL); netdev->features &= ~(NETIF_F_GSO_UDP_TUNNEL); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla5662.92%133.33%
sriharsha basavapatnasriharsha basavapatna3337.08%266.67%
Total89100.00%3100.00%


static void be_calculate_vf_res(struct be_adapter *adapter, u16 num_vfs, struct be_resources *vft_res) { struct be_resources res = adapter->pool_res; u32 vf_if_cap_flags = res.vf_if_cap_flags; struct be_resources res_mod = {0}; u16 num_vf_qs = 1; /* Distribute the queue resources among the PF and it's VFs */ if (num_vfs) { /* Divide the rx queues evenly among the VFs and the PF, capped * at VF-EQ-count. Any remainder queues belong to the PF. */ num_vf_qs = min(SH_VF_MAX_NIC_EQS, res.max_rss_qs / (num_vfs + 1)); /* Skyhawk-R chip supports only MAX_PORT_RSS_TABLES * RSS Tables per port. Provide RSS on VFs, only if number of * VFs requested is less than it's PF Pool's RSS Tables limit. */ if (num_vfs >= be_max_pf_pool_rss_tables(adapter)) num_vf_qs = 1; } /* Resource with fields set to all '1's by GET_PROFILE_CONFIG cmd, * which are modifiable using SET_PROFILE_CONFIG cmd. */ be_cmd_get_profile_config(adapter, &res_mod, NULL, ACTIVE_PROFILE_TYPE, RESOURCE_MODIFIABLE, 0); /* If RSS IFACE capability flags are modifiable for a VF, set the * capability flag as valid and set RSS and DEFQ_RSS IFACE flags if * more than 1 RSSQ is available for a VF. * Otherwise, provision only 1 queue pair for VF. */ if (res_mod.vf_if_cap_flags & BE_IF_FLAGS_RSS) { vft_res->flags |= BIT(IF_CAPS_FLAGS_VALID_SHIFT); if (num_vf_qs > 1) { vf_if_cap_flags |= BE_IF_FLAGS_RSS; if (res.if_cap_flags & BE_IF_FLAGS_DEFQ_RSS) vf_if_cap_flags |= BE_IF_FLAGS_DEFQ_RSS; } else { vf_if_cap_flags &= ~(BE_IF_FLAGS_RSS | BE_IF_FLAGS_DEFQ_RSS); } } else { num_vf_qs = 1; } if (res_mod.vf_if_cap_flags & BE_IF_FLAGS_VLAN_PROMISCUOUS) { vft_res->flags |= BIT(IF_CAPS_FLAGS_VALID_SHIFT); vf_if_cap_flags &= ~BE_IF_FLAGS_VLAN_PROMISCUOUS; } vft_res->vf_if_cap_flags = vf_if_cap_flags; vft_res->max_rx_qs = num_vf_qs; vft_res->max_rss_qs = num_vf_qs; vft_res->max_tx_qs = res.max_tx_qs / (num_vfs + 1); vft_res->max_cq_count = res.max_cq_count / (num_vfs + 1); /* Distribute unicast MACs, VLANs, IFACE count and MCCQ count equally * among the PF and it's VFs, if the fields are changeable */ if (res_mod.max_uc_mac == FIELD_MODIFIABLE) vft_res->max_uc_mac = res.max_uc_mac / (num_vfs + 1); if (res_mod.max_vlans == FIELD_MODIFIABLE) vft_res->max_vlans = res.max_vlans / (num_vfs + 1); if (res_mod.max_iface_count == FIELD_MODIFIABLE) vft_res->max_iface_count = res.max_iface_count / (num_vfs + 1); if (res_mod.max_mcc_count == FIELD_MODIFIABLE) vft_res->max_mcc_count = res.max_mcc_count / (num_vfs + 1); }

Contributors

PersonTokensPropCommitsCommitProp
suresh reddysuresh reddy25678.77%125.00%
vasundhara volamvasundhara volam4915.08%125.00%
somnath kotursomnath kotur113.38%125.00%
sriharsha basavapatnasriharsha basavapatna92.77%125.00%
Total325100.00%4100.00%


static void be_if_destroy(struct be_adapter *adapter) { be_cmd_if_destroy(adapter, adapter->if_handle, 0); kfree(adapter->pmac_id); adapter->pmac_id = NULL; kfree(adapter->mc_list); adapter->mc_list = NULL; kfree(adapter->uc_list); adapter->uc_list = NULL; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla61100.00%1100.00%
Total61100.00%1100.00%


static int be_clear(struct be_adapter *adapter) { struct pci_dev *pdev = adapter->pdev; struct be_resources vft_res = {0}; be_cancel_worker(adapter); flush_workqueue(be_wq); if (sriov_enabled(adapter)) be_vf_clear(adapter); /* Re-configure FW to distribute resources evenly across max-supported * number of VFs, only when VFs are not already enabled. */ if (skyhawk_chip(adapter) && be_physfn(adapter) && !pci_vfs_assigned(pdev)) { be_calculate_vf_res(adapter, pci_sriov_get_totalvfs(pdev), &vft_res); be_cmd_set_sriov_config(adapter, adapter->pool_res, pci_sriov_get_totalvfs(pdev), &vft_res); } be_disable_vxlan_offloads(adapter); be_if_destroy(adapter); be_clear_queues(adapter); be_msix_disable(adapter); adapter->flags &= ~BE_FLAGS_SETUP_DONE; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
vasundhara volamvasundhara volam5541.98%325.00%
somnath kotursomnath kotur2922.14%18.33%
sathya perlasathya perla2619.85%541.67%
suresh reddysuresh reddy139.92%18.33%
kalesh purayilkalesh purayil75.34%18.33%
padmanabh ratnakarpadmanabh ratnakar10.76%18.33%
Total131100.00%12100.00%


static int be_vfs_if_create(struct be_adapter *adapter) { struct be_resources res = {0}; u32 cap_flags, en_flags, vf; struct be_vf_cfg *vf_cfg; int status; /* If a FW profile exists, then cap_flags are updated */ cap_flags = BE_VF_IF_EN_FLAGS; for_all_vfs(adapter, vf_cfg, vf) { if (!BE3_chip(adapter)) { status = be_cmd_get_profile_config(adapter, &res, NULL, ACTIVE_PROFILE_TYPE, RESOURCE_LIMITS, vf + 1); if (!status) { cap_flags = res.if_cap_flags; /* Prevent VFs from enabling VLAN promiscuous * mode */ cap_flags &= ~BE_IF_FLAGS_VLAN_PROMISCUOUS; } } /* PF should enable IF flags during proxy if_create call */ en_flags = cap_flags & BE_VF_IF_EN_FLAGS; status = be_cmd_if_create(adapter, cap_flags, en_flags, &vf_cfg->if_handle, vf + 1); if (status) return status; } return 0; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla7051.85%220.00%
padmanabh ratnakarpadmanabh ratnakar2518.52%110.00%
kalesh purayilkalesh purayil2216.30%220.00%
vasundhara volamvasundhara volam118.15%330.00%
somnath kotursomnath kotur42.96%110.00%
venkat duvvuruvenkat duvvuru32.22%110.00%
Total135100.00%10100.00%


static int be_vf_setup_init(struct be_adapter *adapter) { struct be_vf_cfg *vf_cfg; int vf; adapter->vf_cfg = kcalloc(adapter->num_vfs, sizeof(*vf_cfg), GFP_KERNEL); if (!adapter->vf_cfg) return -ENOMEM; for_all_vfs(adapter, vf_cfg, vf) { vf_cfg->if_handle = -1; vf_cfg->pmac_id = -1; } return 0; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla76100.00%4100.00%
Total76100.00%4100.00%


static int be_vf_setup(struct be_adapter *adapter) { struct device *dev = &adapter->pdev->dev; struct be_vf_cfg *vf_cfg; int status, old_vfs, vf; bool spoofchk; old_vfs = pci_num_vf(adapter->pdev); status = be_vf_setup_init(adapter); if (status) goto err; if (old_vfs) { for_all_vfs(adapter, vf_cfg, vf) { status = be_cmd_get_if_id(adapter, vf_cfg, vf); if (status) goto err; } status = be_vfs_mac_query(adapter); if (status) goto err; } else { status = be_vfs_if_create(adapter); if (status) goto err; status = be_vf_eth_addr_config(adapter); if (status) goto err; } for_all_vfs(adapter, vf_cfg, vf) { /* Allow VFs to programs MAC/VLAN filters */ status = be_cmd_get_fn_privileges(adapter, &vf_cfg->privileges, vf + 1); if (!status && !(vf_cfg->privileges & BE_PRIV_FILTMGMT)) { status = be_cmd_set_fn_privileges(adapter, vf_cfg->privileges | BE_PRIV_FILTMGMT, vf + 1); if (!status) { vf_cfg->privileges |= BE_PRIV_FILTMGMT; dev_info(dev, "VF%d has FILTMGMT privilege\n", vf); } } /* Allow full available bandwidth */ if (!old_vfs) be_cmd_config_qos(adapter, 0, 0, vf + 1); status = be_cmd_get_hsw_config(adapter, NULL, vf + 1, vf_cfg->if_handle, NULL, &spoofchk); if (!status) vf_cfg->spoofchk = spoofchk; if (!old_vfs) { be_cmd_enable_vf(adapter, vf + 1); be_cmd_set_logical_link_config(adapter, IFLA_VF_LINK_STATE_AUTO, vf+1); } } if (!old_vfs) { status = pci_enable_sriov(adapter->pdev, adapter->num_vfs); if (status) { dev_err(dev, "SRIOV enable failed\n"); adapter->num_vfs = 0; goto err; } } if (BE3_chip(adapter)) { /* On BE3, enable VEB only when SRIOV is enabled */ status = be_cmd_set_hsw_config(adapter, 0, 0, adapter->if_handle, PORT_FWD_TYPE_VEB, 0); if (status) goto err; } adapter->flags |= BE_FLAGS_SRIOV_ENABLED; return 0; err: dev_err(dev, "VF setup failed\n"); be_vf_clear(adapter); return status; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla25061.73%1350.00%
somnath kotursomnath kotur4811.85%27.69%
kalesh purayilkalesh purayil368.89%13.85%
vasundhara volamvasundhara volam256.17%415.38%
padmanabh ratnakarpadmanabh ratnakar163.95%27.69%
suresh reddysuresh reddy133.21%13.85%
sarveshwar bandisarveshwar bandi112.72%13.85%
ravikumar nelavelliravikumar nelavelli30.74%13.85%
ajit khapardeajit khaparde30.74%13.85%
Total405100.00%26100.00%

/* Converting function_mode bits on BE3 to SH mc_type enums */
static u8 be_convert_mc_type(u32 function_mode) { if (function_mode & VNIC_MODE && function_mode & QNQ_MODE) return vNIC1; else if (function_mode & QNQ_MODE) return FLEX10; else if (function_mode & VNIC_MODE) return vNIC2; else if (function_mode & UMC_ENABLED) return UMC; else return MC_NONE; }

Contributors

PersonTokensPropCommitsCommitProp
vasundhara volamvasundhara volam5496.43%150.00%
suresh reddysuresh reddy23.57%150.00%
Total56100.00%2100.00%

/* On BE2/BE3 FW does not suggest the supported limits */
static void BEx_get_resources(struct be_adapter *adapter, struct be_resources *res) { bool use_sriov = adapter->num_vfs ? 1 : 0; if (be_physfn(adapter)) res->max_uc_mac = BE_UC_PMAC_COUNT; else res->max_uc_mac = BE_VF_UC_PMAC_COUNT; adapter->mc_type = be_convert_mc_type(adapter->function_mode); if (be_is_mc(adapter)) { /* Assuming that there are 4 channels per port, * when multi-channel is enabled */ if (be_is_qnq_mode(adapter)) res->max_vlans = BE_NUM_VLANS_SUPPORTED/8; else /* In a non-qnq multichannel mode, the pvid * takes up one vlan entry */ res->max_vlans = (BE_NUM_VLANS_SUPPORTED / 4) - 1; } else { res->max_vlans = BE_NUM_VLANS_SUPPORTED; } res->max_mcast_mac = BE_MAX_MC; /* 1) For BE3 1Gb ports, FW does not support multiple TXQs * 2) Create multiple TX rings on a BE3-R multi-channel interface * *only* if it is RSS-capable. */ if (BE2_chip(adapter) || use_sriov || (adapter->port_num > 1) || be_virtfn(adapter) || (be_is_mc(adapter) && !(adapter->function_caps & BE_FUNCTION_CAPS_RSS))) { res->max_tx_qs = 1; } else if (adapter->function_caps & BE_FUNCTION_CAPS_SUPER_NIC) { struct be_resources super_nic_res = {0}; /* On a SuperNIC profile, the driver needs to use the * GET_PROFILE_CONFIG cmd to query the per-function TXQ limits */ be_cmd_get_profile_config(adapter, &super_nic_res, NULL, ACTIVE_PROFILE_TYPE, RESOURCE_LIMITS, 0); /* Some old versions of BE3 FW don't report max_tx_qs value */ res->max_tx_qs = super_nic_res.max_tx_qs ? : BE3_MAX_TX_QS; } else { res->max_tx_qs = BE3_MAX_TX_QS; } if ((adapter->function_caps & BE_FUNCTION_CAPS_RSS) && !use_sriov && be_physfn(adapter)) res->max_rss_qs = (adapter->be3_native) ? BE3_MAX_RSS_QS : BE2_MAX_RSS_QS; res->max_rx_qs = res->max_rss_qs + 1; if (be_physfn(adapter)) res->max_evt_qs = (be_max_vfs(adapter) > 0) ? BE3_SRIOV_MAX_EVT_QS : BE3_MAX_EVT_QS; else res->max_evt_qs = 1; res->if_cap_flags = BE_IF_CAP_FLAGS_WANT; res->if_cap_flags &= ~BE_IF_FLAGS_DEFQ_RSS; if (!(adapter->function_caps & BE_FUNCTION_CAPS_RSS)) res->if_cap_flags &= ~BE_IF_FLAGS_RSS; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla12037.50%315.79%
vasundhara volamvasundhara volam8426.25%842.11%
suresh reddysuresh reddy6620.62%315.79%
padmanabh ratnakarpadmanabh ratnakar4012.50%210.53%
ajit khapardeajit khaparde51.56%15.26%
somnath kotursomnath kotur41.25%15.26%
kalesh purayilkalesh purayil10.31%15.26%
Total320100.00%19100.00%


static void be_setup_init(struct be_adapter *adapter) { adapter->vlan_prio_bmap = 0xff; adapter->phy.link_speed = -1; adapter->if_handle = -1; adapter->be3_native = false; adapter->if_flags = 0; adapter->phy_state = BE_UNKNOWN_PHY_STATE; if (be_physfn(adapter)) adapter->cmd_privileges = MAX_PRIVILEGES; else adapter->cmd_privileges = MIN_PRIVILEGES; }

Contributors

PersonTokensPropCommitsCommitProp
vasundhara volamvasundhara volam4563.38%120.00%
sathya perlasathya perla1419.72%240.00%
padmanabh ratnakarpadmanabh ratnakar68.45%120.00%
ajit khapardeajit khaparde68.45%120.00%
Total71100.00%5100.00%

/* HW supports only MAX_PORT_RSS_TABLES RSS Policy Tables per port. * However, this HW limitation is not exposed to the host via any SLI cmd. * As a result, in the case of SRIOV and in particular multi-partition configs * the driver needs to calcuate a proportional share of RSS Tables per PF-pool * for distribution between the VFs. This self-imposed limit will determine the * no: of VFs for which RSS can be enabled. */
static void be_calculate_pf_pool_rss_tables(struct be_adapter *adapter) { struct be_port_resources port_res = {0}; u8 rss_tables_on_port; u16 max_vfs = be_max_vfs(adapter); be_cmd_get_profile_config(adapter, NULL, &port_res, SAVED_PROFILE_TYPE, RESOURCE_LIMITS, 0); rss_tables_on_port = MAX_PORT_RSS_TABLES - port_res.nic_pfs; /* Each PF Pool's RSS Tables limit = * PF's Max VFs / Total_Max_VFs on Port * RSS Tables on Port */ adapter->pool_res.max_rss_tables = max_vfs * rss_tables_on_port / port_res.max_vfs; }

Contributors

PersonTokensPropCommitsCommitProp
somnath kotursomnath kotur6898.55%150.00%
baoyou xiebaoyou xie11.45%150.00%
Total69100.00%2100.00%


static int be_get_sriov_config(struct be_adapter *adapter) { struct be_resources res = {0}; int max_vfs, old_vfs; be_cmd_get_profile_config(adapter, &res, NULL, ACTIVE_PROFILE_TYPE, RESOURCE_LIMITS, 0); /* Some old versions of BE3 FW don't report max_vfs value */ if (BE3_chip(adapter) && !res.max_vfs) { max_vfs = pci_sriov_get_totalvfs(adapter->pdev); res.max_vfs = max_vfs > 0 ? min(MAX_VFS, max_vfs) : 0; } adapter->pool_res = res; /* If during previous unload of the driver, the VFs were not disabled, * then we cannot rely on the PF POOL limits for the TotalVFs value. * Instead use the TotalVFs value stored in the pci-dev struct. */ old_vfs = pci_num_vf(adapter->pdev); if (old_vfs) { dev_info(&adapter->pdev->dev, "%d VFs are already enabled\n", old_vfs); adapter->pool_res.max_vfs = pci_sriov_get_totalvfs(adapter->pdev); adapter->num_vfs = old_vfs; } if (skyhawk_chip(adapter) && be_max_vfs(adapter) && !old_vfs) { be_calculate_pf_pool_rss_tables(adapter); dev_info(&adapter->pdev->dev, "RSS can be enabled for all VFs if num_vfs <= %d\n", be_max_pf_pool_rss_tables(adapter)); } return 0; }

Contributors

PersonTokensPropCommitsCommitProp
vasundhara volamvasundhara volam12972.47%350.00%
somnath kotursomnath kotur4324.16%116.67%
sathya perlasathya perla31.69%116.67%
padmanabh ratnakarpadmanabh ratnakar31.69%116.67%
Total178100.00%6100.00%


static void be_alloc_sriov_res(struct be_adapter *adapter) { int old_vfs = pci_num_vf(adapter->pdev); struct be_resources vft_res = {0}; int status; be_get_sriov_config(adapter); if (!old_vfs) pci_sriov_set_totalvfs(adapter->pdev, be_max_vfs(adapter)); /* When the HW is in SRIOV capable configuration, the PF-pool * resources are given to PF during driver load, if there are no * old VFs. This facility is not available in BE3 FW. * Also, this is done by FW in Lancer chip. */ if (skyhawk_chip(adapter) && be_max_vfs(adapter) && !old_vfs) { be_calculate_vf_res(adapter, 0, &vft_res); status = be_cmd_set_sriov_config(adapter, adapter->pool_res, 0, &vft_res); if (status) dev_err(&adapter->pdev->dev, "Failed to optimize SRIOV resources\n"); } }

Contributors

PersonTokensPropCommitsCommitProp
vasundhara volamvasundhara volam8877.19%233.33%
suresh reddysuresh reddy1311.40%116.67%
padmanabh ratnakarpadmanabh ratnakar119.65%116.67%
sathya perlasathya perla21.75%233.33%
Total114100.00%6100.00%


static int be_get_resources(struct be_adapter *adapter) { struct device *dev = &adapter->pdev->dev; struct be_resources res = {0}; int status; /* For Lancer, SH etc read per-function resource limits from FW. * GET_FUNC_CONFIG returns per function guaranteed limits. * GET_PROFILE_CONFIG returns PCI-E related limits PF-pool limits */ if (BEx_chip(adapter)) { BEx_get_resources(adapter, &res); } else { status = be_cmd_get_func_config(adapter, &res); if (status) return status; /* If a deafault RXQ must be created, we'll use up one RSSQ*/ if (res.max_rss_qs && res.max_rss_qs == res.max_rx_qs && !(res.if_cap_flags & BE_IF_FLAGS_DEFQ_RSS)) res.max_rss_qs -= 1; } /* If RoCE is supported stash away half the EQs for RoCE */ res.max_nic_evt_qs = be_roce_supported(adapter) ? res.max_evt_qs / 2 : res.max_evt_qs; adapter->res = res; /* If FW supports RSS default queue, then skip creating non-RSS * queue for non-IP traffic. */ adapter->need_def_rxq = (be_if_cap_flags(adapter) & BE_IF_FLAGS_DEFQ_RSS) ? 0 : 1; dev_info(dev, "Max: txqs %d, rxqs %d, rss %d, eqs %d, vfs %d\n", be_max_txqs(adapter), be_max_rxqs(adapter), be_max_rss(adapter), be_max_nic_eqs(adapter), be_max_vfs(adapter)); dev_info(dev, "Max: uc-macs %d, mc-macs %d, vlans %d\n", be_max_uc(adapter), be_max_mc(adapter), be_max_vlans(adapter)); /* Ensure RX and TX queues are created in pairs at init time */ adapter->cfg_num_rx_irqs = min_t(u16, netif_get_num_default_rss_queues(), be_max_qp_irqs(adapter)); adapter->cfg_num_tx_irqs = adapter->cfg_num_rx_irqs; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla15065.50%457.14%
vasundhara volamvasundhara volam6327.51%228.57%
padmanabh ratnakarpadmanabh ratnakar166.99%114.29%
Total229100.00%7100.00%


static int be_get_config(struct be_adapter *adapter) { int status, level; u16 profile_id; status = be_cmd_get_cntl_attributes(adapter); if (status) return status; status = be_cmd_query_fw_cfg(adapter); if (status) return status; if (!lancer_chip(adapter) && be_physfn(adapter)) be_cmd_get_fat_dump_len(adapter, &adapter->fat_dump_len); if (BEx_chip(adapter)) { level = be_cmd_get_fw_log_level(adapter); adapter->msg_enable = level <= FW_LOG_LEVEL_DEFAULT ? NETIF_MSG_HW : 0; } be_cmd_get_acpi_wol_cap(adapter); pci_enable_wake(adapter->pdev, PCI_D3hot, adapter->wol_en); pci_enable_wake(adapter->pdev, PCI_D3cold, adapter->wol_en); be_cmd_query_port_name(adapter); if (be_physfn(adapter)) { status = be_cmd_get_active_profile(adapter, &profile_id); if (!status) dev_info(&adapter->pdev->dev, "Using profile 0x%x\n", profile_id); } return 0; }

Contributors

PersonTokensPropCommitsCommitProp
vasundhara volamvasundhara volam5229.71%436.36%
sathya perlasathya perla5129.14%327.27%
sriharsha basavapatnasriharsha basavapatna2614.86%19.09%
venkat duvvuruvenkat duvvuru2313.14%19.09%
suresh reddysuresh reddy148.00%19.09%
padmanabh ratnakarpadmanabh ratnakar95.14%19.09%
Total175100.00%11100.00%


static int be_mac_setup(struct be_adapter *adapter) { u8 mac[ETH_ALEN]; int status; if (is_zero_ether_addr(adapter->netdev->dev_addr)) { status = be_cmd_get_perm_mac(adapter, mac); if (status) return status; memcpy(adapter->netdev->dev_addr, mac, ETH_ALEN); memcpy(adapter->netdev->perm_addr, mac, ETH_ALEN); /* Initial MAC for BE3 VFs is already programmed by PF */ if (BEx_chip(adapter) && be_virtfn(adapter)) memcpy(adapter->dev_mac, mac, ETH_ALEN); } return 0; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla7876.47%150.00%
ivan veceraivan vecera2423.53%150.00%
Total102100.00%2100.00%


static void be_schedule_worker(struct be_adapter *adapter) { queue_delayed_work(be_wq, &adapter->work, msecs_to_jiffies(1000)); adapter->flags |= BE_FLAGS_WORKER_SCHEDULED; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla32100.00%2100.00%
Total32100.00%2100.00%


static void be_destroy_err_recovery_workq(void) { if (!be_err_recovery_workq) return; flush_workqueue(be_err_recovery_workq); destroy_workqueue(be_err_recovery_workq); be_err_recovery_workq = NULL; }

Contributors

PersonTokensPropCommitsCommitProp
sriharsha basavapatnasriharsha basavapatna28100.00%1100.00%
Total28100.00%1100.00%


static void be_schedule_err_detection(struct be_adapter *adapter, u32 delay) { struct be_error_recovery *err_rec = &adapter->error_recovery; if (!be_err_recovery_workq) return; queue_delayed_work(be_err_recovery_workq, &err_rec->err_detection_work, msecs_to_jiffies(delay)); adapter->flags |= BE_FLAGS_ERR_DETECTION_SCHEDULED; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla2650.98%133.33%
sriharsha basavapatnasriharsha basavapatna2141.18%133.33%
padmanabh ratnakarpadmanabh ratnakar47.84%133.33%
Total51100.00%3100.00%


static int be_setup_queues(struct be_adapter *adapter) { struct net_device *netdev = adapter->netdev; int status; status = be_evt_queues_create(adapter); if (status) goto err; status = be_tx_qs_create(adapter); if (status) goto err; status = be_rx_cqs_create(adapter); if (status) goto err; status = be_mcc_queues_create(adapter); if (status) goto err; status = netif_set_real_num_rx_queues(netdev, adapter->num_rx_qs); if (status) goto err; status = netif_set_real_num_tx_queues(netdev, adapter->num_tx_qs); if (status) goto err; return 0; err: dev_err(&adapter->pdev->dev, "queue_setup failed\n"); return status; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla10477.04%466.67%
padmanabh ratnakarpadmanabh ratnakar2216.30%116.67%
somnath kotursomnath kotur96.67%116.67%
Total135100.00%6100.00%


static int be_if_create(struct be_adapter *adapter) { u32 en_flags = BE_IF_FLAGS_RSS | BE_IF_FLAGS_DEFQ_RSS; u32 cap_flags = be_if_cap_flags(adapter); int status; /* alloc required memory for other filtering fields */ adapter->pmac_id = kcalloc(be_max_uc(adapter), sizeof(*adapter->pmac_id), GFP_KERNEL); if (!adapter->pmac_id) return -ENOMEM; adapter->mc_list = kcalloc(be_max_mc(adapter), sizeof(*adapter->mc_list), GFP_KERNEL); if (!adapter->mc_list) return -ENOMEM; adapter->uc_list = kcalloc(be_max_uc(adapter), sizeof(*adapter->uc_list), GFP_KERNEL); if (!adapter->uc_list) return -ENOMEM; if (adapter->cfg_num_rx_irqs == 1) cap_flags &= ~(BE_IF_FLAGS_DEFQ_RSS | BE_IF_FLAGS_RSS); en_flags &= cap_flags; /* will enable all the needed filter flags in be_open() */ status = be_cmd_if_create(adapter, be_if_cap_flags(adapter), en_flags, &adapter->if_handle, 0); if (status) return status; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla10959.89%266.67%
ajit khapardeajit khaparde7340.11%133.33%
Total182100.00%3100.00%


int be_update_queues(struct be_adapter *adapter) { struct net_device *netdev = adapter->netdev; int status; if (netif_running(netdev)) be_close(netdev); be_cancel_worker(adapter); /* If any vectors have been shared with RoCE we cannot re-program * the MSIx table. */ if (!adapter->num_msix_roce_vec) be_msix_disable(adapter); be_clear_queues(adapter); status = be_cmd_if_destroy(adapter, adapter->if_handle, 0); if (status) return status; if (!msix_enabled(adapter)) { status = be_msix_enable(adapter); if (status) return status; } status = be_if_create(adapter); if (status) return status; status = be_setup_queues(adapter); if (status) return status; be_schedule_worker(adapter); if (netif_running(netdev)) status = be_open(netdev); return status; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla11777.48%150.00%
ajit khapardeajit khaparde3422.52%150.00%
Total151100.00%2100.00%


static inline int fw_major_num(const char *fw_ver) { int fw_major = 0, i; i = sscanf(fw_ver, "%d.", &fw_major); if (i != 1) return 0; return fw_major; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla43100.00%1100.00%
Total43100.00%1100.00%

/* If it is error recovery, FLR the PF * Else if any VFs are already enabled don't FLR the PF */
static bool be_reset_required(struct be_adapter *adapter) { if (be_error_recovering(adapter)) return true; else return pci_num_vf(adapter->pdev) == 0; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla1959.38%150.00%
sriharsha basavapatnasriharsha basavapatna1340.62%150.00%
Total32100.00%2100.00%

/* Wait for the FW to be ready and perform the required initialization */
static int be_func_init(struct be_adapter *adapter) { int status; status = be_fw_wait_ready(adapter); if (status) return status; /* FW is now ready; clear errors to allow cmds/doorbell */ be_clear_error(adapter, BE_CLEAR_ALL); if (be_reset_required(adapter)) { status = be_cmd_reset_function(adapter); if (status) return status; /* Wait for interrupts to quiesce after an FLR */ msleep(100); } /* Tell FW we're ready to fire cmds */ status = be_cmd_fw_init(adapter); if (status) return status; /* Allow interrupts for other ULPs running on NIC function */ be_intr_set(adapter, true); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla8391.21%150.00%
sriharsha basavapatnasriharsha basavapatna88.79%150.00%
Total91100.00%2100.00%


static int be_setup(struct be_adapter *adapter) { struct device *dev = &adapter->pdev->dev; int status; status = be_func_init(adapter); if (status) return status; be_setup_init(adapter); if (!lancer_chip(adapter)) be_cmd_req_native_mode(adapter); /* invoke this cmd first to get pf_num and vf_num which are needed * for issuing profile related cmds */ if (!BEx_chip(adapter)) { status = be_cmd_get_func_config(adapter, NULL); if (status) return status; } status = be_get_config(adapter); if (status) goto err; if (!BE2_chip(adapter) && be_physfn(adapter)) be_alloc_sriov_res(adapter); status = be_get_resources(adapter); if (status) goto err; status = be_msix_enable(adapter); if (status) goto err; /* will enable all the needed filter flags in be_open() */ status = be_if_create(adapter); if (status) goto err; /* Updating real_num_tx/rx_queues() requires rtnl_lock() */ rtnl_lock(); status = be_setup_queues(adapter); rtnl_unlock(); if (status) goto err; be_cmd_get_fn_privileges(adapter, &adapter->cmd_privileges, 0); status = be_mac_setup(adapter); if (status) goto err; be_cmd_get_fw_ver(adapter); dev_info(dev, "FW version is %s\n", adapter->fw_ver); if (BE2_chip(adapter) && fw_major_num(adapter->fw_ver) < 4) { dev_err(dev, "Firmware on card is old(%s), IRQs may not work", adapter->fw_ver); dev_err(dev, "Please upgrade firmware to version >= 4.0\n"); } status = be_cmd_set_flow_control(adapter, adapter->tx_fc, adapter->rx_fc); if (status) be_cmd_get_flow_control(adapter, &adapter->tx_fc, &adapter->rx_fc); dev_info(&adapter->pdev->dev, "HW Flow control - TX:%d RX:%d\n", adapter->tx_fc, adapter->rx_fc); if (be_physfn(adapter)) be_cmd_set_logical_link_config(adapter, IFLA_VF_LINK_STATE_AUTO, 0); /* BE3 EVB echoes broadcast/multicast packets back to PF's vport * confusing a linux bridge or OVS that it might be connected to. * Set the EVB to PASSTHRU mode which effectively disables the EVB * when SRIOV is not enabled. */ if (BE3_chip(adapter)) be_cmd_set_hsw_config(adapter, 0, 0, adapter->if_handle, PORT_FWD_TYPE_PASSTHRU, 0); if (adapter->num_vfs) be_vf_setup(adapter); status = be_cmd_get_phy_info(adapter); if (!status && be_pause_supported(adapter)) adapter->phy.fc_autoneg = 1; if (be_physfn(adapter) && !lancer_chip(adapter)) be_cmd_set_features(adapter); be_schedule_worker(adapter); adapter->flags |= BE_FLAGS_SETUP_DONE; return 0; err: be_clear(adapter); return status; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla17340.05%1542.86%
somnath kotursomnath kotur8720.14%514.29%
kalesh purayilkalesh purayil378.56%38.57%
ajit khapardeajit khaparde368.33%411.43%
suresh reddysuresh reddy306.94%25.71%
padmanabh ratnakarpadmanabh ratnakar306.94%25.71%
vasundhara volamvasundhara volam214.86%38.57%
sriharsha basavapatnasriharsha basavapatna184.17%12.86%
Total432100.00%35100.00%

#ifdef CONFIG_NET_POLL_CONTROLLER
static void be_netpoll(struct net_device *netdev) { struct be_adapter *adapter = netdev_priv(netdev); struct be_eq_obj *eqo; int i; for_all_evt_queues(adapter, eqo, i) { be_eq_notify(eqo->adapter, eqo->q.id, false, true, 0, 0); napi_schedule(&eqo->napi); } }

Contributors

PersonTokensPropCommitsCommitProp
ivan veceraivan vecera3652.94%125.00%
sathya perlasathya perla3044.12%250.00%
padmanabh ratnakarpadmanabh ratnakar22.94%125.00%
Total68100.00%4100.00%

#endif
int be_load_fw(struct be_adapter *adapter, u8 *fw_file) { const struct firmware *fw; int status; if (!netif_running(adapter->netdev)) { dev_err(&adapter->pdev->dev, "Firmware load not allowed (interface is down)\n"); return -ENETDOWN; } status = request_firmware(&fw, fw_file, &adapter->pdev->dev); if (status) goto fw_exit; dev_info(&adapter->pdev->dev, "Flashing firmware file %s\n", fw_file); if (lancer_chip(adapter)) status = lancer_fw_download(adapter, fw); else status = be_fw_download(adapter, fw); if (!status) be_cmd_get_fw_ver(adapter); fw_exit: release_firmware(fw); return status; }

Contributors

PersonTokensPropCommitsCommitProp
shripad nunjundaraoshripad nunjundarao11383.70%125.00%
ajit khapardeajit khaparde118.15%125.00%
somnath kotursomnath kotur107.41%125.00%
kalesh purayilkalesh purayil10.74%125.00%
Total135100.00%4100.00%


static int be_ndo_bridge_setlink(struct net_device *dev, struct nlmsghdr *nlh, u16 flags) { struct be_adapter *adapter = netdev_priv(dev); struct nlattr *attr, *br_spec; int rem; int status = 0; u16 mode = 0; if (!sriov_enabled(adapter)) return -EOPNOTSUPP; br_spec = nlmsg_find_attr(nlh, sizeof(struct ifinfomsg), IFLA_AF_SPEC); if (!br_spec) return -EINVAL; nla_for_each_nested(attr, br_spec, rem) { if (nla_type(attr) != IFLA_BRIDGE_MODE) continue; if (nla_len(attr) < sizeof(mode)) return -EINVAL; mode = nla_get_u16(attr); if (BE3_chip(adapter) && mode == BRIDGE_MODE_VEPA) return -EOPNOTSUPP; if (mode != BRIDGE_MODE_VEPA && mode != BRIDGE_MODE_VEB) return -EINVAL; status = be_cmd_set_hsw_config(adapter, 0, 0, adapter->if_handle, mode == BRIDGE_MODE_VEPA ? PORT_FWD_TYPE_VEPA : PORT_FWD_TYPE_VEB, 0); if (status) goto err; dev_info(&adapter->pdev->dev, "enabled switch mode: %s\n", mode == BRIDGE_MODE_VEPA ? "VEPA" : "VEB"); return status; } err: dev_err(&adapter->pdev->dev, "Failed to set switch mode %s\n", mode == BRIDGE_MODE_VEPA ? "VEPA" : "VEB"); return status; }

Contributors

PersonTokensPropCommitsCommitProp
ajit khapardeajit khaparde19381.09%116.67%
thomas grafthomas graf2510.50%233.33%
suresh reddysuresh reddy156.30%116.67%
roopa prabhuroopa prabhu31.26%116.67%
kalesh purayilkalesh purayil20.84%116.67%
Total238100.00%6100.00%


static int be_ndo_bridge_getlink(struct sk_buff *skb, u32 pid, u32 seq, struct net_device *dev, u32 filter_mask, int nlflags) { struct be_adapter *adapter = netdev_priv(dev); int status = 0; u8 hsw_mode; /* BE and Lancer chips support VEB mode only */ if (BEx_chip(adapter) || lancer_chip(adapter)) { /* VEB is disabled in non-SR-IOV profiles on BE3/Lancer */ if (!pci_sriov_get_totalvfs(adapter->pdev)) return 0; hsw_mode = PORT_FWD_TYPE_VEB; } else { status = be_cmd_get_hsw_config(adapter, NULL, 0, adapter->if_handle, &hsw_mode, NULL); if (status) return 0; if (hsw_mode == PORT_FWD_TYPE_PASSTHRU) return 0; } return ndo_dflt_bridge_getlink(skb, pid, seq, dev, hsw_mode == PORT_FWD_TYPE_VEPA ? BRIDGE_MODE_VEPA : BRIDGE_MODE_VEB, 0, 0, nlflags, filter_mask, NULL); }

Contributors

PersonTokensPropCommitsCommitProp
ajit khapardeajit khaparde11074.32%114.29%
ivan veceraivan vecera149.46%114.29%
kalesh purayilkalesh purayil117.43%228.57%
scott feldmanscott feldman85.41%228.57%
nicolas dichtelnicolas dichtel53.38%114.29%
Total148100.00%7100.00%


static struct be_cmd_work *be_alloc_work(struct be_adapter *adapter, void (*func)(struct work_struct *)) { struct be_cmd_work *work; work = kzalloc(sizeof(*work), GFP_ATOMIC); if (!work) { dev_err(&adapter->pdev->dev, "be_work memory allocation failed\n"); return NULL; } INIT_WORK(&work->work, func); work->adapter = adapter; return work; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla83100.00%1100.00%
Total83100.00%1100.00%

/* VxLAN offload Notes: * * The stack defines tunnel offload flags (hw_enc_features) for IP and doesn't * distinguish various types of transports (VxLAN, GRE, NVGRE ..). So, offload * is expected to work across all types of IP tunnels once exported. Skyhawk * supports offloads for either VxLAN or NVGRE, exclusively. So we export VxLAN * offloads in hw_enc_features only when a VxLAN port is added. If other (non * VxLAN) tunnels are configured while VxLAN offloads are enabled, offloads for * those other tunnels are unexported on the fly through ndo_features_check(). * * Skyhawk supports VxLAN offloads only for one UDP dport. So, if the stack * adds more than one port, disable offloads and don't re-enable them again * until after all the tunnels are removed. */
static void be_work_add_vxlan_port(struct work_struct *work) { struct be_cmd_work *cmd_work = container_of(work, struct be_cmd_work, work); struct be_adapter *adapter = cmd_work->adapter; struct net_device *netdev = adapter->netdev; struct device *dev = &adapter->pdev->dev; __be16 port = cmd_work->info.vxlan_port; int status; if (adapter->vxlan_port == port && adapter->vxlan_port_count) { adapter->vxlan_port_aliases++; goto done; } if (adapter->flags & BE_FLAGS_VXLAN_OFFLOADS) { dev_info(dev, "Only one UDP port supported for VxLAN offloads\n"); dev_info(dev, "Disabling VxLAN offloads\n"); adapter->vxlan_port_count++; goto err; } if (adapter->vxlan_port_count++ >= 1) goto done; status = be_cmd_manage_iface(adapter, adapter->if_handle, OP_CONVERT_NORMAL_TO_TUNNEL); if (status) { dev_warn(dev, "Failed to convert normal interface to tunnel\n"); goto err; } status = be_cmd_set_vxlan_port(adapter, port); if (status) { dev_warn(dev, "Failed to add VxLAN port\n"); goto err; } adapter->flags |= BE_FLAGS_VXLAN_OFFLOADS; adapter->vxlan_port = port; netdev->hw_enc_features |= NETIF_F_IP_CSUM | NETIF_F_IPV6_CSUM | NETIF_F_TSO | NETIF_F_TSO6 | NETIF_F_GSO_UDP_TUNNEL; netdev->hw_features |= NETIF_F_GSO_UDP_TUNNEL; netdev->features |= NETIF_F_GSO_UDP_TUNNEL; dev_info(dev, "Enabled VxLAN offloads for UDP port %d\n", be16_to_cpu(port)); goto done; err: be_disable_vxlan_offloads(adapter); done: kfree(cmd_work); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla18472.16%233.33%
sriharsha basavapatnasriharsha basavapatna4618.04%233.33%
jiri bencjiri benc197.45%116.67%
alexander duyckalexander duyck62.35%116.67%
Total255100.00%6100.00%


static void be_work_del_vxlan_port(struct work_struct *work) { struct be_cmd_work *cmd_work = container_of(work, struct be_cmd_work, work); struct be_adapter *adapter = cmd_work->adapter; __be16 port = cmd_work->info.vxlan_port; if (adapter->vxlan_port != port) goto done; if (adapter->vxlan_port_aliases) { adapter->vxlan_port_aliases--; goto out; } be_disable_vxlan_offloads(adapter); dev_info(&adapter->pdev->dev, "Disabled VxLAN offloads for UDP port %d\n", be16_to_cpu(port)); done: adapter->vxlan_port_count--; out: kfree(cmd_work); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla7671.03%240.00%
jiri bencjiri benc1312.15%120.00%
sriharsha basavapatnasriharsha basavapatna109.35%120.00%
alexander duyckalexander duyck87.48%120.00%
Total107100.00%5100.00%


static void be_cfg_vxlan_port(struct net_device *netdev, struct udp_tunnel_info *ti, void (*func)(struct work_struct *)) { struct be_adapter *adapter = netdev_priv(netdev); struct be_cmd_work *cmd_work; if (ti->type != UDP_TUNNEL_TYPE_VXLAN) return; if (lancer_chip(adapter) || BEx_chip(adapter) || be_is_mc(adapter)) return; cmd_work = be_alloc_work(adapter, func); if (cmd_work) { cmd_work->info.vxlan_port = ti->port; queue_work(be_wq, &cmd_work->work); } }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla104100.00%1100.00%
Total104100.00%1100.00%


static void be_del_vxlan_port(struct net_device *netdev, struct udp_tunnel_info *ti) { be_cfg_vxlan_port(netdev, ti, be_work_del_vxlan_port); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla25100.00%1100.00%
Total25100.00%1100.00%


static void be_add_vxlan_port(struct net_device *netdev, struct udp_tunnel_info *ti) { be_cfg_vxlan_port(netdev, ti, be_work_add_vxlan_port); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla25100.00%2100.00%
Total25100.00%2100.00%


static netdev_features_t be_features_check(struct sk_buff *skb, struct net_device *dev, netdev_features_t features) { struct be_adapter *adapter = netdev_priv(dev); u8 l4_hdr = 0; /* The code below restricts offload features for some tunneled packets. * Offload features for normal (non tunnel) packets are unchanged. */ if (!skb->encapsulation || !(adapter->flags & BE_FLAGS_VXLAN_OFFLOADS)) return features; /* It's an encapsulated packet and VxLAN offloads are enabled. We * should disable tunnel offload features if it's not a VxLAN packet, * as tunnel offloads have been enabled only for VxLAN. This is done to * allow other tunneled traffic like GRE work fine while VxLAN * offloads are configured in Skyhawk-R. */ switch (vlan_get_protocol(skb)) { case htons(ETH_P_IP): l4_hdr = ip_hdr(skb)->protocol; break; case htons(ETH_P_IPV6): l4_hdr = ipv6_hdr(skb)->nexthdr; break; default: return features; } if (l4_hdr != IPPROTO_UDP || skb->inner_protocol_type != ENCAP_TYPE_ETHER || skb->inner_protocol != htons(ETH_P_TEB) || skb_inner_mac_header(skb) - skb_transport_header(skb) != sizeof(struct udphdr) + sizeof(struct vxlanhdr) || !adapter->vxlan_port || udp_hdr(skb)->dest != adapter->vxlan_port) return features & ~(NETIF_F_CSUM_MASK | NETIF_F_GSO_MASK); return features; }

Contributors

PersonTokensPropCommitsCommitProp
sriharsha basavapatnasriharsha basavapatna13075.58%120.00%
joe stringerjoe stringer1911.05%120.00%
sabrina dubrocasabrina dubroca169.30%120.00%
jesse grossjesse gross63.49%120.00%
tom herberttom herbert10.58%120.00%
Total172100.00%5100.00%


static int be_get_phys_port_id(struct net_device *dev, struct netdev_phys_item_id *ppid) { int i, id_len = CNTL_SERIAL_NUM_WORDS * CNTL_SERIAL_NUM_WORD_SZ + 1; struct be_adapter *adapter = netdev_priv(dev); u8 *id; if (MAX_PHYS_ITEM_ID_LEN < id_len) return -ENOSPC; ppid->id[0] = adapter->hba_port_num + 1; id = &ppid->id[1]; for (i = CNTL_SERIAL_NUM_WORDS - 1; i >= 0; i--, id += CNTL_SERIAL_NUM_WORD_SZ) memcpy(id, &adapter->serial_num[i], CNTL_SERIAL_NUM_WORD_SZ); ppid->id_len = id_len; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
sriharsha basavapatnasriharsha basavapatna117100.00%1100.00%
Total117100.00%1100.00%


static void be_set_rx_mode(struct net_device *dev) { struct be_adapter *adapter = netdev_priv(dev); struct be_cmd_work *work; work = be_alloc_work(adapter, be_work_set_rx_mode); if (work) queue_work(be_wq, &work->work); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla49100.00%1100.00%
Total49100.00%1100.00%

static const struct net_device_ops be_netdev_ops = { .ndo_open = be_open, .ndo_stop = be_close, .ndo_start_xmit = be_xmit, .ndo_set_rx_mode = be_set_rx_mode, .ndo_set_mac_address = be_mac_addr_set, .ndo_get_stats64 = be_get_stats64, .ndo_validate_addr = eth_validate_addr, .ndo_vlan_rx_add_vid = be_vlan_add_vid, .ndo_vlan_rx_kill_vid = be_vlan_rem_vid, .ndo_set_vf_mac = be_set_vf_mac, .ndo_set_vf_vlan = be_set_vf_vlan, .ndo_set_vf_rate = be_set_vf_tx_rate, .ndo_get_vf_config = be_get_vf_config, .ndo_set_vf_link_state = be_set_vf_link_state, .ndo_set_vf_spoofchk = be_set_vf_spoofchk, #ifdef CONFIG_NET_POLL_CONTROLLER .ndo_poll_controller = be_netpoll, #endif .ndo_bridge_setlink = be_ndo_bridge_setlink, .ndo_bridge_getlink = be_ndo_bridge_getlink, #ifdef CONFIG_NET_RX_BUSY_POLL .ndo_busy_poll = be_busy_poll, #endif .ndo_udp_tunnel_add = be_add_vxlan_port, .ndo_udp_tunnel_del = be_del_vxlan_port, .ndo_features_check = be_features_check, .ndo_get_phys_port_id = be_get_phys_port_id, };
static void be_netdev_init(struct net_device *netdev) { struct be_adapter *adapter = netdev_priv(netdev); netdev->hw_features |= NETIF_F_SG | NETIF_F_TSO | NETIF_F_TSO6 | NETIF_F_IP_CSUM | NETIF_F_IPV6_CSUM | NETIF_F_RXCSUM | NETIF_F_HW_VLAN_CTAG_TX; if ((be_if_cap_flags(adapter) & BE_IF_FLAGS_RSS)) netdev->hw_features |= NETIF_F_RXHASH; netdev->features |= netdev->hw_features | NETIF_F_HW_VLAN_CTAG_RX | NETIF_F_HW_VLAN_CTAG_FILTER; netdev->vlan_features |= NETIF_F_SG | NETIF_F_TSO | NETIF_F_TSO6 | NETIF_F_IP_CSUM | NETIF_F_IPV6_CSUM; netdev->priv_flags |= IFF_UNICAST_FLT; netdev->flags |= IFF_MULTICAST; netif_set_gso_max_size(netdev, BE_MAX_GSO_SIZE - ETH_HLEN); netdev->netdev_ops = &be_netdev_ops; netdev->ethtool_ops = &be_ethtool_ops; /* MTU range: 256 - 9000 */ netdev->min_mtu = BE_MIN_MTU; netdev->max_mtu = BE_MAX_MTU; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla4736.15%211.11%
ajit khapardeajit khaparde4030.77%844.44%
michal miroslawmichal miroslaw2015.38%316.67%
jarod wilsonjarod wilson1310.00%15.56%
patrick mchardypatrick mchardy32.31%15.56%
wilfried klaebewilfried klaebe32.31%15.56%
sarveshwar bandisarveshwar bandi21.54%15.56%
padmanabh ratnakarpadmanabh ratnakar21.54%15.56%
Total130100.00%18100.00%


static void be_cleanup(struct be_adapter *adapter) { struct net_device *netdev = adapter->netdev; rtnl_lock(); netif_device_detach(netdev); if (netif_running(netdev)) be_close(netdev); rtnl_unlock(); be_clear(adapter); }

Contributors

PersonTokensPropCommitsCommitProp
kalesh purayilkalesh purayil48100.00%1100.00%
Total48100.00%1100.00%


static int be_resume(struct be_adapter *adapter) { struct net_device *netdev = adapter->netdev; int status; status = be_setup(adapter); if (status) return status; rtnl_lock(); if (netif_running(netdev)) status = be_open(netdev); rtnl_unlock(); if (status) return status; netif_device_attach(netdev); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla4258.33%350.00%
kalesh purayilkalesh purayil2433.33%233.33%
hannes frederic sowahannes frederic sowa68.33%116.67%
Total72100.00%6100.00%


static void be_soft_reset(struct be_adapter *adapter) { u32 val; dev_info(&adapter->pdev->dev, "Initiating chip soft reset\n"); val = ioread32(adapter->pcicfg + SLIPORT_SOFTRESET_OFFSET); val |= SLIPORT_SOFTRESET_SR_MASK; iowrite32(val, adapter->pcicfg + SLIPORT_SOFTRESET_OFFSET); }

Contributors

PersonTokensPropCommitsCommitProp
sriharsha basavapatnasriharsha basavapatna2955.77%120.00%
kalesh purayilkalesh purayil1426.92%120.00%
padmanabh ratnakarpadmanabh ratnakar713.46%120.00%
sathya perlasathya perla23.85%240.00%
Total52100.00%5100.00%


static bool be_err_is_recoverable(struct be_adapter *adapter) { struct be_error_recovery *err_rec = &adapter->error_recovery; unsigned long initial_idle_time = msecs_to_jiffies(ERR_RECOVERY_IDLE_TIME); unsigned long recovery_interval = msecs_to_jiffies(ERR_RECOVERY_INTERVAL); u16 ue_err_code; u32 val; val = be_POST_stage_get(adapter); if ((val & POST_STAGE_RECOVERABLE_ERR) != POST_STAGE_RECOVERABLE_ERR) return false; ue_err_code = val & POST_ERR_RECOVERY_CODE_MASK; if (ue_err_code == 0) return false; dev_err(&adapter->pdev->dev, "Recoverable HW error code: 0x%x\n", ue_err_code); if (jiffies - err_rec->probe_time <= initial_idle_time) { dev_err(&adapter->pdev->dev, "Cannot recover within %lu sec from driver load\n", jiffies_to_msecs(initial_idle_time) / MSEC_PER_SEC); return false; } if (err_rec->last_recovery_time && (jiffies - err_rec->last_recovery_time <= recovery_interval)) { dev_err(&adapter->pdev->dev, "Cannot recover within %lu sec from last recovery\n", jiffies_to_msecs(recovery_interval) / MSEC_PER_SEC); return false; } if (ue_err_code == err_rec->last_err_code) { dev_err(&adapter->pdev->dev, "Cannot recover from a consecutive TPE error\n"); return false; } err_rec->last_recovery_time = jiffies; err_rec->last_err_code = ue_err_code; return true; }

Contributors

PersonTokensPropCommitsCommitProp
sriharsha basavapatnasriharsha basavapatna18287.50%114.29%
sathya perlasathya perla178.17%342.86%
padmanabh ratnakarpadmanabh ratnakar73.37%228.57%
venkat duvvuruvenkat duvvuru20.96%114.29%
Total208100.00%7100.00%


static int be_tpe_recover(struct be_adapter *adapter) { struct be_error_recovery *err_rec = &adapter->error_recovery; int status = -EAGAIN; u32 val; switch (err_rec->recovery_state) { case ERR_RECOVERY_ST_NONE: err_rec->recovery_state = ERR_RECOVERY_ST_DETECT; err_rec->resched_delay = ERR_RECOVERY_UE_DETECT_DURATION; break; case ERR_RECOVERY_ST_DETECT: val = be_POST_stage_get(adapter); if ((val & POST_STAGE_RECOVERABLE_ERR) != POST_STAGE_RECOVERABLE_ERR) { dev_err(&adapter->pdev->dev, "Unrecoverable HW error detected: 0x%x\n", val); status = -EINVAL; err_rec->resched_delay = 0; break; } dev_err(&adapter->pdev->dev, "Recoverable HW error detected\n"); /* Only PF0 initiates Chip Soft Reset. But PF0 must wait UE2SR * milliseconds before it checks for final error status in * SLIPORT_SEMAPHORE to determine if recovery criteria is met. * If it does, then PF0 initiates a Soft Reset. */ if (adapter->pf_num == 0) { err_rec->recovery_state = ERR_RECOVERY_ST_RESET; err_rec->resched_delay = err_rec->ue_to_reset_time - ERR_RECOVERY_UE_DETECT_DURATION; break; } err_rec->recovery_state = ERR_RECOVERY_ST_PRE_POLL; err_rec->resched_delay = err_rec->ue_to_poll_time - ERR_RECOVERY_UE_DETECT_DURATION; break; case ERR_RECOVERY_ST_RESET: if (!be_err_is_recoverable(adapter)) { dev_err(&adapter->pdev->dev, "Failed to meet recovery criteria\n"); status = -EIO; err_rec->resched_delay = 0; break; } be_soft_reset(adapter); err_rec->recovery_state = ERR_RECOVERY_ST_PRE_POLL; err_rec->resched_delay = err_rec->ue_to_poll_time - err_rec->ue_to_reset_time; break; case ERR_RECOVERY_ST_PRE_POLL: err_rec->recovery_state = ERR_RECOVERY_ST_REINIT; err_rec->resched_delay = 0; status = 0; /* done */ break; default: status = -EINVAL; err_rec->resched_delay = 0; break; } return status; }

Contributors

PersonTokensPropCommitsCommitProp
sriharsha basavapatnasriharsha basavapatna257100.00%1100.00%
Total257100.00%1100.00%


static int be_err_recover(struct be_adapter *adapter) { int status; if (!lancer_chip(adapter)) { if (!adapter->error_recovery.recovery_supported || adapter->priv_flags & BE_DISABLE_TPE_RECOVERY) return -EIO; status = be_tpe_recover(adapter); if (status) goto err; } /* Wait for adapter to reach quiescent state before * destroying queues */ status = be_fw_wait_ready(adapter); if (status) goto err; adapter->flags |= BE_FLAGS_TRY_RECOVERY; be_cleanup(adapter); status = be_resume(adapter); if (status) goto err; adapter->flags &= ~BE_FLAGS_TRY_RECOVERY; err: return status; }

Contributors

PersonTokensPropCommitsCommitProp
sriharsha basavapatnasriharsha basavapatna109100.00%1100.00%
Total109100.00%1100.00%


static void be_err_detection_task(struct work_struct *work) { struct be_error_recovery *err_rec = container_of(work, struct be_error_recovery, err_detection_work.work); struct be_adapter *adapter = container_of(err_rec, struct be_adapter, error_recovery); u32 resched_delay = ERR_RECOVERY_DETECTION_DELAY; struct device *dev = &adapter->pdev->dev; int recovery_status; be_detect_error(adapter); if (!be_check_error(adapter, BE_ERROR_HW)) goto reschedule_task; recovery_status = be_err_recover(adapter); if (!recovery_status) { err_rec->recovery_retries = 0; err_rec->recovery_state = ERR_RECOVERY_ST_NONE; dev_info(dev, "Adapter recovery successful\n"); goto reschedule_task; } else if (!lancer_chip(adapter) && err_rec->resched_delay) { /* BEx/SH recovery state machine */ if (adapter->pf_num == 0 && err_rec->recovery_state > ERR_RECOVERY_ST_DETECT) dev_err(&adapter->pdev->dev, "Adapter recovery in progress\n"); resched_delay = err_rec->resched_delay; goto reschedule_task; } else if (lancer_chip(adapter) && be_virtfn(adapter)) { /* For VFs, check if PF have allocated resources * every second. */ dev_err(dev, "Re-trying adapter recovery\n"); goto reschedule_task; } else if (lancer_chip(adapter) && err_rec->recovery_retries++ < ERR_RECOVERY_MAX_RETRY_COUNT) { /* In case of another error during recovery, it takes 30 sec * for adapter to come out of error. Retry error recovery after * this time interval. */ dev_err(&adapter->pdev->dev, "Re-trying adapter recovery\n"); resched_delay = ERR_RECOVERY_RETRY_DELAY; goto reschedule_task; } else { dev_err(dev, "Adapter recovery failed\n"); dev_err(dev, "Please reboot server to recover\n"); } return; reschedule_task: be_schedule_err_detection(adapter, resched_delay); }

Contributors

PersonTokensPropCommitsCommitProp
sriharsha basavapatnasriharsha basavapatna16965.50%112.50%
padmanabh ratnakarpadmanabh ratnakar7227.91%225.00%
sathya perlasathya perla176.59%562.50%
Total258100.00%8100.00%


static void be_log_sfp_info(struct be_adapter *adapter) { int status; status = be_cmd_query_sfp_info(adapter); if (!status) { dev_err(&adapter->pdev->dev, "Port %c: %s Vendor: %s part no: %s", adapter->port_name, be_misconfig_evt_port_state[adapter->phy_state], adapter->phy.vendor_name, adapter->phy.vendor_pn); } adapter->flags &= ~BE_FLAGS_PHY_MISCONFIGURED; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla5882.86%360.00%
ajit khapardeajit khaparde912.86%120.00%
ivan veceraivan vecera34.29%120.00%
Total70100.00%5100.00%


static void be_worker(struct work_struct *work) { struct be_adapter *adapter = container_of(work, struct be_adapter, work.work); struct be_rx_obj *rxo; int i; if (be_physfn(adapter) && MODULO(adapter->work_counter, adapter->be_get_temp_freq) == 0) be_cmd_get_die_temperature(adapter); /* when interrupts are not yet enabled, just reap any pending * mcc completions */ if (!netif_running(adapter->netdev)) { local_bh_disable(); be_process_mcc(adapter); local_bh_enable(); goto reschedule; } if (!adapter->stats_cmd_sent) { if (lancer_chip(adapter)) lancer_cmd_get_pport_stats(adapter, &adapter->stats_cmd); else be_cmd_get_stats(adapter, &adapter->stats_cmd); } for_all_rx_queues(adapter, rxo, i) { /* Replenish RX-queues starved due to memory * allocation failures. */ if (rxo->rx_post_starved) be_post_rx_frags(rxo, GFP_KERNEL, MAX_RX_POST); } /* EQ-delay update for Skyhawk is done while notifying EQ */ if (!skyhawk_chip(adapter)) be_eqd_update(adapter, false); if (adapter->flags & BE_FLAGS_PHY_MISCONFIGURED) be_log_sfp_info(adapter); reschedule: adapter->work_counter++; queue_delayed_work(be_wq, &adapter->work, msecs_to_jiffies(1000)); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla15978.71%861.54%
guilherme g. piccoliguilherme g. piccoli2512.38%17.69%
padmanabh ratnakarpadmanabh ratnakar115.45%17.69%
sarveshwar bandisarveshwar bandi41.98%17.69%
ivan veceraivan vecera20.99%17.69%
ajit khapardeajit khaparde10.50%17.69%
Total202100.00%13100.00%


static void be_unmap_pci_bars(struct be_adapter *adapter) { if (adapter->csr) pci_iounmap(adapter->pdev, adapter->csr); if (adapter->db) pci_iounmap(adapter->pdev, adapter->db); if (adapter->pcicfg && adapter->pcicfg_mapped) pci_iounmap(adapter->pdev, adapter->pcicfg); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla4568.18%266.67%
douglas millerdouglas miller2131.82%133.33%
Total66100.00%3100.00%


static int db_bar(struct be_adapter *adapter) { if (lancer_chip(adapter) || be_virtfn(adapter)) return 0; else return 4; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla2480.00%360.00%
ajit khapardeajit khaparde516.67%120.00%
kalesh purayilkalesh purayil13.33%120.00%
Total30100.00%5100.00%


static int be_roce_map_pci_bars(struct be_adapter *adapter) { if (skyhawk_chip(adapter)) { adapter->roce_db.size = 4096; adapter->roce_db.io_addr = pci_resource_start(adapter->pdev, db_bar(adapter)); adapter->roce_db.total_size = pci_resource_len(adapter->pdev, db_bar(adapter)); } return 0; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla5176.12%240.00%
selvin xavierselvin xavier1014.93%120.00%
ajit khapardeajit khaparde57.46%120.00%
ivan veceraivan vecera11.49%120.00%
Total67100.00%5100.00%


static int be_map_pci_bars(struct be_adapter *adapter) { struct pci_dev *pdev = adapter->pdev; u8 __iomem *addr; u32 sli_intf; pci_read_config_dword(adapter->pdev, SLI_INTF_REG_OFFSET, &sli_intf); adapter->sli_family = (sli_intf & SLI_INTF_FAMILY_MASK) >> SLI_INTF_FAMILY_SHIFT; adapter->virtfn = (sli_intf & SLI_INTF_FT_MASK) ? 1 : 0; if (BEx_chip(adapter) && be_physfn(adapter)) { adapter->csr = pci_iomap(pdev, 2, 0); if (!adapter->csr) return -ENOMEM; } addr = pci_iomap(pdev, db_bar(adapter), 0); if (!addr) goto pci_map_err; adapter->db = addr; if (skyhawk_chip(adapter) || BEx_chip(adapter)) { if (be_physfn(adapter)) { /* PCICFG is the 2nd BAR in BE2 */ addr = pci_iomap(pdev, BE2_chip(adapter) ? 1 : 0, 0); if (!addr) goto pci_map_err; adapter->pcicfg = addr; adapter->pcicfg_mapped = true; } else { adapter->pcicfg = adapter->db + SRIOV_VF_PCICFG_OFFSET; adapter->pcicfg_mapped = false; } } be_roce_map_pci_bars(adapter); return 0; pci_map_err: dev_err(&pdev->dev, "Error in mapping PCI BARs\n"); be_unmap_pci_bars(adapter); return -ENOMEM; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla13555.79%533.33%
david s. millerdavid s. miller5723.55%16.67%
ajit khapardeajit khaparde166.61%213.33%
douglas millerdouglas miller124.96%16.67%
padmanabh ratnakarpadmanabh ratnakar104.13%320.00%
somnath kotursomnath kotur104.13%213.33%
selvin xavierselvin xavier20.83%16.67%
Total242100.00%15100.00%


static void be_drv_cleanup(struct be_adapter *adapter) { struct be_dma_mem *mem = &adapter->mbox_mem_alloced; struct device *dev = &adapter->pdev->dev; if (mem->va) dma_free_coherent(dev, mem->size, mem->va, mem->dma); mem = &adapter->rx_filter; if (mem->va) dma_free_coherent(dev, mem->size, mem->va, mem->dma); mem = &adapter->stats_cmd; if (mem->va) dma_free_coherent(dev, mem->size, mem->va, mem->dma); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla7262.07%250.00%
padmanabh ratnakarpadmanabh ratnakar3126.72%125.00%
somnath kotursomnath kotur1311.21%125.00%
Total116100.00%4100.00%

/* Allocate and initialize various fields in be_adapter struct */
static int be_drv_init(struct be_adapter *adapter) { struct be_dma_mem *mbox_mem_alloc = &adapter->mbox_mem_alloced; struct be_dma_mem *mbox_mem_align = &adapter->mbox_mem; struct be_dma_mem *rx_filter = &adapter->rx_filter; struct be_dma_mem *stats_cmd = &adapter->stats_cmd; struct device *dev = &adapter->pdev->dev; int status = 0; mbox_mem_alloc->size = sizeof(struct be_mcc_mailbox) + 16; mbox_mem_alloc->va = dma_zalloc_coherent(dev, mbox_mem_alloc->size, &mbox_mem_alloc->dma, GFP_KERNEL); if (!mbox_mem_alloc->va) return -ENOMEM; mbox_mem_align->size = sizeof(struct be_mcc_mailbox); mbox_mem_align->va = PTR_ALIGN(mbox_mem_alloc->va, 16); mbox_mem_align->dma = PTR_ALIGN(mbox_mem_alloc->dma, 16); rx_filter->size = sizeof(struct be_cmd_req_rx_filter); rx_filter->va = dma_zalloc_coherent(dev, rx_filter->size, &rx_filter->dma, GFP_KERNEL); if (!rx_filter->va) { status = -ENOMEM; goto free_mbox; } if (lancer_chip(adapter)) stats_cmd->size = sizeof(struct lancer_cmd_req_pport_stats); else if (BE2_chip(adapter)) stats_cmd->size = sizeof(struct be_cmd_req_get_stats_v0); else if (BE3_chip(adapter)) stats_cmd->size = sizeof(struct be_cmd_req_get_stats_v1); else stats_cmd->size = sizeof(struct be_cmd_req_get_stats_v2); stats_cmd->va = dma_zalloc_coherent(dev, stats_cmd->size, &stats_cmd->dma, GFP_KERNEL); if (!stats_cmd->va) { status = -ENOMEM; goto free_rx_filter; } mutex_init(&adapter->mbox_lock); mutex_init(&adapter->mcc_lock); mutex_init(&adapter->rx_filter_lock); spin_lock_init(&adapter->mcc_cq_lock); init_completion(&adapter->et_cmd_compl); pci_save_state(adapter->pdev); INIT_DELAYED_WORK(&adapter->work, be_worker); adapter->error_recovery.recovery_state = ERR_RECOVERY_ST_NONE; adapter->error_recovery.resched_delay = 0; INIT_DELAYED_WORK(&adapter->error_recovery.err_detection_work, be_err_detection_task); adapter->rx_fc = true; adapter->tx_fc = true; /* Must be a power of 2 or else MODULO will BUG_ON */ adapter->be_get_temp_freq = 64; return 0; free_rx_filter: dma_free_coherent(dev, rx_filter->size, rx_filter->va, rx_filter->dma); free_mbox: dma_free_coherent(dev, mbox_mem_alloc->size, mbox_mem_alloc->va, mbox_mem_alloc->dma); return status; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla34277.20%333.33%
padmanabh ratnakarpadmanabh ratnakar4810.84%222.22%
vasundhara volamvasundhara volam286.32%111.11%
sriharsha basavapatnasriharsha basavapatna204.51%222.22%
somnath kotursomnath kotur51.13%111.11%
Total443100.00%9100.00%


static void be_remove(struct pci_dev *pdev) { struct be_adapter *adapter = pci_get_drvdata(pdev); if (!adapter) return; be_roce_dev_remove(adapter); be_intr_set(adapter, false); be_cancel_err_detection(adapter); unregister_netdev(adapter->netdev); be_clear(adapter); if (!pci_vfs_assigned(adapter->pdev)) be_cmd_reset_function(adapter); /* tell fw we're done with firing cmds */ be_cmd_fw_clean(adapter); be_unmap_pci_bars(adapter); be_drv_cleanup(adapter); pci_disable_pcie_error_reporting(pdev); pci_release_regions(pdev); pci_disable_device(pdev); free_netdev(adapter->netdev); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla4944.95%228.57%
padmanabh ratnakarpadmanabh ratnakar4238.53%342.86%
somnath kotursomnath kotur1513.76%114.29%
vasundhara volamvasundhara volam32.75%114.29%
Total109100.00%7100.00%


static ssize_t be_hwmon_show_temp(struct device *dev, struct device_attribute *dev_attr, char *buf) { struct be_adapter *adapter = dev_get_drvdata(dev); /* Unit: millidegree Celsius */ if (adapter->hwmon_info.be_on_die_temp == BE_INVALID_DIE_TEMP) return -EIO; else return sprintf(buf, "%u\n", adapter->hwmon_info.be_on_die_temp * 1000); }

Contributors

PersonTokensPropCommitsCommitProp
venkat duvvuruvenkat duvvuru6198.39%150.00%
arnd bergmannarnd bergmann11.61%150.00%
Total62100.00%2100.00%

static SENSOR_DEVICE_ATTR(temp1_input, S_IRUGO, be_hwmon_show_temp, NULL, 1); static struct attribute *be_hwmon_attrs[] = { &sensor_dev_attr_temp1_input.dev_attr.attr, NULL }; ATTRIBUTE_GROUPS(be_hwmon);
static char *mc_name(struct be_adapter *adapter) { char *str = ""; /* default */ switch (adapter->mc_type) { case UMC: str = "UMC"; break; case FLEX10: str = "FLEX10"; break; case vNIC1: str = "vNIC-1"; break; case nPAR: str = "nPAR"; break; case UFP: str = "UFP"; break; case vNIC2: str = "vNIC-2"; break; default: str = ""; } return str; }

Contributors

PersonTokensPropCommitsCommitProp
vasundhara volamvasundhara volam6477.11%150.00%
sathya perlasathya perla1922.89%150.00%
Total83100.00%2100.00%


static inline char *func_name(struct be_adapter *adapter) { return be_physfn(adapter) ? "PF" : "VF"; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla23100.00%1100.00%
Total23100.00%1100.00%


static inline char *nic_name(struct pci_dev *pdev) { switch (pdev->device) { case OC_DEVICE_ID1: return OC_NAME; case OC_DEVICE_ID2: return OC_NAME_BE; case OC_DEVICE_ID3: case OC_DEVICE_ID4: return OC_NAME_LANCER; case BE_DEVICE_ID2: return BE3_NAME; case OC_DEVICE_ID5: case OC_DEVICE_ID6: return OC_NAME_SH; default: return BE_NAME; } }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla61100.00%1100.00%
Total61100.00%1100.00%


static int be_probe(struct pci_dev *pdev, const struct pci_device_id *pdev_id) { struct be_adapter *adapter; struct net_device *netdev; int status = 0; dev_info(&pdev->dev, "%s version is %s\n", DRV_NAME, DRV_VER); status = pci_enable_device(pdev); if (status) goto do_none; status = pci_request_regions(pdev, DRV_NAME); if (status) goto disable_dev; pci_set_master(pdev); netdev = alloc_etherdev_mqs(sizeof(*adapter), MAX_TX_QS, MAX_RX_QS); if (!netdev) { status = -ENOMEM; goto rel_reg; } adapter = netdev_priv(netdev); adapter->pdev = pdev; pci_set_drvdata(pdev, adapter); adapter->netdev = netdev; SET_NETDEV_DEV(netdev, &pdev->dev); status = dma_set_mask_and_coherent(&pdev->dev, DMA_BIT_MASK(64)); if (!status) { netdev->features |= NETIF_F_HIGHDMA; } else { status = dma_set_mask_and_coherent(&pdev->dev, DMA_BIT_MASK(32)); if (status) { dev_err(&pdev->dev, "Could not set PCI DMA Mask\n"); goto free_netdev; } } status = pci_enable_pcie_error_reporting(pdev); if (!status) dev_info(&pdev->dev, "PCIe error reporting enabled\n"); status = be_map_pci_bars(adapter); if (status) goto free_netdev; status = be_drv_init(adapter); if (status) goto unmap_bars; status = be_setup(adapter); if (status) goto drv_cleanup; be_netdev_init(netdev); status = register_netdev(netdev); if (status != 0) goto unsetup; be_roce_dev_add(adapter); be_schedule_err_detection(adapter, ERR_DETECTION_DELAY); adapter->error_recovery.probe_time = jiffies; /* On Die temperature not supported for VF. */ if (be_physfn(adapter) && IS_ENABLED(CONFIG_BE2NET_HWMON)) { adapter->hwmon_info.hwmon_dev = devm_hwmon_device_register_with_groups(&pdev->dev, DRV_NAME, adapter, be_hwmon_groups); adapter->hwmon_info.be_on_die_temp = BE_INVALID_DIE_TEMP; } dev_info(&pdev->dev, "%s: %s %s port %c\n", nic_name(pdev), func_name(adapter), mc_name(adapter), adapter->port_name); return 0; unsetup: be_clear(adapter); drv_cleanup: be_drv_cleanup(adapter); unmap_bars: be_unmap_pci_bars(adapter); free_netdev: free_netdev(netdev); rel_reg: pci_release_regions(pdev); disable_dev: pci_disable_device(pdev); do_none: dev_err(&pdev->dev, "%s initialization failed\n", nic_name(pdev)); return status; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla30767.62%1343.33%
padmanabh ratnakarpadmanabh ratnakar4610.13%413.33%
venkat duvvuruvenkat duvvuru388.37%13.33%
somnath kotursomnath kotur143.08%13.33%
ajit khapardeajit khaparde143.08%26.67%
sriharsha basavapatnasriharsha basavapatna81.76%13.33%
vasundhara volamvasundhara volam61.32%13.33%
arnd bergmannarnd bergmann51.10%13.33%
parav panditparav pandit51.10%13.33%
ivan veceraivan vecera40.88%26.67%
yang hongyangyang hongyang40.88%13.33%
russell kingrussell king20.44%13.33%
kalesh purayilkalesh purayil10.22%13.33%
Total454100.00%30100.00%


static int be_suspend(struct pci_dev *pdev, pm_message_t state) { struct be_adapter *adapter = pci_get_drvdata(pdev); be_intr_set(adapter, false); be_cancel_err_detection(adapter); be_cleanup(adapter); pci_save_state(pdev); pci_disable_device(pdev); pci_set_power_state(pdev, pci_choose_state(pdev, state)); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla5481.82%350.00%
ajit khapardeajit khaparde710.61%116.67%
padmanabh ratnakarpadmanabh ratnakar46.06%116.67%
kalesh purayilkalesh purayil11.52%116.67%
Total66100.00%6100.00%


static int be_pci_resume(struct pci_dev *pdev) { struct be_adapter *adapter = pci_get_drvdata(pdev); int status = 0; status = pci_enable_device(pdev); if (status) return status; pci_restore_state(pdev); status = be_resume(adapter); if (status) return status; be_schedule_err_detection(adapter, ERR_DETECTION_DELAY); return 0; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla6086.96%350.00%
kalesh purayilkalesh purayil57.25%116.67%
sarveshwar bandisarveshwar bandi22.90%116.67%
padmanabh ratnakarpadmanabh ratnakar22.90%116.67%
Total69100.00%6100.00%

/* * An FLR will stop BE from DMAing any data. */
static void be_shutdown(struct pci_dev *pdev) { struct be_adapter *adapter = pci_get_drvdata(pdev); if (!adapter) return; be_roce_dev_shutdown(adapter); cancel_delayed_work_sync(&adapter->work); be_cancel_err_detection(adapter); netif_device_detach(adapter->netdev); be_cmd_reset_function(adapter); pci_disable_device(pdev); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla3353.23%228.57%
ajit khapardeajit khaparde2032.26%342.86%
devesh sharmadevesh sharma58.06%114.29%
padmanabh ratnakarpadmanabh ratnakar46.45%114.29%
Total62100.00%7100.00%


static pci_ers_result_t be_eeh_err_detected(struct pci_dev *pdev, pci_channel_state_t state) { struct be_adapter *adapter = pci_get_drvdata(pdev); dev_err(&adapter->pdev->dev, "EEH error detected\n"); be_roce_dev_remove(adapter); if (!be_check_error(adapter, BE_ERROR_EEH)) { be_set_error(adapter, BE_ERROR_EEH); be_cancel_err_detection(adapter); be_cleanup(adapter); } if (state == pci_channel_io_perm_failure) return PCI_ERS_RESULT_DISCONNECT; pci_disable_device(pdev); /* The error could cause the FW to trigger a flash debug dump. * Resetting the card while flash dump is in progress * can cause it not to recover; wait for it to finish. * Wait only for first function as it is needed only once per * adapter. */ if (pdev->devfn == 0) ssleep(30); return PCI_ERS_RESULT_NEED_RESET; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla6059.41%222.22%
padmanabh ratnakarpadmanabh ratnakar1817.82%333.33%
somnath kotursomnath kotur1211.88%222.22%
venkat duvvuruvenkat duvvuru109.90%111.11%
kalesh purayilkalesh purayil10.99%111.11%
Total101100.00%9100.00%


static pci_ers_result_t be_eeh_reset(struct pci_dev *pdev) { struct be_adapter *adapter = pci_get_drvdata(pdev); int status; dev_info(&adapter->pdev->dev, "EEH reset\n"); status = pci_enable_device(pdev); if (status) return PCI_ERS_RESULT_DISCONNECT; pci_set_master(pdev); pci_restore_state(pdev); /* Check if card is ok and fw is ready */ dev_info(&adapter->pdev->dev, "Waiting for FW to be ready after EEH reset\n"); status = be_fw_wait_ready(adapter); if (status) return PCI_ERS_RESULT_DISCONNECT; pci_cleanup_aer_uncorrect_error_status(pdev); be_clear_error(adapter, BE_CLEAR_ALL); return PCI_ERS_RESULT_RECOVERED; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla9492.16%350.00%
somnath kotursomnath kotur43.92%116.67%
venkat duvvuruvenkat duvvuru32.94%116.67%
padmanabh ratnakarpadmanabh ratnakar10.98%116.67%
Total102100.00%6100.00%


static void be_eeh_resume(struct pci_dev *pdev) { int status = 0; struct be_adapter *adapter = pci_get_drvdata(pdev); dev_info(&adapter->pdev->dev, "EEH resume\n"); pci_save_state(pdev); status = be_resume(adapter); if (status) goto err; be_roce_dev_add(adapter); be_schedule_err_detection(adapter, ERR_DETECTION_DELAY); return; err: dev_err(&adapter->pdev->dev, "EEH resume failed\n"); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla7690.48%240.00%
padmanabh ratnakarpadmanabh ratnakar78.33%240.00%
kalesh purayilkalesh purayil11.19%120.00%
Total84100.00%5100.00%


static int be_pci_sriov_configure(struct pci_dev *pdev, int num_vfs) { struct be_adapter *adapter = pci_get_drvdata(pdev); struct be_resources vft_res = {0}; int status; if (!num_vfs) be_vf_clear(adapter); adapter->num_vfs = num_vfs; if (adapter->num_vfs == 0 && pci_vfs_assigned(pdev)) { dev_warn(&pdev->dev, "Cannot disable VFs while they are assigned\n"); return -EBUSY; } /* When the HW is in SRIOV capable configuration, the PF-pool resources * are equally distributed across the max-number of VFs. The user may * request only a subset of the max-vfs to be enabled. * Based on num_vfs, redistribute the resources across num_vfs so that * each VF will have access to more number of resources. * This facility is not available in BE3 FW. * Also, this is done by FW in Lancer chip. */ if (skyhawk_chip(adapter) && !pci_num_vf(pdev)) { be_calculate_vf_res(adapter, adapter->num_vfs, &vft_res); status = be_cmd_set_sriov_config(adapter, adapter->pool_res, adapter->num_vfs, &vft_res); if (status) dev_err(&pdev->dev, "Failed to optimize SR-IOV resources\n"); } status = be_get_resources(adapter); if (status) return be_cmd_status(status); /* Updating real_num_tx/rx_queues() requires rtnl_lock() */ rtnl_lock(); status = be_update_queues(adapter); rtnl_unlock(); if (status) return be_cmd_status(status); if (adapter->num_vfs) status = be_vf_setup(adapter); if (!status) return adapter->num_vfs; return 0; }

Contributors

PersonTokensPropCommitsCommitProp
vasundhara volamvasundhara volam19493.72%150.00%
suresh reddysuresh reddy136.28%150.00%
Total207100.00%2100.00%

static const struct pci_error_handlers be_eeh_handlers = { .error_detected = be_eeh_err_detected, .slot_reset = be_eeh_reset, .resume = be_eeh_resume, }; static struct pci_driver be_driver = { .name = DRV_NAME, .id_table = be_dev_ids, .probe = be_probe, .remove = be_remove, .suspend = be_suspend, .resume = be_pci_resume, .shutdown = be_shutdown, .sriov_configure = be_pci_sriov_configure, .err_handler = &be_eeh_handlers };
static int __init be_init_module(void) { int status; if (rx_frag_size != 8192 && rx_frag_size != 4096 && rx_frag_size != 2048) { printk(KERN_WARNING DRV_NAME " : Module param rx_frag_size must be 2048/4096/8192." " Using 2048\n"); rx_frag_size = 2048; } if (num_vfs > 0) { pr_info(DRV_NAME " : Module param num_vfs is obsolete."); pr_info(DRV_NAME " : Use sysfs method to enable VFs\n"); } be_wq = create_singlethread_workqueue("be_wq"); if (!be_wq) { pr_warn(DRV_NAME "workqueue creation failed\n"); return -1; } be_err_recovery_workq = create_singlethread_workqueue("be_err_recover"); if (!be_err_recovery_workq) pr_warn(DRV_NAME "Could not create error recovery workqueue\n"); status = pci_register_driver(&be_driver); if (status) { destroy_workqueue(be_wq); be_destroy_err_recovery_workq(); } return status; }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla6652.38%250.00%
sriharsha basavapatnasriharsha basavapatna4031.75%125.00%
vasundhara volamvasundhara volam2015.87%125.00%
Total126100.00%4100.00%

module_init(be_init_module);
static void __exit be_exit_module(void) { pci_unregister_driver(&be_driver); be_destroy_err_recovery_workq(); if (be_wq) destroy_workqueue(be_wq); }

Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla2488.89%266.67%
sriharsha basavapatnasriharsha basavapatna311.11%133.33%
Total27100.00%3100.00%

module_exit(be_exit_module);

Overall Contributors

PersonTokensPropCommitsCommitProp
sathya perlasathya perla1424849.58%11326.04%
ajit khapardeajit khaparde353912.31%6615.21%
sriharsha basavapatnasriharsha basavapatna27249.48%163.69%
vasundhara volamvasundhara volam15425.37%276.22%
padmanabh ratnakarpadmanabh ratnakar12344.29%327.37%
kalesh purayilkalesh purayil9903.44%204.61%
suresh reddysuresh reddy9623.35%184.15%
somnath kotursomnath kotur8963.12%327.37%
venkat duvvuruvenkat duvvuru8052.80%81.84%
ivan veceraivan vecera3271.14%133.00%
selvin xavierselvin xavier2450.85%20.46%
ravikumar nelavelliravikumar nelavelli1840.64%20.46%
sarveshwar bandisarveshwar bandi1640.57%81.84%
eric dumazeteric dumazet1260.44%122.76%
shripad nunjundaraoshripad nunjundarao1130.39%10.23%
david s. millerdavid s. miller700.24%40.92%
alexander duyckalexander duyck490.17%30.69%
parav panditparav pandit440.15%10.23%
michal miroslawmichal miroslaw350.12%30.69%
douglas millerdouglas miller330.11%10.23%
jiri bencjiri benc320.11%10.23%
john stultzjohn stultz300.10%10.23%
alexander gordeevalexander gordeev280.10%10.23%
thomas grafthomas graf250.09%20.46%
guilherme g. piccoliguilherme g. piccoli250.09%10.23%
sucheta chakrabortysucheta chakraborty240.08%10.23%
joe stringerjoe stringer220.08%10.23%
patrick mchardypatrick mchardy190.07%30.69%
moshe shemeshmoshe shemesh160.06%10.23%
sabrina dubrocasabrina dubroca160.06%10.23%
tom herberttom herbert150.05%30.69%
ian campbellian campbell140.05%10.23%
rusty russellrusty russell130.05%10.23%
jarod wilsonjarod wilson130.05%10.23%
jiri pirkojiri pirko120.04%30.69%
mammatha edhalamammatha edhala90.03%10.23%
jesse grossjesse gross80.03%10.23%
stephen hemmingerstephen hemminger80.03%40.92%
eric w. biedermaneric w. biederman80.03%10.23%
scott feldmanscott feldman80.03%20.46%
paul gortmakerpaul gortmaker60.02%20.46%
joe perchesjoe perches60.02%20.46%
benoit tainebenoit taine60.02%10.23%
arnd bergmannarnd bergmann60.02%10.23%
hannes frederic sowahannes frederic sowa60.02%10.23%
nicolas dichtelnicolas dichtel50.02%10.23%
devesh sharmadevesh sharma50.02%10.23%
yang hongyangyang hongyang40.01%10.23%
wilfried klaebewilfried klaebe30.01%10.23%
roopa prabhuroopa prabhu30.01%10.23%
dan carpenterdan carpenter30.01%10.23%
russell kingrussell king20.01%10.23%
fujita tomonorifujita tomonori20.01%20.46%
ding tianhongding tianhong20.01%10.23%
jingoo hanjingoo han20.01%10.23%
wei yongjunwei yongjun20.01%10.23%
baoyou xiebaoyou xie10.00%10.23%
rick jonesrick jones10.00%10.23%
Total28740100.00%434100.00%
Information contained on this website is for historical information purposes only and does not indicate or represent copyright ownership.