200 likes | 524 Views
Reliable Transmission. Overview. Recover from Corrupt Frames Error Correction Codes (ECC); also called Forward Error Correction (FEC) Acknowledgements and Timeouts; also called Automatic Repeat reQuest (ARQ). ARQ. Send the data When acknowledged (ACK), send the next piece of data
E N D
Overview • Recover from Corrupt Frames • Error Correction Codes (ECC); also called Forward Error Correction (FEC) • Acknowledgements and Timeouts; also called Automatic Repeat reQuest (ARQ)
ARQ • Send the data • When acknowledged (ACK), send the next piece of data • Time out and resend if no acknowledgement • Resend on negative acknowledgement (NACK)
Proverbs 2:5-7 • Trust in the Lord with all thine heart; and lean not unto thine own understanding. • In all thy ways acknowledge him, and he shall direct thy paths. • Be not wise in thine own eyes: fear the Lord, and depart from evil
D&C 59:21 • And in nothing doth man offend God, or against none is his wrath kindled, save those who confess not his hand in all things, and obey not his commandments.
Alan Wilkins • Told of temple experience doing work for his grandmother • He felt the spirit strongly and felt presence of his grandmother • He then wondered if his grandmother was proud of him for his position compared to his other relatives. • The spirit left him and though he fought to rid himself of those thoughts it wouldn’t come back.
Receiver Sender Stop and Wait Frame 0 Ack0 Frame 1 Time Ack 1 Frame 0 Ack 0
Stop-and-Wait • Problem: Keeping the pipe full. • Example: 1.5Mbps link x 45ms RTT = 67.5Kb (8KB) delay*bandwidth product. • 45ms to receive Ack for a 1KB frame • BW=8192b/45ms=182Kbps= 1/8 of available bandwidth • Assuming frame size of 1KB, stop-and-wait uses about one-eighth of the link's capacity. • The sender must be able to transmit up to 8 frames before having to wait for an ACK to use the available bandwidth.
What about a window size=2KB • Example: 1.5Mbps link x 45ms RTT = 67.5Kb (8KB) delay*bandwidth product. • 45ms to receive acks for 2 1KB frames • BW=16384b/45ms=364Kbps= 1/4 of available bandwidth • Assuming frame size of 1KB, a 2KB window size uses about one-fourth of the link's capacity. • Full bandwidth with 8KB window = Delay*bandwidth.
Sliding Window • Idea: Allow sender to transmit multiple frames before receiving an ACK, thereby keeping the pipe full. • There is an upper limit on the number of outstanding (un-ACKed) frames allowed.
Sliding Window Sender Receiver . . Time
Sender: • Assign sequence number to each frame (SeqNum) • Maintain three state variables: • send window size (SWS) • last acknowledgment received (LAR) • last frame sent (LFS) • Maintain invariant: LFS - LAR + 1 <= SWS • When ACK arrives, advance LAR, thereby opening window • Buffer up to SWS frames <=SWS LAR LFS
Receiver • Maintain three state variables: • receive window size (RWS) • Largest Acceptable Frame (LAF) • Last Frame Received (LFR) • Maintain invariant: LAF - LFR <= RWS <=RWS LFR LAF
Cumulative Acks • Assume NFE=5, RWS=4, LFA=9 • Frames can arrive out of order • Assume frames 6 and 7 arrive • They cant be acked because 5 hasn’t arrived • When frame 5 arrives, all three frames will be acknowledged • Could NAK 5 to indicate it needs to be resent • Could selectively ack 6 and 7
Sequence Number Space • SeqNum field is finite; sequence numbers wrap around • Sequence number space must be larger than number of outstanding frames • SWS <= MaxSeqNum-1 is not sufficient • suppose 3-bit SeqNum field (0..7) • SWS=RWS=7 • sender transmit frames 0..6
Sequence Number • arrive successfully, but ACKs lost • sender retransmits 0..6 • receiver expecting 7,0..5, but receives second incarnation of old 0..5 • SWS < (MaxSeqNum+1)/2 is correct rule • Intuitively, SeqNum “slides” between two halves of sequence number space
0 1 2 3 0 0 1 1 2 2 3 3 Illustration WS=4, Max Sequence=3 0 0 1 1 2 2 3 3 4 4 5 5 6 6 7 7 8 8 9 9 10 10 Receiver Sender