diff options
author | Hao Chen <chenhao288@hisilicon.com> | 2022-03-26 10:51:01 +0100 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2022-03-26 17:16:49 +0100 |
commit | a89cbb16995bf15582e0d1bdb922ad1a54a2fa8c (patch) | |
tree | 94c8af0bf919c6e07426f5cdf596eec0960bcf0c /drivers/net/ethernet | |
parent | net: hns3: fix ethtool tx copybreak buf size indicating not aligned issue (diff) | |
download | linux-a89cbb16995bf15582e0d1bdb922ad1a54a2fa8c.tar.xz linux-a89cbb16995bf15582e0d1bdb922ad1a54a2fa8c.zip |
net: hns3: add max order judgement for tx spare buffer
Add max order judgement for tx spare buffer to avoid triggering
call trace, print related fail information instead, when user
set tx spare buf size to a large value which causes order
exceeding 10.
Fixes: e445f08af2b1 ("net: hns3: add support to set/get tx copybreak buf size via ethtool for hns3 driver")
Signed-off-by: Hao Chen <chenhao288@hisilicon.com>
Signed-off-by: Guangbin Huang <huangguangbin2@huawei.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/ethernet')
-rw-r--r-- | drivers/net/ethernet/hisilicon/hns3/hns3_enet.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/drivers/net/ethernet/hisilicon/hns3/hns3_enet.c b/drivers/net/ethernet/hisilicon/hns3/hns3_enet.c index 16137238ddbf..530ba8bef503 100644 --- a/drivers/net/ethernet/hisilicon/hns3/hns3_enet.c +++ b/drivers/net/ethernet/hisilicon/hns3/hns3_enet.c @@ -1038,6 +1038,12 @@ static void hns3_init_tx_spare_buffer(struct hns3_enet_ring *ring) return; order = get_order(alloc_size); + if (order >= MAX_ORDER) { + if (net_ratelimit()) + dev_warn(ring_to_dev(ring), "failed to allocate tx spare buffer, exceed to max order\n"); + return; + } + tx_spare = devm_kzalloc(ring_to_dev(ring), sizeof(*tx_spare), GFP_KERNEL); if (!tx_spare) { |