mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-12 00:38:55 +00:00
Merge branch 'net-hns-bugfixes-for-HNS-Driver'
Yonglong Liu says: ==================== net: hns: bugfixes for HNS Driver This patchset fix some bugs that were found in the test of various scenarios, or identify by KASAN/sparse. ==================== Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
commit
47b62cd836
@ -150,7 +150,6 @@ out_buffer_fail:
|
||||
/* free desc along with its attached buffer */
|
||||
static void hnae_free_desc(struct hnae_ring *ring)
|
||||
{
|
||||
hnae_free_buffers(ring);
|
||||
dma_unmap_single(ring_to_dev(ring), ring->desc_dma_addr,
|
||||
ring->desc_num * sizeof(ring->desc[0]),
|
||||
ring_to_dma_dir(ring));
|
||||
@ -183,6 +182,9 @@ static int hnae_alloc_desc(struct hnae_ring *ring)
|
||||
/* fini ring, also free the buffer for the ring */
|
||||
static void hnae_fini_ring(struct hnae_ring *ring)
|
||||
{
|
||||
if (is_rx_ring(ring))
|
||||
hnae_free_buffers(ring);
|
||||
|
||||
hnae_free_desc(ring);
|
||||
kfree(ring->desc_cb);
|
||||
ring->desc_cb = NULL;
|
||||
|
@ -357,7 +357,7 @@ struct hnae_buf_ops {
|
||||
};
|
||||
|
||||
struct hnae_queue {
|
||||
void __iomem *io_base;
|
||||
u8 __iomem *io_base;
|
||||
phys_addr_t phy_base;
|
||||
struct hnae_ae_dev *dev; /* the device who use this queue */
|
||||
struct hnae_ring rx_ring ____cacheline_internodealigned_in_smp;
|
||||
|
@ -370,7 +370,7 @@ int hns_mac_clr_multicast(struct hns_mac_cb *mac_cb, int vfn)
|
||||
static void hns_mac_param_get(struct mac_params *param,
|
||||
struct hns_mac_cb *mac_cb)
|
||||
{
|
||||
param->vaddr = (void *)mac_cb->vaddr;
|
||||
param->vaddr = mac_cb->vaddr;
|
||||
param->mac_mode = hns_get_enet_interface(mac_cb);
|
||||
ether_addr_copy(param->addr, mac_cb->addr_entry_idx[0].addr);
|
||||
param->mac_id = mac_cb->mac_id;
|
||||
|
@ -187,7 +187,7 @@ struct mac_statistics {
|
||||
/*mac para struct ,mac get param from nic or dsaf when initialize*/
|
||||
struct mac_params {
|
||||
char addr[ETH_ALEN];
|
||||
void *vaddr; /*virtual address*/
|
||||
u8 __iomem *vaddr; /*virtual address*/
|
||||
struct device *dev;
|
||||
u8 mac_id;
|
||||
/**< Ethernet operation mode (MAC-PHY interface and speed) */
|
||||
@ -402,7 +402,7 @@ struct mac_driver {
|
||||
enum mac_mode mac_mode;
|
||||
u8 mac_id;
|
||||
struct hns_mac_cb *mac_cb;
|
||||
void __iomem *io_base;
|
||||
u8 __iomem *io_base;
|
||||
unsigned int mac_en_flg;/*you'd better don't enable mac twice*/
|
||||
unsigned int virt_dev_num;
|
||||
struct device *dev;
|
||||
|
@ -1602,8 +1602,6 @@ static void hns_dsaf_set_mac_key(
|
||||
DSAF_TBL_TCAM_KEY_VLAN_S, vlan_id);
|
||||
dsaf_set_field(mac_key->low.bits.port_vlan, DSAF_TBL_TCAM_KEY_PORT_M,
|
||||
DSAF_TBL_TCAM_KEY_PORT_S, port);
|
||||
|
||||
mac_key->low.bits.port_vlan = le16_to_cpu(mac_key->low.bits.port_vlan);
|
||||
}
|
||||
|
||||
/**
|
||||
@ -1663,8 +1661,8 @@ int hns_dsaf_set_mac_uc_entry(
|
||||
/* default config dvc to 0 */
|
||||
mac_data.tbl_ucast_dvc = 0;
|
||||
mac_data.tbl_ucast_out_port = mac_entry->port_num;
|
||||
tcam_data.tbl_tcam_data_high = cpu_to_le32(mac_key.high.val);
|
||||
tcam_data.tbl_tcam_data_low = cpu_to_le32(mac_key.low.val);
|
||||
tcam_data.tbl_tcam_data_high = mac_key.high.val;
|
||||
tcam_data.tbl_tcam_data_low = mac_key.low.val;
|
||||
|
||||
hns_dsaf_tcam_uc_cfg(dsaf_dev, entry_index, &tcam_data, &mac_data);
|
||||
|
||||
@ -1786,9 +1784,6 @@ int hns_dsaf_add_mac_mc_port(struct dsaf_device *dsaf_dev,
|
||||
0xff,
|
||||
mc_mask);
|
||||
|
||||
mask_key.high.val = le32_to_cpu(mask_key.high.val);
|
||||
mask_key.low.val = le32_to_cpu(mask_key.low.val);
|
||||
|
||||
pmask_key = (struct dsaf_tbl_tcam_data *)(&mask_key);
|
||||
}
|
||||
|
||||
@ -1840,8 +1835,8 @@ int hns_dsaf_add_mac_mc_port(struct dsaf_device *dsaf_dev,
|
||||
dsaf_dev->ae_dev.name, mac_key.high.val,
|
||||
mac_key.low.val, entry_index);
|
||||
|
||||
tcam_data.tbl_tcam_data_high = cpu_to_le32(mac_key.high.val);
|
||||
tcam_data.tbl_tcam_data_low = cpu_to_le32(mac_key.low.val);
|
||||
tcam_data.tbl_tcam_data_high = mac_key.high.val;
|
||||
tcam_data.tbl_tcam_data_low = mac_key.low.val;
|
||||
|
||||
/* config mc entry with mask */
|
||||
hns_dsaf_tcam_mc_cfg(dsaf_dev, entry_index, &tcam_data,
|
||||
@ -1956,9 +1951,6 @@ int hns_dsaf_del_mac_mc_port(struct dsaf_device *dsaf_dev,
|
||||
/* config key mask */
|
||||
hns_dsaf_set_mac_key(dsaf_dev, &mask_key, 0x00, 0xff, mc_mask);
|
||||
|
||||
mask_key.high.val = le32_to_cpu(mask_key.high.val);
|
||||
mask_key.low.val = le32_to_cpu(mask_key.low.val);
|
||||
|
||||
pmask_key = (struct dsaf_tbl_tcam_data *)(&mask_key);
|
||||
}
|
||||
|
||||
@ -2012,8 +2004,8 @@ int hns_dsaf_del_mac_mc_port(struct dsaf_device *dsaf_dev,
|
||||
soft_mac_entry += entry_index;
|
||||
soft_mac_entry->index = DSAF_INVALID_ENTRY_IDX;
|
||||
} else { /* not zero, just del port, update */
|
||||
tcam_data.tbl_tcam_data_high = cpu_to_le32(mac_key.high.val);
|
||||
tcam_data.tbl_tcam_data_low = cpu_to_le32(mac_key.low.val);
|
||||
tcam_data.tbl_tcam_data_high = mac_key.high.val;
|
||||
tcam_data.tbl_tcam_data_low = mac_key.low.val;
|
||||
|
||||
hns_dsaf_tcam_mc_cfg(dsaf_dev, entry_index,
|
||||
&tcam_data,
|
||||
@ -2750,6 +2742,17 @@ int hns_dsaf_get_regs_count(void)
|
||||
return DSAF_DUMP_REGS_NUM;
|
||||
}
|
||||
|
||||
static int hns_dsaf_get_port_id(u8 port)
|
||||
{
|
||||
if (port < DSAF_SERVICE_NW_NUM)
|
||||
return port;
|
||||
|
||||
if (port >= DSAF_BASE_INNER_PORT_NUM)
|
||||
return port - DSAF_BASE_INNER_PORT_NUM + DSAF_SERVICE_NW_NUM;
|
||||
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
static void set_promisc_tcam_enable(struct dsaf_device *dsaf_dev, u32 port)
|
||||
{
|
||||
struct dsaf_tbl_tcam_ucast_cfg tbl_tcam_ucast = {0, 1, 0, 0, 0x80};
|
||||
@ -2815,23 +2818,33 @@ static void set_promisc_tcam_enable(struct dsaf_device *dsaf_dev, u32 port)
|
||||
memset(&temp_key, 0x0, sizeof(temp_key));
|
||||
mask_entry.addr[0] = 0x01;
|
||||
hns_dsaf_set_mac_key(dsaf_dev, &mask_key, mask_entry.in_vlan_id,
|
||||
port, mask_entry.addr);
|
||||
0xf, mask_entry.addr);
|
||||
tbl_tcam_mcast.tbl_mcast_item_vld = 1;
|
||||
tbl_tcam_mcast.tbl_mcast_old_en = 0;
|
||||
|
||||
if (port < DSAF_SERVICE_NW_NUM) {
|
||||
mskid = port;
|
||||
} else if (port >= DSAF_BASE_INNER_PORT_NUM) {
|
||||
mskid = port - DSAF_BASE_INNER_PORT_NUM + DSAF_SERVICE_NW_NUM;
|
||||
} else {
|
||||
/* set MAC port to handle multicast */
|
||||
mskid = hns_dsaf_get_port_id(port);
|
||||
if (mskid == -EINVAL) {
|
||||
dev_err(dsaf_dev->dev, "%s,pnum(%d)error,key(%#x:%#x)\n",
|
||||
dsaf_dev->ae_dev.name, port,
|
||||
mask_key.high.val, mask_key.low.val);
|
||||
return;
|
||||
}
|
||||
|
||||
dsaf_set_bit(tbl_tcam_mcast.tbl_mcast_port_msk[mskid / 32],
|
||||
mskid % 32, 1);
|
||||
|
||||
/* set pool bit map to handle multicast */
|
||||
mskid = hns_dsaf_get_port_id(port_num);
|
||||
if (mskid == -EINVAL) {
|
||||
dev_err(dsaf_dev->dev,
|
||||
"%s, pool bit map pnum(%d)error,key(%#x:%#x)\n",
|
||||
dsaf_dev->ae_dev.name, port_num,
|
||||
mask_key.high.val, mask_key.low.val);
|
||||
return;
|
||||
}
|
||||
dsaf_set_bit(tbl_tcam_mcast.tbl_mcast_port_msk[mskid / 32],
|
||||
mskid % 32, 1);
|
||||
|
||||
memcpy(&temp_key, &mask_key, sizeof(mask_key));
|
||||
hns_dsaf_tcam_mc_cfg_vague(dsaf_dev, entry_index, &tbl_tcam_data_mc,
|
||||
(struct dsaf_tbl_tcam_data *)(&mask_key),
|
||||
|
@ -467,4 +467,6 @@ int hns_dsaf_clr_mac_mc_port(struct dsaf_device *dsaf_dev,
|
||||
u8 mac_id, u8 port_num);
|
||||
int hns_dsaf_wait_pkt_clean(struct dsaf_device *dsaf_dev, int port);
|
||||
|
||||
int hns_dsaf_roce_reset(struct fwnode_handle *dsaf_fwnode, bool dereset);
|
||||
|
||||
#endif /* __HNS_DSAF_MAIN_H__ */
|
||||
|
@ -670,7 +670,7 @@ static int hns_mac_config_sds_loopback(struct hns_mac_cb *mac_cb, bool en)
|
||||
dsaf_set_field(origin, 1ull << 10, 10, en);
|
||||
dsaf_write_syscon(mac_cb->serdes_ctrl, reg_offset, origin);
|
||||
} else {
|
||||
u8 *base_addr = (u8 *)mac_cb->serdes_vaddr +
|
||||
u8 __iomem *base_addr = mac_cb->serdes_vaddr +
|
||||
(mac_cb->mac_id <= 3 ? 0x00280000 : 0x00200000);
|
||||
dsaf_set_reg_field(base_addr, reg_offset, 1ull << 10, 10, en);
|
||||
}
|
||||
|
@ -61,7 +61,7 @@ void hns_ppe_set_indir_table(struct hns_ppe_cb *ppe_cb,
|
||||
}
|
||||
}
|
||||
|
||||
static void __iomem *
|
||||
static u8 __iomem *
|
||||
hns_ppe_common_get_ioaddr(struct ppe_common_cb *ppe_common)
|
||||
{
|
||||
return ppe_common->dsaf_dev->ppe_base + PPE_COMMON_REG_OFFSET;
|
||||
@ -111,8 +111,8 @@ hns_ppe_common_free_cfg(struct dsaf_device *dsaf_dev, u32 comm_index)
|
||||
dsaf_dev->ppe_common[comm_index] = NULL;
|
||||
}
|
||||
|
||||
static void __iomem *hns_ppe_get_iobase(struct ppe_common_cb *ppe_common,
|
||||
int ppe_idx)
|
||||
static u8 __iomem *hns_ppe_get_iobase(struct ppe_common_cb *ppe_common,
|
||||
int ppe_idx)
|
||||
{
|
||||
return ppe_common->dsaf_dev->ppe_base + ppe_idx * PPE_REG_OFFSET;
|
||||
}
|
||||
|
@ -80,7 +80,7 @@ struct hns_ppe_cb {
|
||||
struct hns_ppe_hw_stats hw_stats;
|
||||
|
||||
u8 index; /* index in a ppe common device */
|
||||
void __iomem *io_base;
|
||||
u8 __iomem *io_base;
|
||||
int virq;
|
||||
u32 rss_indir_table[HNS_PPEV2_RSS_IND_TBL_SIZE]; /*shadow indir tab */
|
||||
u32 rss_key[HNS_PPEV2_RSS_KEY_NUM]; /* rss hash key */
|
||||
@ -89,7 +89,7 @@ struct hns_ppe_cb {
|
||||
struct ppe_common_cb {
|
||||
struct device *dev;
|
||||
struct dsaf_device *dsaf_dev;
|
||||
void __iomem *io_base;
|
||||
u8 __iomem *io_base;
|
||||
|
||||
enum ppe_common_mode ppe_mode;
|
||||
|
||||
|
@ -458,7 +458,7 @@ static void hns_rcb_ring_get_cfg(struct hnae_queue *q, int ring_type)
|
||||
mdnum_ppkt = HNS_RCB_RING_MAX_BD_PER_PKT;
|
||||
} else {
|
||||
ring = &q->tx_ring;
|
||||
ring->io_base = (u8 __iomem *)ring_pair_cb->q.io_base +
|
||||
ring->io_base = ring_pair_cb->q.io_base +
|
||||
HNS_RCB_TX_REG_OFFSET;
|
||||
irq_idx = HNS_RCB_IRQ_IDX_TX;
|
||||
mdnum_ppkt = is_ver1 ? HNS_RCB_RING_MAX_TXBD_PER_PKT :
|
||||
@ -764,7 +764,7 @@ static int hns_rcb_get_ring_num(struct dsaf_device *dsaf_dev)
|
||||
}
|
||||
}
|
||||
|
||||
static void __iomem *hns_rcb_common_get_vaddr(struct rcb_common_cb *rcb_common)
|
||||
static u8 __iomem *hns_rcb_common_get_vaddr(struct rcb_common_cb *rcb_common)
|
||||
{
|
||||
struct dsaf_device *dsaf_dev = rcb_common->dsaf_dev;
|
||||
|
||||
|
@ -1018,7 +1018,7 @@
|
||||
#define XGMAC_PAUSE_CTL_RSP_MODE_B 2
|
||||
#define XGMAC_PAUSE_CTL_TX_XOFF_B 3
|
||||
|
||||
static inline void dsaf_write_reg(void __iomem *base, u32 reg, u32 value)
|
||||
static inline void dsaf_write_reg(u8 __iomem *base, u32 reg, u32 value)
|
||||
{
|
||||
writel(value, base + reg);
|
||||
}
|
||||
@ -1053,7 +1053,7 @@ static inline int dsaf_read_syscon(struct regmap *base, u32 reg, u32 *val)
|
||||
#define dsaf_set_bit(origin, shift, val) \
|
||||
dsaf_set_field((origin), (1ull << (shift)), (shift), (val))
|
||||
|
||||
static inline void dsaf_set_reg_field(void __iomem *base, u32 reg, u32 mask,
|
||||
static inline void dsaf_set_reg_field(u8 __iomem *base, u32 reg, u32 mask,
|
||||
u32 shift, u32 val)
|
||||
{
|
||||
u32 origin = dsaf_read_reg(base, reg);
|
||||
@ -1073,7 +1073,7 @@ static inline void dsaf_set_reg_field(void __iomem *base, u32 reg, u32 mask,
|
||||
#define dsaf_get_bit(origin, shift) \
|
||||
dsaf_get_field((origin), (1ull << (shift)), (shift))
|
||||
|
||||
static inline u32 dsaf_get_reg_field(void __iomem *base, u32 reg, u32 mask,
|
||||
static inline u32 dsaf_get_reg_field(u8 __iomem *base, u32 reg, u32 mask,
|
||||
u32 shift)
|
||||
{
|
||||
u32 origin;
|
||||
@ -1089,11 +1089,11 @@ static inline u32 dsaf_get_reg_field(void __iomem *base, u32 reg, u32 mask,
|
||||
dsaf_get_reg_field((dev)->io_base, (reg), (1ull << (bit)), (bit))
|
||||
|
||||
#define dsaf_write_b(addr, data)\
|
||||
writeb((data), (__iomem unsigned char *)(addr))
|
||||
writeb((data), (__iomem u8 *)(addr))
|
||||
#define dsaf_read_b(addr)\
|
||||
readb((__iomem unsigned char *)(addr))
|
||||
readb((__iomem u8 *)(addr))
|
||||
|
||||
#define hns_mac_reg_read64(drv, offset) \
|
||||
readq((__iomem void *)(((u8 *)(drv)->io_base + 0xc00 + (offset))))
|
||||
readq((__iomem void *)(((drv)->io_base + 0xc00 + (offset))))
|
||||
|
||||
#endif /* _DSAF_REG_H */
|
||||
|
@ -129,7 +129,7 @@ static void hns_xgmac_lf_rf_control_init(struct mac_driver *mac_drv)
|
||||
dsaf_set_bit(val, XGMAC_UNIDIR_EN_B, 0);
|
||||
dsaf_set_bit(val, XGMAC_RF_TX_EN_B, 1);
|
||||
dsaf_set_field(val, XGMAC_LF_RF_INSERT_M, XGMAC_LF_RF_INSERT_S, 0);
|
||||
dsaf_write_reg(mac_drv, XGMAC_MAC_TX_LF_RF_CONTROL_REG, val);
|
||||
dsaf_write_dev(mac_drv, XGMAC_MAC_TX_LF_RF_CONTROL_REG, val);
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -29,9 +29,6 @@
|
||||
|
||||
#define SERVICE_TIMER_HZ (1 * HZ)
|
||||
|
||||
#define NIC_TX_CLEAN_MAX_NUM 256
|
||||
#define NIC_RX_CLEAN_MAX_NUM 64
|
||||
|
||||
#define RCB_IRQ_NOT_INITED 0
|
||||
#define RCB_IRQ_INITED 1
|
||||
#define HNS_BUFFER_SIZE_2048 2048
|
||||
@ -376,8 +373,6 @@ netdev_tx_t hns_nic_net_xmit_hw(struct net_device *ndev,
|
||||
wmb(); /* commit all data before submit */
|
||||
assert(skb->queue_mapping < priv->ae_handle->q_num);
|
||||
hnae_queue_xmit(priv->ae_handle->qs[skb->queue_mapping], buf_num);
|
||||
ring->stats.tx_pkts++;
|
||||
ring->stats.tx_bytes += skb->len;
|
||||
|
||||
return NETDEV_TX_OK;
|
||||
|
||||
@ -999,6 +994,9 @@ static int hns_nic_tx_poll_one(struct hns_nic_ring_data *ring_data,
|
||||
/* issue prefetch for next Tx descriptor */
|
||||
prefetch(&ring->desc_cb[ring->next_to_clean]);
|
||||
}
|
||||
/* update tx ring statistics. */
|
||||
ring->stats.tx_pkts += pkts;
|
||||
ring->stats.tx_bytes += bytes;
|
||||
|
||||
NETIF_TX_UNLOCK(ring);
|
||||
|
||||
@ -2152,7 +2150,7 @@ static int hns_nic_init_ring_data(struct hns_nic_priv *priv)
|
||||
hns_nic_tx_fini_pro_v2;
|
||||
|
||||
netif_napi_add(priv->netdev, &rd->napi,
|
||||
hns_nic_common_poll, NIC_TX_CLEAN_MAX_NUM);
|
||||
hns_nic_common_poll, NAPI_POLL_WEIGHT);
|
||||
rd->ring->irq_init_flag = RCB_IRQ_NOT_INITED;
|
||||
}
|
||||
for (i = h->q_num; i < h->q_num * 2; i++) {
|
||||
@ -2165,7 +2163,7 @@ static int hns_nic_init_ring_data(struct hns_nic_priv *priv)
|
||||
hns_nic_rx_fini_pro_v2;
|
||||
|
||||
netif_napi_add(priv->netdev, &rd->napi,
|
||||
hns_nic_common_poll, NIC_RX_CLEAN_MAX_NUM);
|
||||
hns_nic_common_poll, NAPI_POLL_WEIGHT);
|
||||
rd->ring->irq_init_flag = RCB_IRQ_NOT_INITED;
|
||||
}
|
||||
|
||||
|
@ -39,7 +39,7 @@ struct hns_mdio_sc_reg {
|
||||
};
|
||||
|
||||
struct hns_mdio_device {
|
||||
void *vbase; /* mdio reg base address */
|
||||
u8 __iomem *vbase; /* mdio reg base address */
|
||||
struct regmap *subctrl_vbase;
|
||||
struct hns_mdio_sc_reg sc_reg;
|
||||
};
|
||||
@ -96,21 +96,17 @@ enum mdio_c45_op_seq {
|
||||
#define MDIO_SC_CLK_ST 0x531C
|
||||
#define MDIO_SC_RESET_ST 0x5A1C
|
||||
|
||||
static void mdio_write_reg(void *base, u32 reg, u32 value)
|
||||
static void mdio_write_reg(u8 __iomem *base, u32 reg, u32 value)
|
||||
{
|
||||
u8 __iomem *reg_addr = (u8 __iomem *)base;
|
||||
|
||||
writel_relaxed(value, reg_addr + reg);
|
||||
writel_relaxed(value, base + reg);
|
||||
}
|
||||
|
||||
#define MDIO_WRITE_REG(a, reg, value) \
|
||||
mdio_write_reg((a)->vbase, (reg), (value))
|
||||
|
||||
static u32 mdio_read_reg(void *base, u32 reg)
|
||||
static u32 mdio_read_reg(u8 __iomem *base, u32 reg)
|
||||
{
|
||||
u8 __iomem *reg_addr = (u8 __iomem *)base;
|
||||
|
||||
return readl_relaxed(reg_addr + reg);
|
||||
return readl_relaxed(base + reg);
|
||||
}
|
||||
|
||||
#define mdio_set_field(origin, mask, shift, val) \
|
||||
@ -121,7 +117,7 @@ static u32 mdio_read_reg(void *base, u32 reg)
|
||||
|
||||
#define mdio_get_field(origin, mask, shift) (((origin) >> (shift)) & (mask))
|
||||
|
||||
static void mdio_set_reg_field(void *base, u32 reg, u32 mask, u32 shift,
|
||||
static void mdio_set_reg_field(u8 __iomem *base, u32 reg, u32 mask, u32 shift,
|
||||
u32 val)
|
||||
{
|
||||
u32 origin = mdio_read_reg(base, reg);
|
||||
@ -133,7 +129,7 @@ static void mdio_set_reg_field(void *base, u32 reg, u32 mask, u32 shift,
|
||||
#define MDIO_SET_REG_FIELD(dev, reg, mask, shift, val) \
|
||||
mdio_set_reg_field((dev)->vbase, (reg), (mask), (shift), (val))
|
||||
|
||||
static u32 mdio_get_reg_field(void *base, u32 reg, u32 mask, u32 shift)
|
||||
static u32 mdio_get_reg_field(u8 __iomem *base, u32 reg, u32 mask, u32 shift)
|
||||
{
|
||||
u32 origin;
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user