A A-to-C channel C-to-A channel Lo B B-to-C channel C-to-B channel C NAK from C received Resend last packet to C START: Call rdt send(data) to get first data from above Compute checksum Create packet to C with (data, checksum, A) Send packet to C Wait ACK SENDER A wwwww ACK from C Call rdt send(data) to get next data from above Compute checksum Create packet to C with (data, checksum, "A") Send packet to C
A protocol for interleaved deliveries from two senders.
Consider the figure below, which shows three nodes, A, B, and C. A and C are connected by a bi-directional channel; B and C are connected by a separate independent bi-directional channel. A and B can not communicate with each other.
The goal of the protocol you will design is to transfer data from A and from B in a coordinated manner to C. The protocol between sender A and receiver C (and sender B and C) operates as follows. Senders A and B each receive data from their upper layer, via a call to rdt_send(data), which returns the data to be sent, exactly the same as the rdt protocols we studied in class and in the text. Senders A and B are to reliably send their sequence of data obtained via subsequent calls from rdt_send(data) to C.
Node C should deliver to its application layer (via a call to deliver_data())a data item from A (as soon as it has correctly received that data item), followed by a data item from B (as soon as it has correctly received that data item), followed by the next data item from A, followed by the next data item from B and so on. As in rdt, a sender should NOT begin sending the next data item until it knows that receiver C has delivered the current data item it has been sending.
The A-to-C channel and the B-to-C channel can corrupt but will not lose/drop packets. The C-to-A channel and the C-to-B channels are perfect; they will neither corrupt nor lose/drop packets. (Re-read these channel assumptions; they're important!)
I’ve done some of the work for you! In particular, I’ve given the FSM for sender A (sender B has a similar FSM) below. Sender A sends a message to C and then waits for an ACK or a NAK from C. If an ACK is received it will then get another data item and send to C. If a NAK is received, the last packet will be retransmitted.
Question statement:
- 9a. Give the FSM description for the receiver C that interoperates with A and B to implement the interleaved-delivery functionality described above. You can specify your FSM events and actions for receiver C in English, similar to how the FSM for A is specified above. You only use those
mechanisms necessary in order to implement this functionality with the given channel assumptions. - 9b. In addition to your FSM, give a short explanation (e.g., a paragraph long) of how your receiver works. In particular explain how it ensure alternating delivery of messages from A and B, and passes up (via ) received data item (in the interleaved/alternating fashion) from A or B as soon as that data item has been received correctly.
data:image/s3,"s3://crabby-images/4c4ab/4c4ab0eec0b21d5afd2fcfda279e64b9728753c8" alt="A
A-to-C channel
C-to-A channel
Lo
B
B-to-C channel
C-to-B channel
C"
data:image/s3,"s3://crabby-images/668d8/668d8cf8e44ef1b577805b74d45028657e3b25a0" alt="NAK from C received
Resend last packet to C
START:
Call rdt send(data) to get first data from above
Compute checksum
Create packet to C with (data, checksum, A)
Send packet to C
Wait
ACK
SENDER A
wwwww
ACK from C
Call rdt send(data) to get next data from above
Compute checksum
Create packet to C with (data, checksum, "A")
Send packet to C"
Unlock instant AI solutions
Tap the button
to generate a solution
data:image/s3,"s3://crabby-images/60092/600925f3c879aa48326d2697cc12cbd501c16012" alt="Database System Concepts"
data:image/s3,"s3://crabby-images/b5b1d/b5b1d5cf4b4f0b9fa5f7299e517dda8c78973ae2" alt="Starting Out with Python (4th Edition)"
data:image/s3,"s3://crabby-images/861e9/861e9f01dc31d6a60742dd6c59ed7da7e28cd75d" alt="Digital Fundamentals (11th Edition)"
data:image/s3,"s3://crabby-images/60092/600925f3c879aa48326d2697cc12cbd501c16012" alt="Database System Concepts"
data:image/s3,"s3://crabby-images/b5b1d/b5b1d5cf4b4f0b9fa5f7299e517dda8c78973ae2" alt="Starting Out with Python (4th Edition)"
data:image/s3,"s3://crabby-images/861e9/861e9f01dc31d6a60742dd6c59ed7da7e28cd75d" alt="Digital Fundamentals (11th Edition)"
data:image/s3,"s3://crabby-images/134f1/134f1b748b071d72903e45f776c363a56b72169f" alt="C How to Program (8th Edition)"
data:image/s3,"s3://crabby-images/3a774/3a774d976e0979e81f9a09e78124a494a1b36d93" alt="Database Systems: Design, Implementation, & Manag…"
data:image/s3,"s3://crabby-images/307b2/307b272f255471d7f7dc31378bac8a580ae1c49c" alt="Programmable Logic Controllers"