CEF (Cisco Express Forwarding)

Perhaps you have heard about the term “wire speed” before. It’s something the marketing department likes to use when it comes to selling networking equipment. It means that packets can be forwarded without any noticeable delay. Everything that I explain in this lesson about multilayer switches also applies to routers. Let’s take a look at the difference between layer two and multilayer switches from the switch’s perspective:

layer two vs multilayer switch

You know that layer two switches only will switch Ethernet frames within a VLAN, and if we want we can filter traffic based on layer two (for example with port-security). The multilayer switch can do the same but is also able to route between VLANs and filter on layers three or four using access lists.

Forwarding on layer two is based on the destination MAC address. Our switch learns the source MAC addresses on incoming frames, and it builds the MAC address table. Whenever an Ethernet frame enters one of our interfaces, we’ll check the MAC address table to find the destination MAC address, and we’ll send it out to the correct interface.

Forwarding on layer three is based on the destination IP address. Forwarding happens when the switch receives an IP packet where the source IP address is in a different subnet than the destination IP address.

When our multilayer switch receives an IP packet with its own MAC address as the destination in the Ethernet header, there are two possibilities:

  • If the destination IP address is an address that is configured on the multilayer switch, then the IP packet was destined for this switch.
  • If the destination IP address is an address that is not configured on the multilayer switch, then we have to act as a gateway and “route” the packet. This means we’ll have to do a lookup in the routing table to check for the longest match. Also, we have to check if the IP packet is allowed if you configured an ACL.

Back in the days…switching was done at hardware speed while routing was done in software. Nowadays, both switching and routing are done at hardware speed. In the remaining of this lesson, you’ll learn why.

Let’s take a look at the difference between handling Ethernet Frames and IP Packets:

mac address table switch headers

The life of a layer two switch is simple:

  1. The switch will verify the checksum of the Ethernet frame to make it sure it’s not corrupted or altered.
  2. The switch receives an Ethernet frame and adds the source MAC address to the MAC address table.
  3. The switch forwards the Ethernet frame to the correct interface if it knows the destination MAC address. If not, it will be flooded.

There is no alteration of the Ethernet frame!

Now, let’s see what we have to do when we receive an IP packet on a multilayer switch:

multilayer switch packet forwarding

In the example above, H1 is sending an IP packet towards H2. Note that they are in different subnets, so we will have to route it. When our multilayer switch receives the IP packet, this is what will happen:

  1. The switch will verify the checksum of the Ethernet frame to make it sure it’s not corrupted or altered.
  2. The switch will verify the checksum of the IP packet to make it sure it’s not corrupted or altered.

The multilayer switch will check the routing table, notices that 192.168.20.0/24 is directly connected, and the following will happen:

  1. Check the ARP table to see if there’s a layer two to 3 mapping for H2. If there is no mapping, the multilayer switch will send an ARP request.
  2. The destination MAC address changes from FFF (Multilayer switch Fa0/1 ) to BBB (H2).
  3. The source MAC address changes from AAA (H1) to GGG (Multilayer switch Fa0/2).
  4. The TTL (time to live) field in the IP packet is decreased by one, and because of this, the IP header checksum will be recalculated.
  5. The Ethernet frame checksum must be recalculated.
  6. The Ethernet frame carrying the IP packet will be sent out of the interface towards H2.

As you can see, there are quite some steps involved if we want to route IP packets.

When we look at multilayer switches, there is a “separation of duties”. We have to build a table for the MAC addresses, fill a routing table, ARP requests, check if an IP packet matches an access-list, etc, and we need to forward our IP packets. These tasks are divided between the “control plane” and the “data plane”. Let me give you an illustration:

Control vs Data Plane

The control plane is responsible for exchanging routing information using routing protocols and building a routing table and ARP table. The data plane is responsible for the actual forwarding of IP packets. The routing table isn’t very suitable for fast forwarding because we have to deal with recursive routing. What is recursive routing? Let me give you an example:

three cisco routers in a row

In the example above, I have three routers. R3 has a loopback interface that we want to reach from R1. I will use static routes for reachability:

R1(config)#ip route 3.3.3.0 255.255.255.0 192.168.23.3
R1(config)#ip route 192.168.23.0 255.255.255.0 192.168.12.2

The first static route is to reach the loopback0 interface of R3 and points to the FastEthernet0/0 interface of R3. The second static route is required to reach network 192.168.23.0/24.

R1#show ip route         
Codes: C - connected, S - static, R - RIP, M - mobile, B - BGP
       D - EIGRP, EX - EIGRP external, O - OSPF, IA - OSPF inter area 
       N1 - OSPF NSSA external type 1, N2 - OSPF NSSA external type 2
       E1 - OSPF external type 1, E2 - OSPF external type 2
       i - IS-IS, su - IS-IS summary, L1 - IS-IS level-1, L2 -IS-IS level-2
       ia - IS-IS inter area, * - candidate default, per-user static route
       o - ODR, P - periodic downloaded static route

