diff options
author | anlan_cs <anlan_cs@tom.com> | 2022-01-12 13:53:25 +0100 |
---|---|---|
committer | anlan_cs <anlan_cs@tom.com> | 2022-01-12 14:08:29 +0100 |
commit | 10f02a2ac936737cb5841cec5e8c063514fd5c70 (patch) | |
tree | bf74af97457a263dcfc64ea6f4a947fcb89432b5 | |
parent | Merge pull request #10317 from ton31337/fix/shutdown_msg (diff) | |
download | frr-10f02a2ac936737cb5841cec5e8c063514fd5c70.tar.xz frr-10f02a2ac936737cb5841cec5e8c063514fd5c70.zip |
lib: fix the right value is returned for fail cases
Currently `bfd_get_peer_info` should return invalid sp->family
and dp->family during fail cases.
Before this fix, in those fail cases `bfd_get_peer_info` maybe
return valid sp->family and dp->family.
This fix ensures all fail cases return invalid sp->family and
dp->family for outside callers.
Signed-off-by: anlan_cs <anlan_cs@tom.com>
-rw-r--r-- | lib/bfd.c | 6 |
1 files changed, 6 insertions, 0 deletions
@@ -171,6 +171,12 @@ static struct interface *bfd_get_peer_info(struct stream *s, struct prefix *dp, return ifp; stream_failure: + /* + * Clean dp and sp because caller + * will immediately check them valid or not + */ + memset(dp, 0, sizeof(*dp)); + memset(sp, 0, sizeof(*sp)); return NULL; } |