mirror of
https://github.com/torvalds/linux.git
synced 2026-05-27 16:44:58 +02:00
net: hibmcge: fix the division by zero issue
When the network port is down, the queue is released, and ring->len is 0.
In debugfs, hbg_get_queue_used_num() will be called,
which may lead to a division by zero issue.
This patch adds a check, if ring->len is 0,
hbg_get_queue_used_num() directly returns 0.
Fixes: 40735e7543 ("net: hibmcge: Implement .ndo_start_xmit function")
Signed-off-by: Jijie Shao <shaojijie@huawei.com>
Reviewed-by: Simon Horman <horms@kernel.org>
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
This commit is contained in:
parent
c875503a9b
commit
7004b26f0b
|
|
@ -29,7 +29,12 @@ static inline bool hbg_fifo_is_full(struct hbg_priv *priv, enum hbg_dir dir)
|
|||
|
||||
static inline u32 hbg_get_queue_used_num(struct hbg_ring *ring)
|
||||
{
|
||||
return (ring->ntu + ring->len - ring->ntc) % ring->len;
|
||||
u32 len = READ_ONCE(ring->len);
|
||||
|
||||
if (!len)
|
||||
return 0;
|
||||
|
||||
return (READ_ONCE(ring->ntu) + len - READ_ONCE(ring->ntc)) % len;
|
||||
}
|
||||
|
||||
netdev_tx_t hbg_net_start_xmit(struct sk_buff *skb, struct net_device *netdev);
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user