Gateway of last resort is not set

C    192.168.12.0/24 is directly connected, FastEthernet0/0
     3.0.0.0/24 is subnetted, 1 subnets
S       3.3.3.0 [1/0] via 192.168.23.3
S    192.168.23.0/24 [1/0] via 192.168.12.2

Whenever R1 wants to reach 3.3.3.0/24, we have to do three lookups:

  • The first lookup is to check the entry for 3.3.3.0 /24. It’s there, and the next hop IP address is 192.168.23.3
  • The second lookup is for 192.168.23.3. There’s an entry, and the next hop IP address is 192.168.12.2.
  • The third and last lookup is for 192.168.12.2. There’s an entry, and it is directly connected.

R1 has to check the routing table 3 times before it knows where to send its traffic. That doesn’t sound very efficient, right? Doing multiple lookups to reach a specific network is called recursive routing.

Most of the time, all incoming and outgoing IP packets will be processed and forwarded by the data plane, but there are some exceptions. First let me show you this picture:

Data plane forwarding packets

Most of the IP packets can be forwarded by the data plane. However, there are some “special” IP packets that can’t be forwarded by the data plane immediately, and they are sent to the control plane. Here are some examples:

  • IP packets destined for one of the IP addresses of the multilayer switch.
  • Routing protocol traffic like OSPF, EIGRP, or BGP.
  • IP packets that have some of the options set in the IP header.
  • IP packets with an expired TTL.

The control plane can forward outgoing IP packets to the data plane or use its forwarding mechanism to determine the outgoing interface and the next hop IP address. An example of this is local policy-based routing.

Our multilayer switch has many more steps to take than the layer two switches, so theoretically, it should be slower, right?

One reason that multilayer switches are able to forward frames and packets at wire speed is because of special hardware called ASICs in the data plane.

Information like MAC addresses, the routing table, or access lists are stored in these ASICs. The tables are stored in content-addressable memory (CAM) and ternary content-addressable memory (TCAM).

  • The CAM table is used to store layer two information like:
    • The source MAC address.
    • The interface where we learned the MAC address.
    • To which VLAN the MAC address belongs.

Table lookups are fast! Whenever the switch receives an Ethernet frame, it will use a hashing algorithm to create a “key” for the destination MAC address + VLAN, and it will compare this hash to the already hashed information in the CAM table. This way, it is able to quickly look up information in the CAM table.

  • The TCAM table is used to store “higher layer” information like:
    • Access-lists.
    • Quality of service information.
    • Routing table.
  • The TCAM table can match on three different values:
    • 0 = must be 0.
    • 1 = must be 1.
    • X = 0 or 1, both acceptable.
  • The longest match will return a hit.
  • Useful for a lookup where we don’t need an exact match. (routing table or ACLs, for example).

Because there are three values, we call it ternary.

So why are there two types of tables?

When we look for a MAC address, we always require an exact match. We require the exact MAC address to forward an Ethernet frame. The MAC address table is stored in a CAM table.

Whenever we need to match an IP packet against the routing table or an access-list, we don’t always need an exact match. For example, an IP packet with destination address 192.168.20.44 will match:

  • 192.168.20.44 /32
  • 192.168.20.0 /24
  • 192.168.0.0 /16

Information like the routing table is stored in a TCAM table for this reason. We can decide whether all or some bits have to match.

Here’s an example of a TCAM table:

TCAM Table

If we want to match IP address 192.168.10.22, the multilayer switch will first see if there’s a “most specific match”. Nothing matches 192.168.10.22 /32, so we’ll continue if there is anything else that matches. In this case, there is an entry that matches 192.168.10.0 /24. The example above applies to routing table lookups, access lists but also quality of service, VLAN access lists, and more.

Now you know all the steps a multilayer switch has to take when it has to forward ip packets, the control/data plane, and that we use different tables stored in special hardware called ASICs. Let’s take a closer look at the actual ‘forwarding’ of IP packets.

There are different switching methods to forward IP packets. Here are the different switching options:

  • Process switching:
    • All packets are examined by the CPU, and all forwarding decisions are made in software…very slow!
  • Fast switching (also known as route caching):
    • The first packet in a flow is examined by the CPU; the forwarding decision is cached in hardware for the next packets in the same flow. This is a faster method.
  • (CEF) Cisco Express Forwarding (also known as topology-based switching):
    • Forwarding table created in hardware beforehand. All packets will be switched using hardware. This is the fastest method but there are some limitations. Multilayer switches and routers use CEF.

