smoltcpserver.rs 3.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. #![feature(associated_consts, type_ascription)]
  2. #[macro_use]
  3. extern crate log;
  4. extern crate env_logger;
  5. extern crate smoltcp;
  6. use std::env;
  7. use std::time::Instant;
  8. use log::{LogLevelFilter, LogRecord};
  9. use env_logger::{LogBuilder};
  10. use smoltcp::Error;
  11. use smoltcp::phy::{Tracer, TapInterface};
  12. use smoltcp::wire::{EthernetFrame, EthernetAddress, IpAddress, IpEndpoint};
  13. use smoltcp::iface::{SliceArpCache, EthernetInterface};
  14. use smoltcp::socket::AsSocket;
  15. use smoltcp::socket::{UdpSocket, UdpSocketBuffer, UdpPacketBuffer};
  16. use smoltcp::socket::{TcpSocket, TcpSocketBuffer};
  17. fn main() {
  18. let startup_time = Instant::now();
  19. LogBuilder::new()
  20. .format(move |record: &LogRecord| {
  21. let elapsed = Instant::now().duration_since(startup_time);
  22. format!("[{:6}.{:03}ms] ({}): {}",
  23. elapsed.as_secs(), elapsed.subsec_nanos() / 1000000,
  24. record.target().replace("smoltcp::", ""), record.args())
  25. })
  26. .filter(None, LogLevelFilter::Trace)
  27. .init()
  28. .unwrap();
  29. let ifname = env::args().nth(1).unwrap();
  30. let device = TapInterface::new(ifname.as_ref()).unwrap();
  31. let device = Tracer::<_, EthernetFrame<&[u8]>>::new(device);
  32. let arp_cache = SliceArpCache::new(vec![Default::default(); 8]);
  33. let endpoint = IpEndpoint::new(IpAddress::default(), 6969);
  34. let udp_rx_buffer = UdpSocketBuffer::new(vec![UdpPacketBuffer::new(vec![0; 2048])]);
  35. let udp_tx_buffer = UdpSocketBuffer::new(vec![UdpPacketBuffer::new(vec![0; 2048])]);
  36. let udp_socket = UdpSocket::new(endpoint, udp_rx_buffer, udp_tx_buffer);
  37. let tcp_rx_buffer = TcpSocketBuffer::new(vec![0; 8192]);
  38. let tcp_tx_buffer = TcpSocketBuffer::new(vec![0; 8192]);
  39. let mut tcp_socket = TcpSocket::new(tcp_rx_buffer, tcp_tx_buffer);
  40. (tcp_socket.as_socket() : &mut TcpSocket).listen(endpoint);
  41. let hardware_addr = EthernetAddress([0x02, 0x00, 0x00, 0x00, 0x00, 0x01]);
  42. let protocol_addrs = [IpAddress::v4(192, 168, 69, 1)];
  43. let sockets = vec![udp_socket, tcp_socket];
  44. let mut iface = EthernetInterface::new(device, arp_cache,
  45. hardware_addr, protocol_addrs, sockets);
  46. loop {
  47. match iface.poll() {
  48. Ok(()) => (),
  49. Err(e) => debug!("poll error: {}", e)
  50. }
  51. {
  52. let socket: &mut UdpSocket = iface.sockets()[0].as_socket();
  53. let client = match socket.recv() {
  54. Ok((endpoint, data)) => {
  55. debug!("udp recv data: {:?} from {}", data, endpoint);
  56. Some(endpoint)
  57. }
  58. Err(Error::Exhausted) => {
  59. None
  60. }
  61. Err(e) => {
  62. debug!("udp recv error: {}", e);
  63. None
  64. }
  65. };
  66. if let Some(endpoint) = client {
  67. socket.send_slice(endpoint, b"yo dawg").unwrap()
  68. }
  69. }
  70. {
  71. let socket: &mut TcpSocket = iface.sockets()[1].as_socket();
  72. let data = {
  73. let mut data = socket.recv(128).to_owned();
  74. if data.len() > 0 {
  75. debug!("tcp recv data: {:?}", &data[..]);
  76. data = data.split(|&b| b == b'\n').next().unwrap().to_owned();
  77. data.reverse();
  78. data.extend(b"\n");
  79. }
  80. data
  81. };
  82. socket.send_slice(data.as_ref());
  83. }
  84. }
  85. }