#include "network_interface.hh" #include "arp_message.hh" #include "ethernet_frame.hh" #include // Dummy implementation of a network interface // Translates from {IP datagram, next hop address} to link-layer frame, and from link-layer frame to IP datagram // For Lab 5, please replace with a real implementation that passes the // automated checks run by `make check_lab5`. // You will need to add private members to the class declaration in `network_interface.hh` template void DUMMY_CODE(Targs &&... /* unused */) {} using namespace std; //! \param[in] ethernet_address Ethernet (what ARP calls "hardware") address of the interface //! \param[in] ip_address IP (what ARP calls "protocol") address of the interface NetworkInterface::NetworkInterface(const EthernetAddress ðernet_address, const Address &ip_address) : _ethernet_address(ethernet_address), _ip_address(ip_address) { cerr << "DEBUG: Network interface has Ethernet address " << to_string(_ethernet_address) << " and IP address " << ip_address.ip() << "\n"; } //! \param[in] dgram the IPv4 datagram to be sent //! \param[in] next_hop the IP address of the interface to send it to (typically a router or default gateway, but may also be another host if directly connected to the same network as the destination) //! (Note: the Address type can be converted to a uint32_t (raw 32-bit IP address) with the Address::ipv4_numeric() method.) void NetworkInterface::send_datagram(const InternetDatagram &dgram, const Address &next_hop) { // convert IP address of next hop to raw 32-bit representation (used in ARP header) const uint32_t next_hop_ip = next_hop.ipv4_numeric(); DUMMY_CODE(dgram, next_hop, next_hop_ip); } //! \param[in] frame the incoming Ethernet frame optional NetworkInterface::recv_frame(const EthernetFrame &frame) { DUMMY_CODE(frame); return {}; } //! \param[in] ms_since_last_tick the number of milliseconds since the last call to this method void NetworkInterface::tick(const size_t ms_since_last_tick) { DUMMY_CODE(ms_since_last_tick); }