mirror of
https://git.proxmox.com/git/mirror_frr
synced 2025-04-30 15:02:54 +00:00
isisd: send proper LSP after DIS election
After an IS has been elected as the Designated IS for a LAN, it did not refresh the content of the pseudo-node after a new node has been connected to the same LAN. Instead, the periodically reoriginated pseudo-node LSP still contained only those IS neighbors that were already present when the DIS election process was commenced. The fix for the problem schedules an LSP regeneration rather than just reoriginating the same LSP with the old content. Signed-off-by: Fritz Reichmann <fritz@reichmann.nl>
This commit is contained in:
parent
7fd6cd819f
commit
907fd95e50
@ -1187,6 +1187,7 @@ dontcheckadj:
|
|||||||
/* 7.3.15.1 e) 1) LSP newer than the one in db or no LSP in db */
|
/* 7.3.15.1 e) 1) LSP newer than the one in db or no LSP in db */
|
||||||
if ((!lsp || comp == LSP_NEWER))
|
if ((!lsp || comp == LSP_NEWER))
|
||||||
{
|
{
|
||||||
|
int regenerate = (lsp == NULL);
|
||||||
/* i */
|
/* i */
|
||||||
if (lsp)
|
if (lsp)
|
||||||
{
|
{
|
||||||
@ -1232,6 +1233,9 @@ dontcheckadj:
|
|||||||
if (circuit->circ_type != CIRCUIT_T_BROADCAST)
|
if (circuit->circ_type != CIRCUIT_T_BROADCAST)
|
||||||
ISIS_SET_FLAG (lsp->SSNflags, circuit);
|
ISIS_SET_FLAG (lsp->SSNflags, circuit);
|
||||||
/* FIXME: v) */
|
/* FIXME: v) */
|
||||||
|
if (regenerate && circuit->u.bc.is_dr[level - 1]) {
|
||||||
|
lsp_l1_pseudo_generate (circuit);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
/* 7.3.15.1 e) 2) LSP equal to the one in db */
|
/* 7.3.15.1 e) 2) LSP equal to the one in db */
|
||||||
else if (comp == LSP_EQUAL)
|
else if (comp == LSP_EQUAL)
|
||||||
|
Loading…
Reference in New Issue
Block a user