… updated on Tuesday, August 22, 2023 15:17 UTC
Running OSPF over Unnumbered Ethernet Interfaces
Remember the unnumbered IP interfaces saga? Let’s conclude with the final challenge: can we run link-state routing protocols (OSPF or IS-IS) over unnumbered interfaces?
Quick answer: Sure, just use IPv6.
Cheater! IPv6 doesn’t count. There are no unnumbered interfaces in IPv6 – every interface has at least a link-local address (LLA). Even more, routing protocols are designed to run over LLA addresses, including some EBGP implementations, allowing you to build an LLA-only network (see RFC 7404 for details).
OK, what about IPv4?
TL&DR: It works, but…
As always, let’s start with the fundamentals. Every router running a routing protocol needs to:
- Advertise itself (unless you’re using static neighbor configuration)
- Find its neighbors
- Build some sort of relationship with the neighbors (adjacency)
- Encode its local topology in some data structure
- Exchange data with its neighbors
- Select the best routes according to its view of the world
Can OSPF do all that over unnumbered interfaces? We’ll use the following lab topology to test it out (all interfaces are unnumbered):

Lab topology
Hello messages: no problem. Use the IP address assigned to the interface (usually the loopback address) as the source IP. The destination IP is a multicast address anyway.
Finding the neighbors and building adjacency: getting trickier. While the standard never spells it out (or I couldn’t find it), I have an impression that the underlying assumption is that all OSPF interfaces apart from P2P links have an IP subnet associated with them. I found one of the closest matches in Section 8.2 (receiving protocol packets):
If the receiving interface connects to a broadcast network, Point-to-MultiPoint network, or NBMA network, the sender is identified by the IP source address in the packet’s IP header. If the receiving interface connects to a point-to-point network or a virtual link, the sender is identified by the Router ID (source router) found in the packet’s OSPF header.
Next, there’s the check of the network mask advertised in the OSPF Hello packet. The network mask might match (loopback interfaces usually use /32 prefixes), but we have another get-out-of-jail card on P2P links. Section 10.5 of RFC 2328 says
However, there is one exception to the above rule: on point-to-point networks and virtual links, the Network Mask in the received Hello Packet should be ignored.
To recap: while the OSPF adjacency works perfectly fine on unnumbered point-to-point links, it would be an exercise in futility to try to make it work on point-to-multipoint unnumbered interfaces. Cisco IOS XE neatly solves the conundrum by not sending Hello packets out of unnumbered interfaces that are not configured as point-to-point OSPF networks.
Exchanging information: trivial. OSPF routers use AllSPFRouters (224.0.0.5) as the destination IP address on point-to-point links, and multicast packets get delivered to whoever listens to that multicast IP address.
That also explains why OSPF runs flawlessly over unnumbered P2P links but fails to work on unnumbered multi-access links1
Encoding local topology: trivial. Add a router link to type-1 LSA without a corresponding stub link you’d get on a numbered link. Here’s a type-1 LSA from a router with an unnumbered interface:
r1#show ip ospf data router 10.0.0.1
            OSPF Router with ID (10.0.0.1) (Process ID 1)
		Router Link States (Area 0.0.0.0)
  LS age: 420
  Options: (No TOS-capability, DC)
  LS Type: Router Links
  Link State ID: 10.0.0.1
  Advertising Router: 10.0.0.1
  LS Seq Number: 8000000A
  Checksum: 0x6E6D
  Length: 48
  Number of Links: 2
    Link connected to: a Stub Network
     (Link ID) Network/subnet number: 10.0.0.1
     (Link Data) Network Mask: 255.255.255.255
      Number of MTID metrics: 0
       TOS 0 Metrics: 1
    Link connected to: another Router (point-to-point)
     (Link ID) Neighboring Router ID: 10.0.0.2
     (Link Data) Router Interface address: 0.0.0.8
      Number of MTID metrics: 0
       TOS 0 Metrics: 10
