pub struct Routes<'a> { /* private fields */ }
Expand description
A routing table.
Examples
On systems with heap, this table can be created with:
use std::collections::BTreeMap;
use smoltcp::iface::Routes;
let mut routes = Routes::new(BTreeMap::new());
On systems without heap, use:
use smoltcp::iface::Routes;
let mut routes_storage = [];
let mut routes = Routes::new(&mut routes_storage[..]);
Implementations§
source§impl<'a> Routes<'a>
impl<'a> Routes<'a>
sourcepub fn new<T>(storage: T) -> Routes<'a>where
T: Into<ManagedMap<'a, IpCidr, Route>>,
pub fn new<T>(storage: T) -> Routes<'a>where
T: Into<ManagedMap<'a, IpCidr, Route>>,
Creates a routing tables. The backing storage is not cleared upon creation.
sourcepub fn update<F: FnOnce(&mut ManagedMap<'a, IpCidr, Route>)>(&mut self, f: F)
pub fn update<F: FnOnce(&mut ManagedMap<'a, IpCidr, Route>)>(&mut self, f: F)
Update the routes of this node.
sourcepub fn add_default_ipv4_route(
&mut self,
gateway: Ipv4Address
) -> Result<Option<Route>>
pub fn add_default_ipv4_route(
&mut self,
gateway: Ipv4Address
) -> Result<Option<Route>>
Add a default ipv4 gateway (ie. “ip route add 0.0.0.0/0 via gateway
”).
On success, returns the previous default route, if any.
sourcepub fn add_default_ipv6_route(
&mut self,
gateway: Ipv6Address
) -> Result<Option<Route>>
pub fn add_default_ipv6_route(
&mut self,
gateway: Ipv6Address
) -> Result<Option<Route>>
Add a default ipv6 gateway (ie. “ip -6 route add ::/0 via gateway
”).
On success, returns the previous default route, if any.