浏览代码

fix mtu calculation for raw raw_socket

Previously, the ethernet frame header was added twice to the MTU. The
first time in `interface_mtu` and a second time after calling
`interface_mtu` in the raw socket `new` function. I removed the one in
the `interface_mtu` function.
Thibaut Vandervelden 2 年之前
父节点
当前提交
6f3ea00a6a
共有 2 个文件被更改,包括 2 次插入7 次删除
  1. 1 1
      src/phy/raw_socket.rs
  2. 1 6
      src/phy/sys/raw_socket.rs

+ 1 - 1
src/phy/raw_socket.rs

@@ -43,7 +43,7 @@ impl RawSocket {
         Ok(RawSocket {
             medium,
             lower: Rc::new(RefCell::new(lower)),
-            mtu: mtu,
+            mtu,
         })
     }
 }

+ 1 - 6
src/phy/sys/raw_socket.rs

@@ -1,6 +1,5 @@
 use super::*;
 use crate::phy::Medium;
-use crate::wire::EthernetFrame;
 use std::os::unix::io::{AsRawFd, RawFd};
 use std::{io, mem};
 
@@ -48,11 +47,7 @@ impl RawSocketDesc {
     }
 
     pub fn interface_mtu(&mut self) -> io::Result<usize> {
-        // SIOCGIFMTU returns the IP MTU (typically 1500 bytes.)
-        // smoltcp counts the entire Ethernet packet in the MTU, so add the Ethernet header size to it.
-        let ip_mtu =
-            ifreq_ioctl(self.lower, &mut self.ifreq, imp::SIOCGIFMTU).map(|mtu| mtu as usize)?;
-        Ok(ip_mtu + EthernetFrame::<&[u8]>::header_len())
+        ifreq_ioctl(self.lower, &mut self.ifreq, imp::SIOCGIFMTU).map(|mtu| mtu as usize)
     }
 
     pub fn bind_interface(&mut self) -> io::Result<()> {