When using process switching, the router will remove the header for each Ethernet frame, look for the destination IP address in the routing table for each IP packet, and then forward the Ethernet frame with the rewritten MAC addresses and CRC to the outgoing interface. Everything is done in software, so this is very CPU-intensive.

Fast switching is more efficient because it will look up the first IP packet and store the forwarding decision in the fast switching cache. When the routers receive Ethernet frames carrying IP packets in the same flow, it can use the information in the cache to forward them to the correct outgoing interface.

The default for routers is CEF (Cisco Express Forwarding). Let’s take a closer look at CEF:

CEF Forwarding Information Table

The multilayer switch will use the information from tables built by the (control plane) to build hardware tables. It will use the routing table to build the FIB (Forwarding Information Base) and the ARP table to build the adjacency table. This is the fastest switching method because we now have all the layer two and three information required to forward IP packets in hardware.

I should mention that some “lower-end” routers don’t have dedicated hardware for forwarding. They store these tables in software.

Are you following me so far? Let’s look at the forwarding information table and the adjacency table on some routers. If you want to follow me along, you can take a look at your multilayer switch OR use routers in GNS3:

three cisco routers in a row

I’ll use the same topology that I showed you earlier. 3 routers and R3 has a loopback0 interface.

I’ll use static routes to have full connectivity:

R1(config)#ip route 3.3.3.0 255.255.255.0 192.168.23.3
R1(config)#ip route 192.168.23.0 255.255.255.0 192.168.12.2
R2(config)#ip route 3.3.3.0 255.255.255.0 192.168.23.3
R3(config)#ip route 192.168.12.0 255.255.255.0 192.168.23.2

These are the static routes that I’ll use.
Now let me show you the routing and FIB table:

R1#show ip route 
Codes: C - connected, S - static, R - RIP, M - mobile, B - BGP
       D - EIGRP, EX - EIGRP external, O - OSPF, IA - OSPF inter area 
       N1 - OSPF NSSA external type 1, N2 - OSPF NSSA external type 2
       E1 - OSPF external type 1, E2 - OSPF external type 2
       i - IS-IS, su - IS-IS summary, L1 - IS-IS level-1, L2 - IS-IS level-2
       ia - IS-IS inter area, * - candidate default, U - per-user static route
       o - ODR, P - periodic downloaded static route

Gateway of last resort is not set

C    192.168.12.0/24 is directly connected, FastEthernet0/0
     3.0.0.0/24 is subnetted, 1 subnets
S       3.3.3.0 [1/0] via 192.168.23.3
S    192.168.23.0/24 [1/0] via 192.168.12.2
R1#show ip cef 
Prefix              Next Hop             Interface
0.0.0.0/0           drop                 Null0 (default route handler entry)
0.0.0.0/32          receive
3.3.3.0/24          192.168.12.2         FastEthernet0/0
192.168.12.0/24     attached             FastEthernet0/0
192.168.12.0/32     receive
192.168.12.1/32     receive
192.168.12.2/32     192.168.12.2         FastEthernet0/0
192.168.12.255/32   receive
192.168.23.0/24     192.168.12.2         FastEthernet0/0
224.0.0.0/4         drop
224.0.0.0/24        receive
255.255.255.255/32  receive

show ip cef reveals the FIB table to us.

You can see there’s quite some stuff in the FIB table. Let me explain some of the entries:

  • 0.0.0.0/0 is for the null0 interface. When we receive IP packets that match this rule, then it will be dropped.
  • 0.0.0.0/32 is for all-zero broadcasts. Forget about this one since we don’t use it anymore.
  • 3.3.3.0/24 is the entry for the loopback0 interface of R3. The next hop is 192.168.12.2 and NOT 192.168.23.3, as in the routing table!
  • 192.168.12.0/24 is our directly connected network.
  • 192.168.12.0/32 is reserved for the exact network address.
  • 192.168.12.1/32 is the IP address on interface FastEthernet 0/0.
  • 192.168.12.2/32 is the IP address on R2’s FastEthernet 0/0 interface.
  • 192.168.12.255/32 is the broadcast address for network 192.168.12.0/24.
  • 224.0.0.0/4 matches all multicast traffic. It will be dropped if multicast support is disabled globally.
  • 224.0.0.0/24 matches all multicast traffic reserved for local network control traffic (for example, OSPF, EIGRP).
  • 255.255.255.255/32 is the broadcast address for a subnet.

Let’s take a detailed look at the entry for network 3.3.3.0 /24:

R1#show ip cef 3.3.3.0 
3.3.3.0/24, version 8, epoch 0, cached adjacency 192.168.12.2
0 packets, 0 bytes
  via 192.168.23.3, 0 dependencies, recursive
    next hop 192.168.12.2, FastEthernet0/0 via 192.168.23.0/24
    valid cached adjacency

