Longest Prefix Matching in Routers
What is Forwarding?
Forwarding is moving incoming packets to appropriate interface. Routers use forwarding table to decide which incoming packet should be forwarded to which next hop.
What is IP prefix?
IP prefix is a prefix of IP address. All computers on one network have same IP prefix. For example, in 220.127.116.11/18, 18 is length of prefix and prefix is first 18 bits of the address.
How does forwarding work?
Routers basically look at destination address’s IP prefix, searches the forwarding table for a match and forwards the packet to corresponding next hop in forwarding table.
What happens if the prefixes overlap?
Since prefixes might overlap (this is possible as classless addressing is used everywhere), an incoming IP’s prefix may match multiple IP entries in table.
For example, consider the below forwarding table
In above table, addresses from 18.104.22.168 to 22.214.171.124 overlap, i.e., match with both entries of the table.
To handle above situation, routers use Longest Prefix Matching rule. The rule is to find the entry in table which has the longest prefix matching with incoming packet’s destination IP, and forward the packet to corresponding next hope.
In the above example, all packets in overlapping range (126.96.36.199 to 188.8.131.52) are forwarded to next hop B as B has longer prefix (22 bits).
Example 1: Routers forward a packet using forwarding table entries. The network address of incoming packet may match multiple entries. How routers resolve this?
(A) Forward it the router whose entry matches with the longest prefix of incoming packet
(B) Forward the packet to all routers whose network addresses match.
(C) Discard the packet.
(D) Forward it the router whose entry matches with the longest suffix of incoming packet
Answer: (A) The network addresses of different entries may overlap in forwarding table. Routers forward the incoming packet to the router which hash the longest prefix matching with the incoming packet.
Example 2: Classless Inter-domain Routing (CIDR) receives a packet with address 184.108.40.206. The router’s routing table has the following entries: (GATE CS 2015)
Prefix Output Interface Identifier 220.127.116.11/12 3 18.104.22.168/14 5 22.214.171.124/16 2 126.96.36.199/15 1
The identifier of the output interface on which this packet will be forwarded is ______.
Answer: “1”. We need to first find out matching table entries for incoming packet with address “188.8.131.52”. The address matches with two entries “184.108.40.206/12” and “220.127.116.11/15” (We found this by matching first 12 and 15 bits respectively).
So should the packet go to interface 3 or 1? We use Longest Prefix Matching to decide among two. The most specific of the matching table entries is used as the interface. Since “18.104.22.168/15” is most specific, the packet goes to interface 1.
Consider the following routing table of a router.
Consider the following three IP addresses.
How are the packets with above three destination IP addresses are forwarded?
(A) 1->D, 2->B, 3->B
(B) 1->D, 2->B, 3->D
(C) 1->B, 2->D, 3->D
(D) 1->D, 2->D, 3->D
Answer is: B
Please write comments if you find anything incorrect, or you want to share more information about the topic discussed above
Attention reader! Don’t stop learning now. Get hold of all the important CS Theory concepts for SDE interviews with the CS Theory Course at a student-friendly price and become industry ready.My Personal Notes arrow_drop_up