Lines Matching +full:msi +full:- +full:base +full:- +full:vec
4 * Copyright (c) 2003-2016 Chelsio Communications, Inc. All rights reserved.
16 * - Redistributions of source code must retain the above
20 * - Redistributions in binary form must reproduce the above
61 #define CH_WARN(adap, fmt, ...) dev_warn(adap->pdev_dev, fmt, ## __VA_ARGS__)
138 FEC_RS = 1 << 1, /* Reed-Solomon */
139 FEC_BASER_RS = 1 << 2 /* BaseR/Reed-Solomon */
262 u64 rx_ovflow0; /* drops due to buffer-group 0 overflows */
263 u64 rx_ovflow1; /* drops due to buffer-group 1 overflows */
264 u64 rx_ovflow2; /* drops due to buffer-group 2 overflows */
265 u64 rx_ovflow3; /* drops due to buffer-group 3 overflows */
266 u64 rx_trunc0; /* buffer-group 0 truncated packets */
267 u64 rx_trunc1; /* buffer-group 1 truncated packets */
268 u64 rx_trunc2; /* buffer-group 2 truncated packets */
269 u64 rx_trunc3; /* buffer-group 3 truncated packets */
374 * places we store their offsets here, or a -1 if the field isn't
408 unsigned int tc; /* PCI-E traffic class */
482 u8 fw_caps_support; /* 32-bit Port Capabilities */
505 /* Firmware Mailbox Command/Reply log. All values are in Host-Endian format.
511 u64 timestamp; /* OS-dependent timestamp */
571 typedef u16 fw_port_cap16_t; /* 16-bit Port Capabilities integral value */
572 typedef u32 fw_port_cap32_t; /* 32-bit Port Capabilities integral value */
576 FW_CAPS16 = 1, /* old Firmware: 16-bit Port Capabilities */
577 FW_CAPS32 = 2, /* new Firmware: 32-bit Port Capabilities */
601 bool new_module; /* ->OS Transceiver Module inserted */
602 bool redo_l1cfg; /* ->CC redo current "sticky" L1 CFG */
735 struct sge_fl { /* SGE free-buffer queue state */
822 unsigned long imm; /* # of immediate-data packets */
846 unsigned int in_use; /* # of in-use Tx descriptors */
1007 void **egr_map; /* qid->queue egress queue map */
1008 struct sge_rspq **ingr_map; /* qid->queue ingress queue map */
1015 int fwevtq_msix_idx; /* Index to firmware event queue MSI-X info */
1016 int nd_msix_idx; /* Index to non-data interrupts MSI-X info */
1019 #define for_each_ethrxq(sge, i) for (i = 0; i < (sge)->ethqsets; i++)
1020 #define for_each_ofldtxq(sge, i) for (i = 0; i < (sge)->ofldqsets; i++)
1026 /* T4 supports SRIOV on PF0-3 and T5 on PF0-7. However, the Serial
1027 * Configuration initialization for T5 only has SR-IOV functionality enabled
1028 * on PF0-3 in order to simplify everything.
1053 unsigned short vec; member
1130 /* MSI-X Info for NIC and OFLD queues */
1138 u8 chan_map[NCHAN]; /* channel -> port map */
1238 /* Ethtool n-tuple */
1242 /* Support for "sched-class" command to allow a TX Scheduling Class to be
1250 u8 mode; /* per-class or per-flow */
1274 SCHED_CLASS_MODE_CLASS = 0, /* per-class scheduling */
1275 SCHED_CLASS_MODE_FLOW, /* per-flow scheduling */
1332 * We really need to come up with a hardware-independent mechanism to
1338 * filter match rules -- up to a maximum of 36 bits. Because
1354 uint32_t pf:PF_BITWIDTH; /* PCI-E PF ID */
1355 uint32_t vf:VF_BITWIDTH; /* PCI-E VF ID */
1381 u32 hash:1; /* 0 => wild-card, 1 => exact-match */
1400 * packet -- potentially with some Ethernet header rewriting.
1449 NAT_MODE_ALL /* NAT on entire 4-tuple */
1456 * firmware command. The use of bit-field structure elements is purely to
1474 * internal forms -- for instance the Ingress Queue ID passed in from
1482 return adap->params.offload; in is_offload()
1487 return adap->params.hash_filter; in is_hashfilter()
1492 return adap->params.crypto; in is_pci_uld()
1497 return (adap->params.offload || adap->params.crypto); in is_uld()
1502 return adap->params.ethofld; in is_ethofld()
1507 return readl(adap->regs + reg_addr); in t4_read_reg()
1512 writel(val, adap->regs + reg_addr); in t4_write_reg()
1530 return readq(adap->regs + reg_addr); in t4_read_reg64()
1535 writeq(val, adap->regs + reg_addr); in t4_write_reg64()
1539 * t4_set_hw_addr - store a port's MAC address in SW
1550 ether_addr_copy(adapter->port[port_idx]->dev_addr, hw_addr); in t4_set_hw_addr()
1551 ether_addr_copy(adapter->port[port_idx]->perm_addr, hw_addr); in t4_set_hw_addr()
1555 * netdev2pinfo - return the port_info structure associated with a net_device
1566 * adap2pinfo - return the port_info of a port
1574 return netdev_priv(adap->port[idx]); in adap2pinfo()
1578 * netdev2adap - return the adapter structure associated with a net_device
1585 return netdev2pinfo(dev)->adapter; in netdev2adap()
1589 * - bits 0..9: chip version
1590 * - bits 10..15: chip revision
1591 * - bits 16..23: register dump version
1595 return CHELSIO_CHIP_VERSION(ap->params.chip) | in mk_adap_vers()
1596 (CHELSIO_CHIP_RELEASE(ap->params.chip) << 10) | (1 << 16); in mk_adap_vers()
1599 /* Return a queue's interrupt hold-off time in us. 0 means no timer. */
1603 unsigned int idx = q->intr_params >> 1; in qtimer_val()
1605 return idx < SGE_NTIMERS ? adap->sge.timer_val[idx] : 0; in qtimer_val()
1653 for (iter = 0; iter < (adapter)->params.nports; ++iter)
1657 return adap->params.bypass; in is_bypass()
1687 return adap->params.vpd.cclk / 1000; in core_ticks_per_usec()
1693 return (us * adap->params.vpd.cclk) / 1000; in us_to_core_ticks()
1700 return ((ticks * 1000 + adapter->params.vpd.cclk/2) / in core_ticks_to_us()
1701 adapter->params.vpd.cclk); in core_ticks_to_us()
1707 return (ticks << adap->params.tp.dack_re) / core_ticks_per_usec(adap); in dack_ticks_to_usec()
1739 * hash_mac_addr - return the hash value of a MAC address
1740 * @addr: the 48-bit Ethernet MAC address
1762 q->adap = adap; in init_rspq()
1764 q->iqe_len = iqe_size; in init_rspq()
1765 q->size = size; in init_rspq()
1769 * t4_is_inserted_mod_type - is a plugged in Firmware Module Type
1933 void t4_read_cimq_cfg(struct adapter *adap, u16 *base, u16 *size, u16 *thres);
2029 bool ucast, u64 vec, bool sleep_ok);
2137 int cxgb4_set_msix_aff(struct adapter *adap, unsigned short vec,
2139 void cxgb4_clear_msix_aff(unsigned short vec, cpumask_var_t aff_mask);