Selecting the best routes: needs a bit of extra effort. Consider the following route pointing to an unnumbered Ethernet interface:
r1#show ip route 10.0.0.3
Routing entry for 10.0.0.3/32
  Known via "ospf 1", distance 110, metric 21, type intra area
  Last update from 10.0.0.2 on GigabitEthernet2, 01:14:44 ago
  Routing Descriptor Blocks:
  * 10.0.0.2, from 10.0.0.3, 01:14:44 ago, via GigabitEthernet2
      Route metric is 21, traffic share count is 1
The route’s next hop is 10.0.0.2… but how do we know where that is? Well, we have an entry for 10.0.0.2, but it’s not exactly helpful – it says to get there, go there.
r1#show ip route 10.0.0.2
Routing entry for 10.0.0.2/32
  Known via "ospf 1", distance 110, metric 11, type intra area
  Last update from 10.0.0.2 on GigabitEthernet2, 01:16:05 ago
  Routing Descriptor Blocks:
  * 10.0.0.2, from 10.0.0.2, 01:16:05 ago, via GigabitEthernet2
      Route metric is 11, traffic share count is 1
I explained the necessary glue in the Unnumbered Ethernet Interfaces blog post; here’s the TL&DF2 summary:
- The OSPF next hops are supposed to be directly connected.
- What we need is a glue ARP entry for 10.0.0.2 on outgoing internet (GigabitEthernet2)
r1#show arp gigabitEthernet2
Protocol  Address          Age (min)  Hardware Addr   Type   Interface
Internet  10.0.0.1                -   5254.0091.b284  ARPA   GigabitEthernet2
Internet  10.0.0.2               91   5254.00e1.4213  ARPA   GigabitEthernet2
OK, so the theory sounds great. Does any vendor support that? Hint: how do you think I got the printouts?
On a more serious note: I got OSPF running over unnumbered Ethernet interfaces on EOS (requires a nerd knob), IOS, IOS XE, IOS XR, NX-OS, Junos, Cumulus Linux, and FRR. It also works on Nokia SR OS and VyOS (check netlab OSPF support tables for more details).
Finally, you REALLY SHOULD read the Unnumbered Links In OSPF blog post by Daniel Dib.
Next: Running IS-IS over Unnumbered Ethernet Interfaces Continue
Revision History
- 2023-08-22
- Added the exchanging information section after a stimulating discussion with Daniel Dib (thank you!).
 
- Updated the list of platforms known to support OSPF over unnumbered IPv4 interfaces
 
- 
Another niche advantage of IS-IS is that it works over unnumbered multi-access links because it does not use IP to transport routing protocol messages. ↩︎ 
- 
Too Lazy, Didn’t Follow ↩︎ 
hello Ivan,
Interesting post as always.
Just one observation on the mask check thingy as it has always puzzled me.
I came to the conclusion that the reason for checking the mask (carried within the hello messages) to spot possible network mismatches is based on the fact that unicast encapsulation of ospf messages always happens regardless of the OSPF network type (see Direct-ACKs, DBD messages and LSA retransmissions for instance if am not mistaken) and thus ARP is always required but it is not gonna work (this way breaking OSPF) if there's a network (not just a mask) mismatch.
Having said that, there is though one exception which is the P2P OSPF network type as in that case there's no actual need for ARP since what goes into one side comes out at the other side and thus ARP can actually be avoided by simply looking at the SRC IP and MAC of the incoming Hello packets. So, there’s no need to check the mask in this case. Could anyone confirm this conjecture ? Having said that though, the various implementations then kick in and I remember testing p2p numbered ospf interfaces in IOS and JUNOS and finding out that IOS complains (as.. it complains and doesn’t form adjacency) about a netmask mismatch but not about a network mismatch while JUNOS complains about both mismatches (!!). I then tested with JUNOS a p2p unnumbered interface with a network mismatch and it was fine with it which was expected but it makes the previous test results on p2p numbered interfaces mismatches even more obscure.
This should be tested again really - maybe a specific post ?
Cheers/Ciao
Andrea