net: ethernet: mtk_eth_soc: fix usage of foe_entry_size
authorDaniel Golle <daniel@makrotopia.org>
Sun, 25 Sep 2022 14:48:43 +0000 (15:48 +0100)
committerJakub Kicinski <kuba@kernel.org>
Tue, 27 Sep 2022 14:43:54 +0000 (07:43 -0700)
As sizeof(hwe->data) can now longer be used as the actual size depends
on foe_entry_size, in commit 9d8cb4c096ab02
("net: ethernet: mtk_eth_soc: add foe_entry_size to mtk_eth_soc") the
use of sizeof(hwe->data) is hence replaced.

However, replacing it with ppe->eth->soc->foe_entry_size is wrong as
foe_entry_size represents the size of the whole descriptor and not just
the 'data' field.

Fix this by subtracing the size of the only other field in the struct
'ib1', so we actually end up with the correct size to be copied to the
data field.

Reported-by: Chen Minqiang <ptpt52@gmail.com>
Fixes: 9d8cb4c096ab02 ("net: ethernet: mtk_eth_soc: add foe_entry_size to mtk_eth_soc")
Signed-off-by: Daniel Golle <daniel@makrotopia.org>
Acked-by: Lorenzo Bianconi <lorenzo@kernel.org>
Link: https://lore.kernel.org/r/YzBqPIgQR2gLrPoK@makrotopia.org
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
drivers/net/ethernet/mediatek/mtk_ppe.c

index 4ea2b342f252acd8b13c00bea80f9c5296b89d12..887f430734f7479d37e24f6161142fe10cf717d5 100644 (file)
@@ -547,7 +547,7 @@ __mtk_foe_entry_commit(struct mtk_ppe *ppe, struct mtk_foe_entry *entry,
        }
 
        hwe = mtk_foe_get_entry(ppe, hash);
-       memcpy(&hwe->data, &entry->data, eth->soc->foe_entry_size);
+       memcpy(&hwe->data, &entry->data, eth->soc->foe_entry_size - sizeof(hwe->ib1));
        wmb();
        hwe->ib1 = entry->ib1;