netlink_packet_route/link/sriov/
vlan.rs

1// SPDX-License-Identifier: MIT
2
3use netlink_packet_core::{DecodeError, Emitable, Parseable};
4
5const VF_INFO_VLAN_LEN: usize = 12;
6
7#[derive(Debug, Clone, Copy, Eq, PartialEq, Default)]
8#[non_exhaustive]
9pub struct VfInfoVlan {
10    pub vf_id: u32,
11    pub vlan_id: u32,
12    pub qos: u32,
13}
14
15impl VfInfoVlan {
16    pub fn new(vf_id: u32, vlan_id: u32, qos: u32) -> Self {
17        Self {
18            vf_id,
19            vlan_id,
20            qos,
21        }
22    }
23}
24
25buffer!(VfInfoVlanBuffer(VF_INFO_VLAN_LEN) {
26    vf_id: (u32, 0..4),
27    vlan_id: (u32, 4..8),
28    qos: (u32, 8..12)
29});
30
31impl<T: AsRef<[u8]> + ?Sized> Parseable<VfInfoVlanBuffer<&T>> for VfInfoVlan {
32    fn parse(buf: &VfInfoVlanBuffer<&T>) -> Result<Self, DecodeError> {
33        Ok(Self {
34            vf_id: buf.vf_id(),
35            vlan_id: buf.vlan_id(),
36            qos: buf.qos(),
37        })
38    }
39}
40
41impl Emitable for VfInfoVlan {
42    fn buffer_len(&self) -> usize {
43        VF_INFO_VLAN_LEN
44    }
45
46    fn emit(&self, buffer: &mut [u8]) {
47        let mut buffer = VfInfoVlanBuffer::new(buffer);
48        buffer.set_vf_id(self.vf_id);
49        buffer.set_vlan_id(self.vlan_id);
50        buffer.set_qos(self.qos);
51    }
52}