netlink_packet_route/address/
cache_info.rs1use netlink_packet_core::{DecodeError, Emitable, Parseable};
4
5#[derive(Debug, Clone, Copy, Eq, PartialEq, Default)]
6#[non_exhaustive]
7pub struct CacheInfo {
8 pub ifa_preferred: u32,
9 pub ifa_valid: u32,
10 pub cstamp: u32,
11 pub tstamp: u32,
12}
13
14const ADDRESSS_CACHE_INFO_LEN: usize = 16;
15
16buffer!(CacheInfoBuffer(ADDRESSS_CACHE_INFO_LEN) {
17 ifa_preferred: (u32, 0..4),
18 ifa_valid: (u32, 4..8),
19 cstamp: (u32, 8..12),
20 tstamp: (u32, 12..16),
21});
22
23impl<T: AsRef<[u8]>> Parseable<CacheInfoBuffer<T>> for CacheInfo {
24 fn parse(buf: &CacheInfoBuffer<T>) -> Result<Self, DecodeError> {
25 Ok(CacheInfo {
26 ifa_preferred: buf.ifa_preferred(),
27 ifa_valid: buf.ifa_valid(),
28 cstamp: buf.cstamp(),
29 tstamp: buf.tstamp(),
30 })
31 }
32}
33
34impl Emitable for CacheInfo {
35 fn buffer_len(&self) -> usize {
36 ADDRESSS_CACHE_INFO_LEN
37 }
38
39 fn emit(&self, buffer: &mut [u8]) {
40 let mut buffer = CacheInfoBuffer::new(buffer);
41 buffer.set_ifa_preferred(self.ifa_preferred);
42 buffer.set_ifa_valid(self.ifa_valid);
43 buffer.set_cstamp(self.cstamp);
44 buffer.set_tstamp(self.tstamp);
45 }
46}