mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-13 08:39:52 +00:00
Merge branch 'hns3-next'
Salil Mehta says: ==================== Bug fixes, snall modifications & cleanup for HNS3 driver This patch presents some bug fixes, small modifications and cleanups to the HNS3 VF and PF driver. ==================== Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
commit
4f4b93a88c
@ -107,6 +107,7 @@ enum hnae3_media_type {
|
||||
HNAE3_MEDIA_TYPE_FIBER,
|
||||
HNAE3_MEDIA_TYPE_COPPER,
|
||||
HNAE3_MEDIA_TYPE_BACKPLANE,
|
||||
HNAE3_MEDIA_TYPE_NONE,
|
||||
};
|
||||
|
||||
enum hnae3_reset_notify_type {
|
||||
@ -410,7 +411,6 @@ struct hnae3_ae_ops {
|
||||
void (*get_link_mode)(struct hnae3_handle *handle,
|
||||
unsigned long *supported,
|
||||
unsigned long *advertising);
|
||||
void (*get_port_type)(struct hnae3_handle *handle, u8 *port_type);
|
||||
};
|
||||
|
||||
struct hnae3_dcb_ops {
|
||||
|
@ -1807,7 +1807,7 @@ static int hns3_map_buffer(struct hns3_enet_ring *ring, struct hns3_desc_cb *cb)
|
||||
cb->dma = dma_map_page(ring_to_dev(ring), cb->priv, 0,
|
||||
cb->length, ring_to_dma_dir(ring));
|
||||
|
||||
if (dma_mapping_error(ring_to_dev(ring), cb->dma))
|
||||
if (unlikely(dma_mapping_error(ring_to_dev(ring), cb->dma)))
|
||||
return -EIO;
|
||||
|
||||
return 0;
|
||||
@ -1973,6 +1973,7 @@ static int is_valid_clean_head(struct hns3_enet_ring *ring, int h)
|
||||
void hns3_clean_tx_ring(struct hns3_enet_ring *ring)
|
||||
{
|
||||
struct net_device *netdev = ring->tqp->handle->kinfo.netdev;
|
||||
struct hns3_nic_priv *priv = netdev_priv(netdev);
|
||||
struct netdev_queue *dev_queue;
|
||||
int bytes, pkts;
|
||||
int head;
|
||||
@ -2018,7 +2019,8 @@ void hns3_clean_tx_ring(struct hns3_enet_ring *ring)
|
||||
* sees the new next_to_clean.
|
||||
*/
|
||||
smp_mb();
|
||||
if (netif_tx_queue_stopped(dev_queue)) {
|
||||
if (netif_tx_queue_stopped(dev_queue) &&
|
||||
!test_bit(HNS3_NIC_STATE_DOWN, &priv->state)) {
|
||||
netif_tx_wake_queue(dev_queue);
|
||||
ring->stats.restart_queue++;
|
||||
}
|
||||
@ -2147,7 +2149,6 @@ static void hns3_rx_checksum(struct hns3_enet_ring *ring, struct sk_buff *skb,
|
||||
hnae3_get_bit(l234info, HNS3_RXD_L4E_B) ||
|
||||
hnae3_get_bit(l234info, HNS3_RXD_OL3E_B) ||
|
||||
hnae3_get_bit(l234info, HNS3_RXD_OL4E_B))) {
|
||||
netdev_err(netdev, "L3/L4 error pkt\n");
|
||||
u64_stats_update_begin(&ring->syncp);
|
||||
ring->stats.l3l4_csum_err++;
|
||||
u64_stats_update_end(&ring->syncp);
|
||||
@ -2176,6 +2177,8 @@ static void hns3_rx_checksum(struct hns3_enet_ring *ring, struct sk_buff *skb,
|
||||
l4_type == HNS3_L4_TYPE_SCTP))
|
||||
skb->ip_summed = CHECKSUM_UNNECESSARY;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
@ -2324,8 +2327,6 @@ static int hns3_handle_rx_bd(struct hns3_enet_ring *ring,
|
||||
}
|
||||
|
||||
if (unlikely(!hnae3_get_bit(bd_base_info, HNS3_RXD_VLD_B))) {
|
||||
netdev_err(netdev, "no valid bd,%016llx,%016llx\n",
|
||||
((u64 *)desc)[0], ((u64 *)desc)[1]);
|
||||
u64_stats_update_begin(&ring->syncp);
|
||||
ring->stats.non_vld_descs++;
|
||||
u64_stats_update_end(&ring->syncp);
|
||||
@ -2336,7 +2337,6 @@ static int hns3_handle_rx_bd(struct hns3_enet_ring *ring,
|
||||
|
||||
if (unlikely((!desc->rx.pkt_len) ||
|
||||
hnae3_get_bit(l234info, HNS3_RXD_TRUNCAT_B))) {
|
||||
netdev_err(netdev, "truncated pkt\n");
|
||||
u64_stats_update_begin(&ring->syncp);
|
||||
ring->stats.err_pkt_len++;
|
||||
u64_stats_update_end(&ring->syncp);
|
||||
@ -2346,7 +2346,6 @@ static int hns3_handle_rx_bd(struct hns3_enet_ring *ring,
|
||||
}
|
||||
|
||||
if (unlikely(hnae3_get_bit(l234info, HNS3_RXD_L2E_B))) {
|
||||
netdev_err(netdev, "L2 error pkt\n");
|
||||
u64_stats_update_begin(&ring->syncp);
|
||||
ring->stats.l2_err++;
|
||||
u64_stats_update_end(&ring->syncp);
|
||||
|
@ -22,13 +22,13 @@ struct hns3_stats {
|
||||
static const struct hns3_stats hns3_txq_stats[] = {
|
||||
/* Tx per-queue statistics */
|
||||
HNS3_TQP_STAT("io_err_cnt", io_err_cnt),
|
||||
HNS3_TQP_STAT("tx_dropped", sw_err_cnt),
|
||||
HNS3_TQP_STAT("dropped", sw_err_cnt),
|
||||
HNS3_TQP_STAT("seg_pkt_cnt", seg_pkt_cnt),
|
||||
HNS3_TQP_STAT("packets", tx_pkts),
|
||||
HNS3_TQP_STAT("bytes", tx_bytes),
|
||||
HNS3_TQP_STAT("errors", tx_err_cnt),
|
||||
HNS3_TQP_STAT("tx_wake", restart_queue),
|
||||
HNS3_TQP_STAT("tx_busy", tx_busy),
|
||||
HNS3_TQP_STAT("wake", restart_queue),
|
||||
HNS3_TQP_STAT("busy", tx_busy),
|
||||
};
|
||||
|
||||
#define HNS3_TXQ_STATS_COUNT ARRAY_SIZE(hns3_txq_stats)
|
||||
@ -36,7 +36,7 @@ static const struct hns3_stats hns3_txq_stats[] = {
|
||||
static const struct hns3_stats hns3_rxq_stats[] = {
|
||||
/* Rx per-queue statistics */
|
||||
HNS3_TQP_STAT("io_err_cnt", io_err_cnt),
|
||||
HNS3_TQP_STAT("rx_dropped", sw_err_cnt),
|
||||
HNS3_TQP_STAT("dropped", sw_err_cnt),
|
||||
HNS3_TQP_STAT("seg_pkt_cnt", seg_pkt_cnt),
|
||||
HNS3_TQP_STAT("packets", rx_pkts),
|
||||
HNS3_TQP_STAT("bytes", rx_bytes),
|
||||
@ -351,9 +351,10 @@ static int hns3_get_sset_count(struct net_device *netdev, int stringset)
|
||||
|
||||
case ETH_SS_TEST:
|
||||
return ops->get_sset_count(h, stringset);
|
||||
}
|
||||
|
||||
return 0;
|
||||
default:
|
||||
return -EOPNOTSUPP;
|
||||
}
|
||||
}
|
||||
|
||||
static void *hns3_update_strings(u8 *data, const struct hns3_stats *stats,
|
||||
@ -369,7 +370,7 @@ static void *hns3_update_strings(u8 *data, const struct hns3_stats *stats,
|
||||
data[ETH_GSTRING_LEN - 1] = '\0';
|
||||
|
||||
/* first, prepend the prefix string */
|
||||
n1 = snprintf(data, MAX_PREFIX_SIZE, "%s#%d_",
|
||||
n1 = snprintf(data, MAX_PREFIX_SIZE, "%s%d_",
|
||||
prefix, i);
|
||||
n1 = min_t(uint, n1, MAX_PREFIX_SIZE - 1);
|
||||
size_left = (ETH_GSTRING_LEN - 1) - n1;
|
||||
@ -417,6 +418,8 @@ static void hns3_get_strings(struct net_device *netdev, u32 stringset, u8 *data)
|
||||
case ETH_SS_TEST:
|
||||
ops->get_strings(h, stringset, data);
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
@ -542,55 +545,67 @@ static int hns3_set_pauseparam(struct net_device *netdev,
|
||||
return -EOPNOTSUPP;
|
||||
}
|
||||
|
||||
static void hns3_get_ksettings(struct hnae3_handle *h,
|
||||
struct ethtool_link_ksettings *cmd)
|
||||
{
|
||||
const struct hnae3_ae_ops *ops = h->ae_algo->ops;
|
||||
|
||||
/* 1.auto_neg & speed & duplex from cmd */
|
||||
if (ops->get_ksettings_an_result)
|
||||
ops->get_ksettings_an_result(h,
|
||||
&cmd->base.autoneg,
|
||||
&cmd->base.speed,
|
||||
&cmd->base.duplex);
|
||||
|
||||
/* 2.get link mode*/
|
||||
if (ops->get_link_mode)
|
||||
ops->get_link_mode(h,
|
||||
cmd->link_modes.supported,
|
||||
cmd->link_modes.advertising);
|
||||
|
||||
/* 3.mdix_ctrl&mdix get from phy reg */
|
||||
if (ops->get_mdix_mode)
|
||||
ops->get_mdix_mode(h, &cmd->base.eth_tp_mdix_ctrl,
|
||||
&cmd->base.eth_tp_mdix);
|
||||
}
|
||||
|
||||
static int hns3_get_link_ksettings(struct net_device *netdev,
|
||||
struct ethtool_link_ksettings *cmd)
|
||||
{
|
||||
struct hnae3_handle *h = hns3_get_handle(netdev);
|
||||
const struct hnae3_ae_ops *ops;
|
||||
u8 media_type;
|
||||
u8 link_stat;
|
||||
|
||||
if (!h->ae_algo || !h->ae_algo->ops)
|
||||
return -EOPNOTSUPP;
|
||||
|
||||
ops = h->ae_algo->ops;
|
||||
if (ops->get_port_type)
|
||||
ops->get_port_type(h, &cmd->base.port);
|
||||
if (ops->get_media_type)
|
||||
ops->get_media_type(h, &media_type);
|
||||
else
|
||||
return -EOPNOTSUPP;
|
||||
|
||||
switch (cmd->base.port) {
|
||||
case PORT_FIBRE:
|
||||
/* 1.auto_neg & speed & duplex from cmd */
|
||||
if (ops->get_ksettings_an_result)
|
||||
ops->get_ksettings_an_result(h,
|
||||
&cmd->base.autoneg,
|
||||
&cmd->base.speed,
|
||||
&cmd->base.duplex);
|
||||
else
|
||||
return -EOPNOTSUPP;
|
||||
|
||||
/* 2.get link mode*/
|
||||
if (ops->get_link_mode)
|
||||
ops->get_link_mode(h,
|
||||
cmd->link_modes.supported,
|
||||
cmd->link_modes.advertising);
|
||||
|
||||
/* 3.mdix_ctrl&mdix get from phy reg */
|
||||
if (ops->get_mdix_mode)
|
||||
ops->get_mdix_mode(h, &cmd->base.eth_tp_mdix_ctrl,
|
||||
&cmd->base.eth_tp_mdix);
|
||||
|
||||
switch (media_type) {
|
||||
case HNAE3_MEDIA_TYPE_NONE:
|
||||
cmd->base.port = PORT_NONE;
|
||||
hns3_get_ksettings(h, cmd);
|
||||
break;
|
||||
case PORT_TP:
|
||||
case HNAE3_MEDIA_TYPE_FIBER:
|
||||
cmd->base.port = PORT_FIBRE;
|
||||
hns3_get_ksettings(h, cmd);
|
||||
break;
|
||||
case HNAE3_MEDIA_TYPE_COPPER:
|
||||
if (!netdev->phydev)
|
||||
return -EOPNOTSUPP;
|
||||
|
||||
cmd->base.port = PORT_TP;
|
||||
phy_ethtool_ksettings_get(netdev->phydev, cmd);
|
||||
|
||||
break;
|
||||
default:
|
||||
netdev_warn(netdev,
|
||||
"Unknown port type, neither Fibre/Copper detected");
|
||||
|
||||
netdev_warn(netdev, "Unknown media type");
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
@ -73,6 +73,7 @@ static int hclge_ieee_getets(struct hnae3_handle *h, struct ieee_ets *ets)
|
||||
static int hclge_ets_validate(struct hclge_dev *hdev, struct ieee_ets *ets,
|
||||
u8 *tc, bool *changed)
|
||||
{
|
||||
bool has_ets_tc = false;
|
||||
u32 total_ets_bw = 0;
|
||||
u8 max_tc = 0;
|
||||
u8 i;
|
||||
@ -100,13 +101,14 @@ static int hclge_ets_validate(struct hclge_dev *hdev, struct ieee_ets *ets,
|
||||
*changed = true;
|
||||
|
||||
total_ets_bw += ets->tc_tx_bw[i];
|
||||
break;
|
||||
has_ets_tc = true;
|
||||
break;
|
||||
default:
|
||||
return -EINVAL;
|
||||
}
|
||||
}
|
||||
|
||||
if (total_ets_bw != BW_PERCENT)
|
||||
if (has_ets_tc && total_ets_bw != BW_PERCENT)
|
||||
return -EINVAL;
|
||||
|
||||
*tc = max_tc + 1;
|
||||
|
@ -354,7 +354,7 @@ static u8 *hclge_tqps_get_strings(struct hnae3_handle *handle, u8 *data)
|
||||
for (i = 0; i < kinfo->num_tqps; i++) {
|
||||
struct hclge_tqp *tqp = container_of(handle->kinfo.tqp[i],
|
||||
struct hclge_tqp, q);
|
||||
snprintf(buff, ETH_GSTRING_LEN, "txq#%d_pktnum_rcd",
|
||||
snprintf(buff, ETH_GSTRING_LEN, "txq%d_pktnum_rcd",
|
||||
tqp->index);
|
||||
buff = buff + ETH_GSTRING_LEN;
|
||||
}
|
||||
@ -362,7 +362,7 @@ static u8 *hclge_tqps_get_strings(struct hnae3_handle *handle, u8 *data)
|
||||
for (i = 0; i < kinfo->num_tqps; i++) {
|
||||
struct hclge_tqp *tqp = container_of(kinfo->tqp[i],
|
||||
struct hclge_tqp, q);
|
||||
snprintf(buff, ETH_GSTRING_LEN, "rxq#%d_pktnum_rcd",
|
||||
snprintf(buff, ETH_GSTRING_LEN, "rxq%d_pktnum_rcd",
|
||||
tqp->index);
|
||||
buff = buff + ETH_GSTRING_LEN;
|
||||
}
|
||||
@ -2224,6 +2224,8 @@ static void hclge_clear_event_cause(struct hclge_dev *hdev, u32 event_type,
|
||||
case HCLGE_VECTOR0_EVENT_MBX:
|
||||
hclge_write_dev(&hdev->hw, HCLGE_VECTOR0_CMDQ_SRC_REG, regclr);
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
@ -3387,7 +3389,7 @@ static int hclge_set_serdes_loopback(struct hclge_dev *hdev, bool en)
|
||||
struct hclge_desc desc;
|
||||
int ret, i = 0;
|
||||
|
||||
req = (struct hclge_serdes_lb_cmd *)&desc.data[0];
|
||||
req = (struct hclge_serdes_lb_cmd *)desc.data;
|
||||
hclge_cmd_setup_basic_desc(&desc, HCLGE_OPC_SERDES_LOOPBACK, false);
|
||||
|
||||
if (en) {
|
||||
@ -4634,7 +4636,7 @@ static int hclge_set_vlan_protocol_type(struct hclge_dev *hdev)
|
||||
|
||||
hclge_cmd_setup_basic_desc(&desc, HCLGE_OPC_MAC_VLAN_INSERT, false);
|
||||
|
||||
tx_req = (struct hclge_tx_vlan_type_cfg_cmd *)&desc.data;
|
||||
tx_req = (struct hclge_tx_vlan_type_cfg_cmd *)desc.data;
|
||||
tx_req->ot_vlan_type = cpu_to_le16(hdev->vlan_type_cfg.tx_ot_vlan_type);
|
||||
tx_req->in_vlan_type = cpu_to_le16(hdev->vlan_type_cfg.tx_in_vlan_type);
|
||||
|
||||
@ -5218,6 +5220,10 @@ static int hclge_init_client_instance(struct hnae3_client *client,
|
||||
|
||||
hnae3_set_client_init_flag(client, ae_dev, 1);
|
||||
}
|
||||
|
||||
break;
|
||||
default:
|
||||
return -EINVAL;
|
||||
}
|
||||
}
|
||||
|
||||
@ -5964,27 +5970,6 @@ static void hclge_get_link_mode(struct hnae3_handle *handle,
|
||||
}
|
||||
}
|
||||
|
||||
static void hclge_get_port_type(struct hnae3_handle *handle,
|
||||
u8 *port_type)
|
||||
{
|
||||
struct hclge_vport *vport = hclge_get_vport(handle);
|
||||
struct hclge_dev *hdev = vport->back;
|
||||
u8 media_type = hdev->hw.mac.media_type;
|
||||
|
||||
switch (media_type) {
|
||||
case HNAE3_MEDIA_TYPE_FIBER:
|
||||
*port_type = PORT_FIBRE;
|
||||
break;
|
||||
case HNAE3_MEDIA_TYPE_COPPER:
|
||||
*port_type = PORT_TP;
|
||||
break;
|
||||
case HNAE3_MEDIA_TYPE_UNKNOWN:
|
||||
default:
|
||||
*port_type = PORT_OTHER;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
static const struct hnae3_ae_ops hclge_ops = {
|
||||
.init_ae_dev = hclge_init_ae_dev,
|
||||
.uninit_ae_dev = hclge_uninit_ae_dev,
|
||||
@ -6042,7 +6027,6 @@ static const struct hnae3_ae_ops hclge_ops = {
|
||||
.get_regs = hclge_get_regs,
|
||||
.set_led_id = hclge_set_led_id,
|
||||
.get_link_mode = hclge_get_link_mode,
|
||||
.get_port_type = hclge_get_port_type,
|
||||
};
|
||||
|
||||
static struct hnae3_ae_algo ae_algo = {
|
||||
|
@ -172,7 +172,7 @@ static int hclge_pfc_pause_en_cfg(struct hclge_dev *hdev, u8 tx_rx_bitmap,
|
||||
u8 pfc_bitmap)
|
||||
{
|
||||
struct hclge_desc desc;
|
||||
struct hclge_pfc_en_cmd *pfc = (struct hclge_pfc_en_cmd *)&desc.data;
|
||||
struct hclge_pfc_en_cmd *pfc = (struct hclge_pfc_en_cmd *)desc.data;
|
||||
|
||||
hclge_cmd_setup_basic_desc(&desc, HCLGE_OPC_CFG_PFC_PAUSE_EN, false);
|
||||
|
||||
@ -188,7 +188,7 @@ static int hclge_pause_param_cfg(struct hclge_dev *hdev, const u8 *addr,
|
||||
struct hclge_cfg_pause_param_cmd *pause_param;
|
||||
struct hclge_desc desc;
|
||||
|
||||
pause_param = (struct hclge_cfg_pause_param_cmd *)&desc.data;
|
||||
pause_param = (struct hclge_cfg_pause_param_cmd *)desc.data;
|
||||
|
||||
hclge_cmd_setup_basic_desc(&desc, HCLGE_OPC_CFG_MAC_PARA, false);
|
||||
|
||||
@ -207,7 +207,7 @@ int hclge_pause_addr_cfg(struct hclge_dev *hdev, const u8 *mac_addr)
|
||||
u8 trans_gap;
|
||||
int ret;
|
||||
|
||||
pause_param = (struct hclge_cfg_pause_param_cmd *)&desc.data;
|
||||
pause_param = (struct hclge_cfg_pause_param_cmd *)desc.data;
|
||||
|
||||
hclge_cmd_setup_basic_desc(&desc, HCLGE_OPC_CFG_MAC_PARA, true);
|
||||
|
||||
|
@ -134,7 +134,7 @@ static int hclgevf_init_cmd_queue(struct hclgevf_dev *hdev,
|
||||
|
||||
hclgevf_write_dev(hw, HCLGEVF_NIC_CSQ_HEAD_REG, 0);
|
||||
hclgevf_write_dev(hw, HCLGEVF_NIC_CSQ_TAIL_REG, 0);
|
||||
break;
|
||||
return 0;
|
||||
case HCLGEVF_TYPE_CRQ:
|
||||
reg_val = (u32)ring->desc_dma_addr;
|
||||
hclgevf_write_dev(hw, HCLGEVF_NIC_CRQ_BASEADDR_L_REG, reg_val);
|
||||
@ -147,10 +147,10 @@ static int hclgevf_init_cmd_queue(struct hclgevf_dev *hdev,
|
||||
|
||||
hclgevf_write_dev(hw, HCLGEVF_NIC_CRQ_HEAD_REG, 0);
|
||||
hclgevf_write_dev(hw, HCLGEVF_NIC_CRQ_TAIL_REG, 0);
|
||||
break;
|
||||
return 0;
|
||||
default:
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
void hclgevf_cmd_setup_basic_desc(struct hclgevf_desc *desc,
|
||||
|
@ -31,16 +31,15 @@ static inline struct hclgevf_dev *hclgevf_ae_get_hdev(
|
||||
|
||||
static int hclgevf_tqps_update_stats(struct hnae3_handle *handle)
|
||||
{
|
||||
struct hnae3_knic_private_info *kinfo = &handle->kinfo;
|
||||
struct hclgevf_dev *hdev = hclgevf_ae_get_hdev(handle);
|
||||
struct hnae3_queue *queue;
|
||||
struct hclgevf_desc desc;
|
||||
struct hclgevf_tqp *tqp;
|
||||
int status;
|
||||
int i;
|
||||
|
||||
for (i = 0; i < hdev->num_tqps; i++) {
|
||||
queue = handle->kinfo.tqp[i];
|
||||
tqp = container_of(queue, struct hclgevf_tqp, q);
|
||||
for (i = 0; i < kinfo->num_tqps; i++) {
|
||||
tqp = container_of(kinfo->tqp[i], struct hclgevf_tqp, q);
|
||||
hclgevf_cmd_setup_basic_desc(&desc,
|
||||
HCLGEVF_OPC_QUERY_RX_STATUS,
|
||||
true);
|
||||
@ -77,17 +76,16 @@ static int hclgevf_tqps_update_stats(struct hnae3_handle *handle)
|
||||
static u64 *hclgevf_tqps_get_stats(struct hnae3_handle *handle, u64 *data)
|
||||
{
|
||||
struct hnae3_knic_private_info *kinfo = &handle->kinfo;
|
||||
struct hclgevf_dev *hdev = hclgevf_ae_get_hdev(handle);
|
||||
struct hclgevf_tqp *tqp;
|
||||
u64 *buff = data;
|
||||
int i;
|
||||
|
||||
for (i = 0; i < hdev->num_tqps; i++) {
|
||||
tqp = container_of(handle->kinfo.tqp[i], struct hclgevf_tqp, q);
|
||||
for (i = 0; i < kinfo->num_tqps; i++) {
|
||||
tqp = container_of(kinfo->tqp[i], struct hclgevf_tqp, q);
|
||||
*buff++ = tqp->tqp_stats.rcb_tx_ring_pktnum_rcd;
|
||||
}
|
||||
for (i = 0; i < kinfo->num_tqps; i++) {
|
||||
tqp = container_of(handle->kinfo.tqp[i], struct hclgevf_tqp, q);
|
||||
tqp = container_of(kinfo->tqp[i], struct hclgevf_tqp, q);
|
||||
*buff++ = tqp->tqp_stats.rcb_rx_ring_pktnum_rcd;
|
||||
}
|
||||
|
||||
@ -96,29 +94,29 @@ static u64 *hclgevf_tqps_get_stats(struct hnae3_handle *handle, u64 *data)
|
||||
|
||||
static int hclgevf_tqps_get_sset_count(struct hnae3_handle *handle, int strset)
|
||||
{
|
||||
struct hclgevf_dev *hdev = hclgevf_ae_get_hdev(handle);
|
||||
struct hnae3_knic_private_info *kinfo = &handle->kinfo;
|
||||
|
||||
return hdev->num_tqps * 2;
|
||||
return kinfo->num_tqps * 2;
|
||||
}
|
||||
|
||||
static u8 *hclgevf_tqps_get_strings(struct hnae3_handle *handle, u8 *data)
|
||||
{
|
||||
struct hclgevf_dev *hdev = hclgevf_ae_get_hdev(handle);
|
||||
struct hnae3_knic_private_info *kinfo = &handle->kinfo;
|
||||
u8 *buff = data;
|
||||
int i = 0;
|
||||
|
||||
for (i = 0; i < hdev->num_tqps; i++) {
|
||||
struct hclgevf_tqp *tqp = container_of(handle->kinfo.tqp[i],
|
||||
struct hclgevf_tqp, q);
|
||||
snprintf(buff, ETH_GSTRING_LEN, "txq#%d_pktnum_rcd",
|
||||
for (i = 0; i < kinfo->num_tqps; i++) {
|
||||
struct hclgevf_tqp *tqp = container_of(kinfo->tqp[i],
|
||||
struct hclgevf_tqp, q);
|
||||
snprintf(buff, ETH_GSTRING_LEN, "txq%d_pktnum_rcd",
|
||||
tqp->index);
|
||||
buff += ETH_GSTRING_LEN;
|
||||
}
|
||||
|
||||
for (i = 0; i < hdev->num_tqps; i++) {
|
||||
struct hclgevf_tqp *tqp = container_of(handle->kinfo.tqp[i],
|
||||
struct hclgevf_tqp, q);
|
||||
snprintf(buff, ETH_GSTRING_LEN, "rxq#%d_pktnum_rcd",
|
||||
for (i = 0; i < kinfo->num_tqps; i++) {
|
||||
struct hclgevf_tqp *tqp = container_of(kinfo->tqp[i],
|
||||
struct hclgevf_tqp, q);
|
||||
snprintf(buff, ETH_GSTRING_LEN, "rxq%d_pktnum_rcd",
|
||||
tqp->index);
|
||||
buff += ETH_GSTRING_LEN;
|
||||
}
|
||||
@ -182,7 +180,7 @@ static int hclgevf_get_tc_info(struct hclgevf_dev *hdev)
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int hclge_get_queue_info(struct hclgevf_dev *hdev)
|
||||
static int hclgevf_get_queue_info(struct hclgevf_dev *hdev)
|
||||
{
|
||||
#define HCLGEVF_TQPS_RSS_INFO_LEN 8
|
||||
u8 resp_msg[HCLGEVF_TQPS_RSS_INFO_LEN];
|
||||
@ -738,14 +736,12 @@ static int hclgevf_get_queue_id(struct hnae3_queue *queue)
|
||||
|
||||
static void hclgevf_reset_tqp_stats(struct hnae3_handle *handle)
|
||||
{
|
||||
struct hclgevf_dev *hdev = hclgevf_ae_get_hdev(handle);
|
||||
struct hnae3_queue *queue;
|
||||
struct hnae3_knic_private_info *kinfo = &handle->kinfo;
|
||||
struct hclgevf_tqp *tqp;
|
||||
int i;
|
||||
|
||||
for (i = 0; i < hdev->num_tqps; i++) {
|
||||
queue = handle->kinfo.tqp[i];
|
||||
tqp = container_of(queue, struct hclgevf_tqp, q);
|
||||
for (i = 0; i < kinfo->num_tqps; i++) {
|
||||
tqp = container_of(kinfo->tqp[i], struct hclgevf_tqp, q);
|
||||
memset(&tqp->tqp_stats, 0, sizeof(tqp->tqp_stats));
|
||||
}
|
||||
}
|
||||
@ -1344,8 +1340,10 @@ static int hclgevf_configure(struct hclgevf_dev *hdev)
|
||||
{
|
||||
int ret;
|
||||
|
||||
hdev->hw.mac.media_type = HNAE3_MEDIA_TYPE_NONE;
|
||||
|
||||
/* get queue configuration from PF */
|
||||
ret = hclge_get_queue_info(hdev);
|
||||
ret = hclgevf_get_queue_info(hdev);
|
||||
if (ret)
|
||||
return ret;
|
||||
/* get tc configuration from PF */
|
||||
@ -1420,12 +1418,13 @@ static int hclgevf_init_vlan_config(struct hclgevf_dev *hdev)
|
||||
|
||||
static int hclgevf_ae_start(struct hnae3_handle *handle)
|
||||
{
|
||||
struct hnae3_knic_private_info *kinfo = &handle->kinfo;
|
||||
struct hclgevf_dev *hdev = hclgevf_ae_get_hdev(handle);
|
||||
int i, queue_id;
|
||||
|
||||
for (i = 0; i < handle->kinfo.num_tqps; i++) {
|
||||
for (i = 0; i < kinfo->num_tqps; i++) {
|
||||
/* ring enable */
|
||||
queue_id = hclgevf_get_queue_id(handle->kinfo.tqp[i]);
|
||||
queue_id = hclgevf_get_queue_id(kinfo->tqp[i]);
|
||||
if (queue_id < 0) {
|
||||
dev_warn(&hdev->pdev->dev,
|
||||
"Get invalid queue id, ignore it\n");
|
||||
@ -1448,14 +1447,15 @@ static int hclgevf_ae_start(struct hnae3_handle *handle)
|
||||
|
||||
static void hclgevf_ae_stop(struct hnae3_handle *handle)
|
||||
{
|
||||
struct hnae3_knic_private_info *kinfo = &handle->kinfo;
|
||||
struct hclgevf_dev *hdev = hclgevf_ae_get_hdev(handle);
|
||||
int i, queue_id;
|
||||
|
||||
set_bit(HCLGEVF_STATE_DOWN, &hdev->state);
|
||||
|
||||
for (i = 0; i < hdev->num_tqps; i++) {
|
||||
for (i = 0; i < kinfo->num_tqps; i++) {
|
||||
/* Ring disable */
|
||||
queue_id = hclgevf_get_queue_id(handle->kinfo.tqp[i]);
|
||||
queue_id = hclgevf_get_queue_id(kinfo->tqp[i]);
|
||||
if (queue_id < 0) {
|
||||
dev_warn(&hdev->pdev->dev,
|
||||
"Get invalid queue id, ignore it\n");
|
||||
@ -1669,6 +1669,9 @@ static int hclgevf_init_client_instance(struct hnae3_client *client,
|
||||
}
|
||||
|
||||
hnae3_set_client_init_flag(client, ae_dev, 1);
|
||||
break;
|
||||
default:
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
return 0;
|
||||
@ -2008,6 +2011,14 @@ void hclgevf_update_speed_duplex(struct hclgevf_dev *hdev, u32 speed,
|
||||
hdev->hw.mac.duplex = duplex;
|
||||
}
|
||||
|
||||
static void hclgevf_get_media_type(struct hnae3_handle *handle,
|
||||
u8 *media_type)
|
||||
{
|
||||
struct hclgevf_dev *hdev = hclgevf_ae_get_hdev(handle);
|
||||
if (media_type)
|
||||
*media_type = hdev->hw.mac.media_type;
|
||||
}
|
||||
|
||||
static const struct hnae3_ae_ops hclgevf_ops = {
|
||||
.init_ae_dev = hclgevf_init_ae_dev,
|
||||
.uninit_ae_dev = hclgevf_uninit_ae_dev,
|
||||
@ -2045,6 +2056,7 @@ static const struct hnae3_ae_ops hclgevf_ops = {
|
||||
.get_tqps_and_rss_info = hclgevf_get_tqps_and_rss_info,
|
||||
.get_status = hclgevf_get_status,
|
||||
.get_ksettings_an_result = hclgevf_get_ksettings_an_result,
|
||||
.get_media_type = hclgevf_get_media_type,
|
||||
};
|
||||
|
||||
static struct hnae3_ae_algo ae_algovf = {
|
||||
|
@ -66,6 +66,7 @@ enum hclgevf_states {
|
||||
#define HCLGEVF_MPF_ENBALE 1
|
||||
|
||||
struct hclgevf_mac {
|
||||
u8 media_type;
|
||||
u8 mac_addr[ETH_ALEN];
|
||||
int link;
|
||||
u8 duplex;
|
||||
|
Loading…
x
Reference in New Issue
Block a user