tuntap_interface.rs 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. use std::cell::RefCell;
  2. use std::vec::Vec;
  3. use std::rc::Rc;
  4. use std::io;
  5. use std::os::unix::io::{RawFd, AsRawFd};
  6. use crate::Result;
  7. use crate::phy::{self, sys, DeviceCapabilities, Device, Medium};
  8. use crate::time::Instant;
  9. /// A virtual TUN (IP) or TAP (Ethernet) interface.
  10. #[derive(Debug)]
  11. pub struct TunTapInterface {
  12. lower: Rc<RefCell<sys::TunTapInterfaceDesc>>,
  13. mtu: usize,
  14. medium: Medium,
  15. }
  16. impl AsRawFd for TunTapInterface {
  17. fn as_raw_fd(&self) -> RawFd {
  18. self.lower.borrow().as_raw_fd()
  19. }
  20. }
  21. impl TunTapInterface {
  22. /// Attaches to a TUN/TAP interface called `name`, or creates it if it does not exist.
  23. ///
  24. /// If `name` is a persistent interface configured with UID of the current user,
  25. /// no special privileges are needed. Otherwise, this requires superuser privileges
  26. /// or a corresponding capability set on the executable.
  27. pub fn new(name: &str, medium: Medium) -> io::Result<TunTapInterface> {
  28. let mut lower = sys::TunTapInterfaceDesc::new(name, medium)?;
  29. lower.attach_interface()?;
  30. let mtu = lower.interface_mtu()?;
  31. Ok(TunTapInterface {
  32. lower: Rc::new(RefCell::new(lower)),
  33. mtu,
  34. medium,
  35. })
  36. }
  37. }
  38. impl<'a> Device<'a> for TunTapInterface {
  39. type RxToken = RxToken;
  40. type TxToken = TxToken;
  41. fn capabilities(&self) -> DeviceCapabilities {
  42. DeviceCapabilities {
  43. max_transmission_unit: self.mtu,
  44. medium: self.medium,
  45. ..DeviceCapabilities::default()
  46. }
  47. }
  48. fn receive(&'a mut self) -> Option<(Self::RxToken, Self::TxToken)> {
  49. let mut lower = self.lower.borrow_mut();
  50. let mut buffer = vec![0; self.mtu];
  51. match lower.recv(&mut buffer[..]) {
  52. Ok(size) => {
  53. buffer.resize(size, 0);
  54. let rx = RxToken { buffer };
  55. let tx = TxToken { lower: self.lower.clone() };
  56. Some((rx, tx))
  57. }
  58. Err(ref err) if err.kind() == io::ErrorKind::WouldBlock => {
  59. None
  60. }
  61. Err(err) => panic!("{}", err)
  62. }
  63. }
  64. fn transmit(&'a mut self) -> Option<Self::TxToken> {
  65. Some(TxToken {
  66. lower: self.lower.clone(),
  67. })
  68. }
  69. }
  70. #[doc(hidden)]
  71. pub struct RxToken {
  72. buffer: Vec<u8>
  73. }
  74. impl phy::RxToken for RxToken {
  75. fn consume<R, F>(mut self, _timestamp: Instant, f: F) -> Result<R>
  76. where F: FnOnce(&mut [u8]) -> R
  77. {
  78. Ok(f(&mut self.buffer[..]))
  79. }
  80. }
  81. #[doc(hidden)]
  82. pub struct TxToken {
  83. lower: Rc<RefCell<sys::TunTapInterfaceDesc>>,
  84. }
  85. impl phy::TxToken for TxToken {
  86. fn consume<R, F>(self, _timestamp: Instant, len: usize, f: F) -> Result<R>
  87. where F: FnOnce(&mut [u8]) -> R
  88. {
  89. let mut lower = self.lower.borrow_mut();
  90. let mut buffer = vec![0; len];
  91. let result = f(&mut buffer);
  92. lower.send(&buffer[..]).unwrap();
  93. Ok(result)
  94. }
  95. }