[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[no subject]



On Apr 14, 2005, at 4:31 PM, Zhao-Yang Dong wrote:

In an OSPF link state database, each LSA is supposed to have a unique Link State ID (LSID). Sometimes this is not true, especially in multiple vendor devices environment.

The LSA ID is qualified by the originating system, so it is entirely reasonable to have multiple LSAs with the same LSA ID but different router IDs.


What is *not* allowed is to have multiple LSAs with the same LSA ID originated by the same system. This cannot happen according to the rules, and they will not be propagated if they were, also according to the rules. Whether there are multiple vendors has no impact on this.

When originating summary and/or AS-external LSAs, how to assign unique LSID for a network number who has multiple (different length of) masks is described in RFC 2328 appendix E. However, I did not see any discussion in RFC 2328 nor this archive how to handle/process summary and/or AS-external LSAs received from other routers with the same LSID but different length of masks.

A router can do anything it wants to guarantee LSA ID uniqueness on the LSAs it generates; appendix E is one way (though there are ways that will go further before they fail than the one outlined there.) Note that RFC2328 also refers to appendix E for Summary LSAs as well; see appendix A.4.5.


It is not the job of a receiving router to deal with this case, because it cannot happen (according to the rules) and it is indistinguishable from the case where somebody changes the netmask on a redistributed static route.


 

According RFC 2328, a LSA is identified by LS type, LSID and advertising router. To determine which LSA of two LSA instances is newer, LS sequence number, checksum and age are compared. Network mask does not seem play any role while processing the received LSAs.

It does not, nor should it. An LSA is identified by originating router ID, LSA type, and LSA ID. Period. Any router that attempts to generate two different LSAs with the same ID is broken.



 

My question is, for example, if I received a LSA with LSID=A.B.C.D and 24 bits mask and installed in my database, and later I received the same LSA (i.e. same LS type, LSID and advertising router) but with 28 bits mask. If the second LSA has the larger sequence number, should I replace my database copy with the second LSA?

That's what the rules say. This is why a broken system generating multiple LSAs with the same ID will not get far; only one of them (with the higher sequence number) will get acknowledged, and the other will be retransmitted ad infinitum.



The problem is that the Founding Fathers that spec'ed OSPF screwed up and overloaded the LSA ID with routing information because they were afraid of spending another four bytes per LSA. One could blame it on classful networking, but in a purely classful environment you wouldn't even need masks. Basically it was yet another mistaken optimization.


It's impossible to guarantee uniqueness; if you try hard enough you can generate a situation that no algorithm can work around (because the LSA ID space is by definition sparse due to the masking requirement, but the space of possible external routes is dense.) As a practical matter, however, it's very unlikely that there will be an LSA ID collision if a reasonably good algorithm is chosen.


BTW, the cisco IOS implementation appears to attempt to detect this case, though it's not clear why. I assume it complains if it sees the same LSA ID and a different netmask, but that's a perfectly legal situation. If anybody from cisco can explain this, I'm quite curious.


--Dave



 

Thanks,

Zhaoyang