net: hns3: fix hclge_dbg_dump_tm_pg() stack usage
This function copies strings around between multiple buffers including a large on-stack array that causes a build warning on 32-bit systems: drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_debugfs.c: In function 'hclge_dbg_dump_tm_pg': drivers/net/ethernet/hisilicon/hns3/hns3pf/hclge_debugfs.c:782:1: error: the frame size of 1424 bytes is larger than 1400 bytes [-Werror=frame-larger-than=] The function can probably be cleaned up a lot, to go back to printing directly into the output buffer, but dynamically allocating the structure is a simpler workaround for now. Fixes: 04d96139ddb3 ("net: hns3: refine function hclge_dbg_dump_tm_pri()") Signed-off-by: Arnd Bergmann <arnd@arndb.de> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
c6995117b6
commit
c894b51e2a
@ -719,9 +719,9 @@ static void hclge_dbg_fill_shaper_content(struct hclge_tm_shaper_para *para,
|
|||||||
sprintf(result[(*index)++], "%6u", para->rate);
|
sprintf(result[(*index)++], "%6u", para->rate);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int hclge_dbg_dump_tm_pg(struct hclge_dev *hdev, char *buf, int len)
|
static int __hclge_dbg_dump_tm_pg(struct hclge_dev *hdev, char *data_str,
|
||||||
|
char *buf, int len)
|
||||||
{
|
{
|
||||||
char data_str[ARRAY_SIZE(tm_pg_items)][HCLGE_DBG_DATA_STR_LEN];
|
|
||||||
struct hclge_tm_shaper_para c_shaper_para, p_shaper_para;
|
struct hclge_tm_shaper_para c_shaper_para, p_shaper_para;
|
||||||
char *result[ARRAY_SIZE(tm_pg_items)], *sch_mode_str;
|
char *result[ARRAY_SIZE(tm_pg_items)], *sch_mode_str;
|
||||||
u8 pg_id, sch_mode, weight, pri_bit_map, i, j;
|
u8 pg_id, sch_mode, weight, pri_bit_map, i, j;
|
||||||
@ -729,8 +729,10 @@ static int hclge_dbg_dump_tm_pg(struct hclge_dev *hdev, char *buf, int len)
|
|||||||
int pos = 0;
|
int pos = 0;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
for (i = 0; i < ARRAY_SIZE(tm_pg_items); i++)
|
for (i = 0; i < ARRAY_SIZE(tm_pg_items); i++) {
|
||||||
result[i] = &data_str[i][0];
|
result[i] = data_str;
|
||||||
|
data_str += HCLGE_DBG_DATA_STR_LEN;
|
||||||
|
}
|
||||||
|
|
||||||
hclge_dbg_fill_content(content, sizeof(content), tm_pg_items,
|
hclge_dbg_fill_content(content, sizeof(content), tm_pg_items,
|
||||||
NULL, ARRAY_SIZE(tm_pg_items));
|
NULL, ARRAY_SIZE(tm_pg_items));
|
||||||
@ -781,6 +783,24 @@ static int hclge_dbg_dump_tm_pg(struct hclge_dev *hdev, char *buf, int len)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int hclge_dbg_dump_tm_pg(struct hclge_dev *hdev, char *buf, int len)
|
||||||
|
{
|
||||||
|
char *data_str;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
data_str = kcalloc(ARRAY_SIZE(tm_pg_items),
|
||||||
|
HCLGE_DBG_DATA_STR_LEN, GFP_KERNEL);
|
||||||
|
|
||||||
|
if (!data_str)
|
||||||
|
return -ENOMEM;
|
||||||
|
|
||||||
|
ret = __hclge_dbg_dump_tm_pg(hdev, data_str, buf, len);
|
||||||
|
|
||||||
|
kfree(data_str);
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
static int hclge_dbg_dump_tm_port(struct hclge_dev *hdev, char *buf, int len)
|
static int hclge_dbg_dump_tm_port(struct hclge_dev *hdev, char *buf, int len)
|
||||||
{
|
{
|
||||||
struct hclge_tm_shaper_para shaper_para;
|
struct hclge_tm_shaper_para shaper_para;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user