1 / 19

CS4514-Help Session 2

CS4514-Help Session 2. ---- By Huahui Wu. Description. In this project, you are supposed to implement a PAR (Positive Acknowledgement with Retransmission) Protocol on top of an emulated physical layer (It is actually the TCP here). Network Layer. Datalink Layer. Physical Layer.

Download Presentation

CS4514-Help Session 2

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. CS4514-Help Session 2 ---- By Huahui Wu

  2. Description • In this project, you are supposed to implement a PAR (Positive Acknowledgement with Retransmission) Protocol on top of an emulated physical layer (It is actually the TCP here)

  3. Network Layer Datalink Layer Physical Layer Network Layer Datalink Layer Physical Layer Don’t put everything in one Super main() Framework Client Server Threads?

  4. PHL PHL Physical Layer Server Client 2. phl_send(…) 3. phl_recv(…) 1. phl_connect(…) TCP Connection 4. phl_close(…) NOTE:Real TCP does the actual transmission for your PHL.

  5. NWL NWL Network Layer Client Server 2. read packets from file “testdata.raw” 5. write packets to file “server.out” 3. dll_send(… pkt …) 4. dll_recv(… pkt …) 1. phl_connect(…) 6. phl_close(…)

  6. Testdata File Pkt_num the number of packets Packet_i_len the byte number of the i-th packet. Packet_i the i-th packet in raw byte form …… 2 {one byte} 38 {one byte} CS4514, computer network course, FL320 {38 bytes} 31 Worcester Polytechnic Institute

  7. EX1: Read testdata.raw #include <fcntl.h> #include <stdio.h> main(int argc, char* argv[]){ int fp, i; unsigned char packets[205]; unsigned char byteNum; unsigned char p; char if ((fp = open(argv[1], O_RDONLY)) < 0) { fprintf(stderr, "Open testData file error!"); printf("Usage: %s filename\n", argv[0]); exit(-1); }

  8. EX1: Read testdata.raw (Cont) read(fp, &p, 1); printf("The total number of packets is: %d\n\n", p); for (i = 0; i < p; i++) { read(fp, &byteNum, 1); printf("The length of %dth packet : %d\n", i+1,byteNum); read(fp, packets, byteNum); packets[byteNum] = '\0'; printf("The content of %dth packet : %s\n\n", i+1,packets); } close(fp); } //Raw file: /cs/cs4514/pub/C02_proj2/miniData.raw

  9. Client: dll_send(…Pkt…) 1.Split a packet into payloads client.log 2. Create a new frame Force some error Every 5-th Frame 3. Start a Timer phl_send(…) 4. Send the frame to PHL 5. Wait for receiving a ACK frame 6. Retransmit it if timeout !! phl_recv(…) 7. Receive a ACK frame Yes No Correct Ack Frm?

  10. Create a new frame 1. Generate the payload from the packet Datafield 2.compute sequence number and end-of-packet byte Seq EOP Datafield 3. Compute Error-Detection byte (Using XOR on Seq+EOP+Data) Seq EOP Datafield ED 4. Byte Stuffing on Seq+EOP+ED+Data Bytes after stuffing 5. Add Start-flag&End-flag SF Bytes after stuffing EF • EOP: End of Packet ED: Error Detection • SF: Start-flag EF: End-flag

  11. Creating a new Ack frame 1.Compute sequence number Seq 2. Compute Error-Detection byte by XOR (ED=Seq) Seq ED 3. Byte Stuffing on Seq+ED Bytes after stuffing 4. Add Start-flag&End-flag SF Bytes after stuffing EF

  12. Server dll_recv(…pkt…) server.log 7. If end-of-packet, return and forward the packet to the Network Layer. 6. Reassemble the packet phl_send(…) 5. Check whether it’s duplicate. If yes, drop it. Send ACK frame Force some error Every 8-th ACK Frame 4. Drop it if there’s an ED error 3. Compute ED and check it 2. Unstuffing the frame phl_recv(…) 1. Receive a frame from PHL

  13. Timer • The client can’t wait the server’s response forever. It will retransmit when timeout. • Two kinds of timer can be used in proj2 • 1. select(): Easy to use • 2. signal: need to use in proj3, maybe you want start using it now.

  14. System call: select() In this assignment, you can call select and tell the kernel to return only when: - the socket descriptor in physical layer is ready for reading, or - a preset timer timeout

  15. System call: select() # include <sys/select.h> # include <sys/time.h> int select ( int maxfdp1, fd_set *readset, fd_set *writeset, fd_set *exceptset, const struct timeval *timeout);

  16. Struct timeval struct timeval { long tv_sec; /* seconds */ long tv_usec; /* microseconds */ }

  17. EX2: how to use select() { fd_set bvfdRead; FD_SET(sockfd, &bvfdRead); int readyNo; readyNo = select(sockfd+1, struct timeval timeout; &bvfdRead, 0, 0, &timeout); int sockfd; if(readyNo < 0) //some errors error_handler; while (true) { else if(readyNo = = 0) // timeout timeout.tv_sec = 0; timeout_handler; timeout.tv_usec = 500; else // receive data from socket FD_ZERO(&bvfdRead); receive_handler; } }

  18. Time signal • Head files #include <sys/signal.h> #include <sys/time.h> #include <sys/timers.h> • Register a function to TIMEOUT signal signal (SIGALRM, timeout); • Create a timer and begin to run timer_create(); timer_settime();

  19. EX3: How to use Time Signal //set timeout to 1 second time_value.it_value.tv_sec = 1; time_value.it_value.tv_nsec = 0; time_value.it_interval.tv_sec = 0; time_value.it_interval.tv_nsec = 0; timer_settime( timer_id, 0, &time_value, NULL ); } main(){ start_timer(); for(;;); } #include <stdio.h> #include <stdlib.h> #include <sys/signal.h> #include <sys/time.h> #include <sys/timers.h> timer_t timer_id; void timeout(){ printf("\n Time out!!!!\n"); exit(0); } void start_timer(){ struct itimerspec time_value; signal (SIGALRM, timeout); timer_create( CLOCK_REALTIME, NULL, &timer_id);

More Related