Review of Last Lecture - PowerPoint PPT Presentation

1 / 20
About This Presentation
Title:

Review of Last Lecture

Description:

sender retransmits current pkt if ACK/NAK garbled. sender adds sequence number to each pkt ... rdt2.1: sender, handles garbled ACK/NAKs. Wait for call 0 from above ... – PowerPoint PPT presentation

Number of Views:100
Avg rating:3.0/5.0
Slides: 21
Provided by: Kur459
Category:
Tags: garbled | last | lecture | review

less

Transcript and Presenter's Notes

Title: Review of Last Lecture


1
Review of Last Lecture
  • What does UDP do?
  • What are multiplexing and demultiplexing ?
  • How does TCP and UDP differ in multiplexing and
    demultiplexing ?
  • What is connectionless service and
    connection-oriented services?
  • The size of UDP header?

2
Chapter 3 outline
  • 3.1 Transport-layer services
  • 3.2 Multiplexing and demultiplexing
  • 3.3 Connectionless transport UDP
  • 3.4 Principles of reliable data transfer
  • 3.5 Connection-oriented transport TCP
  • segment structure
  • reliable data transfer
  • flow control
  • connection management
  • 3.6 Principles of congestion control
  • 3.7 TCP congestion control

3
Principles of reliable data transfer
  • 3.4 Principles of reliable data transfer
  • Notations
  • What is reliability, what problems to deal with?
  • Reliable Data Transfer protocol (rdt) , progress
    step by step to move a basic algorithm to a more
    complicated one.
  • Rdt1.0 reliable transfer over a reliable channel
  • Rdt2.0 channel with bit errors
  • Rdt 2.1, rdt 2.2
  • rdt3.0 channels with errors and loss
  • Go-back-N

4
Principles of Reliable data transfer
  • important in app., transport, link layers
  • top-10 list of important networking topics!

5
Principles of Reliable data transfer
  • important in app., transport, link layers
  • top-10 list of important networking topics!
  • characteristics of unreliable channel will
    determine complexity of reliable data transfer
    protocol (rdt)

6
Principles of Reliable data transfer
  • important in app., transport, link layers
  • top-10 list of important networking topics!
  • characteristics of unreliable channel will
    determine complexity of reliable data transfer
    protocol (rdt)

7
Reliable data transfer getting started
send side
receive side
8
Reliable data transfer getting started
  • Well
  • incrementally develop sender, receiver sides of
    reliable data transfer protocol (rdt)
  • consider only unidirectional data transfer
  • but control info will flow on both directions!
  • use finite state machines (FSM) to specify
    sender, receiver

event causing state transition
initial state
actions taken on state transition
state when in this state next state uniquely
determined by next event
9
Rdt1.0 reliable transfer over a reliable channel
  • underlying channel perfectly reliable
  • no bit errors
  • no loss of packets
  • separate FSMs for sender, receiver
  • sender sends data into underlying channel
  • receiver read data from underlying channel

sender
receiver
10
Rdt2.0 channel with bit errors
  • underlying channel may flip bits in packet
  • recall UDP checksum to detect bit errors
  • the question how to recover from errors
  • acknowledgements (ACKs) receiver explicitly
    tells sender that pkt received OK
  • negative acknowledgements (NAKs) receiver
    explicitly tells sender that pkt had errors
  • sender retransmits pkt on receipt of NAK
  • new mechanisms in rdt2.0 (beyond rdt1.0)
  • error detection
  • receiver feedback control msgs (ACK,NAK)
    rcvr-gtsender
  • retransmission sender retransmits pkt on receipt
    of NAK

