Constant netlink_packet_route::rtnl::constants::RT_TABLE_LOCAL

source ·
pub const RT_TABLE_LOCAL: u8 = 255;
Expand description

The local table.

This table is populated automatically by the kernel when addresses are configured.

On a machine that has 192.168.44.211/24 configured on wlp58s0, iproute2 shows the following routes in the local table:

$ ip route show table local

broadcast 127.0.0.0 dev lo proto kernel scope link src 127.0.0.1
local 127.0.0.0/8 dev lo proto kernel scope host src 127.0.0.1
local 127.0.0.1 dev lo proto kernel scope host src 127.0.0.1
broadcast 127.255.255.255 dev lo proto kernel scope link src 127.0.0.1

broadcast 192.168.44.0 dev wlp58s0 proto kernel scope link src 192.168.44.211
local 192.168.44.211 dev wlp58s0 proto kernel scope host src 192.168.44.211
broadcast 192.168.44.255 dev wlp58s0 proto kernel scope link src 192.168.44.211

When the IP address 192.168.44.211 was configured on the wlp58s0 interface, the kernel automatically added the appropriate routes:

  • a route for 192.168.44.211 for local unicast delivery to the IP address
  • a route for 192.168.44.255 for broadcast delivery to the broadcast address
  • a route for 192.168.44.0 for broadcast delivery to the network address

When 127.0.0.1 was configured on the loopback interface, the same kind of routes were added to the local table. However, a loopback address receives a special treatment and the kernel also adds the whole subnet to the local table.

Note that this is similar for IPv6:

$ ip -6 route show table local
local ::1 dev lo proto kernel metric 0 pref medium
local fe80::7de1:4914:99b7:aa28 dev wlp58s0 proto kernel metric 0 pref medium
ff00::/8 dev wlp58s0 metric 256 pref medium

§Source

This documentation is adapted from Vincent Bernat’s excellent blog