Skip to content

Commit

Permalink
change(wire): remove generic in parse and emit
Browse files Browse the repository at this point in the history
  • Loading branch information
thvdveld committed Dec 13, 2023
1 parent 260f462 commit 72f947d
Show file tree
Hide file tree
Showing 30 changed files with 155 additions and 240 deletions.
4 changes: 2 additions & 2 deletions examples/ping.rs
Original file line number Diff line number Diff line change
Expand Up @@ -208,7 +208,7 @@ fn main() {

match remote_addr {
IpAddress::Ipv4(_) => {
let icmp_packet = Icmpv4Packet::new_checked(&payload).unwrap();
let icmp_packet = Icmpv4Packet::new_checked(&payload[..]).unwrap();
let icmp_repr = Icmpv4Repr::parse(&icmp_packet, &device_caps.checksum).unwrap();
get_icmp_pong!(
Icmpv4Repr,
Expand All @@ -221,7 +221,7 @@ fn main() {
);
}
IpAddress::Ipv6(address) => {
let icmp_packet = Icmpv6Packet::new_checked(&payload).unwrap();
let icmp_packet = Icmpv6Packet::new_checked(&payload[..]).unwrap();
let icmp_repr = Icmpv6Repr::parse(
&remote_addr,
&iface
Expand Down
2 changes: 1 addition & 1 deletion src/iface/interface/sixlowpan.rs
Original file line number Diff line number Diff line change
Expand Up @@ -752,7 +752,7 @@ mod tests {
0xfd, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0, 0x0,
])];

let ieee_frame = Ieee802154Frame::new_checked(&SIXLOWPAN_COMPRESSED_RPL_DAO).unwrap();
let ieee_frame = Ieee802154Frame::new_checked(&SIXLOWPAN_COMPRESSED_RPL_DAO[..]).unwrap();
let ieee_repr = Ieee802154Repr::parse(&ieee_frame).unwrap();

let mut buffer = [0u8; 256];
Expand Down
4 changes: 2 additions & 2 deletions src/iface/interface/tests/ipv4.rs
Original file line number Diff line number Diff line change
Expand Up @@ -181,8 +181,8 @@ fn test_icmp_error_port_unreachable(#[case] medium: Medium) {

let mut udp_bytes_unicast = vec![0u8; 20];
let mut udp_bytes_broadcast = vec![0u8; 20];
let mut packet_unicast = UdpPacket::new_unchecked(&mut udp_bytes_unicast);
let mut packet_broadcast = UdpPacket::new_unchecked(&mut udp_bytes_broadcast);
let mut packet_unicast = UdpPacket::new_unchecked(&mut udp_bytes_unicast[..]);
let mut packet_broadcast = UdpPacket::new_unchecked(&mut udp_bytes_broadcast[..]);

let udp_repr = UdpRepr {
src_port: 67,
Expand Down
2 changes: 1 addition & 1 deletion src/iface/interface/tests/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -78,7 +78,7 @@ fn test_handle_udp_broadcast(
let udp_socket = udp::Socket::new(rx_buffer, tx_buffer);

let mut udp_bytes = vec![0u8; 13];
let mut packet = UdpPacket::new_unchecked(&mut udp_bytes);
let mut packet = UdpPacket::new_unchecked(&mut udp_bytes[..]);

let socket_handle = sockets.add(udp_socket);

Expand Down
16 changes: 8 additions & 8 deletions src/socket/icmp.rs
Original file line number Diff line number Diff line change
Expand Up @@ -723,7 +723,7 @@ mod test_ipv4 {
assert!(socket.can_send());

let mut bytes = [0xff; 24];
let mut packet = Icmpv4Packet::new_unchecked(&mut bytes);
let mut packet = Icmpv4Packet::new_unchecked(&mut bytes[..]);
ECHOV4_REPR.emit(&mut packet, &checksum);

assert_eq!(
Expand Down Expand Up @@ -770,7 +770,7 @@ mod test_ipv4 {
let checksum = ChecksumCapabilities::default();

let mut bytes = [0xff; 24];
let mut packet = Icmpv4Packet::new_unchecked(&mut bytes);
let mut packet = Icmpv4Packet::new_unchecked(&mut bytes[..]);
ECHOV4_REPR.emit(&mut packet, &checksum);

s.set_hop_limit(Some(0x2a));
Expand Down Expand Up @@ -840,7 +840,7 @@ mod test_ipv4 {

let checksum = ChecksumCapabilities::default();
let mut bytes = [0xff; 20];
let mut packet = Icmpv4Packet::new_unchecked(&mut bytes);
let mut packet = Icmpv4Packet::new_unchecked(&mut bytes[..]);
let icmp_repr = Icmpv4Repr::EchoRequest {
ident: 0x4321,
seq_no: 0x5678,
Expand All @@ -866,7 +866,7 @@ mod test_ipv4 {
let checksum = ChecksumCapabilities::default();

let mut bytes = [0xff; 18];
let mut packet = UdpPacket::new_unchecked(&mut bytes);
let mut packet = UdpPacket::new_unchecked(&mut bytes[..]);
UDP_REPR.emit(
&mut packet,
&REMOTE_IPV4.into(),
Expand Down Expand Up @@ -986,7 +986,7 @@ mod test_ipv6 {
assert!(socket.can_send());

let mut bytes = vec![0xff; 24];
let mut packet = Icmpv6Packet::new_unchecked(&mut bytes);
let mut packet = Icmpv6Packet::new_unchecked(&mut bytes[..]);
ECHOV6_REPR.emit(
&LOCAL_IPV6.into(),
&REMOTE_IPV6.into(),
Expand Down Expand Up @@ -1038,7 +1038,7 @@ mod test_ipv6 {
let checksum = ChecksumCapabilities::default();

let mut bytes = vec![0xff; 24];
let mut packet = Icmpv6Packet::new_unchecked(&mut bytes);
let mut packet = Icmpv6Packet::new_unchecked(&mut bytes[..]);
ECHOV6_REPR.emit(
&LOCAL_IPV6.into(),
&REMOTE_IPV6.into(),
Expand Down Expand Up @@ -1154,7 +1154,7 @@ mod test_ipv6 {

let checksum = ChecksumCapabilities::default();
let mut bytes = [0xff; 20];
let mut packet = Icmpv6Packet::new_unchecked(&mut bytes);
let mut packet = Icmpv6Packet::new_unchecked(&mut bytes[..]);
let icmp_repr = Icmpv6Repr::EchoRequest {
ident: 0x4321,
seq_no: 0x5678,
Expand Down Expand Up @@ -1185,7 +1185,7 @@ mod test_ipv6 {
let checksum = ChecksumCapabilities::default();

let mut bytes = [0xff; 18];
let mut packet = UdpPacket::new_unchecked(&mut bytes);
let mut packet = UdpPacket::new_unchecked(&mut bytes[..]);
UDP_REPR.emit(
&mut packet,
&REMOTE_IPV6.into(),
Expand Down
10 changes: 5 additions & 5 deletions src/wire/arp.rs
Original file line number Diff line number Diff line change
Expand Up @@ -270,7 +270,7 @@ pub enum Repr {
impl Repr {
/// Parse an Address Resolution Protocol packet and return a high-level representation,
/// or return `Err(Error)` if the packet is not recognized.
pub fn parse<T: AsRef<[u8]>>(packet: &Packet<T>) -> Result<Repr> {
pub fn parse(packet: &Packet<&[u8]>) -> Result<Repr> {
match (
packet.hardware_type(),
packet.protocol_type(),
Expand All @@ -296,7 +296,7 @@ impl Repr {
}

/// Emit a high-level representation into an Address Resolution Protocol packet.
pub fn emit<T: AsRef<[u8]> + AsMut<[u8]>>(&self, packet: &mut Packet<T>) {
pub fn emit(&self, packet: &mut Packet<&mut [u8]>) {
match *self {
Repr::EthernetIpv4 {
operation,
Expand All @@ -319,7 +319,7 @@ impl Repr {
}
}

impl<T: AsRef<[u8]>> fmt::Display for Packet<T> {
impl fmt::Display for Packet<&[u8]> {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
match Repr::parse(self) {
Ok(repr) => write!(f, "{repr}"),
Expand Down Expand Up @@ -375,7 +375,7 @@ impl<T: AsRef<[u8]>> PrettyPrint for Packet<T> {
f: &mut fmt::Formatter,
indent: &mut PrettyIndent,
) -> fmt::Result {
match Packet::new_checked(buffer) {
match Packet::new_checked(buffer.as_ref()) {
Err(err) => write!(f, "{indent}({err})"),
Ok(packet) => write!(f, "{indent}{packet}"),
}
Expand Down Expand Up @@ -451,7 +451,7 @@ mod test {
#[test]
fn test_emit() {
let mut bytes = vec![0xa5; 28];
let mut packet = Packet::new_unchecked(&mut bytes);
let mut packet = Packet::new_unchecked(&mut bytes[..]);
packet_repr().emit(&mut packet);
assert_eq!(&*packet.into_inner(), &PACKET_BYTES[..]);
}
Expand Down
18 changes: 6 additions & 12 deletions src/wire/dhcpv4.rs
Original file line number Diff line number Diff line change
Expand Up @@ -703,10 +703,7 @@ impl<'a> Repr<'a> {
}

/// Parse a DHCP packet and return a high-level representation.
pub fn parse<T>(packet: &'a Packet<&'a T>) -> Result<Self>
where
T: AsRef<[u8]> + ?Sized,
{
pub fn parse(packet: &'a Packet<&'a [u8]>) -> Result<Self> {
let transaction_id = packet.transaction_id();
let client_hardware_address = packet.client_hardware_address();
let client_ip = packet.client_ip();
Expand Down Expand Up @@ -834,10 +831,7 @@ impl<'a> Repr<'a> {

/// Emit a high-level representation into a Dynamic Host
/// Configuration Protocol packet.
pub fn emit<T>(&self, packet: &mut Packet<&mut T>) -> Result<()>
where
T: AsRef<[u8]> + AsMut<[u8]> + ?Sized,
{
pub fn emit(&self, packet: &mut Packet<&mut [u8]>) -> Result<()> {
packet.set_sname_and_boot_file_to_zero();
packet.set_opcode(self.message_type.opcode());
packet.set_hardware_type(Hardware::Ethernet);
Expand Down Expand Up @@ -1211,7 +1205,7 @@ mod test {
fn test_emit_discover() {
let repr = discover_repr();
let mut bytes = vec![0xa5; repr.buffer_len()];
let mut packet = Packet::new_unchecked(&mut bytes);
let mut packet = Packet::new_unchecked(&mut bytes[..]);
repr.emit(&mut packet).unwrap();
let packet = &*packet.into_inner();
let packet_len = packet.len();
Expand All @@ -1225,7 +1219,7 @@ mod test {
fn test_emit_offer() {
let repr = offer_repr();
let mut bytes = vec![0xa5; repr.buffer_len()];
let mut packet = Packet::new_unchecked(&mut bytes);
let mut packet = Packet::new_unchecked(&mut bytes[..]);
repr.emit(&mut packet).unwrap();
}

Expand All @@ -1244,10 +1238,10 @@ mod test {
repr
};
let mut bytes = vec![0xa5; repr.buffer_len()];
let mut packet = Packet::new_unchecked(&mut bytes);
let mut packet = Packet::new_unchecked(&mut bytes[..]);
repr.emit(&mut packet).unwrap();

let packet = Packet::new_unchecked(&bytes);
let packet = Packet::new_unchecked(&bytes[..]);
let repr_parsed = Repr::parse(&packet).unwrap();

assert_eq!(
Expand Down
5 changes: 1 addition & 4 deletions src/wire/dns.rs
Original file line number Diff line number Diff line change
Expand Up @@ -417,10 +417,7 @@ impl<'a> Repr<'a> {
}

/// Emit a high-level representation into a DNS packet.
pub fn emit<T: ?Sized>(&self, packet: &mut Packet<&mut T>)
where
T: AsRef<[u8]> + AsMut<[u8]>,
{
pub fn emit(&self, packet: &mut Packet<&mut [u8]>) {
packet.set_transaction_id(self.transaction_id);
packet.set_flags(self.flags);
packet.set_opcode(self.opcode);
Expand Down
4 changes: 2 additions & 2 deletions src/wire/ethernet.rs
Original file line number Diff line number Diff line change
Expand Up @@ -267,7 +267,7 @@ pub struct Repr {

impl Repr {
/// Parse an Ethernet II frame and return a high-level representation.
pub fn parse<T: AsRef<[u8]> + ?Sized>(frame: &Frame<&T>) -> Result<Repr> {
pub fn parse(frame: &Frame<&[u8]>) -> Result<Repr> {
frame.check_len()?;
Ok(Repr {
src_addr: frame.src_addr(),
Expand All @@ -282,7 +282,7 @@ impl Repr {
}

/// Emit a high-level representation into an Ethernet II frame.
pub fn emit<T: AsRef<[u8]> + AsMut<[u8]>>(&self, frame: &mut Frame<T>) {
pub fn emit(&self, frame: &mut Frame<&mut [u8]>) {
frame.set_src_addr(self.src_addr);
frame.set_dst_addr(self.dst_addr);
frame.set_ethertype(self.ethertype);
Expand Down
20 changes: 7 additions & 13 deletions src/wire/icmpv4.rs
Original file line number Diff line number Diff line change
Expand Up @@ -392,13 +392,10 @@ pub enum Repr<'a> {
impl<'a> Repr<'a> {
/// Parse an Internet Control Message Protocol version 4 packet and return
/// a high-level representation.
pub fn parse<T>(
packet: &Packet<&'a T>,
pub fn parse(
packet: &Packet<&'a [u8]>,
checksum_caps: &ChecksumCapabilities,
) -> Result<Repr<'a>>
where
T: AsRef<[u8]> + ?Sized,
{
) -> Result<Repr<'a>> {
// Valid checksum is expected.
if checksum_caps.icmpv4.rx() && !packet.verify_checksum() {
return Err(Error);
Expand Down Expand Up @@ -482,10 +479,7 @@ impl<'a> Repr<'a> {

/// Emit a high-level representation into an Internet Control Message Protocol version 4
/// packet.
pub fn emit<T>(&self, packet: &mut Packet<&mut T>, checksum_caps: &ChecksumCapabilities)
where
T: AsRef<[u8]> + AsMut<[u8]> + ?Sized,
{
pub fn emit(&self, packet: &mut Packet<&mut [u8]>, checksum_caps: &ChecksumCapabilities) {
packet.set_msg_code(0);
match *self {
Repr::EchoRequest {
Expand Down Expand Up @@ -553,7 +547,7 @@ impl<'a> Repr<'a> {
}
}

impl<'a, T: AsRef<[u8]> + ?Sized> fmt::Display for Packet<&'a T> {
impl<'a> fmt::Display for Packet<&'a [u8]> {
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
match Repr::parse(self, &ChecksumCapabilities::default()) {
Ok(repr) => write!(f, "{repr}"),
Expand Down Expand Up @@ -617,7 +611,7 @@ impl<T: AsRef<[u8]>> PrettyPrint for Packet<T> {
f: &mut fmt::Formatter,
indent: &mut PrettyIndent,
) -> fmt::Result {
let packet = match Packet::new_checked(buffer) {
let packet = match Packet::new_checked(buffer.as_ref()) {
Err(err) => return write!(f, "{indent}({err})"),
Ok(packet) => packet,
};
Expand Down Expand Up @@ -687,7 +681,7 @@ mod test {
fn test_echo_emit() {
let repr = echo_packet_repr();
let mut bytes = vec![0xa5; repr.buffer_len()];
let mut packet = Packet::new_unchecked(&mut bytes);
let mut packet = Packet::new_unchecked(&mut bytes[..]);
repr.emit(&mut packet, &ChecksumCapabilities::default());
assert_eq!(&packet.into_inner()[..], &ECHO_PACKET_BYTES[..]);
}
Expand Down
30 changes: 13 additions & 17 deletions src/wire/icmpv6.rs
Original file line number Diff line number Diff line change
Expand Up @@ -608,15 +608,12 @@ pub enum Repr<'a> {
impl<'a> Repr<'a> {
/// Parse an Internet Control Message Protocol version 6 packet and return
/// a high-level representation.
pub fn parse<T>(
pub fn parse(
src_addr: &IpAddress,
dst_addr: &IpAddress,
packet: &Packet<&'a T>,
packet: &Packet<&'a [u8]>,
checksum_caps: &ChecksumCapabilities,
) -> Result<Repr<'a>>
where
T: AsRef<[u8]> + ?Sized,
{
) -> Result<Repr<'a>> {
fn create_packet_from_payload<'a, T>(packet: &Packet<&'a T>) -> Result<(&'a [u8], Ipv6Repr)>
where
T: AsRef<[u8]> + ?Sized,
Expand Down Expand Up @@ -721,15 +718,13 @@ impl<'a> Repr<'a> {

/// Emit a high-level representation into an Internet Control Message Protocol version 6
/// packet.
pub fn emit<T>(
pub fn emit(
&self,
src_addr: &IpAddress,
dst_addr: &IpAddress,
packet: &mut Packet<&mut T>,
packet: &mut Packet<&mut [u8]>,
checksum_caps: &ChecksumCapabilities,
) where
T: AsRef<[u8]> + AsMut<[u8]> + ?Sized,
{
) {
fn emit_contained_packet<T>(packet: &mut Packet<&mut T>, header: Ipv6Repr, data: &[u8])
where
T: AsRef<[u8]> + AsMut<[u8]> + ?Sized,
Expand Down Expand Up @@ -938,7 +933,7 @@ mod test {
fn test_echo_emit() {
let repr = echo_packet_repr();
let mut bytes = vec![0xa5; repr.buffer_len()];
let mut packet = Packet::new_unchecked(&mut bytes);
let mut packet = Packet::new_unchecked(&mut bytes[..]);
repr.emit(
&MOCK_IP_ADDR_1,
&MOCK_IP_ADDR_2,
Expand Down Expand Up @@ -991,7 +986,7 @@ mod test {
fn test_too_big_emit() {
let repr = too_big_packet_repr();
let mut bytes = vec![0xa5; repr.buffer_len()];
let mut packet = Packet::new_unchecked(&mut bytes);
let mut packet = Packet::new_unchecked(&mut bytes[..]);
repr.emit(
&MOCK_IP_ADDR_1,
&MOCK_IP_ADDR_2,
Expand Down Expand Up @@ -1026,7 +1021,8 @@ mod test {
hop_limit: 64,
payload_len: IPV6_MIN_MTU - IPV6_HEADER_LEN,
};
let mut ip_packet = Ipv6Packet::new_unchecked(vec![0; IPV6_MIN_MTU]);
let mut buffer = [0; IPV6_MIN_MTU];
let mut ip_packet = Ipv6Packet::new_unchecked(&mut buffer[..]);
ip_packet_repr.emit(&mut ip_packet);

let repr1 = Repr::PktTooBig {
Expand All @@ -1042,15 +1038,15 @@ mod test {
data: &ip_packet.as_ref()[IPV6_HEADER_LEN..repr1.buffer_len() - field::UNUSED.end],
};
let mut data = vec![0; MAX_ERROR_PACKET_LEN];
let mut packet = Packet::new_unchecked(&mut data);
let mut packet = Packet::new_unchecked(&mut data[..]);
repr1.emit(
&MOCK_IP_ADDR_1,
&MOCK_IP_ADDR_2,
&mut packet,
&ChecksumCapabilities::default(),
);

let packet = Packet::new_unchecked(&data);
let packet = Packet::new_unchecked(&data[..]);
let repr2 = Repr::parse(
&MOCK_IP_ADDR_1,
&MOCK_IP_ADDR_2,
Expand All @@ -1066,7 +1062,7 @@ mod test {
fn test_truncated_payload_ipv6_header_parse_fails() {
let repr = too_big_packet_repr();
let mut bytes = vec![0xa5; repr.buffer_len()];
let mut packet = Packet::new_unchecked(&mut bytes);
let mut packet = Packet::new_unchecked(&mut bytes[..]);
repr.emit(
&MOCK_IP_ADDR_1,
&MOCK_IP_ADDR_2,
Expand Down
Loading

0 comments on commit 72f947d

Please sign in to comment.