net: airoha: Fix an error handling path in airoha_alloc_gdm_port()
authorChristophe JAILLET <christophe.jaillet@wanadoo.fr>
Sat, 24 May 2025 07:29:11 +0000 (09:29 +0200)
committerJakub Kicinski <kuba@kernel.org>
Wed, 28 May 2025 00:20:10 +0000 (17:20 -0700)
commitc59783780c8ad66f6076a9a7c74df3e006e29519
tree3404536fa6b3ef1e5304b9267285f2165fa640bc
parent0795b05a59b1371b18ffbf09d385296b12e9f5d5
net: airoha: Fix an error handling path in airoha_alloc_gdm_port()

If register_netdev() fails, the error handling path of the probe will not
free the memory allocated by the previous airoha_metadata_dst_alloc() call
because port->dev->reg_state will not be NETREG_REGISTERED.

So, an explicit airoha_metadata_dst_free() call is needed in this case to
avoid a memory leak.

Fixes: af3cf757d5c9 ("net: airoha: Move DSA tag in DMA descriptor")
Signed-off-by: Christophe JAILLET <christophe.jaillet@wanadoo.fr>
Acked-by: Lorenzo Bianconi <lorenzo@kernel.org>
Reviewed-by: Simon Horman <horms@kernel.org>
Link: https://patch.msgid.link/1b94b91345017429ed653e2f05d25620dc2823f9.1746715755.git.christophe.jaillet@wanadoo.fr
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
drivers/net/ethernet/airoha/airoha_eth.c