Request for Comments # 210                                     W. Conrad
Categories  C.4                                                  Harvard
NIC 7189                                                    16 August 71

                      Improvement of Flow Control

The current "give back" - "return" scheme seems to put the cart before
the horse in that the "return" command indicates the amount of space
the sending host is returning rather than the amount of space it has
left after decrementing by the amount specified in the "give back"
command.  Considering the fact that allocation counters at sending and
receiving hosts may get out of synchronization and the fact that the
receiving host has a preemptive priority in the allocation of its
resources, it is only logical that the receiving host be able to find
out exactly how much of its buffer space a sending host thinks it can
claim.

If the "return" command is to accurately reflect a sending host's
current allocation, and if successive "give backs" are to produce
"return" commands which can be properly interpreted, certain race
conditions must be avoided. A "give back" must be answered by a
"return" and no more "give backs" can be issued until that "return" is
received.  In some sense, a "return" command as here proposed is
really a give back reply, and, perhaps, should implemented under that
name. On the sending side, the "return" command must not be issued as
long as a data RFNM is awaited on the link to which the "return"
refers. As soon as the net is clear of data messages, the "return" may
be sent and data transmission may continue when the RFNM for this
message containing the "return" command is received.

The current "give back" command uses fractions and has a format
different from the "allocate" and "return" commands making processing
unnecessarily complicated. By adopting the convention that allocations
can not be decremented below zero, one can safely specify absolute
decrements in a format like that of the "allocate" command. If the
receiving host's estimate of a suitable decrement is inaccurate, no
harm is done and the "return" command in response to the "give back"
provides immediate corrective information.

                                                                [Page 1]

SUMMARY

          Proposal                       Advantage

1    "Return" specifies amount       Provides more pertinent
     of space left after             information and a means
     decrementing.                   of resynchronization other
                                     than closing connection.

2    "Give Back" must get            Provide more accurate
     "return" in reply and           allocation information
     "return" must not be            by eliminating race
     sent with data on the           conditions.
     link.

3    Eliminate fractions             Eliminate messy math
     from "give back".               and provide symmetry
                                     to allocation commands
                                     making processing easier.

       [ This RFC was put into machine readable form for entry ]
        [ into the online RFC archives by Gunnar Reichert 6/97 ]

                                                                [Page 2]