1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64
// SPDX-License-Identifier: MIT
use netlink_packet_utils::{
traits::{Emitable, Parseable},
DecodeError,
};
use crate::{NeighbourMessageBuffer, NEIGHBOUR_HEADER_LEN};
/// Neighbour headers have the following structure:
///
/// ```no_rust
/// 0 8 16 24 32
/// +----------------+----------------+----------------+----------------+
/// | family | padding |
/// +----------------+----------------+----------------+----------------+
/// | link index |
/// +----------------+----------------+----------------+----------------+
/// | state | flags | ntype |
/// +----------------+----------------+----------------+----------------+
/// ```
///
/// `NeighbourHeader` exposes all these fields.
#[derive(Debug, PartialEq, Eq, Clone, Default)]
pub struct NeighbourHeader {
pub family: u8,
pub ifindex: u32,
/// Neighbour cache entry state. It should be set to one of the
/// `NUD_*` constants
pub state: u16,
/// Neighbour cache entry flags. It should be set to a combination
/// of the `NTF_*` constants
pub flags: u8,
/// Neighbour cache entry type. It should be set to one of the
/// `NDA_*` constants.
pub ntype: u8,
}
impl<T: AsRef<[u8]>> Parseable<NeighbourMessageBuffer<T>> for NeighbourHeader {
fn parse(buf: &NeighbourMessageBuffer<T>) -> Result<Self, DecodeError> {
Ok(Self {
family: buf.family(),
ifindex: buf.ifindex(),
state: buf.state(),
flags: buf.flags(),
ntype: buf.ntype(),
})
}
}
impl Emitable for NeighbourHeader {
fn buffer_len(&self) -> usize {
NEIGHBOUR_HEADER_LEN
}
fn emit(&self, buffer: &mut [u8]) {
let mut packet = NeighbourMessageBuffer::new(buffer);
packet.set_family(self.family);
packet.set_ifindex(self.ifindex);
packet.set_state(self.state);
packet.set_flags(self.flags);
packet.set_ntype(self.ntype);
}
}