The main goal of this project is to Implement Networking Stack on xv6 till Ethernet Layer. Networking is an important part of any OS implementation and our idea was to augment the current xv6 implementation with Networking Stack. Using the default E1000/N2K_PCI networking driver model (virtual driver provided by QEMU), we will build driver code and system calls to expose networking stack . We will showcase the output of this project, through an execution of ARP (Address Resolution Protocol) , which is basically a data frame over raw Ethernet Frame. More details are listed below.
- QEMU Virtual Network Devices: Either the E1000 default adapter provided by QEMU or the N2000 PCI network adapter.
- QEMU network backend: Either the TAP device backend or the SLiRP backend.
- Device Driver: Create the device driver for the chosen network interface adapter. The software would communicate with the device using port-mapped IO. The driver should implement DMA to copy data directly to and from the Physical memory to the network card. We'll create a simple implementation of the ring Buffers with all the memory for packet data allocated during initialization in the kernel.
- Network Stack: Only implemented till the Ethernet Layer with ARP for IPv4.
- MAC Layer: Create and parse Ethernet frames.
- ARP Protocol: Create and parse ARP packets.
- ARP system call and client: Expose the create_arp() call as a system call to test ARP through a user space client application.
- We were able to intialise and register the driver and all its resources.
- We were able to create ARP Packets and have written the code for parsing it at the receiving end as well. So, our Network stack till Arp Frame is comlpeted.
- We were able to capture the packets sent from our driver on our Linux Host through wireshark.
- Uploaded an image showing one executable demo: DEMO.png, which involves:
- Creation of two QEMU instances with each of them having their own Driver (through tap interfaces: tap0 and tap1)
- Created a linux Bridge on our Host linux machines to bridge the two tap devices.
- We showcase, ARP packet was succesfully generated and received.
- Incomplete Part: For some reason, interrupts are not being triggered by the xv6 system after receiving a new packet.
- Pradeep Kumar Beri (u1077774)
- Anmol Vatsa (u1082186)
- Vinod Reddy (u1142935)