netlink_packet_route/link/sriov/
vlan.rs

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
// SPDX-License-Identifier: MIT

use netlink_packet_utils::{DecodeError, Emitable, Parseable};

const VF_INFO_VLAN_LEN: usize = 12;

#[derive(Debug, Clone, Copy, Eq, PartialEq, Default)]
#[non_exhaustive]
pub struct VfInfoVlan {
    pub vf_id: u32,
    pub vlan_id: u32,
    pub qos: u32,
}

impl VfInfoVlan {
    pub fn new(vf_id: u32, vlan_id: u32, qos: u32) -> Self {
        Self { vf_id, vlan_id, qos }
    }
}

buffer!(VfInfoVlanBuffer(VF_INFO_VLAN_LEN) {
    vf_id: (u32, 0..4),
    vlan_id: (u32, 4..8),
    qos: (u32, 8..12)
});

impl<'a, T: AsRef<[u8]> + ?Sized> Parseable<VfInfoVlanBuffer<&'a T>> for VfInfoVlan {
    type Error = DecodeError;
    fn parse(buf: &VfInfoVlanBuffer<&T>) -> Result<Self, DecodeError> {
        Ok(Self { vf_id: buf.vf_id(), vlan_id: buf.vlan_id(), qos: buf.qos() })
    }
}

impl Emitable for VfInfoVlan {
    fn buffer_len(&self) -> usize {
        VF_INFO_VLAN_LEN
    }

    fn emit(&self, buffer: &mut [u8]) {
        let mut buffer = VfInfoVlanBuffer::new(buffer);
        buffer.set_vf_id(self.vf_id);
        buffer.set_vlan_id(self.vlan_id);
        buffer.set_qos(self.qos);
    }
}