Re: [EXT] [bug report] octeontx2-af: cn10k: Uninitialized variables
From: Geethasowjanya Akula
Date: Sat Feb 13 2021 - 22:35:06 EST
Hi Gustavo,
please see inline.
Thank you,
Geetha.
________________________________________
>From: Gustavo A. R. Silva <gustavoars@xxxxxxxxxx>
>Sent: Saturday, February 13, 2021 12:09 AM
>To: Sunil Kovvuri Goutham; Linu Cherian; Geethasowjanya Akula; Jerin Jacob >Kollanukkaran; Hariprasad Kelam; Subbaraya Sundeep Bhatta; David S. Miller; Jakub >Kicinski
>Cc: netdev@xxxxxxxxxxxxxxx; linux-kernel@xxxxxxxxxxxxxxx; Gustavo A. R. Silva
>Subject: [EXT] [bug report] octeontx2-af: cn10k: Uninitialized variables
>External Email
----------------------------------------------------------------------
>Hi,
>Variables cgx_id and lmac_id are being used uninitialized at lines 731
>and 733 in the following function:
>723 static int rvu_cgx_config_intlbk(struct rvu *rvu, u16 pcifunc, bool en)
>724 {
>725 struct mac_ops *mac_ops;
>726 u8 cgx_id, lmac_id;
>727
>728 if (!is_cgx_config_permitted(rvu, pcifunc))
>729 return -EPERM;
>730
>731 mac_ops = get_mac_ops(rvu_cgx_pdata(cgx_id, rvu));
>732
>733 return mac_ops->mac_lmac_intl_lbk(rvu_cgx_pdata(cgx_id, rvu),
>734 lmac_id, en);
735 }
>This bug was introduced by commit 3ad3f8f93c81 ("octeontx2-af: cn10k: MAC internal >loopback support")
>What's the right solution for this?
Thanks Gustavo. Sorry I missed it. Below is the fix.
static int rvu_cgx_config_intlbk(struct rvu *rvu, u16 pcifunc, bool en)
{
+ int pf = rvu_get_pf(pcifunc);
struct mac_ops *mac_ops;
u8 cgx_id, lmac_id;
if (!is_cgx_config_permitted(rvu, pcifunc))
return -EPERM;
+ rvu_get_cgx_lmac_id(rvu->pf2cgxlmac_map[pf], &cgx_id, &lmac_id);
mac_ops = get_mac_ops(rvu_cgx_pdata(cgx_id, rvu));
Thanks
--
Gustavo