The version number tells us how often this CEF entry has been updated since the table was generated. We can see that to reach 3.3.3.0/24, we need to go to 192.168.23.3 and that a recursive lookup is required. The next hop is 192.168.12.2. It also says that it’s a valid cached adjacency. There are several different adjacencies:

  • Null adjacency: used to send packets to the null0 interface.
  • Drop adjacency: you’ll see this for packets that can’t be forwarded because of encapsulation errors, routes that cannot be resolved, or protocols that are not supported.
  • Discard adjacency: this is for packets that have to be discarded because of an access-list or other policy.
  • Punt adjacency: used for packets that CEF can’t forward. They will be “punted” to the next switching method (fast switching and process switching).
  • Glean adjacency:  used for directly connected routes. It’s used to tell the router that it should check the ARP table since it can reach the device directly.

The CPU handles packets that CEF does not forward. If you have many of those packets, then you might see performance issues.

You can see how many packets have been handled by the CPU:

R1#show cef not-cef-switched 
CEF Packets passed on to next switching layer
Slot  No_adj No_encap Unsupp'ted Redirect  Receive  Options   Access     Frag
RP         0       0           0        0       17        0        0        0

You can use the show cef not-cef-switched command to verify this; the number of packets is listed per reason:

  • No_adj: adjacency is incomplete.
  • No_encap: ARP information is incomplete.
  • Unsupp’ted: The packet has features that are not supported.
  • Redirect: ICMP redirects.
  • Receive: These are the packets that were destined for an IP address configured on a layer three interface, packets that are meant for our router.
  • Options: There are IP options in the header of the packet.
  • Access: access-list evaluation failure.
  • Frag: packet fragmentation error.

We can also take a look at the adjacency table that stores the layer two information for each entry:

R1#show adjacency summary 
Adjacency Table has 1 adjacency
  Table epoch: 0 (1 entry at this epoch)

  Interface                 Adjacency Count
  FastEthernet0/0           1

You can use the show adjacency summary command to take a quick look at how many adjacencies we have. An adjacency is a mapping from layer two to 3 and comes from the ARP table.

R1#show adjacency 
Protocol Interface                 Address
IP       FastEthernet0/0           192.168.12.2(9)

R1 only has a single interface that is connected to R2. You can see the entry for 192.168.12.2, which is the FastEthernet 0/0 interface of R2. Let’s zoom in on this entry:

R1#show adjacency detail 
Protocol Interface                 Address
IP       FastEthernet0/0           192.168.12.2(9)
                                   0 packets, 0 bytes
                                   CC011D800000CC001D8000000800
                                   ARP        03:55:00  
                                   Epoch: 0

We can see there’s an entry for 192.168.12.2, and it says:

CC011D800000CC001D8000000800

What does this number mean? It’s the MAC addresses that we require and the Ethertype…let me break it down for you:

Unlock This Lesson for Free - No Payment Required!

If you like to keep on reading, register now!

  • Learn CCNA, CCNP and CCIE R&S. Explained As Simple As Possible.
  • Get Instant Access to this Full Lesson, Completely for Free!
  • Unlock More to Read. More Lessons Added Every Week!
  • Content created by Rene Molenaar (CCIE #41726)
2456 Sign Ups in the last 30 days

Tags:


Forum Replies

  1. Wow, great article. Thanks for your work. I knew that there is always a “ip cef” command in the routers, but I never did a deep inspection of that.

    • What I am missing is a small summary. What is Cisco CEF all about? Maybe this is one of your core points?: “The multilayer switch will use the information from tables that are built by the (control plane) to build hardware tables.”
    • What about other router vendors? I think they are doing the same but have different names for it?

  2. Thanks Johannes!

    The reason why we need CEF is simple…a router has to perform multiple steps before it can forward a packet…routing table lookup, ARP table lookup, ACLs, etc. If you do all of this in software then it will be very slow. With CEF we put all this information into a single hardware table which allows really fast packet forwarding.

    Other vendors do the same thing, CEF is Cisco-only though.

    Rene

  3. One small thing that may need to be clarified. CEF isn’t linked to hardware forwarding.

    Routers can have both software forwarding with CEF, or it can install the CEF entries into hardware. This is platform dependent - platforms such as the 1800 or 2800 don’t have dedicated forwarding hardware.

  4. Hi Greg,

    Thanks for your comment and you are right, this is important to know. I’ll edit the post to mention this.

    Rene

  5. Hi Rene,
    Thanks. Complex technology explained in simple article and very easy to understand.

166 more replies! Ask a question or join the discussion by visiting our Community Forum