11
rdt2.0 FSM specification
rdt_send(data)
receiver
sndpkt make_pkt(data, checksum) udt_send(sndpkt)
rdt_rcv(rcvpkt) isNAK(rcvpkt)
Wait for call from above
udt_send(sndpkt)
rdt_rcv(rcvpkt) isACK(rcvpkt)
L
sender
rdt_rcv(rcvpkt) notcorrupt(rcvpkt)
extract(rcvpkt,data) deliver_data(data) udt_send(A
CK)
Also known as ARQ (Automatic Repeat reQuest)
protocols.
12
rdt2.0 operation with no errors
rdt_send(data)
sndpkt make_pkt(data, checksum) udt_send(sndpkt)
rdt_rcv(rcvpkt) isNAK(rcvpkt)
Wait for call from above
udt_send(sndpkt)
rdt_rcv(rcvpkt) isACK(rcvpkt)
Wait for call from below
L
rdt_rcv(rcvpkt) notcorrupt(rcvpkt)
extract(rcvpkt,data) deliver_data(data) udt_send(A
CK)
13
rdt2.0 error scenario
rdt_send(data)
sndpkt make_pkt(data, checksum) udt_send(sndpkt)
rdt_rcv(rcvpkt) isNAK(rcvpkt)
Wait for call from above
udt_send(sndpkt)
rdt_rcv(rcvpkt) isACK(rcvpkt)
Wait for call from below
L
rdt_rcv(rcvpkt) notcorrupt(rcvpkt)
extract(rcvpkt,data) deliver_data(data) udt_send(A
CK)
14
rdt2.0 has a fatal flaw!
  • What happens if ACK/NAK corrupted?
  • Handling duplicates
  • sender retransmits current pkt if ACK/NAK garbled
  • sender adds sequence number to each pkt
  • receiver discards (doesnt deliver to upper
    layer) duplicate pkt
  • sender doesnt know what happened at receiver!
  • ACK or NAK?
  • cant just retransmit possible duplicate
  • If ACK corrupted

15
rdt2.1 discussion
  • Sender
  • seq added to pkt
  • two seq. s (0,1) will suffice. Why?
  • must check if received ACK/NAK corrupted
  • twice as many states
  • state must remember whether current pkt has 0
    or 1 seq.
  • Receiver
  • note receiver can not know if its last ACK/NAK
    received OK at sender
  • must check if received packet is duplicate
  • state indicates whether 0 or 1 is expected pkt
    seq

16
rdt2.1 sender, handles garbled ACK/NAKs
Wait for call 0 from above
17
rdt2.1 receiver, handles garbled ACK/NAKs
18
rdt2.2 a NAK-free protocol
  • instead of NAK, receiver sends ACK for last pkt
    received OK
  • receiver must explicitly include seq of pkt
    being ACKed
  • duplicate ACK at sender results in same action as
    NAK retransmit current pkt
  • same functionality as rdt2.1, using ACKs only

19
rdt2.2 sender, receiver fragments
rdt_send(data)
sndpkt make_pkt(0, data, checksum) udt_send(sndp
kt)
rdt_rcv(rcvpkt) ( corrupt(rcvpkt)
isACK(rcvpkt,1) )
udt_send(sndpkt)
sender FSM fragment
rdt_rcv(rcvpkt) notcorrupt(rcvpkt)
isACK(rcvpkt,0)
rdt_rcv(rcvpkt) (corrupt(rcvpkt)
has_seq1(rcvpkt))
L
receiver FSM fragment
udt_send(sndpkt)
rdt_rcv(rcvpkt) notcorrupt(rcvpkt)
has_seq1(rcvpkt)
extract(rcvpkt,data) deliver_data(data) sndpkt
make_pkt(ACK1, chksum) udt_send(sndpkt)
20
rdt2.1 in action
rdt2.2 in action
receiver
Sender
receiver
Sender
State
State
State
State
pkt0
0
0
pkt0
0
0
Ack
Ack0
pkt1
1
1
pkt1
1
1
NAK
Ack0
1
pkt1
1
1
pkt1
1
Ack
Ack1
0
pkt1
1
0
1
pkt1
Ack
DUPLICATE
Ack1
DUPLICATE
pkt0
0
pkt0
0
0
0
NAK
Ack1
pkt0
0
0
pkt0
0
0
Ack
Ack 0
1
pkt1
1
1
pkt1
1
Write a Comment
User Comments (0)
About PowerShow.com